141 lines
3.7 KiB
PHP
141 lines
3.7 KiB
PHP
<?php
|
|
|
|
/*
|
|
* This file is part of the 2amigos/yii2-usuario project.
|
|
*
|
|
* (c) 2amigOS! <http://2amigos.us/>
|
|
*
|
|
* For the full copyright and license information, please view
|
|
* the LICENSE file that was distributed with this source code.
|
|
*/
|
|
|
|
namespace Da\User\Form;
|
|
|
|
use Da\User\Helper\SecurityHelper;
|
|
use Da\User\Model\User;
|
|
use Da\User\Query\UserQuery;
|
|
use Da\User\Traits\ModuleAwareTrait;
|
|
use Yii;
|
|
use yii\base\Model;
|
|
|
|
class LoginForm extends Model
|
|
{
|
|
use ModuleAwareTrait;
|
|
|
|
/**
|
|
* @var string login User's email or username
|
|
*/
|
|
public $login;
|
|
/**
|
|
* @var string User's password
|
|
*/
|
|
public $password;
|
|
/**
|
|
* @var bool whether to remember User's login
|
|
*/
|
|
public $rememberMe = false;
|
|
/**
|
|
* @var User
|
|
*/
|
|
protected $user;
|
|
/**
|
|
* @var UserQuery
|
|
*/
|
|
protected $query;
|
|
/**
|
|
* @var SecurityHelper
|
|
*/
|
|
protected $securityHelper;
|
|
|
|
/**
|
|
* @param UserQuery $query
|
|
* @param SecurityHelper $securityHelper
|
|
* @param array $config
|
|
*/
|
|
public function __construct(UserQuery $query, SecurityHelper $securityHelper, $config = [])
|
|
{
|
|
$this->query = $query;
|
|
$this->securityHelper = $securityHelper;
|
|
parent::__construct($config);
|
|
}
|
|
|
|
/**
|
|
* {@inheritdoc}
|
|
*/
|
|
public function attributeLabels()
|
|
{
|
|
return [
|
|
'login' => Yii::t('usuario', 'Login'),
|
|
'password' => Yii::t('usuario', 'Password'),
|
|
'rememberMe' => Yii::t('usuario', 'Remember me next time'),
|
|
];
|
|
}
|
|
|
|
/**
|
|
* {@inheritdoc}
|
|
*/
|
|
public function rules()
|
|
{
|
|
return [
|
|
'requiredFields' => [['login', 'password'], 'required'],
|
|
'loginTrim' => ['login', 'trim'],
|
|
'passwordValidate' => [
|
|
'password',
|
|
function ($attribute) {
|
|
if ($this->user === null ||
|
|
!$this->securityHelper->validatePassword($this->password, $this->user->password_hash)
|
|
) {
|
|
$this->addError($attribute, Yii::t('usuario', 'Invalid login or password'));
|
|
}
|
|
},
|
|
],
|
|
'confirmationValidate' => [
|
|
'login',
|
|
function ($attribute) {
|
|
if ($this->user !== null) {
|
|
$module = $this->getModule();
|
|
$confirmationRequired = $module->enableEmailConfirmation && !$module->allowUnconfirmedEmailLogin;
|
|
if ($confirmationRequired && !$this->user->getIsConfirmed()) {
|
|
$this->addError($attribute, Yii::t('usuario', 'You need to confirm your email address'));
|
|
}
|
|
if ($this->user->getIsBlocked()) {
|
|
$this->addError($attribute, Yii::t('usuario', 'Your account has been blocked'));
|
|
}
|
|
}
|
|
},
|
|
],
|
|
'rememberMe' => ['rememberMe', 'boolean'],
|
|
];
|
|
}
|
|
|
|
/**
|
|
* Validates form and logs the user in.
|
|
*
|
|
* @return bool whether the user is logged in successfully
|
|
*/
|
|
public function login()
|
|
{
|
|
if ($this->validate()) {
|
|
$duration = $this->rememberMe ? $this->module->rememberLoginLifespan : 0;
|
|
|
|
return Yii::$app->getUser()->login($this->user, $duration);
|
|
} else {
|
|
return false;
|
|
}
|
|
}
|
|
|
|
/**
|
|
* {@inheritdoc}
|
|
*/
|
|
public function beforeValidate()
|
|
{
|
|
if (parent::beforeValidate()) {
|
|
$this->user = $this->query->whereUsernameOrEmail(trim($this->login))->one();
|
|
|
|
return true;
|
|
}
|
|
|
|
return false;
|
|
}
|
|
}
|