Welcome to mirror list, hosted at ThFree Co, Russian Federation.

Access.php « modules - github.com/matomo-org/matomo.git - Unnamed repository; edit this file 'description' to name the repository.
summaryrefslogtreecommitdiff
blob: 830877f454e5aabe347d2339b46c9aaeff2ec049 (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
84
85
86
87
88
89
90
91
92
93
94
95
96
97
98
99
100
101
102
103
104
105
106
107
108
109
110
111
112
113
114
115
116
117
118
119
120
121
122
123
124
125
126
127
128
129
130
131
132
133
134
135
136
137
138
139
140
141
<?php
Zend_Loader::loadClass('Piwik_SitesManager');
class Piwik_Access
{
	private $acl = null;
	private $accesssByIdsite = null;
	private $idsitesByAccess = null;
	private $identity = null; //login
	private $isSuperUser = false;
	
	
	static private $availableAccess = array('noaccess', 'view', 'admin', 'superuser');
	
	static public function getListAccess()
	{
		return self::$availableAccess;
	}
	
	public function __construct( $auth )
	{
		$this->auth = $auth;
    }
	
	public function loadAccess()
	{
		$accessByIdsite = array();
		$idsitesByAccess = array( 'view' => array(), 'admin'  => array(), 'superuser'  => array());
		
		// access = array ( idsite => accessIdSite, idsite2 => accessIdSite2)
        $result = $this->auth->authenticate();
		
		if($result->isValid())
		{
			$this->identity = $result->getIdentity();
			
			// case the superUser is logged in
			if($result->getCode() == Piwik_Auth::SUCCESS_SUPERUSER_AUTH_CODE)
			{
				$this->isSuperUser = true;
				$sitesId = Piwik_SitesManager::getAllSitesId();
				foreach($sitesId as $idSite)
				{
					$accessByIdsite[$idSite] = 'superuser';
					$idsitesByAccess['superuser'][] = $idSite;
				}
			}
			// valid authentification (normal user logged in)
			else
			{				
				$db = Zend_Registry::get('db');
				$accessRaw = $db->fetchAll("SELECT access, idsite 
								  FROM ".Piwik::prefixTable('access').
								" WHERE login=?", $this->identity);
	
				foreach($accessRaw as $access)
				{
					$accessByIdsite[$access['idsite']] = $access['access'];
					$idsitesByAccess[$access['access']][] = $access['idsite'];
				}
			}
		}
		
		$this->accessByIdsite = $accessByIdsite;
		$this->idsitesByAccess = $idsitesByAccess;
	}
	
	public function getIdentity()
	{
		return $this->identity;
	}
	
	public function getSitesIdWithAtLeastViewAccess()
	{
		return array_unique(array_merge(
					$this->idsitesByAccess['view'],
					$this->idsitesByAccess['admin'],
					$this->idsitesByAccess['superuser']));
	}
	
	public function getSitesIdWithAdminAccess()
	{
		return array_unique(array_merge(
					$this->idsitesByAccess['admin'],
					$this->idsitesByAccess['superuser']));
	}
	
	public function getSitesIdWithViewAccess()
	{
		return 	$this->idsitesByAccess['view'];
	}
		
	public function checkUserIsSuperUser()
	{
		if($this->isSuperUser === false)
		{
			throw new Exception("You can't access this resource as it requires a 'superuser' access.");
		}
	}
	
	public function checkUserHasSomeAdminAccess()
	{
			$idSitesAccessible = $this->getSitesIdWithAdminAccess();
			if(count($idSitesAccessible) == 0)
			{
				throw new Exception("You can't access this resource as it requires an 'admin' access for at least one website.");
			}
	}
	public function checkUserHasAdminAccess( $idSites )
	{
		if(!is_array($idSites))
		{
			$idSites = array($idSites);
		}
			$idSitesAccessible = $this->getSitesIdWithAdminAccess();
			foreach($idSites as $idsite)
			{
				if(!in_array($idsite, $idSitesAccessible))
				{
					throw new Exception("You can't access this resource as it requires an 'admin' access for the website id = $idsite.");
				}
			}
	}
	
	public function checkUserHasViewAccess( $idSites )
	{
		if(!is_array($idSites))
		{
			$idSites = array($idSites);
		}
			$idSitesAccessible = $this->getSitesIdWithAtLeastViewAccess();
			foreach($idSites as $idsite)
			{
				if(!in_array($idsite, $idSitesAccessible))
				{
					throw new Exception("You can't access this resource as it requires a 'view' access for the website id = $idsite.");
				}
			}
	}
}

?>