LevelController.php 3.0 KB

12345678910111213141516171819202122232425262728293031323334353637383940414243444546474849505152535455565758596061626364656667686970717273747576777879808182838485868788899091929394
  1. <?php
  2. namespace App\Http\Controllers\Admin\Config;
  3. use App\Http\Controllers\Controller;
  4. use App\Models\Level;
  5. use App\Models\User;
  6. use Exception;
  7. use Illuminate\Http\JsonResponse;
  8. use Illuminate\Http\Request;
  9. use Log;
  10. use Response;
  11. use Validator;
  12. class LevelController extends Controller
  13. {
  14. // 添加等级
  15. public function store(Request $request): JsonResponse
  16. {
  17. $validator = Validator::make($request->all(), [
  18. 'level' => 'required|numeric|unique:level,level',
  19. 'level_name' => 'required',
  20. ]);
  21. if ($validator->fails()) {
  22. return Response::json(['status' => 'fail', 'message' => $validator->errors()->first()]);
  23. }
  24. $obj = new Level();
  25. $obj->level = $request->input('level');
  26. $obj->name = $request->input('level_name');
  27. $obj->save();
  28. if ($obj->id) {
  29. return Response::json(['status' => 'success', 'message' => '提交成功']);
  30. }
  31. return Response::json(['status' => 'fail', 'message' => '操作失败']);
  32. }
  33. // 编辑等级
  34. public function update(Request $request, $id): JsonResponse
  35. {
  36. $level = $request->input('level');
  37. $validator = Validator::make($request->all(), [
  38. 'level' => 'required|numeric',
  39. 'level_name' => 'required',
  40. ]);
  41. if ($validator->fails()) {
  42. return Response::json(['status' => 'fail', 'message' => $validator->errors()->first()]);
  43. }
  44. // 校验该等级下是否存在关联账号
  45. $levelCheck = Level::where('id', '<>', $id)->whereLevel($level)->exists();
  46. if ($levelCheck) {
  47. return Response::json(['status' => 'fail', 'message' => '该等级已存在!']);
  48. }
  49. // 校验该等级下是否存在关联账号
  50. $userCount = User::whereLevel($level)->count();
  51. if ($userCount) {
  52. return Response::json(['status' => 'fail', 'message' => '该等级下存在关联账号,请先取消关联!']);
  53. }
  54. Level::whereId($id)->update(['level' => $level, 'name' => $request->input('level_name')]);
  55. return Response::json(['status' => 'success', 'message' => '操作成功']);
  56. }
  57. // 删除等级
  58. public function destroy($id): JsonResponse
  59. {
  60. $level = Level::find($id);
  61. // 校验该等级下是否存在关联账号
  62. $userCount = User::whereLevel($level->level)->count();
  63. if ($userCount) {
  64. return Response::json(['status' => 'fail', 'message' => '该等级下存在关联账号,请先取消关联']);
  65. }
  66. try {
  67. if (Level::whereId($id)->delete()) {
  68. return Response::json(['status' => 'success', 'message' => '删除成功']);
  69. }
  70. } catch (Exception $e) {
  71. Log::error('删除等级时报错:'.$e->getMessage());
  72. return Response::json(['status' => 'fail', 'message' => '删除失败:'.$e->getMessage()]);
  73. }
  74. return Response::json(['status' => 'fail', 'message' => '删除失败']);
  75. }
  76. }