UNPKG

@cdktf/provider-google

Version:

Prebuilt google Provider for Terraform CDK (cdktf)

229 lines (228 loc) 12.3 kB
/** * Copyright (c) HashiCorp, Inc. * SPDX-License-Identifier: MPL-2.0 */ import { Construct } from 'constructs'; import * as cdktf from 'cdktf'; export interface FolderAccessApprovalSettingsConfig extends cdktf.TerraformMetaArguments { /** * The asymmetric crypto key version to use for signing approval requests. * Empty active_key_version indicates that a Google-managed key should be used for signing. * This property will be ignored if set by an ancestor of the resource, and new non-empty values may not be set. * * Docs at Terraform Registry: {@link https://registry.terraform.io/providers/hashicorp/google/6.13.0/docs/resources/folder_access_approval_settings#active_key_version FolderAccessApprovalSettings#active_key_version} */ readonly activeKeyVersion?: string; /** * ID of the folder of the access approval settings. * * Docs at Terraform Registry: {@link https://registry.terraform.io/providers/hashicorp/google/6.13.0/docs/resources/folder_access_approval_settings#folder_id FolderAccessApprovalSettings#folder_id} */ readonly folderId: string; /** * Docs at Terraform Registry: {@link https://registry.terraform.io/providers/hashicorp/google/6.13.0/docs/resources/folder_access_approval_settings#id FolderAccessApprovalSettings#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; /** * A list of email addresses to which notifications relating to approval requests should be sent. * Notifications relating to a resource will be sent to all emails in the settings of ancestor * resources of that resource. A maximum of 50 email addresses are allowed. * * Docs at Terraform Registry: {@link https://registry.terraform.io/providers/hashicorp/google/6.13.0/docs/resources/folder_access_approval_settings#notification_emails FolderAccessApprovalSettings#notification_emails} */ readonly notificationEmails?: string[]; /** * enrolled_services block * * Docs at Terraform Registry: {@link https://registry.terraform.io/providers/hashicorp/google/6.13.0/docs/resources/folder_access_approval_settings#enrolled_services FolderAccessApprovalSettings#enrolled_services} */ readonly enrolledServices: FolderAccessApprovalSettingsEnrolledServices[] | cdktf.IResolvable; /** * timeouts block * * Docs at Terraform Registry: {@link https://registry.terraform.io/providers/hashicorp/google/6.13.0/docs/resources/folder_access_approval_settings#timeouts FolderAccessApprovalSettings#timeouts} */ readonly timeouts?: FolderAccessApprovalSettingsTimeouts; } export interface FolderAccessApprovalSettingsEnrolledServices { /** * The product for which Access Approval will be enrolled. Allowed values are listed (case-sensitive): * * all * * App Engine * * BigQuery * * Cloud Bigtable * * Cloud Key Management Service * * Compute Engine * * Cloud Dataflow * * Cloud Identity and Access Management * * Cloud Pub/Sub * * Cloud Storage * * Persistent Disk * * Note: These values are supported as input, but considered a legacy format: * * all * * appengine.googleapis.com * * bigquery.googleapis.com * * bigtable.googleapis.com * * cloudkms.googleapis.com * * compute.googleapis.com * * dataflow.googleapis.com * * iam.googleapis.com * * pubsub.googleapis.com * * storage.googleapis.com * * Docs at Terraform Registry: {@link https://registry.terraform.io/providers/hashicorp/google/6.13.0/docs/resources/folder_access_approval_settings#cloud_product FolderAccessApprovalSettings#cloud_product} */ readonly cloudProduct: string; /** * The enrollment level of the service. Default value: "BLOCK_ALL" Possible values: ["BLOCK_ALL"] * * Docs at Terraform Registry: {@link https://registry.terraform.io/providers/hashicorp/google/6.13.0/docs/resources/folder_access_approval_settings#enrollment_level FolderAccessApprovalSettings#enrollment_level} */ readonly enrollmentLevel?: string; } export declare function folderAccessApprovalSettingsEnrolledServicesToTerraform(struct?: FolderAccessApprovalSettingsEnrolledServices | cdktf.IResolvable): any; export declare function folderAccessApprovalSettingsEnrolledServicesToHclTerraform(struct?: FolderAccessApprovalSettingsEnrolledServices | cdktf.IResolvable): any; export declare class FolderAccessApprovalSettingsEnrolledServicesOutputReference extends cdktf.ComplexObject { private isEmptyObject; private resolvableValue?; /** * @param terraformResource The parent resource * @param terraformAttribute The attribute on the parent resource this class is referencing * @param complexObjectIndex the index of this item in the list * @param complexObjectIsFromSet whether the list is wrapping a set (will add tolist() to be able to access an item via an index) */ constructor(terraformResource: cdktf.IInterpolatingParent, terraformAttribute: string, complexObjectIndex: number, complexObjectIsFromSet: boolean); get internalValue(): FolderAccessApprovalSettingsEnrolledServices | cdktf.IResolvable | undefined; set internalValue(value: FolderAccessApprovalSettingsEnrolledServices | cdktf.IResolvable | undefined); private _cloudProduct?; get cloudProduct(): string; set cloudProduct(value: string); get cloudProductInput(): string | undefined; private _enrollmentLevel?; get enrollmentLevel(): string; set enrollmentLevel(value: string); resetEnrollmentLevel(): void; get enrollmentLevelInput(): string | undefined; } export declare class FolderAccessApprovalSettingsEnrolledServicesList extends cdktf.ComplexList { protected terraformResource: cdktf.IInterpolatingParent; protected terraformAttribute: string; protected wrapsSet: boolean; internalValue?: FolderAccessApprovalSettingsEnrolledServices[] | cdktf.IResolvable; /** * @param terraformResource The parent resource * @param terraformAttribute The attribute on the parent resource this class is referencing * @param wrapsSet whether the list is wrapping a set (will add tolist() to be able to access an item via an index) */ constructor(terraformResource: cdktf.IInterpolatingParent, terraformAttribute: string, wrapsSet: boolean); /** * @param index the index of the item to return */ get(index: number): FolderAccessApprovalSettingsEnrolledServicesOutputReference; } export interface FolderAccessApprovalSettingsTimeouts { /** * Docs at Terraform Registry: {@link https://registry.terraform.io/providers/hashicorp/google/6.13.0/docs/resources/folder_access_approval_settings#create FolderAccessApprovalSettings#create} */ readonly create?: string; /** * Docs at Terraform Registry: {@link https://registry.terraform.io/providers/hashicorp/google/6.13.0/docs/resources/folder_access_approval_settings#delete FolderAccessApprovalSettings#delete} */ readonly delete?: string; /** * Docs at Terraform Registry: {@link https://registry.terraform.io/providers/hashicorp/google/6.13.0/docs/resources/folder_access_approval_settings#update FolderAccessApprovalSettings#update} */ readonly update?: string; } export declare function folderAccessApprovalSettingsTimeoutsToTerraform(struct?: FolderAccessApprovalSettingsTimeouts | cdktf.IResolvable): any; export declare function folderAccessApprovalSettingsTimeoutsToHclTerraform(struct?: FolderAccessApprovalSettingsTimeouts | cdktf.IResolvable): any; export declare class FolderAccessApprovalSettingsTimeoutsOutputReference 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(): FolderAccessApprovalSettingsTimeouts | cdktf.IResolvable | undefined; set internalValue(value: FolderAccessApprovalSettingsTimeouts | 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/folder_access_approval_settings google_folder_access_approval_settings} */ export declare class FolderAccessApprovalSettings extends cdktf.TerraformResource { static readonly tfResourceType = "google_folder_access_approval_settings"; /** * Generates CDKTF code for importing a FolderAccessApprovalSettings 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 FolderAccessApprovalSettings to import * @param importFromId The id of the existing FolderAccessApprovalSettings that should be imported. Refer to the {@link https://registry.terraform.io/providers/hashicorp/google/6.13.0/docs/resources/folder_access_approval_settings#import import section} in the documentation of this resource for the id to use * @param provider? Optional instance of the provider where the FolderAccessApprovalSettings 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/folder_access_approval_settings google_folder_access_approval_settings} 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 FolderAccessApprovalSettingsConfig */ constructor(scope: Construct, id: string, config: FolderAccessApprovalSettingsConfig); private _activeKeyVersion?; get activeKeyVersion(): string; set activeKeyVersion(value: string); resetActiveKeyVersion(): void; get activeKeyVersionInput(): string | undefined; get ancestorHasActiveKeyVersion(): cdktf.IResolvable; get enrolledAncestor(): cdktf.IResolvable; private _folderId?; get folderId(): string; set folderId(value: string); get folderIdInput(): string | undefined; private _id?; get id(): string; set id(value: string); resetId(): void; get idInput(): string | undefined; get invalidKeyVersion(): cdktf.IResolvable; get name(): string; private _notificationEmails?; get notificationEmails(): string[]; set notificationEmails(value: string[]); resetNotificationEmails(): void; get notificationEmailsInput(): string[] | undefined; private _enrolledServices; get enrolledServices(): FolderAccessApprovalSettingsEnrolledServicesList; putEnrolledServices(value: FolderAccessApprovalSettingsEnrolledServices[] | cdktf.IResolvable): void; get enrolledServicesInput(): cdktf.IResolvable | FolderAccessApprovalSettingsEnrolledServices[] | undefined; private _timeouts; get timeouts(): FolderAccessApprovalSettingsTimeoutsOutputReference; putTimeouts(value: FolderAccessApprovalSettingsTimeouts): void; resetTimeouts(): void; get timeoutsInput(): cdktf.IResolvable | FolderAccessApprovalSettingsTimeouts | undefined; protected synthesizeAttributes(): { [name: string]: any; }; protected synthesizeHclAttributes(): { [name: string]: any; }; }