RoleController.php 2.7 KB

1234567891011121314151617181920212223242526272829303132333435363738394041424344454647484950515253545556575859606162636465666768697071727374757677787980818283848586
  1. <?php
  2. namespace App\Http\Controllers\Admin;
  3. use App\Http\Controllers\Controller;
  4. use Illuminate\Http\Request;
  5. use Illuminate\Http\Response;
  6. use Spatie\Permission\Models\Permission;
  7. use Spatie\Permission\Models\Role;
  8. class RoleController extends Controller
  9. {
  10. public function index()
  11. {
  12. $roles = Role::with('permissions')->paginate(15);
  13. return view('admin.role.index', compact('roles'));
  14. }
  15. public function create()
  16. {
  17. $permissions = Permission::all()->pluck('description', 'name');
  18. return view('admin.role.info', compact('permissions'));
  19. }
  20. public function store(Request $request)
  21. {
  22. $validator = validator()->make($request->all(), ['name' => 'required', 'description' => 'required']);
  23. if ($validator->fails()) {
  24. return redirect()->back()->withInput()->withErrors($validator->errors());
  25. }
  26. $role = Role::create($request->except('permissions'));
  27. $permissions = $request->input('permissions') ?: [];
  28. if ($role->givePermissionTo($permissions)) {
  29. return redirect()->route('admin.role.edit', $role)->with('successMsg', '操作成功');
  30. }
  31. return redirect()->back()->withInput()->withErrors('操作失败');
  32. }
  33. public function edit(Role $role)
  34. {
  35. $role->load('permissions');
  36. $permissions = Permission::all()->pluck('description', 'name');
  37. return view('admin.role.info', compact('role', 'permissions'));
  38. }
  39. public function update(Request $request, Role $role)
  40. {
  41. $validator = validator()->make($request->all(), ['name' => 'required', 'description' => 'required']);
  42. if ($validator->fails()) {
  43. return redirect()->back()->withInput()->withErrors($validator->errors());
  44. }
  45. if ($role->name === 'Super Admin') {
  46. return redirect()->back()->withInput()->withErrors('请勿修改超级管理员');
  47. }
  48. $role->update($request->except('permissions'));
  49. $permissions = $request->input('permissions') ?: [];
  50. if ($role->syncPermissions($permissions)) {
  51. return redirect()->back()->with('successMsg', '操作成功');
  52. }
  53. return redirect()->back()->withInput()->withErrors('操作失败');
  54. }
  55. public function destroy(Role $role)
  56. {
  57. try {
  58. if ($role->name === 'Super Admin') {
  59. return Response::json(['status' => 'fail', 'message' => '请勿删除超级管理员']);
  60. }
  61. $role->delete();
  62. } catch (Exception $e) {
  63. return Response::json(['status' => 'fail', 'message' => '删除失败,'.$e->getMessage()]);
  64. }
  65. return Response::json(['status' => 'success', 'message' => '清理成功']);
  66. }
  67. }