-
Notifications
You must be signed in to change notification settings - Fork 676
Expand file tree
/
Copy pathmember_roles.py
More file actions
102 lines (92 loc) · 2.77 KB
/
member_roles.py
File metadata and controls
102 lines (92 loc) · 2.77 KB
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
"""
GitLab API:
https://docs.gitlab.com/ee/api/instance_level_ci_variables.html
https://docs.gitlab.com/ee/api/project_level_variables.html
https://docs.gitlab.com/ee/api/group_level_variables.html
"""
from gitlab.base import RESTObject
from gitlab.mixins import (
CreateMixin,
DeleteMixin,
ListMixin,
ObjectDeleteMixin,
SaveMixin,
)
from gitlab.types import RequiredOptional
__all__ = [
"MemberRole",
"MemberRoleManager",
"GroupMemberRole",
"GroupMemberRoleManager",
]
class MemberRole(SaveMixin, ObjectDeleteMixin, RESTObject):
pass
class MemberRoleManager(
ListMixin[MemberRole], CreateMixin[MemberRole], DeleteMixin[MemberRole]
):
_path = "/member_roles"
_obj_cls = MemberRole
_create_attrs = RequiredOptional(
required=("name", "base_access_level"),
optional=(
"description",
"admin_cicd_variables",
"admin_compliance_framework",
"admin_group_member",
"admin_group_member",
"admin_merge_request",
"admin_push_rules",
"admin_terraform_state",
"admin_vulnerability",
"admin_web_hook",
"archive_project",
"manage_deploy_tokens",
"manage_group_access_tokens",
"manage_merge_request_settings",
"manage_project_access_tokens",
"manage_security_policy_link",
"read_code",
"read_runners",
"read_dependency",
"read_vulnerability",
"remove_group",
"remove_project",
),
)
class GroupMemberRole(SaveMixin, ObjectDeleteMixin, RESTObject):
pass
class GroupMemberRoleManager(
ListMixin[GroupMemberRole],
CreateMixin[GroupMemberRole],
DeleteMixin[GroupMemberRole],
):
_path = "/groups/{group_id}/member_roles"
_from_parent_attrs = {"group_id": "id"}
_obj_cls = GroupMemberRole
_create_attrs = RequiredOptional(
required=("name", "base_access_level"),
optional=(
"description",
"admin_cicd_variables",
"admin_compliance_framework",
"admin_group_member",
"admin_group_member",
"admin_merge_request",
"admin_push_rules",
"admin_terraform_state",
"admin_vulnerability",
"admin_web_hook",
"archive_project",
"manage_deploy_tokens",
"manage_group_access_tokens",
"manage_merge_request_settings",
"manage_project_access_tokens",
"manage_security_policy_link",
"read_code",
"read_runners",
"read_dependency",
"read_vulnerability",
"remove_group",
"remove_project",
),
)