@cdktf/provider-google
Version:
Prebuilt google Provider for Terraform CDK (cdktf)
185 lines (184 loc) • 9.69 kB
TypeScript
/**
* Copyright (c) HashiCorp, Inc.
* SPDX-License-Identifier: MPL-2.0
*/
import { Construct } from 'constructs';
import * as cdktf from 'cdktf';
export interface ComputeManagedSslCertificateConfig extends cdktf.TerraformMetaArguments {
/**
* An optional description of this resource.
*
* Docs at Terraform Registry: {@link https://registry.terraform.io/providers/hashicorp/google/6.13.0/docs/resources/compute_managed_ssl_certificate#description ComputeManagedSslCertificate#description}
*/
readonly description?: string;
/**
* Docs at Terraform Registry: {@link https://registry.terraform.io/providers/hashicorp/google/6.13.0/docs/resources/compute_managed_ssl_certificate#id ComputeManagedSslCertificate#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.
*/
readonly id?: string;
/**
* Name of the resource. Provided by the client when the resource is
* created. The name must be 1-63 characters long, and comply with
* RFC1035. Specifically, the name must be 1-63 characters long and match
* the regular expression '[a-z]([-a-z0-9]*[a-z0-9])?' which means the
* first character must be a lowercase letter, and all following
* characters must be a dash, lowercase letter, or digit, except the last
* character, which cannot be a dash.
*
* These are in the same namespace as the managed SSL certificates.
*
* Docs at Terraform Registry: {@link https://registry.terraform.io/providers/hashicorp/google/6.13.0/docs/resources/compute_managed_ssl_certificate#name ComputeManagedSslCertificate#name}
*/
readonly name?: string;
/**
* Docs at Terraform Registry: {@link https://registry.terraform.io/providers/hashicorp/google/6.13.0/docs/resources/compute_managed_ssl_certificate#project ComputeManagedSslCertificate#project}
*/
readonly project?: string;
/**
* Enum field whose value is always 'MANAGED' - used to signal to the API
* which type this is. Default value: "MANAGED" Possible values: ["MANAGED"]
*
* Docs at Terraform Registry: {@link https://registry.terraform.io/providers/hashicorp/google/6.13.0/docs/resources/compute_managed_ssl_certificate#type ComputeManagedSslCertificate#type}
*/
readonly type?: string;
/**
* managed block
*
* Docs at Terraform Registry: {@link https://registry.terraform.io/providers/hashicorp/google/6.13.0/docs/resources/compute_managed_ssl_certificate#managed ComputeManagedSslCertificate#managed}
*/
readonly managed?: ComputeManagedSslCertificateManaged;
/**
* timeouts block
*
* Docs at Terraform Registry: {@link https://registry.terraform.io/providers/hashicorp/google/6.13.0/docs/resources/compute_managed_ssl_certificate#timeouts ComputeManagedSslCertificate#timeouts}
*/
readonly timeouts?: ComputeManagedSslCertificateTimeouts;
}
export interface ComputeManagedSslCertificateManaged {
/**
* Domains for which a managed SSL certificate will be valid. Currently,
* there can be up to 100 domains in this list.
*
* Docs at Terraform Registry: {@link https://registry.terraform.io/providers/hashicorp/google/6.13.0/docs/resources/compute_managed_ssl_certificate#domains ComputeManagedSslCertificate#domains}
*/
readonly domains: string[];
}
export declare function computeManagedSslCertificateManagedToTerraform(struct?: ComputeManagedSslCertificateManagedOutputReference | ComputeManagedSslCertificateManaged): any;
export declare function computeManagedSslCertificateManagedToHclTerraform(struct?: ComputeManagedSslCertificateManagedOutputReference | ComputeManagedSslCertificateManaged): any;
export declare class ComputeManagedSslCertificateManagedOutputReference 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(): ComputeManagedSslCertificateManaged | undefined;
set internalValue(value: ComputeManagedSslCertificateManaged | undefined);
private _domains?;
get domains(): string[];
set domains(value: string[]);
get domainsInput(): string[] | undefined;
}
export interface ComputeManagedSslCertificateTimeouts {
/**
* Docs at Terraform Registry: {@link https://registry.terraform.io/providers/hashicorp/google/6.13.0/docs/resources/compute_managed_ssl_certificate#create ComputeManagedSslCertificate#create}
*/
readonly create?: string;
/**
* Docs at Terraform Registry: {@link https://registry.terraform.io/providers/hashicorp/google/6.13.0/docs/resources/compute_managed_ssl_certificate#delete ComputeManagedSslCertificate#delete}
*/
readonly delete?: string;
}
export declare function computeManagedSslCertificateTimeoutsToTerraform(struct?: ComputeManagedSslCertificateTimeouts | cdktf.IResolvable): any;
export declare function computeManagedSslCertificateTimeoutsToHclTerraform(struct?: ComputeManagedSslCertificateTimeouts | cdktf.IResolvable): any;
export declare class ComputeManagedSslCertificateTimeoutsOutputReference 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(): ComputeManagedSslCertificateTimeouts | cdktf.IResolvable | undefined;
set internalValue(value: ComputeManagedSslCertificateTimeouts | 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;
}
/**
* Represents a {@link https://registry.terraform.io/providers/hashicorp/google/6.13.0/docs/resources/compute_managed_ssl_certificate google_compute_managed_ssl_certificate}
*/
export declare class ComputeManagedSslCertificate extends cdktf.TerraformResource {
static readonly tfResourceType = "google_compute_managed_ssl_certificate";
/**
* Generates CDKTF code for importing a ComputeManagedSslCertificate 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 ComputeManagedSslCertificate to import
* @param importFromId The id of the existing ComputeManagedSslCertificate that should be imported. Refer to the {@link https://registry.terraform.io/providers/hashicorp/google/6.13.0/docs/resources/compute_managed_ssl_certificate#import import section} in the documentation of this resource for the id to use
* @param provider? Optional instance of the provider where the ComputeManagedSslCertificate 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/google/6.13.0/docs/resources/compute_managed_ssl_certificate google_compute_managed_ssl_certificate} 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 ComputeManagedSslCertificateConfig = {}
*/
constructor(scope: Construct, id: string, config?: ComputeManagedSslCertificateConfig);
get certificateId(): number;
get creationTimestamp(): string;
private _description?;
get description(): string;
set description(value: string);
resetDescription(): void;
get descriptionInput(): string | undefined;
get expireTime(): string;
private _id?;
get id(): string;
set id(value: string);
resetId(): void;
get idInput(): string | undefined;
private _name?;
get name(): string;
set name(value: string);
resetName(): void;
get nameInput(): string | undefined;
private _project?;
get project(): string;
set project(value: string);
resetProject(): void;
get projectInput(): string | undefined;
get selfLink(): string;
get subjectAlternativeNames(): string[];
private _type?;
get type(): string;
set type(value: string);
resetType(): void;
get typeInput(): string | undefined;
private _managed;
get managed(): ComputeManagedSslCertificateManagedOutputReference;
putManaged(value: ComputeManagedSslCertificateManaged): void;
resetManaged(): void;
get managedInput(): ComputeManagedSslCertificateManaged | undefined;
private _timeouts;
get timeouts(): ComputeManagedSslCertificateTimeoutsOutputReference;
putTimeouts(value: ComputeManagedSslCertificateTimeouts): void;
resetTimeouts(): void;
get timeoutsInput(): cdktf.IResolvable | ComputeManagedSslCertificateTimeouts | undefined;
protected synthesizeAttributes(): {
[name: string]: any;
};
protected synthesizeHclAttributes(): {
[name: string]: any;
};
}