RoleController.php 2.4 KB

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