BaUserForm.php 8.8 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235
  1. <?php
  2. namespace common\models\forms;
  3. use common\components\Model;
  4. use common\helpers\Date;
  5. use common\helpers\user\Info;
  6. use common\libs\logging\operate\UserOperate;
  7. use common\models\BaUser;
  8. use common\models\BaUserInfo;
  9. use common\models\User;
  10. use common\models\UserInfo;
  11. use Yii;
  12. use yii\db\Exception;
  13. /**
  14. * Login form
  15. */
  16. class BaUserForm extends Model
  17. {
  18. public $userId;
  19. public $userName;
  20. public $zcPv;
  21. public $zcAmount;
  22. public $conUserName;
  23. public $recUserName;
  24. public $conUid;
  25. public $recUid;
  26. public $location;
  27. public $idCard;
  28. public $allData; // 批量报单的全部报单数据
  29. //个人资料
  30. public $nation;
  31. public $realName;
  32. public $mobile;
  33. public $openBank;
  34. public $bankAddress;
  35. public $bankNo;
  36. public $email;
  37. //修改密码
  38. public $password;
  39. public $oldPassword;
  40. public $verifyPassword;
  41. public $payPassword;
  42. private $_conUid;
  43. private $_recUid;
  44. private $_limit = 1000;
  45. private $_conTopDeep;
  46. public function init() {
  47. parent::init();
  48. $this->userOperateLogger = new UserOperate([
  49. 'fetchClass' => BaUser::class,
  50. ]);
  51. }
  52. /**
  53. * @inheritdoc
  54. */
  55. public function rules()
  56. {
  57. return [
  58. [['userId', 'userName', 'zcPv', 'zcAmount', 'conUserName', 'recUserName','conUid', 'recUid', 'location',/* 'nation', */'realName', /* 'mobile','openBank','bankAddress','bankNo', */ 'email'], 'trim'],
  59. [['userId', 'userName',/* 'zcPv', 'zcAmount',*/ 'conUid', 'recUid', 'location'], 'required', 'on'=>'addWithUid'],
  60. [['userId', 'userName',/* 'zcPv', 'zcAmount', 'conUserName',*/ 'recUserName', /*'location'*/], 'required', 'on'=>['addWithUserName', 'addByAdmin']],
  61. [['idCard', 'allData'], 'required', 'on'=>['addWithUserName']],
  62. [['userName'], 'required', 'on'=>['validateUser', 'noLoginModifyPassword']],
  63. [['conUid'], 'required', 'on'=>['validateCon', 'validateAddWithUid']],
  64. [['conUserName'], 'required', 'on'=>['validateConName', 'validateAddWithName']],
  65. [['recUid'], 'required', 'on'=>['validateRec', 'validateAddWithUid']],
  66. [['recUserName'], 'required', 'on'=>['validateRecName', 'validateAddWithName']],
  67. [['conUid', 'location'], 'required', 'on'=>['validateLocation', 'validateAddWithUid']],
  68. [['conUserName', 'location'], 'required', 'on'=>['validateLocationConName', 'validateAddWithName']],
  69. [[/* 'nation' ,*/'realName'/*, 'mobile', */ /*'idCard',*/ /* 'openBank', 'bankAddress', 'bankNo' *//*, 'email'*/], 'required', 'on'=>'modifyProfile'],
  70. [['oldPassword','verifyPassword'], 'required','on' => ['modifyPassword', 'modifyPasswordPay', 'noLoginModifyPassword']],
  71. [['password'], 'required','on' => ['modifyPassword', 'noLoginModifyPassword']],
  72. [['payPassword'], 'required','on' => ['modifyPasswordPay']],
  73. ['verifyPassword', 'compare', 'compareAttribute' => 'password' ,'message'=>'The two login passwords are inconsistent' ,'on' => ['modifyPassword', 'noLoginModifyPassword']],//两次登录密码输入不一致
  74. ['verifyPassword', 'compare', 'compareAttribute' => 'payPassword' ,'message'=>'The two payment passwords are inconsistent' ,'on' => ['modifyPasswordPay']],//两次支付密码输入不一致
  75. [['userId'], 'unique', 'targetClass'=>BaUserInfo::class, 'targetAttribute'=>'USER_ID', 'on' => ['addWithUserName', 'addWithUid', 'addByAdmin']],
  76. [['userName'], 'unique', 'targetClass'=>BaUserInfo::class, 'targetAttribute'=>'USER_NAME' , 'on' => ['addWithUserName', 'addWithUid', 'addByAdmin']],
  77. [['recUid'], 'exist', 'targetClass'=>UserInfo::class, 'targetAttribute'=>'USER_ID', 'on' => ['addWithUserName', 'addWithUid', 'addByAdmin']],
  78. [['recUid'], 'isRecUid', 'on' => ['addWithUserName', 'addWithUid', 'addByAdmin']],
  79. [['conUserName'], 'exist', 'targetClass'=>UserInfo::class, 'targetAttribute'=>'USER_NAME', 'on' => ['addWithUserName', 'addWithUid', 'addByAdmin']],
  80. [['recUserName'], 'exist', 'targetClass'=>UserInfo::class, 'targetAttribute'=>'USER_NAME', 'on' => ['addWithUserName', 'addWithUid', 'addByAdmin']],
  81. [['recUserName'], 'isRec', 'on' => ['addWithUserName', 'addWithUid', 'addByAdmin']],
  82. [[/*'zcPv',*/ 'zcAmount'], 'price', 'on' => ['addWithUserName', 'addWithUid', 'addByAdmin']],
  83. ];
  84. }
  85. public function attributeLabels()
  86. {
  87. return [
  88. 'userId' => '会员ID',
  89. 'recUserName' => '开拓人帐号',
  90. 'verifyPassword' => 'Confirm password',//确认密码
  91. 'oldPassword' => 'Original password',//原密码
  92. 'password' => 'Login password',//登录密码
  93. 'payPassword' => 'Payment password',//支付密码
  94. 'email' => 'Email',
  95. ];
  96. }
  97. /**
  98. * 推荐人是否可用
  99. * @param $attribute
  100. * @param $params
  101. */
  102. public function isRecUid($attribute, $params) {
  103. $this->_recUid = $this->recUid;
  104. }
  105. /**
  106. * 推荐人是否可用
  107. * @param $attribute
  108. * @param $params
  109. */
  110. public function isRec($attribute, $params){
  111. // 根据账号找到开拓人
  112. $oneRecUserInfo = User::findOneAsArray('USER_NAME=:USER_NAME', [':USER_NAME'=>$this->recUserName]);
  113. if($oneRecUserInfo && $oneRecUserInfo['STATUS']){
  114. $this->_recUid = $oneRecUserInfo['ID'];
  115. } else {
  116. $this->addError($attribute, '注册'.$this->userName.'时,开拓人'.$this->recUserName.'帐号无效或未激活');
  117. }
  118. }
  119. /**
  120. * 添加会员
  121. */
  122. public function add()
  123. {
  124. if(!$this->validate()){
  125. return null;
  126. }
  127. $insertUid = $this->userId;
  128. $insertUserName = $this->userName;
  129. $recUid = $this->_recUid;
  130. try {
  131. // 加入会员信息
  132. $userInfoModel = new BaUserInfo();
  133. $userInfoModel->USER_ID = $insertUid;
  134. $userInfoModel->USER_NAME = $insertUserName;
  135. $userInfoModel->ZC_AMOUNT = $this->zcAmount;
  136. $userInfoModel->CON_UID = '';
  137. $userInfoModel->REC_UID = $recUid;
  138. $userInfoModel->CREATED_AT = Date::nowTime();
  139. $userInfoModel->ALLOW_TRANSFER = 1;
  140. $userInfoModel->TRANSFER_PROP = 100.00;
  141. $userInfoModel->IS_GROUP_LEADER = 0;
  142. $userInfoModel->GROUP_LEADER_AT = 0;
  143. $userInfoModel->save();
  144. return $userInfoModel;
  145. } catch (Exception $e) {
  146. $this->addError('userId', $e->getMessage());
  147. return null;
  148. }
  149. }
  150. /**
  151. * 修改个人资料
  152. */
  153. public function modifyProfile(){
  154. if(!$this->validate()){
  155. return null;
  156. }
  157. $this->userOperateLogger->beforeUpdate(\Yii::$app->user->id,'ID',['select'=>'NATION,OPEN_BANK,BANK_NO,BANK_ADDRESS,EMAIL']);
  158. $uid = \Yii::$app->user->id;
  159. $model = BaUser::findOne(['ID'=>$uid]);
  160. $model->EMAIL = $this->email;
  161. if(!$model->save()){
  162. $this->addErrors($model->getErrors());
  163. return null;
  164. }
  165. BaUser::updateBaseInfoToRedis($uid);
  166. $this->userOperateLogger->afterUpdate(\Yii::$app->user->id,'ID',['select'=>'NATION,OPEN_BANK,BANK_NO,BANK_ADDRESS']);
  167. $this->userOperateLogger->clean()->save([
  168. 'optType' => '会员修改资料',
  169. 'userId' => \Yii::$app->user->id,
  170. 'userName' => Info::getUserNameByUserId(\Yii::$app->user->id),
  171. ]);
  172. return $model;
  173. }
  174. /**
  175. * 修改密码
  176. */
  177. public function modifyPassword(){
  178. if(!$this->validate()){
  179. return null;
  180. }
  181. $uid = \Yii::$app->user->id;
  182. $model = BaUser::findOne(['ID'=>$uid]);
  183. if ( !$model->validatePassword($this->oldPassword) ) {
  184. $this->addError('modifyPassword', Yii::t('app', 'originalLoginPasswordError'));
  185. return false;
  186. }
  187. $model->PASSWORD_HASH = \Yii::$app->security->generatePasswordHash($this->password);
  188. if(!$model->save()){
  189. $this->addErrors($model->getErrors());
  190. return false;
  191. }
  192. return true;
  193. }
  194. /**
  195. * 修改支付密码
  196. */
  197. public function modifyPasswordPay(){
  198. if(!$this->validate()){
  199. return null;
  200. }
  201. $uid = \Yii::$app->user->id;
  202. $model = BaUser::findOne(['ID'=>$uid]);
  203. if ( !$model->validatePasswordPay($this->oldPassword) ) {
  204. $this->addError('modifyPasswordPay', Yii::t('app', 'originalPaymentPasswordError'));
  205. return false;
  206. }
  207. $model->PAY_PASSWORD = \Yii::$app->security->generatePasswordHash($this->payPassword);
  208. if(!$model->save()){
  209. $this->addErrors($model->getErrors());
  210. return false;
  211. }
  212. return true;
  213. }
  214. }