Documentation ¶
Index ¶
- func KmsCryptoKey_IsConstruct(x interface{}) *bool
- func KmsCryptoKey_IsTerraformElement(x interface{}) *bool
- func KmsCryptoKey_IsTerraformResource(x interface{}) *bool
- func KmsCryptoKey_TfResourceType() *string
- func NewKmsCryptoKeyTimeoutsOutputReference_Override(k KmsCryptoKeyTimeoutsOutputReference, ...)
- func NewKmsCryptoKeyVersionTemplateOutputReference_Override(k KmsCryptoKeyVersionTemplateOutputReference, ...)
- func NewKmsCryptoKey_Override(k KmsCryptoKey, scope constructs.Construct, id *string, ...)
- type KmsCryptoKey
- type KmsCryptoKeyConfig
- type KmsCryptoKeyTimeouts
- type KmsCryptoKeyTimeoutsOutputReference
- type KmsCryptoKeyVersionTemplate
- type KmsCryptoKeyVersionTemplateOutputReference
Constants ¶
This section is empty.
Variables ¶
This section is empty.
Functions ¶
func KmsCryptoKey_IsConstruct ¶
func KmsCryptoKey_IsConstruct(x interface{}) *bool
Checks if `x` is a construct.
Use this method instead of `instanceof` to properly detect `Construct` instances, even when the construct library is symlinked.
Explanation: in JavaScript, multiple copies of the `constructs` library on disk are seen as independent, completely different libraries. As a consequence, the class `Construct` in each copy of the `constructs` library is seen as a different class, and an instance of one class will not test as `instanceof` the other class. `npm install` will not create installations like this, but users may manually symlink construct libraries together or use a monorepo tool: in those cases, multiple copies of the `constructs` library can be accidentally installed, and `instanceof` will behave unpredictably. It is safest to avoid using `instanceof`, and using this type-testing method instead.
Returns: true if `x` is an object created from a class which extends `Construct`.
func KmsCryptoKey_IsTerraformElement ¶
func KmsCryptoKey_IsTerraformElement(x interface{}) *bool
Experimental.
func KmsCryptoKey_IsTerraformResource ¶
func KmsCryptoKey_IsTerraformResource(x interface{}) *bool
Experimental.
func KmsCryptoKey_TfResourceType ¶
func KmsCryptoKey_TfResourceType() *string
func NewKmsCryptoKeyTimeoutsOutputReference_Override ¶
func NewKmsCryptoKeyTimeoutsOutputReference_Override(k KmsCryptoKeyTimeoutsOutputReference, terraformResource cdktf.IInterpolatingParent, terraformAttribute *string)
func NewKmsCryptoKeyVersionTemplateOutputReference_Override ¶
func NewKmsCryptoKeyVersionTemplateOutputReference_Override(k KmsCryptoKeyVersionTemplateOutputReference, terraformResource cdktf.IInterpolatingParent, terraformAttribute *string)
func NewKmsCryptoKey_Override ¶
func NewKmsCryptoKey_Override(k KmsCryptoKey, scope constructs.Construct, id *string, config *KmsCryptoKeyConfig)
Create a new {@link https://registry.terraform.io/providers/hashicorp/google/4.84.0/docs/resources/kms_crypto_key google_kms_crypto_key} Resource.
Types ¶
type KmsCryptoKey ¶
type KmsCryptoKey interface { cdktf.TerraformResource // Experimental. CdktfStack() cdktf.TerraformStack // Experimental. Connection() interface{} // Experimental. SetConnection(val interface{}) // Experimental. ConstructNodeMetadata() *map[string]interface{} // Experimental. Count() interface{} // Experimental. SetCount(val interface{}) // Experimental. DependsOn() *[]*string // Experimental. SetDependsOn(val *[]*string) DestroyScheduledDuration() *string SetDestroyScheduledDuration(val *string) DestroyScheduledDurationInput() *string // Experimental. ForEach() cdktf.ITerraformIterator // Experimental. SetForEach(val cdktf.ITerraformIterator) // Experimental. Fqn() *string // Experimental. FriendlyUniqueId() *string Id() *string SetId(val *string) IdInput() *string ImportOnly() interface{} SetImportOnly(val interface{}) ImportOnlyInput() interface{} KeyRing() *string SetKeyRing(val *string) KeyRingInput() *string Labels() *map[string]*string SetLabels(val *map[string]*string) LabelsInput() *map[string]*string // Experimental. Lifecycle() *cdktf.TerraformResourceLifecycle // Experimental. SetLifecycle(val *cdktf.TerraformResourceLifecycle) Name() *string SetName(val *string) NameInput() *string // The tree node. Node() constructs.Node // Experimental. Provider() cdktf.TerraformProvider // Experimental. SetProvider(val cdktf.TerraformProvider) // Experimental. Provisioners() *[]interface{} // Experimental. SetProvisioners(val *[]interface{}) Purpose() *string SetPurpose(val *string) PurposeInput() *string // Experimental. RawOverrides() interface{} RotationPeriod() *string SetRotationPeriod(val *string) RotationPeriodInput() *string SkipInitialVersionCreation() interface{} SetSkipInitialVersionCreation(val interface{}) SkipInitialVersionCreationInput() interface{} // Experimental. TerraformGeneratorMetadata() *cdktf.TerraformProviderGeneratorMetadata // Experimental. TerraformMetaArguments() *map[string]interface{} // Experimental. TerraformResourceType() *string Timeouts() KmsCryptoKeyTimeoutsOutputReference TimeoutsInput() interface{} VersionTemplate() KmsCryptoKeyVersionTemplateOutputReference VersionTemplateInput() *KmsCryptoKeyVersionTemplate // Experimental. AddOverride(path *string, value interface{}) // Experimental. GetAnyMapAttribute(terraformAttribute *string) *map[string]interface{} // Experimental. GetBooleanAttribute(terraformAttribute *string) cdktf.IResolvable // Experimental. GetBooleanMapAttribute(terraformAttribute *string) *map[string]*bool // Experimental. GetListAttribute(terraformAttribute *string) *[]*string // Experimental. GetNumberAttribute(terraformAttribute *string) *float64 // Experimental. GetNumberListAttribute(terraformAttribute *string) *[]*float64 // Experimental. GetNumberMapAttribute(terraformAttribute *string) *map[string]*float64 // Experimental. GetStringAttribute(terraformAttribute *string) *string // Experimental. GetStringMapAttribute(terraformAttribute *string) *map[string]*string // Experimental. InterpolationForAttribute(terraformAttribute *string) cdktf.IResolvable // Overrides the auto-generated logical ID with a specific ID. // Experimental. OverrideLogicalId(newLogicalId *string) PutTimeouts(value *KmsCryptoKeyTimeouts) PutVersionTemplate(value *KmsCryptoKeyVersionTemplate) ResetDestroyScheduledDuration() ResetId() ResetImportOnly() ResetLabels() // Resets a previously passed logical Id to use the auto-generated logical id again. // Experimental. ResetOverrideLogicalId() ResetPurpose() ResetRotationPeriod() ResetSkipInitialVersionCreation() ResetTimeouts() ResetVersionTemplate() SynthesizeAttributes() *map[string]interface{} // Experimental. ToMetadata() interface{} // Returns a string representation of this construct. ToString() *string // Adds this resource to the terraform JSON output. // Experimental. ToTerraform() interface{} }
Represents a {@link https://registry.terraform.io/providers/hashicorp/google/4.84.0/docs/resources/kms_crypto_key google_kms_crypto_key}.
func NewKmsCryptoKey ¶
func NewKmsCryptoKey(scope constructs.Construct, id *string, config *KmsCryptoKeyConfig) KmsCryptoKey
Create a new {@link https://registry.terraform.io/providers/hashicorp/google/4.84.0/docs/resources/kms_crypto_key google_kms_crypto_key} Resource.
type KmsCryptoKeyConfig ¶
type KmsCryptoKeyConfig struct { // Experimental. Connection interface{} `field:"optional" json:"connection" yaml:"connection"` // Experimental. Count interface{} `field:"optional" json:"count" yaml:"count"` // Experimental. DependsOn *[]cdktf.ITerraformDependable `field:"optional" json:"dependsOn" yaml:"dependsOn"` // Experimental. ForEach cdktf.ITerraformIterator `field:"optional" json:"forEach" yaml:"forEach"` // Experimental. Lifecycle *cdktf.TerraformResourceLifecycle `field:"optional" json:"lifecycle" yaml:"lifecycle"` // Experimental. Provider cdktf.TerraformProvider `field:"optional" json:"provider" yaml:"provider"` // Experimental. Provisioners *[]interface{} `field:"optional" json:"provisioners" yaml:"provisioners"` // The KeyRing that this key belongs to. Format: ”projects/{{project}}/locations/{{location}}/keyRings/{{keyRing}}”. // // Docs at Terraform Registry: {@link https://registry.terraform.io/providers/hashicorp/google/4.84.0/docs/resources/kms_crypto_key#key_ring KmsCryptoKey#key_ring} KeyRing *string `field:"required" json:"keyRing" yaml:"keyRing"` // The resource name for the CryptoKey. // // Docs at Terraform Registry: {@link https://registry.terraform.io/providers/hashicorp/google/4.84.0/docs/resources/kms_crypto_key#name KmsCryptoKey#name} Name *string `field:"required" json:"name" yaml:"name"` // The period of time that versions of this key spend in the DESTROY_SCHEDULED state before transitioning to DESTROYED. // // If not specified at creation time, the default duration is 24 hours. // // Docs at Terraform Registry: {@link https://registry.terraform.io/providers/hashicorp/google/4.84.0/docs/resources/kms_crypto_key#destroy_scheduled_duration KmsCryptoKey#destroy_scheduled_duration} DestroyScheduledDuration *string `field:"optional" json:"destroyScheduledDuration" yaml:"destroyScheduledDuration"` // Docs at Terraform Registry: {@link https://registry.terraform.io/providers/hashicorp/google/4.84.0/docs/resources/kms_crypto_key#id KmsCryptoKey#id}. // // Please be aware that the id field is automatically added to all resources in Terraform providers using a Terraform provider SDK version below 2. // If you experience problems setting this value it might not be settable. Please take a look at the provider documentation to ensure it should be settable. Id *string `field:"optional" json:"id" yaml:"id"` // Whether this key may contain imported versions only. // // Docs at Terraform Registry: {@link https://registry.terraform.io/providers/hashicorp/google/4.84.0/docs/resources/kms_crypto_key#import_only KmsCryptoKey#import_only} ImportOnly interface{} `field:"optional" json:"importOnly" yaml:"importOnly"` // Labels with user-defined metadata to apply to this resource. // // Docs at Terraform Registry: {@link https://registry.terraform.io/providers/hashicorp/google/4.84.0/docs/resources/kms_crypto_key#labels KmsCryptoKey#labels} Labels *map[string]*string `field:"optional" json:"labels" yaml:"labels"` // The immutable purpose of this CryptoKey. See the [purpose reference](https://cloud.google.com/kms/docs/reference/rest/v1/projects.locations.keyRings.cryptoKeys#CryptoKeyPurpose) for possible inputs. Default value is "ENCRYPT_DECRYPT". // // Docs at Terraform Registry: {@link https://registry.terraform.io/providers/hashicorp/google/4.84.0/docs/resources/kms_crypto_key#purpose KmsCryptoKey#purpose} Purpose *string `field:"optional" json:"purpose" yaml:"purpose"` // Every time this period passes, generate a new CryptoKeyVersion and set it as the primary. // // The first rotation will take place after the specified period. The rotation period has // the format of a decimal number with up to 9 fractional digits, followed by the // letter 's' (seconds). It must be greater than a day (ie, 86400). // // Docs at Terraform Registry: {@link https://registry.terraform.io/providers/hashicorp/google/4.84.0/docs/resources/kms_crypto_key#rotation_period KmsCryptoKey#rotation_period} RotationPeriod *string `field:"optional" json:"rotationPeriod" yaml:"rotationPeriod"` // If set to true, the request will create a CryptoKey without any CryptoKeyVersions. // // You must use the 'google_kms_key_ring_import_job' resource to import the CryptoKeyVersion. // // Docs at Terraform Registry: {@link https://registry.terraform.io/providers/hashicorp/google/4.84.0/docs/resources/kms_crypto_key#skip_initial_version_creation KmsCryptoKey#skip_initial_version_creation} SkipInitialVersionCreation interface{} `field:"optional" json:"skipInitialVersionCreation" yaml:"skipInitialVersionCreation"` // timeouts block. // // Docs at Terraform Registry: {@link https://registry.terraform.io/providers/hashicorp/google/4.84.0/docs/resources/kms_crypto_key#timeouts KmsCryptoKey#timeouts} Timeouts *KmsCryptoKeyTimeouts `field:"optional" json:"timeouts" yaml:"timeouts"` // version_template block. // // Docs at Terraform Registry: {@link https://registry.terraform.io/providers/hashicorp/google/4.84.0/docs/resources/kms_crypto_key#version_template KmsCryptoKey#version_template} VersionTemplate *KmsCryptoKeyVersionTemplate `field:"optional" json:"versionTemplate" yaml:"versionTemplate"` }
type KmsCryptoKeyTimeouts ¶
type KmsCryptoKeyTimeouts struct { // Docs at Terraform Registry: {@link https://registry.terraform.io/providers/hashicorp/google/4.84.0/docs/resources/kms_crypto_key#create KmsCryptoKey#create}. Create *string `field:"optional" json:"create" yaml:"create"` // Docs at Terraform Registry: {@link https://registry.terraform.io/providers/hashicorp/google/4.84.0/docs/resources/kms_crypto_key#delete KmsCryptoKey#delete}. Delete *string `field:"optional" json:"delete" yaml:"delete"` // Docs at Terraform Registry: {@link https://registry.terraform.io/providers/hashicorp/google/4.84.0/docs/resources/kms_crypto_key#update KmsCryptoKey#update}. Update *string `field:"optional" json:"update" yaml:"update"` }
type KmsCryptoKeyTimeoutsOutputReference ¶
type KmsCryptoKeyTimeoutsOutputReference interface { cdktf.ComplexObject // the index of the complex object in a list. // Experimental. ComplexObjectIndex() interface{} // Experimental. SetComplexObjectIndex(val interface{}) // set to true if this item is from inside a set and needs tolist() for accessing it set to "0" for single list items. // Experimental. ComplexObjectIsFromSet() *bool // Experimental. SetComplexObjectIsFromSet(val *bool) Create() *string SetCreate(val *string) CreateInput() *string // The creation stack of this resolvable which will be appended to errors thrown during resolution. // // If this returns an empty array the stack will not be attached. // Experimental. CreationStack() *[]*string Delete() *string SetDelete(val *string) DeleteInput() *string // Experimental. Fqn() *string InternalValue() interface{} SetInternalValue(val interface{}) // Experimental. TerraformAttribute() *string // Experimental. SetTerraformAttribute(val *string) // Experimental. TerraformResource() cdktf.IInterpolatingParent // Experimental. SetTerraformResource(val cdktf.IInterpolatingParent) Update() *string SetUpdate(val *string) UpdateInput() *string // Experimental. ComputeFqn() *string // Experimental. GetAnyMapAttribute(terraformAttribute *string) *map[string]interface{} // Experimental. GetBooleanAttribute(terraformAttribute *string) cdktf.IResolvable // Experimental. GetBooleanMapAttribute(terraformAttribute *string) *map[string]*bool // Experimental. GetListAttribute(terraformAttribute *string) *[]*string // Experimental. GetNumberAttribute(terraformAttribute *string) *float64 // Experimental. GetNumberListAttribute(terraformAttribute *string) *[]*float64 // Experimental. GetNumberMapAttribute(terraformAttribute *string) *map[string]*float64 // Experimental. GetStringAttribute(terraformAttribute *string) *string // Experimental. GetStringMapAttribute(terraformAttribute *string) *map[string]*string // Experimental. InterpolationAsList() cdktf.IResolvable // Experimental. InterpolationForAttribute(property *string) cdktf.IResolvable ResetCreate() ResetDelete() ResetUpdate() // Produce the Token's value at resolution time. // Experimental. Resolve(_context cdktf.IResolveContext) interface{} // Return a string representation of this resolvable object. // // Returns a reversible string representation. // Experimental. ToString() *string }
func NewKmsCryptoKeyTimeoutsOutputReference ¶
func NewKmsCryptoKeyTimeoutsOutputReference(terraformResource cdktf.IInterpolatingParent, terraformAttribute *string) KmsCryptoKeyTimeoutsOutputReference
type KmsCryptoKeyVersionTemplate ¶
type KmsCryptoKeyVersionTemplate struct { // The algorithm to use when creating a version based on this template. See the [algorithm reference](https://cloud.google.com/kms/docs/reference/rest/v1/CryptoKeyVersionAlgorithm) for possible inputs. // // Docs at Terraform Registry: {@link https://registry.terraform.io/providers/hashicorp/google/4.84.0/docs/resources/kms_crypto_key#algorithm KmsCryptoKey#algorithm} Algorithm *string `field:"required" json:"algorithm" yaml:"algorithm"` // The protection level to use when creating a version based on this template. // // Possible values include "SOFTWARE", "HSM", "EXTERNAL", "EXTERNAL_VPC". Defaults to "SOFTWARE". // // Docs at Terraform Registry: {@link https://registry.terraform.io/providers/hashicorp/google/4.84.0/docs/resources/kms_crypto_key#protection_level KmsCryptoKey#protection_level} ProtectionLevel *string `field:"optional" json:"protectionLevel" yaml:"protectionLevel"` }
type KmsCryptoKeyVersionTemplateOutputReference ¶
type KmsCryptoKeyVersionTemplateOutputReference interface { cdktf.ComplexObject Algorithm() *string SetAlgorithm(val *string) AlgorithmInput() *string // the index of the complex object in a list. // Experimental. ComplexObjectIndex() interface{} // Experimental. SetComplexObjectIndex(val interface{}) // set to true if this item is from inside a set and needs tolist() for accessing it set to "0" for single list items. // Experimental. ComplexObjectIsFromSet() *bool // Experimental. SetComplexObjectIsFromSet(val *bool) // The creation stack of this resolvable which will be appended to errors thrown during resolution. // // If this returns an empty array the stack will not be attached. // Experimental. CreationStack() *[]*string // Experimental. Fqn() *string InternalValue() *KmsCryptoKeyVersionTemplate SetInternalValue(val *KmsCryptoKeyVersionTemplate) ProtectionLevel() *string SetProtectionLevel(val *string) ProtectionLevelInput() *string // Experimental. TerraformAttribute() *string // Experimental. SetTerraformAttribute(val *string) // Experimental. TerraformResource() cdktf.IInterpolatingParent // Experimental. SetTerraformResource(val cdktf.IInterpolatingParent) // Experimental. ComputeFqn() *string // Experimental. GetAnyMapAttribute(terraformAttribute *string) *map[string]interface{} // Experimental. GetBooleanAttribute(terraformAttribute *string) cdktf.IResolvable // Experimental. GetBooleanMapAttribute(terraformAttribute *string) *map[string]*bool // Experimental. GetListAttribute(terraformAttribute *string) *[]*string // Experimental. GetNumberAttribute(terraformAttribute *string) *float64 // Experimental. GetNumberListAttribute(terraformAttribute *string) *[]*float64 // Experimental. GetNumberMapAttribute(terraformAttribute *string) *map[string]*float64 // Experimental. GetStringAttribute(terraformAttribute *string) *string // Experimental. GetStringMapAttribute(terraformAttribute *string) *map[string]*string // Experimental. InterpolationAsList() cdktf.IResolvable // Experimental. InterpolationForAttribute(property *string) cdktf.IResolvable ResetProtectionLevel() // Produce the Token's value at resolution time. // Experimental. Resolve(_context cdktf.IResolveContext) interface{} // Return a string representation of this resolvable object. // // Returns a reversible string representation. // Experimental. ToString() *string }
func NewKmsCryptoKeyVersionTemplateOutputReference ¶
func NewKmsCryptoKeyVersionTemplateOutputReference(terraformResource cdktf.IInterpolatingParent, terraformAttribute *string) KmsCryptoKeyVersionTemplateOutputReference
Source Files ¶
- KmsCryptoKey.go
- KmsCryptoKeyConfig.go
- KmsCryptoKeyTimeouts.go
- KmsCryptoKeyTimeoutsOutputReference.go
- KmsCryptoKeyTimeoutsOutputReference__checks.go
- KmsCryptoKeyVersionTemplate.go
- KmsCryptoKeyVersionTemplateOutputReference.go
- KmsCryptoKeyVersionTemplateOutputReference__checks.go
- KmsCryptoKey__checks.go
- main.go