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
88
89
90
91
92
93
94
95
96
97
98
99
100
101
102
103
104
105
106
107
108
109
110
111
112
113
114
115
116
117
118
119
120
121
122
123
124
125
126
127
128
129
130
131
132
133
134
135
136
137
138
139
140
141
142
143
144
145
146
147
148
149
150
151
152
|
# Copyright 2009 Canonical Ltd. This software is licensed under the
# GNU Affero General Public License version 3 (see the file LICENSE).
# pylint: disable-msg=E0211,E0213,W0611
"""Interfaces that define common roles associated with objects."""
__metaclass__ = type
__all__ = [
'IHasAppointedDriver',
'IHasDrivers',
'IHasOwner',
'IPersonRoles',
]
from zope.interface import (
Attribute,
Interface,
)
from zope.schema import (
Bool,
Choice,
)
from canonical.launchpad import _
class IHasOwner(Interface):
"""An object that has an owner."""
owner = Attribute("The object's owner, which is an IPerson.")
class IHasDrivers(Interface):
"""An object that has drivers.
Drivers have permission to approve bugs and features for specific
series.
"""
drivers = Attribute("A list of drivers")
def personHasDriverRights(person):
"""Does the given person have launchpad.Driver rights on this object?
True if the person is one of this object's drivers, its owner or a
Launchpad admin.
"""
class IHasAppointedDriver(Interface):
"""An object that has an appointed driver."""
driver = Choice(
title=_("Driver"), required=False, vocabulary='ValidPersonOrTeam')
class IPersonRoles(Interface):
"""What celebrity teams a person is member of and similar helpers.
Convenience methods that remove frequent calls to ILaunchpadCelebrities
and IPerson.inTeam from permission checkers. May also be used in model
or view code.
All person celebrities in ILaunchpadCelbrities must have a matching
in_ attribute here and vice versa.
"""
person = Attribute("The IPerson object that these checks refer to.")
in_admin = Bool(
title=_("True if this person is a Launchpad admin."),
required=True, readonly=True)
in_bazaar_experts = Bool(
title=_("True if this person is a Bazaar expert."),
required=True, readonly=True)
in_software_center_agent = Bool(
title=_("True if this person is the Software Center Agent."),
required=True, readonly=True)
in_bug_importer = Bool(
title=_("True if this person is a bug importer."),
required=True, readonly=True)
in_bug_watch_updater = Bool(
title=_("True if this person is a bug watch updater."),
required=True, readonly=True)
in_buildd_admin = Bool(
title=_("True if this person is a buildd admin."),
required=True, readonly=True)
in_commercial_admin = Bool(
title=_("True if this person is a commercial admin."),
required=True, readonly=True)
in_hwdb_team = Bool(
title=_("True if this person is on the hwdb team."),
required=True, readonly=True)
in_janitor = Bool(
title=_("True if this person is the janitor."),
required=True, readonly=True)
in_katie = Bool(
title=_("True if this person is Katie."),
required=True, readonly=True)
in_launchpad_beta_testers = Bool(
title=_("True if this person is a Launchpad beta tester."),
required=True, readonly=True)
in_launchpad_developers = Bool(
title=_("True if this person is a Launchpad developer."),
required=True, readonly=True)
in_ppa_key_guard = Bool(
title=_("True if this person is the ppa key guard."),
required=True, readonly=True)
in_registry_experts = Bool(
title=_("True if this person is a registry expert."),
required=True, readonly=True)
in_rosetta_experts = Bool(
title=_("True if this person is a rosetta expert."),
required=True, readonly=True)
in_ubuntu_security = Bool(
title=_("True if this person is on the Ubuntu security team."),
required=True, readonly=True)
in_ubuntu_techboard = Bool(
title=_("True if this person is on the Ubuntu tech board."),
required=True, readonly=True)
in_vcs_imports = Bool(
title=_("True if this person is on the vcs-imports team."),
required=True, readonly=True)
def inTeam(team):
"""Is this person a member or the owner of `team`?
Passed through to the same method in 'IPersonPublic'.
"""
def isOwner(obj):
"""Is this person the owner of the object?"""
def isDriver(obj):
"""Is this person the driver of the object?"""
def isOneOfDrivers(obj):
"""Is this person on of the drivers of the object?
Works on objects that implement 'IHasDrivers' but will default to
isDriver if it doesn't, i.e. check the driver attribute.
"""
def isOneOf(obj, attributes):
"""Is this person one of the roles in relation to the object?
Check if the person is inTeam of one of the given IPerson attributes
of the object.
:param obj: The object to check the relation to.
:param attributes: A list of attribute names to check with inTeam.
"""
|