wanglizhong
2025-05-05 9b8a7157bb9c401de973a4107f74ff3e723ec156
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
<?php
class LtRbac {
 
    public $configHandle;
 
    protected $acl; 
 
    public function __construct()
    {
        if (! $this->configHandle instanceof LtConfig)
        {
            if (class_exists("LtObjectUtil", false))
            {
                $this->configHandle = LtObjectUtil::singleton("LtConfig");
            }
            else
            {
                $this->configHandle = new LtConfig;
            }
        }
    }
 
    public function init()
    {
        $this->acl = $this->configHandle->get('rbac.acl');
    }
 
    public function checkAcl($roles, $resource)
    {
        $allow = false;
        // deny priority
        foreach (array("allow", "deny") as $operation) 
        {
            foreach($roles as $role) 
            {
                if (isset($this->acl[$operation][$role])) 
                {
                    // everyone *
                    if (in_array($resource, $this->acl[$operation]['*'])) 
                    {
                        $allow = "allow" == $operation ? true : false;
                        break;
                    } 
                    if (in_array($resource, $this->acl[$operation][$role])) 
                    {
                        $allow = "allow" == $operation ? true : false;
                        break;
                    }
                    else 
                    {
                        $res = explode('/', trim($resource, '/'));
                        for ($i = count($res)-1; $i >= 0; $i--) 
                        {
                            $res[$i] = '*';
                            $tmp = implode('/', $res);
                            if (in_array($tmp, $this->acl[$operation][$role])) 
                            {
                                $allow = "allow" == $operation ? true : false;
                                break;
                            }
                            unset($res[$i]);
                        }
                    }
                }
            }
        }
        return $allow;
    }
/*
    private function __set($p,$v)
    {
        $this->$p = $v;
    }
 
    private function __get($p)
    {
        if(isset($this->$p))
        {
            return($this->$p);
        }
        else
        {
            return(NULL);
        }
    }
*/
}