SsConfigController.php 1.8 KB

1234567891011121314151617181920212223242526272829303132333435363738394041424344454647484950515253545556575859606162
  1. <?php
  2. namespace App\Http\Controllers\Admin\Config;
  3. use App\Http\Controllers\Controller;
  4. use App\Models\SsConfig;
  5. use Exception;
  6. use Illuminate\Http\JsonResponse;
  7. use Illuminate\Http\Request;
  8. use Log;
  9. use Response;
  10. use Validator;
  11. class SsConfigController extends Controller
  12. {
  13. // 添加SS配置
  14. public function store(Request $request): JsonResponse
  15. {
  16. $validator = Validator::make($request->all(), [
  17. 'name' => 'required|string|unique:ss_config,name',
  18. 'type' => 'required|numeric|between:1,3',
  19. ]);
  20. if ($validator->fails()) {
  21. return Response::json(['status' => 'fail', 'message' => $validator->errors()->all()]);
  22. }
  23. if (SsConfig::create($validator->validated())) {
  24. return Response::json(['status' => 'success', 'message' => '添加成功']);
  25. }
  26. return Response::json(['status' => 'fail', 'message' => '添加失败']);
  27. }
  28. // 设置SS默认配置
  29. public function update(SsConfig $ss): JsonResponse
  30. {
  31. // 去除该配置所属类型的默认值
  32. SsConfig::default()->type($ss->type)->update(['is_default' => 0]);
  33. // 将该ID对应记录值置为默认值
  34. $ss->update(['is_default' => 1]);
  35. return Response::json(['status' => 'success', 'message' => '操作成功']);
  36. }
  37. // 删除SS配置
  38. public function destroy(SsConfig $ss): JsonResponse
  39. {
  40. try {
  41. if ($ss->delete()) {
  42. return Response::json(['status' => 'success', 'message' => '删除成功']);
  43. }
  44. } catch (Exception $e) {
  45. Log::error('删除SS配置时失败:'.$e->getMessage());
  46. return Response::json(['status' => 'fail', 'message' => '删除失败:'.$e->getMessage()]);
  47. }
  48. return Response::json(['status' => 'fail', 'message' => '删除失败']);
  49. }
  50. }