RoleController.php 4.2 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146
  1. <?php
  2. namespace App\Http\Controllers\Admin;
  3. use App\Http\Requests\RoleCreateRequest;
  4. use App\Http\Requests\RoleUpdateRequest;
  5. use Illuminate\Http\Request;
  6. use App\Http\Controllers\Controller;
  7. use App\Models\Role;
  8. class RoleController extends Controller
  9. {
  10. /**
  11. * Display a listing of the resource.
  12. *
  13. * @return \Illuminate\Http\Response
  14. */
  15. public function index()
  16. {
  17. return view('admin.role.index');
  18. }
  19. /**
  20. * Show the form for creating a new resource.
  21. *
  22. * @return \Illuminate\Http\Response
  23. */
  24. public function create()
  25. {
  26. return view('admin.role.create');
  27. }
  28. /**
  29. * Store a newly created resource in storage.
  30. *
  31. * @param \Illuminate\Http\Request $request
  32. * @return \Illuminate\Http\Response
  33. */
  34. public function store(RoleCreateRequest $request)
  35. {
  36. $data = $request->only(['name','display_name']);
  37. if (Role::create($data)){
  38. return redirect()->to(route('admin.role'))->with(['status'=>'添加角色成功']);
  39. }
  40. return redirect()->to(route('admin.role'))->withErrors('系统错误');
  41. }
  42. /**
  43. * Display the specified resource.
  44. *
  45. * @param int $id
  46. * @return \Illuminate\Http\Response
  47. */
  48. public function show($id)
  49. {
  50. //
  51. }
  52. /**
  53. * Show the form for editing the specified resource.
  54. *
  55. * @param int $id
  56. * @return \Illuminate\Http\Response
  57. */
  58. public function edit($id)
  59. {
  60. $role = Role::findOrFail($id);
  61. return view('admin.role.edit',compact('role'));
  62. }
  63. /**
  64. * Update the specified resource in storage.
  65. *
  66. * @param \Illuminate\Http\Request $request
  67. * @param int $id
  68. * @return \Illuminate\Http\Response
  69. */
  70. public function update(RoleUpdateRequest $request, $id)
  71. {
  72. $role = Role::findOrFail($id);
  73. $data = $request->only(['name','display_name']);
  74. if ($role->update($data)){
  75. return redirect()->to(route('admin.role'))->with(['status'=>'更新角色成功']);
  76. }
  77. return redirect()->to(route('admin.role'))->withErrors('系统错误');
  78. }
  79. /**
  80. * Remove the specified resource from storage.
  81. *
  82. * @param int $id
  83. * @return \Illuminate\Http\Response
  84. */
  85. public function destroy(Request $request)
  86. {
  87. $ids = $request->get('ids');
  88. if (empty($ids)){
  89. return response()->json(['code'=>1,'msg'=>'请选择删除项']);
  90. }
  91. if (Role::destroy($ids)){
  92. return response()->json(['code'=>0,'msg'=>'删除成功']);
  93. }
  94. return response()->json(['code'=>1,'msg'=>'删除失败']);
  95. }
  96. /**
  97. * 分配权限
  98. */
  99. public function permission(Request $request,$id)
  100. {
  101. $role = Role::findOrFail($id);
  102. $permissions = $this->tree();
  103. foreach ($permissions as $key1 => $item1){
  104. $permissions[$key1]['own'] = $role->hasPermissionTo($item1['id']) ? 'checked' : false ;
  105. if (isset($item1['_child'])){
  106. foreach ($item1['_child'] as $key2 => $item2){
  107. $permissions[$key1]['_child'][$key2]['own'] = $role->hasPermissionTo($item2['id']) ? 'checked' : false ;
  108. if (isset($item2['_child'])){
  109. foreach ($item2['_child'] as $key3 => $item3){
  110. $permissions[$key1]['_child'][$key2]['_child'][$key3]['own'] = $role->hasPermissionTo($item3['id']) ? 'checked' : false ;
  111. }
  112. }
  113. }
  114. }
  115. }
  116. return view('admin.role.permission',compact('role','permissions'));
  117. }
  118. /**
  119. * 存储权限
  120. */
  121. public function assignPermission(Request $request,$id)
  122. {
  123. $role = Role::findOrFail($id);
  124. $permissions = $request->get('permissions');
  125. if (empty($permissions)){
  126. $role->permissions()->detach();
  127. return redirect()->to(route('admin.role'))->with(['status'=>'已更新角色权限']);
  128. }
  129. $role->syncPermissions($permissions);
  130. return redirect()->to(route('admin.role'))->with(['status'=>'已更新角色权限']);
  131. }
  132. }