RegType.php 4.4 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128
  1. <?php
  2. namespace common\models;
  3. use common\helpers\Cache;
  4. use Yii;
  5. /**
  6. * This is the model class for table "{{%REG_TYPE}}".
  7. *
  8. * @property string $ID
  9. * @property string $TYPE_NAME 类型名称
  10. * @property int $IS_PACT 是否启用协议
  11. * @property string $MONTH_LIMIT_AMOUNT 达到月提现金额升级应注册类型
  12. * @property string $YEAR_LIMIT_AMOUNT 达到年提现金额升级应注册类型
  13. * @property string $CREATE_ADMIN 创建管理员
  14. * @property string $UPDATE_ADMIN 修改管管理
  15. * @property string $REMARK 备注
  16. * @property int $SORT 排序
  17. * @property int $CREATED_AT 创建时间
  18. * @property int $UPDATED_AT 更新时间
  19. */
  20. class RegType extends \common\components\ActiveRecord {
  21. /**
  22. * {@inheritdoc}
  23. */
  24. public static function tableName() {
  25. return '{{%REG_TYPE}}';
  26. }
  27. /**
  28. * {@inheritdoc}
  29. */
  30. public function rules() {
  31. return [
  32. [['TYPE_NAME', 'CREATED_AT'], 'required'],
  33. [['IS_PACT', 'SORT', 'CREATED_AT', 'UPDATED_AT'], 'integer'],
  34. [['MONTH_LIMIT_AMOUNT', 'YEAR_LIMIT_AMOUNT'], 'number'],
  35. [['ID', 'CREATE_ADMIN', 'UPDATE_ADMIN'], 'string', 'max' => 32],
  36. [['TYPE_NAME'], 'string', 'max' => 48],
  37. [['REMARK'], 'string', 'max' => 4000],
  38. [['TYPE_NAME'], 'unique'],
  39. [['ID'], 'unique'],
  40. ];
  41. }
  42. /**
  43. * {@inheritdoc}
  44. */
  45. public function attributeLabels() {
  46. return [
  47. 'ID' => 'ID',
  48. 'TYPE_NAME' => '类型名称',
  49. 'IS_PACT' => '是否启用协议',
  50. 'MONTH_LIMIT_AMOUNT' => '达到月提现金额升级应注册类型',
  51. 'YEAR_LIMIT_AMOUNT' => '达到年提现金额升级应注册类型',
  52. 'CREATE_ADMIN' => '创建管理员',
  53. 'UPDATE_ADMIN' => '修改管理员',
  54. 'REMARK' => '备注',
  55. 'SORT' => '排序',
  56. 'CREATED_AT' => '创建时间',
  57. 'UPDATED_AT' => '更新时间',
  58. ];
  59. }
  60. /**
  61. * 从缓存获取信息
  62. * @return array|mixed|\yii\db\ActiveRecord[]
  63. */
  64. public static function getFromCache(){
  65. $data = Yii::$app->cache->get(Cache::REG_TYPE_CONFIG_KEY);
  66. if(!$data){
  67. // 获取信息
  68. $data = self::getTypes();
  69. Yii::$app->cache->set(Cache::REG_TYPE_CONFIG_KEY, $data);
  70. }
  71. // i18n转换
  72. foreach ($data as &$item) {
  73. $item['TYPE_NAME'] = Yii::t('ctx', $item['LANGUAGE_KEY']);
  74. }
  75. return $data;
  76. }
  77. /**
  78. * 更新缓存
  79. * @return array|\yii\db\ActiveRecord[]
  80. */
  81. public static function updateToCache(){
  82. // 获取配置
  83. $data = self::getTypes();
  84. Yii::$app->cache->set(Cache::REG_TYPE_CONFIG_KEY, $data);
  85. return $data;
  86. }
  87. /**
  88. * 获取注册类型
  89. * @return array|null
  90. */
  91. public static function getTypes() {
  92. return self::find()->indexBy('ID')->orderBy('SORT ASC')->asArray()->all();
  93. }
  94. /**
  95. * 是否满足修改应注册类型
  96. * @param $uid
  97. * @param $shouldRegType
  98. * @param $year
  99. * @param $month
  100. */
  101. public static function chkRegType($uid, $shouldRegType, $year, $month) {
  102. $status = [Withdraw::STATUS_APPLIED, Withdraw::STATUS_AUDITED, Withdraw::STATUS_WAIT_PAID, Withdraw::STATUS_PAID_FALSE, Withdraw::STATUS_PAID];
  103. $statusStr = implode("','", $status);
  104. $statusStr = "'" . $statusStr . "'";
  105. $withdrawMonth = Withdraw::find()->where('USER_ID=:USER_ID AND WITHDRAW_MONTH=:WITHDRAW_MONTH AND WITHDRAW_YEAR=:WITHDRAW_YEAR AND AUDIT_STATUS IN (' . $statusStr . ')', [':USER_ID' => $uid, ':WITHDRAW_MONTH' => $month, ':WITHDRAW_YEAR' => $year])->sum('AMOUNT');
  106. $withdrawYear = Withdraw::find()->where('USER_ID=:USER_ID AND WITHDRAW_YEAR=:WITHDRAW_YEAR AND AUDIT_STATUS IN (' . $statusStr . ')', [':USER_ID' => $uid, ':WITHDRAW_YEAR' => $year])->sum('AMOUNT');
  107. $regTypes = array_reverse(self::getTypes());
  108. $toType = $shouldRegType;
  109. foreach ($regTypes as $value) {
  110. if ($withdrawMonth >= $value['MONTH_LIMIT_AMOUNT'] || $withdrawYear >= $value['YEAR_LIMIT_AMOUNT']) {
  111. if ($value['SORT'] != 1) $toType = $value['ID'];
  112. break;
  113. }
  114. }
  115. if ($toType != $shouldRegType) {
  116. UserInfo::updateAll(['SHOULD_REG_TYPE' => $toType], 'USER_ID=:USER_ID', [':USER_ID' => $uid]);
  117. }
  118. }
  119. }