Info.php 28 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236237238239240241242243244245246247248249250251252253254255256257258259260261262263264265266267268269270271272273274275276277278279280281282283284285286287288289290291292293294295296297298299300301302303304305306307308309310311312313314315316317318319320321322323324325326327328329330331332333334335336337338339340341342343344345346347348349350351352353354355356357358359360361362363364365366367368369370371372373374375376377378379380381382383384385386387388389390391392393394395396397398399400401402403404405406407408409410411412413414415416417418419420421422423424425426427428429430431432433434435436437438439440441442443444445446447448449450451452453454455456457458459460461462463464465466467468469470471472473474475476477478479480481482483484485486487488489490491492493494495496497498499500501502503504505506507508509510511512513514515516517518519520521522523524525526527528529530531532533534535536537538539540541542543544545546547548549550551552553554555556557558559560561562563564565566567568569570571572573574575576577578579580581582583584585586587588589590591592593594595596597598599600601602603604605606607608609610611612613614615616617618619620621622623624625626627628629630631632633634635636637638639640641642643644645646647648649650651652653654655656657658659660661662663664665666667668669670671672673674675676677678679680681682683684685686687688689690691692693694695696697698699700701702703704705706707708709710711712713714715716717718719720721722723724725726727728729730731732733734735736737738739740741742743744745746747748749750751752753754755756757758759760761762763764765
  1. <?php
  2. /**
  3. * Created by PhpStorm.
  4. * User: leo
  5. * Date: 2018/11/2
  6. * Time: 上午9:16
  7. */
  8. namespace common\helpers\user;
  9. use common\components\ActiveQuery;
  10. use common\components\ActiveRecord;
  11. use common\helpers\Cache;
  12. use common\helpers\LoggerTool;
  13. use common\helpers\Tool;
  14. use common\models\BaUser;
  15. use common\models\BaUserInfo;
  16. use common\models\Config;
  17. use common\models\Countries;
  18. use common\models\PerfMonth;
  19. use common\models\PerfPeriod;
  20. use common\models\Period;
  21. use common\models\DeclarationLevel;
  22. use common\models\DecRole;
  23. use common\models\EmployLevel;
  24. use common\models\OpenBank;
  25. use common\models\Region;
  26. use common\models\StarCrownLevel;
  27. use common\models\User;
  28. use common\models\UserBonus;
  29. use common\models\UserInfo;
  30. use common\models\UserNetwork;
  31. use common\models\UserRelation;
  32. use common\models\UserSystem;
  33. use common\models\UserWallet;
  34. use Yii;
  35. use yii\base\Exception;
  36. class Info {
  37. /**
  38. * 获取用户ID
  39. * @param $userName
  40. * @return mixed
  41. */
  42. public static function getUserIdByUserName($userName) {
  43. $user = UserInfo::findOneAsArray('USER_NAME=:USER_NAME AND DELETED=0', [':USER_NAME' => $userName], 'USER_ID');
  44. return $user ? $user['USER_ID'] : null;
  45. }
  46. /**
  47. * 获取会员名通过ID
  48. * @param $userId
  49. * @return mixed|null
  50. */
  51. public static function getUserNameByUserId($userId) {
  52. $user = UserInfo::findOneAsArray('USER_ID=:USER_ID AND DELETED=0', [':USER_ID' => $userId], 'USER_NAME');
  53. return $user ? $user['USER_NAME'] : null;
  54. }
  55. /**
  56. * 获取用户EMAIL
  57. * @param $userName
  58. * @return mixed
  59. */
  60. public static function getEmailByUserId($userId) {
  61. $user = UserInfo::findOneAsArray('USER_ID=:USER_ID AND DELETED=0', [':USER_ID' => $userId], 'USER_NAME');
  62. return $user ? $user['EMAIL'] : null;
  63. }
  64. /**
  65. * 获取会员姓名通过ID
  66. * @param $userId
  67. * @return null
  68. */
  69. public static function getUserRealNameByUserId($userId) {
  70. $user = User::findOneAsArray('ID=:ID AND DELETED=0', [':ID' => $userId], 'REAL_NAME');
  71. return $user ? $user['REAL_NAME'] : null;
  72. }
  73. /**
  74. * 获取会员邮箱通过ID
  75. * @param $userId
  76. * @return null
  77. */
  78. public static function getUserEmailByUserId($userId) {
  79. $user = User::findOneAsArray('ID=:ID AND DELETED=0', [':ID' => $userId], 'EMAIL');
  80. return $user ? $user['EMAIL'] : null;
  81. }
  82. /**
  83. * 获取会员国家通过ID
  84. * @param $userId
  85. * @return null
  86. */
  87. public static function getUserCountryByUserId($userId) {
  88. $user = User::findOneAsArray('ID=:ID AND DELETED=0', [':ID' => $userId], 'COUNTRY_ID');
  89. return $user ? $user['COUNTRY_ID'] : null;
  90. }
  91. /**
  92. * 获取会员语言通过ID
  93. * @param $userId
  94. * @return null
  95. */
  96. public static function getUserLanguageByUserId($userId) {
  97. $user = User::findOneAsArray('ID=:ID AND DELETED=0', [':ID' => $userId], 'LANGUAGE_ID');
  98. return $user ? $user['LANGUAGE_ID'] : null;
  99. }
  100. /**
  101. * 获取手机号通过ID
  102. * @param $userId
  103. * @return null
  104. */
  105. public static function getUserMobileByUserId($userId) {
  106. $user = User::findOneAsArray('ID=:ID AND DELETED=0', [':ID' => $userId], 'MOBILE');
  107. return $user ? $user['MOBILE'] : null;
  108. }
  109. /**
  110. * 通过用户ID获取用户的编号和名称
  111. * @param $userId
  112. * @return array|null
  113. */
  114. public static function getBaseUserById($userId) {
  115. return User::findOneAsArray('ID=:ID', [':ID' => $userId], 'ID,USER_NAME,REAL_NAME');
  116. }
  117. /**
  118. * 通过用户ID获取用户的编号和名称
  119. * @param $username
  120. * @return array|null
  121. */
  122. public static function getBaseUserByUserName($username) {
  123. return User::findOneAsArray('USER_NAME=:USER_NAME', [':USER_NAME' => $username]);
  124. }
  125. /**
  126. * 当前期数的会员信息
  127. * @param $userId
  128. * @return array|\yii\db\ActiveRecord|null
  129. * @throws Exception
  130. */
  131. public static function baseInfoNowPeriod($userId) {
  132. $data = User::find()->where('ID=:ID', [':ID' => $userId])->asArray()->one();
  133. if (!$data) throw new Exception('Member does not exist'.$userId);//会员不存在
  134. $infoData = UserInfo::find()->where('USER_ID=:USER_ID', [':USER_ID' => $userId])->select('ZC_PV,CON_UID,REC_UID,CON_NUM,REC_NUM,NETWORK_DEEP,RELATION_DEEP,SYSTEM_ID,REG_TYPE,REG_NAME,CREDIT_CODE,PREMISES,LEGAL_PERSON,CLOSE_LOGIN,IS_BIND_MAIN,HIGHEST_EMP_LV,HIGHEST_EMP_LV_PERIOD,SHOULD_REG_TYPE,IS_SYSTEM_LEADER,ALLOW_TRANSFER,TRANSFER_PROP,IS_GROUP_LEADER,GROUP_LEADER_AT,SHOW_EMP_LV')->asArray()->one();
  135. if ($infoData) {
  136. $data = array_merge($data, $infoData);
  137. }
  138. if (!$data['DEC_LV']) $data['DEC_LV'] = DeclarationLevel::getDefaultLevelId();
  139. if (!$data['LAST_DEC_LV']) $data['LAST_DEC_LV'] = DeclarationLevel::getDefaultLevelId();
  140. if (!$data['EMP_LV']) $data['EMP_LV'] = EmployLevel::getDefaultLevelId();
  141. if (!$data['CROWN_LV']) $data['CROWN_LV'] = StarCrownLevel::getDefaultLevelId();
  142. return $data;
  143. }
  144. /**
  145. * 获取会员信息,通过用户编号
  146. * @param $userId
  147. * @return array|\yii\db\ActiveRecord|null
  148. * @throws Exception
  149. */
  150. public static function baseInfoByUserName($userName) {
  151. $data = User::find()->where('USER_NAME=:USER_NAME', [':USER_NAME' => $userName])->asArray()->one();
  152. if (!$data) throw new Exception('Member does not exist:'.$userName);//会员不存在
  153. $userId = $data['ID'];
  154. $infoData = UserInfo::find()
  155. ->where('USER_ID=:USER_ID', [':USER_ID' => $userId])
  156. ->select('ZC_PV,CON_UID,REC_UID,CON_NUM,REC_NUM,NETWORK_DEEP,RELATION_DEEP,SYSTEM_ID,REG_TYPE,REG_NAME,
  157. CREDIT_CODE,PREMISES,LEGAL_PERSON,CLOSE_LOGIN,IS_BIND_MAIN,HIGHEST_EMP_LV,HIGHEST_EMP_LV_PERIOD,
  158. SHOULD_REG_TYPE,IS_SYSTEM_LEADER,ALLOW_TRANSFER,TRANSFER_PROP,IS_GROUP_LEADER,GROUP_LEADER_AT,SHOW_EMP_LV')
  159. ->asArray()
  160. ->one();
  161. if ($infoData) {
  162. $data = array_merge($data, $infoData);
  163. }
  164. if (!$data['DEC_LV']) $data['DEC_LV'] = DeclarationLevel::getDefaultLevelId();
  165. if (!$data['LAST_DEC_LV']) $data['LAST_DEC_LV'] = DeclarationLevel::getDefaultLevelId();
  166. if (!$data['EMP_LV']) $data['EMP_LV'] = EmployLevel::getDefaultLevelId();
  167. return $data;
  168. }
  169. public static function baseInfoZhByUserName($userName) {
  170. $baseInfo = self::baseInfoByUserName($userName);
  171. // 状态处理
  172. $baseInfo['STATUS_NAME'] = Tool::paramConvert(Yii::$app->params['userStatus'])[$baseInfo['STATUS']]['label'];
  173. //登录状态
  174. $baseInfo['LOGIN_STATUS_NAME'] = $baseInfo['ALLOW_LOGIN'] == 0 ? '禁止登录' : '允许登录';
  175. // 子公司
  176. $baseInfo['SUB_COM_NAME'] = '';
  177. $baseInfo['PROVINCE_NAME'] = $baseInfo['PROVINCE'] ? Region::getCnName($baseInfo['PROVINCE']) : '';
  178. $baseInfo['CITY_NAME'] = $baseInfo['CITY'] ? Region::getCnName($baseInfo['CITY']) : '';
  179. $baseInfo['COUNTY_NAME'] = $baseInfo['COUNTY'] ? Region::getCnName($baseInfo['COUNTY']) : '';
  180. $baseInfo['BANK_PROVINCE_NAME'] = $baseInfo['BANK_PROVINCE'] ? Region::getCnName($baseInfo['BANK_PROVINCE']) : '';
  181. $baseInfo['BANK_CITY_NAME'] = $baseInfo['BANK_CITY'] ? Region::getCnName($baseInfo['BANK_CITY']) : '';
  182. $baseInfo['BANK_COUNTY_NAME'] = $baseInfo['BANK_COUNTY'] ? Region::getCnName($baseInfo['BANK_COUNTY']) : '';
  183. $baseInfo['OPEN_BANK_NAME'] = $baseInfo['OPEN_BANK'] ? OpenBank::getCnName($baseInfo['OPEN_BANK']) : '';
  184. // 获取会员体系
  185. $baseInfo['SYSTEM_NAME'] = '';
  186. // 获取会员级别名称
  187. $baseInfo['DEC_LV_NAME'] = Cache::getDecLevelConfig()[$baseInfo['DEC_LV']]['LEVEL_NAME'];
  188. $baseInfo['LAST_DEC_LV_NAME'] = Cache::getDecLevelConfig()[$baseInfo['LAST_DEC_LV']]['LEVEL_NAME'];
  189. $baseInfo['EMP_LV_NAME'] = Cache::getEmpLevelConfig()[$baseInfo['EMP_LV']]['LEVEL_NAME'];
  190. $baseInfo['HIGHEST_EMP_LV_NAME'] = '';
  191. // 获取会员报单级别
  192. $baseInfo['DEC_ROLE_NAME'] = '无';
  193. //民族
  194. $baseInfo['NATION_NAME'] = \Yii::$app->params['nation'][$baseInfo['NATION']]['name']??'';
  195. // 国家
  196. $baseInfo['COUNTRY_NAME'] = Countries::getById($baseInfo['COUNTRY_ID'])['NAME'] ?? '';
  197. return $baseInfo;
  198. }
  199. /**
  200. * 基本信息
  201. * @param $userId
  202. * @param $periodNum
  203. * @return array|\yii\db\ActiveRecord|null
  204. * @throws Exception
  205. */
  206. public static function baseInfo($userId, $periodNum = null) {
  207. if($periodNum == null){
  208. return self::baseInfoNowPeriod($userId);
  209. } else {
  210. // 获取当前期数
  211. $tableName = '{{%USER_ALL_'.$periodNum.'}}';
  212. if(ActiveRecord::isExistsTable($tableName, 'dbNetPoint')){
  213. if($data = \Yii::$app->dbNetPoint->createCommand("SELECT * FROM $tableName WHERE ID=:ID")->bindValues([':ID'=>$userId])->queryOne()) {
  214. if (!$data['DEC_LV']) $data['DEC_LV'] = DeclarationLevel::getDefaultLevelId();
  215. if (!$data['LAST_DEC_LV']) $data['LAST_DEC_LV'] = DeclarationLevel::getDefaultLevelId();
  216. if (!$data['EMP_LV']) $data['EMP_LV'] = EmployLevel::getDefaultLevelId();
  217. if (!$data['CROWN_LV']) $data['CROWN_LV'] = StarCrownLevel::getDefaultLevelId();
  218. if (!$data['HIGHEST_EMP_LV']) $data['HIGHEST_EMP_LV'] = EmployLevel::getDefaultLevelId();
  219. return $data;
  220. }else{
  221. return self::baseInfoNowPeriod($userId);
  222. }
  223. } else {
  224. return self::baseInfoNowPeriod($userId);
  225. }
  226. }
  227. }
  228. /**
  229. * 基本信息含中文地区和中文子公司
  230. * @param $userId
  231. * @param $periodNum
  232. * @return array|\yii\db\ActiveRecord|null
  233. * @throws Exception
  234. */
  235. public static function baseInfoZh($userId, $periodNum = null) {
  236. $baseInfo = self::baseInfo($userId, $periodNum);
  237. // 状态处理
  238. $baseInfo['STATUS_NAME'] = Tool::paramConvert(Yii::$app->params['userStatus'])[$baseInfo['STATUS']]['label'];
  239. //登录状态
  240. $baseInfo['LOGIN_STATUS_NAME'] = $baseInfo['ALLOW_LOGIN'] == 0 ? '禁止登录' : '允许登录';
  241. // 子公司
  242. $baseInfo['SUB_COM_NAME'] = '';
  243. $baseInfo['PROVINCE_NAME'] = $baseInfo['PROVINCE'] ? Region::getCnName($baseInfo['PROVINCE']) : '';
  244. $baseInfo['CITY_NAME'] = $baseInfo['CITY'] ? Region::getCnName($baseInfo['CITY']) : '';
  245. $baseInfo['COUNTY_NAME'] = $baseInfo['COUNTY'] ? Region::getCnName($baseInfo['COUNTY']) : '';
  246. $baseInfo['BANK_PROVINCE_NAME'] = $baseInfo['BANK_PROVINCE'] ? Region::getCnName($baseInfo['BANK_PROVINCE']) : '';
  247. $baseInfo['BANK_CITY_NAME'] = $baseInfo['BANK_CITY'] ? Region::getCnName($baseInfo['BANK_CITY']) : '';
  248. $baseInfo['BANK_COUNTY_NAME'] = $baseInfo['BANK_COUNTY'] ? Region::getCnName($baseInfo['BANK_COUNTY']) : '';
  249. $baseInfo['OPEN_BANK_NAME'] = $baseInfo['OPEN_BANK'] ? OpenBank::getCnName($baseInfo['OPEN_BANK']) : '';
  250. // 获取会员体系
  251. $baseInfo['SYSTEM_NAME'] = '';
  252. // 获取会员级别名称
  253. $baseInfo['DEC_LV_NAME'] = Cache::getDecLevelConfig()[$baseInfo['DEC_LV']]['LEVEL_NAME'];
  254. $baseInfo['LAST_DEC_LV_NAME'] = Cache::getDecLevelConfig()[$baseInfo['LAST_DEC_LV']]['LEVEL_NAME'];
  255. $baseInfo['EMP_LV_NAME'] = Cache::getEmpLevelConfig()[$baseInfo['EMP_LV']]['LEVEL_NAME'];
  256. $baseInfo['HIGHEST_EMP_LV_NAME'] = '';
  257. // 获取会员报单级别
  258. $baseInfo['DEC_ROLE_NAME'] = '无';
  259. //民族
  260. $baseInfo['NATION_NAME'] = \Yii::$app->params['nation'][$baseInfo['NATION']]['name']??'';
  261. return $baseInfo;
  262. }
  263. /**
  264. * 基本信息及余额
  265. * @param $userId
  266. * @param $periodNum
  267. * @return array
  268. */
  269. public static function baseInfoWithBalance($userId, $periodNum = null) {
  270. $baseInfo = self::baseInfoZh($userId, $periodNum);
  271. if ($baseInfo) {
  272. $userBonus = self::BalanceInfo($userId);
  273. }
  274. return array_merge($baseInfo, $userBonus);
  275. }
  276. /**
  277. * 获取余额信息
  278. * @param $userId
  279. * @return array|int[]|null
  280. */
  281. public static function BalanceInfo($userId) {
  282. $userBonus = [
  283. 'BONUS' => 0,
  284. 'BONUS_FREEZE' => 0,
  285. 'CF' => 0,
  286. 'LX' => 0,
  287. 'QY_TOTAL' => 0,
  288. 'YC_TOTAL' => 0,
  289. 'FX_TOTAL' => 0,
  290. 'LS_TOTAL' => 0,
  291. 'CF_TOTAL' => 0,
  292. 'LX_TOTAL' => 0,
  293. 'FL_TOTAL' => 0,
  294. 'BT_TOTAL' => 0,
  295. 'FW_TOTAL' => 0,
  296. 'CASH' => 0,
  297. ];
  298. if ($userBonusResult = UserBonus::findOneAsArray(['USER_ID' => $userId])) {
  299. $userBonus = $userBonusResult;
  300. }
  301. if ($userCashResult = UserWallet::findOneAsArray(['USER_ID' => $userId])) {
  302. $userBonus['CASH'] = $userCashResult['CASH'];
  303. }
  304. return $userBonus;
  305. }
  306. /**
  307. * 基本信息带着网络和节点信息
  308. * @param $userId
  309. * @param $periodNum
  310. * @return array|null|\yii\db\ActiveRecord
  311. */
  312. public static function baseInfoWithNet($userId, $periodNum = null) {
  313. $baseInfo = self::baseInfoZh($userId, $periodNum);
  314. $baseInfo['CON_USER_NAME'] = '';
  315. $baseInfo['CON_REAL_NAME'] = '';
  316. $baseInfo['LOCATION'] = '';
  317. $baseInfo['REC_USER_NAME'] = '';
  318. $baseInfo['REC_REAL_NAME'] = '';
  319. $baseInfo['DEC_USER_NAME'] = '';
  320. $baseInfo['DEC_REAL_NAME'] = '';
  321. $baseInfo['DEC_DEC_LV'] = '';
  322. $baseInfo['DEC_DEC_LV_NAME'] = '';
  323. if ($baseInfo) {
  324. if (isset($baseInfo['CON_UID']) && $baseInfo['CON_UID']) {
  325. // 安置网上级
  326. //$netParentUserInfo = UserNetwork::getFirstParentUserInfo($userId);
  327. $netParentBaseInfo = self::baseInfo($baseInfo['CON_UID']);
  328. $networkParent = UserNetwork::findOneAsArray('USER_ID=:USER_ID', [':USER_ID' => $userId]);
  329. //$baseInfo['CON_UID'] = $baseInfo['CON_UID'];
  330. $baseInfo['CON_USER_NAME'] = $netParentBaseInfo['USER_NAME'];
  331. $baseInfo['CON_REAL_NAME'] = $netParentBaseInfo['REAL_NAME'];
  332. $baseInfo['LOCATION'] = $networkParent['RELATIVE_LOCATION'];
  333. }
  334. if (isset($baseInfo['REC_UID']) && $baseInfo['REC_UID']) {
  335. // 推荐网上级
  336. //$relationParentUserInfo = UserRelation::getFirstParentUserInfo($userId);
  337. $relationParentBaseInfo = self::baseInfo($baseInfo['REC_UID']);
  338. //$baseInfo['REC_UID'] = $relationParentUserInfo['USER_ID'];
  339. $baseInfo['REC_USER_NAME'] = $relationParentBaseInfo['USER_NAME'];
  340. $baseInfo['REC_REAL_NAME'] = $relationParentBaseInfo['REAL_NAME'];
  341. }
  342. if (isset($baseInfo['DEC_ID']) && $baseInfo['DEC_ID']) {
  343. $decBaseInfo = self::baseInfoZh($baseInfo['DEC_ID']);
  344. $baseInfo['DEC_USER_NAME'] = $decBaseInfo['USER_NAME'];
  345. $baseInfo['DEC_REAL_NAME'] = $decBaseInfo['REAL_NAME'];
  346. $baseInfo['DEC_DEC_LV'] = $decBaseInfo['DEC_LV'];
  347. $baseInfo['DEC_DEC_LV_NAME'] = $decBaseInfo['DEC_LV_NAME'];
  348. $baseInfo['DEC_DEC_ROLE_NAME'] = $decBaseInfo['DEC_ROLE_NAME'];
  349. $baseInfo['DEC_DEC_ROLE_ID'] = $decBaseInfo['DEC_ROLE_ID'];
  350. }
  351. }
  352. return $baseInfo;
  353. }
  354. /**
  355. * 基本信息含网络和余额
  356. * @param $userId
  357. * @param $periodNum
  358. * @return array
  359. */
  360. public static function baseInfoWithNetAndBalance($userId, $periodNum = null) {
  361. return array_merge(self::baseInfoWithNet($userId), self::BalanceInfo($userId));
  362. }
  363. /**
  364. * 通过用户名获取用户信息从INFO表
  365. * @param $userName
  366. * @return array|null|\yii\db\ActiveRecord
  367. */
  368. public static function getUserByUserNameFromUserInfoTable($userName) {
  369. return UserInfo::findOneAsArray(['USER_NAME' => $userName]);
  370. }
  371. /**
  372. * 获取报单级别
  373. * @param $userId
  374. * @param null $periodNum
  375. * @return mixed
  376. * @throws \yii\db\Exception
  377. */
  378. public static function getDecLv($userId, $periodNum = null) {
  379. if ($periodNum === null) {
  380. $data = User::findOneAsArray('ID=:ID', [':ID' => $userId], 'DEC_LV');
  381. $decLv = $data['DEC_LV'];
  382. } else {
  383. $period = Period::instance();
  384. $yearMonth = $period->getYearMonth($periodNum);
  385. $data = PerfPeriod::find()->yearMonth($yearMonth)->select('LAST_DEC_LV')->where('USER_ID=:USER_ID AND PERIOD_NUM=:PERIOD_NUM', [':USER_ID' => $userId, ':PERIOD_NUM' => $periodNum])->asArray()->one();
  386. $decLv = $data ? $data['LAST_DEC_LV'] : DeclarationLevel::getDefaultLevelId();
  387. }
  388. return $decLv;
  389. }
  390. /**
  391. * 获取聘级
  392. * @param $userId
  393. * @param null $periodNum
  394. * @return mixed
  395. * @throws \yii\db\Exception
  396. */
  397. public static function getEmpLv($userId, $periodNum = null) {
  398. if ($periodNum === null) {
  399. $data = User::findOneAsArray('ID=:ID', [':ID' => $userId], 'EMP_LV');
  400. $empLv = $data['EMP_LV'];
  401. } else {
  402. $period = Period::instance();
  403. $yearMonth = $period->getYearMonth($periodNum);
  404. $data = PerfMonth::find()->yearMonth($yearMonth)->select('LAST_EMP_LV')->where('USER_ID=:USER_ID AND CALC_MONTH=:CALC_MONTH', [':USER_ID' => $userId, ':CALC_MONTH' => $yearMonth])->asArray()->one();
  405. $empLv = $data ? $data['LAST_EMP_LV'] : EmployLevel::getDefaultLevelId();
  406. }
  407. return $empLv;
  408. }
  409. /**
  410. * 获取最高聘级
  411. * @param $userId
  412. * @return mixed
  413. */
  414. public static function getHighEmpLv($userId){
  415. $data = UserInfo::findOneAsArray('USER_ID=:USER_ID', [':USER_ID' => $userId], 'HIGHEST_EMP_LV');
  416. $empLv = $data ? $data['HIGHEST_EMP_LV'] : EmployLevel::getDefaultLevelId();
  417. return $empLv;
  418. }
  419. /**
  420. * 获取报单级别名称
  421. * @param $userId
  422. * @param null $periodNum
  423. * @return mixed
  424. * @throws \yii\db\Exception
  425. */
  426. public static function getDecLvName($userId, $periodNum = null) {
  427. if (!$decLv = self::getDecLv($userId, $periodNum)) {
  428. $decLv = DeclarationLevel::getDefaultLevelId();
  429. }
  430. return Cache::getDecLevelConfig()[$decLv]['LEVEL_NAME'];
  431. }
  432. /**
  433. * 获取聘级名称
  434. * @param $userId
  435. * @param null $periodNum
  436. * @return mixed
  437. * @throws \yii\db\Exception
  438. */
  439. public static function getEmpLvName($userId, $periodNum = null) {
  440. if (!$empLv = self::getEmpLv($userId, $periodNum)) {
  441. $empLv = EmployLevel::getDefaultLevelId();
  442. }
  443. return Cache::getEmpLevelConfig()[$empLv]['LEVEL_NAME'];
  444. }
  445. /**
  446. * 获取民族对应的代码
  447. * @param $str
  448. * @return int|string
  449. */
  450. public static function getNationCode($str) {
  451. $str = preg_replace('/族$/', '', $str);
  452. $allNation = \Yii::$app->params['nation'];
  453. foreach ($allNation as $key => $nation) {
  454. if ($str . '族' == $nation['name']) {
  455. return $key;
  456. }
  457. }
  458. return 0;
  459. }
  460. /**
  461. * 生成用户名
  462. * @param string $prefix
  463. * @param int $length
  464. * @return string
  465. */
  466. public static function generateUserName(string $prefix = 'HZ', int $length = 10) {
  467. $result = Tool::randomString($length, $prefix).array_rand([0,1,2,3,5,6,7,8,9],1);
  468. if (User::find()->where('USER_NAME=:USER_NAME', [':USER_NAME' => $result])->exists()) {
  469. return self::generateUserName($prefix, $length);
  470. }
  471. return $result;
  472. }
  473. /**
  474. * 新增加的 生成前端姓名里用户名
  475. * @param string $prefix
  476. * @param int $length
  477. * @return string
  478. */
  479. public static function generateWebUserName(string $prefix = 'HZ', int $length = 10) {
  480. $result = Tool::randomString($length, $prefix).array_rand([0,1,2,3,5,6,7,8,9],1);
  481. if (substr($result ,-1) == '4'){
  482. return self::generateWebUserName($prefix, $length);
  483. }
  484. if (User::find()->where('USER_NAME=:USER_NAME', [':USER_NAME' => $result])->exists()) {
  485. return self::generateWebUserName($prefix, $length);
  486. }
  487. if (BaUser::find()->where('USER_NAME=:USER_NAME', [':USER_NAME' => $result])->exists()) {
  488. return self::generateWebUserName($prefix, $length);
  489. }
  490. return $result;
  491. }
  492. public static function generateWebName(string $countryId, int $length = 9) {
  493. // 名字前缀取国家简码
  494. $country = Countries::getById($countryId);
  495. $prefix = $country['CODE'] ?: 'NG';
  496. $result = Tool::randomString($length, $prefix).array_rand([0,1,2,3,5,6,7,8,9],1);
  497. if (substr($result ,-1) == '4'){
  498. return self::generateWebUserName($prefix, $length);
  499. }
  500. if (User::find()->where('USER_NAME=:USER_NAME', [':USER_NAME' => $result])->exists()) {
  501. return self::generateWebUserName($prefix, $length);
  502. }
  503. if (BaUser::find()->where('USER_NAME=:USER_NAME', [':USER_NAME' => $result])->exists()) {
  504. return self::generateWebUserName($prefix, $length);
  505. }
  506. return $result;
  507. }
  508. /**
  509. * 定位会员的子公司
  510. * @param $userArea
  511. * @return array|bool
  512. */
  513. public static function location($userArea){
  514. if(!is_array($userArea)){
  515. $userArea = json_decode($userArea, true);
  516. }
  517. if(!$userArea || !isset($userArea[0])){
  518. return false;
  519. }
  520. //获取会员的所在省份
  521. $userProvince = $userArea[0];
  522. $list = [];
  523. if(!$list){
  524. return false;
  525. }
  526. $matched = [];
  527. $userCity = isset($userArea[1]) ? intval($userArea[1]) : 0;
  528. $userCounty = isset($userArea[2]) ? intval($userArea[2]) : 0;
  529. foreach($list as $row){
  530. $manageRange = json_decode($row['MANAGE_RANGE'], true);
  531. foreach($manageRange as $manage){
  532. // $manage = ["370000","371000","371082"] or ["210000",""];
  533. $pro = isset($manage[0]) ? intval($manage[0]) : 0;
  534. $city = isset($manage[1]) ? intval($manage[1]) : 0;
  535. $county = isset($manage[2]) ? intval($manage[2]) : 0;
  536. if($userProvince == $pro && $userCity == $city && $userCounty == $county){
  537. $matched = $row;
  538. break;
  539. }
  540. if($userProvince == $pro && $userCity == $city && $county == 0){
  541. $matched = $row;
  542. break;
  543. }
  544. if($userProvince == $pro && $city == 0 && $county == 0){
  545. $matched = $row;
  546. break;
  547. }
  548. }
  549. }
  550. unset($userCounty, $userCity, $userArea, $userProvince, $list);
  551. return $matched;
  552. }
  553. /**
  554. * 通过id获取身份证号
  555. * @param $userId
  556. * @return null
  557. */
  558. public static function getIdCardByUserId($userId) {
  559. $user = User::findOneAsArray('ID=:ID', [':ID' => $userId], 'ID_CARD');
  560. return $user ? $user['ID_CARD'] : null;
  561. }
  562. /**
  563. * 通过id获取状态
  564. * @param $userId
  565. * @return null
  566. */
  567. public static function getStatusByUserId($userId){
  568. $user = User::findOneAsArray('ID=:ID', [':ID' => $userId], 'STATUS');
  569. return $user ? $user['STATUS'] : null;
  570. }
  571. /**
  572. * 通过id获取期数
  573. * @param $userId
  574. * @return null
  575. */
  576. public static function getPeriodNumByUserId($userId) {
  577. $user = User::findOneAsArray('ID=:ID', [':ID' => $userId], 'PERIOD_AT');
  578. return $user ? $user['PERIOD_AT'] : null;
  579. }
  580. /**
  581. * 是否实名认证
  582. * @param $userId
  583. * @return bool
  584. */
  585. public static function isVerified($userId) {
  586. $user = User::findOneAsArray('ID=:ID', [':ID' => $userId], 'VERIFIED');
  587. if ($user && $user['VERIFIED'] == 1) return true;
  588. return false;
  589. }
  590. /**
  591. * 根据商城设置获取密码
  592. * @param $idCard
  593. * @param $userName
  594. * @param bool $payPwd
  595. * @return bool|string
  596. */
  597. public static function passwordGenerator($idCard,$userName,$payPwd=false) {
  598. $systemConfig = Cache::getSystemConfig();
  599. if($payPwd){
  600. $config = $systemConfig['payPasswordRule'];
  601. }else{
  602. $config = $systemConfig['passwordRule'];
  603. }
  604. $rule = $config['VALUE']; //id_s_6 , id_p_8, user_name 后台设置,分别为身份证的后6位,前8位或者用户名
  605. switch ($rule) {
  606. case 'id_s_6':
  607. $password = substr($idCard, -6);
  608. break;
  609. case 'id_p_8':
  610. $password = substr($idCard, 0, 8);
  611. break;
  612. case 'user_name':
  613. $password = $userName;
  614. break;
  615. default:
  616. $password = '111111';
  617. }
  618. return $password;
  619. }
  620. /**
  621. * 当时会员级别状态等
  622. * @param $userId
  623. * @return array|null
  624. */
  625. public static function getLastInfo($userId){
  626. $data = User::findOneAsArray('ID=:ID', [':ID' => $userId], 'LAST_DEC_LV AS DEC_LV,EMP_LV,LAST_EMP_LV,STATUS,CROWN_LV,LAST_CROWN_LV');
  627. return $data;
  628. }
  629. /**
  630. * 是否合作会员
  631. * @param $userId
  632. * @return bool
  633. */
  634. public static function isUnion($userId){
  635. $data = User::findOneAsArray('ID=:ID', [':ID' => $userId], 'IS_UNION');
  636. if ($data && $data['IS_UNION'] == 1) return true;
  637. return false;
  638. }
  639. /**
  640. * 获取Ba用户ID
  641. * @param $userName
  642. * @return mixed
  643. */
  644. public static function getBaUserIdByUserName($userName) {
  645. $user = BaUserInfo::findOneAsArray('USER_NAME=:USER_NAME AND DELETED=0', [':USER_NAME' => $userName], 'USER_ID');
  646. return $user ? $user['USER_ID'] : null;
  647. }
  648. /**
  649. * 获取会员名通过ID
  650. * @param $userId
  651. * @return mixed|null
  652. */
  653. public static function getBaUserNameByUserId($userId) {
  654. $user = BaUserInfo::findOneAsArray('USER_ID=:USER_ID AND DELETED=0', [':USER_ID' => $userId], 'USER_NAME');
  655. return $user ? $user['USER_NAME'] : null;
  656. }
  657. /**
  658. * 获取用户EMAIL
  659. * @param $userName
  660. * @return mixed
  661. */
  662. public static function getBaEmailByUserId($userId) {
  663. $user = BaUserInfo::findOneAsArray('USER_ID=:USER_ID AND DELETED=0', [':USER_ID' => $userId], 'USER_NAME');
  664. return $user ? $user['EMAIL'] : null;
  665. }
  666. /**
  667. * 获取会员姓名通过ID
  668. * @param $userId
  669. * @return null
  670. */
  671. public static function getBaUserRealNameByUserId($userId) {
  672. $user = BaUser::findOneAsArray('ID=:ID AND DELETED=0', [':ID' => $userId], 'REAL_NAME');
  673. return $user ? $user['REAL_NAME'] : null;
  674. }
  675. /**
  676. * 获取会员邮箱通过ID
  677. * @param $userId
  678. * @return null
  679. */
  680. public static function getBaUserEmailByUserId($userId) {
  681. $user = BaUser::findOneAsArray('ID=:ID AND DELETED=0', [':ID' => $userId], 'EMAIL');
  682. return $user ? $user['EMAIL'] : null;
  683. }
  684. /**
  685. * 获取手机号通过ID
  686. * @param $userId
  687. * @return null
  688. */
  689. public static function getBaUserMobileByUserId($userId) {
  690. $user = BaUser::findOneAsArray('ID=:ID AND DELETED=0', [':ID' => $userId], 'MOBILE');
  691. return $user ? $user['MOBILE'] : null;
  692. }
  693. /**
  694. * 通过用户ID获取用户的编号和名称
  695. * @param $userId
  696. * @return array|null
  697. */
  698. public static function getBaBaseUserById($userId) {
  699. return BaUser::findOneAsArray('ID=:ID', [':ID' => $userId], 'ID,USER_NAME,REAL_NAME');
  700. }
  701. /**
  702. * 通过用户ID获取用户的编号和名称
  703. * @param $username
  704. * @return array|null
  705. */
  706. public static function getBaBaseUserByUserName($username) {
  707. return BaUser::findOneAsArray('USER_NAME=:USER_NAME', [':USER_NAME' => $username]);
  708. }
  709. }