UserController.php 5.2 KB

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