@cdktf/provider-aws
Version:
Prebuilt aws Provider for Terraform CDK (cdktf)
377 lines (376 loc) • 21.7 kB
TypeScript
/**
* Copyright (c) HashiCorp, Inc.
* SPDX-License-Identifier: MPL-2.0
*/
import { Construct } from 'constructs';
import * as cdktf from 'cdktf';
export interface VpcEncryptionControlConfig extends cdktf.TerraformMetaArguments {
/**
* Docs at Terraform Registry: {@link https://registry.terraform.io/providers/hashicorp/aws/6.25.0/docs/resources/vpc_encryption_control#egress_only_internet_gateway_exclusion VpcEncryptionControl#egress_only_internet_gateway_exclusion}
*/
readonly egressOnlyInternetGatewayExclusion?: string;
/**
* Docs at Terraform Registry: {@link https://registry.terraform.io/providers/hashicorp/aws/6.25.0/docs/resources/vpc_encryption_control#elastic_file_system_exclusion VpcEncryptionControl#elastic_file_system_exclusion}
*/
readonly elasticFileSystemExclusion?: string;
/**
* Docs at Terraform Registry: {@link https://registry.terraform.io/providers/hashicorp/aws/6.25.0/docs/resources/vpc_encryption_control#internet_gateway_exclusion VpcEncryptionControl#internet_gateway_exclusion}
*/
readonly internetGatewayExclusion?: string;
/**
* Docs at Terraform Registry: {@link https://registry.terraform.io/providers/hashicorp/aws/6.25.0/docs/resources/vpc_encryption_control#lambda_exclusion VpcEncryptionControl#lambda_exclusion}
*/
readonly lambdaExclusion?: string;
/**
* Docs at Terraform Registry: {@link https://registry.terraform.io/providers/hashicorp/aws/6.25.0/docs/resources/vpc_encryption_control#mode VpcEncryptionControl#mode}
*/
readonly mode: string;
/**
* Docs at Terraform Registry: {@link https://registry.terraform.io/providers/hashicorp/aws/6.25.0/docs/resources/vpc_encryption_control#nat_gateway_exclusion VpcEncryptionControl#nat_gateway_exclusion}
*/
readonly natGatewayExclusion?: string;
/**
* Region where this resource will be [managed](https://docs.aws.amazon.com/general/latest/gr/rande.html#regional-endpoints). Defaults to the Region set in the [provider configuration](https://registry.terraform.io/providers/hashicorp/aws/latest/docs#aws-configuration-reference).
*
* Docs at Terraform Registry: {@link https://registry.terraform.io/providers/hashicorp/aws/6.25.0/docs/resources/vpc_encryption_control#region VpcEncryptionControl#region}
*/
readonly region?: string;
/**
* Docs at Terraform Registry: {@link https://registry.terraform.io/providers/hashicorp/aws/6.25.0/docs/resources/vpc_encryption_control#tags VpcEncryptionControl#tags}
*/
readonly tags?: {
[key: string]: string;
};
/**
* Docs at Terraform Registry: {@link https://registry.terraform.io/providers/hashicorp/aws/6.25.0/docs/resources/vpc_encryption_control#virtual_private_gateway_exclusion VpcEncryptionControl#virtual_private_gateway_exclusion}
*/
readonly virtualPrivateGatewayExclusion?: string;
/**
* Docs at Terraform Registry: {@link https://registry.terraform.io/providers/hashicorp/aws/6.25.0/docs/resources/vpc_encryption_control#vpc_id VpcEncryptionControl#vpc_id}
*/
readonly vpcId: string;
/**
* Docs at Terraform Registry: {@link https://registry.terraform.io/providers/hashicorp/aws/6.25.0/docs/resources/vpc_encryption_control#vpc_lattice_exclusion VpcEncryptionControl#vpc_lattice_exclusion}
*/
readonly vpcLatticeExclusion?: string;
/**
* Docs at Terraform Registry: {@link https://registry.terraform.io/providers/hashicorp/aws/6.25.0/docs/resources/vpc_encryption_control#vpc_peering_exclusion VpcEncryptionControl#vpc_peering_exclusion}
*/
readonly vpcPeeringExclusion?: string;
/**
* timeouts block
*
* Docs at Terraform Registry: {@link https://registry.terraform.io/providers/hashicorp/aws/6.25.0/docs/resources/vpc_encryption_control#timeouts VpcEncryptionControl#timeouts}
*/
readonly timeouts?: VpcEncryptionControlTimeouts;
}
export interface VpcEncryptionControlResourceExclusionsEgressOnlyInternetGateway {
}
export declare function vpcEncryptionControlResourceExclusionsEgressOnlyInternetGatewayToTerraform(struct?: VpcEncryptionControlResourceExclusionsEgressOnlyInternetGateway): any;
export declare function vpcEncryptionControlResourceExclusionsEgressOnlyInternetGatewayToHclTerraform(struct?: VpcEncryptionControlResourceExclusionsEgressOnlyInternetGateway): any;
export declare class VpcEncryptionControlResourceExclusionsEgressOnlyInternetGatewayOutputReference extends cdktf.ComplexObject {
private isEmptyObject;
/**
* @param terraformResource The parent resource
* @param terraformAttribute The attribute on the parent resource this class is referencing
*/
constructor(terraformResource: cdktf.IInterpolatingParent, terraformAttribute: string);
get internalValue(): VpcEncryptionControlResourceExclusionsEgressOnlyInternetGateway | undefined;
set internalValue(value: VpcEncryptionControlResourceExclusionsEgressOnlyInternetGateway | undefined);
get state(): string;
get stateMessage(): string;
}
export interface VpcEncryptionControlResourceExclusionsElasticFileSystem {
}
export declare function vpcEncryptionControlResourceExclusionsElasticFileSystemToTerraform(struct?: VpcEncryptionControlResourceExclusionsElasticFileSystem): any;
export declare function vpcEncryptionControlResourceExclusionsElasticFileSystemToHclTerraform(struct?: VpcEncryptionControlResourceExclusionsElasticFileSystem): any;
export declare class VpcEncryptionControlResourceExclusionsElasticFileSystemOutputReference extends cdktf.ComplexObject {
private isEmptyObject;
/**
* @param terraformResource The parent resource
* @param terraformAttribute The attribute on the parent resource this class is referencing
*/
constructor(terraformResource: cdktf.IInterpolatingParent, terraformAttribute: string);
get internalValue(): VpcEncryptionControlResourceExclusionsElasticFileSystem | undefined;
set internalValue(value: VpcEncryptionControlResourceExclusionsElasticFileSystem | undefined);
get state(): string;
get stateMessage(): string;
}
export interface VpcEncryptionControlResourceExclusionsInternetGateway {
}
export declare function vpcEncryptionControlResourceExclusionsInternetGatewayToTerraform(struct?: VpcEncryptionControlResourceExclusionsInternetGateway): any;
export declare function vpcEncryptionControlResourceExclusionsInternetGatewayToHclTerraform(struct?: VpcEncryptionControlResourceExclusionsInternetGateway): any;
export declare class VpcEncryptionControlResourceExclusionsInternetGatewayOutputReference extends cdktf.ComplexObject {
private isEmptyObject;
/**
* @param terraformResource The parent resource
* @param terraformAttribute The attribute on the parent resource this class is referencing
*/
constructor(terraformResource: cdktf.IInterpolatingParent, terraformAttribute: string);
get internalValue(): VpcEncryptionControlResourceExclusionsInternetGateway | undefined;
set internalValue(value: VpcEncryptionControlResourceExclusionsInternetGateway | undefined);
get state(): string;
get stateMessage(): string;
}
export interface VpcEncryptionControlResourceExclusionsLambda {
}
export declare function vpcEncryptionControlResourceExclusionsLambdaToTerraform(struct?: VpcEncryptionControlResourceExclusionsLambda): any;
export declare function vpcEncryptionControlResourceExclusionsLambdaToHclTerraform(struct?: VpcEncryptionControlResourceExclusionsLambda): any;
export declare class VpcEncryptionControlResourceExclusionsLambdaOutputReference extends cdktf.ComplexObject {
private isEmptyObject;
/**
* @param terraformResource The parent resource
* @param terraformAttribute The attribute on the parent resource this class is referencing
*/
constructor(terraformResource: cdktf.IInterpolatingParent, terraformAttribute: string);
get internalValue(): VpcEncryptionControlResourceExclusionsLambda | undefined;
set internalValue(value: VpcEncryptionControlResourceExclusionsLambda | undefined);
get state(): string;
get stateMessage(): string;
}
export interface VpcEncryptionControlResourceExclusionsNatGateway {
}
export declare function vpcEncryptionControlResourceExclusionsNatGatewayToTerraform(struct?: VpcEncryptionControlResourceExclusionsNatGateway): any;
export declare function vpcEncryptionControlResourceExclusionsNatGatewayToHclTerraform(struct?: VpcEncryptionControlResourceExclusionsNatGateway): any;
export declare class VpcEncryptionControlResourceExclusionsNatGatewayOutputReference extends cdktf.ComplexObject {
private isEmptyObject;
/**
* @param terraformResource The parent resource
* @param terraformAttribute The attribute on the parent resource this class is referencing
*/
constructor(terraformResource: cdktf.IInterpolatingParent, terraformAttribute: string);
get internalValue(): VpcEncryptionControlResourceExclusionsNatGateway | undefined;
set internalValue(value: VpcEncryptionControlResourceExclusionsNatGateway | undefined);
get state(): string;
get stateMessage(): string;
}
export interface VpcEncryptionControlResourceExclusionsVirtualPrivateGateway {
}
export declare function vpcEncryptionControlResourceExclusionsVirtualPrivateGatewayToTerraform(struct?: VpcEncryptionControlResourceExclusionsVirtualPrivateGateway): any;
export declare function vpcEncryptionControlResourceExclusionsVirtualPrivateGatewayToHclTerraform(struct?: VpcEncryptionControlResourceExclusionsVirtualPrivateGateway): any;
export declare class VpcEncryptionControlResourceExclusionsVirtualPrivateGatewayOutputReference extends cdktf.ComplexObject {
private isEmptyObject;
/**
* @param terraformResource The parent resource
* @param terraformAttribute The attribute on the parent resource this class is referencing
*/
constructor(terraformResource: cdktf.IInterpolatingParent, terraformAttribute: string);
get internalValue(): VpcEncryptionControlResourceExclusionsVirtualPrivateGateway | undefined;
set internalValue(value: VpcEncryptionControlResourceExclusionsVirtualPrivateGateway | undefined);
get state(): string;
get stateMessage(): string;
}
export interface VpcEncryptionControlResourceExclusionsVpcLattice {
}
export declare function vpcEncryptionControlResourceExclusionsVpcLatticeToTerraform(struct?: VpcEncryptionControlResourceExclusionsVpcLattice): any;
export declare function vpcEncryptionControlResourceExclusionsVpcLatticeToHclTerraform(struct?: VpcEncryptionControlResourceExclusionsVpcLattice): any;
export declare class VpcEncryptionControlResourceExclusionsVpcLatticeOutputReference extends cdktf.ComplexObject {
private isEmptyObject;
/**
* @param terraformResource The parent resource
* @param terraformAttribute The attribute on the parent resource this class is referencing
*/
constructor(terraformResource: cdktf.IInterpolatingParent, terraformAttribute: string);
get internalValue(): VpcEncryptionControlResourceExclusionsVpcLattice | undefined;
set internalValue(value: VpcEncryptionControlResourceExclusionsVpcLattice | undefined);
get state(): string;
get stateMessage(): string;
}
export interface VpcEncryptionControlResourceExclusionsVpcPeering {
}
export declare function vpcEncryptionControlResourceExclusionsVpcPeeringToTerraform(struct?: VpcEncryptionControlResourceExclusionsVpcPeering): any;
export declare function vpcEncryptionControlResourceExclusionsVpcPeeringToHclTerraform(struct?: VpcEncryptionControlResourceExclusionsVpcPeering): any;
export declare class VpcEncryptionControlResourceExclusionsVpcPeeringOutputReference extends cdktf.ComplexObject {
private isEmptyObject;
/**
* @param terraformResource The parent resource
* @param terraformAttribute The attribute on the parent resource this class is referencing
*/
constructor(terraformResource: cdktf.IInterpolatingParent, terraformAttribute: string);
get internalValue(): VpcEncryptionControlResourceExclusionsVpcPeering | undefined;
set internalValue(value: VpcEncryptionControlResourceExclusionsVpcPeering | undefined);
get state(): string;
get stateMessage(): string;
}
export interface VpcEncryptionControlResourceExclusions {
}
export declare function vpcEncryptionControlResourceExclusionsToTerraform(struct?: VpcEncryptionControlResourceExclusions): any;
export declare function vpcEncryptionControlResourceExclusionsToHclTerraform(struct?: VpcEncryptionControlResourceExclusions): any;
export declare class VpcEncryptionControlResourceExclusionsOutputReference extends cdktf.ComplexObject {
private isEmptyObject;
/**
* @param terraformResource The parent resource
* @param terraformAttribute The attribute on the parent resource this class is referencing
*/
constructor(terraformResource: cdktf.IInterpolatingParent, terraformAttribute: string);
get internalValue(): VpcEncryptionControlResourceExclusions | undefined;
set internalValue(value: VpcEncryptionControlResourceExclusions | undefined);
private _egressOnlyInternetGateway;
get egressOnlyInternetGateway(): VpcEncryptionControlResourceExclusionsEgressOnlyInternetGatewayOutputReference;
private _elasticFileSystem;
get elasticFileSystem(): VpcEncryptionControlResourceExclusionsElasticFileSystemOutputReference;
private _internetGateway;
get internetGateway(): VpcEncryptionControlResourceExclusionsInternetGatewayOutputReference;
private _lambda;
get lambda(): VpcEncryptionControlResourceExclusionsLambdaOutputReference;
private _natGateway;
get natGateway(): VpcEncryptionControlResourceExclusionsNatGatewayOutputReference;
private _virtualPrivateGateway;
get virtualPrivateGateway(): VpcEncryptionControlResourceExclusionsVirtualPrivateGatewayOutputReference;
private _vpcLattice;
get vpcLattice(): VpcEncryptionControlResourceExclusionsVpcLatticeOutputReference;
private _vpcPeering;
get vpcPeering(): VpcEncryptionControlResourceExclusionsVpcPeeringOutputReference;
}
export interface VpcEncryptionControlTimeouts {
/**
* A string that can be [parsed as a duration](https://pkg.go.dev/time#ParseDuration) consisting of numbers and unit suffixes, such as "30s" or "2h45m". Valid time units are "s" (seconds), "m" (minutes), "h" (hours).
*
* Docs at Terraform Registry: {@link https://registry.terraform.io/providers/hashicorp/aws/6.25.0/docs/resources/vpc_encryption_control#create VpcEncryptionControl#create}
*/
readonly create?: string;
/**
* A string that can be [parsed as a duration](https://pkg.go.dev/time#ParseDuration) consisting of numbers and unit suffixes, such as "30s" or "2h45m". Valid time units are "s" (seconds), "m" (minutes), "h" (hours). Setting a timeout for a Delete operation is only applicable if changes are saved into state before the destroy operation occurs.
*
* Docs at Terraform Registry: {@link https://registry.terraform.io/providers/hashicorp/aws/6.25.0/docs/resources/vpc_encryption_control#delete VpcEncryptionControl#delete}
*/
readonly delete?: string;
/**
* A string that can be [parsed as a duration](https://pkg.go.dev/time#ParseDuration) consisting of numbers and unit suffixes, such as "30s" or "2h45m". Valid time units are "s" (seconds), "m" (minutes), "h" (hours).
*
* Docs at Terraform Registry: {@link https://registry.terraform.io/providers/hashicorp/aws/6.25.0/docs/resources/vpc_encryption_control#update VpcEncryptionControl#update}
*/
readonly update?: string;
}
export declare function vpcEncryptionControlTimeoutsToTerraform(struct?: VpcEncryptionControlTimeouts | cdktf.IResolvable): any;
export declare function vpcEncryptionControlTimeoutsToHclTerraform(struct?: VpcEncryptionControlTimeouts | cdktf.IResolvable): any;
export declare class VpcEncryptionControlTimeoutsOutputReference extends cdktf.ComplexObject {
private isEmptyObject;
private resolvableValue?;
/**
* @param terraformResource The parent resource
* @param terraformAttribute The attribute on the parent resource this class is referencing
*/
constructor(terraformResource: cdktf.IInterpolatingParent, terraformAttribute: string);
get internalValue(): VpcEncryptionControlTimeouts | cdktf.IResolvable | undefined;
set internalValue(value: VpcEncryptionControlTimeouts | cdktf.IResolvable | undefined);
private _create?;
get create(): string;
set create(value: string);
resetCreate(): void;
get createInput(): string | undefined;
private _delete?;
get delete(): string;
set delete(value: string);
resetDelete(): void;
get deleteInput(): string | undefined;
private _update?;
get update(): string;
set update(value: string);
resetUpdate(): void;
get updateInput(): string | undefined;
}
/**
* Represents a {@link https://registry.terraform.io/providers/hashicorp/aws/6.25.0/docs/resources/vpc_encryption_control aws_vpc_encryption_control}
*/
export declare class VpcEncryptionControl extends cdktf.TerraformResource {
static readonly tfResourceType = "aws_vpc_encryption_control";
/**
* Generates CDKTF code for importing a VpcEncryptionControl resource upon running "cdktf plan <stack-name>"
* @param scope The scope in which to define this construct
* @param importToId The construct id used in the generated config for the VpcEncryptionControl to import
* @param importFromId The id of the existing VpcEncryptionControl that should be imported. Refer to the {@link https://registry.terraform.io/providers/hashicorp/aws/6.25.0/docs/resources/vpc_encryption_control#import import section} in the documentation of this resource for the id to use
* @param provider? Optional instance of the provider where the VpcEncryptionControl to import is found
*/
static generateConfigForImport(scope: Construct, importToId: string, importFromId: string, provider?: cdktf.TerraformProvider): cdktf.ImportableResource;
/**
* Create a new {@link https://registry.terraform.io/providers/hashicorp/aws/6.25.0/docs/resources/vpc_encryption_control aws_vpc_encryption_control} Resource
*
* @param scope The scope in which to define this construct
* @param id The scoped construct ID. Must be unique amongst siblings in the same scope
* @param options VpcEncryptionControlConfig
*/
constructor(scope: Construct, id: string, config: VpcEncryptionControlConfig);
private _egressOnlyInternetGatewayExclusion?;
get egressOnlyInternetGatewayExclusion(): string;
set egressOnlyInternetGatewayExclusion(value: string);
resetEgressOnlyInternetGatewayExclusion(): void;
get egressOnlyInternetGatewayExclusionInput(): string | undefined;
private _elasticFileSystemExclusion?;
get elasticFileSystemExclusion(): string;
set elasticFileSystemExclusion(value: string);
resetElasticFileSystemExclusion(): void;
get elasticFileSystemExclusionInput(): string | undefined;
get id(): string;
private _internetGatewayExclusion?;
get internetGatewayExclusion(): string;
set internetGatewayExclusion(value: string);
resetInternetGatewayExclusion(): void;
get internetGatewayExclusionInput(): string | undefined;
private _lambdaExclusion?;
get lambdaExclusion(): string;
set lambdaExclusion(value: string);
resetLambdaExclusion(): void;
get lambdaExclusionInput(): string | undefined;
private _mode?;
get mode(): string;
set mode(value: string);
get modeInput(): string | undefined;
private _natGatewayExclusion?;
get natGatewayExclusion(): string;
set natGatewayExclusion(value: string);
resetNatGatewayExclusion(): void;
get natGatewayExclusionInput(): string | undefined;
private _region?;
get region(): string;
set region(value: string);
resetRegion(): void;
get regionInput(): string | undefined;
private _resourceExclusions;
get resourceExclusions(): VpcEncryptionControlResourceExclusionsOutputReference;
get state(): string;
get stateMessage(): string;
private _tags?;
get tags(): {
[key: string]: string;
};
set tags(value: {
[key: string]: string;
});
resetTags(): void;
get tagsInput(): {
[key: string]: string;
} | undefined;
private _tagsAll;
get tagsAll(): cdktf.StringMap;
private _virtualPrivateGatewayExclusion?;
get virtualPrivateGatewayExclusion(): string;
set virtualPrivateGatewayExclusion(value: string);
resetVirtualPrivateGatewayExclusion(): void;
get virtualPrivateGatewayExclusionInput(): string | undefined;
private _vpcId?;
get vpcId(): string;
set vpcId(value: string);
get vpcIdInput(): string | undefined;
private _vpcLatticeExclusion?;
get vpcLatticeExclusion(): string;
set vpcLatticeExclusion(value: string);
resetVpcLatticeExclusion(): void;
get vpcLatticeExclusionInput(): string | undefined;
private _vpcPeeringExclusion?;
get vpcPeeringExclusion(): string;
set vpcPeeringExclusion(value: string);
resetVpcPeeringExclusion(): void;
get vpcPeeringExclusionInput(): string | undefined;
private _timeouts;
get timeouts(): VpcEncryptionControlTimeoutsOutputReference;
putTimeouts(value: VpcEncryptionControlTimeouts): void;
resetTimeouts(): void;
get timeoutsInput(): cdktf.IResolvable | VpcEncryptionControlTimeouts | undefined;
protected synthesizeAttributes(): {
[name: string]: any;
};
protected synthesizeHclAttributes(): {
[name: string]: any;
};
}