summaryrefslogtreecommitdiffstats
path: root/modules/statistics/lib/AccessCheck.php
blob: 92d1f906a5775c8fe2071d8edb125be781f4f399 (plain)
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
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
<?php

/**
 * Class implementing the access checker function for the statistics module.
 *
 * @package simpleSAMLphp
 */
class sspmod_statistics_AccessCheck {


	/**
	 * Check that the user has access to the statistics.
	 *
	 * If the user doesn't have access, send the user to the login page.
	 */
	public static function checkAccess(SimpleSAML_Configuration $statconfig) {
		$protected = $statconfig->getBoolean('protected', FALSE);
		$authsource = $statconfig->getString('auth', NULL);
		$allowedusers = $statconfig->getValue('allowedUsers', NULL);
		$useridattr = $statconfig->getString('useridattr', 'eduPersonPrincipalName');

		$acl = $statconfig->getValue('acl', NULL);
		if ($acl !== NULL && !is_string($acl) && !is_array($acl)) {
			throw new SimpleSAML_Error_Exception('Invalid value for \'acl\'-option. Should be an array or a string.');
		}

		if (!$protected) {
			return;
		}

		if (SimpleSAML_Utilities::isAdmin()) {
			// User logged in as admin. OK.
			SimpleSAML_Logger::debug('Statistics auth - logged in as admin, access granted');
			return;
		}

		if (!isset($authsource)) {
			// If authsource is not defined, init admin login.
			SimpleSAML_Utilities::requireAdmin();
		}

		/* We are using an authsource for login. */

		$as = new SimpleSAML_Auth_Simple($authsource);
		$as->requireAuth();

		// User logged in with auth source.
		SimpleSAML_Logger::debug('Statistics auth - valid login with auth source [' . $authsource . ']');

		// Retrieving attributes
		$attributes = $as->getAttributes();

		if (!empty($allowedusers)) {
			// Check if userid exists
			if (!isset($attributes[$useridattr][0]))
				throw new Exception('User ID is missing');

			// Check if userid is allowed access..
			if (in_array($attributes[$useridattr][0], $allowedusers)) {
				SimpleSAML_Logger::debug('Statistics auth - User granted access by user ID [' . $attributes[$useridattr][0] . ']');
				return;
			}
			SimpleSAML_Logger::debug('Statistics auth - User denied access by user ID [' . $attributes[$useridattr][0] . ']');

		} else {
			SimpleSAML_Logger::debug('Statistics auth - no allowedUsers list.');
		}

		if (!is_null($acl)) {
			$acl = new sspmod_core_ACL($acl);
			if ($acl->allows($attributes)) {
				SimpleSAML_Logger::debug('Statistics auth - allowed access by ACL.');
				return;
			}
			SimpleSAML_Logger::debug('Statistics auth - denied access by ACL.');
		} else {
			SimpleSAML_Logger::debug('Statistics auth - no ACL configured.');
		}

		throw new SimpleSAML_Error_Exception('Access denied to the current user.');
	}

}