RoleController.php 4.4 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164
  1. <?php
  2. namespace App\Http\Controllers\API;
  3. use App\Http\Controllers\Controller;
  4. use App\Http\Requests\API\Role\CreateOrUpdateRequest;
  5. use App\Http\Resources\API\MenuResource;
  6. use App\Http\Resources\API\RoleResource;
  7. use App\Http\Resources\API\RoleSimpleResource;
  8. use App\Models\Menu;
  9. use App\Models\Role;
  10. use App\Models\User;
  11. use Illuminate\Http\Request;
  12. class RoleController extends Controller
  13. {
  14. /**
  15. * Display a listing of the resource.
  16. */
  17. public function index(Request $request)
  18. {
  19. $roles = Role::query()->filter($request->all())->get();
  20. $roles->transform(function (Role $role) {
  21. $role->display_id = $role->id;
  22. return $role;
  23. });
  24. return RoleResource::collection($roles);
  25. }
  26. /**
  27. * Display a listing of the resource.
  28. */
  29. public function publicSearch(Request $request)
  30. {
  31. $roles = Role::query()->filter($request->all())->get();
  32. return RoleSimpleResource::collection($roles);
  33. }
  34. /**
  35. * Store a newly created resource in storage.
  36. */
  37. public function store(CreateOrUpdateRequest $request)
  38. {
  39. Role::create([
  40. ...$request->only(['name', 'description']),
  41. 'guard_name' => 'api',
  42. ]);
  43. return $this->created();
  44. }
  45. /**
  46. * Display the specified resource.
  47. */
  48. public function show(string $id)
  49. {
  50. //
  51. $role=Role::query()->findOrFail($id);
  52. return new RoleResource($role);
  53. }
  54. /**
  55. * Update the specified resource in storage.
  56. */
  57. public function update(CreateOrUpdateRequest $request, string $id)
  58. {
  59. $role = Role::query()->findOrFail($id);
  60. $role->update($request->only([
  61. 'name', 'description'
  62. ]));
  63. return $this->noContent();
  64. }
  65. /**
  66. * Remove the specified resource from storage.
  67. */
  68. public function destroy(string $id)
  69. {
  70. Role::destroy($id);
  71. return $this->noContent();
  72. }
  73. public function permissions(string $id)
  74. {
  75. $role = Role::query()->findOrFail($id);
  76. return $this->success([
  77. 'data' => $role->permissions?->pluck('name'),
  78. ]);
  79. }
  80. public function assignPermissions(string $id, Request $request)
  81. {
  82. $role = Role::query()->findOrFail($id);
  83. $role->syncPermissions($request->input('permissions', []));
  84. return $this->noContent();
  85. }
  86. public function menus(string $id)
  87. {
  88. $role = Role::query()->findOrFail($id);
  89. $menus = Menu::query()->where("group", \request("group", "web"))
  90. ->get();
  91. $rolePermission=$role->permissions->pluck('name')->toArray();
  92. $flattenedPaths = [];
  93. foreach ($menus as $index=> $menu) {
  94. if(in_array($menu->permission,$rolePermission)){
  95. $individualPaths = explode(',', $menu->path);
  96. $flattenedPaths = array_merge($flattenedPaths, $individualPaths);
  97. }
  98. }
  99. $roleHasMenu=Menu::query()->whereIn('id',$flattenedPaths)->get();
  100. return MenuResource::collection($roleHasMenu);
  101. }
  102. public function assignMenusPermissions(string $id, Request $request)
  103. {
  104. $role = Role::query()->findOrFail($id);
  105. //获取菜单所有权限
  106. $menusPermission=Menu::query()->where("group", \request("group", "web"))->pluck('permission')->toArray();
  107. //通过获取用户拥有的菜单权限
  108. $roleMenusPermissions=$role->permissions->filter(function ($permission) use ($menusPermission) {
  109. return in_array($permission->name, $menusPermission);
  110. })->pluck('name')->toArray();
  111. $permissions=$request->input('permissions');
  112. // 找出需要新增的权限
  113. $extraPermissions = array_diff($permissions, $roleMenusPermissions);
  114. if(!empty($extraPermissions)&&count($extraPermissions)!=0){
  115. foreach ($extraPermissions as $extraPermission){
  116. $role->givePermissionTo($extraPermission);
  117. }
  118. }
  119. // 找出需要剔除的权限
  120. $missingPermissions = array_diff($roleMenusPermissions, $permissions);
  121. if(!empty($missingPermissions)&&count($missingPermissions)!=0){
  122. foreach ($missingPermissions as $missingPermission){
  123. $role->revokePermissionTo($missingPermission);
  124. }
  125. }
  126. return $this->noContent();
  127. }
  128. }