User.php 21 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236237238239240241242243244245246247248249250251252253254255256257258259260261262263264265266267268269270271272273274275276277278279280281282283284285286287288289290291292293294295296297298299300301302303304305306307308309310311312313314315316317318319320321322323324325326327328329330331332333334335336337338339340341342343344345346347348349350351352353354355356357358359360361362363364365366367368369370371372373374375376377378379380381382383384385386387388389390391392393394395396397398399400401402403404405406407408409410411412413414415416417418419420421422423424425426427428429430431432433434435436437438439440441442443444445446447448449450451452453454455456457458459460461462463464465466467468469470471472473474475476477478479480481482483484485486487488489490491492493494495496497498499500501502503504505506507508509510511512513514515516517518519520521522523524
  1. <?php
  2. namespace common\models;
  3. use common\helpers\Cache;
  4. use common\helpers\Tool;
  5. use common\helpers\user\Info;
  6. use Yii;
  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 int $PROVINCE 省份
  39. * @property int $CITY 城市
  40. * @property int $COUNTY 县区
  41. * @property string $TEL 座机
  42. * @property string $SUB_COM_ID 子公司ID
  43. * @property string $AVATAR 头像
  44. * @property int $DELETED 是否删除
  45. * @property int $DELETED_AT 删除时间
  46. * @property int $IS_DEC 是否为报单中心
  47. * @property int $IS_ATLAS 是否显示图谱
  48. * @property int $IS_RECHARGE 是否显示充值
  49. * @property string $DEC_ID 报单中心ID
  50. * @property string $BIRTHDAY 生日
  51. * @property string $DEC_ROLE_ID 报单中心级别
  52. * @property int $PERIOD_AT 期数
  53. * @property int $DEC_PROVINCE 报单中心所属的省份
  54. * @property int $DEC_CITY 报单中心所属的城市
  55. * @property int $DEC_COUNTY 报单中心所属的县区
  56. * @property int $IS_UNION 是否为点位合作
  57. * @property int $STATUS_AT 状态更改时间
  58. * @property int $VERIFIED 是否认证
  59. * @property int $VERIFIED_AT 认证时间
  60. * @property int $ALLOW_LOGIN 允许登录
  61. * @property int $NOT_OPERATING 不运作
  62. * @property int $REG_FROM 注册类型
  63. * @property string $ID_CARD_PREFIX 身份证前缀
  64. * @property string $SEX 性别
  65. * @property string $DEC_ACCOUNT_OLD 老系统中的报单中心编号
  66. * @property int $BANK_UPDATED_AT 银行信息更新时间
  67. * @property int $IS_DIRECT_SELLER 是否为直销员
  68. * @property int $DEC_LV_UPDATED_AT 报单级别更新时间
  69. * @property int $DEC_LV_UPDATED_PERIOD 报单级别更新期数
  70. * @property string $DEC_ADDRESS 报单中心详细地址
  71. * @property string $DEC_PHONE 报单中心电话
  72. * @property string $GUARANTOR 担保人编号
  73. * @property string $GUARANTOR_NAME 担保人姓名
  74. * @property int $PART_FUNC_CLOSED 部分功能开启
  75. * @property int $LAST_DEC_LV_UPDATED_PERIOD 上次报单级别更新期数
  76. * @property string $USER_CREATOR 创建人
  77. * @property string $USER_UPDATER 修改人
  78. * @property int $LAST_DEC_LV_UPDATED_AT 上次报单级别更新时间
  79. * @property int $DEC_CREATED_AT 成为报单中心时间
  80. * @property string $PART_FUNC_CLOSED_REMARK 部分功能关闭原因
  81. * @property int $DEC_CREATED_PERIOD 成为报单中心期数
  82. * @property int $PASSWORD_CHANGED 是否修改过密码
  83. * @property int $SUB_COM_LEADER 是否为分公司领导
  84. * @property string $ZG_UPGRADE_PV 增购升级PV
  85. * @property string $APP_CLIENT_ID APP设备ID
  86. * @property int $READ_AGREEMENT 已读协议
  87. * @property string $LAST_DEC_LV 上次的报单级别
  88. * @property string $BONUS_APP_CLIENT_ID 结算APP设备ID
  89. * @property int $IS_FIRST_OPEN 首次开通
  90. * @property int $IS_MODIFY_PASSWORD 是否修改密码
  91. * @property int $IS_STUDIO 是否是工作室
  92. * @property string $EMAIL 邮箱
  93. * @property string COUNTRY_ID 国家
  94. * @property string LANGUAGE_ID
  95. */
  96. class User extends \common\components\ActiveRecord
  97. {
  98. /**
  99. * @inheritdoc
  100. */
  101. public static function tableName()
  102. {
  103. return '{{%USER}}';
  104. }
  105. /**
  106. * @inheritdoc
  107. */
  108. public function rules()
  109. {
  110. return [
  111. [['USER_NAME', 'PASSWORD_HASH', 'PAY_PASSWORD', 'REAL_NAME',/* 'ID_CARD',*/ 'AVATAR', 'COUNTRY_ID'], 'required'],
  112. [['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'],
  113. [['ZG_UPGRADE_PV'], 'number'],
  114. [['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],
  115. [['USER_NAME', 'SPOUSE_NAME', 'TEL'], 'string', 'max' => 16],
  116. [['PASSWORD_HASH', 'PAY_PASSWORD', 'ID_IMAGE', 'BANK_ADDRESS', 'AVATAR'], 'string', 'max' => 255],
  117. [['REAL_NAME', 'APP_CLIENT_ID', 'BONUS_APP_CLIENT_ID'], 'string', 'max' => 128],
  118. // [['ID_CARD', 'SPOUSE_IDCARD'], 'string','min' => 18, 'max' => 18],
  119. [['MOBILE'], 'string','min' => 11, 'max' => 11],
  120. [['ADDRESS', 'DEC_ADDRESS'], 'string', 'max' => 2000],
  121. [['DEC_ACCOUNT_OLD', 'GUARANTOR_NAME'], 'string', 'max' => 64],
  122. [['PART_FUNC_CLOSED_REMARK'], 'string', 'max' => 4000],
  123. [['USER_NAME'], 'unique'],
  124. [['ID'], 'unique'],
  125. ];
  126. }
  127. /**
  128. * @inheritdoc
  129. */
  130. public function attributeLabels()
  131. {
  132. return [
  133. 'ID' => 'ID',
  134. 'USER_NAME' => Yii::t('app', 'userName'),
  135. 'PASSWORD_HASH' => Yii::t('app', 'passwordHash'),
  136. 'PAY_PASSWORD' => Yii::t('app', 'payPassword'),
  137. 'NATION' => Yii::t('app', 'nation'),
  138. 'REAL_NAME' => Yii::t('app', 'realName'),
  139. 'ID_CARD' => Yii::t('app', 'IDCard'),
  140. 'ID_TYPE' => Yii::t('app', 'IDType'),
  141. 'MOBILE' => Yii::t('app', 'mobile'),
  142. 'ADDRESS' => Yii::t('app', 'address'),
  143. 'ID_IMAGE' => Yii::t('app', 'IDImage'),
  144. 'OPEN_BANK' => Yii::t('app', 'openBank'),
  145. 'BANK_ADDRESS' => Yii::t('app', 'bankAddress'),
  146. 'BANK_NO' => Yii::t('app', 'bankNo'),
  147. 'BANK_PROVINCE' => Yii::t('app', 'bankProvince'),
  148. 'BANK_CITY' => Yii::t('app', 'bankCity'),
  149. 'BANK_COUNTY' => Yii::t('app', 'bankCounty'),
  150. 'SPOUSE_NAME' => Yii::t('app', 'spouseName'),
  151. 'SPOUSE_IDCARD' => Yii::t('app', 'spouseIDCard'),
  152. 'CREATED_AT' => Yii::t('app', 'createAt'),
  153. 'UPDATED_AT' => Yii::t('app', 'updateAt'),
  154. 'STATUS' => Yii::t('app', 'status'),
  155. 'DEC_CLOSED' => Yii::t('app', 'decClosed'),
  156. 'DEC_CLOSED_AT' => Yii::t('app', 'decClosedAt'),
  157. 'DEC_LV' => Yii::t('app', 'decLv'),
  158. 'EMP_LV' => Yii::t('app', 'empLv'),
  159. 'CROWN_LV' => Yii::t('app', 'crownLv'),
  160. 'PROVINCE' => Yii::t('app', 'province'),
  161. 'CITY' => Yii::t('app', 'city'),
  162. 'COUNTY' => Yii::t('app', 'county'),
  163. 'TEL' => Yii::t('app', 'tel'),
  164. 'SUB_COM_ID' => Yii::t('app', 'subComID'),
  165. 'AVATAR' => Yii::t('app', 'avatar'),
  166. 'DELETED' => Yii::t('app', 'deleted'),
  167. 'DELETED_AT' => Yii::t('app', 'deletedAt'),
  168. 'IS_DEC' => Yii::t('app', 'isDec'),
  169. 'IS_ATLAS' => Yii::t('app', 'isAtlas'),
  170. 'IS_RECHARGE' => Yii::t('app', 'isRecharge'),
  171. 'DEC_ID' => Yii::t('app', 'DEC_ID'),
  172. 'BIRTHDAY' => Yii::t('app', 'birthday'),
  173. 'DEC_ROLE_ID' => Yii::t('app', 'decRoleID'),
  174. 'PERIOD_AT' => Yii::t('app', 'periodAt'),
  175. 'DEC_PROVINCE' => Yii::t('app', 'decProvince'),
  176. 'DEC_CITY' => Yii::t('app', 'decCity'),
  177. 'DEC_COUNTY' => Yii::t('app', 'decCounty'),
  178. 'IS_UNION' => Yii::t('app', 'isUnion'),
  179. 'STATUS_AT' => Yii::t('app', 'statusAt'),
  180. 'VERIFIED' => Yii::t('app', 'verified'),
  181. 'VERIFIED_AT' => Yii::t('app', 'verifiedAt'),
  182. 'ALLOW_LOGIN' => Yii::t('app', 'allowLogin'),
  183. 'NOT_OPERATING' => Yii::t('app', 'notOperating'),
  184. 'REG_FROM' => Yii::t('app', 'regFrom'),
  185. 'ID_CARD_PREFIX' => Yii::t('app', 'IDCardPrefix'),
  186. 'SEX' => Yii::t('app', 'sex'),
  187. 'DEC_ACCOUNT_OLD' => Yii::t('app', 'decAccountOld'),
  188. 'BANK_UPDATED_AT' => Yii::t('app', 'bankUpdatedAt'),
  189. 'IS_DIRECT_SELLER' => Yii::t('app', 'isDirectSeller'),
  190. 'DEC_LV_UPDATED_AT' => Yii::t('app', 'decLvUpdatedAt'),
  191. 'DEC_LV_UPDATED_PERIOD' => Yii::t('app', 'decLvUpdatedPeriod'),
  192. 'DEC_ADDRESS' => Yii::t('app', 'decAddress'),
  193. 'DEC_PHONE' => Yii::t('app', 'decPhone'),
  194. 'GUARANTOR' => Yii::t('app', 'guarantor'),
  195. 'GUARANTOR_NAME' => Yii::t('app', 'guarantorName'),
  196. 'PART_FUNC_CLOSED' => Yii::t('app', 'partFuncClosed'),
  197. 'LAST_DEC_LV_UPDATED_PERIOD' => Yii::t('app', 'lastDecLvUpdatedPeriod'),
  198. 'USER_CREATOR' => Yii::t('app', 'userCreator'),
  199. 'USER_UPDATER' => Yii::t('app', 'userUpdater'),
  200. 'LAST_DEC_LV_UPDATED_AT' => Yii::t('app', 'lastDecLvUpdatedAt'),
  201. 'DEC_CREATED_AT' => Yii::t('app', 'decCreatedAt'),
  202. 'PART_FUNC_CLOSED_REMARK' => Yii::t('app', 'partFuncClosedRemark'),
  203. 'DEC_CREATED_PERIOD' => Yii::t('app', 'decCreatedPeriod'),
  204. 'PASSWORD_CHANGED' => Yii::t('app', 'passwordChanged'),
  205. 'SUB_COM_LEADER' => Yii::t('app', 'subComLeader'),
  206. 'ZG_UPGRADE_PV' => Yii::t('app', 'zgUpgradePv'),
  207. 'APP_CLIENT_ID' => Yii::t('app', 'appClientID'),
  208. 'READ_AGREEMENT' => Yii::t('app', 'readAgreement'),
  209. 'LAST_DEC_LV' => Yii::t('app', 'lastDecLv'),
  210. 'BONUS_APP_CLIENT_ID' => Yii::t('app', 'bonusAppClientID'),
  211. 'IS_FIRST_OPEN' => Yii::t('app', 'isFirstOpen'),
  212. 'IS_MODIFY_PASSWORD' => Yii::t('app', 'isModifyPassword'),
  213. 'IS_STUDIO' => Yii::t('app', 'isStudio'),
  214. 'EMAIL' => Yii::t('app', 'email'),
  215. 'COUNTRY_ID' => Yii::t('app', 'country'),
  216. ];
  217. }
  218. public function getUserInfo()
  219. {
  220. return $this->hasOne(UserInfo::class, ['USER_ID' => 'ID']);
  221. }
  222. /**
  223. * 获取会员基本信息
  224. * @param $userId
  225. * @return array|null|\yii\db\ActiveRecord
  226. */
  227. public static function getBaseInfo($userId){
  228. return static::findUseSlaves()->where('ID=:ID', [':ID'=>$userId])->asArray()->one();
  229. }
  230. /**
  231. * 获取用户基本信息从redis里面
  232. * @param $userId
  233. * @return array|null|\yii\db\ActiveRecord
  234. */
  235. public static function getBaseInfoFromRedis($userId){
  236. $userInfo = Yii::$app->redis->hget(Cache::USER_INFO_KEY, $userId);
  237. if(!$userInfo){
  238. $userInfo = static::find()->select('ID,USER_NAME,NATION,COUNTRY_ID,LANGUAGE_ID,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();
  239. Yii::$app->redis->hset(Cache::USER_INFO_KEY, $userId, Json::encode($userInfo));
  240. } else {
  241. $userInfo = Json::decode($userInfo);
  242. }
  243. return $userInfo;
  244. }
  245. /**
  246. * 更新缓存
  247. * @param $userId
  248. * @return mixed
  249. */
  250. public static function updateBaseInfoToRedis($userId){
  251. $userInfo = static::find()->select('ID,USER_NAME,NATION,COUNTRY_ID,LANGUAGE_ID,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();
  252. return Yii::$app->redis->hset(Cache::USER_INFO_KEY, $userId, Json::encode($userInfo));
  253. }
  254. /**
  255. * @param $userId
  256. * 删除用户信息缓存
  257. */
  258. public static function deleteBaseInfoFromRedis($userId) {
  259. Yii::$app->redis->hdel(Cache::USER_INFO_KEY, $userId);
  260. }
  261. /**
  262. * 批量删除用户
  263. * @return void
  264. */
  265. public static function deleteAllBaseInfoFromRedis() {
  266. \Yii::$app->redis->del(Cache::USER_INFO_KEY);
  267. }
  268. /**
  269. * 判断用户是否是观察期
  270. * 观望期:自加入算起2个月
  271. * 例子:2022年5月14日加入, 观望期至2022年7月31日。
  272. * true为是观察期用户 false为不是观察期用户
  273. */
  274. public static function checkIsObserve($addAt, $month) {
  275. if (empty($month)) {
  276. // 如果0 代表全站全额升级
  277. return false;
  278. }
  279. $appendMonth = date("Y-m", strtotime("first day of +$month month", $addAt)); // 指定月份
  280. $lastDay = date("t", strtotime($appendMonth)); // 获取指定月的最后一天
  281. $eTime = strtotime($appendMonth.'-'.$lastDay);
  282. return time() < $eTime;
  283. }
  284. // 获取用户报单PV总和
  285. public static function sumDevPvByUserId($userId) {
  286. $decOrderPv = DecOrder::find()
  287. ->select('SUM(DEC_PV) AS PV_SUM')
  288. ->where('TO_USER_ID=:TO_USER_ID AND IS_DEL=0',
  289. ['TO_USER_ID'=>$userId]
  290. )
  291. ->asArray()
  292. ->one();
  293. $decOrderPv = isset($decOrderPv['PV_SUM']) ? $decOrderPv['PV_SUM'] : 0;
  294. $orderDecPv = OrderDec::find()
  295. ->select('SUM(PAY_PV) AS PV_SUM')
  296. ->where('USER_ID=:USER_ID AND IS_DELETE=0',
  297. [
  298. 'USER_ID'=>$userId,
  299. ]
  300. )
  301. ->asArray()
  302. ->one();
  303. $orderDecPv = isset($orderDecPv['PV_SUM']) ? $orderDecPv['PV_SUM'] : 0;
  304. // 还得加上用户在老系统中的所有报单PV之和
  305. $originPv = OriginDecPv::find()
  306. ->select('SUM(DEC_PV) AS PV_SUM')
  307. ->where('USER_ID=:USER_ID',
  308. [
  309. 'USER_ID'=>$userId,
  310. ]
  311. )
  312. ->asArray()
  313. ->one();
  314. $originPv = isset($originPv['PV_SUM']) ? $originPv['PV_SUM'] : 0;
  315. $total = $orderDecPv + $decOrderPv + $originPv;
  316. return $total;
  317. }
  318. /**
  319. * 获取会员的部分信息并对敏感信息加密
  320. * @param $userId
  321. * @return array
  322. */
  323. public static function getEnCodeInfo($userId){
  324. $userInfo = self::getBaseInfoFromRedis($userId);
  325. return [
  326. 'ID' => $userId,
  327. 'USER_NAME' => $userInfo['USER_NAME'],
  328. 'NATION' => \Yii::$app->params['nation'][$userInfo['NATION']]['name']??'',
  329. 'NATION_ID' => \Yii::$app->params['nation'][$userInfo['NATION']]['id']??'',
  330. 'REAL_NAME' => $userInfo['REAL_NAME'],
  331. 'ID_CARD' => $userInfo['ID_CARD'],
  332. 'MOBILE' => $userInfo['MOBILE'],
  333. 'AVATAR' => $userInfo['AVATAR'],
  334. 'VERIFIED' => $userInfo['VERIFIED'],
  335. 'IS_UNION' => $userInfo['IS_UNION'],
  336. 'IS_DEC' => $userInfo['IS_DEC'],
  337. 'IS_ATLAS' => $userInfo['IS_ATLAS'],
  338. 'IS_RECHARGE' => $userInfo['IS_RECHARGE'],
  339. 'IS_STUDIO' => $userInfo['IS_STUDIO'],
  340. 'DEC_ROLE_ID' => $userInfo['DEC_ROLE_ID'],
  341. 'OPEN_BANK' => $userInfo['OPEN_BANK'],
  342. 'BANK_ADDRESS' => $userInfo['BANK_ADDRESS'],
  343. 'DEC_LV' => $userInfo['DEC_LV'] ?? DeclarationLevel::getDefaultLevelId(),
  344. 'EMP_LV' => $userInfo['EMP_LV'] ?? EmployLevel::getDefaultLevelId(),
  345. 'PROVINCE' => $userInfo['PROVINCE'],
  346. 'CITY' => $userInfo['CITY'],
  347. 'COUNTY' => $userInfo['COUNTY'],
  348. 'BANK_NO' => $userInfo['BANK_NO'],
  349. 'EMAIL' => $userInfo['EMAIL'] ?? '',
  350. 'COUNTRY_ID' => $userInfo['COUNTRY_ID'],
  351. 'LANGUAGE_ID' => $userInfo['LANGUAGE_ID'],
  352. ];
  353. }
  354. /**
  355. * 验证密码
  356. * @param $password
  357. * @return bool
  358. */
  359. public function validatePassword($password) {
  360. if( !$this->PASSWORD_HASH ) return false;
  361. return password_verify($password, $this->PASSWORD_HASH);
  362. }
  363. /**
  364. * 验证支付密码
  365. * @param $payPassword
  366. * @return bool
  367. */
  368. public function validatePasswordPay($payPassword) {
  369. if( !$this->PAY_PASSWORD ) return false;
  370. return password_verify($payPassword, $this->PAY_PASSWORD);
  371. }
  372. /**
  373. * 检验支付密码
  374. * @param $userId
  375. * @param $password
  376. * @return bool
  377. */
  378. public static function validatePayPassword($userId, $password){
  379. $oneUser = static::find()->select('PAY_PASSWORD')->where('ID=:ID', [':ID'=>$userId])->asArray()->one();
  380. if($oneUser){
  381. return password_verify($password, $oneUser['PAY_PASSWORD']);
  382. } else {
  383. return false;
  384. }
  385. }
  386. /**
  387. * 操作日志记录条件
  388. * @return array
  389. */
  390. public function attrLabelsWithLogType(){
  391. return [
  392. 'ID' => 'ID',
  393. 'USER_NAME' => '帐号',
  394. 'NATION' => [
  395. 'label' => '民族',
  396. 'type' => function($data){
  397. $value = $data['value'];
  398. return \Yii::$app->params['nation'][$value]['name']??'';
  399. },
  400. ],
  401. 'REAL_NAME' => '姓名',
  402. 'ID_CARD' => '身份证号',
  403. 'ID_TYPE' => [
  404. 'label' => '证件类型',
  405. 'type' => function($data){
  406. return '身份证';
  407. },
  408. ],
  409. 'MOBILE' => '手机号',
  410. 'ADDRESS' => '身份证地址',
  411. 'ID_IMAGE' => '证件图片',
  412. 'OPEN_BANK' => '开户行',
  413. 'BANK_ADDRESS' => '银行地址',
  414. 'BANK_NO' => '银行卡号',
  415. 'COUNTRY' => '国家',
  416. 'BANK_PROVINCE' => [
  417. 'label' => '银行省份',
  418. 'type' => ValueTypeConfig::REGION_TYPE
  419. ],
  420. 'BANK_CITY' => [
  421. 'label' => '银行城市',
  422. 'type' => ValueTypeConfig::REGION_TYPE
  423. ],
  424. 'BANK_COUNTY' => [
  425. 'label' => '银行县区',
  426. 'type' => ValueTypeConfig::REGION_TYPE
  427. ],
  428. 'SPOUSE_NAME' => '配偶姓名',
  429. 'SPOUSE_IDCARD' => '配偶证件号',
  430. 'STATUS' => [
  431. 'label' => '状态',
  432. 'type' => ValueTypeConfig::USER_STATUS_TYPE
  433. ],
  434. 'DEC_CLOSED' => [
  435. 'label' => '是否关闭报单功能',
  436. 'type' => ValueTypeConfig::YES_NO_TYPE,
  437. ],
  438. 'DEC_CLOSED_AT' => [
  439. 'label' => '关闭报单时间',
  440. 'type' => ValueTypeConfig::DATE_TIME_TYPE,
  441. ],
  442. 'DEC_LV' => [
  443. 'label' => '报单级别',
  444. 'type' => ValueTypeConfig::DEC_LV_TYPE,
  445. ],
  446. 'EMP_LV' => [
  447. 'label' => '聘级',
  448. 'type' => ValueTypeConfig::EMP_LV_TYPE,
  449. ],
  450. 'CROWN_LV' => [
  451. 'label' => '星级',
  452. 'type' => ValueTypeConfig::CROWN_LV_TYPE,
  453. ],
  454. 'LAST_DEC_LV' => [
  455. 'label' => '上次的报单级别',
  456. 'type' => ValueTypeConfig::DEC_LV_TYPE,
  457. ],
  458. 'PROVINCE' => [
  459. 'label' => '省份',
  460. 'type' => ValueTypeConfig::REGION_TYPE
  461. ],
  462. 'CITY' => [
  463. 'label' => '城市',
  464. 'type' => ValueTypeConfig::REGION_TYPE
  465. ],
  466. 'COUNTY' => [
  467. 'label' => '县区',
  468. 'type' => ValueTypeConfig::REGION_TYPE
  469. ],
  470. 'TEL' => '备用手机号码',
  471. 'SUB_COM_ID' => '分公司ID',
  472. 'TRANSFER_PROP' => '转帐比例',
  473. 'IS_DEC' => [
  474. 'label' => '是否为报单中心',
  475. 'type' => ValueTypeConfig::YES_NO_TYPE,
  476. ],
  477. 'DEC_ROLE_ID' => [
  478. 'label' => '报单中心级别',
  479. 'type' => ValueTypeConfig::DEC_ROLE_ID_TYPE,
  480. ],
  481. 'IS_UNION' => [
  482. 'label' => '是否为点位合作',
  483. 'type' => ValueTypeConfig::YES_NO_TYPE,
  484. ],
  485. 'STATUS_AT' => '状态修改时间',
  486. 'ALLOW_LOGIN' => [
  487. 'label' => '是否允许商城登录',
  488. 'type' => ValueTypeConfig::YES_NO_TYPE,
  489. ],
  490. 'NOT_OPERATING' => [
  491. 'label' => '不运作',
  492. 'type' => ValueTypeConfig::YES_NO_TYPE,
  493. ],
  494. 'BIRTHDAY' => '生日',
  495. 'SEX' => '性别',
  496. 'EMAIL' => 'Email'
  497. ];
  498. }
  499. }