OptionController.php 1.7 KB

12345678910111213141516171819202122232425262728293031323334353637383940414243444546474849505152535455565758596061
  1. <?php
  2. namespace App\Http\Controllers\Settings;
  3. use App\Classes\Options;
  4. use Illuminate\Http\Request;
  5. use App\Classes\DbProtection;
  6. use App\Http\Controllers\Controller;
  7. class OptionController extends Controller
  8. {
  9. /**
  10. * Get options
  11. * @return [type] [description]
  12. */
  13. public function index()
  14. {
  15. // Fetch all setting values
  16. $settings = Options::get();
  17. return response()->json(['settings' => $settings], 200);
  18. }
  19. /**
  20. * Save options
  21. * @return [type] [description]
  22. */
  23. public function store(Request $request)
  24. {
  25. // The useEncryption option impacts the [existing] content of the database.
  26. // Encryption/Decryption of the data is done only if the user change the value of the option
  27. // to prevent successive encryption
  28. if( isset($request->useEncryption))
  29. {
  30. if( $request->useEncryption && !Options::get('useEncryption') ) {
  31. // user enabled the encryption
  32. if( !DbProtection::enable() ) {
  33. return response()->json(['message' => __('errors.error_during_encryption'), 'settings' => Options::get()], 400);
  34. }
  35. }
  36. else if( !$request->useEncryption && Options::get('useEncryption') ) {
  37. // user disabled the encryption
  38. if( !DbProtection::disable() ) {
  39. return response()->json(['message' => __('errors.error_during_decryption'), 'settings' => Options::get()], 400);
  40. }
  41. }
  42. }
  43. // Store all options
  44. Options::store($request->all());
  45. return response()->json(['message' => __('settings.forms.setting_saved'), 'settings' => Options::get()], 200);
  46. }
  47. }