98 lines
1.9 KiB
PHP
98 lines
1.9 KiB
PHP
|
<?php declare(strict_types=1);
|
||
|
/**
|
||
|
* Hummingbird Anime List Client
|
||
|
*
|
||
|
* An API client for Kitsu to manage anime and manga watch lists
|
||
|
*
|
||
|
* PHP version 7.1
|
||
|
*
|
||
|
* @package HummingbirdAnimeClient
|
||
|
* @author Timothy J. Warren <tim@timshomepage.net>
|
||
|
* @copyright 2015 - 2018 Timothy J. Warren
|
||
|
* @license http://www.opensource.org/licenses/mit-license.html MIT License
|
||
|
* @version 4.1
|
||
|
* @link https://git.timshomepage.net/timw4mail/HummingBirdAnimeClient
|
||
|
*/
|
||
|
|
||
|
namespace Aviat\AnimeClient\Controller;
|
||
|
|
||
|
use Aviat\AnimeClient\Controller as BaseController;
|
||
|
use Aviat\Ion\Di\ContainerInterface;
|
||
|
use Aviat\Ion\View\HtmlView;
|
||
|
|
||
|
/**
|
||
|
* Controller for handling routes that don't fit elsewhere
|
||
|
*/
|
||
|
final class Misc extends BaseController {
|
||
|
/**
|
||
|
* Purges the API cache
|
||
|
*
|
||
|
* @return void
|
||
|
*/
|
||
|
public function clearCache()
|
||
|
{
|
||
|
$this->cache->clear();
|
||
|
$this->outputHTML('blank', [
|
||
|
'title' => 'Cache cleared'
|
||
|
]);
|
||
|
}
|
||
|
|
||
|
/**
|
||
|
* Show the login form
|
||
|
*
|
||
|
* @param string $status
|
||
|
* @return void
|
||
|
*/
|
||
|
public function login(string $status = '')
|
||
|
{
|
||
|
$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
|
||
|
], $view);
|
||
|
}
|
||
|
|
||
|
/**
|
||
|
* Attempt login authentication
|
||
|
*
|
||
|
* @return void
|
||
|
*/
|
||
|
public function loginAction()
|
||
|
{
|
||
|
$auth = $this->container->get('auth');
|
||
|
$post = $this->request->getParsedBody();
|
||
|
|
||
|
if ($auth->authenticate($post['password']))
|
||
|
{
|
||
|
$this->sessionRedirect();
|
||
|
return;
|
||
|
}
|
||
|
|
||
|
$this->setFlashMessage('Invalid username or password.');
|
||
|
$this->redirect($this->url->generate('login'), 303);
|
||
|
}
|
||
|
|
||
|
/**
|
||
|
* Deauthorize the current user
|
||
|
*
|
||
|
* @return void
|
||
|
*/
|
||
|
public function logout()
|
||
|
{
|
||
|
$auth = $this->container->get('auth');
|
||
|
$auth->logout();
|
||
|
|
||
|
$this->redirectToDefaultRoute();
|
||
|
}
|
||
|
}
|