2018-11-01 22:12:41 -04:00
|
|
|
<?php declare(strict_types=1);
|
|
|
|
/**
|
|
|
|
* Hummingbird Anime List Client
|
|
|
|
*
|
|
|
|
* An API client for Kitsu to manage anime and manga watch lists
|
|
|
|
*
|
2021-02-04 11:57:01 -05:00
|
|
|
* PHP version 8
|
2018-11-01 22:12:41 -04:00
|
|
|
*
|
|
|
|
* @package HummingbirdAnimeClient
|
|
|
|
* @author Timothy J. Warren <tim@timshomepage.net>
|
2021-01-13 01:52:03 -05:00
|
|
|
* @copyright 2015 - 2021 Timothy J. Warren
|
2018-11-01 22:12:41 -04:00
|
|
|
* @license http://www.opensource.org/licenses/mit-license.html MIT License
|
2020-12-10 17:06:50 -05:00
|
|
|
* @version 5.2
|
2018-11-01 22:12:41 -04:00
|
|
|
* @link https://git.timshomepage.net/timw4mail/HummingBirdAnimeClient
|
|
|
|
*/
|
|
|
|
|
|
|
|
namespace Aviat\AnimeClient\Controller;
|
|
|
|
|
|
|
|
use Aviat\AnimeClient\Controller as BaseController;
|
2020-05-06 13:16:40 -04:00
|
|
|
use Aviat\AnimeClient\Enum\EventType;
|
|
|
|
use Aviat\Ion\Event;
|
2018-11-01 22:12:41 -04:00
|
|
|
use Aviat\Ion\View\HtmlView;
|
|
|
|
|
|
|
|
/**
|
|
|
|
* Controller for handling routes that don't fit elsewhere
|
|
|
|
*/
|
2022-03-03 17:26:09 -05:00
|
|
|
final class Misc extends BaseController
|
|
|
|
{
|
2018-11-01 22:12:41 -04:00
|
|
|
/**
|
|
|
|
* Purges the API cache
|
|
|
|
*/
|
2018-11-09 10:38:35 -05:00
|
|
|
public function clearCache(): void
|
2018-11-01 22:12:41 -04:00
|
|
|
{
|
2020-05-06 13:16:40 -04:00
|
|
|
$this->checkAuth();
|
|
|
|
|
|
|
|
Event::emit(EventType::CLEAR_CACHE);
|
|
|
|
|
2018-11-01 22:12:41 -04:00
|
|
|
$this->outputHTML('blank', [
|
2022-03-03 17:26:09 -05:00
|
|
|
'title' => 'Cache cleared',
|
2018-11-01 22:12:41 -04:00
|
|
|
]);
|
|
|
|
}
|
|
|
|
|
|
|
|
/**
|
|
|
|
* Show the login form
|
|
|
|
*/
|
2018-11-09 10:38:35 -05:00
|
|
|
public function login(string $status = ''): void
|
2018-11-01 22:12:41 -04:00
|
|
|
{
|
|
|
|
$message = '';
|
|
|
|
|
|
|
|
$view = new HtmlView($this->container);
|
|
|
|
|
|
|
|
if ($status !== '')
|
|
|
|
{
|
|
|
|
$message = $this->showMessage($view, 'error', $status);
|
|
|
|
}
|
|
|
|
|
|
|
|
// Set the redirect url
|
|
|
|
$this->setSessionRedirect();
|
|
|
|
|
|
|
|
$this->outputHTML('login', [
|
|
|
|
'title' => 'Api login',
|
2022-03-03 17:26:09 -05:00
|
|
|
'message' => $message,
|
2018-11-01 22:12:41 -04:00
|
|
|
], $view);
|
|
|
|
}
|
|
|
|
|
|
|
|
/**
|
|
|
|
* Attempt login authentication
|
|
|
|
*/
|
2018-11-09 10:38:35 -05:00
|
|
|
public function loginAction(): void
|
2018-11-01 22:12:41 -04:00
|
|
|
{
|
2022-03-03 17:26:09 -05:00
|
|
|
$post = (array) $this->request->getParsedBody();
|
2018-11-01 22:12:41 -04:00
|
|
|
|
2020-08-05 21:46:14 -04:00
|
|
|
if ($this->auth->authenticate($post['password']))
|
2018-11-01 22:12:41 -04:00
|
|
|
{
|
|
|
|
$this->sessionRedirect();
|
2022-03-03 17:26:09 -05:00
|
|
|
|
2018-11-01 22:12:41 -04:00
|
|
|
return;
|
|
|
|
}
|
|
|
|
|
|
|
|
$this->setFlashMessage('Invalid username or password.');
|
2021-02-11 19:54:22 -05:00
|
|
|
|
|
|
|
$redirectUrl = $this->url->generate('login');
|
|
|
|
$redirectUrl = ($redirectUrl !== FALSE) ? $redirectUrl : '';
|
|
|
|
|
|
|
|
$this->redirect($redirectUrl, 303);
|
2018-11-01 22:12:41 -04:00
|
|
|
}
|
|
|
|
|
|
|
|
/**
|
|
|
|
* Deauthorize the current user
|
|
|
|
*/
|
2018-11-09 10:38:35 -05:00
|
|
|
public function logout(): void
|
2018-11-01 22:12:41 -04:00
|
|
|
{
|
2020-08-05 21:46:14 -04:00
|
|
|
$this->auth->logout();
|
2018-11-01 22:12:41 -04:00
|
|
|
|
|
|
|
$this->redirectToDefaultRoute();
|
|
|
|
}
|
2020-08-05 21:46:14 -04:00
|
|
|
|
|
|
|
/**
|
|
|
|
* Check if the current user is logged in
|
|
|
|
*/
|
|
|
|
public function heartbeat(): void
|
|
|
|
{
|
|
|
|
$this->outputJSON(['hasAuth' => $this->auth->isAuthenticated()], 200);
|
|
|
|
}
|
2022-03-03 17:26:09 -05:00
|
|
|
}
|