Info.php 28 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236237238239240241242243244245246247248249250251252253254255256257258259260261262263264265266267268269270271272273274275276277278279280281282283284285286287288289290291292293294295296297298299300301302303304305306307308309310311312313314315316317318319320321322323324325326327328329330331332333334335336337338339340341342343344345346347348349350351352353354355356357358359360361362363364365366367368369370371372373374375376377378379380381382383384385386387388389390391392393394395396397398399400401402403404405406407408409410411412413414415416417418419420421422423424425426427428429430431432433434435436437438439440441442443444445446447448449450451452453454455456457458459460461462463464465466467468469470471472473474475476477478479480481482483484485486487488489490491492493494495496497498499500501502503504505506507508509510511512513514515516517518519520521522523524525526527528529530531532533534535536537538539540541542543544545546547548549550551552553554555556557558559560561562563564565566567568569570571572573574575576577578579580581582583584585586587588589590591592593594595596597598599600601602603604605606607608609610611612613614615616617618619620621622623624625626627628629630631632633634635636637638639640641642643644645646647648649650651652653654655656657658659660661662663664665666667668669670671672673674675676677678679680681682683684685686687688689690691692693694695696697698699700701702703704705706707708709710711712713714715716717718719720721722723724725726727728729730731732733734735736737738739740741742743744745746747748749750751752753754755756757758759760761762763764765766
  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. $baseInfo['CROWN_LV_NAME'] = Cache::getStarCrownLevelConfig()[$baseInfo['CROWN_LV']]['LEVEL_NAME'];
  258. // 获取会员报单级别
  259. $baseInfo['DEC_ROLE_NAME'] = '无';
  260. //民族
  261. $baseInfo['NATION_NAME'] = \Yii::$app->params['nation'][$baseInfo['NATION']]['name']??'';
  262. return $baseInfo;
  263. }
  264. /**
  265. * 基本信息及余额
  266. * @param $userId
  267. * @param $periodNum
  268. * @return array
  269. */
  270. public static function baseInfoWithBalance($userId, $periodNum = null) {
  271. $baseInfo = self::baseInfoZh($userId, $periodNum);
  272. if ($baseInfo) {
  273. $userBonus = self::BalanceInfo($userId);
  274. }
  275. return array_merge($baseInfo, $userBonus);
  276. }
  277. /**
  278. * 获取余额信息
  279. * @param $userId
  280. * @return array|int[]|null
  281. */
  282. public static function BalanceInfo($userId) {
  283. $userBonus = [
  284. 'BONUS' => 0,
  285. 'BONUS_FREEZE' => 0,
  286. 'CF' => 0,
  287. 'LX' => 0,
  288. 'QY_TOTAL' => 0,
  289. 'YC_TOTAL' => 0,
  290. 'FX_TOTAL' => 0,
  291. 'LS_TOTAL' => 0,
  292. 'CF_TOTAL' => 0,
  293. 'LX_TOTAL' => 0,
  294. 'FL_TOTAL' => 0,
  295. 'BT_TOTAL' => 0,
  296. 'FW_TOTAL' => 0,
  297. 'CASH' => 0,
  298. ];
  299. if ($userBonusResult = UserBonus::findOneAsArray(['USER_ID' => $userId])) {
  300. $userBonus = $userBonusResult;
  301. }
  302. if ($userCashResult = UserWallet::findOneAsArray(['USER_ID' => $userId])) {
  303. $userBonus['CASH'] = $userCashResult['CASH'];
  304. }
  305. return $userBonus;
  306. }
  307. /**
  308. * 基本信息带着网络和节点信息
  309. * @param $userId
  310. * @param $periodNum
  311. * @return array|null|\yii\db\ActiveRecord
  312. */
  313. public static function baseInfoWithNet($userId, $periodNum = null) {
  314. $baseInfo = self::baseInfoZh($userId, $periodNum);
  315. $baseInfo['CON_USER_NAME'] = '';
  316. $baseInfo['CON_REAL_NAME'] = '';
  317. $baseInfo['LOCATION'] = '';
  318. $baseInfo['REC_USER_NAME'] = '';
  319. $baseInfo['REC_REAL_NAME'] = '';
  320. $baseInfo['DEC_USER_NAME'] = '';
  321. $baseInfo['DEC_REAL_NAME'] = '';
  322. $baseInfo['DEC_DEC_LV'] = '';
  323. $baseInfo['DEC_DEC_LV_NAME'] = '';
  324. if ($baseInfo) {
  325. if (isset($baseInfo['CON_UID']) && $baseInfo['CON_UID']) {
  326. // 安置网上级
  327. //$netParentUserInfo = UserNetwork::getFirstParentUserInfo($userId);
  328. $netParentBaseInfo = self::baseInfo($baseInfo['CON_UID']);
  329. $networkParent = UserNetwork::findOneAsArray('USER_ID=:USER_ID', [':USER_ID' => $userId]);
  330. //$baseInfo['CON_UID'] = $baseInfo['CON_UID'];
  331. $baseInfo['CON_USER_NAME'] = $netParentBaseInfo['USER_NAME'];
  332. $baseInfo['CON_REAL_NAME'] = $netParentBaseInfo['REAL_NAME'];
  333. $baseInfo['LOCATION'] = $networkParent['RELATIVE_LOCATION'];
  334. }
  335. if (isset($baseInfo['REC_UID']) && $baseInfo['REC_UID']) {
  336. // 推荐网上级
  337. //$relationParentUserInfo = UserRelation::getFirstParentUserInfo($userId);
  338. $relationParentBaseInfo = self::baseInfo($baseInfo['REC_UID']);
  339. //$baseInfo['REC_UID'] = $relationParentUserInfo['USER_ID'];
  340. $baseInfo['REC_USER_NAME'] = $relationParentBaseInfo['USER_NAME'];
  341. $baseInfo['REC_REAL_NAME'] = $relationParentBaseInfo['REAL_NAME'];
  342. }
  343. if (isset($baseInfo['DEC_ID']) && $baseInfo['DEC_ID']) {
  344. $decBaseInfo = self::baseInfoZh($baseInfo['DEC_ID']);
  345. $baseInfo['DEC_USER_NAME'] = $decBaseInfo['USER_NAME'];
  346. $baseInfo['DEC_REAL_NAME'] = $decBaseInfo['REAL_NAME'];
  347. $baseInfo['DEC_DEC_LV'] = $decBaseInfo['DEC_LV'];
  348. $baseInfo['DEC_DEC_LV_NAME'] = $decBaseInfo['DEC_LV_NAME'];
  349. $baseInfo['DEC_DEC_ROLE_NAME'] = $decBaseInfo['DEC_ROLE_NAME'];
  350. $baseInfo['DEC_DEC_ROLE_ID'] = $decBaseInfo['DEC_ROLE_ID'];
  351. }
  352. }
  353. return $baseInfo;
  354. }
  355. /**
  356. * 基本信息含网络和余额
  357. * @param $userId
  358. * @param $periodNum
  359. * @return array
  360. */
  361. public static function baseInfoWithNetAndBalance($userId, $periodNum = null) {
  362. return array_merge(self::baseInfoWithNet($userId), self::BalanceInfo($userId));
  363. }
  364. /**
  365. * 通过用户名获取用户信息从INFO表
  366. * @param $userName
  367. * @return array|null|\yii\db\ActiveRecord
  368. */
  369. public static function getUserByUserNameFromUserInfoTable($userName) {
  370. return UserInfo::findOneAsArray(['USER_NAME' => $userName]);
  371. }
  372. /**
  373. * 获取报单级别
  374. * @param $userId
  375. * @param null $periodNum
  376. * @return mixed
  377. * @throws \yii\db\Exception
  378. */
  379. public static function getDecLv($userId, $periodNum = null) {
  380. if ($periodNum === null) {
  381. $data = User::findOneAsArray('ID=:ID', [':ID' => $userId], 'DEC_LV');
  382. $decLv = $data['DEC_LV'];
  383. } else {
  384. $period = Period::instance();
  385. $yearMonth = $period->getYearMonth($periodNum);
  386. $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();
  387. $decLv = $data ? $data['LAST_DEC_LV'] : DeclarationLevel::getDefaultLevelId();
  388. }
  389. return $decLv;
  390. }
  391. /**
  392. * 获取聘级
  393. * @param $userId
  394. * @param null $periodNum
  395. * @return mixed
  396. * @throws \yii\db\Exception
  397. */
  398. public static function getEmpLv($userId, $periodNum = null) {
  399. if ($periodNum === null) {
  400. $data = User::findOneAsArray('ID=:ID', [':ID' => $userId], 'EMP_LV');
  401. $empLv = $data['EMP_LV'];
  402. } else {
  403. $period = Period::instance();
  404. $yearMonth = $period->getYearMonth($periodNum);
  405. $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();
  406. $empLv = $data ? $data['LAST_EMP_LV'] : EmployLevel::getDefaultLevelId();
  407. }
  408. return $empLv;
  409. }
  410. /**
  411. * 获取最高聘级
  412. * @param $userId
  413. * @return mixed
  414. */
  415. public static function getHighEmpLv($userId){
  416. $data = UserInfo::findOneAsArray('USER_ID=:USER_ID', [':USER_ID' => $userId], 'HIGHEST_EMP_LV');
  417. $empLv = $data ? $data['HIGHEST_EMP_LV'] : EmployLevel::getDefaultLevelId();
  418. return $empLv;
  419. }
  420. /**
  421. * 获取报单级别名称
  422. * @param $userId
  423. * @param null $periodNum
  424. * @return mixed
  425. * @throws \yii\db\Exception
  426. */
  427. public static function getDecLvName($userId, $periodNum = null) {
  428. if (!$decLv = self::getDecLv($userId, $periodNum)) {
  429. $decLv = DeclarationLevel::getDefaultLevelId();
  430. }
  431. return Cache::getDecLevelConfig()[$decLv]['LEVEL_NAME'];
  432. }
  433. /**
  434. * 获取聘级名称
  435. * @param $userId
  436. * @param null $periodNum
  437. * @return mixed
  438. * @throws \yii\db\Exception
  439. */
  440. public static function getEmpLvName($userId, $periodNum = null) {
  441. if (!$empLv = self::getEmpLv($userId, $periodNum)) {
  442. $empLv = EmployLevel::getDefaultLevelId();
  443. }
  444. return Cache::getEmpLevelConfig()[$empLv]['LEVEL_NAME'];
  445. }
  446. /**
  447. * 获取民族对应的代码
  448. * @param $str
  449. * @return int|string
  450. */
  451. public static function getNationCode($str) {
  452. $str = preg_replace('/族$/', '', $str);
  453. $allNation = \Yii::$app->params['nation'];
  454. foreach ($allNation as $key => $nation) {
  455. if ($str . '族' == $nation['name']) {
  456. return $key;
  457. }
  458. }
  459. return 0;
  460. }
  461. /**
  462. * 生成用户名
  463. * @param string $prefix
  464. * @param int $length
  465. * @return string
  466. */
  467. public static function generateUserName(string $prefix = 'HZ', int $length = 10) {
  468. $result = Tool::randomString($length, $prefix).array_rand([0,1,2,3,5,6,7,8,9],1);
  469. if (User::find()->where('USER_NAME=:USER_NAME', [':USER_NAME' => $result])->exists()) {
  470. return self::generateUserName($prefix, $length);
  471. }
  472. return $result;
  473. }
  474. /**
  475. * 新增加的 生成前端姓名里用户名
  476. * @param string $prefix
  477. * @param int $length
  478. * @return string
  479. */
  480. public static function generateWebUserName(string $prefix = 'HZ', int $length = 10) {
  481. $result = Tool::randomString($length, $prefix).array_rand([0,1,2,3,5,6,7,8,9],1);
  482. if (substr($result ,-1) == '4'){
  483. return self::generateWebUserName($prefix, $length);
  484. }
  485. if (User::find()->where('USER_NAME=:USER_NAME', [':USER_NAME' => $result])->exists()) {
  486. return self::generateWebUserName($prefix, $length);
  487. }
  488. if (BaUser::find()->where('USER_NAME=:USER_NAME', [':USER_NAME' => $result])->exists()) {
  489. return self::generateWebUserName($prefix, $length);
  490. }
  491. return $result;
  492. }
  493. public static function generateWebName(string $countryId, int $length = 9) {
  494. // 名字前缀取国家简码
  495. $country = Countries::getById($countryId);
  496. $prefix = $country ? $country['CODE'] :'NG';
  497. $result = Tool::randomString($length, $prefix).array_rand([0,1,2,3,5,6,7,8,9],1);
  498. if (substr($result ,-1) == '4'){
  499. return self::generateWebUserName($prefix, $length);
  500. }
  501. if (User::find()->where('USER_NAME=:USER_NAME', [':USER_NAME' => $result])->exists()) {
  502. return self::generateWebUserName($prefix, $length);
  503. }
  504. if (BaUser::find()->where('USER_NAME=:USER_NAME', [':USER_NAME' => $result])->exists()) {
  505. return self::generateWebUserName($prefix, $length);
  506. }
  507. return $result;
  508. }
  509. /**
  510. * 定位会员的子公司
  511. * @param $userArea
  512. * @return array|bool
  513. */
  514. public static function location($userArea){
  515. if(!is_array($userArea)){
  516. $userArea = json_decode($userArea, true);
  517. }
  518. if(!$userArea || !isset($userArea[0])){
  519. return false;
  520. }
  521. //获取会员的所在省份
  522. $userProvince = $userArea[0];
  523. $list = [];
  524. if(!$list){
  525. return false;
  526. }
  527. $matched = [];
  528. $userCity = isset($userArea[1]) ? intval($userArea[1]) : 0;
  529. $userCounty = isset($userArea[2]) ? intval($userArea[2]) : 0;
  530. foreach($list as $row){
  531. $manageRange = json_decode($row['MANAGE_RANGE'], true);
  532. foreach($manageRange as $manage){
  533. // $manage = ["370000","371000","371082"] or ["210000",""];
  534. $pro = isset($manage[0]) ? intval($manage[0]) : 0;
  535. $city = isset($manage[1]) ? intval($manage[1]) : 0;
  536. $county = isset($manage[2]) ? intval($manage[2]) : 0;
  537. if($userProvince == $pro && $userCity == $city && $userCounty == $county){
  538. $matched = $row;
  539. break;
  540. }
  541. if($userProvince == $pro && $userCity == $city && $county == 0){
  542. $matched = $row;
  543. break;
  544. }
  545. if($userProvince == $pro && $city == 0 && $county == 0){
  546. $matched = $row;
  547. break;
  548. }
  549. }
  550. }
  551. unset($userCounty, $userCity, $userArea, $userProvince, $list);
  552. return $matched;
  553. }
  554. /**
  555. * 通过id获取身份证号
  556. * @param $userId
  557. * @return null
  558. */
  559. public static function getIdCardByUserId($userId) {
  560. $user = User::findOneAsArray('ID=:ID', [':ID' => $userId], 'ID_CARD');
  561. return $user ? $user['ID_CARD'] : null;
  562. }
  563. /**
  564. * 通过id获取状态
  565. * @param $userId
  566. * @return null
  567. */
  568. public static function getStatusByUserId($userId){
  569. $user = User::findOneAsArray('ID=:ID', [':ID' => $userId], 'STATUS');
  570. return $user ? $user['STATUS'] : null;
  571. }
  572. /**
  573. * 通过id获取期数
  574. * @param $userId
  575. * @return null
  576. */
  577. public static function getPeriodNumByUserId($userId) {
  578. $user = User::findOneAsArray('ID=:ID', [':ID' => $userId], 'PERIOD_AT');
  579. return $user ? $user['PERIOD_AT'] : null;
  580. }
  581. /**
  582. * 是否实名认证
  583. * @param $userId
  584. * @return bool
  585. */
  586. public static function isVerified($userId) {
  587. $user = User::findOneAsArray('ID=:ID', [':ID' => $userId], 'VERIFIED');
  588. if ($user && $user['VERIFIED'] == 1) return true;
  589. return false;
  590. }
  591. /**
  592. * 根据商城设置获取密码
  593. * @param $idCard
  594. * @param $userName
  595. * @param bool $payPwd
  596. * @return bool|string
  597. */
  598. public static function passwordGenerator($idCard,$userName,$payPwd=false) {
  599. $systemConfig = Cache::getSystemConfig();
  600. if($payPwd){
  601. $config = $systemConfig['payPasswordRule'];
  602. }else{
  603. $config = $systemConfig['passwordRule'];
  604. }
  605. $rule = $config['VALUE']; //id_s_6 , id_p_8, user_name 后台设置,分别为身份证的后6位,前8位或者用户名
  606. switch ($rule) {
  607. case 'id_s_6':
  608. $password = substr($idCard, -6);
  609. break;
  610. case 'id_p_8':
  611. $password = substr($idCard, 0, 8);
  612. break;
  613. case 'user_name':
  614. $password = $userName;
  615. break;
  616. default:
  617. $password = '111111';
  618. }
  619. return $password;
  620. }
  621. /**
  622. * 当时会员级别状态等
  623. * @param $userId
  624. * @return array|null
  625. */
  626. public static function getLastInfo($userId){
  627. $data = User::findOneAsArray('ID=:ID', [':ID' => $userId], 'LAST_DEC_LV AS DEC_LV,EMP_LV,LAST_EMP_LV,STATUS,CROWN_LV,LAST_CROWN_LV');
  628. return $data;
  629. }
  630. /**
  631. * 是否合作会员
  632. * @param $userId
  633. * @return bool
  634. */
  635. public static function isUnion($userId){
  636. $data = User::findOneAsArray('ID=:ID', [':ID' => $userId], 'IS_UNION');
  637. if ($data && $data['IS_UNION'] == 1) return true;
  638. return false;
  639. }
  640. /**
  641. * 获取Ba用户ID
  642. * @param $userName
  643. * @return mixed
  644. */
  645. public static function getBaUserIdByUserName($userName) {
  646. $user = BaUserInfo::findOneAsArray('USER_NAME=:USER_NAME AND DELETED=0', [':USER_NAME' => $userName], 'USER_ID');
  647. return $user ? $user['USER_ID'] : null;
  648. }
  649. /**
  650. * 获取会员名通过ID
  651. * @param $userId
  652. * @return mixed|null
  653. */
  654. public static function getBaUserNameByUserId($userId) {
  655. $user = BaUserInfo::findOneAsArray('USER_ID=:USER_ID AND DELETED=0', [':USER_ID' => $userId], 'USER_NAME');
  656. return $user ? $user['USER_NAME'] : null;
  657. }
  658. /**
  659. * 获取用户EMAIL
  660. * @param $userName
  661. * @return mixed
  662. */
  663. public static function getBaEmailByUserId($userId) {
  664. $user = BaUserInfo::findOneAsArray('USER_ID=:USER_ID AND DELETED=0', [':USER_ID' => $userId], 'USER_NAME');
  665. return $user ? $user['EMAIL'] : null;
  666. }
  667. /**
  668. * 获取会员姓名通过ID
  669. * @param $userId
  670. * @return null
  671. */
  672. public static function getBaUserRealNameByUserId($userId) {
  673. $user = BaUser::findOneAsArray('ID=:ID AND DELETED=0', [':ID' => $userId], 'REAL_NAME');
  674. return $user ? $user['REAL_NAME'] : null;
  675. }
  676. /**
  677. * 获取会员邮箱通过ID
  678. * @param $userId
  679. * @return null
  680. */
  681. public static function getBaUserEmailByUserId($userId) {
  682. $user = BaUser::findOneAsArray('ID=:ID AND DELETED=0', [':ID' => $userId], 'EMAIL');
  683. return $user ? $user['EMAIL'] : null;
  684. }
  685. /**
  686. * 获取手机号通过ID
  687. * @param $userId
  688. * @return null
  689. */
  690. public static function getBaUserMobileByUserId($userId) {
  691. $user = BaUser::findOneAsArray('ID=:ID AND DELETED=0', [':ID' => $userId], 'MOBILE');
  692. return $user ? $user['MOBILE'] : null;
  693. }
  694. /**
  695. * 通过用户ID获取用户的编号和名称
  696. * @param $userId
  697. * @return array|null
  698. */
  699. public static function getBaBaseUserById($userId) {
  700. return BaUser::findOneAsArray('ID=:ID', [':ID' => $userId], 'ID,USER_NAME,REAL_NAME');
  701. }
  702. /**
  703. * 通过用户ID获取用户的编号和名称
  704. * @param $username
  705. * @return array|null
  706. */
  707. public static function getBaBaseUserByUserName($username) {
  708. return BaUser::findOneAsArray('USER_NAME=:USER_NAME', [':USER_NAME' => $username]);
  709. }
  710. }