/usr/share/pyshared/zope/securitypolicy/vocabulary.py is in python-zope.securitypolicy 3.7.0-0ubuntu4.
This file is owned by root:root, with mode 0o644.
The actual contents of the file can be viewed below.
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 | ##############################################################################
#
# Copyright (c) 2004 Zope Foundation and Contributors.
# All Rights Reserved.
#
# This software is subject to the provisions of the Zope Public License,
# Version 2.1 (ZPL). A copy of the ZPL should accompany this distribution.
# THIS SOFTWARE IS PROVIDED "AS IS" AND ANY AND ALL EXPRESS OR IMPLIED
# WARRANTIES ARE DISCLAIMED, INCLUDING, BUT NOT LIMITED TO, THE IMPLIED
# WARRANTIES OF TITLE, MERCHANTABILITY, AGAINST INFRINGEMENT, AND FITNESS
# FOR A PARTICULAR PURPOSE.
#
##############################################################################
"""Role Id Vocabulary.
This vocabulary provides role IDs.
"""
__docformat__ = 'restructuredtext'
import zope.component
from zope.interface import implements, classProvides
from zope.schema.vocabulary import SimpleTerm, SimpleVocabulary
from zope.schema.interfaces import IVocabularyFactory
from zope.securitypolicy.interfaces import IRole
from zope.securitypolicy.interfaces import IGrantVocabulary
class RoleIdsVocabulary(SimpleVocabulary):
"""A vocabular of role IDs.
Term values are the role ID strings
Term are stored by title
To illustrate, we need to register the role IDs vocab:
>>> from zope.schema import vocabulary
>>> from zope.component.testing import setUp, tearDown
>>> setUp()
>>> vocabulary.setVocabularyRegistry(None)
>>> registry = vocabulary.getVocabularyRegistry()
>>> registry.register('Role Ids', RoleIdsVocabulary)
Let's register some sample roles to test against them
>>> from zope.securitypolicy.interfaces import IRole
>>> from zope.securitypolicy.role import Role
>>> from zope.component import provideUtility
>>> provideUtility(Role('a_id','a_title'), IRole, 'a_id')
>>> provideUtility(Role('b_id','b_title'), IRole, 'b_id')
Let's lookup the roles using the vocabulary
>>> vocab = registry.get(None, 'Role Ids')
>>> vocab.getTermByToken('a_id').value
u'a_id'
>>> vocab.getTermByToken('b_id').value
u'b_id'
>>> tearDown()
"""
classProvides(IVocabularyFactory)
def __init__(self, context):
terms = []
roles = zope.component.getUtilitiesFor(IRole, context)
for name, role in roles:
terms.append(SimpleTerm(name, name, name))
super(RoleIdsVocabulary, self).__init__(terms)
class GrantVocabulary(SimpleVocabulary):
"""A vocabular for getting the RadioWidget via the Choice field."""
classProvides(IVocabularyFactory)
implements(IGrantVocabulary)
|