當前位置: 首頁>>代碼示例>>Python>>正文


Python AccessControl類代碼示例

本文整理匯總了Python中AccessControl的典型用法代碼示例。如果您正苦於以下問題:Python AccessControl類的具體用法?Python AccessControl怎麽用?Python AccessControl使用的例子?那麽, 這裏精選的類代碼示例或許可以為您提供幫助。


在下文中一共展示了AccessControl類的15個代碼示例,這些例子默認根據受歡迎程度排序。您可以為喜歡或者感覺有用的代碼點讚,您的評價將有助於係統推薦出更棒的Python代碼示例。

示例1: setupSecurityOptions

    def setupSecurityOptions(self):
        import AccessControl

        AccessControl.setImplementation(self.cfg.security_policy_implementation)
        AccessControl.setDefaultBehaviors(
            not self.cfg.skip_ownership_checking, not self.cfg.skip_authentication_checking, self.cfg.verbose_security
        )
開發者ID:pombredanne,項目名稱:Zope-1,代碼行數:7,代碼來源:__init__.py

示例2: _create_yearfolder

def _create_yearfolder(inbox, year):
    """creates the yearfolder for the given year"""

    _sm = AccessControl.getSecurityManager()
    AccessControl.SecurityManagement.newSecurityManager(
        inbox.REQUEST,
        AccessControl.SecurityManagement.SpecialUsers.system)
    try:
        # for creating the folder, we need to be a superuser since
        # normal user should not be able to add year folders.
        # --- help i18ndude ---
        msg = _(u'yearfolder_title', default=u'Closed ${year}',
                mapping=dict(year=str(year)))
        # --- / help i18ndude ---
        folder_title = translate(str(msg), msg.domain, msg.mapping,
                                 context=inbox.REQUEST, default=msg.default)
        folder = createContentInContainer(
            inbox, 'opengever.inbox.yearfolder',
            title=folder_title, id=year)
    except:
        AccessControl.SecurityManagement.setSecurityManager(_sm)
        raise
    else:
        AccessControl.SecurityManagement.setSecurityManager(_sm)

    return folder
開發者ID:pemzurigo,項目名稱:opengever.core,代碼行數:26,代碼來源:utils.py

示例3: __enter__

    def __enter__(self):
        assert self._original_security is None

        self._original_security = AccessControl.getSecurityManager()

        _system_user = AccessControl.SecurityManagement.SpecialUsers.system
        AccessControl.SecurityManagement.newSecurityManager(None, _system_user)
開發者ID:4teamwork,項目名稱:ftw.downloadtoken,代碼行數:7,代碼來源:downloadfile.py

示例4: is_already_done

    def is_already_done(self, transition, text):
        """This method returns `True` if this exact request was already
        executed.
        This is the case when the sender client has a conflict error when
        committing and the sender-request needs to be re-done. In this case
        this view is called another time but the changes were already made
        and committed - so we need to return "OK" and do nothing.
        """

        response_container = IResponseContainer(self.context)
        if len(response_container) == 0:
            return False

        last_response = response_container[-1]
        current_user = AccessControl.getSecurityManager().getUser()

        if (
            last_response.transition == transition
            and last_response.creator == current_user.getId()
            and last_response.text == text
        ):
            return True

        else:
            return False
開發者ID:4teamwork,項目名稱:opengever.core,代碼行數:25,代碼來源:statesyncer.py

示例5: setUp

    def setUp(self):
        """Shared test environment set-up, ran before every test."""
        portal = self.portal = self.layer['portal']
        portal._setObject('hpm', HasProtectedMethods('hpm'))

        sm = AccessControl.getSecurityManager()
        sm._policy._verbose = 1

        for role in ('Member', 'VIP', 'Manager'):
            portal._addRole(role)

        for permission, roles in role_mapping:
            portal.manage_permission(permission, roles, 1)

        api.user.create(
            username='boss',
            email='[email protected]',
            password='123',
            roles=('Member', 'VIP')
        )

        self._old_sm = AccessControl.SecurityManagement.getSecurityManager()

        AccessControl.SecurityManagement.newSecurityManager(
            self.portal.REQUEST,
            self.portal.acl_users.getUser('boss'),
        )
開發者ID:matejc,項目名稱:plone.api,代碼行數:27,代碼來源:test_env.py

