pulumi-azuredevops 3.6.0a1737523387__py3-none-any.whl → 3.7.0a1738589303__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.
Files changed (119) hide show
  1. pulumi_azuredevops/__init__.py +64 -0
  2. pulumi_azuredevops/_inputs.py +120 -117
  3. pulumi_azuredevops/area_permissions.py +49 -49
  4. pulumi_azuredevops/branch_policy_auto_reviewers.py +7 -7
  5. pulumi_azuredevops/branch_policy_build_validation.py +7 -7
  6. pulumi_azuredevops/branch_policy_comment_resolution.py +7 -7
  7. pulumi_azuredevops/branch_policy_merge_types.py +7 -7
  8. pulumi_azuredevops/branch_policy_status_check.py +7 -7
  9. pulumi_azuredevops/branch_policy_work_item_linking.py +7 -7
  10. pulumi_azuredevops/build_definition.py +7 -7
  11. pulumi_azuredevops/check_branch_control.py +7 -7
  12. pulumi_azuredevops/check_business_hours.py +7 -7
  13. pulumi_azuredevops/check_exclusive_lock.py +7 -7
  14. pulumi_azuredevops/check_rest_api.py +986 -0
  15. pulumi_azuredevops/feed.py +8 -8
  16. pulumi_azuredevops/feed_permission.py +9 -9
  17. pulumi_azuredevops/feed_retention_policy.py +422 -0
  18. pulumi_azuredevops/get_agent_queue.py +2 -2
  19. pulumi_azuredevops/get_area.py +1 -1
  20. pulumi_azuredevops/get_client_config.py +3 -0
  21. pulumi_azuredevops/get_feed.py +4 -4
  22. pulumi_azuredevops/get_git_repository.py +8 -8
  23. pulumi_azuredevops/get_group.py +4 -4
  24. pulumi_azuredevops/get_groups.py +3 -3
  25. pulumi_azuredevops/get_identity_group.py +3 -0
  26. pulumi_azuredevops/get_identity_groups.py +1 -1
  27. pulumi_azuredevops/get_identity_users.py +5 -5
  28. pulumi_azuredevops/get_pool.py +14 -2
  29. pulumi_azuredevops/get_pools.py +3 -3
  30. pulumi_azuredevops/get_project.py +32 -0
  31. pulumi_azuredevops/get_projects.py +4 -4
  32. pulumi_azuredevops/get_repositories.py +7 -3
  33. pulumi_azuredevops/get_securityrole_definitions.py +4 -4
  34. pulumi_azuredevops/get_service_endpoint_azure_rm.py +5 -5
  35. pulumi_azuredevops/get_service_endpoint_github.py +6 -6
  36. pulumi_azuredevops/get_service_principal.py +153 -0
  37. pulumi_azuredevops/get_serviceendpoint_azurecr.py +1 -1
  38. pulumi_azuredevops/get_serviceendpoint_bitbucket.py +6 -6
  39. pulumi_azuredevops/get_serviceendpoint_npm.py +3 -3
  40. pulumi_azuredevops/get_serviceendpoint_sonarcloud.py +2 -2
  41. pulumi_azuredevops/get_team.py +4 -3
  42. pulumi_azuredevops/get_teams.py +2 -3
  43. pulumi_azuredevops/get_users.py +5 -9
  44. pulumi_azuredevops/git.py +7 -7
  45. pulumi_azuredevops/git_permissions.py +14 -21
  46. pulumi_azuredevops/git_repository_file.py +7 -14
  47. pulumi_azuredevops/group.py +21 -7
  48. pulumi_azuredevops/group_entitlement.py +16 -20
  49. pulumi_azuredevops/group_membership.py +35 -50
  50. pulumi_azuredevops/iterative_permissions.py +34 -34
  51. pulumi_azuredevops/library_permissions.py +75 -75
  52. pulumi_azuredevops/outputs.py +129 -102
  53. pulumi_azuredevops/pipeline_authorization.py +7 -7
  54. pulumi_azuredevops/pool.py +4 -4
  55. pulumi_azuredevops/project.py +114 -63
  56. pulumi_azuredevops/project_features.py +87 -45
  57. pulumi_azuredevops/project_permissions.py +7 -7
  58. pulumi_azuredevops/project_pipeline_settings.py +28 -35
  59. pulumi_azuredevops/project_tags.py +263 -0
  60. pulumi_azuredevops/pulumi-plugin.json +1 -1
  61. pulumi_azuredevops/queue.py +7 -14
  62. pulumi_azuredevops/repository_policy_author_email_pattern.py +21 -14
  63. pulumi_azuredevops/repository_policy_max_file_size.py +7 -7
  64. pulumi_azuredevops/resource_authorization.py +35 -35
  65. pulumi_azuredevops/service_endpoint_artifactory.py +24 -18
  66. pulumi_azuredevops/service_endpoint_aws.py +2 -2
  67. pulumi_azuredevops/service_endpoint_azure_ecr.py +13 -15
  68. pulumi_azuredevops/service_endpoint_azure_rm.py +25 -25
  69. pulumi_azuredevops/service_endpoint_bit_bucket.py +2 -2
  70. pulumi_azuredevops/service_endpoint_docker_registry.py +2 -2
  71. pulumi_azuredevops/service_endpoint_generic.py +2 -2
  72. pulumi_azuredevops/service_endpoint_generic_git.py +4 -8
  73. pulumi_azuredevops/service_endpoint_git_hub.py +15 -2
  74. pulumi_azuredevops/service_endpoint_git_hub_enterprise.py +15 -2
  75. pulumi_azuredevops/service_endpoint_kubernetes.py +23 -23
  76. pulumi_azuredevops/service_endpoint_npm.py +4 -4
  77. pulumi_azuredevops/service_endpoint_pipeline.py +4 -4
  78. pulumi_azuredevops/service_endpoint_service_fabric.py +48 -9
  79. pulumi_azuredevops/service_endpoint_sonar_cloud.py +11 -11
  80. pulumi_azuredevops/service_endpoint_sonar_qube.py +11 -11
  81. pulumi_azuredevops/service_endpoint_ssh.py +2 -6
  82. pulumi_azuredevops/service_principal_entitlement.py +386 -0
  83. pulumi_azuredevops/serviceendpoint_argocd.py +2 -2
  84. pulumi_azuredevops/serviceendpoint_azure_service_bus.py +2 -2
  85. pulumi_azuredevops/serviceendpoint_checkmarx_one.py +627 -0
  86. pulumi_azuredevops/serviceendpoint_checkmarx_sast.py +575 -0
  87. pulumi_azuredevops/serviceendpoint_checkmarx_sca.py +674 -0
  88. pulumi_azuredevops/serviceendpoint_dynamics_lifecycle_services.py +2 -2
  89. pulumi_azuredevops/serviceendpoint_externaltfs.py +63 -11
  90. pulumi_azuredevops/serviceendpoint_gcp_terraform.py +2 -2
  91. pulumi_azuredevops/serviceendpoint_incomingwebhook.py +2 -2
  92. pulumi_azuredevops/serviceendpoint_jenkins.py +2 -2
  93. pulumi_azuredevops/serviceendpoint_jfrog_artifactory_v2.py +18 -18
  94. pulumi_azuredevops/serviceendpoint_jfrog_distribution_v2.py +18 -18
  95. pulumi_azuredevops/serviceendpoint_jfrog_platform_v2.py +18 -18
  96. pulumi_azuredevops/serviceendpoint_jfrog_xray_v2.py +18 -18
  97. pulumi_azuredevops/serviceendpoint_maven.py +2 -2
  98. pulumi_azuredevops/serviceendpoint_nexus.py +2 -2
  99. pulumi_azuredevops/serviceendpoint_nuget.py +2 -2
  100. pulumi_azuredevops/serviceendpoint_octopusdeploy.py +2 -2
  101. pulumi_azuredevops/serviceendpoint_permissions.py +40 -40
  102. pulumi_azuredevops/serviceendpoint_snyk.py +2 -2
  103. pulumi_azuredevops/serviceendpoint_visualstudiomarketplace.py +4 -6
  104. pulumi_azuredevops/servicehook_permissions.py +51 -51
  105. pulumi_azuredevops/servicehook_storage_queue_pipelines.py +4 -4
  106. pulumi_azuredevops/tagging_permissions.py +49 -49
  107. pulumi_azuredevops/team.py +76 -56
  108. pulumi_azuredevops/team_administrators.py +83 -56
  109. pulumi_azuredevops/team_members.py +56 -49
  110. pulumi_azuredevops/variable_group.py +4 -2
  111. pulumi_azuredevops/variable_group_permissions.py +75 -75
  112. pulumi_azuredevops/wiki.py +15 -2
  113. pulumi_azuredevops/wiki_page.py +2 -2
  114. pulumi_azuredevops/work_item_query_permissions.py +7 -7
  115. {pulumi_azuredevops-3.6.0a1737523387.dist-info → pulumi_azuredevops-3.7.0a1738589303.dist-info}/METADATA +1 -1
  116. pulumi_azuredevops-3.7.0a1738589303.dist-info/RECORD +148 -0
  117. pulumi_azuredevops-3.6.0a1737523387.dist-info/RECORD +0 -140
  118. {pulumi_azuredevops-3.6.0a1737523387.dist-info → pulumi_azuredevops-3.7.0a1738589303.dist-info}/WHEEL +0 -0
  119. {pulumi_azuredevops-3.6.0a1737523387.dist-info → pulumi_azuredevops-3.7.0a1738589303.dist-info}/top_level.txt +0 -0
