blob: fb04bd198e82846f1da37d3093589510a69610af (
plain) (
blame)
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
|
<?php
/**
* UserFrosting (http://www.userfrosting.com)
*
* @link https://github.com/userfrosting/UserFrosting
* @license https://github.com/userfrosting/UserFrosting/blob/master/licenses/UserFrosting.md (MIT License)
*/
namespace UserFrosting\Sprinkle\Account\Error\Handler;
use UserFrosting\Sprinkle\Core\Error\Handler\HttpExceptionHandler;
/**
* Handler for AuthExpiredExceptions.
*
* Forwards the user to the login page when their session has expired.
* @author Alex Weissman (https://alexanderweissman.com)
*/
class AuthExpiredExceptionHandler extends HttpExceptionHandler
{
/**
* Custom handling for requests that did not pass authentication.
*/
public function handle() {
// For auth expired exceptions, we always add messages to the alert stream.
$this->writeAlerts();
$response = $this->response;
// For non-AJAX requests, we forward the user to the login page.
if (!$this->request->isXhr()) {
$uri = $this->request->getUri();
$path = $uri->getPath();
$query = $uri->getQuery();
$fragment = $uri->getFragment();
$path = $path
. ($query ? '?' . $query : '')
. ($fragment ? '#' . $fragment : '');
$loginPage = $this->ci->router->pathFor('login', [], [
'redirect' => $path
]);
$response = $response->withRedirect($loginPage);
}
return $response;
}
}
|