示例6: participate_user

    def participate_user(self):
        """Participates `self.user` on `self.context`.
        """
        local_roles = dict(self.context.get_local_roles())
        # get all current local roles of the user on this context
        user_roles = list(local_roles.get(self.member.getId(), []))
        user_roles.extend(self.roles())
        # make the roles unique
        user_roles = dict(zip(user_roles, user_roles)).keys()

        # Set the local roles with the security of the inviter. If
        # he has no longer permissions on this context this will
        # fail.
        _old_security_manager = AccessControl.getSecurityManager()
        _new_user = self.context.acl_users.getUserById(
            self.invitation.inviter)
        AccessControl.SecurityManagement.newSecurityManager(
            self.request, _new_user)
        try:
            self.context.manage_setLocalRoles(self.member.getId(),
                                              user_roles)
            self.context.reindexObjectSecurity()
        except:
            AccessControl.SecurityManagement.setSecurityManager(
                _old_security_manager)
            raise
        else:
            AccessControl.SecurityManagement.setSecurityManager(
                _old_security_manager)
開發者ID:4teamwork,項目名稱:ftw.participation,代碼行數:29,代碼來源:setter.py

示例7: get_visible_groups

    def get_visible_groups(self):
        # get the top level site ID to use with the cache
        site_root = self.context.site_root()
        top_level_site_id = site_root.getId()

        user = AccessControl.getSecurityManager().getUser()
        userId = user.getId()
        groups = '-'.join(user.getGroups())
        key = '-'.join((top_level_site_id, self.siteInfo.id, groups))

        if self.siteUserVisibleGroupsIds.has_key(key):  # lint:ok
            visibleGroupsIds = self.siteUserVisibleGroupsIds.get(key)
            visibleGroups = []
            for groupId in visibleGroupsIds:
                try:
                    visibleGroups.append(getattr(self.groupsObj, groupId))
                except:
                    log.warn("trouble adding '%s' to visible groups" % groupId)
        else:
            top = time.time()
            visibleGroups = self.__visible_groups_for_current_user()
            visibleGroupsIds = [group.getId() for group in visibleGroups]
            self.siteUserVisibleGroupsIds.add(key, visibleGroupsIds)
            bottom = time.time()
            log.debug("Generated visible-groups for (%s) on %s (%s) in "
                        "%.2fms" % (userId, self.siteInfo.name,
                                    self.siteInfo.id, (bottom - top) * 1000.0))

        assert type(visibleGroups) == list, "visibleGroups is not a list"
        return visibleGroups
開發者ID:groupserver,項目名稱:gs.groups,代碼行數:30,代碼來源:groupsInfo.py

示例8: __visible_groups_for_current_user

 def __visible_groups_for_current_user(self):
     securityManager = AccessControl.getSecurityManager()
     allGroups = self.get_all_groups()
     # Quite a simple process, really: itterate through all the groups,
     #   checking to see if the "messages" instance is visible.
     visibleGroups = []
     for group in allGroups:
         # AM: "Visible groups" should really be: groups which a user
         #   is a member of, public groups, and private groups.
         #   Therefore, we should only be checking the visibility of the
         #   group, not of the messages.
         #
         #   A separate method ("visible messages" or similar) should be
         #   used to determine what messages and files should be included
         #   in search results (and in turn, latest topics and files on a
         #   site homepage) should be shown to users.
         #   **HOWEVER** at this point in time, we do not make a
         #   distinction. Therefore, to preserve security, we define
         #   "visible groups" very restrictively.
         if (hasattr(group, 'messages')
             and securityManager.checkPermission('View', group)
             and securityManager.checkPermission(
                 'View', group.aq_explicit.messages)):
             visibleGroups.append(group)
     assert type(visibleGroups) == list
     return visibleGroups
開發者ID:groupserver,項目名稱:gs.groups,代碼行數:26,代碼來源:groupsInfo.py

示例9: member_groups

 def member_groups(self):
     user = AccessControl.getSecurityManager().getUser()
     memberGroups = self.groupsInfo.get_member_groups_for_user(user, user)
     if self.maxGroupsToDisplay:
         memberGroups = memberGroups[:self.maxGroupsToDisplay]
     groups = map(IGSGroupInfo, memberGroups)
     return groups
開發者ID:e-democracy,項目名稱:edem.content.layout,代碼行數:7,代碼來源:contentprovider.py

示例10: getTransitionVocab

def getTransitionVocab(context):

    if AccessControl.getSecurityManager(
        ).getUser() == AccessControl.SpecialUsers.nobody:
        return SimpleVocabulary([])

    wftool = getToolByName(context, 'portal_workflow')
    transitions = []
    if opengever.task.task.ITask.providedBy(context) and \
            context.REQUEST.URL.find('++add++opengever.task.task') == -1:
        for tdef in wftool.getTransitionsFor(context):
            transitions.append(SimpleVocabulary.createTerm(
                    tdef['id'],
                    tdef['id'],
                    PMF(tdef['id'], default=tdef['title_or_id'])))
        return SimpleVocabulary(transitions)

    else:
        wf = wftool.get(wftool.getChainForPortalType('opengever.task.task')[0])
        state = wf.states.get(wf.initial_state)
        for tid in state.transitions:
            tdef = wf.transitions.get(tid, None)
            transitions.append(SimpleVocabulary.createTerm(
                    tdef.id,
                    tdef.id,
                    PMF(tdef.id, default=tdef.title_or_id)))
        return SimpleVocabulary(transitions)
