1 | <?php |
||
2 | |||
3 | declare(strict_types=1); |
||
4 | |||
5 | namespace SimpleSAML\Module\statistics; |
||
6 | |||
7 | use Exception; |
||
8 | use SimpleSAML\Auth; |
||
9 | use SimpleSAML\Configuration; |
||
10 | use SimpleSAML\Error; |
||
11 | use SimpleSAML\Logger; |
||
12 | use SimpleSAML\Utils; |
||
13 | |||
14 | /** |
||
15 | * Class implementing the access checker function for the statistics module. |
||
16 | * |
||
17 | * @package SimpleSAMLphp |
||
18 | */ |
||
19 | class AccessCheck |
||
20 | { |
||
21 | /** |
||
22 | * Check that the user has access to the statistics. |
||
23 | * If the user doesn't have access, send the user to the login page. |
||
24 | * |
||
25 | * @param \SimpleSAML\Configuration $statconfig |
||
26 | * @throws \Exception |
||
27 | * @throws \SimpleSAML\Error\Exception |
||
28 | */ |
||
29 | public static function checkAccess(Configuration $statconfig): void |
||
30 | { |
||
31 | $protected = $statconfig->getOptionalBoolean('protected', false); |
||
32 | $authsource = $statconfig->getOptionalString('auth', null); |
||
33 | $allowedusers = $statconfig->getOptionalValue('allowedUsers', null); |
||
34 | $useridattr = $statconfig->getOptionalString('useridattr', 'eduPersonPrincipalName'); |
||
35 | |||
36 | $acl = $statconfig->getOptionalValue('acl', null); |
||
37 | if ($acl !== null && !is_string($acl) && !is_array($acl)) { |
||
38 | throw new Error\Exception('Invalid value for \'acl\'-option. Should be an array or a string.'); |
||
39 | } |
||
40 | |||
41 | if (!$protected) { |
||
0 ignored issues
–
show
|
|||
42 | return; |
||
43 | } |
||
44 | |||
45 | $authUtils = new Utils\Auth(); |
||
46 | if ($authUtils->isAdmin()) { |
||
47 | // User logged in as admin. OK. |
||
48 | Logger::debug('Statistics auth - logged in as admin, access granted'); |
||
49 | return; |
||
50 | } |
||
51 | |||
52 | if (!isset($authsource)) { |
||
53 | // If authsource is not defined, init admin login. |
||
54 | $authUtils->requireAdmin(); |
||
55 | } |
||
56 | |||
57 | // We are using an authsource for login. |
||
58 | |||
59 | $as = new Auth\Simple($authsource); |
||
60 | $as->requireAuth(); |
||
61 | |||
62 | // User logged in with auth source. |
||
63 | Logger::debug('Statistics auth - valid login with auth source [' . $authsource . ']'); |
||
64 | |||
65 | // Retrieving attributes |
||
66 | $attributes = $as->getAttributes(); |
||
67 | |||
68 | if (!empty($allowedusers)) { |
||
69 | // Check if userid exists |
||
70 | if (!isset($attributes[$useridattr][0])) { |
||
71 | throw new Exception('User ID is missing'); |
||
72 | } |
||
73 | |||
74 | // Check if userid is allowed access.. |
||
75 | if (in_array($attributes[$useridattr][0], $allowedusers, true)) { |
||
76 | Logger::debug( |
||
77 | 'Statistics auth - User granted access by user ID [' . $attributes[$useridattr][0] . ']', |
||
78 | ); |
||
79 | return; |
||
80 | } |
||
81 | Logger::debug( |
||
82 | 'Statistics auth - User denied access by user ID [' . $attributes[$useridattr][0] . ']', |
||
83 | ); |
||
84 | } else { |
||
85 | Logger::debug('Statistics auth - no allowedUsers list.'); |
||
86 | } |
||
87 | |||
88 | if (!is_null($acl)) { |
||
89 | $acl = new ACL($acl); |
||
90 | if ($acl->allows($attributes)) { |
||
91 | Logger::debug('Statistics auth - allowed access by ACL.'); |
||
92 | return; |
||
93 | } |
||
94 | Logger::debug('Statistics auth - denied access by ACL.'); |
||
95 | } else { |
||
96 | Logger::debug('Statistics auth - no ACL configured.'); |
||
97 | } |
||
98 | throw new Error\Exception('Access denied to the current user.'); |
||
99 | } |
||
100 | } |
||
101 |
If an expression can have both
false
, andnull
as possible values. It is generally a good practice to always use strict comparison to clearly distinguish between those two values.