source: WAeUP_SRP/branches/joachim-event-branch/PatchCPSUserFolderUserFolder.py @ 1563

Last change on this file since 1563 was 1558, checked in by joachim, 18 years ago

merged trunk up to 1557

File size: 4.7 KB
RevLine 
[880]1from AccessControl import ClassSecurityInfo
2from ExtensionClass import Base
3from Acquisition import Implicit
4from Acquisition import aq_base, aq_parent, aq_inner
5
6security = ClassSecurityInfo()
7
8security.declarePublic('getRolesInContext')
9def getRolesInContext(self, object):
[881]10    """Get the list of roles assigned to the user.
11    This includes local roles assigned in the context of
12    the passed in object.
13    Knows about local roles blocking (roles starting with '-').
14    """
[880]15    name = self.getUserName()
16    roles = self.getRoles()
[881]17    # deal with groups
18    groups = self.getComputedGroups()
19    # end groups
[880]20    local = {}
21    stop_loop = 0
[881]22    real_object = object
[880]23    object = aq_inner(object)
24    while 1:
25        # Collect all roles info
26        lrd = {}
27        local_roles = getattr(object, '__ac_local_roles__', None)
28        if local_roles:
29            if callable(local_roles):
30                local_roles = local_roles() or {}
31            for r in local_roles.get(name, ()):
32                if r:
33                    lrd[r] = None
34        local_group_roles = getattr(object, '__ac_local_group_roles__', None)
35        if local_group_roles:
36            if callable(local_group_roles):
37                local_group_roles = local_group_roles() or {}
38            for g in groups:
39                for r in local_group_roles.get(g, ()):
40                    if r:
41                        lrd[r] = None
42        lr = lrd.keys()
43        # Positive role assertions
44        for r in lr:
45            if r[0] != '-':
46                if not local.has_key(r):
47                    local[r] = 1 # acquired role
48        # Negative (blocking) role assertions
49        for r in lr:
50            if r[0] == '-':
51                r = r[1:]
52                if not r:
53                    # role '-' blocks all acquisition
54                    stop_loop = 1
55                    break
56                if not local.has_key(r):
57                    local[r] = 0 # blocked role
58        if stop_loop:
59            break
[881]60        if hasattr(object, 'aq_parent'):
61            object = aq_inner(object.aq_parent)
[880]62            continue
63        if hasattr(object, 'im_self'):
[881]64            object = aq_inner(object.im_self)
[880]65            continue
66        break
67    roles = list(roles)
68    for r, v in local.items():
69        if v: # only if not blocked
70            roles.append(r)
71    ## patch to assign dynamic roles for WAeUP
72    while 1:
[1035]73        if callable(real_object) and hasattr(real_object,'im_self'):
74            real_object = real_object.im_self
[1558]75
[1035]76        if hasattr(real_object,'portal_type') and\
[1515]77                   real_object.portal_type not in ("Student","StudentClearance","StudentStudyLevel"):
[880]78            break
[1558]79
80        #from pdb import set_trace;set_trace()
81        # can be later simplified by replacing by students_catalog values - Henrik
82        # getattr works always because of acquisition ?! Henrik
[902]83        sc = getattr(real_object,'study_course',None)
84        if sc is None:
85            break
[1471]86        sc_obj = sc.getContent()
[1558]87        cert_id = sc_obj.study_course
88        res_cert = self.portal_catalog(id = cert_id)
89        if len(res_cert) != 1:
[1471]90            break
[1558]91        certificate_brain = res_cert[0]
92        certificate_obj = certificate_brain.getObject()
93        cert_path = certificate_brain.getPath().split('/')
[1471]94        fac_id = cert_path[-4]
95        dep_id = cert_path[-3]
[1558]96        # temporary self-healing function
[1471]97        # deprecated after reindexing the students_catalog
[1076]98        student_id = self.getStudentId()
99        res = self.students_catalog(id=student_id)
[1066]100        if len(res) != 1:
101            break
[1558]102        st_entry = res[0]
103        if st_entry.faculty != fac_id or\
104           st_entry.department != dep_id or\
105           st_entry.course != cert_id:
106               self.students_catalog.modifyRecord(id = student_id,
[1471]107                                                faculty = fac_id,
108                                                department = dep_id,
[1558]109                                                course = cert_id
[1515]110                                                )
[1558]111        if real_object.portal_type == "StudentStudyLevel":
112            context_obj = getattr(certificate_obj,real_object.getId())
113            allowed = ('CourseAdviser', 'SectionManager')
114        else:
115            res = self.portal_catalog(portal_type="Department",id=dep_id)
116            allowed = ('ClearanceOfficer', 'SectionManager')
117            if len(res) != 1:
118                break
119            context_obj = res[0].getObject()
120        dynamic_roles = self.getRolesInContext(context_obj)
121        for dr in allowed:
[880]122            if dr in dynamic_roles:
123                roles.append(dr)
124        break
125    return roles
126
[881]127from Products.CPSUserFolder.CPSUserFolder import CPSUser
128CPSUser.getRolesInContext = getRolesInContext
Note: See TracBrowser for help on using the repository browser.