pulumi-vault 5.19.0a1705621752__py3-none-any.whl → 5.20.0__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_vault/__init__.py +59 -0
- pulumi_vault/_inputs.py +380 -0
- pulumi_vault/_utilities.py +2 -2
- pulumi_vault/aws/secret_backend.py +188 -0
- pulumi_vault/aws/secret_backend_static_role.py +2 -2
- pulumi_vault/azure/backend.py +7 -21
- pulumi_vault/config/__init__.pyi +0 -3
- pulumi_vault/config/outputs.py +380 -0
- pulumi_vault/config/vars.py +0 -3
- pulumi_vault/consul/secret_backend.py +7 -35
- pulumi_vault/database/_inputs.py +176 -0
- pulumi_vault/database/outputs.py +168 -0
- pulumi_vault/get_raft_autopilot_state.py +0 -12
- pulumi_vault/identity/group_alias.py +6 -6
- pulumi_vault/kubernetes/secret_backend_role.py +8 -4
- pulumi_vault/kv/_inputs.py +12 -0
- pulumi_vault/kv/outputs.py +12 -0
- pulumi_vault/ldap/secret_backend_dynamic_role.py +2 -2
- pulumi_vault/ldap/secret_backend_static_role.py +2 -2
- pulumi_vault/managed/_inputs.py +12 -0
- pulumi_vault/managed/keys.py +20 -0
- pulumi_vault/managed/outputs.py +12 -0
- pulumi_vault/mongodbatlas/secret_role.py +2 -2
- pulumi_vault/namespace.py +46 -14
- pulumi_vault/pkisecret/secret_backend_config_issuers.py +0 -6
- pulumi_vault/pkisecret/secret_backend_issuer.py +0 -10
- pulumi_vault/pkisecret/secret_backend_role.py +7 -7
- pulumi_vault/rabbitmq/_inputs.py +36 -0
- pulumi_vault/rabbitmq/outputs.py +36 -0
- pulumi_vault/saml/auth_backend_role.py +7 -14
- pulumi_vault/secrets/__init__.py +14 -0
- pulumi_vault/secrets/sync_association.py +464 -0
- pulumi_vault/secrets/sync_aws_destination.py +564 -0
- pulumi_vault/secrets/sync_azure_destination.py +674 -0
- pulumi_vault/secrets/sync_config.py +297 -0
- pulumi_vault/secrets/sync_gcp_destination.py +438 -0
- pulumi_vault/secrets/sync_gh_destination.py +511 -0
- pulumi_vault/secrets/sync_vercel_destination.py +541 -0
- pulumi_vault/ssh/secret_backend_role.py +7 -14
- {pulumi_vault-5.19.0a1705621752.dist-info → pulumi_vault-5.20.0.dist-info}/METADATA +2 -2
- {pulumi_vault-5.19.0a1705621752.dist-info → pulumi_vault-5.20.0.dist-info}/RECORD +43 -35
- {pulumi_vault-5.19.0a1705621752.dist-info → pulumi_vault-5.20.0.dist-info}/WHEEL +0 -0
- {pulumi_vault-5.19.0a1705621752.dist-info → pulumi_vault-5.20.0.dist-info}/top_level.txt +0 -0
@@ -0,0 +1,564 @@
|
|
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__ = ['SyncAwsDestinationArgs', 'SyncAwsDestination']
|
13
|
+
|
14
|
+
@pulumi.input_type
|
15
|
+
class SyncAwsDestinationArgs:
|
16
|
+
def __init__(__self__, *,
|
17
|
+
access_key_id: Optional[pulumi.Input[str]] = None,
|
18
|
+
custom_tags: Optional[pulumi.Input[Mapping[str, Any]]] = None,
|
19
|
+
name: Optional[pulumi.Input[str]] = None,
|
20
|
+
namespace: Optional[pulumi.Input[str]] = None,
|
21
|
+
region: Optional[pulumi.Input[str]] = None,
|
22
|
+
secret_access_key: Optional[pulumi.Input[str]] = None,
|
23
|
+
secret_name_template: Optional[pulumi.Input[str]] = None):
|
24
|
+
"""
|
25
|
+
The set of arguments for constructing a SyncAwsDestination resource.
|
26
|
+
:param pulumi.Input[str] access_key_id: Access key id to authenticate against the AWS secrets manager.
|
27
|
+
Can be omitted and directly provided to Vault using the `AWS_ACCESS_KEY_ID` environment
|
28
|
+
variable.
|
29
|
+
:param pulumi.Input[Mapping[str, Any]] custom_tags: Custom tags to set on the secret managed at the destination.
|
30
|
+
:param pulumi.Input[str] name: Unique name of the AWS destination.
|
31
|
+
:param pulumi.Input[str] namespace: The namespace to provision the resource in.
|
32
|
+
The value should not contain leading or trailing forward slashes.
|
33
|
+
The `namespace` is always relative to the provider's configured [namespace](https://www.terraform.io/docs/providers/vault#namespace).
|
34
|
+
:param pulumi.Input[str] region: Region where to manage the secrets manager entries.
|
35
|
+
Can be omitted and directly provided to Vault using the `AWS_REGION` environment
|
36
|
+
variable.
|
37
|
+
:param pulumi.Input[str] secret_access_key: Secret access key to authenticate against the AWS secrets manager.
|
38
|
+
Can be omitted and directly provided to Vault using the `AWS_SECRET_ACCESS_KEY` environment
|
39
|
+
variable.
|
40
|
+
:param pulumi.Input[str] secret_name_template: Template describing how to generate external secret names.
|
41
|
+
Supports a subset of the Go Template syntax.
|
42
|
+
"""
|
43
|
+
if access_key_id is not None:
|
44
|
+
pulumi.set(__self__, "access_key_id", access_key_id)
|
45
|
+
if custom_tags is not None:
|
46
|
+
pulumi.set(__self__, "custom_tags", custom_tags)
|
47
|
+
if name is not None:
|
48
|
+
pulumi.set(__self__, "name", name)
|
49
|
+
if namespace is not None:
|
50
|
+
pulumi.set(__self__, "namespace", namespace)
|
51
|
+
if region is not None:
|
52
|
+
pulumi.set(__self__, "region", region)
|
53
|
+
if secret_access_key is not None:
|
54
|
+
pulumi.set(__self__, "secret_access_key", secret_access_key)
|
55
|
+
if secret_name_template is not None:
|
56
|
+
pulumi.set(__self__, "secret_name_template", secret_name_template)
|
57
|
+
|
58
|
+
@property
|
59
|
+
@pulumi.getter(name="accessKeyId")
|
60
|
+
def access_key_id(self) -> Optional[pulumi.Input[str]]:
|
61
|
+
"""
|
62
|
+
Access key id to authenticate against the AWS secrets manager.
|
63
|
+
Can be omitted and directly provided to Vault using the `AWS_ACCESS_KEY_ID` environment
|
64
|
+
variable.
|
65
|
+
"""
|
66
|
+
return pulumi.get(self, "access_key_id")
|
67
|
+
|
68
|
+
@access_key_id.setter
|
69
|
+
def access_key_id(self, value: Optional[pulumi.Input[str]]):
|
70
|
+
pulumi.set(self, "access_key_id", value)
|
71
|
+
|
72
|
+
@property
|
73
|
+
@pulumi.getter(name="customTags")
|
74
|
+
def custom_tags(self) -> Optional[pulumi.Input[Mapping[str, Any]]]:
|
75
|
+
"""
|
76
|
+
Custom tags to set on the secret managed at the destination.
|
77
|
+
"""
|
78
|
+
return pulumi.get(self, "custom_tags")
|
79
|
+
|
80
|
+
@custom_tags.setter
|
81
|
+
def custom_tags(self, value: Optional[pulumi.Input[Mapping[str, Any]]]):
|
82
|
+
pulumi.set(self, "custom_tags", value)
|
83
|
+
|
84
|
+
@property
|
85
|
+
@pulumi.getter
|
86
|
+
def name(self) -> Optional[pulumi.Input[str]]:
|
87
|
+
"""
|
88
|
+
Unique name of the AWS destination.
|
89
|
+
"""
|
90
|
+
return pulumi.get(self, "name")
|
91
|
+
|
92
|
+
@name.setter
|
93
|
+
def name(self, value: Optional[pulumi.Input[str]]):
|
94
|
+
pulumi.set(self, "name", value)
|
95
|
+
|
96
|
+
@property
|
97
|
+
@pulumi.getter
|
98
|
+
def namespace(self) -> Optional[pulumi.Input[str]]:
|
99
|
+
"""
|
100
|
+
The namespace to provision the resource in.
|
101
|
+
The value should not contain leading or trailing forward slashes.
|
102
|
+
The `namespace` is always relative to the provider's configured [namespace](https://www.terraform.io/docs/providers/vault#namespace).
|
103
|
+
"""
|
104
|
+
return pulumi.get(self, "namespace")
|
105
|
+
|
106
|
+
@namespace.setter
|
107
|
+
def namespace(self, value: Optional[pulumi.Input[str]]):
|
108
|
+
pulumi.set(self, "namespace", value)
|
109
|
+
|
110
|
+
@property
|
111
|
+
@pulumi.getter
|
112
|
+
def region(self) -> Optional[pulumi.Input[str]]:
|
113
|
+
"""
|
114
|
+
Region where to manage the secrets manager entries.
|
115
|
+
Can be omitted and directly provided to Vault using the `AWS_REGION` environment
|
116
|
+
variable.
|
117
|
+
"""
|
118
|
+
return pulumi.get(self, "region")
|
119
|
+
|
120
|
+
@region.setter
|
121
|
+
def region(self, value: Optional[pulumi.Input[str]]):
|
122
|
+
pulumi.set(self, "region", value)
|
123
|
+
|
124
|
+
@property
|
125
|
+
@pulumi.getter(name="secretAccessKey")
|
126
|
+
def secret_access_key(self) -> Optional[pulumi.Input[str]]:
|
127
|
+
"""
|
128
|
+
Secret access key to authenticate against the AWS secrets manager.
|
129
|
+
Can be omitted and directly provided to Vault using the `AWS_SECRET_ACCESS_KEY` environment
|
130
|
+
variable.
|
131
|
+
"""
|
132
|
+
return pulumi.get(self, "secret_access_key")
|
133
|
+
|
134
|
+
@secret_access_key.setter
|
135
|
+
def secret_access_key(self, value: Optional[pulumi.Input[str]]):
|
136
|
+
pulumi.set(self, "secret_access_key", value)
|
137
|
+
|
138
|
+
@property
|
139
|
+
@pulumi.getter(name="secretNameTemplate")
|
140
|
+
def secret_name_template(self) -> Optional[pulumi.Input[str]]:
|
141
|
+
"""
|
142
|
+
Template describing how to generate external secret names.
|
143
|
+
Supports a subset of the Go Template syntax.
|
144
|
+
"""
|
145
|
+
return pulumi.get(self, "secret_name_template")
|
146
|
+
|
147
|
+
@secret_name_template.setter
|
148
|
+
def secret_name_template(self, value: Optional[pulumi.Input[str]]):
|
149
|
+
pulumi.set(self, "secret_name_template", value)
|
150
|
+
|
151
|
+
|
152
|
+
@pulumi.input_type
|
153
|
+
class _SyncAwsDestinationState:
|
154
|
+
def __init__(__self__, *,
|
155
|
+
access_key_id: Optional[pulumi.Input[str]] = None,
|
156
|
+
custom_tags: Optional[pulumi.Input[Mapping[str, Any]]] = None,
|
157
|
+
name: Optional[pulumi.Input[str]] = None,
|
158
|
+
namespace: Optional[pulumi.Input[str]] = None,
|
159
|
+
region: Optional[pulumi.Input[str]] = None,
|
160
|
+
secret_access_key: Optional[pulumi.Input[str]] = None,
|
161
|
+
secret_name_template: Optional[pulumi.Input[str]] = None,
|
162
|
+
type: Optional[pulumi.Input[str]] = None):
|
163
|
+
"""
|
164
|
+
Input properties used for looking up and filtering SyncAwsDestination resources.
|
165
|
+
:param pulumi.Input[str] access_key_id: Access key id to authenticate against the AWS secrets manager.
|
166
|
+
Can be omitted and directly provided to Vault using the `AWS_ACCESS_KEY_ID` environment
|
167
|
+
variable.
|
168
|
+
:param pulumi.Input[Mapping[str, Any]] custom_tags: Custom tags to set on the secret managed at the destination.
|
169
|
+
:param pulumi.Input[str] name: Unique name of the AWS destination.
|
170
|
+
:param pulumi.Input[str] namespace: The namespace to provision the resource in.
|
171
|
+
The value should not contain leading or trailing forward slashes.
|
172
|
+
The `namespace` is always relative to the provider's configured [namespace](https://www.terraform.io/docs/providers/vault#namespace).
|
173
|
+
:param pulumi.Input[str] region: Region where to manage the secrets manager entries.
|
174
|
+
Can be omitted and directly provided to Vault using the `AWS_REGION` environment
|
175
|
+
variable.
|
176
|
+
:param pulumi.Input[str] secret_access_key: Secret access key to authenticate against the AWS secrets manager.
|
177
|
+
Can be omitted and directly provided to Vault using the `AWS_SECRET_ACCESS_KEY` environment
|
178
|
+
variable.
|
179
|
+
:param pulumi.Input[str] secret_name_template: Template describing how to generate external secret names.
|
180
|
+
Supports a subset of the Go Template syntax.
|
181
|
+
:param pulumi.Input[str] type: The type of the secrets destination (`aws-sm`).
|
182
|
+
"""
|
183
|
+
if access_key_id is not None:
|
184
|
+
pulumi.set(__self__, "access_key_id", access_key_id)
|
185
|
+
if custom_tags is not None:
|
186
|
+
pulumi.set(__self__, "custom_tags", custom_tags)
|
187
|
+
if name is not None:
|
188
|
+
pulumi.set(__self__, "name", name)
|
189
|
+
if namespace is not None:
|
190
|
+
pulumi.set(__self__, "namespace", namespace)
|
191
|
+
if region is not None:
|
192
|
+
pulumi.set(__self__, "region", region)
|
193
|
+
if secret_access_key is not None:
|
194
|
+
pulumi.set(__self__, "secret_access_key", secret_access_key)
|
195
|
+
if secret_name_template is not None:
|
196
|
+
pulumi.set(__self__, "secret_name_template", secret_name_template)
|
197
|
+
if type is not None:
|
198
|
+
pulumi.set(__self__, "type", type)
|
199
|
+
|
200
|
+
@property
|
201
|
+
@pulumi.getter(name="accessKeyId")
|
202
|
+
def access_key_id(self) -> Optional[pulumi.Input[str]]:
|
203
|
+
"""
|
204
|
+
Access key id to authenticate against the AWS secrets manager.
|
205
|
+
Can be omitted and directly provided to Vault using the `AWS_ACCESS_KEY_ID` environment
|
206
|
+
variable.
|
207
|
+
"""
|
208
|
+
return pulumi.get(self, "access_key_id")
|
209
|
+
|
210
|
+
@access_key_id.setter
|
211
|
+
def access_key_id(self, value: Optional[pulumi.Input[str]]):
|
212
|
+
pulumi.set(self, "access_key_id", value)
|
213
|
+
|
214
|
+
@property
|
215
|
+
@pulumi.getter(name="customTags")
|
216
|
+
def custom_tags(self) -> Optional[pulumi.Input[Mapping[str, Any]]]:
|
217
|
+
"""
|
218
|
+
Custom tags to set on the secret managed at the destination.
|
219
|
+
"""
|
220
|
+
return pulumi.get(self, "custom_tags")
|
221
|
+
|
222
|
+
@custom_tags.setter
|
223
|
+
def custom_tags(self, value: Optional[pulumi.Input[Mapping[str, Any]]]):
|
224
|
+
pulumi.set(self, "custom_tags", value)
|
225
|
+
|
226
|
+
@property
|
227
|
+
@pulumi.getter
|
228
|
+
def name(self) -> Optional[pulumi.Input[str]]:
|
229
|
+
"""
|
230
|
+
Unique name of the AWS destination.
|
231
|
+
"""
|
232
|
+
return pulumi.get(self, "name")
|
233
|
+
|
234
|
+
@name.setter
|
235
|
+
def name(self, value: Optional[pulumi.Input[str]]):
|
236
|
+
pulumi.set(self, "name", value)
|
237
|
+
|
238
|
+
@property
|
239
|
+
@pulumi.getter
|
240
|
+
def namespace(self) -> Optional[pulumi.Input[str]]:
|
241
|
+
"""
|
242
|
+
The namespace to provision the resource in.
|
243
|
+
The value should not contain leading or trailing forward slashes.
|
244
|
+
The `namespace` is always relative to the provider's configured [namespace](https://www.terraform.io/docs/providers/vault#namespace).
|
245
|
+
"""
|
246
|
+
return pulumi.get(self, "namespace")
|
247
|
+
|
248
|
+
@namespace.setter
|
249
|
+
def namespace(self, value: Optional[pulumi.Input[str]]):
|
250
|
+
pulumi.set(self, "namespace", value)
|
251
|
+
|
252
|
+
@property
|
253
|
+
@pulumi.getter
|
254
|
+
def region(self) -> Optional[pulumi.Input[str]]:
|
255
|
+
"""
|
256
|
+
Region where to manage the secrets manager entries.
|
257
|
+
Can be omitted and directly provided to Vault using the `AWS_REGION` environment
|
258
|
+
variable.
|
259
|
+
"""
|
260
|
+
return pulumi.get(self, "region")
|
261
|
+
|
262
|
+
@region.setter
|
263
|
+
def region(self, value: Optional[pulumi.Input[str]]):
|
264
|
+
pulumi.set(self, "region", value)
|
265
|
+
|
266
|
+
@property
|
267
|
+
@pulumi.getter(name="secretAccessKey")
|
268
|
+
def secret_access_key(self) -> Optional[pulumi.Input[str]]:
|
269
|
+
"""
|
270
|
+
Secret access key to authenticate against the AWS secrets manager.
|
271
|
+
Can be omitted and directly provided to Vault using the `AWS_SECRET_ACCESS_KEY` environment
|
272
|
+
variable.
|
273
|
+
"""
|
274
|
+
return pulumi.get(self, "secret_access_key")
|
275
|
+
|
276
|
+
@secret_access_key.setter
|
277
|
+
def secret_access_key(self, value: Optional[pulumi.Input[str]]):
|
278
|
+
pulumi.set(self, "secret_access_key", value)
|
279
|
+
|
280
|
+
@property
|
281
|
+
@pulumi.getter(name="secretNameTemplate")
|
282
|
+
def secret_name_template(self) -> Optional[pulumi.Input[str]]:
|
283
|
+
"""
|
284
|
+
Template describing how to generate external secret names.
|
285
|
+
Supports a subset of the Go Template syntax.
|
286
|
+
"""
|
287
|
+
return pulumi.get(self, "secret_name_template")
|
288
|
+
|
289
|
+
@secret_name_template.setter
|
290
|
+
def secret_name_template(self, value: Optional[pulumi.Input[str]]):
|
291
|
+
pulumi.set(self, "secret_name_template", value)
|
292
|
+
|
293
|
+
@property
|
294
|
+
@pulumi.getter
|
295
|
+
def type(self) -> Optional[pulumi.Input[str]]:
|
296
|
+
"""
|
297
|
+
The type of the secrets destination (`aws-sm`).
|
298
|
+
"""
|
299
|
+
return pulumi.get(self, "type")
|
300
|
+
|
301
|
+
@type.setter
|
302
|
+
def type(self, value: Optional[pulumi.Input[str]]):
|
303
|
+
pulumi.set(self, "type", value)
|
304
|
+
|
305
|
+
|
306
|
+
class SyncAwsDestination(pulumi.CustomResource):
|
307
|
+
@overload
|
308
|
+
def __init__(__self__,
|
309
|
+
resource_name: str,
|
310
|
+
opts: Optional[pulumi.ResourceOptions] = None,
|
311
|
+
access_key_id: Optional[pulumi.Input[str]] = None,
|
312
|
+
custom_tags: Optional[pulumi.Input[Mapping[str, Any]]] = None,
|
313
|
+
name: Optional[pulumi.Input[str]] = None,
|
314
|
+
namespace: Optional[pulumi.Input[str]] = None,
|
315
|
+
region: Optional[pulumi.Input[str]] = None,
|
316
|
+
secret_access_key: Optional[pulumi.Input[str]] = None,
|
317
|
+
secret_name_template: Optional[pulumi.Input[str]] = None,
|
318
|
+
__props__=None):
|
319
|
+
"""
|
320
|
+
## Example Usage
|
321
|
+
|
322
|
+
```python
|
323
|
+
import pulumi
|
324
|
+
import pulumi_vault as vault
|
325
|
+
|
326
|
+
aws = vault.secrets.SyncAwsDestination("aws",
|
327
|
+
access_key_id=var["access_key_id"],
|
328
|
+
secret_access_key=var["secret_access_key"],
|
329
|
+
region="us-east-1",
|
330
|
+
secret_name_template="vault_{{ .MountAccessor | lowercase }}_{{ .SecretPath | lowercase }}",
|
331
|
+
custom_tags={
|
332
|
+
"foo": "bar",
|
333
|
+
})
|
334
|
+
```
|
335
|
+
|
336
|
+
## Import
|
337
|
+
|
338
|
+
AWS Secrets sync destinations can be imported using the `name`, e.g.
|
339
|
+
|
340
|
+
```sh
|
341
|
+
$ pulumi import vault:secrets/syncAwsDestination:SyncAwsDestination aws aws-dest
|
342
|
+
```
|
343
|
+
|
344
|
+
:param str resource_name: The name of the resource.
|
345
|
+
:param pulumi.ResourceOptions opts: Options for the resource.
|
346
|
+
:param pulumi.Input[str] access_key_id: Access key id to authenticate against the AWS secrets manager.
|
347
|
+
Can be omitted and directly provided to Vault using the `AWS_ACCESS_KEY_ID` environment
|
348
|
+
variable.
|
349
|
+
:param pulumi.Input[Mapping[str, Any]] custom_tags: Custom tags to set on the secret managed at the destination.
|
350
|
+
:param pulumi.Input[str] name: Unique name of the AWS destination.
|
351
|
+
:param pulumi.Input[str] namespace: The namespace to provision the resource in.
|
352
|
+
The value should not contain leading or trailing forward slashes.
|
353
|
+
The `namespace` is always relative to the provider's configured [namespace](https://www.terraform.io/docs/providers/vault#namespace).
|
354
|
+
:param pulumi.Input[str] region: Region where to manage the secrets manager entries.
|
355
|
+
Can be omitted and directly provided to Vault using the `AWS_REGION` environment
|
356
|
+
variable.
|
357
|
+
:param pulumi.Input[str] secret_access_key: Secret access key to authenticate against the AWS secrets manager.
|
358
|
+
Can be omitted and directly provided to Vault using the `AWS_SECRET_ACCESS_KEY` environment
|
359
|
+
variable.
|
360
|
+
:param pulumi.Input[str] secret_name_template: Template describing how to generate external secret names.
|
361
|
+
Supports a subset of the Go Template syntax.
|
362
|
+
"""
|
363
|
+
...
|
364
|
+
@overload
|
365
|
+
def __init__(__self__,
|
366
|
+
resource_name: str,
|
367
|
+
args: Optional[SyncAwsDestinationArgs] = None,
|
368
|
+
opts: Optional[pulumi.ResourceOptions] = None):
|
369
|
+
"""
|
370
|
+
## Example Usage
|
371
|
+
|
372
|
+
```python
|
373
|
+
import pulumi
|
374
|
+
import pulumi_vault as vault
|
375
|
+
|
376
|
+
aws = vault.secrets.SyncAwsDestination("aws",
|
377
|
+
access_key_id=var["access_key_id"],
|
378
|
+
secret_access_key=var["secret_access_key"],
|
379
|
+
region="us-east-1",
|
380
|
+
secret_name_template="vault_{{ .MountAccessor | lowercase }}_{{ .SecretPath | lowercase }}",
|
381
|
+
custom_tags={
|
382
|
+
"foo": "bar",
|
383
|
+
})
|
384
|
+
```
|
385
|
+
|
386
|
+
## Import
|
387
|
+
|
388
|
+
AWS Secrets sync destinations can be imported using the `name`, e.g.
|
389
|
+
|
390
|
+
```sh
|
391
|
+
$ pulumi import vault:secrets/syncAwsDestination:SyncAwsDestination aws aws-dest
|
392
|
+
```
|
393
|
+
|
394
|
+
:param str resource_name: The name of the resource.
|
395
|
+
:param SyncAwsDestinationArgs args: The arguments to use to populate this resource's properties.
|
396
|
+
:param pulumi.ResourceOptions opts: Options for the resource.
|
397
|
+
"""
|
398
|
+
...
|
399
|
+
def __init__(__self__, resource_name: str, *args, **kwargs):
|
400
|
+
resource_args, opts = _utilities.get_resource_args_opts(SyncAwsDestinationArgs, pulumi.ResourceOptions, *args, **kwargs)
|
401
|
+
if resource_args is not None:
|
402
|
+
__self__._internal_init(resource_name, opts, **resource_args.__dict__)
|
403
|
+
else:
|
404
|
+
__self__._internal_init(resource_name, *args, **kwargs)
|
405
|
+
|
406
|
+
def _internal_init(__self__,
|
407
|
+
resource_name: str,
|
408
|
+
opts: Optional[pulumi.ResourceOptions] = None,
|
409
|
+
access_key_id: Optional[pulumi.Input[str]] = None,
|
410
|
+
custom_tags: Optional[pulumi.Input[Mapping[str, Any]]] = None,
|
411
|
+
name: Optional[pulumi.Input[str]] = None,
|
412
|
+
namespace: Optional[pulumi.Input[str]] = None,
|
413
|
+
region: Optional[pulumi.Input[str]] = None,
|
414
|
+
secret_access_key: Optional[pulumi.Input[str]] = None,
|
415
|
+
secret_name_template: Optional[pulumi.Input[str]] = None,
|
416
|
+
__props__=None):
|
417
|
+
opts = pulumi.ResourceOptions.merge(_utilities.get_resource_opts_defaults(), opts)
|
418
|
+
if not isinstance(opts, pulumi.ResourceOptions):
|
419
|
+
raise TypeError('Expected resource options to be a ResourceOptions instance')
|
420
|
+
if opts.id is None:
|
421
|
+
if __props__ is not None:
|
422
|
+
raise TypeError('__props__ is only valid when passed in combination with a valid opts.id to get an existing resource')
|
423
|
+
__props__ = SyncAwsDestinationArgs.__new__(SyncAwsDestinationArgs)
|
424
|
+
|
425
|
+
__props__.__dict__["access_key_id"] = access_key_id
|
426
|
+
__props__.__dict__["custom_tags"] = custom_tags
|
427
|
+
__props__.__dict__["name"] = name
|
428
|
+
__props__.__dict__["namespace"] = namespace
|
429
|
+
__props__.__dict__["region"] = region
|
430
|
+
__props__.__dict__["secret_access_key"] = None if secret_access_key is None else pulumi.Output.secret(secret_access_key)
|
431
|
+
__props__.__dict__["secret_name_template"] = secret_name_template
|
432
|
+
__props__.__dict__["type"] = None
|
433
|
+
secret_opts = pulumi.ResourceOptions(additional_secret_outputs=["secretAccessKey"])
|
434
|
+
opts = pulumi.ResourceOptions.merge(opts, secret_opts)
|
435
|
+
super(SyncAwsDestination, __self__).__init__(
|
436
|
+
'vault:secrets/syncAwsDestination:SyncAwsDestination',
|
437
|
+
resource_name,
|
438
|
+
__props__,
|
439
|
+
opts)
|
440
|
+
|
441
|
+
@staticmethod
|
442
|
+
def get(resource_name: str,
|
443
|
+
id: pulumi.Input[str],
|
444
|
+
opts: Optional[pulumi.ResourceOptions] = None,
|
445
|
+
access_key_id: Optional[pulumi.Input[str]] = None,
|
446
|
+
custom_tags: Optional[pulumi.Input[Mapping[str, Any]]] = None,
|
447
|
+
name: Optional[pulumi.Input[str]] = None,
|
448
|
+
namespace: Optional[pulumi.Input[str]] = None,
|
449
|
+
region: Optional[pulumi.Input[str]] = None,
|
450
|
+
secret_access_key: Optional[pulumi.Input[str]] = None,
|
451
|
+
secret_name_template: Optional[pulumi.Input[str]] = None,
|
452
|
+
type: Optional[pulumi.Input[str]] = None) -> 'SyncAwsDestination':
|
453
|
+
"""
|
454
|
+
Get an existing SyncAwsDestination resource's state with the given name, id, and optional extra
|
455
|
+
properties used to qualify the lookup.
|
456
|
+
|
457
|
+
:param str resource_name: The unique name of the resulting resource.
|
458
|
+
:param pulumi.Input[str] id: The unique provider ID of the resource to lookup.
|
459
|
+
:param pulumi.ResourceOptions opts: Options for the resource.
|
460
|
+
:param pulumi.Input[str] access_key_id: Access key id to authenticate against the AWS secrets manager.
|
461
|
+
Can be omitted and directly provided to Vault using the `AWS_ACCESS_KEY_ID` environment
|
462
|
+
variable.
|
463
|
+
:param pulumi.Input[Mapping[str, Any]] custom_tags: Custom tags to set on the secret managed at the destination.
|
464
|
+
:param pulumi.Input[str] name: Unique name of the AWS destination.
|
465
|
+
:param pulumi.Input[str] namespace: The namespace to provision the resource in.
|
466
|
+
The value should not contain leading or trailing forward slashes.
|
467
|
+
The `namespace` is always relative to the provider's configured [namespace](https://www.terraform.io/docs/providers/vault#namespace).
|
468
|
+
:param pulumi.Input[str] region: Region where to manage the secrets manager entries.
|
469
|
+
Can be omitted and directly provided to Vault using the `AWS_REGION` environment
|
470
|
+
variable.
|
471
|
+
:param pulumi.Input[str] secret_access_key: Secret access key to authenticate against the AWS secrets manager.
|
472
|
+
Can be omitted and directly provided to Vault using the `AWS_SECRET_ACCESS_KEY` environment
|
473
|
+
variable.
|
474
|
+
:param pulumi.Input[str] secret_name_template: Template describing how to generate external secret names.
|
475
|
+
Supports a subset of the Go Template syntax.
|
476
|
+
:param pulumi.Input[str] type: The type of the secrets destination (`aws-sm`).
|
477
|
+
"""
|
478
|
+
opts = pulumi.ResourceOptions.merge(opts, pulumi.ResourceOptions(id=id))
|
479
|
+
|
480
|
+
__props__ = _SyncAwsDestinationState.__new__(_SyncAwsDestinationState)
|
481
|
+
|
482
|
+
__props__.__dict__["access_key_id"] = access_key_id
|
483
|
+
__props__.__dict__["custom_tags"] = custom_tags
|
484
|
+
__props__.__dict__["name"] = name
|
485
|
+
__props__.__dict__["namespace"] = namespace
|
486
|
+
__props__.__dict__["region"] = region
|
487
|
+
__props__.__dict__["secret_access_key"] = secret_access_key
|
488
|
+
__props__.__dict__["secret_name_template"] = secret_name_template
|
489
|
+
__props__.__dict__["type"] = type
|
490
|
+
return SyncAwsDestination(resource_name, opts=opts, __props__=__props__)
|
491
|
+
|
492
|
+
@property
|
493
|
+
@pulumi.getter(name="accessKeyId")
|
494
|
+
def access_key_id(self) -> pulumi.Output[Optional[str]]:
|
495
|
+
"""
|
496
|
+
Access key id to authenticate against the AWS secrets manager.
|
497
|
+
Can be omitted and directly provided to Vault using the `AWS_ACCESS_KEY_ID` environment
|
498
|
+
variable.
|
499
|
+
"""
|
500
|
+
return pulumi.get(self, "access_key_id")
|
501
|
+
|
502
|
+
@property
|
503
|
+
@pulumi.getter(name="customTags")
|
504
|
+
def custom_tags(self) -> pulumi.Output[Optional[Mapping[str, Any]]]:
|
505
|
+
"""
|
506
|
+
Custom tags to set on the secret managed at the destination.
|
507
|
+
"""
|
508
|
+
return pulumi.get(self, "custom_tags")
|
509
|
+
|
510
|
+
@property
|
511
|
+
@pulumi.getter
|
512
|
+
def name(self) -> pulumi.Output[str]:
|
513
|
+
"""
|
514
|
+
Unique name of the AWS destination.
|
515
|
+
"""
|
516
|
+
return pulumi.get(self, "name")
|
517
|
+
|
518
|
+
@property
|
519
|
+
@pulumi.getter
|
520
|
+
def namespace(self) -> pulumi.Output[Optional[str]]:
|
521
|
+
"""
|
522
|
+
The namespace to provision the resource in.
|
523
|
+
The value should not contain leading or trailing forward slashes.
|
524
|
+
The `namespace` is always relative to the provider's configured [namespace](https://www.terraform.io/docs/providers/vault#namespace).
|
525
|
+
"""
|
526
|
+
return pulumi.get(self, "namespace")
|
527
|
+
|
528
|
+
@property
|
529
|
+
@pulumi.getter
|
530
|
+
def region(self) -> pulumi.Output[Optional[str]]:
|
531
|
+
"""
|
532
|
+
Region where to manage the secrets manager entries.
|
533
|
+
Can be omitted and directly provided to Vault using the `AWS_REGION` environment
|
534
|
+
variable.
|
535
|
+
"""
|
536
|
+
return pulumi.get(self, "region")
|
537
|
+
|
538
|
+
@property
|
539
|
+
@pulumi.getter(name="secretAccessKey")
|
540
|
+
def secret_access_key(self) -> pulumi.Output[Optional[str]]:
|
541
|
+
"""
|
542
|
+
Secret access key to authenticate against the AWS secrets manager.
|
543
|
+
Can be omitted and directly provided to Vault using the `AWS_SECRET_ACCESS_KEY` environment
|
544
|
+
variable.
|
545
|
+
"""
|
546
|
+
return pulumi.get(self, "secret_access_key")
|
547
|
+
|
548
|
+
@property
|
549
|
+
@pulumi.getter(name="secretNameTemplate")
|
550
|
+
def secret_name_template(self) -> pulumi.Output[str]:
|
551
|
+
"""
|
552
|
+
Template describing how to generate external secret names.
|
553
|
+
Supports a subset of the Go Template syntax.
|
554
|
+
"""
|
555
|
+
return pulumi.get(self, "secret_name_template")
|
556
|
+
|
557
|
+
@property
|
558
|
+
@pulumi.getter
|
559
|
+
def type(self) -> pulumi.Output[str]:
|
560
|
+
"""
|
561
|
+
The type of the secrets destination (`aws-sm`).
|
562
|
+
"""
|
563
|
+
return pulumi.get(self, "type")
|
564
|
+
|