RoleController.php 3.9 KB

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