RoleController.php 3.1 KB

12345678910111213141516171819202122232425262728293031323334353637383940414243444546474849505152535455565758596061626364656667686970717273747576777879808182838485868788899091929394
  1. <?php
  2. namespace App\Http\Controllers;
  3. use App\Authority;
  4. use App\Components\AsyncResponse;
  5. use App\Owner;
  6. use App\Role;
  7. use App\UserWorkgroup;
  8. use Illuminate\Support\Facades\DB;
  9. use Illuminate\Support\Facades\Gate;
  10. class RoleController extends Controller
  11. {
  12. use AsyncResponse;
  13. public function index()
  14. {
  15. if (!Gate::allows('角色-查询')){return view("exception.authority"); }
  16. $roles = Role::query()->get();
  17. $authorities = app("AuthorityService")->format(Authority::query()->get());
  18. $owners = Owner::query()->whereNull("deleted_at")->get();
  19. $userWorkGroups = UserWorkgroup::query()->get();
  20. return view('maintenance.role.index',compact("roles","authorities","userWorkGroups","owners"));
  21. }
  22. /**
  23. * @throws \Exception
  24. */
  25. public function destroy()
  26. {
  27. $this->gate("角色-删除");
  28. /** @var Role $role */
  29. $role = Role::query()->find(request("id"));
  30. $role->owners()->sync([]);
  31. $role->userWorkGroups()->sync([]);
  32. $role->delete();
  33. app("RoleService")->clearUserAuthority(request("id"),true,true,true);//清除角色下所有控制信息
  34. $this->success();
  35. }
  36. public function save()
  37. {
  38. $this->gate("角色-录入");
  39. $id = request("id");
  40. $name = request("name");
  41. $role = null;
  42. if ($id)Role::query()->where("id",$id)->update(["name"=>$name]);
  43. else $role = Role::query()->create(["name"=>$name]);
  44. $this->success($role);
  45. }
  46. public function loadRelevance()
  47. {
  48. $this->gate("角色-编辑");
  49. $authorities = array_column(DB::select(DB::raw("SELECT id_authority FROM authority_role WHERE id_role = ?"),[request("id")]),"id_authority");
  50. $owners = array_column(DB::select(DB::raw("SELECT owner_id FROM owner_role WHERE role_id = ?"),[request("id")]),"owner_id");
  51. $userWorkGroups = array_column(DB::select(DB::raw("SELECT user_work_group_id FROM role_user_work_group WHERE role_id = ?"),[request("id")]),"user_work_group_id");
  52. $this->success(compact("authorities","owners","userWorkGroups"));
  53. }
  54. public function saveAuthority()
  55. {
  56. $this->gate("角色-编辑");
  57. /** @var Role|\stdClass $role */
  58. $role = new Role();
  59. $role->id = request("id");
  60. $role->authorities()->sync(request("authorities"));
  61. app("RoleService")->clearUserAuthority($role->id);
  62. $this->success();
  63. }
  64. public function saveOwner()
  65. {
  66. $this->gate("角色-编辑");
  67. /** @var Role|\stdClass $role */
  68. $role = new Role();
  69. $role->id = request("id");
  70. $role->owners()->sync(request("owners"));
  71. app("RoleService")->clearUserAuthority($role->id,false,true);
  72. $this->success();
  73. }
  74. public function saveUserWorkGroup()
  75. {
  76. $this->gate("角色-编辑");
  77. /** @var Role|\stdClass $role */
  78. $role = new Role();
  79. $role->id = request("id");
  80. $role->userWorkGroups()->sync(request("userWorkGroups"));
  81. app("RoleService")->clearUserAuthority($role->id,false,false,true);
  82. $this->success();
  83. }
  84. }