5 changed files with 303 additions and 2 deletions
-
3composer.json
-
70composer.lock
-
1config/app.php
-
129config/permission.php
-
102database/migrations/2019_10_06_111735_create_permission_tables.php
@ -0,0 +1,129 @@ |
|||||
|
<?php |
||||
|
|
||||
|
return [ |
||||
|
|
||||
|
'models' => [ |
||||
|
|
||||
|
/* |
||||
|
* When using the "HasPermissions" trait from this package, we need to know which |
||||
|
* Eloquent model should be used to retrieve your permissions. Of course, it |
||||
|
* is often just the "Permission" model but you may use whatever you like. |
||||
|
* |
||||
|
* The model you want to use as a Permission model needs to implement the |
||||
|
* `Spatie\Permission\Contracts\Permission` contract. |
||||
|
*/ |
||||
|
|
||||
|
'permission' => Spatie\Permission\Models\Permission::class, |
||||
|
|
||||
|
/* |
||||
|
* When using the "HasRoles" trait from this package, we need to know which |
||||
|
* Eloquent model should be used to retrieve your roles. Of course, it |
||||
|
* is often just the "Role" model but you may use whatever you like. |
||||
|
* |
||||
|
* The model you want to use as a Role model needs to implement the |
||||
|
* `Spatie\Permission\Contracts\Role` contract. |
||||
|
*/ |
||||
|
|
||||
|
'role' => Spatie\Permission\Models\Role::class, |
||||
|
|
||||
|
], |
||||
|
|
||||
|
'table_names' => [ |
||||
|
|
||||
|
/* |
||||
|
* When using the "HasRoles" trait from this package, we need to know which |
||||
|
* table should be used to retrieve your roles. We have chosen a basic |
||||
|
* default value but you may easily change it to any table you like. |
||||
|
*/ |
||||
|
|
||||
|
'roles' => 'roles', |
||||
|
|
||||
|
/* |
||||
|
* When using the "HasPermissions" trait from this package, we need to know which |
||||
|
* table should be used to retrieve your permissions. We have chosen a basic |
||||
|
* default value but you may easily change it to any table you like. |
||||
|
*/ |
||||
|
|
||||
|
'permissions' => 'permissions', |
||||
|
|
||||
|
/* |
||||
|
* When using the "HasPermissions" trait from this package, we need to know which |
||||
|
* table should be used to retrieve your models permissions. We have chosen a |
||||
|
* basic default value but you may easily change it to any table you like. |
||||
|
*/ |
||||
|
|
||||
|
'model_has_permissions' => 'model_has_permissions', |
||||
|
|
||||
|
/* |
||||
|
* When using the "HasRoles" trait from this package, we need to know which |
||||
|
* table should be used to retrieve your models roles. We have chosen a |
||||
|
* basic default value but you may easily change it to any table you like. |
||||
|
*/ |
||||
|
|
||||
|
'model_has_roles' => 'model_has_roles', |
||||
|
|
||||
|
/* |
||||
|
* When using the "HasRoles" trait from this package, we need to know which |
||||
|
* table should be used to retrieve your roles permissions. We have chosen a |
||||
|
* basic default value but you may easily change it to any table you like. |
||||
|
*/ |
||||
|
|
||||
|
'role_has_permissions' => 'role_has_permissions', |
||||
|
], |
||||
|
|
||||
|
'column_names' => [ |
||||
|
|
||||
|
/* |
||||
|
* Change this if you want to name the related model primary key other than |
||||
|
* `model_id`. |
||||
|
* |
||||
|
* For example, this would be nice if your primary keys are all UUIDs. In |
||||
|
* that case, name this `model_uuid`. |
||||
|
*/ |
||||
|
|
||||
|
'model_morph_key' => 'model_id', |
||||
|
], |
||||
|
|
||||
|
/* |
||||
|
* When set to true, the required permission/role names are added to the exception |
||||
|
* message. This could be considered an information leak in some contexts, so |
||||
|
* the default setting is false here for optimum safety. |
||||
|
*/ |
||||
|
|
||||
|
'display_permission_in_exception' => false, |
||||
|
|
||||
|
'cache' => [ |
||||
|
|
||||
|
/* |
||||
|
* By default all permissions are cached for 24 hours to speed up performance. |
||||
|
* When permissions or roles are updated the cache is flushed automatically. |
||||
|
*/ |
||||
|
|
||||
|
'expiration_time' => \DateInterval::createFromDateString('24 hours'), |
||||
|
|
||||
|
/* |
||||
|
* The cache key used to store all permissions. |
||||
|
*/ |
||||
|
|
||||
|
'key' => 'spatie.permission.cache', |
||||
|
|
||||
|
/* |
||||
|
* When checking for a permission against a model by passing a Permission |
||||
|
* instance to the check, this key determines what attribute on the |
||||
|
* Permissions model is used to cache against. |
||||
|
* |
||||
|
* Ideally, this should match your preferred way of checking permissions, eg: |
||||
|
* `$user->can('view-posts')` would be 'name'. |
||||
|
*/ |
||||
|
|
||||
|
'model_key' => 'name', |
||||
|
|
||||
|
/* |
||||
|
* You may optionally indicate a specific cache driver to use for permission and |
||||
|
* role caching using any of the `store` drivers listed in the cache.php config |
||||
|
* file. Using 'default' here means to use the `default` set in cache.php. |
||||
|
*/ |
||||
|
|
||||
|
'store' => 'default', |
||||
|
], |
||||
|
]; |
||||
@ -0,0 +1,102 @@ |
|||||
|
<?php |
||||
|
|
||||
|
use Illuminate\Support\Facades\Schema; |
||||
|
use Illuminate\Database\Schema\Blueprint; |
||||
|
use Illuminate\Database\Migrations\Migration; |
||||
|
|
||||
|
class CreatePermissionTables extends Migration |
||||
|
{ |
||||
|
/** |
||||
|
* Run the migrations. |
||||
|
* |
||||
|
* @return void |
||||
|
*/ |
||||
|
public function up() |
||||
|
{ |
||||
|
$tableNames = config('permission.table_names'); |
||||
|
$columnNames = config('permission.column_names'); |
||||
|
|
||||
|
Schema::create($tableNames['permissions'], function (Blueprint $table) { |
||||
|
$table->increments('id'); |
||||
|
$table->string('name'); |
||||
|
$table->string('guard_name'); |
||||
|
$table->timestamps(); |
||||
|
}); |
||||
|
|
||||
|
Schema::create($tableNames['roles'], function (Blueprint $table) { |
||||
|
$table->increments('id'); |
||||
|
$table->string('name'); |
||||
|
$table->string('guard_name'); |
||||
|
$table->timestamps(); |
||||
|
}); |
||||
|
|
||||
|
Schema::create($tableNames['model_has_permissions'], function (Blueprint $table) use ($tableNames, $columnNames) { |
||||
|
$table->unsignedInteger('permission_id'); |
||||
|
|
||||
|
$table->string('model_type'); |
||||
|
$table->unsignedBigInteger($columnNames['model_morph_key']); |
||||
|
$table->index([$columnNames['model_morph_key'], 'model_type', ], 'model_has_permissions_model_id_model_type_index'); |
||||
|
|
||||
|
$table->foreign('permission_id') |
||||
|
->references('id') |
||||
|
->on($tableNames['permissions']) |
||||
|
->onDelete('cascade'); |
||||
|
|
||||
|
$table->primary(['permission_id', $columnNames['model_morph_key'], 'model_type'], |
||||
|
'model_has_permissions_permission_model_type_primary'); |
||||
|
}); |
||||
|
|
||||
|
Schema::create($tableNames['model_has_roles'], function (Blueprint $table) use ($tableNames, $columnNames) { |
||||
|
$table->unsignedInteger('role_id'); |
||||
|
|
||||
|
$table->string('model_type'); |
||||
|
$table->unsignedBigInteger($columnNames['model_morph_key']); |
||||
|
$table->index([$columnNames['model_morph_key'], 'model_type', ], 'model_has_roles_model_id_model_type_index'); |
||||
|
|
||||
|
$table->foreign('role_id') |
||||
|
->references('id') |
||||
|
->on($tableNames['roles']) |
||||
|
->onDelete('cascade'); |
||||
|
|
||||
|
$table->primary(['role_id', $columnNames['model_morph_key'], 'model_type'], |
||||
|
'model_has_roles_role_model_type_primary'); |
||||
|
}); |
||||
|
|
||||
|
Schema::create($tableNames['role_has_permissions'], function (Blueprint $table) use ($tableNames) { |
||||
|
$table->unsignedInteger('permission_id'); |
||||
|
$table->unsignedInteger('role_id'); |
||||
|
|
||||
|
$table->foreign('permission_id') |
||||
|
->references('id') |
||||
|
->on($tableNames['permissions']) |
||||
|
->onDelete('cascade'); |
||||
|
|
||||
|
$table->foreign('role_id') |
||||
|
->references('id') |
||||
|
->on($tableNames['roles']) |
||||
|
->onDelete('cascade'); |
||||
|
|
||||
|
$table->primary(['permission_id', 'role_id'], 'role_has_permissions_permission_id_role_id_primary'); |
||||
|
}); |
||||
|
|
||||
|
app('cache') |
||||
|
->store(config('permission.cache.store') != 'default' ? config('permission.cache.store') : null) |
||||
|
->forget(config('permission.cache.key')); |
||||
|
} |
||||
|
|
||||
|
/** |
||||
|
* Reverse the migrations. |
||||
|
* |
||||
|
* @return void |
||||
|
*/ |
||||
|
public function down() |
||||
|
{ |
||||
|
$tableNames = config('permission.table_names'); |
||||
|
|
||||
|
Schema::drop($tableNames['role_has_permissions']); |
||||
|
Schema::drop($tableNames['model_has_roles']); |
||||
|
Schema::drop($tableNames['model_has_permissions']); |
||||
|
Schema::drop($tableNames['roles']); |
||||
|
Schema::drop($tableNames['permissions']); |
||||
|
} |
||||
|
} |
||||
Write
Preview
Loading…
Cancel
Save
Reference in new issue