Added filter for check user session and added new routes for the dashboard

This commit is contained in:
Alfonso Saavedra "Son Link" 2024-07-25 14:48:27 +02:00
parent 833ab2e029
commit 7299f15d60
No known key found for this signature in database
GPG Key ID: D3594BCF897F74D8
3 changed files with 48 additions and 1 deletions

View File

@ -34,6 +34,7 @@ class Filters extends BaseFilters
'forcehttps' => ForceHTTPS::class, 'forcehttps' => ForceHTTPS::class,
'pagecache' => PageCache::class, 'pagecache' => PageCache::class,
'performance' => PerformanceMetrics::class, 'performance' => PerformanceMetrics::class,
'userSession' => \App\Filters\CheckUserSession::class,
]; ];
/** /**

View File

@ -12,3 +12,14 @@ $routes->get('car/(:any)', 'Cars::index/$1');
$routes->get('track/(:any)', 'Tracks::index/$1'); $routes->get('track/(:any)', 'Tracks::index/$1');
$routes->get('race/(:num)', 'Races::index/$1'); $routes->get('race/(:num)', 'Races::index/$1');
$routes->get('users', 'Users::index'); $routes->get('users', 'Users::index');
$routes->get('login', 'Users::login');
$routes->post('webserver', 'Webserver::index');
$routes->group('dashboard', static function ($routes) {
$routes->get('/', 'Dashboard::index', ['filter' => 'userSession']);
$routes->get('user', 'Dashboard::user', ['filter' => 'userSession']);
$routes->get('logout', 'Dashboard::logout');
$routes->post('login', 'Dashboard::login');
$routes->post('update_user', 'Dashboard::updateUser', ['filter' => 'userSession']);
$routes->post('change_passwd', 'Dashboard::changePasswd', ['filter' => 'userSession']);
});

View File

@ -0,0 +1,35 @@
<?php
namespace App\Filters;
use CodeIgniter\Filters\FilterInterface;
use CodeIgniter\HTTP\RequestInterface;
use CodeIgniter\HTTP\ResponseInterface;
use CodeIgniter\HTTP\IncomingRequest;
/**
* Este filtro sirve para comprobar si la sesión aun no se cerro por+
* exceder el limite de tiempo, para así evitar errores, sobre todo al guardar datos
*/
class CheckUserSession implements FilterInterface
{
public function before(RequestInterface $request, $arguments = null)
{
assert($request instanceof IncomingRequest);
$session = session();
if (!$session->has('userid'))
{
$session->destroy();
$response = service('response');
$response->setHeader('Location', base_url('login'));
$response->setStatusCode(302);
return $response->send();
}
}
public function after(RequestInterface $request, ResponseInterface $response, $arguments = null)
{
// Do something here
}
}