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); |
||||
0 ignored issues
–
show
It seems like
$authsource can also be of type null ; however, parameter $authSource of SimpleSAML\Auth\Simple::__construct() does only seem to accept string , maybe add an additional type check?
(
Ignorable by Annotation
)
If this is a false-positive, you can also ignore this issue in your code via the
![]() |
|||||
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.