BaUserForm.php 12 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236237238239240241242243244245246247248249250251252253254255256257258259260261262263264265266267268269270271272273274275276277278279280281282283284285286287288289
  1. <?php
  2. namespace common\models\forms;
  3. use common\components\Model;
  4. use common\helpers\Date;
  5. use common\helpers\Form;
  6. use common\helpers\snowflake\SnowFake;
  7. use common\helpers\user\Balance;
  8. use common\helpers\user\Info;
  9. use common\libs\logging\operate\UserOperate;
  10. use common\models\BaUser;
  11. use common\models\BaUserInfo;
  12. use common\models\Period;
  13. use common\models\DeclarationLevel;
  14. use common\models\EmployLevel;
  15. use common\models\User;
  16. use common\models\UserInfo;
  17. use common\models\UserNetwork;
  18. use common\models\UserRelation;
  19. use yii\db\Exception;
  20. /**
  21. * Login form
  22. */
  23. class BaUserForm extends Model
  24. {
  25. public $userId;
  26. public $userName;
  27. public $zcPv;
  28. public $zcAmount;
  29. public $conUserName;
  30. public $recUserName;
  31. public $conUid;
  32. public $recUid;
  33. public $location;
  34. public $idCard;
  35. public $allData; // 批量报单的全部报单数据
  36. //个人资料
  37. public $nation;
  38. public $realName;
  39. public $mobile;
  40. public $openBank;
  41. public $bankAddress;
  42. public $bankNo;
  43. public $email;
  44. //修改密码
  45. public $password;
  46. public $oldPassword;
  47. public $verifyPassword;
  48. public $payPassword;
  49. private $_conUid;
  50. private $_recUid;
  51. private $_limit = 1000;
  52. // private $_conTopUid;
  53. private $_conTopDeep;
  54. // private $_recTopUid;
  55. // private $_recTopDeep;
  56. public function init() {
  57. parent::init();
  58. $this->userOperateLogger = new UserOperate([
  59. 'fetchClass' => BaUser::class,
  60. ]);
  61. }
  62. /**
  63. * @inheritdoc
  64. */
  65. public function rules()
  66. {
  67. return [
  68. [['userId', 'userName', 'zcPv', 'zcAmount', 'conUserName', 'recUserName','conUid', 'recUid', 'location',/* 'nation', */'realName', /* 'mobile','openBank','bankAddress','bankNo', */ 'email'], 'trim'],
  69. [['userId', 'userName',/* 'zcPv', 'zcAmount',*/ 'conUid', 'recUid', 'location'], 'required', 'on'=>'addWithUid'],
  70. [['userId', 'userName',/* 'zcPv', 'zcAmount', 'conUserName', 'recUserName', 'location'*/], 'required', 'on'=>['addWithUserName', 'addByAdmin']],
  71. [['idCard', 'allData'], 'required', 'on'=>['addWithUserName']],
  72. [['userName'], 'required', 'on'=>['validateUser', 'noLoginModifyPassword']],
  73. [['conUid'], 'required', 'on'=>['validateCon', 'validateAddWithUid']],
  74. [['conUserName'], 'required', 'on'=>['validateConName', 'validateAddWithName']],
  75. [['recUid'], 'required', 'on'=>['validateRec', 'validateAddWithUid']],
  76. [['recUserName'], 'required', 'on'=>['validateRecName', 'validateAddWithName']],
  77. [['conUid', 'location'], 'required', 'on'=>['validateLocation', 'validateAddWithUid']],
  78. [['conUserName', 'location'], 'required', 'on'=>['validateLocationConName', 'validateAddWithName']],
  79. [[/* 'nation' ,*/'realName'/*, 'mobile', */ /*'idCard',*/ /* 'openBank', 'bankAddress', 'bankNo' *//*, 'email'*/], 'required', 'on'=>'modifyProfile'],
  80. [['oldPassword','verifyPassword'], 'required','on' => ['modifyPassword', 'modifyPasswordPay', 'noLoginModifyPassword']],
  81. [['password'], 'required','on' => ['modifyPassword', 'noLoginModifyPassword']],
  82. [['payPassword'], 'required','on' => ['modifyPasswordPay']],
  83. ['verifyPassword', 'compare', 'compareAttribute' => 'password' ,'message'=>'The two login passwords are inconsistent' ,'on' => ['modifyPassword', 'noLoginModifyPassword']],//两次登录密码输入不一致
  84. ['verifyPassword', 'compare', 'compareAttribute' => 'payPassword' ,'message'=>'The two payment passwords are inconsistent' ,'on' => ['modifyPasswordPay']],//两次支付密码输入不一致
  85. [['userId'], 'unique', 'targetClass'=>BaUserInfo::class, 'targetAttribute'=>'USER_ID', 'on' => ['addWithUserName', 'addWithUid', 'addByAdmin']],
  86. [['userName'], 'unique', 'targetClass'=>BaUserInfo::class, 'targetAttribute'=>'USER_NAME' , 'on' => ['addWithUserName', 'addWithUid', 'addByAdmin']],
  87. // [['conUid'], 'exist', 'targetClass'=>UserInfo::class, 'targetAttribute'=>'USER_ID', 'on' => ['addWithUserName', 'addWithUid', 'addByAdmin']],
  88. [['recUid'], 'exist', 'targetClass'=>UserInfo::class, 'targetAttribute'=>'USER_ID', 'on' => ['addWithUserName', 'addWithUid', 'addByAdmin']],
  89. // [['conUid'], 'isConUid', 'on' => ['addWithUserName', 'addWithUid', 'addByAdmin']],
  90. // [['recUid'], 'isRecUid', 'on' => ['addWithUserName', 'addWithUid', 'addByAdmin']],
  91. // [['conUserName'], 'exist', 'targetClass'=>UserInfo::class, 'targetAttribute'=>'USER_NAME', 'on' => ['addWithUserName', 'addWithUid', 'addByAdmin']],
  92. [['recUserName'], 'exist', 'targetClass'=>UserInfo::class, 'targetAttribute'=>'USER_NAME', 'on' => ['addWithUserName', 'addWithUid', 'addByAdmin']],
  93. // [['conUserName'], 'isCon', 'on' => ['addWithUserName', 'addWithUid', 'addByAdmin']],
  94. [['recUserName'], 'isRec', 'on' => ['addWithUserName', 'addWithUid', 'addByAdmin']],
  95. // [['location'], 'isLocation', 'on' => ['addWithUserName', 'addWithUid', 'addByAdmin']],
  96. //[['idCard'], 'isSameNetwork'],
  97. [[/*'zcPv',*/ 'zcAmount'], 'price', 'on' => ['addWithUserName', 'addWithUid', 'addByAdmin']],
  98. // [['zcPv'], 'isMinDecLevel', 'on' => ['addWithUserName', 'addWithUid', 'addByAdmin']],
  99. ];
  100. }
  101. public function attributeLabels()
  102. {
  103. return [
  104. 'userId' => '会员ID',
  105. 'conUserName' => '接点人账号',
  106. 'recUserName' => '开拓人帐号1',
  107. // 'location' => '区位',
  108. // 'nation' => '民族',
  109. //'realName' => '真实姓名',
  110. // 'idCard' => '身份证号',
  111. //'mobile' => '手机号',
  112. // 'openBank' => '银行名称',
  113. // 'bankAddress' => '开户支行',
  114. // 'bankNo' => '银行账号',
  115. 'verifyPassword' => 'Confirm password',//确认密码
  116. 'oldPassword' => 'Original password',//原密码
  117. 'password' => 'Login password',//登录密码
  118. 'payPassword' => 'Payment password',//支付密码
  119. 'email' => 'Email',
  120. ];
  121. }
  122. /**
  123. * 推荐人是否可用
  124. * @param $attribute
  125. * @param $params
  126. */
  127. public function isRec($attribute, $params){
  128. // 根据账号找到开拓人
  129. $oneRecUserInfo = User::findOneAsArray('USER_NAME=:USER_NAME', [':USER_NAME'=>$this->recUserName]);
  130. if($oneRecUserInfo && $oneRecUserInfo['STATUS']){
  131. $this->_recUid = $oneRecUserInfo['ID'];
  132. } else {
  133. $this->addError($attribute, '注册'.$this->userName.'时,开拓人'.$this->recUserName.'帐号无效或未激活');
  134. }
  135. }
  136. /**
  137. * 添加会员
  138. * @return UserInfo|null
  139. * @throws Exception
  140. */
  141. public function add(){
  142. if(!$this->validate()){
  143. return null;
  144. }
  145. $insertUid = $this->userId;
  146. $insertUserName = $this->userName;
  147. // $zcPv = $this->zcPv;
  148. // $conUid = $this->_conUid;
  149. $recUid = $this->_recUid;
  150. // $location = $this->location;
  151. // $db = \Yii::$app->db;
  152. // $transaction = $db->beginTransaction();
  153. try{
  154. // $periodObj = Period::instance();
  155. // $nowPeriodNum = $periodObj->getNowPeriodNum();
  156. // 查找接点人的体系信息
  157. // $conUserInfo = UserInfo::find()->where('USER_ID=:USER_ID', [':USER_ID'=>$conUid])->asArray()->one();
  158. // 加入会员信息
  159. $userInfoModel = new BaUserInfo();
  160. $userInfoModel->USER_ID = $insertUid;
  161. $userInfoModel->USER_NAME = $insertUserName;
  162. // $userInfoModel->ZC_PV = $zcPv;
  163. $userInfoModel->ZC_AMOUNT = $this->zcAmount;
  164. $userInfoModel->CON_UID = '';
  165. $userInfoModel->REC_UID = '';
  166. // $userInfoModel->SYSTEM_ID = $conUserInfo['SYSTEM_ID'];
  167. //$userInfoModel->PERIOD_NUM = $nowPeriodNum;
  168. $userInfoModel->CREATED_AT = Date::nowTime();
  169. // $userInfoModel->HIGHEST_EMP_LV = EmployLevel::getDefaultLevelId();
  170. $userInfoModel->ALLOW_TRANSFER = 1;
  171. // $userInfoModel->HIGHEST_EMP_LV_PERIOD = $nowPeriodNum;
  172. $userInfoModel->TRANSFER_PROP = 100.00;
  173. $userInfoModel->IS_GROUP_LEADER = 0;
  174. $userInfoModel->GROUP_LEADER_AT = 0;
  175. try {
  176. $q = $userInfoModel->save();
  177. }catch (Exception $e) {
  178. throw new Exception($e->getMessage());
  179. }
  180. // print_r($userInfoModel);exit;
  181. // if(!$userInfoModel->save()){
  182. // throw new Exception('会员信息更新失败');
  183. // }
  184. // exit;
  185. // 清空安置网络和开拓网络的顶点和顶点深度的数值
  186. // $this->_conTopUid = null;
  187. // $this->_conTopDeep = null;
  188. // $this->_recTopUid = null;
  189. // $this->_recTopDeep = null;
  190. // $transaction->commit();
  191. return $userInfoModel;
  192. } catch (Exception $e){
  193. throw new Exception($e->getMessage());
  194. // $transaction->rollBack();
  195. $this->addError('userId', $e->getMessage());
  196. return null;
  197. }
  198. }
  199. /**
  200. * 修改个人资料
  201. * @return User|null
  202. */
  203. public function modifyProfile(){
  204. if(!$this->validate()){
  205. return null;
  206. }
  207. $this->userOperateLogger->beforeUpdate(\Yii::$app->user->id,'ID',['select'=>'NATION,OPEN_BANK,BANK_NO,BANK_ADDRESS,EMAIL']);
  208. $uid = \Yii::$app->user->id;
  209. $model = BaUser::findOne(['ID'=>$uid]);
  210. // $model->NATION = $this->nation;
  211. // $model->OPEN_BANK = $this->openBank;
  212. // $model->BANK_NO = $this->bankNo;
  213. // $model->BANK_ADDRESS = $this->bankAddress;
  214. $model->EMAIL = $this->email;
  215. if(!$model->save()){
  216. $this->addErrors($model->getErrors());
  217. return null;
  218. }
  219. BaUser::updateBaseInfoToRedis($uid);
  220. $this->userOperateLogger->afterUpdate(\Yii::$app->user->id,'ID',['select'=>'NATION,OPEN_BANK,BANK_NO,BANK_ADDRESS']);
  221. $this->userOperateLogger->clean()->save([
  222. 'optType' => '会员修改资料',
  223. 'userId' => \Yii::$app->user->id,
  224. 'userName' => Info::getUserNameByUserId(\Yii::$app->user->id),
  225. ]);
  226. return $model;
  227. }
  228. /**
  229. * 修改密码
  230. */
  231. public function modifyPassword(){
  232. if(!$this->validate()){
  233. return null;
  234. }
  235. $uid = \Yii::$app->user->id;
  236. $model = BaUser::findOne(['ID'=>$uid]);
  237. if ( !$model->validatePassword($this->oldPassword) ) {
  238. $this->addError('modifyPassword', 'Original login password error');//原登录密码错误
  239. return false;
  240. }
  241. $model->PASSWORD_HASH = \Yii::$app->security->generatePasswordHash($this->password);
  242. if(!$model->save()){
  243. $this->addErrors($model->getErrors());
  244. return false;
  245. }
  246. return true;
  247. }
  248. /**
  249. * 修改支付密码
  250. */
  251. public function modifyPasswordPay(){
  252. if(!$this->validate()){
  253. return null;
  254. }
  255. $uid = \Yii::$app->user->id;
  256. $model = BaUser::findOne(['ID'=>$uid]);
  257. if ( !$model->validatePasswordPay($this->oldPassword) ) {
  258. $this->addError('modifyPasswordPay', 'Original payment password error');//原支付密码错误
  259. return false;
  260. }
  261. $model->PAY_PASSWORD = \Yii::$app->security->generatePasswordHash($this->payPassword);
  262. if(!$model->save()){
  263. $this->addErrors($model->getErrors());
  264. return false;
  265. }
  266. return true;
  267. }
  268. }