erp/app/Http/Controllers/Permission/PermissionsController.php

87 lines
2.8 KiB
PHP
Raw Normal View History

<?php
namespace App\Http\Controllers\Permission;
use App\Http\Controllers\Controller;
2022-08-01 17:06:43 +08:00
use App\Models\Log as LogModel;
2022-08-04 18:13:00 +08:00
use App\Utils\ArrayUtils;
use App\Utils\FormatUtils;
use Spatie\Permission\Models\Permission;
use Illuminate\Http\Request;
use Illuminate\Support\Facades\Validator;
use Illuminate\Validation\Rule;
use App\Http\Resources\PermissionsResource;
class PermissionsController extends Controller
{
2022-08-01 17:06:43 +08:00
public function __construct(Request $request)
{
$this->log = new LogModel([
'module' => 'permission',
'action' => $request->getMethod(),
'target_type' => 'permission',
]);
}
2022-08-15 16:15:00 +08:00
public function index(Request $request)
{
2022-08-15 16:15:00 +08:00
$permissions = $request->user()->getPermissionsViaRoles()->toArray();
2022-08-04 18:13:00 +08:00
$permissions = ArrayUtils::index($permissions, 'name');
$routes = include(resource_path('lang/zh-CN/permission.php'));
2022-08-15 16:15:00 +08:00
$allowedPermissions = [];
foreach ($routes as $route => $conf) {
if (isset($permissions[$route])) {
$conf['id'] = $permissions[$route]['id'];
$allowedPermissions[] = $conf;
}
2022-08-04 18:13:00 +08:00
}
2022-08-15 16:15:00 +08:00
$allowedPermissions = FormatUtils::formatTreeData($allowedPermissions, 0);
2022-08-15 16:15:00 +08:00
return PermissionsResource::collection($allowedPermissions);
}
public function store(Request $request)
{
$validator = Validator::make($request->all(), [
2022-08-09 16:56:52 +08:00
'name' => 'required|string|max:191|unique:permissions,name',
]);
if ($validator->fails()) {
$this->setValidatorFailResponse($validator->getMessageBag()->getMessages());
return response($this->res, $this->res['httpCode']);
}
$permission = new Permission();
$permission->name = $request->name;
$permission->save();
2023-04-17 18:56:59 +08:00
$this->setAfterUpdateForLog($permission->name);
2022-08-01 17:19:36 +08:00
$this->addLog($permission->id, 'add');
return response($this->res, $this->res['httpCode']);
}
public function show($id)
{
return new PermissionsResource(Permission::query()->find($id));
}
public function update($id, Request $request)
{
$validator = Validator::make($request->all(), [
2022-08-09 16:56:52 +08:00
'name' => ['required', 'string', 'max:191', Rule::unique('permissions')->ignore($id),]
]);
if ($validator->fails()) {
$this->setValidatorFailResponse($validator->getMessageBag()->getMessages());
return response($this->res, $this->res['httpCode']);
}
$permission = Permission::query()->find($id);
2023-04-17 18:56:59 +08:00
$this->setBeforeUpdateForLog($permission->name);
$permission->name = $request->name;
$permission->save();
2023-04-17 18:56:59 +08:00
$this->setAfterUpdateForLog($permission->name);
2022-08-01 17:06:43 +08:00
$this->addLog($id, 'name');
return new PermissionsResource($permission);
}
}