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) { |
|
|
|
|
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.