summaryrefslogtreecommitdiffstats
path: root/library/Pbs/Acl.php
blob: 06cb5366e2805a4a4d37e91003e4f9166846ac7b (plain) (blame)
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
<?php
/*
 * Copyright (c) 2011 - OpenSLX GmbH, RZ Uni Freiburg
 * This program is free software distributed under the GPL version 2.
 * See http://gpl.openslx.org/
 *
 * If you have any feedback please consult http://feedback.openslx.org/ and
 * send your suggestions, praise, or complaints to feedback@openslx.org
 *
 * General information about OpenSLX can be found at http://openslx.org/
 */

class Pbs_Acl {

  public static function checkRight($rightShortcut) {

    $userIDsNamespace = Zend_Session::namespaceGet('userIDs');
    if(!isset($userIDsNamespace['roleID']))
      { return false; }
    $roleID = $userIDsNamespace['roleID'];

    $rightMapper = new Application_Model_RightMapper();
    $element = $rightMapper->findBy(array('shortcut' => $rightShortcut), true);

    if($element == null)
      { return false; }

    $rightRolesMapper = new Application_Model_RightRolesMapper();
    $rightroles = $rightRolesMapper->findBy(array('roleID' => $roleID, 'rightID' => $element[0]['rightID']), true);

    if($rightroles != null)
      { return true; }

    return false;

  }

  public static function checkRightByMembershipID($membershipID, $rightShortcut) {
    $membershipMapper = new Application_Model_MembershipMapper();
    $membership = $membershipMapper->find($membershipID);
    $rightRolesMapper = new Application_Model_RightRolesMapper();
    $rightroles = $rightRolesMapper->findBy(array('roleID' => $membership->getRoleID()), true);
    $rightMapper = new Application_Model_RightMapper();
    foreach($rightroles as $rightrole) {
      $right = $rightMapper->find($rightrole['rightID']);
      if($right->getShortcut == $rightShortcut) {
        return true;
      }
    }
    return false;
  }
}