User.php 21 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236237238239240241242243244245246247248249250251252253254255256257258259260261262263264265266267268269270271272273274275276277278279280281282283284285286287288289290291292293294295296297298299300301302303304305306307308309310311312313314315316317318319320321322323324325326327328329330331332333334335336337338339340341342343344345346347348349350351352353354355356357358359360361362363364365366367368369370371372373374375376377378379380381382383384385386387388389390391392393394395396397398399400401402403404405406407408409410411412413414415416417418419420421422423424425426427428429430431432433434435436437438439440441442443444445446447448449450451452453454455456457458459460461462463464465466467468469470471472473474475476477478479480481482483484485486487488489490491492493494495496497498499500501502503504505506507508509510511512513514515516517518519520521522523524525526527
  1. <?php
  2. namespace common\models;
  3. use common\helpers\Cache;
  4. use common\helpers\LoggerTool;
  5. use Yii;
  6. use yii\db\Exception;
  7. use yii\helpers\Json;
  8. use common\libs\logging\operate\valueType\Config as ValueTypeConfig;
  9. /**
  10. * This is the model class for table "{{%USER}}".
  11. *
  12. * @property string $ID
  13. * @property string $USER_NAME 帐号
  14. * @property string $PASSWORD_HASH 登录密码
  15. * @property string $PAY_PASSWORD 支付密码
  16. * @property int $NATION 民族
  17. * @property string $REAL_NAME 姓名
  18. * @property string $ID_CARD 身份证号
  19. * @property int $ID_TYPE 证件类型
  20. * @property string $MOBILE 手机号
  21. * @property string $ADDRESS 身份证地址
  22. * @property string $ID_IMAGE 证件图片
  23. * @property string $OPEN_BANK 开户行
  24. * @property string $BANK_ADDRESS 银行地址
  25. * @property string $BANK_NO 银行卡号
  26. * @property int $BANK_PROVINCE 银行省份
  27. * @property int $BANK_CITY 银行城市
  28. * @property int $BANK_COUNTY 银行县区
  29. * @property string $SPOUSE_NAME 配偶姓名
  30. * @property string $SPOUSE_IDCARD 配偶证件号
  31. * @property int $CREATED_AT 创建时间
  32. * @property int $UPDATED_AT 更新时间
  33. * @property int $STATUS 状态
  34. * @property int $DEC_CLOSED 是否关闭报单功能
  35. * @property int $DEC_CLOSED_AT 关闭时间
  36. * @property string $DEC_LV 报单级别
  37. * @property string $EMP_LV 聘级
  38. * @property string $CROWN_LV 星级
  39. * @property int $PROVINCE 省份
  40. * @property int $CITY 城市
  41. * @property int $COUNTY 县区
  42. * @property string $TEL 座机
  43. * @property string $SUB_COM_ID 子公司ID
  44. * @property string $AVATAR 头像
  45. * @property int $DELETED 是否删除
  46. * @property int $DELETED_AT 删除时间
  47. * @property int $IS_DEC 是否为报单中心
  48. * @property int $IS_ATLAS 是否显示图谱
  49. * @property int $IS_RECHARGE 是否显示充值
  50. * @property string $DEC_ID 报单中心ID
  51. * @property string $BIRTHDAY 生日
  52. * @property string $DEC_ROLE_ID 报单中心级别
  53. * @property int $PERIOD_AT 期数
  54. * @property int $DEC_PROVINCE 报单中心所属的省份
  55. * @property int $DEC_CITY 报单中心所属的城市
  56. * @property int $DEC_COUNTY 报单中心所属的县区
  57. * @property int $IS_UNION 是否为点位合作
  58. * @property int $STATUS_AT 状态更改时间
  59. * @property int $VERIFIED 是否认证
  60. * @property int $VERIFIED_AT 认证时间
  61. * @property int $ALLOW_LOGIN 允许登录
  62. * @property int $NOT_OPERATING 不运作
  63. * @property int $REG_FROM 注册类型
  64. * @property string $ID_CARD_PREFIX 身份证前缀
  65. * @property string $SEX 性别
  66. * @property string $DEC_ACCOUNT_OLD 老系统中的报单中心编号
  67. * @property int $BANK_UPDATED_AT 银行信息更新时间
  68. * @property int $IS_DIRECT_SELLER 是否为直销员
  69. * @property int $DEC_LV_UPDATED_AT 报单级别更新时间
  70. * @property int $DEC_LV_UPDATED_PERIOD 报单级别更新期数
  71. * @property string $DEC_ADDRESS 报单中心详细地址
  72. * @property string $DEC_PHONE 报单中心电话
  73. * @property string $GUARANTOR 担保人编号
  74. * @property string $GUARANTOR_NAME 担保人姓名
  75. * @property int $PART_FUNC_CLOSED 部分功能开启
  76. * @property int $LAST_DEC_LV_UPDATED_PERIOD 上次报单级别更新期数
  77. * @property string $USER_CREATOR 创建人
  78. * @property string $USER_UPDATER 修改人
  79. * @property int $LAST_DEC_LV_UPDATED_AT 上次报单级别更新时间
  80. * @property int $DEC_CREATED_AT 成为报单中心时间
  81. * @property string $PART_FUNC_CLOSED_REMARK 部分功能关闭原因
  82. * @property int $DEC_CREATED_PERIOD 成为报单中心期数
  83. * @property int $PASSWORD_CHANGED 是否修改过密码
  84. * @property int $SUB_COM_LEADER 是否为分公司领导
  85. * @property string $ZG_UPGRADE_PV 增购升级PV
  86. * @property string $APP_CLIENT_ID APP设备ID
  87. * @property int $READ_AGREEMENT 已读协议
  88. * @property string $LAST_DEC_LV 上次的报单级别
  89. * @property string $BONUS_APP_CLIENT_ID 结算APP设备ID
  90. * @property int $IS_FIRST_OPEN 首次开通
  91. * @property int $IS_MODIFY_PASSWORD 是否修改密码
  92. * @property int $IS_STUDIO 是否是工作室
  93. * @property string $EMAIL 邮箱
  94. */
  95. class User extends \common\components\ActiveRecord
  96. {
  97. /**
  98. * @inheritdoc
  99. */
  100. public static function tableName()
  101. {
  102. return '{{%USER}}';
  103. }
  104. /**
  105. * @inheritdoc
  106. */
  107. public function rules()
  108. {
  109. return [
  110. [['USER_NAME', 'PASSWORD_HASH', 'PAY_PASSWORD', 'REAL_NAME',/* 'ID_CARD',*/ 'AVATAR'], 'required'],
  111. [['NATION', 'ID_TYPE', 'BANK_PROVINCE', 'BANK_CITY', 'BANK_COUNTY', 'CREATED_AT', 'UPDATED_AT', 'STATUS', 'DEC_CLOSED', 'DEC_CLOSED_AT', 'PROVINCE', 'CITY', 'COUNTY', 'DELETED', 'DELETED_AT', 'IS_DEC', 'IS_ATLAS', 'IS_RECHARGE','IS_STUDIO', 'PERIOD_AT', 'DEC_PROVINCE', 'DEC_CITY', 'DEC_COUNTY', 'IS_UNION', 'STATUS_AT', 'VERIFIED', 'VERIFIED_AT', 'ALLOW_LOGIN', 'NOT_OPERATING', 'REG_FROM', 'BANK_UPDATED_AT', 'IS_DIRECT_SELLER', 'DEC_LV_UPDATED_AT', 'DEC_LV_UPDATED_PERIOD', 'PART_FUNC_CLOSED', 'LAST_DEC_LV_UPDATED_PERIOD', 'LAST_DEC_LV_UPDATED_AT', 'DEC_CREATED_AT', 'DEC_CREATED_PERIOD', 'PASSWORD_CHANGED', 'SUB_COM_LEADER', 'READ_AGREEMENT', 'IS_FIRST_OPEN', 'IS_MODIFY_PASSWORD'], 'integer'],
  112. [['ZG_UPGRADE_PV'], 'number'],
  113. [['ID', 'OPEN_BANK', 'BANK_NO', 'DEC_LV', 'EMP_LV', 'CROWN_LV', 'SUB_COM_ID', 'DEC_ID', 'DEC_ROLE_ID', 'ID_CARD_PREFIX', 'SEX', 'DEC_PHONE', 'GUARANTOR', 'USER_CREATOR', 'USER_UPDATER', 'LAST_DEC_LV', 'EMAIL'], 'string', 'max' => 32],
  114. [['USER_NAME', 'SPOUSE_NAME', 'TEL'], 'string', 'max' => 16],
  115. [['PASSWORD_HASH', 'PAY_PASSWORD', 'ID_IMAGE', 'BANK_ADDRESS', 'AVATAR'], 'string', 'max' => 255],
  116. [['REAL_NAME', 'APP_CLIENT_ID', 'BONUS_APP_CLIENT_ID'], 'string', 'max' => 128],
  117. // [['ID_CARD', 'SPOUSE_IDCARD'], 'string','min' => 18, 'max' => 18],
  118. [['MOBILE'], 'string','min' => 11, 'max' => 11],
  119. [['ADDRESS', 'DEC_ADDRESS'], 'string', 'max' => 2000],
  120. [['DEC_ACCOUNT_OLD', 'GUARANTOR_NAME'], 'string', 'max' => 64],
  121. [['PART_FUNC_CLOSED_REMARK'], 'string', 'max' => 4000],
  122. [['USER_NAME'], 'unique'],
  123. [['ID'], 'unique'],
  124. ];
  125. }
  126. /**
  127. * @inheritdoc
  128. */
  129. public function attributeLabels()
  130. {
  131. return [
  132. 'ID' => 'ID',
  133. 'USER_NAME' => '帐号',
  134. 'PASSWORD_HASH' => '登录密码',
  135. 'PAY_PASSWORD' => '支付密码',
  136. 'NATION' => '民族',
  137. 'REAL_NAME' => '姓名',
  138. 'ID_CARD' => '身份证号',
  139. 'ID_TYPE' => '证件类型',
  140. 'MOBILE' => '手机号',
  141. 'ADDRESS' => '身份证地址',
  142. 'ID_IMAGE' => '证件图片',
  143. 'OPEN_BANK' => '开户行',
  144. 'BANK_ADDRESS' => '银行地址',
  145. 'BANK_NO' => '银行卡号',
  146. 'BANK_PROVINCE' => '银行省份',
  147. 'BANK_CITY' => '银行城市',
  148. 'BANK_COUNTY' => '银行县区',
  149. 'SPOUSE_NAME' => '配偶姓名',
  150. 'SPOUSE_IDCARD' => '配偶证件号',
  151. 'CREATED_AT' => '创建时间',
  152. 'UPDATED_AT' => '更新时间',
  153. 'STATUS' => '状态',
  154. 'DEC_CLOSED' => '是否关闭报单功能',
  155. 'DEC_CLOSED_AT' => '关闭时间',
  156. 'DEC_LV' => '报单级别',
  157. 'EMP_LV' => '聘级',
  158. 'CROWN_LV' => '星级',
  159. 'PROVINCE' => '省份',
  160. 'CITY' => '城市',
  161. 'COUNTY' => '县区',
  162. 'TEL' => '座机',
  163. 'SUB_COM_ID' => '子公司ID',
  164. 'AVATAR' => '头像',
  165. 'DELETED' => '是否删除',
  166. 'DELETED_AT' => '删除时间',
  167. 'IS_DEC' => '是否为报单中心',
  168. 'IS_ATLAS' => '是否显示图谱',
  169. 'IS_RECHARGE' => '是否显示充值',
  170. 'DEC_ID' => '报单中心ID',
  171. 'BIRTHDAY' => '生日',
  172. 'DEC_ROLE_ID' => '报单中心级别',
  173. 'PERIOD_AT' => '期数',
  174. 'DEC_PROVINCE' => '报单中心所属的省份',
  175. 'DEC_CITY' => '报单中心所属的城市',
  176. 'DEC_COUNTY' => '报单中心所属的县区',
  177. 'IS_UNION' => '是否为点位合作',
  178. 'STATUS_AT' => '状态更改时间',
  179. 'VERIFIED' => '是否认证',
  180. 'VERIFIED_AT' => '认证时间',
  181. 'ALLOW_LOGIN' => '允许登录',
  182. 'NOT_OPERATING' => '不运作',
  183. 'REG_FROM' => '注册类型',
  184. 'ID_CARD_PREFIX' => '身份证前缀',
  185. 'SEX' => '性别',
  186. 'DEC_ACCOUNT_OLD' => '老系统中的报单中心编号',
  187. 'BANK_UPDATED_AT' => '银行信息更新时间',
  188. 'IS_DIRECT_SELLER' => '是否为直销员',
  189. 'DEC_LV_UPDATED_AT' => '报单级别更新时间',
  190. 'DEC_LV_UPDATED_PERIOD' => '报单级别更新期数',
  191. 'DEC_ADDRESS' => '报单中心详细地址',
  192. 'DEC_PHONE' => '报单中心电话',
  193. 'GUARANTOR' => '担保人编号',
  194. 'GUARANTOR_NAME' => '担保人姓名',
  195. 'PART_FUNC_CLOSED' => '部分功能开启',
  196. 'LAST_DEC_LV_UPDATED_PERIOD' => '上次报单级别更新期数',
  197. 'USER_CREATOR' => '创建人',
  198. 'USER_UPDATER' => '修改人',
  199. 'LAST_DEC_LV_UPDATED_AT' => '上次报单级别更新时间',
  200. 'DEC_CREATED_AT' => '成为报单中心时间',
  201. 'PART_FUNC_CLOSED_REMARK' => '部分功能关闭原因',
  202. 'DEC_CREATED_PERIOD' => '成为报单中心期数',
  203. 'PASSWORD_CHANGED' => '是否修改过密码',
  204. 'SUB_COM_LEADER' => '是否为分公司领导',
  205. 'ZG_UPGRADE_PV' => '增购升级PV',
  206. 'APP_CLIENT_ID' => 'APP设备ID',
  207. 'READ_AGREEMENT' => '已读协议',
  208. 'LAST_DEC_LV' => '上次的报单级别',
  209. 'BONUS_APP_CLIENT_ID' => '结算APP设备ID',
  210. 'IS_FIRST_OPEN' => '首次开通',
  211. 'IS_MODIFY_PASSWORD' => '是否修改密码',
  212. 'IS_STUDIO' => '是否是工作室',
  213. 'EMAIL' => 'Email',
  214. ];
  215. }
  216. public function getUserInfo()
  217. {
  218. return $this->hasOne(UserInfo::class, ['USER_ID' => 'ID']);
  219. }
  220. /**
  221. * 获取会员基本信息
  222. * @param $userId
  223. * @return array|null|\yii\db\ActiveRecord
  224. */
  225. public static function getBaseInfo($userId){
  226. return static::findUseSlaves()->where('ID=:ID', [':ID'=>$userId])->asArray()->one();
  227. }
  228. /**
  229. * 获取用户基本信息从redis里面
  230. * @param $userId
  231. * @return array|null|\yii\db\ActiveRecord
  232. */
  233. public static function getBaseInfoFromRedis($userId){
  234. $userInfo = Yii::$app->redis->hget(Cache::USER_INFO_KEY, $userId);
  235. if(!$userInfo){
  236. $userInfo = static::find()->select('ID,USER_NAME,NATION,REAL_NAME,ID_CARD,ID_TYPE,MOBILE,ADDRESS,STATUS,DEC_LV,LAST_DEC_LV,EMP_LV,CROWN_LV,DEC_CLOSED,AVATAR,OPEN_BANK,BANK_ADDRESS,BANK_NO,VERIFIED,IS_UNION,IS_DEC,IS_ATLAS,IS_RECHARGE,IS_STUDIO,DEC_ROLE_ID,PROVINCE,CITY,COUNTY,EMAIL')->where('ID=:ID', [':ID'=>$userId])->asArray()->one();
  237. Yii::$app->redis->hset(Cache::USER_INFO_KEY, $userId, Json::encode($userInfo));
  238. } else {
  239. $userInfo = Json::decode($userInfo);
  240. }
  241. return $userInfo;
  242. }
  243. /**
  244. * 更新缓存
  245. * @param $userId
  246. * @return mixed
  247. */
  248. public static function updateBaseInfoToRedis($userId){
  249. $userInfo = static::find()->select('ID,USER_NAME,NATION,REAL_NAME,ID_CARD,ID_TYPE,MOBILE,ADDRESS,STATUS,DEC_LV,LAST_DEC_LV,EMP_LV,CROWN_LV,DEC_CLOSED,AVATAR,OPEN_BANK,BANK_ADDRESS,BANK_NO,VERIFIED,IS_UNION,IS_DEC,IS_ATLAS,IS_RECHARGE,IS_STUDIO,DEC_ROLE_ID,PROVINCE,CITY,COUNTY,EMAIL')->where('ID=:ID', [':ID'=>$userId])->asArray()->one();
  250. return Yii::$app->redis->hset(Cache::USER_INFO_KEY, $userId, Json::encode($userInfo));
  251. }
  252. /**
  253. * @param $userId
  254. * 删除用户信息缓存
  255. */
  256. public static function deleteBaseInfoFromRedis($userId) {
  257. Yii::$app->redis->hdel(Cache::USER_INFO_KEY, $userId);
  258. }
  259. /**
  260. * 获取会员的部分信息并对敏感信息加密
  261. * @param $userId
  262. * @return array
  263. */
  264. public static function getEnCodeInfo($userId){
  265. $userInfo = self::getBaseInfoFromRedis($userId);
  266. return [
  267. 'ID' => $userId,
  268. 'USER_NAME' => $userInfo['USER_NAME'],
  269. 'NATION' => \Yii::$app->params['nation'][$userInfo['NATION']]['name']??'',
  270. 'NATION_ID' => \Yii::$app->params['nation'][$userInfo['NATION']]['id']??'',
  271. 'REAL_NAME' => $userInfo['REAL_NAME'],
  272. 'ID_CARD' => $userInfo['ID_CARD'],
  273. // 'ID_CARD' => Tool::hideIdCard($userInfo['ID_CARD']),
  274. 'MOBILE' => $userInfo['MOBILE'],
  275. // 'MOBILE' => Tool::hideMobile($userInfo['MOBILE']),
  276. 'AVATAR' => $userInfo['AVATAR'],
  277. 'VERIFIED' => $userInfo['VERIFIED'],
  278. 'IS_UNION' => $userInfo['IS_UNION'],
  279. 'IS_DEC' => $userInfo['IS_DEC'],
  280. 'IS_ATLAS' => $userInfo['IS_ATLAS'],
  281. 'IS_RECHARGE' => $userInfo['IS_RECHARGE'],
  282. 'IS_STUDIO' => $userInfo['IS_STUDIO'],
  283. 'DEC_ROLE_ID' => $userInfo['DEC_ROLE_ID'],
  284. 'OPEN_BANK' => $userInfo['OPEN_BANK'],
  285. 'BANK_ADDRESS' => $userInfo['BANK_ADDRESS'],
  286. 'DEC_LV' => $userInfo['DEC_LV'],
  287. 'EMP_LV' => $userInfo['EMP_LV'],
  288. 'CROWN_LV' => $userInfo['CROWN_LV'],
  289. 'PROVINCE' => $userInfo['PROVINCE'],
  290. 'CITY' => $userInfo['CITY'],
  291. 'COUNTY' => $userInfo['COUNTY'],
  292. 'BANK_NO' => $userInfo['BANK_NO'],
  293. // 'BANK_NO' => Tool::hideBankNo($userInfo['BANK_NO']),
  294. 'EMAIL' => $userInfo['EMAIL'],
  295. ];
  296. }
  297. /**
  298. * 验证密码
  299. * @param $password
  300. * @return bool
  301. */
  302. public function validatePassword($password) {
  303. if( !$this->PASSWORD_HASH ) return false;
  304. return password_verify($password, $this->PASSWORD_HASH);
  305. }
  306. /**
  307. * 验证支付密码
  308. * @param $payPassword
  309. * @return bool
  310. */
  311. public function validatePasswordPay($payPassword) {
  312. if( !$this->PAY_PASSWORD ) return false;
  313. return password_verify($payPassword, $this->PAY_PASSWORD);
  314. }
  315. /**
  316. * 检验支付密码
  317. * @param $userId
  318. * @param $password
  319. * @return bool
  320. */
  321. public static function validatePayPassword($userId, $password){
  322. $oneUser = static::find()->select('PAY_PASSWORD')->where('ID=:ID', [':ID'=>$userId])->asArray()->one();
  323. if($oneUser){
  324. return password_verify($password, $oneUser['PAY_PASSWORD']);
  325. } else {
  326. return false;
  327. }
  328. }
  329. /**
  330. * 操作日志记录条件
  331. * @return array
  332. */
  333. public function attrLabelsWithLogType(){
  334. return [
  335. 'ID' => 'ID',
  336. 'USER_NAME' => '帐号',
  337. 'NATION' => [
  338. 'label' => '民族',
  339. 'type' => function($data){
  340. $value = $data['value'];
  341. return \Yii::$app->params['nation'][$value]['name']??'';
  342. },
  343. ],
  344. 'REAL_NAME' => '姓名',
  345. 'ID_CARD' => '身份证号',
  346. 'ID_TYPE' => [
  347. 'label' => '证件类型',
  348. 'type' => function($data){
  349. return '身份证';
  350. },
  351. ],
  352. 'MOBILE' => '手机号',
  353. 'ADDRESS' => '身份证地址',
  354. 'ID_IMAGE' => '证件图片',
  355. 'OPEN_BANK' => '开户行',
  356. 'BANK_ADDRESS' => '银行地址',
  357. 'BANK_NO' => '银行卡号',
  358. 'BANK_PROVINCE' => [
  359. 'label' => '银行省份',
  360. 'type' => ValueTypeConfig::REGION_TYPE
  361. ],
  362. 'BANK_CITY' => [
  363. 'label' => '银行城市',
  364. 'type' => ValueTypeConfig::REGION_TYPE
  365. ],
  366. 'BANK_COUNTY' => [
  367. 'label' => '银行县区',
  368. 'type' => ValueTypeConfig::REGION_TYPE
  369. ],
  370. 'SPOUSE_NAME' => '配偶姓名',
  371. 'SPOUSE_IDCARD' => '配偶证件号',
  372. 'STATUS' => [
  373. 'label' => '状态',
  374. 'type' => ValueTypeConfig::USER_STATUS_TYPE
  375. ],
  376. 'DEC_CLOSED' => [
  377. 'label' => '是否关闭报单功能',
  378. 'type' => ValueTypeConfig::YES_NO_TYPE,
  379. ],
  380. 'DEC_CLOSED_AT' => [
  381. 'label' => '关闭报单时间',
  382. 'type' => ValueTypeConfig::DATE_TIME_TYPE,
  383. ],
  384. 'DEC_LV' => [
  385. 'label' => '报单级别',
  386. 'type' => ValueTypeConfig::DEC_LV_TYPE,
  387. ],
  388. 'EMP_LV' => [
  389. 'label' => '聘级',
  390. 'type' => ValueTypeConfig::EMP_LV_TYPE,
  391. ],
  392. 'CROWN_LV' => [
  393. 'label' => '星级',
  394. 'type' => ValueTypeConfig::CROWN_LV_TYPE,
  395. ],
  396. 'LAST_DEC_LV' => [
  397. 'label' => '上次的报单级别',
  398. 'type' => ValueTypeConfig::DEC_LV_TYPE,
  399. ],
  400. 'PROVINCE' => [
  401. 'label' => '省份',
  402. 'type' => ValueTypeConfig::REGION_TYPE
  403. ],
  404. 'CITY' => [
  405. 'label' => '城市',
  406. 'type' => ValueTypeConfig::REGION_TYPE
  407. ],
  408. 'COUNTY' => [
  409. 'label' => '县区',
  410. 'type' => ValueTypeConfig::REGION_TYPE
  411. ],
  412. 'TEL' => '备用手机号码',
  413. 'SUB_COM_ID' => '分公司ID',
  414. 'TRANSFER_PROP' => '转帐比例',
  415. 'IS_DEC' => [
  416. 'label' => '是否为报单中心',
  417. 'type' => ValueTypeConfig::YES_NO_TYPE,
  418. ],
  419. 'DEC_ROLE_ID' => [
  420. 'label' => '报单中心级别',
  421. 'type' => ValueTypeConfig::DEC_ROLE_ID_TYPE,
  422. ],
  423. 'IS_UNION' => [
  424. 'label' => '是否为点位合作',
  425. 'type' => ValueTypeConfig::YES_NO_TYPE,
  426. ],
  427. 'STATUS_AT' => '状态修改时间',
  428. 'ALLOW_LOGIN' => [
  429. 'label' => '是否允许商城登录',
  430. 'type' => ValueTypeConfig::YES_NO_TYPE,
  431. ],
  432. 'NOT_OPERATING' => [
  433. 'label' => '不运作',
  434. 'type' => ValueTypeConfig::YES_NO_TYPE,
  435. ],
  436. 'BIRTHDAY' => '生日',
  437. 'SEX' => '性别',
  438. 'EMAIL' => 'Email'
  439. ];
  440. }
  441. /**
  442. * 判断此期用户是否活跃
  443. * @param string $userId 用户ID
  444. * @param int $periodNum 业绩期
  445. * @param string $calcYearMonth 结算年月
  446. */
  447. public static function isPerfActive($userId, $periodNum, $calcYearMonth): bool {
  448. $sysConfig = Cache::getSystemConfig();
  449. $pv = PerfPeriod::find()->where('USER_ID=:USER_ID AND CALC_MONTH=:CALC_MONTH AND PERIOD_NUM<=:PERIOD_NUM',
  450. ['USER_ID'=>$userId, 'CALC_MONTH'=>$calcYearMonth, 'PERIOD_NUM'=>$periodNum])
  451. ->SUM('PV_PCS');
  452. return $pv >= $sysConfig['monthPcsPvFxCondition']['VALUE'] ? 1 : 0;
  453. }
  454. /**
  455. * 判断会员是否活跃:1. 当月消费30BV. 2.任意水机+150粒的EKSP. (满足任意条件即可)
  456. * @throws Exception
  457. */
  458. // public static function isPerfActive($userId, $periodNum, $calcYearMonth): int
  459. // {
  460. // $sysConfig = Cache::getSystemConfig();
  461. //
  462. // // 条件1: 当月消费30BV
  463. // $pv = PerfPeriod::find()->where('USER_ID=:USER_ID AND CALC_MONTH=:CALC_MONTH AND PERIOD_NUM<=:PERIOD_NUM',
  464. // ['USER_ID' => $userId, 'CALC_MONTH' => $calcYearMonth, 'PERIOD_NUM' => $periodNum])
  465. // ->SUM('PV_PCS');
  466. //
  467. // if ($pv >= $sysConfig['monthPcsPvFxCondition']['VALUE']) {
  468. // return 1;
  469. // }
  470. //
  471. // $periodObj = Period::instance();
  472. // $calcYear = $periodObj->getYear($periodNum);
  473. // $calcMonth = $periodObj->getMonth($periodNum);
  474. // $periodList = $periodObj->getYearMonthAllPeriod($calcYear, $calcMonth);
  475. // $periodList = implode("','", $periodList);
  476. //
  477. // // 条件2: 任意水机分期+150粒的EKSP(HES150N)
  478. // $orderEKSP = Order::find()
  479. // ->alias('O')
  480. // ->select('O.SN')
  481. // ->join('INNER JOIN', OrderGoods::tableName() . ' AS G', 'O.SN = G.ORDER_SN')
  482. // ->where("O.IS_DELETE=0 AND O.USER_ID=:USER_ID AND O.PERIOD_NUM IN ('{$periodList}') AND G.SKU_CODE=:SKU_CODE",
  483. // ['USER_ID' => $userId, ':SKU_CODE' => 'HES150N'])
  484. // ->asArray()
  485. // ->all();
  486. // if (!count($orderEKSP)) {
  487. // return 0;
  488. // }
  489. //
  490. // // 所有分期商品
  491. // $instalmentShopGoods = ShopGoods::find()->where('INSTALMENT>0 AND STATUS=1')->select('GOODS_NO')->column();
  492. // $instalmentShopGoods = implode("','", $instalmentShopGoods);
  493. //
  494. // $orderInstalment = Order::find()
  495. // ->alias('O')
  496. // ->select('O.SN')
  497. // ->join('INNER JOIN', OrderGoods::tableName() . ' AS G', 'O.SN = G.ORDER_SN')
  498. // ->where("O.IS_DELETE=0 AND O.USER_ID=:USER_ID AND O.PERIOD_NUM IN ('{$periodList}') AND G.SKU_CODE IN ('{$instalmentShopGoods}')", ['USER_ID' => $userId])
  499. // ->asArray()
  500. // ->all();
  501. // if (!count($orderInstalment)) {
  502. // return 0;
  503. // }
  504. //
  505. // return 1;
  506. // }
  507. }