2014-08-30 13:04:52 +02:00
|
|
|
<?php
|
|
|
|
namespace Szurubooru\Controllers;
|
|
|
|
|
|
|
|
final class AuthController extends AbstractController
|
|
|
|
{
|
2014-08-30 18:11:32 +02:00
|
|
|
private $authService;
|
2014-08-31 13:16:29 +02:00
|
|
|
private $inputReader;
|
2014-08-30 18:11:32 +02:00
|
|
|
|
2014-08-31 13:16:29 +02:00
|
|
|
public function __construct(
|
|
|
|
\Szurubooru\Services\AuthService $authService,
|
|
|
|
\Szurubooru\Helpers\InputReader $inputReader)
|
2014-08-30 18:11:32 +02:00
|
|
|
{
|
|
|
|
$this->authService = $authService;
|
2014-08-31 13:16:29 +02:00
|
|
|
$this->inputReader = $inputReader;
|
|
|
|
|
2014-08-30 18:11:32 +02:00
|
|
|
}
|
|
|
|
|
2014-08-30 15:04:33 +02:00
|
|
|
public function registerRoutes(\Szurubooru\Router $router)
|
2014-08-30 13:04:52 +02:00
|
|
|
{
|
|
|
|
$router->post('/api/login', [$this, 'login']);
|
2014-08-30 23:17:54 +02:00
|
|
|
$router->put('/api/login', [$this, 'login']);
|
2014-08-30 13:04:52 +02:00
|
|
|
}
|
|
|
|
|
|
|
|
public function login()
|
|
|
|
{
|
2014-08-31 13:16:29 +02:00
|
|
|
if (isset($this->inputReader->userName) and isset($this->inputReader->password))
|
|
|
|
{
|
|
|
|
if (!$this->inputReader->userName)
|
|
|
|
throw new \DomainException('User name cannot be empty.');
|
|
|
|
else if (!$this->inputReader->password)
|
|
|
|
throw new \DomainException('Password cannot be empty.');
|
2014-08-30 23:17:54 +02:00
|
|
|
|
2014-08-31 13:16:29 +02:00
|
|
|
$this->authService->loginFromCredentials($this->inputReader->userName, $this->inputReader->password);
|
|
|
|
}
|
|
|
|
elseif (isset($this->inputReader->token))
|
|
|
|
{
|
|
|
|
if (!$this->inputReader->token)
|
|
|
|
throw new \DomainException('Authentication token cannot be empty.');
|
|
|
|
$this->authService->loginFromToken($this->inputReader->token);
|
|
|
|
}
|
2014-08-30 23:17:54 +02:00
|
|
|
else
|
2014-08-31 13:16:29 +02:00
|
|
|
{
|
|
|
|
$this->authService->loginAnonymous();
|
|
|
|
}
|
2014-08-30 23:17:54 +02:00
|
|
|
|
2014-08-31 13:16:29 +02:00
|
|
|
return
|
|
|
|
[
|
2014-08-31 09:09:17 +02:00
|
|
|
'token' => new \Szurubooru\ViewProxies\Token($this->authService->getLoginToken()),
|
|
|
|
'user' => new \Szurubooru\ViewProxies\User($this->authService->getLoggedInUser()),
|
2014-08-30 23:17:54 +02:00
|
|
|
];
|
2014-08-30 13:04:52 +02:00
|
|
|
}
|
|
|
|
}
|