SettingController.php 2.8 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113
  1. <?php
  2. namespace App\Api\v1\Controllers;
  3. use App\Api\v1\Requests\SettingStoreRequest;
  4. use App\Api\v1\Requests\SettingUpdateRequest;
  5. use App\Facades\Settings;
  6. use App\Http\Controllers\Controller;
  7. class SettingController extends Controller
  8. {
  9. /**
  10. * List all settings
  11. *
  12. * @return \Illuminate\Http\JsonResponse
  13. */
  14. public function index()
  15. {
  16. $settings = Settings::all();
  17. $settingsResources = collect([]);
  18. $settings->each(function (mixed $item, string $key) use ($settingsResources) {
  19. $settingsResources->push([
  20. 'key' => $key,
  21. 'value' => $item,
  22. ]);
  23. });
  24. return response()->json($settingsResources->all(), 200);
  25. }
  26. /**
  27. * Display a setting
  28. *
  29. * @param string $settingName
  30. * @return \Illuminate\Http\JsonResponse
  31. */
  32. public function show($settingName)
  33. {
  34. $setting = Settings::get($settingName);
  35. if (is_null($setting)) {
  36. abort(404);
  37. }
  38. return response()->json([
  39. 'key' => $settingName,
  40. 'value' => $setting,
  41. ], 200);
  42. }
  43. /**
  44. * Store a setting
  45. *
  46. * @param \App\Api\v1\Requests\SettingStoreRequest $request
  47. * @return \Illuminate\Http\JsonResponse
  48. */
  49. public function store(SettingStoreRequest $request)
  50. {
  51. $validated = $request->validated();
  52. Settings::set($validated['key'], $validated['value']);
  53. return response()->json([
  54. 'key' => $validated['key'],
  55. 'value' => $validated['value'],
  56. ], 201);
  57. }
  58. /**
  59. * Update a setting
  60. *
  61. * @param \App\Api\v1\Requests\SettingUpdateRequest $request
  62. * @return \Illuminate\Http\JsonResponse
  63. */
  64. public function update(SettingUpdateRequest $request, string $settingName)
  65. {
  66. $validated = $request->validated();
  67. Settings::set($settingName, $validated['value']);
  68. return response()->json([
  69. 'key' => $settingName,
  70. 'value' => $validated['value'],
  71. ], 200);
  72. }
  73. /**
  74. * Delete a setting
  75. *
  76. * @param string $settingName
  77. * @return \Illuminate\Http\JsonResponse
  78. */
  79. public function destroy(string $settingName)
  80. {
  81. $setting = Settings::get($settingName);
  82. if (is_null($setting)) {
  83. abort(404);
  84. }
  85. $optionsConfig = config('2fauth.options');
  86. if (array_key_exists($settingName, $optionsConfig)) {
  87. return response()->json(
  88. ['message' => 'bad request',
  89. 'reason' => [__('errors.delete_user_setting_only')],
  90. ], 400);
  91. }
  92. Settings::delete($settingName);
  93. return response()->json(null, 204);
  94. }
  95. }