id(); $table->string('name'); $table->string('code')->unique(); $table->timestamps(); $table->softDeletes(); }); DB::table('roles')->insert([ 'name' => 'Administrator', 'code' => 'admin', 'created_at' => Carbon::now(), 'updated_at' => Carbon::now() ]); Schema::create('role_user', function (Blueprint $table) { $table->unsignedBigInteger('user_id')->index(); $table->unsignedBigInteger('role_id'); $table->foreign('user_id')->references('id')->on('users'); $table->foreign('role_id')->references('id')->on('roles'); $table->primary(['user_id', 'role_id']); }); Schema::create('role_permission', function (Blueprint $table) { $table->id(); $table->unsignedBigInteger('role_id')->index(); $table->string('permission'); $table->foreign('role_id')->references('id')->on('roles'); }); } /** * Reverse the migrations. * * @return void */ public function down() { Schema::dropIfExists('role_permission'); Schema::dropIfExists('role_user'); Schema::dropIfExists('roles'); } };