mirror of
https://github.com/YunoHost-Apps/kanboard_ynh.git
synced 2024-09-03 19:36:17 +02:00
119 lines
3.4 KiB
PHP
119 lines
3.4 KiB
PHP
<?php
|
|
|
|
namespace Kanboard\Validator;
|
|
|
|
use SimpleValidator\Validator;
|
|
use SimpleValidator\Validators;
|
|
use Gregwar\Captcha\CaptchaBuilder;
|
|
|
|
/**
|
|
* Authentication Validator
|
|
*
|
|
* @package validator
|
|
* @author Frederic Guillot
|
|
*/
|
|
class AuthValidator extends Base
|
|
{
|
|
/**
|
|
* Validate user login form
|
|
*
|
|
* @access public
|
|
* @param array $values Form values
|
|
* @return array $valid, $errors [0] = Success or not, [1] = List of errors
|
|
*/
|
|
public function validateForm(array $values)
|
|
{
|
|
return $this->executeValidators(array('validateFields', 'validateLocking', 'validateCaptcha', 'validateCredentials'), $values);
|
|
}
|
|
|
|
/**
|
|
* Validate credentials syntax
|
|
*
|
|
* @access protected
|
|
* @param array $values Form values
|
|
* @return array $valid, $errors [0] = Success or not, [1] = List of errors
|
|
*/
|
|
protected function validateFields(array $values)
|
|
{
|
|
$v = new Validator($values, array(
|
|
new Validators\Required('username', t('The username is required')),
|
|
new Validators\MaxLength('username', t('The maximum length is %d characters', 50), 50),
|
|
new Validators\Required('password', t('The password is required')),
|
|
));
|
|
|
|
return array(
|
|
$v->execute(),
|
|
$v->getErrors(),
|
|
);
|
|
}
|
|
|
|
/**
|
|
* Validate user locking
|
|
*
|
|
* @access protected
|
|
* @param array $values Form values
|
|
* @return array $valid, $errors [0] = Success or not, [1] = List of errors
|
|
*/
|
|
protected function validateLocking(array $values)
|
|
{
|
|
$result = true;
|
|
$errors = array();
|
|
|
|
if ($this->userLocking->isLocked($values['username'])) {
|
|
$result = false;
|
|
$errors['login'] = t('Your account is locked for %d minutes', BRUTEFORCE_LOCKDOWN_DURATION);
|
|
$this->logger->error('Account locked: '.$values['username']);
|
|
}
|
|
|
|
return array($result, $errors);
|
|
}
|
|
|
|
/**
|
|
* Validate password syntax
|
|
*
|
|
* @access protected
|
|
* @param array $values Form values
|
|
* @return array $valid, $errors [0] = Success or not, [1] = List of errors
|
|
*/
|
|
protected function validateCredentials(array $values)
|
|
{
|
|
$result = true;
|
|
$errors = array();
|
|
|
|
if (! $this->authenticationManager->passwordAuthentication($values['username'], $values['password'])) {
|
|
$result = false;
|
|
$errors['login'] = t('Bad username or password');
|
|
}
|
|
|
|
return array($result, $errors);
|
|
}
|
|
|
|
/**
|
|
* Validate captcha
|
|
*
|
|
* @access protected
|
|
* @param array $values Form values
|
|
* @return boolean
|
|
*/
|
|
protected function validateCaptcha(array $values)
|
|
{
|
|
$result = true;
|
|
$errors = array();
|
|
|
|
if ($this->userLocking->hasCaptcha($values['username'])) {
|
|
if (! isset($this->sessionStorage->captcha)) {
|
|
$result = false;
|
|
} else {
|
|
$builder = new CaptchaBuilder;
|
|
$builder->setPhrase($this->sessionStorage->captcha);
|
|
$result = $builder->testPhrase(isset($values['captcha']) ? $values['captcha'] : '');
|
|
|
|
if (! $result) {
|
|
$errors['login'] = t('Invalid captcha');
|
|
}
|
|
}
|
|
}
|
|
|
|
return array($result, $errors);;
|
|
}
|
|
}
|