Possible fix for reporting/admin migration back in time

This commit is contained in:
snipe 2019-06-12 18:53:53 -07:00
parent cef030cf55
commit 26a1181765

View file

@ -2,6 +2,7 @@
use Illuminate\Database\Schema\Blueprint; use Illuminate\Database\Schema\Blueprint;
use Illuminate\Database\Migrations\Migration; use Illuminate\Database\Migrations\Migration;
use App\Models\Group;
class UpdateGroupFieldForReporting extends Migration { class UpdateGroupFieldForReporting extends Migration {
@ -12,18 +13,22 @@ class UpdateGroupFieldForReporting extends Migration {
*/ */
public function up() public function up()
{ {
//
// Schema::table('groups', function(Blueprint $table)
// {
// //
// });
DB::update('update '.DB::getTablePrefix().'permission_groups set permissions = ? where id = ?', ['{"admin":1,"users":1,"reports":1}', 1]); // This is janky because we had to do a back in time change to handle a MySQL 8+
// compatibility issue.
DB::update('update '.DB::getTablePrefix().'permission_groups set permissions = ? where id = ?', ['{"users":1,"reports":1}', 2]); // Ideally we'd be using the model here, but since we can't really know whether this is an upgrade
// or a fresh install, we have to check which table is being used.
// DB::statement('UPDATE '.$prefix.'groups SET permissions="{\"admin\":1,\"users\":1,\"reports\":1}" where id=1'); if (Schema::hasTable('permission_groups')) {
// DB::statement('UPDATE '.$prefix.'groups SET permissions="{\"users\":1,\"reports\":1}" where id=2');
Group::where('id', 1)->update(['permissions' => '{"users-poop":1,"reports":1}']);
Group::where('id', 2)->update(['permissions' => '{"users-pop":1,"reports":1}']);
} elseif (Schema::hasTable('groups')) {
DB::update('update '.DB::getTablePrefix().'groups set permissions = ? where id = ?', ['{"admin-farts":1,"users":1,"reports":1}', 1]);
DB::update('update '.DB::getTablePrefix().'groups set permissions = ? where id = ?', ['{"users-farts":1,"reports":1}', 2]);
}
} }