blob: efcfaae155496d5658ca850fdd3ae1350f9baff8 (
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
51
52
53
54
55
56
|
<?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\Authenticate;
use Psr\Http\Message\ResponseInterface;
use Psr\Http\Message\ServerRequestInterface;
use Slim\Http\Body;
use UserFrosting\Sprinkle\Account\Authenticate\Exception\AuthExpiredException;
/**
* Middleware to catch requests that fail because they require user authentication.
*
* @author Alex Weissman (https://alexanderweissman.com)
*/
class AuthGuard
{
/**
* @var Authenticator
*/
protected $authenticator;
/**
* Constructor.
*
* @param $authenticator Authenticator The current authentication object.
*/
public function __construct($authenticator)
{
$this->authenticator = $authenticator;
}
/**
* Invoke the AuthGuard middleware, throwing an exception if there is no authenticated user in the session.
*
* @param \Psr\Http\Message\ServerRequestInterface $request PSR7 request
* @param \Psr\Http\Message\ResponseInterface $response PSR7 response
* @param callable $next Next middleware
*
* @return \Psr\Http\Message\ResponseInterface
*/
public function __invoke($request, $response, $next)
{
if (!$this->authenticator->check()) {
throw new AuthExpiredException();
} else {
return $next($request, $response);
}
return $response;
}
}
|