2023_02_01_181925_create_user_settings.php 7.1 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124
  1. <?php
  2. use App\Classes\LegacySettingsMigration;
  3. use Illuminate\Support\Facades\DB;
  4. class CreateUserSettings extends LegacySettingsMigration
  5. {
  6. public function up(): void
  7. {
  8. $table_exists = DB::table('settings_old')->exists();
  9. // Get the user-set configuration values from the old table.
  10. $this->migrator->add('user.credits_reward_after_verify_discord', $table_exists ? $this->getOldValue('SETTINGS::USER:CREDITS_REWARD_AFTER_VERIFY_DISCORD', 250) : 250);
  11. $this->migrator->add('user.credits_reward_after_verify_email', $table_exists ? $this->getOldValue('SETTINGS::USER:CREDITS_REWARD_AFTER_VERIFY_EMAIL', 250) : 250);
  12. $this->migrator->add('user.force_discord_verification', $table_exists ? $this->getOldValue('SETTINGS::USER:FORCE_DISCORD_VERIFICATION', false) : false);
  13. $this->migrator->add('user.force_email_verification', $table_exists ? $this->getOldValue('SETTINGS::USER:FORCE_EMAIL_VERIFICATION', false) : false);
  14. $this->migrator->add('user.initial_credits', $table_exists ? $this->getOldValue('SETTINGS::USER:INITIAL_CREDITS', 250) : 250);
  15. $this->migrator->add('user.initial_server_limit', $table_exists ? $this->getOldValue('SETTINGS::USER:INITIAL_SERVER_LIMIT', 1) : 1);
  16. $this->migrator->add('user.min_credits_to_make_server', $table_exists ? $this->getOldValue('SETTINGS::USER:MINIMUM_REQUIRED_CREDITS_TO_MAKE_SERVER', 50) : 50);
  17. $this->migrator->add('user.server_limit_after_irl_purchase', $table_exists ? $this->getOldValue('SETTINGS::USER:SERVER_LIMIT_AFTER_IRL_PURCHASE', 10) : 10);
  18. $this->migrator->add('user.server_limit_after_verify_discord', $table_exists ? $this->getOldValue('SETTINGS::USER:SERVER_LIMIT_REWARD_AFTER_VERIFY_DISCORD', 2) : 2);
  19. $this->migrator->add('user.server_limit_after_verify_email', $table_exists ? $this->getOldValue('SETTINGS::USER:SERVER_LIMIT_REWARD_AFTER_VERIFY_EMAIL', 2) : 2);
  20. $this->migrator->add('user.register_ip_check', $table_exists ? $this->getOldValue("SETTINGS::SYSTEM:REGISTER_IP_CHECK", true) : true);
  21. $this->migrator->add('user.creation_enabled', $table_exists ? $this->getOldValue("SETTINGS::SYSTEM:CREATION_OF_NEW_USERS", true) : true);
  22. }
  23. public function down(): void
  24. {
  25. DB::table('settings_old')->insert([
  26. [
  27. 'key' => 'SETTINGS::USER:CREDITS_REWARD_AFTER_VERIFY_DISCORD',
  28. 'value' => $this->getNewValue('credits_reward_after_verify_discord', 'user'),
  29. 'type' => 'integer',
  30. 'description' => 'The amount of credits that the user will receive after verifying their Discord account.',
  31. ],
  32. [
  33. 'key' => 'SETTINGS::USER:CREDITS_REWARD_AFTER_VERIFY_EMAIL',
  34. 'value' => $this->getNewValue('credits_reward_after_verify_email', 'user'),
  35. 'type' => 'integer',
  36. 'description' => 'The amount of credits that the user will receive after verifying their email.',
  37. ],
  38. [
  39. 'key' => 'SETTINGS::USER:FORCE_DISCORD_VERIFICATION',
  40. 'value' => $this->getNewValue('force_discord_verification', 'user'),
  41. 'type' => 'boolean',
  42. 'description' => 'If the user must verify their Discord account to use the panel.',
  43. ],
  44. [
  45. 'key' => 'SETTINGS::USER:FORCE_EMAIL_VERIFICATION',
  46. 'value' => $this->getNewValue('force_email_verification', 'user'),
  47. 'type' => 'boolean',
  48. 'description' => 'If the user must verify their email to use the panel.',
  49. ],
  50. [
  51. 'key' => 'SETTINGS::USER:INITIAL_CREDITS',
  52. 'value' => $this->getNewValue('initial_credits', 'user'),
  53. 'type' => 'integer',
  54. 'description' => 'The amount of credits that the user will receive when they register.',
  55. ],
  56. [
  57. 'key' => 'SETTINGS::USER:INITIAL_SERVER_LIMIT',
  58. 'value' => $this->getNewValue('initial_server_limit', 'user'),
  59. 'type' => 'integer',
  60. 'description' => 'The amount of servers that the user will be able to create when they register.',
  61. ],
  62. [
  63. 'key' => 'SETTINGS::USER:MINIMUM_REQUIRED_CREDITS_TO_MAKE_SERVER',
  64. 'value' => $this->getNewValue('min_credits_to_make_server', 'user'),
  65. 'type' => 'integer',
  66. 'description' => 'The minimum amount of credits that the user must have to create a server.',
  67. ],
  68. [
  69. 'key' => 'SETTINGS::USER:SERVER_LIMIT_AFTER_IRL_PURCHASE',
  70. 'value' => $this->getNewValue('server_limit_after_irl_purchase', 'user'),
  71. 'type' => 'integer',
  72. 'description' => 'The amount of servers that the user will be able to create after making a real purchase.',
  73. ],
  74. [
  75. 'key' => 'SETTINGS::USER:SERVER_LIMIT_REWARD_AFTER_VERIFY_DISCORD',
  76. 'value' => $this->getNewValue('server_limit_after_verify_discord', 'user'),
  77. 'type' => 'integer',
  78. 'description' => 'The amount of servers that the user will be able to create after verifying their Discord account.',
  79. ],
  80. [
  81. 'key' => 'SETTINGS::USER:SERVER_LIMIT_REWARD_AFTER_VERIFY_EMAIL',
  82. 'value' => $this->getNewValue('server_limit_after_verify_email', 'user'),
  83. 'type' => 'integer',
  84. 'description' => 'The amount of servers that the user will be able to create after verifying their email.',
  85. ],
  86. [
  87. 'key' => 'SETTINGS::SYSTEM:REGISTER_IP_CHECK',
  88. 'value' => $this->getNewValue('register_ip_check', 'user'),
  89. 'type' => 'boolean',
  90. 'description' => 'If the user must verify their IP address to register.',
  91. ],
  92. [
  93. 'key' => 'SETTINGS::SYSTEM:CREATION_OF_NEW_USERS',
  94. 'value' => $this->getNewValue('creation_enabled', 'user'),
  95. 'type' => 'boolean',
  96. 'description' => 'If the user can register.',
  97. ],
  98. ]);
  99. try {
  100. $this->migrator->delete('user.credits_reward_after_verify_discord');
  101. $this->migrator->delete('user.credits_reward_after_verify_email');
  102. $this->migrator->delete('user.force_discord_verification');
  103. $this->migrator->delete('user.force_email_verification');
  104. $this->migrator->delete('user.initial_credits');
  105. $this->migrator->delete('user.initial_server_limit');
  106. $this->migrator->delete('user.min_credits_to_make_server');
  107. $this->migrator->delete('user.server_limit_after_irl_purchase');
  108. $this->migrator->delete('user.server_limit_after_verify_discord');
  109. $this->migrator->delete('user.server_limit_after_verify_email');
  110. $this->migrator->delete('user.register_ip_check');
  111. $this->migrator->delete('user.creation_enabled');
  112. } catch (Exception $e) {
  113. // Do nothing
  114. }
  115. }
  116. }