mirror of
https://github.com/BookStackApp/BookStack.git
synced 2024-09-17 23:05:47 +00:00
100 lines
3.6 KiB
PHP
100 lines
3.6 KiB
PHP
<?php
|
|
|
|
use Illuminate\Database\Schema\Blueprint;
|
|
use Illuminate\Database\Migrations\Migration;
|
|
|
|
class UpdatePermissionsAndRoles extends Migration
|
|
{
|
|
/**
|
|
* Run the migrations.
|
|
*
|
|
* @return void
|
|
*/
|
|
public function up()
|
|
{
|
|
// Get roles with permissions we need to change
|
|
$adminRole = \BookStack\Role::getRole('admin');
|
|
$editorRole = \BookStack\Role::getRole('editor');
|
|
|
|
// Delete old permissions
|
|
$permissions = \BookStack\Permission::all();
|
|
$permissions->each(function ($permission) {
|
|
$permission->delete();
|
|
});
|
|
|
|
// Create & attach new admin permissions
|
|
$permissionsToCreate = [
|
|
'settings-manage' => 'Manage Settings',
|
|
'users-manage' => 'Manage Users',
|
|
'user-roles-manage' => 'Manage Roles & Permissions',
|
|
'restrictions-manage-all' => 'Manage All Entity Restrictions',
|
|
'restrictions-manage-own' => 'Manage Entity Restrictions On Own Content'
|
|
];
|
|
foreach ($permissionsToCreate as $name => $displayName) {
|
|
$newPermission = new \BookStack\Permission();
|
|
$newPermission->name = $name;
|
|
$newPermission->display_name = $displayName;
|
|
$newPermission->save();
|
|
$adminRole->attachPermission($newPermission);
|
|
}
|
|
|
|
// Create & attach new entity permissions
|
|
$entities = ['Book', 'Page', 'Chapter', 'Image'];
|
|
$ops = ['Create All', 'Create Own', 'Update All', 'Update Own', 'Delete All', 'Delete Own'];
|
|
foreach ($entities as $entity) {
|
|
foreach ($ops as $op) {
|
|
$newPermission = new \BookStack\Permission();
|
|
$newPermission->name = strtolower($entity) . '-' . strtolower(str_replace(' ', '-', $op));
|
|
$newPermission->display_name = $op . ' ' . $entity . 's';
|
|
$newPermission->save();
|
|
$adminRole->attachPermission($newPermission);
|
|
if ($editorRole !== null) $editorRole->attachPermission($newPermission);
|
|
}
|
|
}
|
|
|
|
}
|
|
|
|
/**
|
|
* Reverse the migrations.
|
|
*
|
|
* @return void
|
|
*/
|
|
public function down()
|
|
{
|
|
// Get roles with permissions we need to change
|
|
$adminRole = \BookStack\Role::getRole('admin');
|
|
|
|
// Delete old permissions
|
|
$permissions = \BookStack\Permission::all();
|
|
$permissions->each(function ($permission) {
|
|
$permission->delete();
|
|
});
|
|
|
|
// Create default CRUD permissions and allocate to admins and editors
|
|
$entities = ['Book', 'Page', 'Chapter', 'Image'];
|
|
$ops = ['Create', 'Update', 'Delete'];
|
|
foreach ($entities as $entity) {
|
|
foreach ($ops as $op) {
|
|
$newPermission = new \BookStack\Permission();
|
|
$newPermission->name = strtolower($entity) . '-' . strtolower($op);
|
|
$newPermission->display_name = $op . ' ' . $entity . 's';
|
|
$newPermission->save();
|
|
$adminRole->attachPermission($newPermission);
|
|
}
|
|
}
|
|
|
|
// Create admin permissions
|
|
$entities = ['Settings', 'User'];
|
|
$ops = ['Create', 'Update', 'Delete'];
|
|
foreach ($entities as $entity) {
|
|
foreach ($ops as $op) {
|
|
$newPermission = new \BookStack\Permission();
|
|
$newPermission->name = strtolower($entity) . '-' . strtolower($op);
|
|
$newPermission->display_name = $op . ' ' . $entity;
|
|
$newPermission->save();
|
|
$adminRole->attachPermission($newPermission);
|
|
}
|
|
}
|
|
}
|
|
}
|