HummingBirdAnimeClient/src/AnimeClient/Controller/Misc.php

106 lines
2.1 KiB
PHP
Raw Normal View History

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
2022-03-04 12:32:17 -05:00
* @author Timothy J. Warren <tim@timshome.page>
* @copyright 2015 - 2022 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;
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
*/
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
{
$this->checkAuth();
Event::emit(EventType::CLEAR_CACHE);
2018-11-01 22:12:41 -04:00
$this->outputHTML('blank', [
'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',
'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
{
$post = (array) $this->request->getParsedBody();
2018-11-01 22:12:41 -04:00
if ($this->auth->authenticate($post['password']))
2018-11-01 22:12:41 -04:00
{
$this->sessionRedirect();
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
{
$this->auth->logout();
2018-11-01 22:12:41 -04:00
$this->redirectToDefaultRoute();
}
/**
* Check if the current user is logged in
*/
public function heartbeat(): void
{
$this->outputJSON(['hasAuth' => $this->auth->isAuthenticated()], 200);
}
}