2020-01-06 17:52:46 +03:00

207 lines
7.6 KiB
PHP

<?php
namespace Database\Seeds;
use App\Abstracts\Model;
use App\Models\Auth\Role;
use App\Models\Auth\Permission;
use Illuminate\Database\Seeder;
class Roles extends Seeder
{
/**
* Run the database seeds.
*
* @return void
*/
public function run()
{
Model::unguard();
$this->create($this->roles(), $this->map());
Model::reguard();
}
private function roles()
{
$rows = [
'admin' => [
'admin-panel' => 'r',
'api' => 'r',
'auth-permissions' => 'c,r,u,d',
'auth-profile' => 'r,u',
'auth-roles' => 'c,r,u,d',
'auth-users' => 'c,r,u,d',
'banking-accounts' => 'c,r,u,d',
'banking-reconciliations' => 'c,r,u,d',
'banking-transactions' => 'c,r,u,d',
'banking-transfers' => 'c,r,u,d',
'common-companies' => 'c,r,u,d',
'common-import' => 'c',
'common-items' => 'c,r,u,d',
'common-notifications' => 'c,r,u,d',
'common-reports' => 'c,r,u,d',
'common-search' => 'r',
'common-uploads' => 'r,d',
'common-widgets' => 'c,r,u,d',
'purchases-bills' => 'c,r,u,d',
'purchases-payments' => 'c,r,u,d',
'purchases-vendors' => 'c,r,u,d',
'sales-customers' => 'c,r,u,d',
'sales-invoices' => 'c,r,u,d',
'sales-revenues' => 'c,r,u,d',
'install-updates' => 'r,u',
'modules-api-key' => 'c,u',
'modules-home' => 'r',
'modules-item' => 'c,r,u,d',
'modules-my' => 'r',
'modules-tiles' => 'r',
'notifications' => 'r,u',
'offline-payments-settings' => 'r,u,d',
'reports-expense-summary' => 'r',
'reports-income-summary' => 'r',
'reports-income-expense-summary' => 'r',
'reports-profit-loss' => 'r',
'reports-tax-summary' => 'r',
'settings-appearance' => 'r,u',
'settings-categories' => 'c,r,u,d',
'settings-company' => 'r',
'settings-currencies' => 'c,r,u,d',
'settings-defaults' => 'r',
'settings-email' => 'r',
'settings-invoice' => 'r',
'settings-localisation' => 'r',
'settings-modules' => 'r,u',
'settings-settings' => 'r,u',
'settings-schedule' => 'r',
'settings-taxes' => 'c,r,u,d',
'widgets-account-balance' => 'r',
'widgets-cash-flow' => 'r',
'widgets-expenses-by-category' => 'r',
'widgets-income-by-category' => 'r',
'widgets-latest-expenses' => 'r',
'widgets-latest-income' => 'r',
'widgets-total-expenses' => 'r',
'widgets-total-income' => 'r',
'widgets-total-profit' => 'r',
'wizard-companies' => 'c,r,u',
'wizard-currencies' => 'c,r,u,d',
'wizard-finish' => 'c,r,u',
'wizard-taxes' => 'c,r,u',
],
'manager' => [
'admin-panel' => 'r',
'auth-profile' => 'r,u',
'banking-accounts' => 'c,r,u,d',
'banking-reconciliations' => 'c,r,u,d',
'banking-transactions' => 'c,r,u,d',
'banking-transfers' => 'c,r,u,d',
'common-companies' => 'c,r,u,d',
'common-import' => 'c',
'common-items' => 'c,r,u,d',
'common-notifications' => 'c,r,u,d',
'common-reports' => 'c,r,u,d',
'common-search' => 'r',
'common-uploads' => 'r',
'common-widgets' => 'r',
'purchases-bills' => 'c,r,u,d',
'purchases-payments' => 'c,r,u,d',
'purchases-vendors' => 'c,r,u,d',
'sales-customers' => 'c,r,u,d',
'sales-invoices' => 'c,r,u,d',
'sales-revenues' => 'c,r,u,d',
'install-updates' => 'r,u',
'notifications' => 'r,u',
'offline-payments-settings' => 'r,u,d',
'reports-expense-summary' => 'r',
'reports-income-summary' => 'r',
'reports-income-expense-summary' => 'r',
'reports-profit-loss' => 'r',
'reports-tax-summary' => 'r',
'settings-categories' => 'c,r,u,d',
'settings-company' => 'r',
'settings-currencies' => 'c,r,u,d',
'settings-defaults' => 'r',
'settings-email' => 'r',
'settings-invoice' => 'r',
'settings-localisation' => 'r',
'settings-modules' => 'r,u',
'settings-settings' => 'r,u',
'settings-schedule' => 'r',
'settings-taxes' => 'c,r,u,d',
'widgets-account-balance' => 'r',
'widgets-cash-flow' => 'r',
'widgets-expenses-by-category' => 'r',
'widgets-income-by-category' => 'r',
'widgets-latest-expenses' => 'r',
'widgets-latest-income' => 'r',
'widgets-total-expenses' => 'r',
'widgets-total-income' => 'r',
'widgets-total-profit' => 'r',
],
'customer' => [
'client-portal' => 'r',
'portal-invoices' => 'r,u',
'portal-payments' => 'r,u',
'portal-profile' => 'r,u',
]
];
return $rows;
}
private function map()
{
$rows = [
'c' => 'create',
'r' => 'read',
'u' => 'update',
'd' => 'delete'
];
return $rows;
}
private function create($roles, $map)
{
$mapPermission = collect($map);
foreach ($roles as $key => $modules) {
// Create a new role
$role = Role::create([
'name' => $key,
'display_name' => ucwords(str_replace("_", " ", $key)),
'description' => ucwords(str_replace("_", " ", $key))
]);
$this->command->info('Creating Role ' . strtoupper($key));
// Reading role permission modules
foreach ($modules as $module => $value) {
$permissions = explode(',', $value);
foreach ($permissions as $p => $perm) {
$permissionValue = $mapPermission->get($perm);
$moduleName = ucwords(str_replace("-", " ", $module));
$permission = Permission::firstOrCreate([
'name' => $permissionValue . '-' . $module,
'display_name' => ucfirst($permissionValue) . ' ' . $moduleName,
'description' => ucfirst($permissionValue) . ' ' . $moduleName
]);
$this->command->info('Creating Permission to ' . $permissionValue . ' for ' . $moduleName);
if (! $role->hasPermission($permission->name)) {
$role->attachPermission($permission);
} else {
$this->command->info($key . ': ' . $p . ' ' . $permissionValue . ' already exist');
}
}
}
}
}
}