PermissionController.php 2.7 KB

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