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