mirror of
https://github.com/YunoHost-Apps/kanboard_ynh.git
synced 2024-09-03 19:36:17 +02:00
94 lines
2.4 KiB
PHP
94 lines
2.4 KiB
PHP
<?php
|
|
|
|
namespace Kanboard\Controller;
|
|
|
|
use Gregwar\Captcha\CaptchaBuilder;
|
|
|
|
/**
|
|
* Authentication controller
|
|
*
|
|
* @package controller
|
|
* @author Frederic Guillot
|
|
*/
|
|
class Auth extends Base
|
|
{
|
|
/**
|
|
* Display the form login
|
|
*
|
|
* @access public
|
|
*/
|
|
public function login(array $values = array(), array $errors = array())
|
|
{
|
|
if ($this->userSession->isLogged()) {
|
|
$this->response->redirect($this->helper->url->to('app', 'index'));
|
|
}
|
|
|
|
$this->response->html($this->template->layout('auth/index', array(
|
|
'captcha' => ! empty($values['username']) && $this->userLocking->hasCaptcha($values['username']),
|
|
'errors' => $errors,
|
|
'values' => $values,
|
|
'no_layout' => true,
|
|
'title' => t('Login')
|
|
)));
|
|
}
|
|
|
|
/**
|
|
* Check credentials
|
|
*
|
|
* @access public
|
|
*/
|
|
public function check()
|
|
{
|
|
$values = $this->request->getValues();
|
|
$this->sessionStorage->hasRememberMe = ! empty($values['remember_me']);
|
|
list($valid, $errors) = $this->authentication->validateForm($values);
|
|
|
|
if ($valid) {
|
|
$this->redirectAfterLogin();
|
|
}
|
|
|
|
$this->login($values, $errors);
|
|
}
|
|
|
|
/**
|
|
* Logout and destroy session
|
|
*
|
|
* @access public
|
|
*/
|
|
public function logout()
|
|
{
|
|
$this->sessionManager->close();
|
|
$this->response->redirect($this->helper->url->to('auth', 'login'));
|
|
}
|
|
|
|
/**
|
|
* Display captcha image
|
|
*
|
|
* @access public
|
|
*/
|
|
public function captcha()
|
|
{
|
|
$this->response->contentType('image/jpeg');
|
|
|
|
$builder = new CaptchaBuilder;
|
|
$builder->build();
|
|
$this->sessionStorage->captcha = $builder->getPhrase();
|
|
$builder->output();
|
|
}
|
|
|
|
/**
|
|
* Redirect the user after the authentication
|
|
*
|
|
* @access private
|
|
*/
|
|
private function redirectAfterLogin()
|
|
{
|
|
if (isset($this->sessionStorage->redirectAfterLogin) && ! empty($this->sessionStorage->redirectAfterLogin) && ! filter_var($this->sessionStorage->redirectAfterLogin, FILTER_VALIDATE_URL)) {
|
|
$redirect = $this->sessionStorage->redirectAfterLogin;
|
|
unset($this->sessionStorage->redirectAfterLogin);
|
|
$this->response->redirect($redirect);
|
|
}
|
|
|
|
$this->response->redirect($this->helper->url->to('app', 'index'));
|
|
}
|
|
}
|