-
Notifications
You must be signed in to change notification settings - Fork 289
Open
Description
In my website I have a clientarea that should have the login and register page always accessible and the other pages only if logged in. If the user is not logged in the other pages should redirect. I'am struggling with this for a few hours already in Klein.
Of course I can do the check inside every route but with the session check before loading the routes I would like to prevent any accidental code executions by not even loading the client routes at all when the client is not logged in.
I currently have the following setup:
if (!$_SESSION['user']) {
$router->with('/clientarea', function () {
$router->respond(['POST', 'GET'], '@^$', function ($request, $response) {
// login page
});
$router->respond(['POST', 'GET'], '/register', function ($request, $response) {
// register page
});
// Here I would like to redirect all pages that are not the login or register page
});
}
else {
$router->with('/clientarea', function () {
$router->respond(['POST', 'GET'], '@^$', function ($request, $response) use ($data, $twig) {
header('Location: /clientarea');
exit;
});
$router->respond(['POST', 'GET'], '/register', function ($request, $response) use ($data, $twig) {
header('Location: /clientarea');
exit;
});
$router->respond('GET', '/page1', function ($request, $response) use ($data, $twig) {
// clientarea page 1
});
$router->respond('GET', '/page2', function ($request, $response) use ($data, $twig) {
// clientarea page 2
});
$router->respond('GET', '/page3', function ($request, $response) use ($data, $twig) {
// clientarea page 3
});
});
}
Metadata
Metadata
Assignees
Labels
No labels