開發者ID:pemzurigo,項目名稱:opengever.core,代碼行數:27,代碼來源:util.py

示例11: update_cache

    def update_cache(self, xslt_obj, source, result, anonymous_only=1):
        """ Update the page cache, based on several conditions.
        
        """
        import time, md5, AccessControl
        
        sm = AccessControl.getSecurityManager()
        user_id = sm.getUser().getId()
        if anonymous_only and user_id != None:
            return 0
        
        checksum = md5.new(source).hexdigest()
        
        page_cache = getattr(self, '_page_cache', OOBTree())
        
        # create the cache file name -- include the user_id, primarily for
        # debugging
        xid = xslt_obj.getId()
        cache_fname = '%s_%s_%s' % (xid, user_id, checksum)
        cachekey = '%s%s' % (xid, checksum)
        if user_id == None:
            page_cache[cachekey] = (cache_fname, time.time(), 0)
        else:
            page_cache[cachekey] = (cache_fname, time.time(), 1)

        cache_file = file('%s/%s' % (self.cache_dir, cache_fname), 'w+')
        cache_file.write(result)
        cache_file.close()
        
        self._page_cache = page_cache
        
        return 1
開發者ID:groupserver,項目名稱:Products.DataTemplates,代碼行數:32,代碼來源:DTCacheManager.py

示例12: attachable_documents_vocabulary

def attachable_documents_vocabulary(context):
    terms = []

    user = AccessControl.getSecurityManager().getUser()
    if user == AccessControl.SpecialUsers.nobody:
        return SimpleVocabulary(terms)

    intids = getUtility(IIntIds)

    ids = []

    for doc in context.getFolderContents(
        full_objects=True,
        contentFilter={'portal_type': ['opengever.document.document',
                                       'ftw.mail.mail']}):

        key = str(intids.getId(doc))
        label = doc.Title()
        terms.append(SimpleVocabulary.createTerm(key, key, label))
        ids.append(key)

    for relation in getattr(context, 'relatedItems', []):
        key = str(relation.to_id)
        # check if the task doesn't contain the related document allready
        if key in ids:
            continue
        label = relation.to_object.Title()
        terms.append(SimpleVocabulary.createTerm(key, key, label))

    return SimpleVocabulary(terms)
開發者ID:pemzurigo,項目名稱:opengever.core,代碼行數:30,代碼來源:vocabulary.py

示例13: checkPermission

def checkPermission(permission, context=None):
    """
    Return true if the current user has the specified permission on the given
    context or the dmd; otherwise, return false.
    """
    manager = AccessControl.getSecurityManager()
    context = context or get_dmd()
    return manager.checkPermission(permission, context)
開發者ID:bbc,項目名稱:zenoss-prodbin,代碼行數:8,代碼來源:__init__.py

示例14: __call__

 def __call__(self, *args, **kwargs):
     """Add the zope user to the security context, as done in
     PageTemplateFile"""
     if not kwargs.has_key('args'):
         kwargs['args'] = args
         bound_names = {'options': kwargs}
         security = AccessControl.getSecurityManager()
         bound_names['user'] = security.getUser()
         return self.pt_render(extra_context=bound_names)
開發者ID:Cenditel,項目名稱:cenditel.comunidades.cynin,代碼行數:9,代碼來源:_named.py

示例15: configure_zope

def configure_zope(config_filename, debug_mode=False):
    """Read zope.conf with zdaemon^Wzcrap.
    """
    from Zope2.Startup import options, handlers
    import AccessControl

    del sys.argv[1:]
    opts = options.ZopeOptions()
    opts.configfile = config_filename
    opts.realize(raise_getopt_errs=0)

    handlers.handleConfig(opts.configroot, opts.confighandlers)
    AccessControl.setImplementation(
        opts.configroot.security_policy_implementation)
    AccessControl.setDefaultBehaviors(
        not opts.configroot.skip_ownership_checking,
        not opts.configroot.skip_authentication_checking,
        opts.configroot.verbose_security)
    App.config.setConfiguration(opts.configroot)
    set_zope_debug_mode(debug_mode)
開發者ID:infrae,項目名稱:infrae.wsgi,代碼行數:20,代碼來源:paster.py


注:本文中的AccessControl類示例由純淨天空整理自Github/MSDocs等開源代碼及文檔管理平台,相關代碼片段篩選自各路編程大神貢獻的開源項目,源碼版權歸原作者所有,傳播和使用請參考對應項目的License;未經允許,請勿轉載。