PermissionController.php 1.9 KB

12345678910111213141516171819202122232425262728293031323334353637383940414243444546474849505152535455565758596061626364
  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\Request;
  7. use Spatie\Permission\Models\Permission;
  8. class PermissionController extends Controller
  9. {
  10. public function index(Request $request)
  11. {
  12. $query = Permission::query();
  13. foreach (['name', 'description'] as $field) {
  14. $request->whenFilled($field, function ($value) use ($query, $field) {
  15. $query->where($field, 'like', "%{$value}%");
  16. });
  17. }
  18. return view('admin.permission.index', ['permissions' => $query->paginate(20)->appends($request->except('page'))]);
  19. }
  20. public function create()
  21. {
  22. return view('admin.permission.info');
  23. }
  24. public function store(PermissionRequest $request)
  25. {
  26. if ($permission = Permission::create($request->validated())) {
  27. return redirect()->route('admin.permission.edit', $permission)->with('successMsg', '操作成功');
  28. }
  29. return redirect()->back()->withInput()->withErrors('操作失败');
  30. }
  31. public function edit(Permission $permission)
  32. {
  33. return view('admin.permission.info', compact('permission'));
  34. }
  35. public function update(PermissionRequest $request, Permission $permission)
  36. {
  37. if ($permission->update($request->validated())) {
  38. return redirect()->back()->with('successMsg', '操作成功');
  39. }
  40. return redirect()->back()->withInput()->withErrors('操作失败');
  41. }
  42. public function destroy(Permission $permission)
  43. {
  44. try {
  45. $permission->delete();
  46. } catch (Exception $e) {
  47. return response()->json(['status' => 'fail', 'message' => '删除失败,'.$e->getMessage()]);
  48. }
  49. return response()->json(['status' => 'success', 'message' => '清理成功']);
  50. }
  51. }