UNPKG

@cdktf/provider-google

Version:

Prebuilt google Provider for Terraform CDK (cdktf)

181 lines (180 loc) 8.26 kB
/** * Copyright (c) HashiCorp, Inc. * SPDX-License-Identifier: MPL-2.0 */ import { Construct } from 'constructs'; import * as cdktf from 'cdktf'; export interface NetappKmsconfigConfig extends cdktf.TerraformMetaArguments { /** * Resource name of the KMS key to use. Only regional keys are supported. Format: 'projects/{{project}}/locations/{{location}}/keyRings/{{key_ring}}/cryptoKeys/{{key}}'. * * Docs at Terraform Registry: {@link https://registry.terraform.io/providers/hashicorp/google/6.13.0/docs/resources/netapp_kmsconfig#crypto_key_name NetappKmsconfig#crypto_key_name} */ readonly cryptoKeyName: string; /** * Description for the CMEK policy. * * Docs at Terraform Registry: {@link https://registry.terraform.io/providers/hashicorp/google/6.13.0/docs/resources/netapp_kmsconfig#description NetappKmsconfig#description} */ readonly description?: string; /** * Docs at Terraform Registry: {@link https://registry.terraform.io/providers/hashicorp/google/6.13.0/docs/resources/netapp_kmsconfig#id NetappKmsconfig#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; /** * Labels as key value pairs. Example: '{ "owner": "Bob", "department": "finance", "purpose": "testing" }'. * * * **Note**: This field is non-authoritative, and will only manage the labels present in your configuration. * Please refer to the field 'effective_labels' for all of the labels present on the resource. * * Docs at Terraform Registry: {@link https://registry.terraform.io/providers/hashicorp/google/6.13.0/docs/resources/netapp_kmsconfig#labels NetappKmsconfig#labels} */ readonly labels?: { [key: string]: string; }; /** * Name of the policy location. CMEK policies apply to the whole region. * * Docs at Terraform Registry: {@link https://registry.terraform.io/providers/hashicorp/google/6.13.0/docs/resources/netapp_kmsconfig#location NetappKmsconfig#location} */ readonly location: string; /** * Name of the CMEK policy. * * Docs at Terraform Registry: {@link https://registry.terraform.io/providers/hashicorp/google/6.13.0/docs/resources/netapp_kmsconfig#name NetappKmsconfig#name} */ readonly name: string; /** * Docs at Terraform Registry: {@link https://registry.terraform.io/providers/hashicorp/google/6.13.0/docs/resources/netapp_kmsconfig#project NetappKmsconfig#project} */ readonly project?: string; /** * timeouts block * * Docs at Terraform Registry: {@link https://registry.terraform.io/providers/hashicorp/google/6.13.0/docs/resources/netapp_kmsconfig#timeouts NetappKmsconfig#timeouts} */ readonly timeouts?: NetappKmsconfigTimeouts; } export interface NetappKmsconfigTimeouts { /** * Docs at Terraform Registry: {@link https://registry.terraform.io/providers/hashicorp/google/6.13.0/docs/resources/netapp_kmsconfig#create NetappKmsconfig#create} */ readonly create?: string; /** * Docs at Terraform Registry: {@link https://registry.terraform.io/providers/hashicorp/google/6.13.0/docs/resources/netapp_kmsconfig#delete NetappKmsconfig#delete} */ readonly delete?: string; /** * Docs at Terraform Registry: {@link https://registry.terraform.io/providers/hashicorp/google/6.13.0/docs/resources/netapp_kmsconfig#update NetappKmsconfig#update} */ readonly update?: string; } export declare function netappKmsconfigTimeoutsToTerraform(struct?: NetappKmsconfigTimeouts | cdktf.IResolvable): any; export declare function netappKmsconfigTimeoutsToHclTerraform(struct?: NetappKmsconfigTimeouts | cdktf.IResolvable): any; export declare class NetappKmsconfigTimeoutsOutputReference 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(): NetappKmsconfigTimeouts | cdktf.IResolvable | undefined; set internalValue(value: NetappKmsconfigTimeouts | 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/google/6.13.0/docs/resources/netapp_kmsconfig google_netapp_kmsconfig} */ export declare class NetappKmsconfig extends cdktf.TerraformResource { static readonly tfResourceType = "google_netapp_kmsconfig"; /** * Generates CDKTF code for importing a NetappKmsconfig 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 NetappKmsconfig to import * @param importFromId The id of the existing NetappKmsconfig that should be imported. Refer to the {@link https://registry.terraform.io/providers/hashicorp/google/6.13.0/docs/resources/netapp_kmsconfig#import import section} in the documentation of this resource for the id to use * @param provider? Optional instance of the provider where the NetappKmsconfig 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/netapp_kmsconfig google_netapp_kmsconfig} 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 NetappKmsconfigConfig */ constructor(scope: Construct, id: string, config: NetappKmsconfigConfig); private _cryptoKeyName?; get cryptoKeyName(): string; set cryptoKeyName(value: string); get cryptoKeyNameInput(): string | undefined; private _description?; get description(): string; set description(value: string); resetDescription(): void; get descriptionInput(): string | undefined; private _effectiveLabels; get effectiveLabels(): cdktf.StringMap; private _id?; get id(): string; set id(value: string); resetId(): void; get idInput(): string | undefined; get instructions(): string; private _labels?; get labels(): { [key: string]: string; }; set labels(value: { [key: string]: string; }); resetLabels(): void; get labelsInput(): { [key: string]: string; } | undefined; private _location?; get location(): string; set location(value: string); get locationInput(): string | undefined; private _name?; get name(): string; set name(value: string); get nameInput(): string | undefined; private _project?; get project(): string; set project(value: string); resetProject(): void; get projectInput(): string | undefined; get serviceAccount(): string; private _terraformLabels; get terraformLabels(): cdktf.StringMap; private _timeouts; get timeouts(): NetappKmsconfigTimeoutsOutputReference; putTimeouts(value: NetappKmsconfigTimeouts): void; resetTimeouts(): void; get timeoutsInput(): cdktf.IResolvable | NetappKmsconfigTimeouts | undefined; protected synthesizeAttributes(): { [name: string]: any; }; protected synthesizeHclAttributes(): { [name: string]: any; }; }