pulumi-azuredevops 2.16.0a1710156155__py3-none-any.whl → 3.6.0a1736832240__py3-none-any.whl
This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
- pulumi_azuredevops/__init__.py +123 -174
- pulumi_azuredevops/_inputs.py +1742 -110
- pulumi_azuredevops/_utilities.py +41 -5
- pulumi_azuredevops/area_permissions.py +9 -6
- pulumi_azuredevops/branch_policy_auto_reviewers.py +52 -49
- pulumi_azuredevops/branch_policy_build_validation.py +86 -79
- pulumi_azuredevops/branch_policy_comment_resolution.py +60 -57
- pulumi_azuredevops/branch_policy_merge_types.py +68 -65
- pulumi_azuredevops/branch_policy_min_reviewers.py +72 -71
- pulumi_azuredevops/branch_policy_status_check.py +66 -61
- pulumi_azuredevops/branch_policy_work_item_linking.py +60 -57
- pulumi_azuredevops/build_definition.py +380 -200
- pulumi_azuredevops/build_definition_permissions.py +186 -165
- pulumi_azuredevops/build_folder.py +13 -10
- pulumi_azuredevops/build_folder_permissions.py +33 -32
- pulumi_azuredevops/check_approval.py +49 -16
- pulumi_azuredevops/check_branch_control.py +139 -110
- pulumi_azuredevops/check_business_hours.py +137 -108
- pulumi_azuredevops/check_exclusive_lock.py +107 -30
- pulumi_azuredevops/check_required_template.py +96 -67
- pulumi_azuredevops/config/__init__.pyi +87 -0
- pulumi_azuredevops/config/vars.py +125 -0
- pulumi_azuredevops/elastic_pool.py +78 -26
- pulumi_azuredevops/environment.py +17 -10
- pulumi_azuredevops/environment_resource_kubernetes.py +534 -0
- pulumi_azuredevops/feed.py +372 -0
- pulumi_azuredevops/feed_permission.py +415 -0
- pulumi_azuredevops/get_agent_queue.py +28 -19
- pulumi_azuredevops/get_area.py +28 -15
- pulumi_azuredevops/get_build_definition.py +32 -15
- pulumi_azuredevops/get_client_config.py +12 -9
- pulumi_azuredevops/get_environment.py +72 -5
- pulumi_azuredevops/get_feed.py +186 -0
- pulumi_azuredevops/get_git_repository.py +39 -10
- pulumi_azuredevops/get_group.py +55 -22
- pulumi_azuredevops/get_groups.py +18 -9
- pulumi_azuredevops/get_identity_group.py +152 -0
- pulumi_azuredevops/get_identity_groups.py +140 -0
- pulumi_azuredevops/get_identity_users.py +122 -0
- pulumi_azuredevops/get_iteration.py +24 -11
- pulumi_azuredevops/get_pool.py +16 -9
- pulumi_azuredevops/get_pools.py +12 -9
- pulumi_azuredevops/get_project.py +22 -10
- pulumi_azuredevops/get_projects.py +16 -9
- pulumi_azuredevops/get_repositories.py +22 -9
- pulumi_azuredevops/get_securityrole_definitions.py +141 -0
- pulumi_azuredevops/get_service_endpoint_azure_rm.py +70 -26
- pulumi_azuredevops/get_service_endpoint_github.py +19 -13
- pulumi_azuredevops/get_serviceendpoint_azurecr.py +31 -11
- pulumi_azuredevops/get_serviceendpoint_bitbucket.py +219 -0
- pulumi_azuredevops/get_serviceendpoint_npm.py +22 -11
- pulumi_azuredevops/get_serviceendpoint_sonarcloud.py +21 -11
- pulumi_azuredevops/get_team.py +29 -15
- pulumi_azuredevops/get_teams.py +16 -9
- pulumi_azuredevops/get_users.py +26 -87
- pulumi_azuredevops/get_variable_group.py +27 -17
- pulumi_azuredevops/git.py +57 -99
- pulumi_azuredevops/git_permissions.py +78 -75
- pulumi_azuredevops/git_repository_branch.py +29 -20
- pulumi_azuredevops/git_repository_file.py +23 -18
- pulumi_azuredevops/group.py +43 -16
- pulumi_azuredevops/group_entitlement.py +5 -8
- pulumi_azuredevops/group_membership.py +57 -30
- pulumi_azuredevops/iterative_permissions.py +9 -6
- pulumi_azuredevops/library_permissions.py +451 -0
- pulumi_azuredevops/outputs.py +460 -56
- pulumi_azuredevops/pipeline_authorization.py +136 -47
- pulumi_azuredevops/pool.py +7 -6
- pulumi_azuredevops/project.py +19 -18
- pulumi_azuredevops/project_features.py +9 -8
- pulumi_azuredevops/project_permissions.py +9 -6
- pulumi_azuredevops/project_pipeline_settings.py +15 -12
- pulumi_azuredevops/provider.py +491 -2
- pulumi_azuredevops/pulumi-plugin.json +2 -1
- pulumi_azuredevops/queue.py +23 -24
- pulumi_azuredevops/repository_policy_author_email_pattern.py +37 -34
- pulumi_azuredevops/repository_policy_case_enforcement.py +37 -34
- pulumi_azuredevops/repository_policy_check_credentials.py +37 -34
- pulumi_azuredevops/repository_policy_file_path_pattern.py +31 -28
- pulumi_azuredevops/repository_policy_max_file_size.py +44 -41
- pulumi_azuredevops/repository_policy_max_path_length.py +37 -34
- pulumi_azuredevops/repository_policy_reserved_names.py +37 -34
- pulumi_azuredevops/resource_authorization.py +23 -20
- pulumi_azuredevops/securityrole_assignment.py +295 -0
- pulumi_azuredevops/service_endpoint_artifactory.py +49 -48
- pulumi_azuredevops/service_endpoint_aws.py +99 -51
- pulumi_azuredevops/service_endpoint_azure_dev_ops.py +17 -14
- pulumi_azuredevops/service_endpoint_azure_ecr.py +275 -33
- pulumi_azuredevops/service_endpoint_azure_rm.py +236 -114
- pulumi_azuredevops/service_endpoint_bit_bucket.py +19 -18
- pulumi_azuredevops/service_endpoint_docker_registry.py +17 -16
- pulumi_azuredevops/service_endpoint_generic.py +19 -20
- pulumi_azuredevops/service_endpoint_generic_git.py +17 -14
- pulumi_azuredevops/service_endpoint_git_hub.py +57 -60
- pulumi_azuredevops/service_endpoint_git_hub_enterprise.py +26 -23
- pulumi_azuredevops/{serviceendpoint/bit_bucket.py → service_endpoint_git_lab.py} +147 -100
- pulumi_azuredevops/service_endpoint_kubernetes.py +160 -17
- pulumi_azuredevops/service_endpoint_npm.py +17 -14
- pulumi_azuredevops/service_endpoint_pipeline.py +28 -25
- pulumi_azuredevops/service_endpoint_service_fabric.py +42 -95
- pulumi_azuredevops/service_endpoint_sonar_cloud.py +17 -14
- pulumi_azuredevops/service_endpoint_sonar_qube.py +17 -14
- pulumi_azuredevops/service_endpoint_ssh.py +17 -14
- pulumi_azuredevops/serviceendpoint_argocd.py +51 -50
- pulumi_azuredevops/serviceendpoint_azure_service_bus.py +429 -0
- pulumi_azuredevops/serviceendpoint_dynamics_lifecycle_services.py +579 -0
- pulumi_azuredevops/serviceendpoint_externaltfs.py +10 -5
- pulumi_azuredevops/serviceendpoint_gcp_terraform.py +17 -14
- pulumi_azuredevops/serviceendpoint_incomingwebhook.py +17 -14
- pulumi_azuredevops/serviceendpoint_jenkins.py +15 -12
- pulumi_azuredevops/serviceendpoint_jfrog_artifactory_v2.py +53 -52
- pulumi_azuredevops/serviceendpoint_jfrog_distribution_v2.py +53 -52
- pulumi_azuredevops/serviceendpoint_jfrog_platform_v2.py +53 -52
- pulumi_azuredevops/serviceendpoint_jfrog_xray_v2.py +53 -52
- pulumi_azuredevops/serviceendpoint_maven.py +49 -48
- pulumi_azuredevops/serviceendpoint_nexus.py +15 -12
- pulumi_azuredevops/serviceendpoint_nuget.py +17 -14
- pulumi_azuredevops/serviceendpoint_octopusdeploy.py +17 -14
- pulumi_azuredevops/serviceendpoint_permissions.py +21 -18
- pulumi_azuredevops/serviceendpoint_snyk.py +429 -0
- pulumi_azuredevops/serviceendpoint_visualstudiomarketplace.py +543 -0
- pulumi_azuredevops/servicehook_permissions.py +9 -6
- pulumi_azuredevops/servicehook_storage_queue_pipelines.py +55 -48
- pulumi_azuredevops/tagging_permissions.py +9 -6
- pulumi_azuredevops/team.py +21 -16
- pulumi_azuredevops/team_administrators.py +19 -12
- pulumi_azuredevops/team_members.py +19 -12
- pulumi_azuredevops/user.py +27 -8
- pulumi_azuredevops/variable_group.py +91 -88
- pulumi_azuredevops/variable_group_permissions.py +517 -0
- pulumi_azuredevops/wiki.py +509 -0
- pulumi_azuredevops/wiki_page.py +377 -0
- pulumi_azuredevops/work_item_query_permissions.py +17 -18
- pulumi_azuredevops/workitem.py +25 -24
- {pulumi_azuredevops-2.16.0a1710156155.dist-info → pulumi_azuredevops-3.6.0a1736832240.dist-info}/METADATA +9 -8
- pulumi_azuredevops-3.6.0a1736832240.dist-info/RECORD +140 -0
- {pulumi_azuredevops-2.16.0a1710156155.dist-info → pulumi_azuredevops-3.6.0a1736832240.dist-info}/WHEEL +1 -1
- pulumi_azuredevops/agent/__init__.py +0 -12
- pulumi_azuredevops/agent/get_pool.py +0 -155
- pulumi_azuredevops/agent/get_pools.py +0 -120
- pulumi_azuredevops/agent/outputs.py +0 -73
- pulumi_azuredevops/agent/pool.py +0 -342
- pulumi_azuredevops/agent/queue.py +0 -376
- pulumi_azuredevops/build/__init__.py +0 -10
- pulumi_azuredevops/build/_inputs.py +0 -1164
- pulumi_azuredevops/build/build_definition.py +0 -987
- pulumi_azuredevops/build/outputs.py +0 -1170
- pulumi_azuredevops/core/__init__.py +0 -13
- pulumi_azuredevops/core/get_client_config.py +0 -102
- pulumi_azuredevops/core/get_project.py +0 -194
- pulumi_azuredevops/core/get_projects.py +0 -166
- pulumi_azuredevops/core/outputs.py +0 -70
- pulumi_azuredevops/core/project.py +0 -538
- pulumi_azuredevops/core/project_features.py +0 -303
- pulumi_azuredevops/entitlement/__init__.py +0 -8
- pulumi_azuredevops/entitlement/user.py +0 -429
- pulumi_azuredevops/identities/__init__.py +0 -13
- pulumi_azuredevops/identities/_inputs.py +0 -42
- pulumi_azuredevops/identities/get_group.py +0 -185
- pulumi_azuredevops/identities/get_users.py +0 -257
- pulumi_azuredevops/identities/group.py +0 -632
- pulumi_azuredevops/identities/group_membership.py +0 -333
- pulumi_azuredevops/identities/outputs.py +0 -124
- pulumi_azuredevops/pipeline/__init__.py +0 -10
- pulumi_azuredevops/pipeline/_inputs.py +0 -175
- pulumi_azuredevops/pipeline/outputs.py +0 -175
- pulumi_azuredevops/pipeline/variable_group.py +0 -594
- pulumi_azuredevops/policy/__init__.py +0 -11
- pulumi_azuredevops/policy/_inputs.py +0 -382
- pulumi_azuredevops/policy/branch_policy_build_validation.py +0 -424
- pulumi_azuredevops/policy/branch_policy_min_reviewers.py +0 -406
- pulumi_azuredevops/policy/outputs.py +0 -397
- pulumi_azuredevops/repository/__init__.py +0 -11
- pulumi_azuredevops/repository/_inputs.py +0 -85
- pulumi_azuredevops/repository/get_repositories.py +0 -177
- pulumi_azuredevops/repository/git.py +0 -627
- pulumi_azuredevops/repository/outputs.py +0 -199
- pulumi_azuredevops/security/__init__.py +0 -8
- pulumi_azuredevops/security/resource_authorization.py +0 -404
- pulumi_azuredevops/serviceendpoint/__init__.py +0 -14
- pulumi_azuredevops/serviceendpoint/_inputs.py +0 -341
- pulumi_azuredevops/serviceendpoint/azure_rm.py +0 -1140
- pulumi_azuredevops/serviceendpoint/docker_registry.py +0 -595
- pulumi_azuredevops/serviceendpoint/git_hub.py +0 -489
- pulumi_azuredevops/serviceendpoint/kubernetes.py +0 -523
- pulumi_azuredevops/serviceendpoint/outputs.py +0 -370
- pulumi_azuredevops-2.16.0a1710156155.dist-info/RECORD +0 -171
- {pulumi_azuredevops-2.16.0a1710156155.dist-info → pulumi_azuredevops-3.6.0a1736832240.dist-info}/top_level.txt +0 -0
@@ -1,333 +0,0 @@
|
|
1
|
-
# coding=utf-8
|
2
|
-
# *** WARNING: this file was generated by the Pulumi Terraform Bridge (tfgen) Tool. ***
|
3
|
-
# *** Do not edit by hand unless you're certain you know what you are doing! ***
|
4
|
-
|
5
|
-
import copy
|
6
|
-
import warnings
|
7
|
-
import pulumi
|
8
|
-
import pulumi.runtime
|
9
|
-
from typing import Any, Mapping, Optional, Sequence, Union, overload
|
10
|
-
from .. import _utilities
|
11
|
-
|
12
|
-
__all__ = ['GroupMembershipArgs', 'GroupMembership']
|
13
|
-
|
14
|
-
@pulumi.input_type
|
15
|
-
class GroupMembershipArgs:
|
16
|
-
def __init__(__self__, *,
|
17
|
-
group: pulumi.Input[str],
|
18
|
-
members: pulumi.Input[Sequence[pulumi.Input[str]]],
|
19
|
-
mode: Optional[pulumi.Input[str]] = None):
|
20
|
-
"""
|
21
|
-
The set of arguments for constructing a GroupMembership resource.
|
22
|
-
:param pulumi.Input[str] group: The descriptor of the group being managed.
|
23
|
-
:param pulumi.Input[Sequence[pulumi.Input[str]]] members: A list of user or group descriptors that will become members of the group.
|
24
|
-
> NOTE: It's possible to define group members both within the `GroupMembership resource` via the members block and by using the `Group` resource. However it's not possible to use both methods to manage group members, since there'll be conflicts.
|
25
|
-
:param pulumi.Input[str] mode: The mode how the resource manages group members.
|
26
|
-
- `mode == add`: the resource will ensure that all specified members will be part of the referenced group
|
27
|
-
- `mode == overwrite`: the resource will replace all existing members with the members specified within the `members` block
|
28
|
-
> NOTE: To clear all members from a group, specify an empty list of descriptors in the `members` attribute and set the `mode` member to `overwrite`.
|
29
|
-
"""
|
30
|
-
pulumi.set(__self__, "group", group)
|
31
|
-
pulumi.set(__self__, "members", members)
|
32
|
-
if mode is not None:
|
33
|
-
pulumi.set(__self__, "mode", mode)
|
34
|
-
|
35
|
-
@property
|
36
|
-
@pulumi.getter
|
37
|
-
def group(self) -> pulumi.Input[str]:
|
38
|
-
"""
|
39
|
-
The descriptor of the group being managed.
|
40
|
-
"""
|
41
|
-
return pulumi.get(self, "group")
|
42
|
-
|
43
|
-
@group.setter
|
44
|
-
def group(self, value: pulumi.Input[str]):
|
45
|
-
pulumi.set(self, "group", value)
|
46
|
-
|
47
|
-
@property
|
48
|
-
@pulumi.getter
|
49
|
-
def members(self) -> pulumi.Input[Sequence[pulumi.Input[str]]]:
|
50
|
-
"""
|
51
|
-
A list of user or group descriptors that will become members of the group.
|
52
|
-
> NOTE: It's possible to define group members both within the `GroupMembership resource` via the members block and by using the `Group` resource. However it's not possible to use both methods to manage group members, since there'll be conflicts.
|
53
|
-
"""
|
54
|
-
return pulumi.get(self, "members")
|
55
|
-
|
56
|
-
@members.setter
|
57
|
-
def members(self, value: pulumi.Input[Sequence[pulumi.Input[str]]]):
|
58
|
-
pulumi.set(self, "members", value)
|
59
|
-
|
60
|
-
@property
|
61
|
-
@pulumi.getter
|
62
|
-
def mode(self) -> Optional[pulumi.Input[str]]:
|
63
|
-
"""
|
64
|
-
The mode how the resource manages group members.
|
65
|
-
- `mode == add`: the resource will ensure that all specified members will be part of the referenced group
|
66
|
-
- `mode == overwrite`: the resource will replace all existing members with the members specified within the `members` block
|
67
|
-
> NOTE: To clear all members from a group, specify an empty list of descriptors in the `members` attribute and set the `mode` member to `overwrite`.
|
68
|
-
"""
|
69
|
-
return pulumi.get(self, "mode")
|
70
|
-
|
71
|
-
@mode.setter
|
72
|
-
def mode(self, value: Optional[pulumi.Input[str]]):
|
73
|
-
pulumi.set(self, "mode", value)
|
74
|
-
|
75
|
-
|
76
|
-
@pulumi.input_type
|
77
|
-
class _GroupMembershipState:
|
78
|
-
def __init__(__self__, *,
|
79
|
-
group: Optional[pulumi.Input[str]] = None,
|
80
|
-
members: Optional[pulumi.Input[Sequence[pulumi.Input[str]]]] = None,
|
81
|
-
mode: Optional[pulumi.Input[str]] = None):
|
82
|
-
"""
|
83
|
-
Input properties used for looking up and filtering GroupMembership resources.
|
84
|
-
:param pulumi.Input[str] group: The descriptor of the group being managed.
|
85
|
-
:param pulumi.Input[Sequence[pulumi.Input[str]]] members: A list of user or group descriptors that will become members of the group.
|
86
|
-
> NOTE: It's possible to define group members both within the `GroupMembership resource` via the members block and by using the `Group` resource. However it's not possible to use both methods to manage group members, since there'll be conflicts.
|
87
|
-
:param pulumi.Input[str] mode: The mode how the resource manages group members.
|
88
|
-
- `mode == add`: the resource will ensure that all specified members will be part of the referenced group
|
89
|
-
- `mode == overwrite`: the resource will replace all existing members with the members specified within the `members` block
|
90
|
-
> NOTE: To clear all members from a group, specify an empty list of descriptors in the `members` attribute and set the `mode` member to `overwrite`.
|
91
|
-
"""
|
92
|
-
if group is not None:
|
93
|
-
pulumi.set(__self__, "group", group)
|
94
|
-
if members is not None:
|
95
|
-
pulumi.set(__self__, "members", members)
|
96
|
-
if mode is not None:
|
97
|
-
pulumi.set(__self__, "mode", mode)
|
98
|
-
|
99
|
-
@property
|
100
|
-
@pulumi.getter
|
101
|
-
def group(self) -> Optional[pulumi.Input[str]]:
|
102
|
-
"""
|
103
|
-
The descriptor of the group being managed.
|
104
|
-
"""
|
105
|
-
return pulumi.get(self, "group")
|
106
|
-
|
107
|
-
@group.setter
|
108
|
-
def group(self, value: Optional[pulumi.Input[str]]):
|
109
|
-
pulumi.set(self, "group", value)
|
110
|
-
|
111
|
-
@property
|
112
|
-
@pulumi.getter
|
113
|
-
def members(self) -> Optional[pulumi.Input[Sequence[pulumi.Input[str]]]]:
|
114
|
-
"""
|
115
|
-
A list of user or group descriptors that will become members of the group.
|
116
|
-
> NOTE: It's possible to define group members both within the `GroupMembership resource` via the members block and by using the `Group` resource. However it's not possible to use both methods to manage group members, since there'll be conflicts.
|
117
|
-
"""
|
118
|
-
return pulumi.get(self, "members")
|
119
|
-
|
120
|
-
@members.setter
|
121
|
-
def members(self, value: Optional[pulumi.Input[Sequence[pulumi.Input[str]]]]):
|
122
|
-
pulumi.set(self, "members", value)
|
123
|
-
|
124
|
-
@property
|
125
|
-
@pulumi.getter
|
126
|
-
def mode(self) -> Optional[pulumi.Input[str]]:
|
127
|
-
"""
|
128
|
-
The mode how the resource manages group members.
|
129
|
-
- `mode == add`: the resource will ensure that all specified members will be part of the referenced group
|
130
|
-
- `mode == overwrite`: the resource will replace all existing members with the members specified within the `members` block
|
131
|
-
> NOTE: To clear all members from a group, specify an empty list of descriptors in the `members` attribute and set the `mode` member to `overwrite`.
|
132
|
-
"""
|
133
|
-
return pulumi.get(self, "mode")
|
134
|
-
|
135
|
-
@mode.setter
|
136
|
-
def mode(self, value: Optional[pulumi.Input[str]]):
|
137
|
-
pulumi.set(self, "mode", value)
|
138
|
-
|
139
|
-
|
140
|
-
warnings.warn("""azuredevops.identities.GroupMembership has been deprecated in favor of azuredevops.GroupMembership""", DeprecationWarning)
|
141
|
-
|
142
|
-
|
143
|
-
class GroupMembership(pulumi.CustomResource):
|
144
|
-
warnings.warn("""azuredevops.identities.GroupMembership has been deprecated in favor of azuredevops.GroupMembership""", DeprecationWarning)
|
145
|
-
|
146
|
-
@overload
|
147
|
-
def __init__(__self__,
|
148
|
-
resource_name: str,
|
149
|
-
opts: Optional[pulumi.ResourceOptions] = None,
|
150
|
-
group: Optional[pulumi.Input[str]] = None,
|
151
|
-
members: Optional[pulumi.Input[Sequence[pulumi.Input[str]]]] = None,
|
152
|
-
mode: Optional[pulumi.Input[str]] = None,
|
153
|
-
__props__=None):
|
154
|
-
"""
|
155
|
-
Manages group membership within Azure DevOps.
|
156
|
-
|
157
|
-
## Example Usage
|
158
|
-
|
159
|
-
<!--Start PulumiCodeChooser -->
|
160
|
-
```python
|
161
|
-
import pulumi
|
162
|
-
import pulumi_azuredevops as azuredevops
|
163
|
-
|
164
|
-
example_project = azuredevops.Project("exampleProject")
|
165
|
-
example_user = azuredevops.User("exampleUser", principal_name="foo@contoso.com")
|
166
|
-
example_group = azuredevops.get_group_output(project_id=example_project.id,
|
167
|
-
name="Build Administrators")
|
168
|
-
example_group_membership = azuredevops.GroupMembership("exampleGroupMembership",
|
169
|
-
group=example_group.descriptor,
|
170
|
-
members=[example_user.descriptor])
|
171
|
-
```
|
172
|
-
<!--End PulumiCodeChooser -->
|
173
|
-
|
174
|
-
## Relevant Links
|
175
|
-
|
176
|
-
- [Azure DevOps Service REST API 7.0 - Memberships](https://docs.microsoft.com/en-us/rest/api/azure/devops/graph/memberships?view=azure-devops-rest-7.0)
|
177
|
-
|
178
|
-
## PAT Permissions Required
|
179
|
-
|
180
|
-
- **Deployment Groups**: Read & Manage
|
181
|
-
|
182
|
-
## Import
|
183
|
-
|
184
|
-
Not supported.
|
185
|
-
|
186
|
-
:param str resource_name: The name of the resource.
|
187
|
-
:param pulumi.ResourceOptions opts: Options for the resource.
|
188
|
-
:param pulumi.Input[str] group: The descriptor of the group being managed.
|
189
|
-
:param pulumi.Input[Sequence[pulumi.Input[str]]] members: A list of user or group descriptors that will become members of the group.
|
190
|
-
> NOTE: It's possible to define group members both within the `GroupMembership resource` via the members block and by using the `Group` resource. However it's not possible to use both methods to manage group members, since there'll be conflicts.
|
191
|
-
:param pulumi.Input[str] mode: The mode how the resource manages group members.
|
192
|
-
- `mode == add`: the resource will ensure that all specified members will be part of the referenced group
|
193
|
-
- `mode == overwrite`: the resource will replace all existing members with the members specified within the `members` block
|
194
|
-
> NOTE: To clear all members from a group, specify an empty list of descriptors in the `members` attribute and set the `mode` member to `overwrite`.
|
195
|
-
"""
|
196
|
-
...
|
197
|
-
@overload
|
198
|
-
def __init__(__self__,
|
199
|
-
resource_name: str,
|
200
|
-
args: GroupMembershipArgs,
|
201
|
-
opts: Optional[pulumi.ResourceOptions] = None):
|
202
|
-
"""
|
203
|
-
Manages group membership within Azure DevOps.
|
204
|
-
|
205
|
-
## Example Usage
|
206
|
-
|
207
|
-
<!--Start PulumiCodeChooser -->
|
208
|
-
```python
|
209
|
-
import pulumi
|
210
|
-
import pulumi_azuredevops as azuredevops
|
211
|
-
|
212
|
-
example_project = azuredevops.Project("exampleProject")
|
213
|
-
example_user = azuredevops.User("exampleUser", principal_name="foo@contoso.com")
|
214
|
-
example_group = azuredevops.get_group_output(project_id=example_project.id,
|
215
|
-
name="Build Administrators")
|
216
|
-
example_group_membership = azuredevops.GroupMembership("exampleGroupMembership",
|
217
|
-
group=example_group.descriptor,
|
218
|
-
members=[example_user.descriptor])
|
219
|
-
```
|
220
|
-
<!--End PulumiCodeChooser -->
|
221
|
-
|
222
|
-
## Relevant Links
|
223
|
-
|
224
|
-
- [Azure DevOps Service REST API 7.0 - Memberships](https://docs.microsoft.com/en-us/rest/api/azure/devops/graph/memberships?view=azure-devops-rest-7.0)
|
225
|
-
|
226
|
-
## PAT Permissions Required
|
227
|
-
|
228
|
-
- **Deployment Groups**: Read & Manage
|
229
|
-
|
230
|
-
## Import
|
231
|
-
|
232
|
-
Not supported.
|
233
|
-
|
234
|
-
:param str resource_name: The name of the resource.
|
235
|
-
:param GroupMembershipArgs args: The arguments to use to populate this resource's properties.
|
236
|
-
:param pulumi.ResourceOptions opts: Options for the resource.
|
237
|
-
"""
|
238
|
-
...
|
239
|
-
def __init__(__self__, resource_name: str, *args, **kwargs):
|
240
|
-
resource_args, opts = _utilities.get_resource_args_opts(GroupMembershipArgs, pulumi.ResourceOptions, *args, **kwargs)
|
241
|
-
if resource_args is not None:
|
242
|
-
__self__._internal_init(resource_name, opts, **resource_args.__dict__)
|
243
|
-
else:
|
244
|
-
__self__._internal_init(resource_name, *args, **kwargs)
|
245
|
-
|
246
|
-
def _internal_init(__self__,
|
247
|
-
resource_name: str,
|
248
|
-
opts: Optional[pulumi.ResourceOptions] = None,
|
249
|
-
group: Optional[pulumi.Input[str]] = None,
|
250
|
-
members: Optional[pulumi.Input[Sequence[pulumi.Input[str]]]] = None,
|
251
|
-
mode: Optional[pulumi.Input[str]] = None,
|
252
|
-
__props__=None):
|
253
|
-
pulumi.log.warn("""GroupMembership is deprecated: azuredevops.identities.GroupMembership has been deprecated in favor of azuredevops.GroupMembership""")
|
254
|
-
opts = pulumi.ResourceOptions.merge(_utilities.get_resource_opts_defaults(), opts)
|
255
|
-
if not isinstance(opts, pulumi.ResourceOptions):
|
256
|
-
raise TypeError('Expected resource options to be a ResourceOptions instance')
|
257
|
-
if opts.id is None:
|
258
|
-
if __props__ is not None:
|
259
|
-
raise TypeError('__props__ is only valid when passed in combination with a valid opts.id to get an existing resource')
|
260
|
-
__props__ = GroupMembershipArgs.__new__(GroupMembershipArgs)
|
261
|
-
|
262
|
-
if group is None and not opts.urn:
|
263
|
-
raise TypeError("Missing required property 'group'")
|
264
|
-
__props__.__dict__["group"] = group
|
265
|
-
if members is None and not opts.urn:
|
266
|
-
raise TypeError("Missing required property 'members'")
|
267
|
-
__props__.__dict__["members"] = members
|
268
|
-
__props__.__dict__["mode"] = mode
|
269
|
-
super(GroupMembership, __self__).__init__(
|
270
|
-
'azuredevops:Identities/groupMembership:GroupMembership',
|
271
|
-
resource_name,
|
272
|
-
__props__,
|
273
|
-
opts)
|
274
|
-
|
275
|
-
@staticmethod
|
276
|
-
def get(resource_name: str,
|
277
|
-
id: pulumi.Input[str],
|
278
|
-
opts: Optional[pulumi.ResourceOptions] = None,
|
279
|
-
group: Optional[pulumi.Input[str]] = None,
|
280
|
-
members: Optional[pulumi.Input[Sequence[pulumi.Input[str]]]] = None,
|
281
|
-
mode: Optional[pulumi.Input[str]] = None) -> 'GroupMembership':
|
282
|
-
"""
|
283
|
-
Get an existing GroupMembership resource's state with the given name, id, and optional extra
|
284
|
-
properties used to qualify the lookup.
|
285
|
-
|
286
|
-
:param str resource_name: The unique name of the resulting resource.
|
287
|
-
:param pulumi.Input[str] id: The unique provider ID of the resource to lookup.
|
288
|
-
:param pulumi.ResourceOptions opts: Options for the resource.
|
289
|
-
:param pulumi.Input[str] group: The descriptor of the group being managed.
|
290
|
-
:param pulumi.Input[Sequence[pulumi.Input[str]]] members: A list of user or group descriptors that will become members of the group.
|
291
|
-
> NOTE: It's possible to define group members both within the `GroupMembership resource` via the members block and by using the `Group` resource. However it's not possible to use both methods to manage group members, since there'll be conflicts.
|
292
|
-
:param pulumi.Input[str] mode: The mode how the resource manages group members.
|
293
|
-
- `mode == add`: the resource will ensure that all specified members will be part of the referenced group
|
294
|
-
- `mode == overwrite`: the resource will replace all existing members with the members specified within the `members` block
|
295
|
-
> NOTE: To clear all members from a group, specify an empty list of descriptors in the `members` attribute and set the `mode` member to `overwrite`.
|
296
|
-
"""
|
297
|
-
opts = pulumi.ResourceOptions.merge(opts, pulumi.ResourceOptions(id=id))
|
298
|
-
|
299
|
-
__props__ = _GroupMembershipState.__new__(_GroupMembershipState)
|
300
|
-
|
301
|
-
__props__.__dict__["group"] = group
|
302
|
-
__props__.__dict__["members"] = members
|
303
|
-
__props__.__dict__["mode"] = mode
|
304
|
-
return GroupMembership(resource_name, opts=opts, __props__=__props__)
|
305
|
-
|
306
|
-
@property
|
307
|
-
@pulumi.getter
|
308
|
-
def group(self) -> pulumi.Output[str]:
|
309
|
-
"""
|
310
|
-
The descriptor of the group being managed.
|
311
|
-
"""
|
312
|
-
return pulumi.get(self, "group")
|
313
|
-
|
314
|
-
@property
|
315
|
-
@pulumi.getter
|
316
|
-
def members(self) -> pulumi.Output[Sequence[str]]:
|
317
|
-
"""
|
318
|
-
A list of user or group descriptors that will become members of the group.
|
319
|
-
> NOTE: It's possible to define group members both within the `GroupMembership resource` via the members block and by using the `Group` resource. However it's not possible to use both methods to manage group members, since there'll be conflicts.
|
320
|
-
"""
|
321
|
-
return pulumi.get(self, "members")
|
322
|
-
|
323
|
-
@property
|
324
|
-
@pulumi.getter
|
325
|
-
def mode(self) -> pulumi.Output[Optional[str]]:
|
326
|
-
"""
|
327
|
-
The mode how the resource manages group members.
|
328
|
-
- `mode == add`: the resource will ensure that all specified members will be part of the referenced group
|
329
|
-
- `mode == overwrite`: the resource will replace all existing members with the members specified within the `members` block
|
330
|
-
> NOTE: To clear all members from a group, specify an empty list of descriptors in the `members` attribute and set the `mode` member to `overwrite`.
|
331
|
-
"""
|
332
|
-
return pulumi.get(self, "mode")
|
333
|
-
|
@@ -1,124 +0,0 @@
|
|
1
|
-
# coding=utf-8
|
2
|
-
# *** WARNING: this file was generated by the Pulumi Terraform Bridge (tfgen) Tool. ***
|
3
|
-
# *** Do not edit by hand unless you're certain you know what you are doing! ***
|
4
|
-
|
5
|
-
import copy
|
6
|
-
import warnings
|
7
|
-
import pulumi
|
8
|
-
import pulumi.runtime
|
9
|
-
from typing import Any, Mapping, Optional, Sequence, Union, overload
|
10
|
-
from .. import _utilities
|
11
|
-
|
12
|
-
__all__ = [
|
13
|
-
'GetUsersFeaturesResult',
|
14
|
-
'GetUsersUserResult',
|
15
|
-
]
|
16
|
-
|
17
|
-
@pulumi.output_type
|
18
|
-
class GetUsersFeaturesResult(dict):
|
19
|
-
def __init__(__self__, *,
|
20
|
-
concurrent_workers: Optional[int] = None):
|
21
|
-
"""
|
22
|
-
:param int concurrent_workers: Number of workers to process user data concurrently.
|
23
|
-
|
24
|
-
> **Note** Setting `concurrent_workers` to a value greater than 1 can greatly decrease the time it takes to read the data source.
|
25
|
-
"""
|
26
|
-
if concurrent_workers is not None:
|
27
|
-
pulumi.set(__self__, "concurrent_workers", concurrent_workers)
|
28
|
-
|
29
|
-
@property
|
30
|
-
@pulumi.getter(name="concurrentWorkers")
|
31
|
-
def concurrent_workers(self) -> Optional[int]:
|
32
|
-
"""
|
33
|
-
Number of workers to process user data concurrently.
|
34
|
-
|
35
|
-
> **Note** Setting `concurrent_workers` to a value greater than 1 can greatly decrease the time it takes to read the data source.
|
36
|
-
"""
|
37
|
-
return pulumi.get(self, "concurrent_workers")
|
38
|
-
|
39
|
-
|
40
|
-
@pulumi.output_type
|
41
|
-
class GetUsersUserResult(dict):
|
42
|
-
def __init__(__self__, *,
|
43
|
-
descriptor: str,
|
44
|
-
display_name: str,
|
45
|
-
id: str,
|
46
|
-
mail_address: str,
|
47
|
-
origin: str,
|
48
|
-
principal_name: str,
|
49
|
-
origin_id: Optional[str] = None):
|
50
|
-
"""
|
51
|
-
:param str descriptor: The descriptor is the primary way to reference the graph subject while the system is running. This field will uniquely identify the same graph subject across both Accounts and Organizations.
|
52
|
-
:param str display_name: This is the non-unique display name of the graph subject. To change this field, you must alter its value in the source provider.
|
53
|
-
:param str id: The user ID.
|
54
|
-
:param str mail_address: The email address of record for a given graph member. This may be different than the principal name.
|
55
|
-
:param str origin: The type of source provider for the `origin_id` parameter (ex:AD, AAD, MSA) The supported origins are listed below.
|
56
|
-
:param str principal_name: The PrincipalName of this graph member from the source provider.
|
57
|
-
:param str origin_id: The unique identifier from the system of origin.
|
58
|
-
"""
|
59
|
-
pulumi.set(__self__, "descriptor", descriptor)
|
60
|
-
pulumi.set(__self__, "display_name", display_name)
|
61
|
-
pulumi.set(__self__, "id", id)
|
62
|
-
pulumi.set(__self__, "mail_address", mail_address)
|
63
|
-
pulumi.set(__self__, "origin", origin)
|
64
|
-
pulumi.set(__self__, "principal_name", principal_name)
|
65
|
-
if origin_id is not None:
|
66
|
-
pulumi.set(__self__, "origin_id", origin_id)
|
67
|
-
|
68
|
-
@property
|
69
|
-
@pulumi.getter
|
70
|
-
def descriptor(self) -> str:
|
71
|
-
"""
|
72
|
-
The descriptor is the primary way to reference the graph subject while the system is running. This field will uniquely identify the same graph subject across both Accounts and Organizations.
|
73
|
-
"""
|
74
|
-
return pulumi.get(self, "descriptor")
|
75
|
-
|
76
|
-
@property
|
77
|
-
@pulumi.getter(name="displayName")
|
78
|
-
def display_name(self) -> str:
|
79
|
-
"""
|
80
|
-
This is the non-unique display name of the graph subject. To change this field, you must alter its value in the source provider.
|
81
|
-
"""
|
82
|
-
return pulumi.get(self, "display_name")
|
83
|
-
|
84
|
-
@property
|
85
|
-
@pulumi.getter
|
86
|
-
def id(self) -> str:
|
87
|
-
"""
|
88
|
-
The user ID.
|
89
|
-
"""
|
90
|
-
return pulumi.get(self, "id")
|
91
|
-
|
92
|
-
@property
|
93
|
-
@pulumi.getter(name="mailAddress")
|
94
|
-
def mail_address(self) -> str:
|
95
|
-
"""
|
96
|
-
The email address of record for a given graph member. This may be different than the principal name.
|
97
|
-
"""
|
98
|
-
return pulumi.get(self, "mail_address")
|
99
|
-
|
100
|
-
@property
|
101
|
-
@pulumi.getter
|
102
|
-
def origin(self) -> str:
|
103
|
-
"""
|
104
|
-
The type of source provider for the `origin_id` parameter (ex:AD, AAD, MSA) The supported origins are listed below.
|
105
|
-
"""
|
106
|
-
return pulumi.get(self, "origin")
|
107
|
-
|
108
|
-
@property
|
109
|
-
@pulumi.getter(name="principalName")
|
110
|
-
def principal_name(self) -> str:
|
111
|
-
"""
|
112
|
-
The PrincipalName of this graph member from the source provider.
|
113
|
-
"""
|
114
|
-
return pulumi.get(self, "principal_name")
|
115
|
-
|
116
|
-
@property
|
117
|
-
@pulumi.getter(name="originId")
|
118
|
-
def origin_id(self) -> Optional[str]:
|
119
|
-
"""
|
120
|
-
The unique identifier from the system of origin.
|
121
|
-
"""
|
122
|
-
return pulumi.get(self, "origin_id")
|
123
|
-
|
124
|
-
|
@@ -1,10 +0,0 @@
|
|
1
|
-
# coding=utf-8
|
2
|
-
# *** WARNING: this file was generated by the Pulumi Terraform Bridge (tfgen) Tool. ***
|
3
|
-
# *** Do not edit by hand unless you're certain you know what you are doing! ***
|
4
|
-
|
5
|
-
from .. import _utilities
|
6
|
-
import typing
|
7
|
-
# Export this package's modules as members:
|
8
|
-
from .variable_group import *
|
9
|
-
from ._inputs import *
|
10
|
-
from . import outputs
|
@@ -1,175 +0,0 @@
|
|
1
|
-
# coding=utf-8
|
2
|
-
# *** WARNING: this file was generated by the Pulumi Terraform Bridge (tfgen) Tool. ***
|
3
|
-
# *** Do not edit by hand unless you're certain you know what you are doing! ***
|
4
|
-
|
5
|
-
import copy
|
6
|
-
import warnings
|
7
|
-
import pulumi
|
8
|
-
import pulumi.runtime
|
9
|
-
from typing import Any, Mapping, Optional, Sequence, Union, overload
|
10
|
-
from .. import _utilities
|
11
|
-
|
12
|
-
__all__ = [
|
13
|
-
'VariableGroupKeyVaultArgs',
|
14
|
-
'VariableGroupVariableArgs',
|
15
|
-
]
|
16
|
-
|
17
|
-
@pulumi.input_type
|
18
|
-
class VariableGroupKeyVaultArgs:
|
19
|
-
def __init__(__self__, *,
|
20
|
-
name: pulumi.Input[str],
|
21
|
-
service_endpoint_id: pulumi.Input[str],
|
22
|
-
search_depth: Optional[pulumi.Input[int]] = None):
|
23
|
-
"""
|
24
|
-
:param pulumi.Input[str] name: The name of the Azure key vault to link secrets from as variables.
|
25
|
-
:param pulumi.Input[str] service_endpoint_id: The id of the Azure subscription endpoint to access the key vault.
|
26
|
-
:param pulumi.Input[int] search_depth: Set the Azure Key Vault Secret search depth. Defaults to `20`.
|
27
|
-
"""
|
28
|
-
pulumi.set(__self__, "name", name)
|
29
|
-
pulumi.set(__self__, "service_endpoint_id", service_endpoint_id)
|
30
|
-
if search_depth is not None:
|
31
|
-
pulumi.set(__self__, "search_depth", search_depth)
|
32
|
-
|
33
|
-
@property
|
34
|
-
@pulumi.getter
|
35
|
-
def name(self) -> pulumi.Input[str]:
|
36
|
-
"""
|
37
|
-
The name of the Azure key vault to link secrets from as variables.
|
38
|
-
"""
|
39
|
-
return pulumi.get(self, "name")
|
40
|
-
|
41
|
-
@name.setter
|
42
|
-
def name(self, value: pulumi.Input[str]):
|
43
|
-
pulumi.set(self, "name", value)
|
44
|
-
|
45
|
-
@property
|
46
|
-
@pulumi.getter(name="serviceEndpointId")
|
47
|
-
def service_endpoint_id(self) -> pulumi.Input[str]:
|
48
|
-
"""
|
49
|
-
The id of the Azure subscription endpoint to access the key vault.
|
50
|
-
"""
|
51
|
-
return pulumi.get(self, "service_endpoint_id")
|
52
|
-
|
53
|
-
@service_endpoint_id.setter
|
54
|
-
def service_endpoint_id(self, value: pulumi.Input[str]):
|
55
|
-
pulumi.set(self, "service_endpoint_id", value)
|
56
|
-
|
57
|
-
@property
|
58
|
-
@pulumi.getter(name="searchDepth")
|
59
|
-
def search_depth(self) -> Optional[pulumi.Input[int]]:
|
60
|
-
"""
|
61
|
-
Set the Azure Key Vault Secret search depth. Defaults to `20`.
|
62
|
-
"""
|
63
|
-
return pulumi.get(self, "search_depth")
|
64
|
-
|
65
|
-
@search_depth.setter
|
66
|
-
def search_depth(self, value: Optional[pulumi.Input[int]]):
|
67
|
-
pulumi.set(self, "search_depth", value)
|
68
|
-
|
69
|
-
|
70
|
-
@pulumi.input_type
|
71
|
-
class VariableGroupVariableArgs:
|
72
|
-
def __init__(__self__, *,
|
73
|
-
name: pulumi.Input[str],
|
74
|
-
content_type: Optional[pulumi.Input[str]] = None,
|
75
|
-
enabled: Optional[pulumi.Input[bool]] = None,
|
76
|
-
expires: Optional[pulumi.Input[str]] = None,
|
77
|
-
is_secret: Optional[pulumi.Input[bool]] = None,
|
78
|
-
secret_value: Optional[pulumi.Input[str]] = None,
|
79
|
-
value: Optional[pulumi.Input[str]] = None):
|
80
|
-
"""
|
81
|
-
:param pulumi.Input[str] name: The key value used for the variable. Must be unique within the Variable Group.
|
82
|
-
:param pulumi.Input[bool] is_secret: A boolean flag describing if the variable value is sensitive. Defaults to `false`.
|
83
|
-
:param pulumi.Input[str] secret_value: The secret value of the variable. If omitted, it will default to empty string. Used when `is_secret` set to `true`.
|
84
|
-
:param pulumi.Input[str] value: The value of the variable. If omitted, it will default to empty string.
|
85
|
-
"""
|
86
|
-
pulumi.set(__self__, "name", name)
|
87
|
-
if content_type is not None:
|
88
|
-
pulumi.set(__self__, "content_type", content_type)
|
89
|
-
if enabled is not None:
|
90
|
-
pulumi.set(__self__, "enabled", enabled)
|
91
|
-
if expires is not None:
|
92
|
-
pulumi.set(__self__, "expires", expires)
|
93
|
-
if is_secret is not None:
|
94
|
-
pulumi.set(__self__, "is_secret", is_secret)
|
95
|
-
if secret_value is not None:
|
96
|
-
pulumi.set(__self__, "secret_value", secret_value)
|
97
|
-
if value is not None:
|
98
|
-
pulumi.set(__self__, "value", value)
|
99
|
-
|
100
|
-
@property
|
101
|
-
@pulumi.getter
|
102
|
-
def name(self) -> pulumi.Input[str]:
|
103
|
-
"""
|
104
|
-
The key value used for the variable. Must be unique within the Variable Group.
|
105
|
-
"""
|
106
|
-
return pulumi.get(self, "name")
|
107
|
-
|
108
|
-
@name.setter
|
109
|
-
def name(self, value: pulumi.Input[str]):
|
110
|
-
pulumi.set(self, "name", value)
|
111
|
-
|
112
|
-
@property
|
113
|
-
@pulumi.getter(name="contentType")
|
114
|
-
def content_type(self) -> Optional[pulumi.Input[str]]:
|
115
|
-
return pulumi.get(self, "content_type")
|
116
|
-
|
117
|
-
@content_type.setter
|
118
|
-
def content_type(self, value: Optional[pulumi.Input[str]]):
|
119
|
-
pulumi.set(self, "content_type", value)
|
120
|
-
|
121
|
-
@property
|
122
|
-
@pulumi.getter
|
123
|
-
def enabled(self) -> Optional[pulumi.Input[bool]]:
|
124
|
-
return pulumi.get(self, "enabled")
|
125
|
-
|
126
|
-
@enabled.setter
|
127
|
-
def enabled(self, value: Optional[pulumi.Input[bool]]):
|
128
|
-
pulumi.set(self, "enabled", value)
|
129
|
-
|
130
|
-
@property
|
131
|
-
@pulumi.getter
|
132
|
-
def expires(self) -> Optional[pulumi.Input[str]]:
|
133
|
-
return pulumi.get(self, "expires")
|
134
|
-
|
135
|
-
@expires.setter
|
136
|
-
def expires(self, value: Optional[pulumi.Input[str]]):
|
137
|
-
pulumi.set(self, "expires", value)
|
138
|
-
|
139
|
-
@property
|
140
|
-
@pulumi.getter(name="isSecret")
|
141
|
-
def is_secret(self) -> Optional[pulumi.Input[bool]]:
|
142
|
-
"""
|
143
|
-
A boolean flag describing if the variable value is sensitive. Defaults to `false`.
|
144
|
-
"""
|
145
|
-
return pulumi.get(self, "is_secret")
|
146
|
-
|
147
|
-
@is_secret.setter
|
148
|
-
def is_secret(self, value: Optional[pulumi.Input[bool]]):
|
149
|
-
pulumi.set(self, "is_secret", value)
|
150
|
-
|
151
|
-
@property
|
152
|
-
@pulumi.getter(name="secretValue")
|
153
|
-
def secret_value(self) -> Optional[pulumi.Input[str]]:
|
154
|
-
"""
|
155
|
-
The secret value of the variable. If omitted, it will default to empty string. Used when `is_secret` set to `true`.
|
156
|
-
"""
|
157
|
-
return pulumi.get(self, "secret_value")
|
158
|
-
|
159
|
-
@secret_value.setter
|
160
|
-
def secret_value(self, value: Optional[pulumi.Input[str]]):
|
161
|
-
pulumi.set(self, "secret_value", value)
|
162
|
-
|
163
|
-
@property
|
164
|
-
@pulumi.getter
|
165
|
-
def value(self) -> Optional[pulumi.Input[str]]:
|
166
|
-
"""
|
167
|
-
The value of the variable. If omitted, it will default to empty string.
|
168
|
-
"""
|
169
|
-
return pulumi.get(self, "value")
|
170
|
-
|
171
|
-
@value.setter
|
172
|
-
def value(self, value: Optional[pulumi.Input[str]]):
|
173
|
-
pulumi.set(self, "value", value)
|
174
|
-
|
175
|
-
|