pulumi-vault 7.6.0a1764657486__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 +1399 -0
- pulumi_vault/_inputs.py +2701 -0
- pulumi_vault/_utilities.py +331 -0
- pulumi_vault/ad/__init__.py +12 -0
- pulumi_vault/ad/get_access_credentials.py +177 -0
- pulumi_vault/ad/secret_backend.py +1916 -0
- pulumi_vault/ad/secret_library.py +546 -0
- pulumi_vault/ad/secret_role.py +499 -0
- pulumi_vault/alicloud/__init__.py +9 -0
- pulumi_vault/alicloud/auth_backend_role.py +866 -0
- pulumi_vault/approle/__init__.py +12 -0
- pulumi_vault/approle/auth_backend_login.py +571 -0
- pulumi_vault/approle/auth_backend_role.py +1082 -0
- pulumi_vault/approle/auth_backend_role_secret_id.py +796 -0
- pulumi_vault/approle/get_auth_backend_role_id.py +169 -0
- pulumi_vault/audit.py +499 -0
- pulumi_vault/audit_request_header.py +277 -0
- pulumi_vault/auth_backend.py +565 -0
- pulumi_vault/aws/__init__.py +22 -0
- pulumi_vault/aws/auth_backend_cert.py +420 -0
- pulumi_vault/aws/auth_backend_client.py +1259 -0
- pulumi_vault/aws/auth_backend_config_identity.py +494 -0
- pulumi_vault/aws/auth_backend_identity_whitelist.py +380 -0
- pulumi_vault/aws/auth_backend_login.py +1046 -0
- pulumi_vault/aws/auth_backend_role.py +1961 -0
- pulumi_vault/aws/auth_backend_role_tag.py +638 -0
- pulumi_vault/aws/auth_backend_roletag_blacklist.py +366 -0
- pulumi_vault/aws/auth_backend_sts_role.py +414 -0
- pulumi_vault/aws/get_access_credentials.py +369 -0
- pulumi_vault/aws/get_static_access_credentials.py +137 -0
- pulumi_vault/aws/secret_backend.py +2018 -0
- pulumi_vault/aws/secret_backend_role.py +1188 -0
- pulumi_vault/aws/secret_backend_static_role.py +639 -0
- pulumi_vault/azure/__init__.py +15 -0
- pulumi_vault/azure/_inputs.py +108 -0
- pulumi_vault/azure/auth_backend_config.py +1096 -0
- pulumi_vault/azure/auth_backend_role.py +1176 -0
- pulumi_vault/azure/backend.py +1793 -0
- pulumi_vault/azure/backend_role.py +883 -0
- pulumi_vault/azure/get_access_credentials.py +400 -0
- pulumi_vault/azure/outputs.py +107 -0
- pulumi_vault/cert_auth_backend_role.py +1539 -0
- pulumi_vault/config/__init__.py +9 -0
- pulumi_vault/config/__init__.pyi +164 -0
- pulumi_vault/config/_inputs.py +73 -0
- pulumi_vault/config/outputs.py +1225 -0
- pulumi_vault/config/ui_custom_message.py +530 -0
- pulumi_vault/config/vars.py +230 -0
- pulumi_vault/consul/__init__.py +10 -0
- pulumi_vault/consul/secret_backend.py +1517 -0
- pulumi_vault/consul/secret_backend_role.py +847 -0
- pulumi_vault/database/__init__.py +14 -0
- pulumi_vault/database/_inputs.py +11907 -0
- pulumi_vault/database/outputs.py +8496 -0
- pulumi_vault/database/secret_backend_connection.py +1676 -0
- pulumi_vault/database/secret_backend_role.py +840 -0
- pulumi_vault/database/secret_backend_static_role.py +881 -0
- pulumi_vault/database/secrets_mount.py +2160 -0
- pulumi_vault/egp_policy.py +399 -0
- pulumi_vault/gcp/__init__.py +17 -0
- pulumi_vault/gcp/_inputs.py +441 -0
- pulumi_vault/gcp/auth_backend.py +1486 -0
- pulumi_vault/gcp/auth_backend_role.py +1235 -0
- pulumi_vault/gcp/get_auth_backend_role.py +514 -0
- pulumi_vault/gcp/outputs.py +302 -0
- pulumi_vault/gcp/secret_backend.py +1807 -0
- pulumi_vault/gcp/secret_impersonated_account.py +484 -0
- pulumi_vault/gcp/secret_roleset.py +554 -0
- pulumi_vault/gcp/secret_static_account.py +557 -0
- pulumi_vault/generic/__init__.py +11 -0
- pulumi_vault/generic/endpoint.py +786 -0
- pulumi_vault/generic/get_secret.py +306 -0
- pulumi_vault/generic/secret.py +486 -0
- pulumi_vault/get_auth_backend.py +226 -0
- pulumi_vault/get_auth_backends.py +170 -0
- pulumi_vault/get_namespace.py +226 -0
- pulumi_vault/get_namespaces.py +202 -0
- pulumi_vault/get_nomad_access_token.py +210 -0
- pulumi_vault/get_policy_document.py +160 -0
- pulumi_vault/get_raft_autopilot_state.py +267 -0
- pulumi_vault/github/__init__.py +13 -0
- pulumi_vault/github/_inputs.py +225 -0
- pulumi_vault/github/auth_backend.py +1194 -0
- pulumi_vault/github/outputs.py +174 -0
- pulumi_vault/github/team.py +380 -0
- pulumi_vault/github/user.py +380 -0
- pulumi_vault/identity/__init__.py +35 -0
- pulumi_vault/identity/entity.py +447 -0
- pulumi_vault/identity/entity_alias.py +398 -0
- pulumi_vault/identity/entity_policies.py +455 -0
- pulumi_vault/identity/get_entity.py +384 -0
- pulumi_vault/identity/get_group.py +467 -0
- pulumi_vault/identity/get_oidc_client_creds.py +175 -0
- pulumi_vault/identity/get_oidc_openid_config.py +334 -0
- pulumi_vault/identity/get_oidc_public_keys.py +179 -0
- pulumi_vault/identity/group.py +805 -0
- pulumi_vault/identity/group_alias.py +386 -0
- pulumi_vault/identity/group_member_entity_ids.py +444 -0
- pulumi_vault/identity/group_member_group_ids.py +467 -0
- pulumi_vault/identity/group_policies.py +471 -0
- pulumi_vault/identity/mfa_duo.py +674 -0
- pulumi_vault/identity/mfa_login_enforcement.py +566 -0
- pulumi_vault/identity/mfa_okta.py +626 -0
- pulumi_vault/identity/mfa_pingid.py +616 -0
- pulumi_vault/identity/mfa_totp.py +758 -0
- pulumi_vault/identity/oidc.py +268 -0
- pulumi_vault/identity/oidc_assignment.py +375 -0
- pulumi_vault/identity/oidc_client.py +667 -0
- pulumi_vault/identity/oidc_key.py +474 -0
- pulumi_vault/identity/oidc_key_allowed_client_id.py +298 -0
- pulumi_vault/identity/oidc_provider.py +550 -0
- pulumi_vault/identity/oidc_role.py +543 -0
- pulumi_vault/identity/oidc_scope.py +355 -0
- pulumi_vault/identity/outputs.py +137 -0
- pulumi_vault/jwt/__init__.py +12 -0
- pulumi_vault/jwt/_inputs.py +225 -0
- pulumi_vault/jwt/auth_backend.py +1347 -0
- pulumi_vault/jwt/auth_backend_role.py +1847 -0
- pulumi_vault/jwt/outputs.py +174 -0
- pulumi_vault/kmip/__init__.py +11 -0
- pulumi_vault/kmip/secret_backend.py +1591 -0
- pulumi_vault/kmip/secret_role.py +1194 -0
- pulumi_vault/kmip/secret_scope.py +372 -0
- pulumi_vault/kubernetes/__init__.py +15 -0
- pulumi_vault/kubernetes/auth_backend_config.py +654 -0
- pulumi_vault/kubernetes/auth_backend_role.py +1031 -0
- pulumi_vault/kubernetes/get_auth_backend_config.py +280 -0
- pulumi_vault/kubernetes/get_auth_backend_role.py +470 -0
- pulumi_vault/kubernetes/get_service_account_token.py +344 -0
- pulumi_vault/kubernetes/secret_backend.py +1341 -0
- pulumi_vault/kubernetes/secret_backend_role.py +1140 -0
- pulumi_vault/kv/__init__.py +18 -0
- pulumi_vault/kv/_inputs.py +124 -0
- pulumi_vault/kv/get_secret.py +240 -0
- pulumi_vault/kv/get_secret_subkeys_v2.py +275 -0
- pulumi_vault/kv/get_secret_v2.py +315 -0
- pulumi_vault/kv/get_secrets_list.py +186 -0
- pulumi_vault/kv/get_secrets_list_v2.py +243 -0
- pulumi_vault/kv/outputs.py +102 -0
- pulumi_vault/kv/secret.py +397 -0
- pulumi_vault/kv/secret_backend_v2.py +455 -0
- pulumi_vault/kv/secret_v2.py +970 -0
- pulumi_vault/ldap/__init__.py +19 -0
- pulumi_vault/ldap/_inputs.py +225 -0
- pulumi_vault/ldap/auth_backend.py +2520 -0
- pulumi_vault/ldap/auth_backend_group.py +386 -0
- pulumi_vault/ldap/auth_backend_user.py +439 -0
- pulumi_vault/ldap/get_dynamic_credentials.py +181 -0
- pulumi_vault/ldap/get_static_credentials.py +192 -0
- pulumi_vault/ldap/outputs.py +174 -0
- pulumi_vault/ldap/secret_backend.py +2207 -0
- pulumi_vault/ldap/secret_backend_dynamic_role.py +767 -0
- pulumi_vault/ldap/secret_backend_library_set.py +552 -0
- pulumi_vault/ldap/secret_backend_static_role.py +541 -0
- pulumi_vault/managed/__init__.py +11 -0
- pulumi_vault/managed/_inputs.py +944 -0
- pulumi_vault/managed/keys.py +398 -0
- pulumi_vault/managed/outputs.py +667 -0
- pulumi_vault/mfa_duo.py +589 -0
- pulumi_vault/mfa_okta.py +623 -0
- pulumi_vault/mfa_pingid.py +670 -0
- pulumi_vault/mfa_totp.py +620 -0
- pulumi_vault/mongodbatlas/__init__.py +10 -0
- pulumi_vault/mongodbatlas/secret_backend.py +388 -0
- pulumi_vault/mongodbatlas/secret_role.py +726 -0
- pulumi_vault/mount.py +1262 -0
- pulumi_vault/namespace.py +452 -0
- pulumi_vault/nomad_secret_backend.py +1559 -0
- pulumi_vault/nomad_secret_role.py +489 -0
- pulumi_vault/oci_auth_backend.py +676 -0
- pulumi_vault/oci_auth_backend_role.py +852 -0
- pulumi_vault/okta/__init__.py +13 -0
- pulumi_vault/okta/_inputs.py +320 -0
- pulumi_vault/okta/auth_backend.py +1231 -0
- pulumi_vault/okta/auth_backend_group.py +369 -0
- pulumi_vault/okta/auth_backend_user.py +416 -0
- pulumi_vault/okta/outputs.py +244 -0
- pulumi_vault/outputs.py +502 -0
- pulumi_vault/pkisecret/__init__.py +38 -0
- pulumi_vault/pkisecret/_inputs.py +270 -0
- pulumi_vault/pkisecret/backend_acme_eab.py +550 -0
- pulumi_vault/pkisecret/backend_config_acme.py +690 -0
- pulumi_vault/pkisecret/backend_config_auto_tidy.py +1370 -0
- pulumi_vault/pkisecret/backend_config_cluster.py +370 -0
- pulumi_vault/pkisecret/backend_config_cmpv2.py +693 -0
- pulumi_vault/pkisecret/backend_config_est.py +756 -0
- pulumi_vault/pkisecret/backend_config_scep.py +738 -0
- pulumi_vault/pkisecret/get_backend_cert_metadata.py +277 -0
- pulumi_vault/pkisecret/get_backend_config_cmpv2.py +226 -0
- pulumi_vault/pkisecret/get_backend_config_est.py +251 -0
- pulumi_vault/pkisecret/get_backend_config_scep.py +271 -0
- pulumi_vault/pkisecret/get_backend_issuer.py +395 -0
- pulumi_vault/pkisecret/get_backend_issuers.py +192 -0
- pulumi_vault/pkisecret/get_backend_key.py +211 -0
- pulumi_vault/pkisecret/get_backend_keys.py +192 -0
- pulumi_vault/pkisecret/outputs.py +270 -0
- pulumi_vault/pkisecret/secret_backend_cert.py +1315 -0
- pulumi_vault/pkisecret/secret_backend_config_ca.py +386 -0
- pulumi_vault/pkisecret/secret_backend_config_issuers.py +392 -0
- pulumi_vault/pkisecret/secret_backend_config_urls.py +462 -0
- pulumi_vault/pkisecret/secret_backend_crl_config.py +846 -0
- pulumi_vault/pkisecret/secret_backend_intermediate_cert_request.py +1629 -0
- pulumi_vault/pkisecret/secret_backend_intermediate_set_signed.py +444 -0
- pulumi_vault/pkisecret/secret_backend_issuer.py +1089 -0
- pulumi_vault/pkisecret/secret_backend_key.py +613 -0
- pulumi_vault/pkisecret/secret_backend_role.py +2694 -0
- pulumi_vault/pkisecret/secret_backend_root_cert.py +2134 -0
- pulumi_vault/pkisecret/secret_backend_root_sign_intermediate.py +2031 -0
- pulumi_vault/pkisecret/secret_backend_sign.py +1194 -0
- pulumi_vault/plugin.py +596 -0
- pulumi_vault/plugin_pinned_version.py +299 -0
- pulumi_vault/policy.py +279 -0
- pulumi_vault/provider.py +781 -0
- pulumi_vault/pulumi-plugin.json +5 -0
- pulumi_vault/py.typed +0 -0
- pulumi_vault/quota_lease_count.py +504 -0
- pulumi_vault/quota_rate_limit.py +751 -0
- pulumi_vault/rabbitmq/__init__.py +12 -0
- pulumi_vault/rabbitmq/_inputs.py +235 -0
- pulumi_vault/rabbitmq/outputs.py +144 -0
- pulumi_vault/rabbitmq/secret_backend.py +1437 -0
- pulumi_vault/rabbitmq/secret_backend_role.py +496 -0
- pulumi_vault/raft_autopilot.py +609 -0
- pulumi_vault/raft_snapshot_agent_config.py +1591 -0
- pulumi_vault/rgp_policy.py +349 -0
- pulumi_vault/saml/__init__.py +12 -0
- pulumi_vault/saml/_inputs.py +225 -0
- pulumi_vault/saml/auth_backend.py +811 -0
- pulumi_vault/saml/auth_backend_role.py +1068 -0
- pulumi_vault/saml/outputs.py +174 -0
- pulumi_vault/scep_auth_backend_role.py +908 -0
- pulumi_vault/secrets/__init__.py +18 -0
- pulumi_vault/secrets/_inputs.py +110 -0
- pulumi_vault/secrets/outputs.py +94 -0
- pulumi_vault/secrets/sync_association.py +450 -0
- pulumi_vault/secrets/sync_aws_destination.py +780 -0
- pulumi_vault/secrets/sync_azure_destination.py +736 -0
- pulumi_vault/secrets/sync_config.py +303 -0
- pulumi_vault/secrets/sync_gcp_destination.py +572 -0
- pulumi_vault/secrets/sync_gh_destination.py +688 -0
- pulumi_vault/secrets/sync_github_apps.py +376 -0
- pulumi_vault/secrets/sync_vercel_destination.py +603 -0
- pulumi_vault/ssh/__init__.py +13 -0
- pulumi_vault/ssh/_inputs.py +76 -0
- pulumi_vault/ssh/get_secret_backend_sign.py +294 -0
- pulumi_vault/ssh/outputs.py +51 -0
- pulumi_vault/ssh/secret_backend_ca.py +588 -0
- pulumi_vault/ssh/secret_backend_role.py +1493 -0
- pulumi_vault/terraformcloud/__init__.py +11 -0
- pulumi_vault/terraformcloud/secret_backend.py +1321 -0
- pulumi_vault/terraformcloud/secret_creds.py +445 -0
- pulumi_vault/terraformcloud/secret_role.py +563 -0
- pulumi_vault/token.py +1026 -0
- pulumi_vault/tokenauth/__init__.py +9 -0
- pulumi_vault/tokenauth/auth_backend_role.py +1135 -0
- pulumi_vault/transform/__init__.py +14 -0
- pulumi_vault/transform/alphabet.py +348 -0
- pulumi_vault/transform/get_decode.py +287 -0
- pulumi_vault/transform/get_encode.py +291 -0
- pulumi_vault/transform/role.py +350 -0
- pulumi_vault/transform/template.py +592 -0
- pulumi_vault/transform/transformation.py +608 -0
- pulumi_vault/transit/__init__.py +15 -0
- pulumi_vault/transit/get_cmac.py +256 -0
- pulumi_vault/transit/get_decrypt.py +181 -0
- pulumi_vault/transit/get_encrypt.py +174 -0
- pulumi_vault/transit/get_sign.py +328 -0
- pulumi_vault/transit/get_verify.py +373 -0
- pulumi_vault/transit/secret_backend_key.py +1202 -0
- pulumi_vault/transit/secret_cache_config.py +302 -0
- pulumi_vault-7.6.0a1764657486.dist-info/METADATA +92 -0
- pulumi_vault-7.6.0a1764657486.dist-info/RECORD +274 -0
- pulumi_vault-7.6.0a1764657486.dist-info/WHEEL +5 -0
- pulumi_vault-7.6.0a1764657486.dist-info/top_level.txt +1 -0
|
@@ -0,0 +1,18 @@
|
|
|
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
|
+
from .. import _utilities
|
|
7
|
+
import typing
|
|
8
|
+
# Export this package's modules as members:
|
|
9
|
+
from .sync_association import *
|
|
10
|
+
from .sync_aws_destination import *
|
|
11
|
+
from .sync_azure_destination import *
|
|
12
|
+
from .sync_config import *
|
|
13
|
+
from .sync_gcp_destination import *
|
|
14
|
+
from .sync_gh_destination import *
|
|
15
|
+
from .sync_github_apps import *
|
|
16
|
+
from .sync_vercel_destination import *
|
|
17
|
+
from ._inputs import *
|
|
18
|
+
from . import outputs
|
|
@@ -0,0 +1,110 @@
|
|
|
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
|
+
|
|
17
|
+
__all__ = [
|
|
18
|
+
'SyncAssociationMetadataArgs',
|
|
19
|
+
'SyncAssociationMetadataArgsDict',
|
|
20
|
+
]
|
|
21
|
+
|
|
22
|
+
MYPY = False
|
|
23
|
+
|
|
24
|
+
if not MYPY:
|
|
25
|
+
class SyncAssociationMetadataArgsDict(TypedDict):
|
|
26
|
+
sub_key: NotRequired[pulumi.Input[_builtins.str]]
|
|
27
|
+
"""
|
|
28
|
+
Subkey of the associated secret.
|
|
29
|
+
"""
|
|
30
|
+
sync_status: NotRequired[pulumi.Input[_builtins.str]]
|
|
31
|
+
"""
|
|
32
|
+
A map of sync statuses for each subkey of the associated secret
|
|
33
|
+
(for ex. `{kv_624bea/aws-token/dev: "SYNCED", kv_624bea/aws-token/prod: "SYNCED"}`).
|
|
34
|
+
"""
|
|
35
|
+
updated_at: NotRequired[pulumi.Input[_builtins.str]]
|
|
36
|
+
"""
|
|
37
|
+
A map of duration strings specifying when each subkey of the associated
|
|
38
|
+
secret was last updated.
|
|
39
|
+
(for ex.
|
|
40
|
+
`{kv_624bea/aws-token/dev: "2024-03-21T12:42:02.558533-07:00",
|
|
41
|
+
kv_624bea/aws-token/prod: "2024-03-21T12:42:02.558533-07:00"}`).
|
|
42
|
+
"""
|
|
43
|
+
elif False:
|
|
44
|
+
SyncAssociationMetadataArgsDict: TypeAlias = Mapping[str, Any]
|
|
45
|
+
|
|
46
|
+
@pulumi.input_type
|
|
47
|
+
class SyncAssociationMetadataArgs:
|
|
48
|
+
def __init__(__self__, *,
|
|
49
|
+
sub_key: Optional[pulumi.Input[_builtins.str]] = None,
|
|
50
|
+
sync_status: Optional[pulumi.Input[_builtins.str]] = None,
|
|
51
|
+
updated_at: Optional[pulumi.Input[_builtins.str]] = None):
|
|
52
|
+
"""
|
|
53
|
+
:param pulumi.Input[_builtins.str] sub_key: Subkey of the associated secret.
|
|
54
|
+
:param pulumi.Input[_builtins.str] sync_status: A map of sync statuses for each subkey of the associated secret
|
|
55
|
+
(for ex. `{kv_624bea/aws-token/dev: "SYNCED", kv_624bea/aws-token/prod: "SYNCED"}`).
|
|
56
|
+
:param pulumi.Input[_builtins.str] updated_at: A map of duration strings specifying when each subkey of the associated
|
|
57
|
+
secret was last updated.
|
|
58
|
+
(for ex.
|
|
59
|
+
`{kv_624bea/aws-token/dev: "2024-03-21T12:42:02.558533-07:00",
|
|
60
|
+
kv_624bea/aws-token/prod: "2024-03-21T12:42:02.558533-07:00"}`).
|
|
61
|
+
"""
|
|
62
|
+
if sub_key is not None:
|
|
63
|
+
pulumi.set(__self__, "sub_key", sub_key)
|
|
64
|
+
if sync_status is not None:
|
|
65
|
+
pulumi.set(__self__, "sync_status", sync_status)
|
|
66
|
+
if updated_at is not None:
|
|
67
|
+
pulumi.set(__self__, "updated_at", updated_at)
|
|
68
|
+
|
|
69
|
+
@_builtins.property
|
|
70
|
+
@pulumi.getter(name="subKey")
|
|
71
|
+
def sub_key(self) -> Optional[pulumi.Input[_builtins.str]]:
|
|
72
|
+
"""
|
|
73
|
+
Subkey of the associated secret.
|
|
74
|
+
"""
|
|
75
|
+
return pulumi.get(self, "sub_key")
|
|
76
|
+
|
|
77
|
+
@sub_key.setter
|
|
78
|
+
def sub_key(self, value: Optional[pulumi.Input[_builtins.str]]):
|
|
79
|
+
pulumi.set(self, "sub_key", value)
|
|
80
|
+
|
|
81
|
+
@_builtins.property
|
|
82
|
+
@pulumi.getter(name="syncStatus")
|
|
83
|
+
def sync_status(self) -> Optional[pulumi.Input[_builtins.str]]:
|
|
84
|
+
"""
|
|
85
|
+
A map of sync statuses for each subkey of the associated secret
|
|
86
|
+
(for ex. `{kv_624bea/aws-token/dev: "SYNCED", kv_624bea/aws-token/prod: "SYNCED"}`).
|
|
87
|
+
"""
|
|
88
|
+
return pulumi.get(self, "sync_status")
|
|
89
|
+
|
|
90
|
+
@sync_status.setter
|
|
91
|
+
def sync_status(self, value: Optional[pulumi.Input[_builtins.str]]):
|
|
92
|
+
pulumi.set(self, "sync_status", value)
|
|
93
|
+
|
|
94
|
+
@_builtins.property
|
|
95
|
+
@pulumi.getter(name="updatedAt")
|
|
96
|
+
def updated_at(self) -> Optional[pulumi.Input[_builtins.str]]:
|
|
97
|
+
"""
|
|
98
|
+
A map of duration strings specifying when each subkey of the associated
|
|
99
|
+
secret was last updated.
|
|
100
|
+
(for ex.
|
|
101
|
+
`{kv_624bea/aws-token/dev: "2024-03-21T12:42:02.558533-07:00",
|
|
102
|
+
kv_624bea/aws-token/prod: "2024-03-21T12:42:02.558533-07:00"}`).
|
|
103
|
+
"""
|
|
104
|
+
return pulumi.get(self, "updated_at")
|
|
105
|
+
|
|
106
|
+
@updated_at.setter
|
|
107
|
+
def updated_at(self, value: Optional[pulumi.Input[_builtins.str]]):
|
|
108
|
+
pulumi.set(self, "updated_at", value)
|
|
109
|
+
|
|
110
|
+
|
|
@@ -0,0 +1,94 @@
|
|
|
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
|
+
|
|
17
|
+
__all__ = [
|
|
18
|
+
'SyncAssociationMetadata',
|
|
19
|
+
]
|
|
20
|
+
|
|
21
|
+
@pulumi.output_type
|
|
22
|
+
class SyncAssociationMetadata(dict):
|
|
23
|
+
@staticmethod
|
|
24
|
+
def __key_warning(key: str):
|
|
25
|
+
suggest = None
|
|
26
|
+
if key == "subKey":
|
|
27
|
+
suggest = "sub_key"
|
|
28
|
+
elif key == "syncStatus":
|
|
29
|
+
suggest = "sync_status"
|
|
30
|
+
elif key == "updatedAt":
|
|
31
|
+
suggest = "updated_at"
|
|
32
|
+
|
|
33
|
+
if suggest:
|
|
34
|
+
pulumi.log.warn(f"Key '{key}' not found in SyncAssociationMetadata. Access the value via the '{suggest}' property getter instead.")
|
|
35
|
+
|
|
36
|
+
def __getitem__(self, key: str) -> Any:
|
|
37
|
+
SyncAssociationMetadata.__key_warning(key)
|
|
38
|
+
return super().__getitem__(key)
|
|
39
|
+
|
|
40
|
+
def get(self, key: str, default = None) -> Any:
|
|
41
|
+
SyncAssociationMetadata.__key_warning(key)
|
|
42
|
+
return super().get(key, default)
|
|
43
|
+
|
|
44
|
+
def __init__(__self__, *,
|
|
45
|
+
sub_key: Optional[_builtins.str] = None,
|
|
46
|
+
sync_status: Optional[_builtins.str] = None,
|
|
47
|
+
updated_at: Optional[_builtins.str] = None):
|
|
48
|
+
"""
|
|
49
|
+
:param _builtins.str sub_key: Subkey of the associated secret.
|
|
50
|
+
:param _builtins.str sync_status: A map of sync statuses for each subkey of the associated secret
|
|
51
|
+
(for ex. `{kv_624bea/aws-token/dev: "SYNCED", kv_624bea/aws-token/prod: "SYNCED"}`).
|
|
52
|
+
:param _builtins.str updated_at: A map of duration strings specifying when each subkey of the associated
|
|
53
|
+
secret was last updated.
|
|
54
|
+
(for ex.
|
|
55
|
+
`{kv_624bea/aws-token/dev: "2024-03-21T12:42:02.558533-07:00",
|
|
56
|
+
kv_624bea/aws-token/prod: "2024-03-21T12:42:02.558533-07:00"}`).
|
|
57
|
+
"""
|
|
58
|
+
if sub_key is not None:
|
|
59
|
+
pulumi.set(__self__, "sub_key", sub_key)
|
|
60
|
+
if sync_status is not None:
|
|
61
|
+
pulumi.set(__self__, "sync_status", sync_status)
|
|
62
|
+
if updated_at is not None:
|
|
63
|
+
pulumi.set(__self__, "updated_at", updated_at)
|
|
64
|
+
|
|
65
|
+
@_builtins.property
|
|
66
|
+
@pulumi.getter(name="subKey")
|
|
67
|
+
def sub_key(self) -> Optional[_builtins.str]:
|
|
68
|
+
"""
|
|
69
|
+
Subkey of the associated secret.
|
|
70
|
+
"""
|
|
71
|
+
return pulumi.get(self, "sub_key")
|
|
72
|
+
|
|
73
|
+
@_builtins.property
|
|
74
|
+
@pulumi.getter(name="syncStatus")
|
|
75
|
+
def sync_status(self) -> Optional[_builtins.str]:
|
|
76
|
+
"""
|
|
77
|
+
A map of sync statuses for each subkey of the associated secret
|
|
78
|
+
(for ex. `{kv_624bea/aws-token/dev: "SYNCED", kv_624bea/aws-token/prod: "SYNCED"}`).
|
|
79
|
+
"""
|
|
80
|
+
return pulumi.get(self, "sync_status")
|
|
81
|
+
|
|
82
|
+
@_builtins.property
|
|
83
|
+
@pulumi.getter(name="updatedAt")
|
|
84
|
+
def updated_at(self) -> Optional[_builtins.str]:
|
|
85
|
+
"""
|
|
86
|
+
A map of duration strings specifying when each subkey of the associated
|
|
87
|
+
secret was last updated.
|
|
88
|
+
(for ex.
|
|
89
|
+
`{kv_624bea/aws-token/dev: "2024-03-21T12:42:02.558533-07:00",
|
|
90
|
+
kv_624bea/aws-token/prod: "2024-03-21T12:42:02.558533-07:00"}`).
|
|
91
|
+
"""
|
|
92
|
+
return pulumi.get(self, "updated_at")
|
|
93
|
+
|
|
94
|
+
|
|
@@ -0,0 +1,450 @@
|
|
|
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__ = ['SyncAssociationArgs', 'SyncAssociation']
|
|
20
|
+
|
|
21
|
+
@pulumi.input_type
|
|
22
|
+
class SyncAssociationArgs:
|
|
23
|
+
def __init__(__self__, *,
|
|
24
|
+
mount: pulumi.Input[_builtins.str],
|
|
25
|
+
secret_name: pulumi.Input[_builtins.str],
|
|
26
|
+
type: pulumi.Input[_builtins.str],
|
|
27
|
+
name: Optional[pulumi.Input[_builtins.str]] = None,
|
|
28
|
+
namespace: Optional[pulumi.Input[_builtins.str]] = None):
|
|
29
|
+
"""
|
|
30
|
+
The set of arguments for constructing a SyncAssociation resource.
|
|
31
|
+
:param pulumi.Input[_builtins.str] mount: Specifies the mount where the secret is located.
|
|
32
|
+
:param pulumi.Input[_builtins.str] secret_name: Specifies the name of the secret to synchronize.
|
|
33
|
+
:param pulumi.Input[_builtins.str] type: Specifies the destination type.
|
|
34
|
+
:param pulumi.Input[_builtins.str] name: Specifies the name of the destination.
|
|
35
|
+
:param pulumi.Input[_builtins.str] namespace: The namespace to provision the resource in.
|
|
36
|
+
The value should not contain leading or trailing forward slashes.
|
|
37
|
+
The `namespace` is always relative to the provider's configured [namespace](https://www.terraform.io/docs/providers/vault/index.html#namespace).
|
|
38
|
+
"""
|
|
39
|
+
pulumi.set(__self__, "mount", mount)
|
|
40
|
+
pulumi.set(__self__, "secret_name", secret_name)
|
|
41
|
+
pulumi.set(__self__, "type", type)
|
|
42
|
+
if name is not None:
|
|
43
|
+
pulumi.set(__self__, "name", name)
|
|
44
|
+
if namespace is not None:
|
|
45
|
+
pulumi.set(__self__, "namespace", namespace)
|
|
46
|
+
|
|
47
|
+
@_builtins.property
|
|
48
|
+
@pulumi.getter
|
|
49
|
+
def mount(self) -> pulumi.Input[_builtins.str]:
|
|
50
|
+
"""
|
|
51
|
+
Specifies the mount where the secret is located.
|
|
52
|
+
"""
|
|
53
|
+
return pulumi.get(self, "mount")
|
|
54
|
+
|
|
55
|
+
@mount.setter
|
|
56
|
+
def mount(self, value: pulumi.Input[_builtins.str]):
|
|
57
|
+
pulumi.set(self, "mount", value)
|
|
58
|
+
|
|
59
|
+
@_builtins.property
|
|
60
|
+
@pulumi.getter(name="secretName")
|
|
61
|
+
def secret_name(self) -> pulumi.Input[_builtins.str]:
|
|
62
|
+
"""
|
|
63
|
+
Specifies the name of the secret to synchronize.
|
|
64
|
+
"""
|
|
65
|
+
return pulumi.get(self, "secret_name")
|
|
66
|
+
|
|
67
|
+
@secret_name.setter
|
|
68
|
+
def secret_name(self, value: pulumi.Input[_builtins.str]):
|
|
69
|
+
pulumi.set(self, "secret_name", value)
|
|
70
|
+
|
|
71
|
+
@_builtins.property
|
|
72
|
+
@pulumi.getter
|
|
73
|
+
def type(self) -> pulumi.Input[_builtins.str]:
|
|
74
|
+
"""
|
|
75
|
+
Specifies the destination type.
|
|
76
|
+
"""
|
|
77
|
+
return pulumi.get(self, "type")
|
|
78
|
+
|
|
79
|
+
@type.setter
|
|
80
|
+
def type(self, value: pulumi.Input[_builtins.str]):
|
|
81
|
+
pulumi.set(self, "type", value)
|
|
82
|
+
|
|
83
|
+
@_builtins.property
|
|
84
|
+
@pulumi.getter
|
|
85
|
+
def name(self) -> Optional[pulumi.Input[_builtins.str]]:
|
|
86
|
+
"""
|
|
87
|
+
Specifies the name of the destination.
|
|
88
|
+
"""
|
|
89
|
+
return pulumi.get(self, "name")
|
|
90
|
+
|
|
91
|
+
@name.setter
|
|
92
|
+
def name(self, value: Optional[pulumi.Input[_builtins.str]]):
|
|
93
|
+
pulumi.set(self, "name", value)
|
|
94
|
+
|
|
95
|
+
@_builtins.property
|
|
96
|
+
@pulumi.getter
|
|
97
|
+
def namespace(self) -> Optional[pulumi.Input[_builtins.str]]:
|
|
98
|
+
"""
|
|
99
|
+
The namespace to provision the resource in.
|
|
100
|
+
The value should not contain leading or trailing forward slashes.
|
|
101
|
+
The `namespace` is always relative to the provider's configured [namespace](https://www.terraform.io/docs/providers/vault/index.html#namespace).
|
|
102
|
+
"""
|
|
103
|
+
return pulumi.get(self, "namespace")
|
|
104
|
+
|
|
105
|
+
@namespace.setter
|
|
106
|
+
def namespace(self, value: Optional[pulumi.Input[_builtins.str]]):
|
|
107
|
+
pulumi.set(self, "namespace", value)
|
|
108
|
+
|
|
109
|
+
|
|
110
|
+
@pulumi.input_type
|
|
111
|
+
class _SyncAssociationState:
|
|
112
|
+
def __init__(__self__, *,
|
|
113
|
+
metadatas: Optional[pulumi.Input[Sequence[pulumi.Input['SyncAssociationMetadataArgs']]]] = None,
|
|
114
|
+
mount: Optional[pulumi.Input[_builtins.str]] = None,
|
|
115
|
+
name: Optional[pulumi.Input[_builtins.str]] = None,
|
|
116
|
+
namespace: Optional[pulumi.Input[_builtins.str]] = None,
|
|
117
|
+
secret_name: Optional[pulumi.Input[_builtins.str]] = None,
|
|
118
|
+
type: Optional[pulumi.Input[_builtins.str]] = None):
|
|
119
|
+
"""
|
|
120
|
+
Input properties used for looking up and filtering SyncAssociation resources.
|
|
121
|
+
:param pulumi.Input[Sequence[pulumi.Input['SyncAssociationMetadataArgs']]] metadatas: Metadata for each subkey of the associated secret.
|
|
122
|
+
:param pulumi.Input[_builtins.str] mount: Specifies the mount where the secret is located.
|
|
123
|
+
:param pulumi.Input[_builtins.str] name: Specifies the name of the destination.
|
|
124
|
+
:param pulumi.Input[_builtins.str] namespace: The namespace to provision the resource in.
|
|
125
|
+
The value should not contain leading or trailing forward slashes.
|
|
126
|
+
The `namespace` is always relative to the provider's configured [namespace](https://www.terraform.io/docs/providers/vault/index.html#namespace).
|
|
127
|
+
:param pulumi.Input[_builtins.str] secret_name: Specifies the name of the secret to synchronize.
|
|
128
|
+
:param pulumi.Input[_builtins.str] type: Specifies the destination type.
|
|
129
|
+
"""
|
|
130
|
+
if metadatas is not None:
|
|
131
|
+
pulumi.set(__self__, "metadatas", metadatas)
|
|
132
|
+
if mount is not None:
|
|
133
|
+
pulumi.set(__self__, "mount", mount)
|
|
134
|
+
if name is not None:
|
|
135
|
+
pulumi.set(__self__, "name", name)
|
|
136
|
+
if namespace is not None:
|
|
137
|
+
pulumi.set(__self__, "namespace", namespace)
|
|
138
|
+
if secret_name is not None:
|
|
139
|
+
pulumi.set(__self__, "secret_name", secret_name)
|
|
140
|
+
if type is not None:
|
|
141
|
+
pulumi.set(__self__, "type", type)
|
|
142
|
+
|
|
143
|
+
@_builtins.property
|
|
144
|
+
@pulumi.getter
|
|
145
|
+
def metadatas(self) -> Optional[pulumi.Input[Sequence[pulumi.Input['SyncAssociationMetadataArgs']]]]:
|
|
146
|
+
"""
|
|
147
|
+
Metadata for each subkey of the associated secret.
|
|
148
|
+
"""
|
|
149
|
+
return pulumi.get(self, "metadatas")
|
|
150
|
+
|
|
151
|
+
@metadatas.setter
|
|
152
|
+
def metadatas(self, value: Optional[pulumi.Input[Sequence[pulumi.Input['SyncAssociationMetadataArgs']]]]):
|
|
153
|
+
pulumi.set(self, "metadatas", value)
|
|
154
|
+
|
|
155
|
+
@_builtins.property
|
|
156
|
+
@pulumi.getter
|
|
157
|
+
def mount(self) -> Optional[pulumi.Input[_builtins.str]]:
|
|
158
|
+
"""
|
|
159
|
+
Specifies the mount where the secret is located.
|
|
160
|
+
"""
|
|
161
|
+
return pulumi.get(self, "mount")
|
|
162
|
+
|
|
163
|
+
@mount.setter
|
|
164
|
+
def mount(self, value: Optional[pulumi.Input[_builtins.str]]):
|
|
165
|
+
pulumi.set(self, "mount", value)
|
|
166
|
+
|
|
167
|
+
@_builtins.property
|
|
168
|
+
@pulumi.getter
|
|
169
|
+
def name(self) -> Optional[pulumi.Input[_builtins.str]]:
|
|
170
|
+
"""
|
|
171
|
+
Specifies the name of the destination.
|
|
172
|
+
"""
|
|
173
|
+
return pulumi.get(self, "name")
|
|
174
|
+
|
|
175
|
+
@name.setter
|
|
176
|
+
def name(self, value: Optional[pulumi.Input[_builtins.str]]):
|
|
177
|
+
pulumi.set(self, "name", value)
|
|
178
|
+
|
|
179
|
+
@_builtins.property
|
|
180
|
+
@pulumi.getter
|
|
181
|
+
def namespace(self) -> Optional[pulumi.Input[_builtins.str]]:
|
|
182
|
+
"""
|
|
183
|
+
The namespace to provision the resource in.
|
|
184
|
+
The value should not contain leading or trailing forward slashes.
|
|
185
|
+
The `namespace` is always relative to the provider's configured [namespace](https://www.terraform.io/docs/providers/vault/index.html#namespace).
|
|
186
|
+
"""
|
|
187
|
+
return pulumi.get(self, "namespace")
|
|
188
|
+
|
|
189
|
+
@namespace.setter
|
|
190
|
+
def namespace(self, value: Optional[pulumi.Input[_builtins.str]]):
|
|
191
|
+
pulumi.set(self, "namespace", value)
|
|
192
|
+
|
|
193
|
+
@_builtins.property
|
|
194
|
+
@pulumi.getter(name="secretName")
|
|
195
|
+
def secret_name(self) -> Optional[pulumi.Input[_builtins.str]]:
|
|
196
|
+
"""
|
|
197
|
+
Specifies the name of the secret to synchronize.
|
|
198
|
+
"""
|
|
199
|
+
return pulumi.get(self, "secret_name")
|
|
200
|
+
|
|
201
|
+
@secret_name.setter
|
|
202
|
+
def secret_name(self, value: Optional[pulumi.Input[_builtins.str]]):
|
|
203
|
+
pulumi.set(self, "secret_name", value)
|
|
204
|
+
|
|
205
|
+
@_builtins.property
|
|
206
|
+
@pulumi.getter
|
|
207
|
+
def type(self) -> Optional[pulumi.Input[_builtins.str]]:
|
|
208
|
+
"""
|
|
209
|
+
Specifies the destination type.
|
|
210
|
+
"""
|
|
211
|
+
return pulumi.get(self, "type")
|
|
212
|
+
|
|
213
|
+
@type.setter
|
|
214
|
+
def type(self, value: Optional[pulumi.Input[_builtins.str]]):
|
|
215
|
+
pulumi.set(self, "type", value)
|
|
216
|
+
|
|
217
|
+
|
|
218
|
+
@pulumi.type_token("vault:secrets/syncAssociation:SyncAssociation")
|
|
219
|
+
class SyncAssociation(pulumi.CustomResource):
|
|
220
|
+
@overload
|
|
221
|
+
def __init__(__self__,
|
|
222
|
+
resource_name: str,
|
|
223
|
+
opts: Optional[pulumi.ResourceOptions] = None,
|
|
224
|
+
mount: Optional[pulumi.Input[_builtins.str]] = None,
|
|
225
|
+
name: Optional[pulumi.Input[_builtins.str]] = None,
|
|
226
|
+
namespace: Optional[pulumi.Input[_builtins.str]] = None,
|
|
227
|
+
secret_name: Optional[pulumi.Input[_builtins.str]] = None,
|
|
228
|
+
type: Optional[pulumi.Input[_builtins.str]] = None,
|
|
229
|
+
__props__=None):
|
|
230
|
+
"""
|
|
231
|
+
## Example Usage
|
|
232
|
+
|
|
233
|
+
```python
|
|
234
|
+
import pulumi
|
|
235
|
+
import json
|
|
236
|
+
import pulumi_vault as vault
|
|
237
|
+
|
|
238
|
+
kvv2 = vault.Mount("kvv2",
|
|
239
|
+
path="kvv2",
|
|
240
|
+
type="kv",
|
|
241
|
+
options={
|
|
242
|
+
"version": "2",
|
|
243
|
+
},
|
|
244
|
+
description="KV Version 2 secret engine mount")
|
|
245
|
+
token = vault.kv.SecretV2("token",
|
|
246
|
+
mount=kvv2.path,
|
|
247
|
+
name="token",
|
|
248
|
+
data_json=json.dumps({
|
|
249
|
+
"dev": "B!gS3cr3t",
|
|
250
|
+
"prod": "S3cureP4$$",
|
|
251
|
+
}))
|
|
252
|
+
gh = vault.secrets.SyncGhDestination("gh",
|
|
253
|
+
name="gh-dest",
|
|
254
|
+
access_token=access_token,
|
|
255
|
+
repository_owner=repo_owner,
|
|
256
|
+
repository_name="repo-name-example",
|
|
257
|
+
secret_name_template="vault_{{ .MountAccessor | lowercase }}_{{ .SecretPath | lowercase }}")
|
|
258
|
+
gh_token = vault.secrets.SyncAssociation("gh_token",
|
|
259
|
+
name=gh.name,
|
|
260
|
+
type=gh.type,
|
|
261
|
+
mount=kvv2.path,
|
|
262
|
+
secret_name=token.name)
|
|
263
|
+
```
|
|
264
|
+
|
|
265
|
+
:param str resource_name: The name of the resource.
|
|
266
|
+
:param pulumi.ResourceOptions opts: Options for the resource.
|
|
267
|
+
:param pulumi.Input[_builtins.str] mount: Specifies the mount where the secret is located.
|
|
268
|
+
:param pulumi.Input[_builtins.str] name: Specifies the name of the destination.
|
|
269
|
+
:param pulumi.Input[_builtins.str] namespace: The namespace to provision the resource in.
|
|
270
|
+
The value should not contain leading or trailing forward slashes.
|
|
271
|
+
The `namespace` is always relative to the provider's configured [namespace](https://www.terraform.io/docs/providers/vault/index.html#namespace).
|
|
272
|
+
:param pulumi.Input[_builtins.str] secret_name: Specifies the name of the secret to synchronize.
|
|
273
|
+
:param pulumi.Input[_builtins.str] type: Specifies the destination type.
|
|
274
|
+
"""
|
|
275
|
+
...
|
|
276
|
+
@overload
|
|
277
|
+
def __init__(__self__,
|
|
278
|
+
resource_name: str,
|
|
279
|
+
args: SyncAssociationArgs,
|
|
280
|
+
opts: Optional[pulumi.ResourceOptions] = None):
|
|
281
|
+
"""
|
|
282
|
+
## Example Usage
|
|
283
|
+
|
|
284
|
+
```python
|
|
285
|
+
import pulumi
|
|
286
|
+
import json
|
|
287
|
+
import pulumi_vault as vault
|
|
288
|
+
|
|
289
|
+
kvv2 = vault.Mount("kvv2",
|
|
290
|
+
path="kvv2",
|
|
291
|
+
type="kv",
|
|
292
|
+
options={
|
|
293
|
+
"version": "2",
|
|
294
|
+
},
|
|
295
|
+
description="KV Version 2 secret engine mount")
|
|
296
|
+
token = vault.kv.SecretV2("token",
|
|
297
|
+
mount=kvv2.path,
|
|
298
|
+
name="token",
|
|
299
|
+
data_json=json.dumps({
|
|
300
|
+
"dev": "B!gS3cr3t",
|
|
301
|
+
"prod": "S3cureP4$$",
|
|
302
|
+
}))
|
|
303
|
+
gh = vault.secrets.SyncGhDestination("gh",
|
|
304
|
+
name="gh-dest",
|
|
305
|
+
access_token=access_token,
|
|
306
|
+
repository_owner=repo_owner,
|
|
307
|
+
repository_name="repo-name-example",
|
|
308
|
+
secret_name_template="vault_{{ .MountAccessor | lowercase }}_{{ .SecretPath | lowercase }}")
|
|
309
|
+
gh_token = vault.secrets.SyncAssociation("gh_token",
|
|
310
|
+
name=gh.name,
|
|
311
|
+
type=gh.type,
|
|
312
|
+
mount=kvv2.path,
|
|
313
|
+
secret_name=token.name)
|
|
314
|
+
```
|
|
315
|
+
|
|
316
|
+
:param str resource_name: The name of the resource.
|
|
317
|
+
:param SyncAssociationArgs args: The arguments to use to populate this resource's properties.
|
|
318
|
+
:param pulumi.ResourceOptions opts: Options for the resource.
|
|
319
|
+
"""
|
|
320
|
+
...
|
|
321
|
+
def __init__(__self__, resource_name: str, *args, **kwargs):
|
|
322
|
+
resource_args, opts = _utilities.get_resource_args_opts(SyncAssociationArgs, pulumi.ResourceOptions, *args, **kwargs)
|
|
323
|
+
if resource_args is not None:
|
|
324
|
+
__self__._internal_init(resource_name, opts, **resource_args.__dict__)
|
|
325
|
+
else:
|
|
326
|
+
__self__._internal_init(resource_name, *args, **kwargs)
|
|
327
|
+
|
|
328
|
+
def _internal_init(__self__,
|
|
329
|
+
resource_name: str,
|
|
330
|
+
opts: Optional[pulumi.ResourceOptions] = None,
|
|
331
|
+
mount: Optional[pulumi.Input[_builtins.str]] = None,
|
|
332
|
+
name: Optional[pulumi.Input[_builtins.str]] = None,
|
|
333
|
+
namespace: Optional[pulumi.Input[_builtins.str]] = None,
|
|
334
|
+
secret_name: Optional[pulumi.Input[_builtins.str]] = None,
|
|
335
|
+
type: Optional[pulumi.Input[_builtins.str]] = None,
|
|
336
|
+
__props__=None):
|
|
337
|
+
opts = pulumi.ResourceOptions.merge(_utilities.get_resource_opts_defaults(), opts)
|
|
338
|
+
if not isinstance(opts, pulumi.ResourceOptions):
|
|
339
|
+
raise TypeError('Expected resource options to be a ResourceOptions instance')
|
|
340
|
+
if opts.id is None:
|
|
341
|
+
if __props__ is not None:
|
|
342
|
+
raise TypeError('__props__ is only valid when passed in combination with a valid opts.id to get an existing resource')
|
|
343
|
+
__props__ = SyncAssociationArgs.__new__(SyncAssociationArgs)
|
|
344
|
+
|
|
345
|
+
if mount is None and not opts.urn:
|
|
346
|
+
raise TypeError("Missing required property 'mount'")
|
|
347
|
+
__props__.__dict__["mount"] = mount
|
|
348
|
+
__props__.__dict__["name"] = name
|
|
349
|
+
__props__.__dict__["namespace"] = namespace
|
|
350
|
+
if secret_name is None and not opts.urn:
|
|
351
|
+
raise TypeError("Missing required property 'secret_name'")
|
|
352
|
+
__props__.__dict__["secret_name"] = secret_name
|
|
353
|
+
if type is None and not opts.urn:
|
|
354
|
+
raise TypeError("Missing required property 'type'")
|
|
355
|
+
__props__.__dict__["type"] = type
|
|
356
|
+
__props__.__dict__["metadatas"] = None
|
|
357
|
+
super(SyncAssociation, __self__).__init__(
|
|
358
|
+
'vault:secrets/syncAssociation:SyncAssociation',
|
|
359
|
+
resource_name,
|
|
360
|
+
__props__,
|
|
361
|
+
opts)
|
|
362
|
+
|
|
363
|
+
@staticmethod
|
|
364
|
+
def get(resource_name: str,
|
|
365
|
+
id: pulumi.Input[str],
|
|
366
|
+
opts: Optional[pulumi.ResourceOptions] = None,
|
|
367
|
+
metadatas: Optional[pulumi.Input[Sequence[pulumi.Input[Union['SyncAssociationMetadataArgs', 'SyncAssociationMetadataArgsDict']]]]] = None,
|
|
368
|
+
mount: Optional[pulumi.Input[_builtins.str]] = None,
|
|
369
|
+
name: Optional[pulumi.Input[_builtins.str]] = None,
|
|
370
|
+
namespace: Optional[pulumi.Input[_builtins.str]] = None,
|
|
371
|
+
secret_name: Optional[pulumi.Input[_builtins.str]] = None,
|
|
372
|
+
type: Optional[pulumi.Input[_builtins.str]] = None) -> 'SyncAssociation':
|
|
373
|
+
"""
|
|
374
|
+
Get an existing SyncAssociation resource's state with the given name, id, and optional extra
|
|
375
|
+
properties used to qualify the lookup.
|
|
376
|
+
|
|
377
|
+
:param str resource_name: The unique name of the resulting resource.
|
|
378
|
+
:param pulumi.Input[str] id: The unique provider ID of the resource to lookup.
|
|
379
|
+
:param pulumi.ResourceOptions opts: Options for the resource.
|
|
380
|
+
:param pulumi.Input[Sequence[pulumi.Input[Union['SyncAssociationMetadataArgs', 'SyncAssociationMetadataArgsDict']]]] metadatas: Metadata for each subkey of the associated secret.
|
|
381
|
+
:param pulumi.Input[_builtins.str] mount: Specifies the mount where the secret is located.
|
|
382
|
+
:param pulumi.Input[_builtins.str] name: Specifies the name of the destination.
|
|
383
|
+
:param pulumi.Input[_builtins.str] namespace: The namespace to provision the resource in.
|
|
384
|
+
The value should not contain leading or trailing forward slashes.
|
|
385
|
+
The `namespace` is always relative to the provider's configured [namespace](https://www.terraform.io/docs/providers/vault/index.html#namespace).
|
|
386
|
+
:param pulumi.Input[_builtins.str] secret_name: Specifies the name of the secret to synchronize.
|
|
387
|
+
:param pulumi.Input[_builtins.str] type: Specifies the destination type.
|
|
388
|
+
"""
|
|
389
|
+
opts = pulumi.ResourceOptions.merge(opts, pulumi.ResourceOptions(id=id))
|
|
390
|
+
|
|
391
|
+
__props__ = _SyncAssociationState.__new__(_SyncAssociationState)
|
|
392
|
+
|
|
393
|
+
__props__.__dict__["metadatas"] = metadatas
|
|
394
|
+
__props__.__dict__["mount"] = mount
|
|
395
|
+
__props__.__dict__["name"] = name
|
|
396
|
+
__props__.__dict__["namespace"] = namespace
|
|
397
|
+
__props__.__dict__["secret_name"] = secret_name
|
|
398
|
+
__props__.__dict__["type"] = type
|
|
399
|
+
return SyncAssociation(resource_name, opts=opts, __props__=__props__)
|
|
400
|
+
|
|
401
|
+
@_builtins.property
|
|
402
|
+
@pulumi.getter
|
|
403
|
+
def metadatas(self) -> pulumi.Output[Sequence['outputs.SyncAssociationMetadata']]:
|
|
404
|
+
"""
|
|
405
|
+
Metadata for each subkey of the associated secret.
|
|
406
|
+
"""
|
|
407
|
+
return pulumi.get(self, "metadatas")
|
|
408
|
+
|
|
409
|
+
@_builtins.property
|
|
410
|
+
@pulumi.getter
|
|
411
|
+
def mount(self) -> pulumi.Output[_builtins.str]:
|
|
412
|
+
"""
|
|
413
|
+
Specifies the mount where the secret is located.
|
|
414
|
+
"""
|
|
415
|
+
return pulumi.get(self, "mount")
|
|
416
|
+
|
|
417
|
+
@_builtins.property
|
|
418
|
+
@pulumi.getter
|
|
419
|
+
def name(self) -> pulumi.Output[_builtins.str]:
|
|
420
|
+
"""
|
|
421
|
+
Specifies the name of the destination.
|
|
422
|
+
"""
|
|
423
|
+
return pulumi.get(self, "name")
|
|
424
|
+
|
|
425
|
+
@_builtins.property
|
|
426
|
+
@pulumi.getter
|
|
427
|
+
def namespace(self) -> pulumi.Output[Optional[_builtins.str]]:
|
|
428
|
+
"""
|
|
429
|
+
The namespace to provision the resource in.
|
|
430
|
+
The value should not contain leading or trailing forward slashes.
|
|
431
|
+
The `namespace` is always relative to the provider's configured [namespace](https://www.terraform.io/docs/providers/vault/index.html#namespace).
|
|
432
|
+
"""
|
|
433
|
+
return pulumi.get(self, "namespace")
|
|
434
|
+
|
|
435
|
+
@_builtins.property
|
|
436
|
+
@pulumi.getter(name="secretName")
|
|
437
|
+
def secret_name(self) -> pulumi.Output[_builtins.str]:
|
|
438
|
+
"""
|
|
439
|
+
Specifies the name of the secret to synchronize.
|
|
440
|
+
"""
|
|
441
|
+
return pulumi.get(self, "secret_name")
|
|
442
|
+
|
|
443
|
+
@_builtins.property
|
|
444
|
+
@pulumi.getter
|
|
445
|
+
def type(self) -> pulumi.Output[_builtins.str]:
|
|
446
|
+
"""
|
|
447
|
+
Specifies the destination type.
|
|
448
|
+
"""
|
|
449
|
+
return pulumi.get(self, "type")
|
|
450
|
+
|