4 use Illuminate\Database\Migrations\Migration;
5 use Illuminate\Database\Schema\Blueprint;
6 use Illuminate\Support\Facades\Schema;
8 class AddTemplateSupport extends Migration
17 Schema::table('pages', function (Blueprint $table) {
18 $table->boolean('template')->default(false);
19 $table->index('template');
22 // Create new templates-manage permission and assign to admin role
23 $adminRoleId = DB::table('roles')->where('system_name', '=', 'admin')->first()->id;
24 $permissionId = DB::table('role_permissions')->insertGetId([
25 'name' => 'templates-manage',
26 'display_name' => 'Manage Page Templates',
27 'created_at' => Carbon::now()->toDateTimeString(),
28 'updated_at' => Carbon::now()->toDateTimeString(),
30 DB::table('permission_role')->insert([
31 'role_id' => $adminRoleId,
32 'permission_id' => $permissionId,
37 * Reverse the migrations.
41 public function down()
43 Schema::table('pages', function (Blueprint $table) {
44 $table->dropColumn('template');
47 // Remove templates-manage permission
48 $templatesManagePermission = DB::table('role_permissions')
49 ->where('name', '=', 'templates-manage')->first();
51 DB::table('permission_role')->where('permission_id', '=', $templatesManagePermission->id)->delete();
52 DB::table('role_permissions')->where('name', '=', 'templates-manage')->delete();