erp/app/Http/Controllers/Role/RolesController.php

95 lines
2.8 KiB
PHP
Raw Normal View History

<?php
namespace App\Http\Controllers\Role;
use App\Http\Controllers\Controller;
2022-08-01 17:06:43 +08:00
use App\Models\Log as LogModel;
use Illuminate\Http\Request;
use Illuminate\Support\Facades\Validator;
use Illuminate\Validation\Rule;
2022-08-01 05:07:38 +08:00
use Spatie\Permission\Models\Permission;
use Spatie\Permission\Models\Role;
use App\Http\Resources\RolesResource;
class RolesController extends Controller
{
2022-08-01 17:06:43 +08:00
public function __construct(Request $request)
{
$this->log = new LogModel([
'module' => 'role',
'action' => $request->getMethod(),
'target_type' => 'role',
]);
}
public function index()
{
$roles = Role::query()->with('permissions')->get()->toArray();
$routes = include(resource_path('lang/zh-CN/permission.php'));
foreach ($roles as &$role) {
$permissions = [];
foreach ($role['permissions'] as $item) {
$permissions[] = $routes[$item['name']]['name'];
}
$role['permissions'] = $permissions;
}
return RolesResource::collection($roles);
}
public function store(Request $request)
{
$validator = Validator::make($request->all(), [
'name' => 'required|string|max:255|unique:roles,name',
]);
if ($validator->fails()) {
$this->setValidatorFailResponse($validator->getMessageBag()->getMessages());
return response($this->res, $this->res['httpCode']);
}
$role = new Role();
$role->name = $request->name;
$role->save();
2022-08-01 17:06:43 +08:00
$this->setAfterUpdate($role->name);
$this->addLog($role->id, 'add');
2022-08-02 18:20:06 +08:00
return new RolesResource($role);
}
2022-08-01 05:07:38 +08:00
public function addPermissions($id, Request $request)
{
$role = Role::query()->findOrFail($id);
$permissions = Permission::query()->findOrFail($request->permissionIds);
$role->syncPermissions($permissions);
2022-08-01 17:06:43 +08:00
$this->setAfterUpdate($permissions->toArray());
$this->addLog($id, 'set', 'permission');
2022-08-01 05:07:38 +08:00
return response($this->res, $this->res['httpCode']);
}
public function show($id)
{
return new RolesResource(Role::query()->find($id));
}
public function update($id, Request $request)
{
$validator = Validator::make($request->all(), [
'name' => ['required', 'string', 'max:255', Rule::unique('roles')->ignore($id),]
]);
if ($validator->fails()) {
$this->setValidatorFailResponse($validator->getMessageBag()->getMessages());
return response($this->res, $this->res['httpCode']);
}
$role = Role::query()->find($id);
2022-08-01 17:06:43 +08:00
$this->setBeforeUpdate($role->name);
$role->name = $request->name;
$role->save();
2022-08-01 17:06:43 +08:00
$this->setAfterUpdate($role->name);
$this->addLog($id, 'name');
return new RolesResource($role);
}
}