1
|
|
|
<?php |
2
|
|
|
|
3
|
|
|
/** |
4
|
|
|
* DefaultAcl |
5
|
|
|
* @copyright Copyright (c) 2011 - 2015 Aleksandr Torosh (http://wezoom.com.ua) |
6
|
|
|
* @author Aleksandr Torosh <[email protected]> |
7
|
|
|
*/ |
8
|
|
|
|
9
|
|
|
namespace Application\Acl; |
10
|
|
|
|
11
|
|
|
class DefaultAcl extends \Phalcon\Acl\Adapter\Memory |
12
|
|
|
{ |
13
|
|
|
|
14
|
|
|
public function __construct() |
15
|
|
|
{ |
16
|
|
|
parent::__construct(); |
17
|
|
|
|
18
|
|
|
$this->setDefaultAction(\Phalcon\Acl::DENY); |
19
|
|
|
|
20
|
|
|
/** |
21
|
|
|
* Full list of Roles |
22
|
|
|
*/ |
23
|
|
|
$roles = []; |
24
|
|
|
$roles['guest'] = new \Phalcon\Acl\Role('guest', 'Guest'); |
25
|
|
|
$roles['member'] = new \Phalcon\Acl\Role('member', 'Member'); |
26
|
|
|
|
27
|
|
|
$roles['journalist'] = new \Phalcon\Acl\Role('journalist', 'Journalist'); |
28
|
|
|
$roles['editor'] = new \Phalcon\Acl\Role('editor', 'Journalist'); |
29
|
|
|
$roles['admin'] = new \Phalcon\Acl\Role('admin', 'Admin'); |
30
|
|
|
|
31
|
|
|
/** |
32
|
|
|
* Frontend roles |
33
|
|
|
*/ |
34
|
|
|
$this->addRole($roles['guest']); |
35
|
|
|
$this->addRole($roles['member'], $roles['guest']); |
36
|
|
|
|
37
|
|
|
/** |
38
|
|
|
* Backend roles |
39
|
|
|
*/ |
40
|
|
|
$this->addRole($roles['journalist'], $roles['guest']); |
41
|
|
|
$this->addRole($roles['editor'], $roles['journalist']); |
42
|
|
|
$this->addRole($roles['admin']); |
43
|
|
|
|
44
|
|
|
/** |
45
|
|
|
* Include resources permissions list from file /app/config/acl.php |
46
|
|
|
*/ |
47
|
|
|
$resources = include APPLICATION_PATH . '/config/acl.php'; |
48
|
|
|
|
49
|
|
|
foreach ($resources as $roles_resources) { |
50
|
|
|
foreach ($roles_resources as $resource => $actions) { |
51
|
|
|
$registerActions = '*'; |
52
|
|
|
if (is_array($actions)) { |
53
|
|
|
$registerActions = $actions; |
54
|
|
|
} |
55
|
|
|
$this->addResource(new \Phalcon\Acl\Resource($resource), $registerActions); |
56
|
|
|
} |
57
|
|
|
} |
58
|
|
|
|
59
|
|
|
/** |
60
|
|
|
* Make unlimited access for admin role |
61
|
|
|
*/ |
62
|
|
|
$this->allow('admin', '*', '*'); |
63
|
|
|
|
64
|
|
|
/** |
65
|
|
|
* Set roles permissions |
66
|
|
|
*/ |
67
|
|
|
foreach ($roles as $k => $role) { |
68
|
|
|
$user_resource = $resources[$k]; |
69
|
|
|
foreach ($user_resource as $roles_resources => $method) { |
70
|
|
|
if ($method == '*') { |
71
|
|
|
$this->allow($k, $roles_resources, '*'); |
72
|
|
|
} else { |
73
|
|
|
$this->allow($k, $roles_resources, $method); |
74
|
|
|
} |
75
|
|
|
|
76
|
|
|
} |
77
|
|
|
} |
78
|
|
|
|
79
|
|
|
} |
80
|
|
|
|
81
|
|
|
} |