/**
 * 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;
    };
}
