2023_02_01_182135_create_referral_settings.php 3.0 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172
  1. <?php
  2. use App\Classes\LegacySettingsMigration;
  3. use Illuminate\Support\Facades\DB;
  4. class CreateReferralSettings 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('referral.always_give_commission', $table_exists ? $this->getOldValue('SETTINGS::REFERRAL::ALWAYS_GIVE_COMMISSION', false) : false);
  11. $this->migrator->add('referral.enabled', $table_exists ? $this->getOldValue('SETTINGS::REFERRAL::ENABLED', false) : false);
  12. $this->migrator->add('referral.reward', $table_exists ? $this->getOldValue('SETTINGS::REFERRAL::REWARD') : 100);
  13. $this->migrator->add('referral.mode', $table_exists ? $this->getOldValue('SETTINGS::REFERRAL:MODE', 'sign-up') : 'sign-up');
  14. $this->migrator->add('referral.percentage', $table_exists ? $this->getOldValue('SETTINGS::REFERRAL:PERCENTAGE', 100) : 100);
  15. }
  16. public function down(): void
  17. {
  18. DB::table('settings_old')->insert([
  19. [
  20. 'key' => 'SETTINGS::REFERRAL::ALLOWED',
  21. 'value' => $this->getNewValue('allowed', 'referral'),
  22. 'type' => 'string',
  23. 'description' => 'The allowed referral types.',
  24. ],
  25. [
  26. 'key' => 'SETTINGS::REFERRAL::ALWAYS_GIVE_COMMISSION',
  27. 'value' => $this->getNewValue('always_give_commission', 'referral'),
  28. 'type' => 'boolean',
  29. 'description' => 'Whether to always give commission to the referrer.',
  30. ],
  31. [
  32. 'key' => 'SETTINGS::REFERRAL::ENABLED',
  33. 'value' => $this->getNewValue('enabled', 'referral'),
  34. 'type' => 'boolean',
  35. 'description' => 'Whether to enable the referral system.',
  36. ],
  37. [
  38. 'key' => 'SETTINGS::REFERRAL::REWARD',
  39. 'value' => $this->getNewValue('reward', 'referral'),
  40. 'type' => 'integer',
  41. 'description' => 'The reward for the referral.',
  42. ],
  43. [
  44. 'key' => 'SETTINGS::REFERRAL:MODE',
  45. 'value' => $this->getNewValue('mode', 'referral'),
  46. 'type' => 'string',
  47. 'description' => 'The referral mode.',
  48. ],
  49. [
  50. 'key' => 'SETTINGS::REFERRAL:PERCENTAGE',
  51. 'value' => $this->getNewValue('percentage', 'referral'),
  52. 'type' => 'integer',
  53. 'description' => 'The referral percentage.',
  54. ],
  55. ]);
  56. try {
  57. $this->migrator->delete('referral.allowed');
  58. $this->migrator->delete('referral.always_give_commission');
  59. $this->migrator->delete('referral.enabled');
  60. $this->migrator->delete('referral.reward');
  61. $this->migrator->delete('referral.mode');
  62. $this->migrator->delete('referral.percentage');
  63. } catch (Exception $e) {
  64. //
  65. }
  66. }
  67. }