本文整理匯總了PHP中backend\models\User::getByEmail方法的典型用法代碼示例。如果您正苦於以下問題:PHP User::getByEmail方法的具體用法?PHP User::getByEmail怎麽用?PHP User::getByEmail使用的例子?那麽, 這裏精選的方法代碼示例或許可以為您提供幫助。您也可以進一步了解該方法所在類backend\models\User
的用法示例。
在下文中一共展示了User::getByEmail方法的3個代碼示例,這些例子默認根據受歡迎程度排序。您可以為喜歡或者感覺有用的代碼點讚,您的評價將有助於係統推薦出更棒的PHP代碼示例。
示例1: actionCreate
/**
* Create a new user
*
* <b>Request Type</b>: POST<br/><br/>
* <b>Request Endpoint</b>:http://{server-domain}/management/user<br/><br/>
* <b>Content-type</b>: application/json<br/><br/>
* <b>Summary</b>: This api is used for billing account to create a new user
* <br/><br/>
*
* <b>Request Params</b>:<br/>
* email: string, the user email, required<br/>
* role: string, the user role, required<br/>
* <br/><br/>
*
* <b>Response Params:</b><br/>
* ack: integer, mark the create result, 0 means create successfully, 1 means create fail<br/>
* data: array, json array to describe the user created<br/>
* <br/><br/>
*
* <b>Request Example:</b><br/>
* <pre>
* {
* "email" : "sarazhang@augmentum.com.cn",
* "role" : "admin"
* }
* </pre>
* <br/><br/>
*
* <b>Response Example</b>:<br/>
* <pre>
* {
* 'ack' : 1,
* 'data': {"msg": "您當前已成功發送驗證郵件到sarazhang@augmentum.com.cn郵箱中", "user": {name:"Devin Jin", avatar:"path/to/avatar", email:"sarazhang@augmentum.com.cn", isActivated:false}}
* }
* </pre>
*/
public function actionCreate()
{
$params = $this->getParams();
if (empty($params['email'])) {
throw new InvalidParameterException(['email' => Yii::t('common', 'email_is_required')]);
}
$params['email'] = mb_strtolower($params['email']);
if (!StringUtil::isEmail($params['email'])) {
throw new InvalidParameterException(['email' => Yii::t('helpDesk', 'email_format_wrong')]);
}
$user = User::getByEmail($params['email']);
if (!empty($user)) {
throw new InvalidParameterException(['email' => Yii::t('helpDesk', 'email_has_used')]);
}
$user = new User();
$user->email = $params['email'];
$user->role = $params['role'];
$user->avatar = Yii::$app->params['defaultAvatar'];
$user->isActivated = User::NOT_ACTIVATED;
$user->accountId = $this->getAccountId();
if ($user->save()) {
$currentUser = $this->getUser();
$link = Yii::$app->request->hostInfo . '/site/invite/code?type=2';
//type=2 means invite user account
$result = EmailUtil::sendInviteEmail($user, $currentUser->name, $link, self::SUBJECT);
if ($result) {
return ['user' => $user];
} else {
throw new ServerErrorHttpException("validation save fail");
}
}
throw new ServerErrorHttpException("create user fail");
}
示例2: actionGenerateByEmail
/**
* create a user by email(generate-by-email)
*/
public function actionGenerateByEmail($email)
{
$email = mb_strtolower($email);
$user = User::getByEmail($email);
if (!empty($user)) {
echo 'email is used' . PHP_EOL;
return;
}
$name = Yii::$app->params['defaultName'];
$accountId = Account::create('', '', $name);
$attributes = ['status' => Account::STATUS_ACTIVATED, 'availableExtMods' => Yii::$app->params['extMods'], 'serviceStartAt' => new \MongoDate()];
Account::updateAll($attributes, ['_id' => $accountId]);
$salt = StringUtil::rndString(6);
$password = User::encryptPassword(md5(Yii::$app->params['defaultPwd']), $salt);
$user = new User();
$user->email = $email;
$user->accountId = $accountId;
$user->name = $name;
$user->role = User::ROLE_ADMIN;
$user->isActivated = User::ACTIVATED;
$user->avatar = Yii::$app->params['defaultAvatar'];
$user->language = Yii::$app->params['defaultLanguage'];
$user->salt = $salt;
$user->password = $password;
if (!$user->save()) {
Account::deleteAll(['_id' => $accountId]);
SensitiveOperation::deleteAll(['accountId' => $accountId]);
MessageTemplate::deleteAll(['accountId' => $accountId]);
echo 'create account fail' . PHP_EOL;
} else {
echo 'create account successfully' . PHP_EOL;
}
}
示例3: actionSendResetPasswordEmail
/**
* Send Reset password email
*/
public function actionSendResetPasswordEmail()
{
$email = $this->getParams('email');
$email = mb_strtolower($email);
if (empty($email)) {
throw new InvalidParameterException(['reset-email' => Yii::t('common', 'email_is_required')]);
}
if (!StringUtil::isEmail($email)) {
throw new InvalidParameterException(['reset-email' => Yii::t('member', 'email_format_error')]);
}
//validate the email
$user = User::getByEmail($email);
if (empty($user)) {
throw new InvalidParameterException(['reset-email' => Yii::t('common', 'incorrect_userid')]);
}
if (!empty($user) && !$user->isActivated) {
throw new InvalidParameterException(['reset-email' => Yii::t('common', 'user_not_activate')]);
}
//generate the validation
$validation = new Validation();
$validation->userId = $user->_id;
$validation->expire = new \MongoDate(strtotime('+7 day'));
if (!$validation->save()) {
throw new ServerErrorHttpException("Failed to save validation");
}
$host = Yii::$app->request->hostInfo;
$link = $host . '/site/resetpassword?code=' . $validation->code;
$mail = Yii::$app->mail;
$vars = ['name' => $user->name, 'link' => $link, 'host' => $host];
$mail->setView('//mail/resetPassword', $vars, '//layouts/email');
$mail->sendMail($user->email, '群脈重置密碼');
return ['status' => 'ok'];
}