PermissionController.php 2.7 KB

1234567891011121314151617181920212223242526272829303132333435363738394041424344454647484950515253545556575859606162636465666768697071
  1. <?php
  2. namespace App\Http\Controllers\Admin;
  3. use App\Http\Controllers\Controller;
  4. use App\Http\Requests\Admin\PermissionRequest;
  5. use Exception;
  6. use Illuminate\Http\JsonResponse;
  7. use Illuminate\Http\RedirectResponse;
  8. use Illuminate\Http\Request;
  9. use Log;
  10. use Spatie\Permission\Models\Permission;
  11. class PermissionController extends Controller
  12. {
  13. public function index(Request $request)
  14. {
  15. $query = Permission::query();
  16. foreach (['name', 'description'] as $field) {
  17. $request->whenFilled($field, function ($value) use ($query, $field) {
  18. $query->where($field, 'like', "%$value%");
  19. });
  20. }
  21. return view('admin.permission.index', ['permissions' => $query->paginate(20)->appends($request->except('page'))]);
  22. }
  23. public function store(PermissionRequest $request): RedirectResponse
  24. {
  25. if ($permission = Permission::create($request->validated())) {
  26. return redirect()->route('admin.permission.edit', $permission)->with('successMsg', trans('common.success_item', ['attribute' => trans('common.add')]));
  27. }
  28. return redirect()->back()->withInput()->withErrors(trans('common.failed_item', ['attribute' => trans('common.add')]));
  29. }
  30. public function create()
  31. {
  32. return view('admin.permission.info');
  33. }
  34. public function edit(Permission $permission)
  35. {
  36. return view('admin.permission.info', compact('permission'));
  37. }
  38. public function update(PermissionRequest $request, Permission $permission): RedirectResponse
  39. {
  40. if ($permission->update($request->validated())) {
  41. return redirect()->back()->with('successMsg', trans('common.success_item', ['attribute' => trans('common.update')]));
  42. }
  43. return redirect()->back()->withInput()->withErrors(trans('common.failed_item', ['attribute' => trans('common.update')]));
  44. }
  45. public function destroy(Permission $permission): JsonResponse
  46. {
  47. try {
  48. if ($permission->delete()) {
  49. return response()->json(['status' => 'success', 'message' => trans('common.success_item', ['attribute' => trans('common.delete')])]);
  50. }
  51. } catch (Exception $e) {
  52. Log::error(trans('common.error_action_item', ['action' => trans('common.delete'), 'attribute' => trans('admin.logs.rule.title')]).': '.$e->getMessage());
  53. return response()->json(['status' => 'fail', 'message' => trans('common.failed_item', ['attribute' => trans('common.delete')]).', '.$e->getMessage()]);
  54. }
  55. return response()->json(['status' => 'fail', 'message' => trans('common.failed_item', ['attribute' => trans('common.delete')])]);
  56. }
  57. }