@@ -0,0 +1,575 @@
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 sys
8
+ import pulumi
9
+ import pulumi.runtime
10
+ from typing import Any, Mapping, Optional, Sequence, Union, overload
11
+ if sys.version_info >= (3, 11):
12
+ from typing import NotRequired, TypedDict, TypeAlias
13
+ else:
14
+ from typing_extensions import NotRequired, TypedDict, TypeAlias
15
+ from . import _utilities
16
+
17
+ __all__ = ['ServiceendpointCheckmarxSastArgs', 'ServiceendpointCheckmarxSast']
18
+
19
+ @pulumi.input_type
20
+ class ServiceendpointCheckmarxSastArgs:
21
+ def __init__(__self__, *,
22
+ password: pulumi.Input[str],
23
+ project_id: pulumi.Input[str],
24
+ server_url: pulumi.Input[str],
25
+ service_endpoint_name: pulumi.Input[str],
26
+ username: pulumi.Input[str],
27
+ authorization: Optional[pulumi.Input[Mapping[str, pulumi.Input[str]]]] = None,
28
+ description: Optional[pulumi.Input[str]] = None,
29
+ preset: Optional[pulumi.Input[str]] = None,
30
+ team: Optional[pulumi.Input[str]] = None):
31
+ """
32
+ The set of arguments for constructing a ServiceendpointCheckmarxSast resource.
33
+ :param pulumi.Input[str] password: The password of the Checkmarx SAST.
34
+ :param pulumi.Input[str] project_id: The ID of the project.
35
+ :param pulumi.Input[str] server_url: The Server URL of the Checkmarx SAST.
36
+ :param pulumi.Input[str] service_endpoint_name: The Service Endpoint name.
37
+ :param pulumi.Input[str] username: The username of the Checkmarx SAST.
38
+ :param pulumi.Input[str] preset: Predefined sets of queries that you can select when Creating, Configuring and Branching Projects. Predefined presets are provided by Checkmarx and you can configure your own. You can also import and export presets (on the server).In Service Connection if preset(optional) value is added, then it will igonres Preset available in pipeline and uses preset available in service connection only.If Preset is blank in service connection then it will use pipelines preset.
39
+ :param pulumi.Input[str] team: The full team name of the Checkmarx.
40
+ """
41
+ pulumi.set(__self__, "password", password)
42
+ pulumi.set(__self__, "project_id", project_id)
43
+ pulumi.set(__self__, "server_url", server_url)
44
+ pulumi.set(__self__, "service_endpoint_name", service_endpoint_name)
45
+ pulumi.set(__self__, "username", username)
46
+ if authorization is not None:
47
+ pulumi.set(__self__, "authorization", authorization)
48
+ if description is not None:
49
+ pulumi.set(__self__, "description", description)
50
+ if preset is not None:
51
+ pulumi.set(__self__, "preset", preset)
52
+ if team is not None:
53
+ pulumi.set(__self__, "team", team)
54
+
55
+ @property
56
+ @pulumi.getter
57
+ def password(self) -> pulumi.Input[str]:
58
+ """
59
+ The password of the Checkmarx SAST.
60
+ """
61
+ return pulumi.get(self, "password")
62
+
63
+ @password.setter
64
+ def password(self, value: pulumi.Input[str]):
65
+ pulumi.set(self, "password", value)
66
+
67
+ @property
68
+ @pulumi.getter(name="projectId")
69
+ def project_id(self) -> pulumi.Input[str]:
70
+ """
71
+ The ID of the project.
72
+ """
73
+ return pulumi.get(self, "project_id")
74
+
75
+ @project_id.setter
76
+ def project_id(self, value: pulumi.Input[str]):
77
+ pulumi.set(self, "project_id", value)
78
+
79
+ @property
80
+ @pulumi.getter(name="serverUrl")
81
+ def server_url(self) -> pulumi.Input[str]:
82
+ """
83
+ The Server URL of the Checkmarx SAST.
84
+ """
85
+ return pulumi.get(self, "server_url")
86
+
87
+ @server_url.setter
88
+ def server_url(self, value: pulumi.Input[str]):
89
+ pulumi.set(self, "server_url", value)
90
+
91
+ @property
92
+ @pulumi.getter(name="serviceEndpointName")
93
+ def service_endpoint_name(self) -> pulumi.Input[str]:
94
+ """
95
+ The Service Endpoint name.
96
+ """
97
+ return pulumi.get(self, "service_endpoint_name")
98
+
99
+ @service_endpoint_name.setter
100
+ def service_endpoint_name(self, value: pulumi.Input[str]):
101
+ pulumi.set(self, "service_endpoint_name", value)
102
+
103
+ @property
104
+ @pulumi.getter
105
+ def username(self) -> pulumi.Input[str]:
106
+ """
107
+ The username of the Checkmarx SAST.
108
+ """
109
+ return pulumi.get(self, "username")
110
+
111
+ @username.setter
112
+ def username(self, value: pulumi.Input[str]):
113
+ pulumi.set(self, "username", value)
114
+
115
+ @property
116
+ @pulumi.getter
117
+ def authorization(self) -> Optional[pulumi.Input[Mapping[str, pulumi.Input[str]]]]:
118
+ return pulumi.get(self, "authorization")
119
+
120
+ @authorization.setter
121
+ def authorization(self, value: Optional[pulumi.Input[Mapping[str, pulumi.Input[str]]]]):
122
+ pulumi.set(self, "authorization", value)
123
+
124
+ @property
125
+ @pulumi.getter
126
+ def description(self) -> Optional[pulumi.Input[str]]:
127
+ return pulumi.get(self, "description")
128
+
129
+ @description.setter
130
+ def description(self, value: Optional[pulumi.Input[str]]):
131
+ pulumi.set(self, "description", value)
132
+
133
+ @property
134
+ @pulumi.getter
135
+ def preset(self) -> Optional[pulumi.Input[str]]:
136
+ """
137
+ Predefined sets of queries that you can select when Creating, Configuring and Branching Projects. Predefined presets are provided by Checkmarx and you can configure your own. You can also import and export presets (on the server).In Service Connection if preset(optional) value is added, then it will igonres Preset available in pipeline and uses preset available in service connection only.If Preset is blank in service connection then it will use pipelines preset.
138
+ """
139
+ return pulumi.get(self, "preset")
140
+
141
+ @preset.setter
142
+ def preset(self, value: Optional[pulumi.Input[str]]):
143
+ pulumi.set(self, "preset", value)
144
+
145
+ @property
146
+ @pulumi.getter
147
+ def team(self) -> Optional[pulumi.Input[str]]:
148
+ """
149
+ The full team name of the Checkmarx.
150
+ """
151
+ return pulumi.get(self, "team")
152
+
153
+ @team.setter
154
+ def team(self, value: Optional[pulumi.Input[str]]):
155
+ pulumi.set(self, "team", value)
156
+
157
+
158
+ @pulumi.input_type
159
+ class _ServiceendpointCheckmarxSastState:
160
+ def __init__(__self__, *,
161
+ authorization: Optional[pulumi.Input[Mapping[str, pulumi.Input[str]]]] = None,
162
+ description: Optional[pulumi.Input[str]] = None,
163
+ password: Optional[pulumi.Input[str]] = None,
164
+ preset: Optional[pulumi.Input[str]] = None,
165
+ project_id: Optional[pulumi.Input[str]] = None,
166
+ server_url: Optional[pulumi.Input[str]] = None,
167
+ service_endpoint_name: Optional[pulumi.Input[str]] = None,
168
+ team: Optional[pulumi.Input[str]] = None,
169
+ username: Optional[pulumi.Input[str]] = None):
170
+ """
171
+ Input properties used for looking up and filtering ServiceendpointCheckmarxSast resources.
172
+ :param pulumi.Input[str] password: The password of the Checkmarx SAST.
173
+ :param pulumi.Input[str] preset: Predefined sets of queries that you can select when Creating, Configuring and Branching Projects. Predefined presets are provided by Checkmarx and you can configure your own. You can also import and export presets (on the server).In Service Connection if preset(optional) value is added, then it will igonres Preset available in pipeline and uses preset available in service connection only.If Preset is blank in service connection then it will use pipelines preset.
174
+ :param pulumi.Input[str] project_id: The ID of the project.
175
+ :param pulumi.Input[str] server_url: The Server URL of the Checkmarx SAST.
176
+ :param pulumi.Input[str] service_endpoint_name: The Service Endpoint name.
177
+ :param pulumi.Input[str] team: The full team name of the Checkmarx.
178
+ :param pulumi.Input[str] username: The username of the Checkmarx SAST.
179
+ """
180
+ if authorization is not None:
181
+ pulumi.set(__self__, "authorization", authorization)
182
+ if description is not None:
183
+ pulumi.set(__self__, "description", description)
184
+ if password is not None:
185
+ pulumi.set(__self__, "password", password)
186
+ if preset is not None:
187
+ pulumi.set(__self__, "preset", preset)
188
+ if project_id is not None:
189
+ pulumi.set(__self__, "project_id", project_id)
190
+ if server_url is not None:
191
+ pulumi.set(__self__, "server_url", server_url)
192
+ if service_endpoint_name is not None:
193
+ pulumi.set(__self__, "service_endpoint_name", service_endpoint_name)
194
+ if team is not None:
195
+ pulumi.set(__self__, "team", team)
196
+ if username is not None:
197
+ pulumi.set(__self__, "username", username)
198
+
199
+ @property
200
+ @pulumi.getter
201
+ def authorization(self) -> Optional[pulumi.Input[Mapping[str, pulumi.Input[str]]]]:
202
+ return pulumi.get(self, "authorization")
203
+
204
+ @authorization.setter
205
+ def authorization(self, value: Optional[pulumi.Input[Mapping[str, pulumi.Input[str]]]]):
206
+ pulumi.set(self, "authorization", value)
207
+
208
+ @property
209
+ @pulumi.getter
210
+ def description(self) -> Optional[pulumi.Input[str]]:
211
+ return pulumi.get(self, "description")
212
+
213
+ @description.setter
214
+ def description(self, value: Optional[pulumi.Input[str]]):
215
+ pulumi.set(self, "description", value)
216
+
217
+ @property
218
+ @pulumi.getter
219
+ def password(self) -> Optional[pulumi.Input[str]]:
220
+ """
221
+ The password of the Checkmarx SAST.
222
+ """
223
+ return pulumi.get(self, "password")
224
+
225
+ @password.setter
226
+ def password(self, value: Optional[pulumi.Input[str]]):
227
+ pulumi.set(self, "password", value)
228
+
229
+ @property
230
+ @pulumi.getter
231
+ def preset(self) -> Optional[pulumi.Input[str]]:
232
+ """
233
+ Predefined sets of queries that you can select when Creating, Configuring and Branching Projects. Predefined presets are provided by Checkmarx and you can configure your own. You can also import and export presets (on the server).In Service Connection if preset(optional) value is added, then it will igonres Preset available in pipeline and uses preset available in service connection only.If Preset is blank in service connection then it will use pipelines preset.
234
+ """
235
+ return pulumi.get(self, "preset")
236
+
237
+ @preset.setter
238
+ def preset(self, value: Optional[pulumi.Input[str]]):
239
+ pulumi.set(self, "preset", value)
240
+
241
+ @property
242
+ @pulumi.getter(name="projectId")
243
+ def project_id(self) -> Optional[pulumi.Input[str]]:
244
+ """
245
+ The ID of the project.
246
+ """
247
+ return pulumi.get(self, "project_id")
248
+
249
+ @project_id.setter
250
+ def project_id(self, value: Optional[pulumi.Input[str]]):
251
+ pulumi.set(self, "project_id", value)
252
+
253
+ @property
254
+ @pulumi.getter(name="serverUrl")
255
+ def server_url(self) -> Optional[pulumi.Input[str]]:
256
+ """
257
+ The Server URL of the Checkmarx SAST.
258
+ """
259
+ return pulumi.get(self, "server_url")
260
+
261
+ @server_url.setter
262
+ def server_url(self, value: Optional[pulumi.Input[str]]):
263
+ pulumi.set(self, "server_url", value)
264
+
265
+ @property
266
+ @pulumi.getter(name="serviceEndpointName")
267
+ def service_endpoint_name(self) -> Optional[pulumi.Input[str]]:
268
+ """
269
+ The Service Endpoint name.
270
+ """
271
+ return pulumi.get(self, "service_endpoint_name")
272
+
273
+ @service_endpoint_name.setter
274
+ def service_endpoint_name(self, value: Optional[pulumi.Input[str]]):
275
+ pulumi.set(self, "service_endpoint_name", value)
276
+
277
+ @property
278
+ @pulumi.getter
279
+ def team(self) -> Optional[pulumi.Input[str]]:
280
+ """
281
+ The full team name of the Checkmarx.
282
+ """
283
+ return pulumi.get(self, "team")
284
+
285
+ @team.setter
286
+ def team(self, value: Optional[pulumi.Input[str]]):
287
+ pulumi.set(self, "team", value)
288
+
289
+ @property
290
+ @pulumi.getter
291
+ def username(self) -> Optional[pulumi.Input[str]]:
292
+ """
293
+ The username of the Checkmarx SAST.
294
+ """
295
+ return pulumi.get(self, "username")
296
+
297
+ @username.setter
298
+ def username(self, value: Optional[pulumi.Input[str]]):
299
+ pulumi.set(self, "username", value)
300
+
301
+
302
+ class ServiceendpointCheckmarxSast(pulumi.CustomResource):
303
+ @overload
304
+ def __init__(__self__,
305
+ resource_name: str,
306
+ opts: Optional[pulumi.ResourceOptions] = None,
307
+ authorization: Optional[pulumi.Input[Mapping[str, pulumi.Input[str]]]] = None,
308
+ description: Optional[pulumi.Input[str]] = None,
309
+ password: Optional[pulumi.Input[str]] = None,
310
+ preset: Optional[pulumi.Input[str]] = None,
311
+ project_id: Optional[pulumi.Input[str]] = None,
312
+ server_url: Optional[pulumi.Input[str]] = None,
313
+ service_endpoint_name: Optional[pulumi.Input[str]] = None,
314
+ team: Optional[pulumi.Input[str]] = None,
315
+ username: Optional[pulumi.Input[str]] = None,
316
+ __props__=None):
317
+ """
318
+ Manages a Checkmarx SAST service endpoint within Azure DevOps. Using this service endpoint requires you to install: [Checkmarx SAST](https://marketplace.visualstudio.com/items?itemName=checkmarx.cxsast)
319
+
320
+ ## Example Usage
321
+
322
+ ```python
323
+ import pulumi
324
+ import pulumi_azuredevops as azuredevops
325
+
326
+ example = azuredevops.Project("example",
327
+ name="Example Project",
328
+ visibility="private",
329
+ version_control="Git",
330
+ work_item_template="Agile",
331
+ description="Managed by Pulumi")
332
+ example_serviceendpoint_checkmarx_sast = azuredevops.ServiceendpointCheckmarxSast("example",
333
+ project_id=example.id,
334
+ service_endpoint_name="Example Checkmarx SAST",
335
+ server_url="https://server.com",
336
+ username="username",
337
+ password="password",
338
+ team="team",
339
+ preset="preset")
340
+ ```
341
+
342
+ ## Relevant Links
343
+
344
+ - [Azure DevOps Service REST API 7.0 - Service Endpoints](https://docs.microsoft.com/en-us/rest/api/azure/devops/serviceendpoint/endpoints?view=azure-devops-rest-7.0)
345
+
346
+ ## Import
347
+
348
+ Azure DevOps Service Endpoint Check Marx SAST can be imported using **projectID/serviceEndpointID** or **projectName/serviceEndpointID**
349
+
350
+ ```sh
351
+ $ pulumi import azuredevops:index/serviceendpointCheckmarxSast:ServiceendpointCheckmarxSast example 00000000-0000-0000-0000-000000000000/00000000-0000-0000-0000-000000000000
352
+ ```
353
+
354
+ :param str resource_name: The name of the resource.
355
+ :param pulumi.ResourceOptions opts: Options for the resource.
356
+ :param pulumi.Input[str] password: The password of the Checkmarx SAST.
357
+ :param pulumi.Input[str] preset: Predefined sets of queries that you can select when Creating, Configuring and Branching Projects. Predefined presets are provided by Checkmarx and you can configure your own. You can also import and export presets (on the server).In Service Connection if preset(optional) value is added, then it will igonres Preset available in pipeline and uses preset available in service connection only.If Preset is blank in service connection then it will use pipelines preset.
358
+ :param pulumi.Input[str] project_id: The ID of the project.
359
+ :param pulumi.Input[str] server_url: The Server URL of the Checkmarx SAST.
360
+ :param pulumi.Input[str] service_endpoint_name: The Service Endpoint name.
361
+ :param pulumi.Input[str] team: The full team name of the Checkmarx.
362
+ :param pulumi.Input[str] username: The username of the Checkmarx SAST.
363
+ """
364
+ ...
365
+ @overload
366
+ def __init__(__self__,
367
+ resource_name: str,
368
+ args: ServiceendpointCheckmarxSastArgs,
369
+ opts: Optional[pulumi.ResourceOptions] = None):
370
+ """
371
+ Manages a Checkmarx SAST service endpoint within Azure DevOps. Using this service endpoint requires you to install: [Checkmarx SAST](https://marketplace.visualstudio.com/items?itemName=checkmarx.cxsast)
372
+
373
+ ## Example Usage
374
+
375
+ ```python
376
+ import pulumi
377
+ import pulumi_azuredevops as azuredevops
378
+
379
+ example = azuredevops.Project("example",
380
+ name="Example Project",
381
+ visibility="private",
382
+ version_control="Git",
383
+ work_item_template="Agile",
384
+ description="Managed by Pulumi")
385
+ example_serviceendpoint_checkmarx_sast = azuredevops.ServiceendpointCheckmarxSast("example",
386
+ project_id=example.id,
387
+ service_endpoint_name="Example Checkmarx SAST",
388
+ server_url="https://server.com",
389
+ username="username",
390
+ password="password",
391
+ team="team",
392
+ preset="preset")
393
+ ```
394
+
395
+ ## Relevant Links
396
+
397
+ - [Azure DevOps Service REST API 7.0 - Service Endpoints](https://docs.microsoft.com/en-us/rest/api/azure/devops/serviceendpoint/endpoints?view=azure-devops-rest-7.0)
398
+
399
+ ## Import
400
+
401
+ Azure DevOps Service Endpoint Check Marx SAST can be imported using **projectID/serviceEndpointID** or **projectName/serviceEndpointID**
402
+
403
+ ```sh
404
+ $ pulumi import azuredevops:index/serviceendpointCheckmarxSast:ServiceendpointCheckmarxSast example 00000000-0000-0000-0000-000000000000/00000000-0000-0000-0000-000000000000
405
+ ```
406
+
407
+ :param str resource_name: The name of the resource.
408
+ :param ServiceendpointCheckmarxSastArgs args: The arguments to use to populate this resource's properties.
409
+ :param pulumi.ResourceOptions opts: Options for the resource.
410
+ """
411
+ ...
412
+ def __init__(__self__, resource_name: str, *args, **kwargs):
413
+ resource_args, opts = _utilities.get_resource_args_opts(ServiceendpointCheckmarxSastArgs, pulumi.ResourceOptions, *args, **kwargs)
414
+ if resource_args is not None:
415
+ __self__._internal_init(resource_name, opts, **resource_args.__dict__)
416
+ else:
417
+ __self__._internal_init(resource_name, *args, **kwargs)
418
+
419
+ def _internal_init(__self__,
420
+ resource_name: str,
421
+ opts: Optional[pulumi.ResourceOptions] = None,
422
+ authorization: Optional[pulumi.Input[Mapping[str, pulumi.Input[str]]]] = None,
423
+ description: Optional[pulumi.Input[str]] = None,
424
+ password: Optional[pulumi.Input[str]] = None,
425
+ preset: Optional[pulumi.Input[str]] = None,
426
+ project_id: Optional[pulumi.Input[str]] = None,
427
+ server_url: Optional[pulumi.Input[str]] = None,
428
+ service_endpoint_name: Optional[pulumi.Input[str]] = None,
429
+ team: Optional[pulumi.Input[str]] = None,
430
+ username: Optional[pulumi.Input[str]] = None,
431
+ __props__=None):
432
+ opts = pulumi.ResourceOptions.merge(_utilities.get_resource_opts_defaults(), opts)
433
+ if not isinstance(opts, pulumi.ResourceOptions):
434
+ raise TypeError('Expected resource options to be a ResourceOptions instance')
435
+ if opts.id is None:
436
+ if __props__ is not None:
437
+ raise TypeError('__props__ is only valid when passed in combination with a valid opts.id to get an existing resource')
438
+ __props__ = ServiceendpointCheckmarxSastArgs.__new__(ServiceendpointCheckmarxSastArgs)
439
+
440
+ __props__.__dict__["authorization"] = authorization
441
+ __props__.__dict__["description"] = description
442
+ if password is None and not opts.urn:
443
+ raise TypeError("Missing required property 'password'")
444
+ __props__.__dict__["password"] = None if password is None else pulumi.Output.secret(password)
445
+ __props__.__dict__["preset"] = preset
446
+ if project_id is None and not opts.urn:
447
+ raise TypeError("Missing required property 'project_id'")
448
+ __props__.__dict__["project_id"] = project_id
449
+ if server_url is None and not opts.urn:
450
+ raise TypeError("Missing required property 'server_url'")
451
+ __props__.__dict__["server_url"] = server_url
452
+ if service_endpoint_name is None and not opts.urn:
453
+ raise TypeError("Missing required property 'service_endpoint_name'")
454
+ __props__.__dict__["service_endpoint_name"] = service_endpoint_name
455
+ __props__.__dict__["team"] = team
456
+ if username is None and not opts.urn:
457
+ raise TypeError("Missing required property 'username'")
458
+ __props__.__dict__["username"] = username
459
+ secret_opts = pulumi.ResourceOptions(additional_secret_outputs=["password"])
460
+ opts = pulumi.ResourceOptions.merge(opts, secret_opts)
461
+ super(ServiceendpointCheckmarxSast, __self__).__init__(
462
+ 'azuredevops:index/serviceendpointCheckmarxSast:ServiceendpointCheckmarxSast',
463
+ resource_name,
464
+ __props__,
465
+ opts)
466
+
467
+ @staticmethod
468
+ def get(resource_name: str,
469
+ id: pulumi.Input[str],
470
+ opts: Optional[pulumi.ResourceOptions] = None,
471
+ authorization: Optional[pulumi.Input[Mapping[str, pulumi.Input[str]]]] = None,
472
+ description: Optional[pulumi.Input[str]] = None,
473
+ password: Optional[pulumi.Input[str]] = None,
474
+ preset: Optional[pulumi.Input[str]] = None,
475
+ project_id: Optional[pulumi.Input[str]] = None,
476
+ server_url: Optional[pulumi.Input[str]] = None,
477
+ service_endpoint_name: Optional[pulumi.Input[str]] = None,
478
+ team: Optional[pulumi.Input[str]] = None,
479
+ username: Optional[pulumi.Input[str]] = None) -> 'ServiceendpointCheckmarxSast':
480
+ """
481
+ Get an existing ServiceendpointCheckmarxSast resource's state with the given name, id, and optional extra
482
+ properties used to qualify the lookup.
483
+
484
+ :param str resource_name: The unique name of the resulting resource.
485
+ :param pulumi.Input[str] id: The unique provider ID of the resource to lookup.
486
+ :param pulumi.ResourceOptions opts: Options for the resource.
487
+ :param pulumi.Input[str] password: The password of the Checkmarx SAST.
488
+ :param pulumi.Input[str] preset: Predefined sets of queries that you can select when Creating, Configuring and Branching Projects. Predefined presets are provided by Checkmarx and you can configure your own. You can also import and export presets (on the server).In Service Connection if preset(optional) value is added, then it will igonres Preset available in pipeline and uses preset available in service connection only.If Preset is blank in service connection then it will use pipelines preset.
489
+ :param pulumi.Input[str] project_id: The ID of the project.
490
+ :param pulumi.Input[str] server_url: The Server URL of the Checkmarx SAST.
491
+ :param pulumi.Input[str] service_endpoint_name: The Service Endpoint name.
492
+ :param pulumi.Input[str] team: The full team name of the Checkmarx.
493
+ :param pulumi.Input[str] username: The username of the Checkmarx SAST.
494
+ """
495
+ opts = pulumi.ResourceOptions.merge(opts, pulumi.ResourceOptions(id=id))
496
+
497
+ __props__ = _ServiceendpointCheckmarxSastState.__new__(_ServiceendpointCheckmarxSastState)
498
+
499
+ __props__.__dict__["authorization"] = authorization
500
+ __props__.__dict__["description"] = description
501
+ __props__.__dict__["password"] = password
502
+ __props__.__dict__["preset"] = preset
503
+ __props__.__dict__["project_id"] = project_id
504
+ __props__.__dict__["server_url"] = server_url
505
+ __props__.__dict__["service_endpoint_name"] = service_endpoint_name
506
+ __props__.__dict__["team"] = team
507
+ __props__.__dict__["username"] = username
508
+ return ServiceendpointCheckmarxSast(resource_name, opts=opts, __props__=__props__)
509
+
510
+ @property
511
+ @pulumi.getter
512
+ def authorization(self) -> pulumi.Output[Mapping[str, str]]:
513
+ return pulumi.get(self, "authorization")
514
+
515
+ @property
516
+ @pulumi.getter
517
+ def description(self) -> pulumi.Output[Optional[str]]:
518
+ return pulumi.get(self, "description")
519
+
520
+ @property
521
+ @pulumi.getter
522
+ def password(self) -> pulumi.Output[str]:
523
+ """
524
+ The password of the Checkmarx SAST.
525
+ """
526
+ return pulumi.get(self, "password")
527
+
528
+ @property
529
+ @pulumi.getter
530
+ def preset(self) -> pulumi.Output[Optional[str]]:
531
+ """
532
+ Predefined sets of queries that you can select when Creating, Configuring and Branching Projects. Predefined presets are provided by Checkmarx and you can configure your own. You can also import and export presets (on the server).In Service Connection if preset(optional) value is added, then it will igonres Preset available in pipeline and uses preset available in service connection only.If Preset is blank in service connection then it will use pipelines preset.
533
+ """
534
+ return pulumi.get(self, "preset")
535
+
536
+ @property
537
+ @pulumi.getter(name="projectId")
538
+ def project_id(self) -> pulumi.Output[str]:
539
+ """
540
+ The ID of the project.
541
+ """
542
+ return pulumi.get(self, "project_id")
543
+
544
+ @property
545
+ @pulumi.getter(name="serverUrl")
546
+ def server_url(self) -> pulumi.Output[str]:
547
+ """
548
+ The Server URL of the Checkmarx SAST.
549
+ """
550
+ return pulumi.get(self, "server_url")
551
+
552
+ @property
553
+ @pulumi.getter(name="serviceEndpointName")
554
+ def service_endpoint_name(self) -> pulumi.Output[str]:
555
+ """
556
+ The Service Endpoint name.
557
+ """
558
+ return pulumi.get(self, "service_endpoint_name")
559
+
560
+ @property
561
+ @pulumi.getter
562
+ def team(self) -> pulumi.Output[Optional[str]]:
563
+ """
564
+ The full team name of the Checkmarx.
565
+ """
566
+ return pulumi.get(self, "team")
567
+
568
+ @property
569
+ @pulumi.getter
570
+ def username(self) -> pulumi.Output[str]:
571
+ """
572
+ The username of the Checkmarx SAST.
573
+ """
574
+ return pulumi.get(self, "username")
575
+