/** * This method attempts changing user email. If user's "unconfirmed_email" field is empty is returns false, else if * somebody already has email that equals user's "unconfirmed_email" it returns false, otherwise returns true and * updates user's password. * * @param string $code * * @return bool * @throws \Exception */ public function attemptEmailChange($code) { // TODO refactor method /** @var Token $token */ $token = $this->finder->findToken(['user_id' => $this->id, 'code' => $code])->andWhere(['in', 'type', [Token::TYPE_CONFIRM_NEW_EMAIL, Token::TYPE_CONFIRM_OLD_EMAIL]])->one(); if (empty($this->unconfirmed_email) || $token === null || $token->isExpired) { Yii::$app->session->setFlash('danger', Yii::t('user', 'Your confirmation token is invalid or expired')); } else { $token->delete(); if (empty($this->unconfirmed_email)) { Yii::$app->session->setFlash('danger', Yii::t('user', 'An error occurred processing your request')); } elseif ($this->finder->findUser(['email' => $this->unconfirmed_email])->exists() == false) { if ($this->module->emailChangeStrategy == Module::STRATEGY_SECURE) { switch ($token->type) { case Token::TYPE_CONFIRM_NEW_EMAIL: $this->flags |= self::NEW_EMAIL_CONFIRMED; Yii::$app->session->setFlash('success', Yii::t('user', 'Awesome, almost there. Now you need to click the confirmation link sent to your old email address')); break; case Token::TYPE_CONFIRM_OLD_EMAIL: $this->flags |= self::OLD_EMAIL_CONFIRMED; Yii::$app->session->setFlash('success', Yii::t('user', 'Awesome, almost there. Now you need to click the confirmation link sent to your new email address')); break; } } if ($this->module->emailChangeStrategy == Module::STRATEGY_DEFAULT || $this->flags & self::NEW_EMAIL_CONFIRMED && $this->flags & self::OLD_EMAIL_CONFIRMED) { $this->email = $this->unconfirmed_email; $this->unconfirmed_email = null; Yii::$app->session->setFlash('success', Yii::t('user', 'Your email address has been changed')); } $this->save(false); //edit ucenter user email UcenterUtil::userEditEmail($this->username, $this->email); } } }
public function save() { if ($this->validate()) { $this->user->scenario = 'settings'; $this->user->username = $this->username; $this->user->password = $this->new_password; if ($this->email == $this->user->email && $this->user->unconfirmed_email != null) { $this->user->unconfirmed_email = null; } elseif ($this->email != $this->user->email) { switch ($this->module->emailChangeStrategy) { case Module::STRATEGY_INSECURE: $this->insecureEmailChange(); break; case Module::STRATEGY_DEFAULT: $this->defaultEmailChange(); break; case Module::STRATEGY_SECURE: $this->secureEmailChange(); break; default: throw new \OutOfBoundsException('Invalid email changing strategy'); } } //同步修改ucenter密码 $flag = UcenterUtil::userEditWithoutEmail($this->username, $this->current_password, $this->new_password, $this->email); if ($flag >= 0 || $flag == -7) { return $this->user->save(); } } return false; }
<br> </div> </div> <?php ActiveForm::end(); ?> </div> <div id="avata" class="profile-edit tab-pane fade"> <h2 class="heading-md">设置你的头像</h2> <p>修改您的头像.</p> <br> <?php echo \common\util\UcenterUtil::ucAvatar(Yii::$app->user->identity); ?> </div> <div id="notifications" class="profile-edit tab-pane fade"> <h2 class="heading-md">管理你的通知</h2> <p>设置下面的开关打或者禁用一些通知消息</p> <br> <form class="sky-form" id="sky-form3" action="#"> <hr> <label class="toggle"><input type="checkbox" checked="" name="checkbox-toggle-1"><i class="no-rounded"></i>接收系统消息</label> <hr>
<?php /** * @author Eugene Terentev <*****@*****.**> */ \yii\base\Event::on(\yii\web\User::className(), \yii\web\User::EVENT_AFTER_LOGIN, function ($event) { //同步登陆ucenter \common\util\UcenterUtil::syncLogin($event); //记录前台登陆日志 $user = $event->identity; $model = new \common\models\UserLoginLog(); $model->user_id = $user->id; $model->username = $user->username; $model->login_ip = \Yii::$app->request->getUserIP(); $model->login_time = time(); $model->os = \Yii::$app->request->getUserAgent(); $model->category = __METHOD__; $model->save(false); }); //同步退出ucenter \yii\base\Event::on(\yii\web\User::className(), \yii\web\User::EVENT_AFTER_LOGOUT, function ($event) { \common\util\UcenterUtil::logout(); }); //同步删除ucenter的用户 \yii\base\Event::on(\dektrium\user\models\User::className(), \dektrium\user\models\User::EVENT_AFTER_DELETE, function ($event) { $ucUser = \common\util\UcenterUtil::getUser($event->sender->username); \common\util\UcenterUtil::ucUserDelete($ucUser[0]); //删除discuz中common_member中用户信息 $dzHelper = new \common\util\DzHelper(); $dzHelper->deleteDzUserByUsername($ucUser[1]); });