RoleController.php 2.8 KB

12345678910111213141516171819202122232425262728293031323334353637383940414243444546474849505152535455565758596061626364656667686970717273747576
  1. <?php
  2. namespace App\Http\Controllers\Admin;
  3. use App\Http\Controllers\Controller;
  4. use App\Http\Requests\Admin\RoleRequest;
  5. use Exception;
  6. use Illuminate\Contracts\View\View;
  7. use Illuminate\Http\JsonResponse;
  8. use Illuminate\Http\RedirectResponse;
  9. use Log;
  10. use Spatie\Permission\Models\Permission;
  11. use Spatie\Permission\Models\Role;
  12. class RoleController extends Controller
  13. {
  14. public function index(): View
  15. {
  16. return view('admin.role.index', ['roles' => Role::with('permissions')->paginate(15)]);
  17. }
  18. public function store(RoleRequest $request): RedirectResponse
  19. {
  20. if ($role = Role::create($request->only(['name', 'description']))) {
  21. $role->givePermissionTo($request->input('permissions') ?? []);
  22. return redirect()->route('admin.role.edit', $role)->with('successMsg', trans('common.success_item', ['attribute' => trans('common.add')]));
  23. }
  24. return redirect()->back()->withInput()->withErrors(trans('common.failed_item', ['attribute' => trans('common.add')]));
  25. }
  26. public function create(): View
  27. {
  28. return view('admin.role.info', ['permissions' => Permission::all()->pluck('description', 'name')]);
  29. }
  30. public function edit(Role $role): View
  31. {
  32. return view('admin.role.info', [
  33. 'role' => $role->load('permissions'),
  34. 'permissions' => Permission::all()->pluck('description', 'name'),
  35. ]);
  36. }
  37. public function update(RoleRequest $request, Role $role): RedirectResponse
  38. {
  39. if ($role->name === 'Super Admin') {
  40. return redirect()->back()->withInput()->withErrors(trans('admin.role.modify_admin_error'));
  41. }
  42. if ($role->update($request->only(['name', 'description']))) {
  43. $role->syncPermissions($request->input('permissions') ?: []);
  44. return redirect()->back()->with('successMsg', trans('common.success_item', ['attribute' => trans('common.edit')]));
  45. }
  46. return redirect()->back()->withInput()->withErrors(trans('common.failed_item', ['attribute' => trans('common.edit')]));
  47. }
  48. public function destroy(Role $role): JsonResponse
  49. {
  50. try {
  51. if ($role->name === 'Super Admin') {
  52. return response()->json(['status' => 'fail', 'message' => trans('admin.role.modify_admin_error')]);
  53. }
  54. $role->delete();
  55. } catch (Exception $e) {
  56. Log::error(trans('common.error_action_item', ['action' => trans('common.delete'), 'attribute' => trans('model.role.attribute')]).': '.$e->getMessage());
  57. return response()->json(['status' => 'fail', 'message' => trans('common.failed_item', ['attribute' => trans('common.delete')]).', '.$e->getMessage()]);
  58. }
  59. return response()->json(['status' => 'success', 'message' => trans('common.success_item', ['attribute' => trans('common.delete')])]);
  60. }
  61. }