pulumi-akamai 9.1.0a1757049021__py3-none-any.whl → 9.2.0a1757567369__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.

Potentially problematic release.


This version of pulumi-akamai might be problematic. Click here for more details.

@@ -0,0 +1,562 @@
1
+ # coding=utf-8
2
+ # *** WARNING: this file was generated by pulumi-language-python. ***
3
+ # *** Do not edit by hand unless you're certain you know what you are doing! ***
4
+
5
+ import builtins as _builtins
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
+ from . import outputs
17
+ from ._inputs import *
18
+
19
+ __all__ = ['MtlskeystoreClientCertificateThirdPartyArgs', 'MtlskeystoreClientCertificateThirdParty']
20
+
21
+ @pulumi.input_type
22
+ class MtlskeystoreClientCertificateThirdPartyArgs:
23
+ def __init__(__self__, *,
24
+ certificate_name: pulumi.Input[_builtins.str],
25
+ contract_id: pulumi.Input[_builtins.str],
26
+ geography: pulumi.Input[_builtins.str],
27
+ group_id: pulumi.Input[_builtins.int],
28
+ notification_emails: pulumi.Input[Sequence[pulumi.Input[_builtins.str]]],
29
+ secure_network: pulumi.Input[_builtins.str],
30
+ versions: pulumi.Input[Mapping[str, pulumi.Input['MtlskeystoreClientCertificateThirdPartyVersionsArgs']]],
31
+ key_algorithm: Optional[pulumi.Input[_builtins.str]] = None,
32
+ subject: Optional[pulumi.Input[_builtins.str]] = None):
33
+ """
34
+ The set of arguments for constructing a MtlskeystoreClientCertificateThirdParty resource.
35
+ :param pulumi.Input[_builtins.str] certificate_name: The name of the client certificate. Must be between 1 and 64 characters.
36
+ :param pulumi.Input[_builtins.str] contract_id: The contract assigned to the client certificate. Must have a length of at least 1.
37
+ :param pulumi.Input[_builtins.str] geography: Specifies the type of network to deploy the client certificate. Possible values: `CORE`, `RUSSIA_AND_CORE`, or `CHINA_AND_CORE`.
38
+ :param pulumi.Input[_builtins.int] group_id: The group assigned to the client certificate. Must be greater than or equal to 0.
39
+ :param pulumi.Input[Sequence[pulumi.Input[_builtins.str]]] notification_emails: The email addresses to notify for client certificate-related issues. Must have at least one email address.
40
+ :param pulumi.Input[_builtins.str] secure_network: Identifies the network deployment type. Possible values: `STANDARD_TLS` or `ENHANCED_TLS`.
41
+ :param pulumi.Input[Mapping[str, pulumi.Input['MtlskeystoreClientCertificateThirdPartyVersionsArgs']]] versions: A map of client certificate versions as a value and user defined identifier as a key. Each version represents a specific iteration of the client certificate.
42
+ :param pulumi.Input[_builtins.str] key_algorithm: The cryptographic algorithm used for key generation. Possible values: `RSA` or `ECDSA`. The default is `RSA`.
43
+ :param pulumi.Input[_builtins.str] subject: The CA certificate’s key value details. The `CN` attribute is required and included in the subject. When not specified, the subject is constructed in this format: `/C=US/O=Akamai Technologies, Inc./OU={vcd_id} {contract_id} {group_id}/CN={certificate_name}/`.
44
+ """
45
+ pulumi.set(__self__, "certificate_name", certificate_name)
46
+ pulumi.set(__self__, "contract_id", contract_id)
47
+ pulumi.set(__self__, "geography", geography)
48
+ pulumi.set(__self__, "group_id", group_id)
49
+ pulumi.set(__self__, "notification_emails", notification_emails)
50
+ pulumi.set(__self__, "secure_network", secure_network)
51
+ pulumi.set(__self__, "versions", versions)
52
+ if key_algorithm is not None:
53
+ pulumi.set(__self__, "key_algorithm", key_algorithm)
54
+ if subject is not None:
55
+ pulumi.set(__self__, "subject", subject)
56
+
57
+ @_builtins.property
58
+ @pulumi.getter(name="certificateName")
59
+ def certificate_name(self) -> pulumi.Input[_builtins.str]:
60
+ """
61
+ The name of the client certificate. Must be between 1 and 64 characters.
62
+ """
63
+ return pulumi.get(self, "certificate_name")
64
+
65
+ @certificate_name.setter
66
+ def certificate_name(self, value: pulumi.Input[_builtins.str]):
67
+ pulumi.set(self, "certificate_name", value)
68
+
69
+ @_builtins.property
70
+ @pulumi.getter(name="contractId")
71
+ def contract_id(self) -> pulumi.Input[_builtins.str]:
72
+ """
73
+ The contract assigned to the client certificate. Must have a length of at least 1.
74
+ """
75
+ return pulumi.get(self, "contract_id")
76
+
77
+ @contract_id.setter
78
+ def contract_id(self, value: pulumi.Input[_builtins.str]):
79
+ pulumi.set(self, "contract_id", value)
80
+
81
+ @_builtins.property
82
+ @pulumi.getter
83
+ def geography(self) -> pulumi.Input[_builtins.str]:
84
+ """
85
+ Specifies the type of network to deploy the client certificate. Possible values: `CORE`, `RUSSIA_AND_CORE`, or `CHINA_AND_CORE`.
86
+ """
87
+ return pulumi.get(self, "geography")
88
+
89
+ @geography.setter
90
+ def geography(self, value: pulumi.Input[_builtins.str]):
91
+ pulumi.set(self, "geography", value)
92
+
93
+ @_builtins.property
94
+ @pulumi.getter(name="groupId")
95
+ def group_id(self) -> pulumi.Input[_builtins.int]:
96
+ """
97
+ The group assigned to the client certificate. Must be greater than or equal to 0.
98
+ """
99
+ return pulumi.get(self, "group_id")
100
+
101
+ @group_id.setter
102
+ def group_id(self, value: pulumi.Input[_builtins.int]):
103
+ pulumi.set(self, "group_id", value)
104
+
105
+ @_builtins.property
106
+ @pulumi.getter(name="notificationEmails")
107
+ def notification_emails(self) -> pulumi.Input[Sequence[pulumi.Input[_builtins.str]]]:
108
+ """
109
+ The email addresses to notify for client certificate-related issues. Must have at least one email address.
110
+ """
111
+ return pulumi.get(self, "notification_emails")
112
+
113
+ @notification_emails.setter
114
+ def notification_emails(self, value: pulumi.Input[Sequence[pulumi.Input[_builtins.str]]]):
115
+ pulumi.set(self, "notification_emails", value)
116
+
117
+ @_builtins.property
118
+ @pulumi.getter(name="secureNetwork")
119
+ def secure_network(self) -> pulumi.Input[_builtins.str]:
120
+ """
121
+ Identifies the network deployment type. Possible values: `STANDARD_TLS` or `ENHANCED_TLS`.
122
+ """
123
+ return pulumi.get(self, "secure_network")
124
+
125
+ @secure_network.setter
126
+ def secure_network(self, value: pulumi.Input[_builtins.str]):
127
+ pulumi.set(self, "secure_network", value)
128
+
129
+ @_builtins.property
130
+ @pulumi.getter
131
+ def versions(self) -> pulumi.Input[Mapping[str, pulumi.Input['MtlskeystoreClientCertificateThirdPartyVersionsArgs']]]:
132
+ """
133
+ A map of client certificate versions as a value and user defined identifier as a key. Each version represents a specific iteration of the client certificate.
134
+ """
135
+ return pulumi.get(self, "versions")
136
+
137
+ @versions.setter
138
+ def versions(self, value: pulumi.Input[Mapping[str, pulumi.Input['MtlskeystoreClientCertificateThirdPartyVersionsArgs']]]):
139
+ pulumi.set(self, "versions", value)
140
+
141
+ @_builtins.property
142
+ @pulumi.getter(name="keyAlgorithm")
143
+ def key_algorithm(self) -> Optional[pulumi.Input[_builtins.str]]:
144
+ """
145
+ The cryptographic algorithm used for key generation. Possible values: `RSA` or `ECDSA`. The default is `RSA`.
146
+ """
147
+ return pulumi.get(self, "key_algorithm")
148
+
149
+ @key_algorithm.setter
150
+ def key_algorithm(self, value: Optional[pulumi.Input[_builtins.str]]):
151
+ pulumi.set(self, "key_algorithm", value)
152
+
153
+ @_builtins.property
154
+ @pulumi.getter
155
+ def subject(self) -> Optional[pulumi.Input[_builtins.str]]:
156
+ """
157
+ The CA certificate’s key value details. The `CN` attribute is required and included in the subject. When not specified, the subject is constructed in this format: `/C=US/O=Akamai Technologies, Inc./OU={vcd_id} {contract_id} {group_id}/CN={certificate_name}/`.
158
+ """
159
+ return pulumi.get(self, "subject")
160
+
161
+ @subject.setter
162
+ def subject(self, value: Optional[pulumi.Input[_builtins.str]]):
163
+ pulumi.set(self, "subject", value)
164
+
165
+
166
+ @pulumi.input_type
167
+ class _MtlskeystoreClientCertificateThirdPartyState:
168
+ def __init__(__self__, *,
169
+ certificate_id: Optional[pulumi.Input[_builtins.int]] = None,
170
+ certificate_name: Optional[pulumi.Input[_builtins.str]] = None,
171
+ contract_id: Optional[pulumi.Input[_builtins.str]] = None,
172
+ geography: Optional[pulumi.Input[_builtins.str]] = None,
173
+ group_id: Optional[pulumi.Input[_builtins.int]] = None,
174
+ key_algorithm: Optional[pulumi.Input[_builtins.str]] = None,
175
+ notification_emails: Optional[pulumi.Input[Sequence[pulumi.Input[_builtins.str]]]] = None,
176
+ secure_network: Optional[pulumi.Input[_builtins.str]] = None,
177
+ subject: Optional[pulumi.Input[_builtins.str]] = None,
178
+ versions: Optional[pulumi.Input[Mapping[str, pulumi.Input['MtlskeystoreClientCertificateThirdPartyVersionsArgs']]]] = None):
179
+ """
180
+ Input properties used for looking up and filtering MtlskeystoreClientCertificateThirdParty resources.
181
+ :param pulumi.Input[_builtins.int] certificate_id: The unique identifier of the client certificate.
182
+ :param pulumi.Input[_builtins.str] certificate_name: The name of the client certificate. Must be between 1 and 64 characters.
183
+ :param pulumi.Input[_builtins.str] contract_id: The contract assigned to the client certificate. Must have a length of at least 1.
184
+ :param pulumi.Input[_builtins.str] geography: Specifies the type of network to deploy the client certificate. Possible values: `CORE`, `RUSSIA_AND_CORE`, or `CHINA_AND_CORE`.
185
+ :param pulumi.Input[_builtins.int] group_id: The group assigned to the client certificate. Must be greater than or equal to 0.
186
+ :param pulumi.Input[_builtins.str] key_algorithm: The cryptographic algorithm used for key generation. Possible values: `RSA` or `ECDSA`. The default is `RSA`.
187
+ :param pulumi.Input[Sequence[pulumi.Input[_builtins.str]]] notification_emails: The email addresses to notify for client certificate-related issues. Must have at least one email address.
188
+ :param pulumi.Input[_builtins.str] secure_network: Identifies the network deployment type. Possible values: `STANDARD_TLS` or `ENHANCED_TLS`.
189
+ :param pulumi.Input[_builtins.str] subject: The CA certificate’s key value details. The `CN` attribute is required and included in the subject. When not specified, the subject is constructed in this format: `/C=US/O=Akamai Technologies, Inc./OU={vcd_id} {contract_id} {group_id}/CN={certificate_name}/`.
190
+ :param pulumi.Input[Mapping[str, pulumi.Input['MtlskeystoreClientCertificateThirdPartyVersionsArgs']]] versions: A map of client certificate versions as a value and user defined identifier as a key. Each version represents a specific iteration of the client certificate.
191
+ """
192
+ if certificate_id is not None:
193
+ pulumi.set(__self__, "certificate_id", certificate_id)
194
+ if certificate_name is not None:
195
+ pulumi.set(__self__, "certificate_name", certificate_name)
196
+ if contract_id is not None:
197
+ pulumi.set(__self__, "contract_id", contract_id)
198
+ if geography is not None:
199
+ pulumi.set(__self__, "geography", geography)
200
+ if group_id is not None:
201
+ pulumi.set(__self__, "group_id", group_id)
202
+ if key_algorithm is not None:
203
+ pulumi.set(__self__, "key_algorithm", key_algorithm)
204
+ if notification_emails is not None:
205
+ pulumi.set(__self__, "notification_emails", notification_emails)
206
+ if secure_network is not None:
207
+ pulumi.set(__self__, "secure_network", secure_network)
208
+ if subject is not None:
209
+ pulumi.set(__self__, "subject", subject)
210
+ if versions is not None:
211
+ pulumi.set(__self__, "versions", versions)
212
+
213
+ @_builtins.property
214
+ @pulumi.getter(name="certificateId")
215
+ def certificate_id(self) -> Optional[pulumi.Input[_builtins.int]]:
216
+ """
217
+ The unique identifier of the client certificate.
218
+ """
219
+ return pulumi.get(self, "certificate_id")
220
+
221
+ @certificate_id.setter
222
+ def certificate_id(self, value: Optional[pulumi.Input[_builtins.int]]):
223
+ pulumi.set(self, "certificate_id", value)
224
+
225
+ @_builtins.property
226
+ @pulumi.getter(name="certificateName")
227
+ def certificate_name(self) -> Optional[pulumi.Input[_builtins.str]]:
228
+ """
229
+ The name of the client certificate. Must be between 1 and 64 characters.
230
+ """
231
+ return pulumi.get(self, "certificate_name")
232
+
233
+ @certificate_name.setter
234
+ def certificate_name(self, value: Optional[pulumi.Input[_builtins.str]]):
235
+ pulumi.set(self, "certificate_name", value)
236
+
237
+ @_builtins.property
238
+ @pulumi.getter(name="contractId")
239
+ def contract_id(self) -> Optional[pulumi.Input[_builtins.str]]:
240
+ """
241
+ The contract assigned to the client certificate. Must have a length of at least 1.
242
+ """
243
+ return pulumi.get(self, "contract_id")
244
+
245
+ @contract_id.setter
246
+ def contract_id(self, value: Optional[pulumi.Input[_builtins.str]]):
247
+ pulumi.set(self, "contract_id", value)
248
+
249
+ @_builtins.property
250
+ @pulumi.getter
251
+ def geography(self) -> Optional[pulumi.Input[_builtins.str]]:
252
+ """
253
+ Specifies the type of network to deploy the client certificate. Possible values: `CORE`, `RUSSIA_AND_CORE`, or `CHINA_AND_CORE`.
254
+ """
255
+ return pulumi.get(self, "geography")
256
+
257
+ @geography.setter
258
+ def geography(self, value: Optional[pulumi.Input[_builtins.str]]):
259
+ pulumi.set(self, "geography", value)
260
+
261
+ @_builtins.property
262
+ @pulumi.getter(name="groupId")
263
+ def group_id(self) -> Optional[pulumi.Input[_builtins.int]]:
264
+ """
265
+ The group assigned to the client certificate. Must be greater than or equal to 0.
266
+ """
267
+ return pulumi.get(self, "group_id")
268
+
269
+ @group_id.setter
270
+ def group_id(self, value: Optional[pulumi.Input[_builtins.int]]):
271
+ pulumi.set(self, "group_id", value)
272
+
273
+ @_builtins.property
274
+ @pulumi.getter(name="keyAlgorithm")
275
+ def key_algorithm(self) -> Optional[pulumi.Input[_builtins.str]]:
276
+ """
277
+ The cryptographic algorithm used for key generation. Possible values: `RSA` or `ECDSA`. The default is `RSA`.
278
+ """
279
+ return pulumi.get(self, "key_algorithm")
280
+
281
+ @key_algorithm.setter
282
+ def key_algorithm(self, value: Optional[pulumi.Input[_builtins.str]]):
283
+ pulumi.set(self, "key_algorithm", value)
284
+
285
+ @_builtins.property
286
+ @pulumi.getter(name="notificationEmails")
287
+ def notification_emails(self) -> Optional[pulumi.Input[Sequence[pulumi.Input[_builtins.str]]]]:
288
+ """
289
+ The email addresses to notify for client certificate-related issues. Must have at least one email address.
290
+ """
291
+ return pulumi.get(self, "notification_emails")
292
+
293
+ @notification_emails.setter
294
+ def notification_emails(self, value: Optional[pulumi.Input[Sequence[pulumi.Input[_builtins.str]]]]):
295
+ pulumi.set(self, "notification_emails", value)
296
+
297
+ @_builtins.property
298
+ @pulumi.getter(name="secureNetwork")
299
+ def secure_network(self) -> Optional[pulumi.Input[_builtins.str]]:
300
+ """
301
+ Identifies the network deployment type. Possible values: `STANDARD_TLS` or `ENHANCED_TLS`.
302
+ """
303
+ return pulumi.get(self, "secure_network")
304
+
305
+ @secure_network.setter
306
+ def secure_network(self, value: Optional[pulumi.Input[_builtins.str]]):
307
+ pulumi.set(self, "secure_network", value)
308
+
309
+ @_builtins.property
310
+ @pulumi.getter
311
+ def subject(self) -> Optional[pulumi.Input[_builtins.str]]:
312
+ """
313
+ The CA certificate’s key value details. The `CN` attribute is required and included in the subject. When not specified, the subject is constructed in this format: `/C=US/O=Akamai Technologies, Inc./OU={vcd_id} {contract_id} {group_id}/CN={certificate_name}/`.
314
+ """
315
+ return pulumi.get(self, "subject")
316
+
317
+ @subject.setter
318
+ def subject(self, value: Optional[pulumi.Input[_builtins.str]]):
319
+ pulumi.set(self, "subject", value)
320
+
321
+ @_builtins.property
322
+ @pulumi.getter
323
+ def versions(self) -> Optional[pulumi.Input[Mapping[str, pulumi.Input['MtlskeystoreClientCertificateThirdPartyVersionsArgs']]]]:
324
+ """
325
+ A map of client certificate versions as a value and user defined identifier as a key. Each version represents a specific iteration of the client certificate.
326
+ """
327
+ return pulumi.get(self, "versions")
328
+
329
+ @versions.setter
330
+ def versions(self, value: Optional[pulumi.Input[Mapping[str, pulumi.Input['MtlskeystoreClientCertificateThirdPartyVersionsArgs']]]]):
331
+ pulumi.set(self, "versions", value)
332
+
333
+
334
+ @pulumi.type_token("akamai:index/mtlskeystoreClientCertificateThirdParty:MtlskeystoreClientCertificateThirdParty")
335
+ class MtlskeystoreClientCertificateThirdParty(pulumi.CustomResource):
336
+ @overload
337
+ def __init__(__self__,
338
+ resource_name: str,
339
+ opts: Optional[pulumi.ResourceOptions] = None,
340
+ certificate_name: Optional[pulumi.Input[_builtins.str]] = None,
341
+ contract_id: Optional[pulumi.Input[_builtins.str]] = None,
342
+ geography: Optional[pulumi.Input[_builtins.str]] = None,
343
+ group_id: Optional[pulumi.Input[_builtins.int]] = None,
344
+ key_algorithm: Optional[pulumi.Input[_builtins.str]] = None,
345
+ notification_emails: Optional[pulumi.Input[Sequence[pulumi.Input[_builtins.str]]]] = None,
346
+ secure_network: Optional[pulumi.Input[_builtins.str]] = None,
347
+ subject: Optional[pulumi.Input[_builtins.str]] = None,
348
+ versions: Optional[pulumi.Input[Mapping[str, pulumi.Input[Union['MtlskeystoreClientCertificateThirdPartyVersionsArgs', 'MtlskeystoreClientCertificateThirdPartyVersionsArgsDict']]]]] = None,
349
+ __props__=None):
350
+ """
351
+ Create a MtlskeystoreClientCertificateThirdParty resource with the given unique name, props, and options.
352
+ :param str resource_name: The name of the resource.
353
+ :param pulumi.ResourceOptions opts: Options for the resource.
354
+ :param pulumi.Input[_builtins.str] certificate_name: The name of the client certificate. Must be between 1 and 64 characters.
355
+ :param pulumi.Input[_builtins.str] contract_id: The contract assigned to the client certificate. Must have a length of at least 1.
356
+ :param pulumi.Input[_builtins.str] geography: Specifies the type of network to deploy the client certificate. Possible values: `CORE`, `RUSSIA_AND_CORE`, or `CHINA_AND_CORE`.
357
+ :param pulumi.Input[_builtins.int] group_id: The group assigned to the client certificate. Must be greater than or equal to 0.
358
+ :param pulumi.Input[_builtins.str] key_algorithm: The cryptographic algorithm used for key generation. Possible values: `RSA` or `ECDSA`. The default is `RSA`.
359
+ :param pulumi.Input[Sequence[pulumi.Input[_builtins.str]]] notification_emails: The email addresses to notify for client certificate-related issues. Must have at least one email address.
360
+ :param pulumi.Input[_builtins.str] secure_network: Identifies the network deployment type. Possible values: `STANDARD_TLS` or `ENHANCED_TLS`.
361
+ :param pulumi.Input[_builtins.str] subject: The CA certificate’s key value details. The `CN` attribute is required and included in the subject. When not specified, the subject is constructed in this format: `/C=US/O=Akamai Technologies, Inc./OU={vcd_id} {contract_id} {group_id}/CN={certificate_name}/`.
362
+ :param pulumi.Input[Mapping[str, pulumi.Input[Union['MtlskeystoreClientCertificateThirdPartyVersionsArgs', 'MtlskeystoreClientCertificateThirdPartyVersionsArgsDict']]]] versions: A map of client certificate versions as a value and user defined identifier as a key. Each version represents a specific iteration of the client certificate.
363
+ """
364
+ ...
365
+ @overload
366
+ def __init__(__self__,
367
+ resource_name: str,
368
+ args: MtlskeystoreClientCertificateThirdPartyArgs,
369
+ opts: Optional[pulumi.ResourceOptions] = None):
370
+ """
371
+ Create a MtlskeystoreClientCertificateThirdParty resource with the given unique name, props, and options.
372
+ :param str resource_name: The name of the resource.
373
+ :param MtlskeystoreClientCertificateThirdPartyArgs args: The arguments to use to populate this resource's properties.
374
+ :param pulumi.ResourceOptions opts: Options for the resource.
375
+ """
376
+ ...
377
+ def __init__(__self__, resource_name: str, *args, **kwargs):
378
+ resource_args, opts = _utilities.get_resource_args_opts(MtlskeystoreClientCertificateThirdPartyArgs, pulumi.ResourceOptions, *args, **kwargs)
379
+ if resource_args is not None:
380
+ __self__._internal_init(resource_name, opts, **resource_args.__dict__)
381
+ else:
382
+ __self__._internal_init(resource_name, *args, **kwargs)
383
+
384
+ def _internal_init(__self__,
385
+ resource_name: str,
386
+ opts: Optional[pulumi.ResourceOptions] = None,
387
+ certificate_name: Optional[pulumi.Input[_builtins.str]] = None,
388
+ contract_id: Optional[pulumi.Input[_builtins.str]] = None,
389
+ geography: Optional[pulumi.Input[_builtins.str]] = None,
390
+ group_id: Optional[pulumi.Input[_builtins.int]] = None,
391
+ key_algorithm: Optional[pulumi.Input[_builtins.str]] = None,
392
+ notification_emails: Optional[pulumi.Input[Sequence[pulumi.Input[_builtins.str]]]] = None,
393
+ secure_network: Optional[pulumi.Input[_builtins.str]] = None,
394
+ subject: Optional[pulumi.Input[_builtins.str]] = None,
395
+ versions: Optional[pulumi.Input[Mapping[str, pulumi.Input[Union['MtlskeystoreClientCertificateThirdPartyVersionsArgs', 'MtlskeystoreClientCertificateThirdPartyVersionsArgsDict']]]]] = None,
396
+ __props__=None):
397
+ opts = pulumi.ResourceOptions.merge(_utilities.get_resource_opts_defaults(), opts)
398
+ if not isinstance(opts, pulumi.ResourceOptions):
399
+ raise TypeError('Expected resource options to be a ResourceOptions instance')
400
+ if opts.id is None:
401
+ if __props__ is not None:
402
+ raise TypeError('__props__ is only valid when passed in combination with a valid opts.id to get an existing resource')
403
+ __props__ = MtlskeystoreClientCertificateThirdPartyArgs.__new__(MtlskeystoreClientCertificateThirdPartyArgs)
404
+
405
+ if certificate_name is None and not opts.urn:
406
+ raise TypeError("Missing required property 'certificate_name'")
407
+ __props__.__dict__["certificate_name"] = certificate_name
408
+ if contract_id is None and not opts.urn:
409
+ raise TypeError("Missing required property 'contract_id'")
410
+ __props__.__dict__["contract_id"] = contract_id
411
+ if geography is None and not opts.urn:
412
+ raise TypeError("Missing required property 'geography'")
413
+ __props__.__dict__["geography"] = geography
414
+ if group_id is None and not opts.urn:
415
+ raise TypeError("Missing required property 'group_id'")
416
+ __props__.__dict__["group_id"] = group_id
417
+ __props__.__dict__["key_algorithm"] = key_algorithm
418
+ if notification_emails is None and not opts.urn:
419
+ raise TypeError("Missing required property 'notification_emails'")
420
+ __props__.__dict__["notification_emails"] = notification_emails
421
+ if secure_network is None and not opts.urn:
422
+ raise TypeError("Missing required property 'secure_network'")
423
+ __props__.__dict__["secure_network"] = secure_network
424
+ __props__.__dict__["subject"] = subject
425
+ if versions is None and not opts.urn:
426
+ raise TypeError("Missing required property 'versions'")
427
+ __props__.__dict__["versions"] = versions
428
+ __props__.__dict__["certificate_id"] = None
429
+ super(MtlskeystoreClientCertificateThirdParty, __self__).__init__(
430
+ 'akamai:index/mtlskeystoreClientCertificateThirdParty:MtlskeystoreClientCertificateThirdParty',
431
+ resource_name,
432
+ __props__,
433
+ opts)
434
+
435
+ @staticmethod
436
+ def get(resource_name: str,
437
+ id: pulumi.Input[str],
438
+ opts: Optional[pulumi.ResourceOptions] = None,
439
+ certificate_id: Optional[pulumi.Input[_builtins.int]] = None,
440
+ certificate_name: Optional[pulumi.Input[_builtins.str]] = None,
441
+ contract_id: Optional[pulumi.Input[_builtins.str]] = None,
442
+ geography: Optional[pulumi.Input[_builtins.str]] = None,
443
+ group_id: Optional[pulumi.Input[_builtins.int]] = None,
444
+ key_algorithm: Optional[pulumi.Input[_builtins.str]] = None,
445
+ notification_emails: Optional[pulumi.Input[Sequence[pulumi.Input[_builtins.str]]]] = None,
446
+ secure_network: Optional[pulumi.Input[_builtins.str]] = None,
447
+ subject: Optional[pulumi.Input[_builtins.str]] = None,
448
+ versions: Optional[pulumi.Input[Mapping[str, pulumi.Input[Union['MtlskeystoreClientCertificateThirdPartyVersionsArgs', 'MtlskeystoreClientCertificateThirdPartyVersionsArgsDict']]]]] = None) -> 'MtlskeystoreClientCertificateThirdParty':
449
+ """
450
+ Get an existing MtlskeystoreClientCertificateThirdParty resource's state with the given name, id, and optional extra
451
+ properties used to qualify the lookup.
452
+
453
+ :param str resource_name: The unique name of the resulting resource.
454
+ :param pulumi.Input[str] id: The unique provider ID of the resource to lookup.
455
+ :param pulumi.ResourceOptions opts: Options for the resource.
456
+ :param pulumi.Input[_builtins.int] certificate_id: The unique identifier of the client certificate.
457
+ :param pulumi.Input[_builtins.str] certificate_name: The name of the client certificate. Must be between 1 and 64 characters.
458
+ :param pulumi.Input[_builtins.str] contract_id: The contract assigned to the client certificate. Must have a length of at least 1.
459
+ :param pulumi.Input[_builtins.str] geography: Specifies the type of network to deploy the client certificate. Possible values: `CORE`, `RUSSIA_AND_CORE`, or `CHINA_AND_CORE`.
460
+ :param pulumi.Input[_builtins.int] group_id: The group assigned to the client certificate. Must be greater than or equal to 0.
461
+ :param pulumi.Input[_builtins.str] key_algorithm: The cryptographic algorithm used for key generation. Possible values: `RSA` or `ECDSA`. The default is `RSA`.
462
+ :param pulumi.Input[Sequence[pulumi.Input[_builtins.str]]] notification_emails: The email addresses to notify for client certificate-related issues. Must have at least one email address.
463
+ :param pulumi.Input[_builtins.str] secure_network: Identifies the network deployment type. Possible values: `STANDARD_TLS` or `ENHANCED_TLS`.
464
+ :param pulumi.Input[_builtins.str] subject: The CA certificate’s key value details. The `CN` attribute is required and included in the subject. When not specified, the subject is constructed in this format: `/C=US/O=Akamai Technologies, Inc./OU={vcd_id} {contract_id} {group_id}/CN={certificate_name}/`.
465
+ :param pulumi.Input[Mapping[str, pulumi.Input[Union['MtlskeystoreClientCertificateThirdPartyVersionsArgs', 'MtlskeystoreClientCertificateThirdPartyVersionsArgsDict']]]] versions: A map of client certificate versions as a value and user defined identifier as a key. Each version represents a specific iteration of the client certificate.
466
+ """
467
+ opts = pulumi.ResourceOptions.merge(opts, pulumi.ResourceOptions(id=id))
468
+
469
+ __props__ = _MtlskeystoreClientCertificateThirdPartyState.__new__(_MtlskeystoreClientCertificateThirdPartyState)
470
+
471
+ __props__.__dict__["certificate_id"] = certificate_id
472
+ __props__.__dict__["certificate_name"] = certificate_name
473
+ __props__.__dict__["contract_id"] = contract_id
474
+ __props__.__dict__["geography"] = geography
475
+ __props__.__dict__["group_id"] = group_id
476
+ __props__.__dict__["key_algorithm"] = key_algorithm
477
+ __props__.__dict__["notification_emails"] = notification_emails
478
+ __props__.__dict__["secure_network"] = secure_network
479
+ __props__.__dict__["subject"] = subject
480
+ __props__.__dict__["versions"] = versions
481
+ return MtlskeystoreClientCertificateThirdParty(resource_name, opts=opts, __props__=__props__)
482
+
483
+ @_builtins.property
484
+ @pulumi.getter(name="certificateId")
485
+ def certificate_id(self) -> pulumi.Output[_builtins.int]:
486
+ """
487
+ The unique identifier of the client certificate.
488
+ """
489
+ return pulumi.get(self, "certificate_id")
490
+
491
+ @_builtins.property
492
+ @pulumi.getter(name="certificateName")
493
+ def certificate_name(self) -> pulumi.Output[_builtins.str]:
494
+ """
495
+ The name of the client certificate. Must be between 1 and 64 characters.
496
+ """
497
+ return pulumi.get(self, "certificate_name")
498
+
499
+ @_builtins.property
500
+ @pulumi.getter(name="contractId")
501
+ def contract_id(self) -> pulumi.Output[_builtins.str]:
502
+ """
503
+ The contract assigned to the client certificate. Must have a length of at least 1.
504
+ """
505
+ return pulumi.get(self, "contract_id")
506
+
507
+ @_builtins.property
508
+ @pulumi.getter
509
+ def geography(self) -> pulumi.Output[_builtins.str]:
510
+ """
511
+ Specifies the type of network to deploy the client certificate. Possible values: `CORE`, `RUSSIA_AND_CORE`, or `CHINA_AND_CORE`.
512
+ """
513
+ return pulumi.get(self, "geography")
514
+
515
+ @_builtins.property
516
+ @pulumi.getter(name="groupId")
517
+ def group_id(self) -> pulumi.Output[_builtins.int]:
518
+ """
519
+ The group assigned to the client certificate. Must be greater than or equal to 0.
520
+ """
521
+ return pulumi.get(self, "group_id")
522
+
523
+ @_builtins.property
524
+ @pulumi.getter(name="keyAlgorithm")
525
+ def key_algorithm(self) -> pulumi.Output[_builtins.str]:
526
+ """
527
+ The cryptographic algorithm used for key generation. Possible values: `RSA` or `ECDSA`. The default is `RSA`.
528
+ """
529
+ return pulumi.get(self, "key_algorithm")
530
+
531
+ @_builtins.property
532
+ @pulumi.getter(name="notificationEmails")
533
+ def notification_emails(self) -> pulumi.Output[Sequence[_builtins.str]]:
534
+ """
535
+ The email addresses to notify for client certificate-related issues. Must have at least one email address.
536
+ """
537
+ return pulumi.get(self, "notification_emails")
538
+
539
+ @_builtins.property
540
+ @pulumi.getter(name="secureNetwork")
541
+ def secure_network(self) -> pulumi.Output[_builtins.str]:
542
+ """
543
+ Identifies the network deployment type. Possible values: `STANDARD_TLS` or `ENHANCED_TLS`.
544
+ """
545
+ return pulumi.get(self, "secure_network")
546
+
547
+ @_builtins.property
548
+ @pulumi.getter
549
+ def subject(self) -> pulumi.Output[_builtins.str]:
550
+ """
551
+ The CA certificate’s key value details. The `CN` attribute is required and included in the subject. When not specified, the subject is constructed in this format: `/C=US/O=Akamai Technologies, Inc./OU={vcd_id} {contract_id} {group_id}/CN={certificate_name}/`.
552
+ """
553
+ return pulumi.get(self, "subject")
554
+
555
+ @_builtins.property
556
+ @pulumi.getter
557
+ def versions(self) -> pulumi.Output[Mapping[str, 'outputs.MtlskeystoreClientCertificateThirdPartyVersions']]:
558
+ """
559
+ A map of client certificate versions as a value and user defined identifier as a key. Each version represents a specific iteration of the client certificate.
560
+ """
561
+ return pulumi.get(self, "versions")
562
+