UNPKG

@cdktf/provider-google

Version:

Prebuilt google Provider for Terraform CDK (cdktf)

1,065 lines (1,064 loc) 171 kB
"use strict"; var _a, _b, _c, _d, _e, _f, _g, _h, _j, _k; Object.defineProperty(exports, "__esModule", { value: true }); exports.NetworkSecurityServerTlsPolicy = exports.NetworkSecurityServerTlsPolicyTimeoutsOutputReference = exports.networkSecurityServerTlsPolicyTimeoutsToHclTerraform = exports.networkSecurityServerTlsPolicyTimeoutsToTerraform = exports.NetworkSecurityServerTlsPolicyServerCertificateOutputReference = exports.networkSecurityServerTlsPolicyServerCertificateToHclTerraform = exports.networkSecurityServerTlsPolicyServerCertificateToTerraform = exports.NetworkSecurityServerTlsPolicyServerCertificateGrpcEndpointOutputReference = exports.networkSecurityServerTlsPolicyServerCertificateGrpcEndpointToHclTerraform = exports.networkSecurityServerTlsPolicyServerCertificateGrpcEndpointToTerraform = exports.NetworkSecurityServerTlsPolicyServerCertificateCertificateProviderInstanceOutputReference = exports.networkSecurityServerTlsPolicyServerCertificateCertificateProviderInstanceToHclTerraform = exports.networkSecurityServerTlsPolicyServerCertificateCertificateProviderInstanceToTerraform = exports.NetworkSecurityServerTlsPolicyMtlsPolicyOutputReference = exports.networkSecurityServerTlsPolicyMtlsPolicyToHclTerraform = exports.networkSecurityServerTlsPolicyMtlsPolicyToTerraform = exports.NetworkSecurityServerTlsPolicyMtlsPolicyClientValidationCaList = exports.NetworkSecurityServerTlsPolicyMtlsPolicyClientValidationCaOutputReference = exports.networkSecurityServerTlsPolicyMtlsPolicyClientValidationCaToHclTerraform = exports.networkSecurityServerTlsPolicyMtlsPolicyClientValidationCaToTerraform = exports.NetworkSecurityServerTlsPolicyMtlsPolicyClientValidationCaGrpcEndpointOutputReference = exports.networkSecurityServerTlsPolicyMtlsPolicyClientValidationCaGrpcEndpointToHclTerraform = exports.networkSecurityServerTlsPolicyMtlsPolicyClientValidationCaGrpcEndpointToTerraform = exports.NetworkSecurityServerTlsPolicyMtlsPolicyClientValidationCaCertificateProviderInstanceOutputReference = exports.networkSecurityServerTlsPolicyMtlsPolicyClientValidationCaCertificateProviderInstanceToHclTerraform = exports.networkSecurityServerTlsPolicyMtlsPolicyClientValidationCaCertificateProviderInstanceToTerraform = void 0; const JSII_RTTI_SYMBOL_1 = Symbol.for("jsii.rtti"); const cdktf = require("cdktf"); function networkSecurityServerTlsPolicyMtlsPolicyClientValidationCaCertificateProviderInstanceToTerraform(struct) { if (!cdktf.canInspect(struct) || cdktf.Tokenization.isResolvable(struct)) { return struct; } if (cdktf.isComplexElement(struct)) { throw new Error("A complex element was used as configuration, this is not supported: https://cdk.tf/complex-object-as-configuration"); } return { plugin_instance: cdktf.stringToTerraform(struct.pluginInstance), }; } exports.networkSecurityServerTlsPolicyMtlsPolicyClientValidationCaCertificateProviderInstanceToTerraform = networkSecurityServerTlsPolicyMtlsPolicyClientValidationCaCertificateProviderInstanceToTerraform; function networkSecurityServerTlsPolicyMtlsPolicyClientValidationCaCertificateProviderInstanceToHclTerraform(struct) { if (!cdktf.canInspect(struct) || cdktf.Tokenization.isResolvable(struct)) { return struct; } if (cdktf.isComplexElement(struct)) { throw new Error("A complex element was used as configuration, this is not supported: https://cdk.tf/complex-object-as-configuration"); } const attrs = { plugin_instance: { value: cdktf.stringToHclTerraform(struct.pluginInstance), isBlock: false, type: "simple", storageClassType: "string", }, }; // remove undefined attributes return Object.fromEntries(Object.entries(attrs).filter(([_, value]) => value !== undefined && value.value !== undefined)); } exports.networkSecurityServerTlsPolicyMtlsPolicyClientValidationCaCertificateProviderInstanceToHclTerraform = networkSecurityServerTlsPolicyMtlsPolicyClientValidationCaCertificateProviderInstanceToHclTerraform; class NetworkSecurityServerTlsPolicyMtlsPolicyClientValidationCaCertificateProviderInstanceOutputReference extends cdktf.ComplexObject { /** * @param terraformResource The parent resource * @param terraformAttribute The attribute on the parent resource this class is referencing */ constructor(terraformResource, terraformAttribute) { super(terraformResource, terraformAttribute, false, 0); this.isEmptyObject = false; } get internalValue() { let hasAnyValues = this.isEmptyObject; const internalValueResult = {}; if (this._pluginInstance !== undefined) { hasAnyValues = true; internalValueResult.pluginInstance = this._pluginInstance; } return hasAnyValues ? internalValueResult : undefined; } set internalValue(value) { if (value === undefined) { this.isEmptyObject = false; this._pluginInstance = undefined; } else { this.isEmptyObject = Object.keys(value).length === 0; this._pluginInstance = value.pluginInstance; } } get pluginInstance() { return this.getStringAttribute('plugin_instance'); } set pluginInstance(value) { this._pluginInstance = value; } // Temporarily expose input value. Use with caution. get pluginInstanceInput() { return this._pluginInstance; } } exports.NetworkSecurityServerTlsPolicyMtlsPolicyClientValidationCaCertificateProviderInstanceOutputReference = NetworkSecurityServerTlsPolicyMtlsPolicyClientValidationCaCertificateProviderInstanceOutputReference; _a = JSII_RTTI_SYMBOL_1; NetworkSecurityServerTlsPolicyMtlsPolicyClientValidationCaCertificateProviderInstanceOutputReference[_a] = { fqn: "@cdktf/provider-google.networkSecurityServerTlsPolicy.NetworkSecurityServerTlsPolicyMtlsPolicyClientValidationCaCertificateProviderInstanceOutputReference", version: "14.12.0" }; function networkSecurityServerTlsPolicyMtlsPolicyClientValidationCaGrpcEndpointToTerraform(struct) { if (!cdktf.canInspect(struct) || cdktf.Tokenization.isResolvable(struct)) { return struct; } if (cdktf.isComplexElement(struct)) { throw new Error("A complex element was used as configuration, this is not supported: https://cdk.tf/complex-object-as-configuration"); } return { target_uri: cdktf.stringToTerraform(struct.targetUri), }; } exports.networkSecurityServerTlsPolicyMtlsPolicyClientValidationCaGrpcEndpointToTerraform = networkSecurityServerTlsPolicyMtlsPolicyClientValidationCaGrpcEndpointToTerraform; function networkSecurityServerTlsPolicyMtlsPolicyClientValidationCaGrpcEndpointToHclTerraform(struct) { if (!cdktf.canInspect(struct) || cdktf.Tokenization.isResolvable(struct)) { return struct; } if (cdktf.isComplexElement(struct)) { throw new Error("A complex element was used as configuration, this is not supported: https://cdk.tf/complex-object-as-configuration"); } const attrs = { target_uri: { value: cdktf.stringToHclTerraform(struct.targetUri), isBlock: false, type: "simple", storageClassType: "string", }, }; // remove undefined attributes return Object.fromEntries(Object.entries(attrs).filter(([_, value]) => value !== undefined && value.value !== undefined)); } exports.networkSecurityServerTlsPolicyMtlsPolicyClientValidationCaGrpcEndpointToHclTerraform = networkSecurityServerTlsPolicyMtlsPolicyClientValidationCaGrpcEndpointToHclTerraform; class NetworkSecurityServerTlsPolicyMtlsPolicyClientValidationCaGrpcEndpointOutputReference extends cdktf.ComplexObject { /** * @param terraformResource The parent resource * @param terraformAttribute The attribute on the parent resource this class is referencing */ constructor(terraformResource, terraformAttribute) { super(terraformResource, terraformAttribute, false, 0); this.isEmptyObject = false; } get internalValue() { let hasAnyValues = this.isEmptyObject; const internalValueResult = {}; if (this._targetUri !== undefined) { hasAnyValues = true; internalValueResult.targetUri = this._targetUri; } return hasAnyValues ? internalValueResult : undefined; } set internalValue(value) { if (value === undefined) { this.isEmptyObject = false; this._targetUri = undefined; } else { this.isEmptyObject = Object.keys(value).length === 0; this._targetUri = value.targetUri; } } get targetUri() { return this.getStringAttribute('target_uri'); } set targetUri(value) { this._targetUri = value; } // Temporarily expose input value. Use with caution. get targetUriInput() { return this._targetUri; } } exports.NetworkSecurityServerTlsPolicyMtlsPolicyClientValidationCaGrpcEndpointOutputReference = NetworkSecurityServerTlsPolicyMtlsPolicyClientValidationCaGrpcEndpointOutputReference; _b = JSII_RTTI_SYMBOL_1; NetworkSecurityServerTlsPolicyMtlsPolicyClientValidationCaGrpcEndpointOutputReference[_b] = { fqn: "@cdktf/provider-google.networkSecurityServerTlsPolicy.NetworkSecurityServerTlsPolicyMtlsPolicyClientValidationCaGrpcEndpointOutputReference", version: "14.12.0" }; function networkSecurityServerTlsPolicyMtlsPolicyClientValidationCaToTerraform(struct) { if (!cdktf.canInspect(struct) || cdktf.Tokenization.isResolvable(struct)) { return struct; } if (cdktf.isComplexElement(struct)) { throw new Error("A complex element was used as configuration, this is not supported: https://cdk.tf/complex-object-as-configuration"); } return { certificate_provider_instance: networkSecurityServerTlsPolicyMtlsPolicyClientValidationCaCertificateProviderInstanceToTerraform(struct.certificateProviderInstance), grpc_endpoint: networkSecurityServerTlsPolicyMtlsPolicyClientValidationCaGrpcEndpointToTerraform(struct.grpcEndpoint), }; } exports.networkSecurityServerTlsPolicyMtlsPolicyClientValidationCaToTerraform = networkSecurityServerTlsPolicyMtlsPolicyClientValidationCaToTerraform; function networkSecurityServerTlsPolicyMtlsPolicyClientValidationCaToHclTerraform(struct) { if (!cdktf.canInspect(struct) || cdktf.Tokenization.isResolvable(struct)) { return struct; } if (cdktf.isComplexElement(struct)) { throw new Error("A complex element was used as configuration, this is not supported: https://cdk.tf/complex-object-as-configuration"); } const attrs = { certificate_provider_instance: { value: networkSecurityServerTlsPolicyMtlsPolicyClientValidationCaCertificateProviderInstanceToHclTerraform(struct.certificateProviderInstance), isBlock: true, type: "list", storageClassType: "NetworkSecurityServerTlsPolicyMtlsPolicyClientValidationCaCertificateProviderInstanceList", }, grpc_endpoint: { value: networkSecurityServerTlsPolicyMtlsPolicyClientValidationCaGrpcEndpointToHclTerraform(struct.grpcEndpoint), isBlock: true, type: "list", storageClassType: "NetworkSecurityServerTlsPolicyMtlsPolicyClientValidationCaGrpcEndpointList", }, }; // remove undefined attributes return Object.fromEntries(Object.entries(attrs).filter(([_, value]) => value !== undefined && value.value !== undefined)); } exports.networkSecurityServerTlsPolicyMtlsPolicyClientValidationCaToHclTerraform = networkSecurityServerTlsPolicyMtlsPolicyClientValidationCaToHclTerraform; class NetworkSecurityServerTlsPolicyMtlsPolicyClientValidationCaOutputReference extends cdktf.ComplexObject { /** * @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, terraformAttribute, complexObjectIndex, complexObjectIsFromSet) { super(terraformResource, terraformAttribute, complexObjectIsFromSet, complexObjectIndex); this.isEmptyObject = false; // certificate_provider_instance - computed: false, optional: true, required: false this._certificateProviderInstance = new NetworkSecurityServerTlsPolicyMtlsPolicyClientValidationCaCertificateProviderInstanceOutputReference(this, "certificate_provider_instance"); // grpc_endpoint - computed: false, optional: true, required: false this._grpcEndpoint = new NetworkSecurityServerTlsPolicyMtlsPolicyClientValidationCaGrpcEndpointOutputReference(this, "grpc_endpoint"); } get internalValue() { if (this.resolvableValue) { return this.resolvableValue; } let hasAnyValues = this.isEmptyObject; const internalValueResult = {}; if (this._certificateProviderInstance?.internalValue !== undefined) { hasAnyValues = true; internalValueResult.certificateProviderInstance = this._certificateProviderInstance?.internalValue; } if (this._grpcEndpoint?.internalValue !== undefined) { hasAnyValues = true; internalValueResult.grpcEndpoint = this._grpcEndpoint?.internalValue; } return hasAnyValues ? internalValueResult : undefined; } set internalValue(value) { if (value === undefined) { this.isEmptyObject = false; this.resolvableValue = undefined; this._certificateProviderInstance.internalValue = undefined; this._grpcEndpoint.internalValue = undefined; } else if (cdktf.Tokenization.isResolvable(value)) { this.isEmptyObject = false; this.resolvableValue = value; } else { this.isEmptyObject = Object.keys(value).length === 0; this.resolvableValue = undefined; this._certificateProviderInstance.internalValue = value.certificateProviderInstance; this._grpcEndpoint.internalValue = value.grpcEndpoint; } } get certificateProviderInstance() { return this._certificateProviderInstance; } putCertificateProviderInstance(value) { this._certificateProviderInstance.internalValue = value; } resetCertificateProviderInstance() { this._certificateProviderInstance.internalValue = undefined; } // Temporarily expose input value. Use with caution. get certificateProviderInstanceInput() { return this._certificateProviderInstance.internalValue; } get grpcEndpoint() { return this._grpcEndpoint; } putGrpcEndpoint(value) { this._grpcEndpoint.internalValue = value; } resetGrpcEndpoint() { this._grpcEndpoint.internalValue = undefined; } // Temporarily expose input value. Use with caution. get grpcEndpointInput() { return this._grpcEndpoint.internalValue; } } exports.NetworkSecurityServerTlsPolicyMtlsPolicyClientValidationCaOutputReference = NetworkSecurityServerTlsPolicyMtlsPolicyClientValidationCaOutputReference; _c = JSII_RTTI_SYMBOL_1; NetworkSecurityServerTlsPolicyMtlsPolicyClientValidationCaOutputReference[_c] = { fqn: "@cdktf/provider-google.networkSecurityServerTlsPolicy.NetworkSecurityServerTlsPolicyMtlsPolicyClientValidationCaOutputReference", version: "14.12.0" }; class NetworkSecurityServerTlsPolicyMtlsPolicyClientValidationCaList extends cdktf.ComplexList { /** * @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, terraformAttribute, wrapsSet) { super(terraformResource, terraformAttribute, wrapsSet); this.terraformResource = terraformResource; this.terraformAttribute = terraformAttribute; this.wrapsSet = wrapsSet; } /** * @param index the index of the item to return */ get(index) { return new NetworkSecurityServerTlsPolicyMtlsPolicyClientValidationCaOutputReference(this.terraformResource, this.terraformAttribute, index, this.wrapsSet); } } exports.NetworkSecurityServerTlsPolicyMtlsPolicyClientValidationCaList = NetworkSecurityServerTlsPolicyMtlsPolicyClientValidationCaList; _d = JSII_RTTI_SYMBOL_1; NetworkSecurityServerTlsPolicyMtlsPolicyClientValidationCaList[_d] = { fqn: "@cdktf/provider-google.networkSecurityServerTlsPolicy.NetworkSecurityServerTlsPolicyMtlsPolicyClientValidationCaList", version: "14.12.0" }; function networkSecurityServerTlsPolicyMtlsPolicyToTerraform(struct) { if (!cdktf.canInspect(struct) || cdktf.Tokenization.isResolvable(struct)) { return struct; } if (cdktf.isComplexElement(struct)) { throw new Error("A complex element was used as configuration, this is not supported: https://cdk.tf/complex-object-as-configuration"); } return { client_validation_mode: cdktf.stringToTerraform(struct.clientValidationMode), client_validation_trust_config: cdktf.stringToTerraform(struct.clientValidationTrustConfig), client_validation_ca: cdktf.listMapper(networkSecurityServerTlsPolicyMtlsPolicyClientValidationCaToTerraform, true)(struct.clientValidationCa), }; } exports.networkSecurityServerTlsPolicyMtlsPolicyToTerraform = networkSecurityServerTlsPolicyMtlsPolicyToTerraform; function networkSecurityServerTlsPolicyMtlsPolicyToHclTerraform(struct) { if (!cdktf.canInspect(struct) || cdktf.Tokenization.isResolvable(struct)) { return struct; } if (cdktf.isComplexElement(struct)) { throw new Error("A complex element was used as configuration, this is not supported: https://cdk.tf/complex-object-as-configuration"); } const attrs = { client_validation_mode: { value: cdktf.stringToHclTerraform(struct.clientValidationMode), isBlock: false, type: "simple", storageClassType: "string", }, client_validation_trust_config: { value: cdktf.stringToHclTerraform(struct.clientValidationTrustConfig), isBlock: false, type: "simple", storageClassType: "string", }, client_validation_ca: { value: cdktf.listMapperHcl(networkSecurityServerTlsPolicyMtlsPolicyClientValidationCaToHclTerraform, true)(struct.clientValidationCa), isBlock: true, type: "list", storageClassType: "NetworkSecurityServerTlsPolicyMtlsPolicyClientValidationCaList", }, }; // remove undefined attributes return Object.fromEntries(Object.entries(attrs).filter(([_, value]) => value !== undefined && value.value !== undefined)); } exports.networkSecurityServerTlsPolicyMtlsPolicyToHclTerraform = networkSecurityServerTlsPolicyMtlsPolicyToHclTerraform; class NetworkSecurityServerTlsPolicyMtlsPolicyOutputReference extends cdktf.ComplexObject { /** * @param terraformResource The parent resource * @param terraformAttribute The attribute on the parent resource this class is referencing */ constructor(terraformResource, terraformAttribute) { super(terraformResource, terraformAttribute, false, 0); this.isEmptyObject = false; // client_validation_ca - computed: false, optional: true, required: false this._clientValidationCa = new NetworkSecurityServerTlsPolicyMtlsPolicyClientValidationCaList(this, "client_validation_ca", false); } get internalValue() { let hasAnyValues = this.isEmptyObject; const internalValueResult = {}; if (this._clientValidationMode !== undefined) { hasAnyValues = true; internalValueResult.clientValidationMode = this._clientValidationMode; } if (this._clientValidationTrustConfig !== undefined) { hasAnyValues = true; internalValueResult.clientValidationTrustConfig = this._clientValidationTrustConfig; } if (this._clientValidationCa?.internalValue !== undefined) { hasAnyValues = true; internalValueResult.clientValidationCa = this._clientValidationCa?.internalValue; } return hasAnyValues ? internalValueResult : undefined; } set internalValue(value) { if (value === undefined) { this.isEmptyObject = false; this._clientValidationMode = undefined; this._clientValidationTrustConfig = undefined; this._clientValidationCa.internalValue = undefined; } else { this.isEmptyObject = Object.keys(value).length === 0; this._clientValidationMode = value.clientValidationMode; this._clientValidationTrustConfig = value.clientValidationTrustConfig; this._clientValidationCa.internalValue = value.clientValidationCa; } } get clientValidationMode() { return this.getStringAttribute('client_validation_mode'); } set clientValidationMode(value) { this._clientValidationMode = value; } resetClientValidationMode() { this._clientValidationMode = undefined; } // Temporarily expose input value. Use with caution. get clientValidationModeInput() { return this._clientValidationMode; } get clientValidationTrustConfig() { return this.getStringAttribute('client_validation_trust_config'); } set clientValidationTrustConfig(value) { this._clientValidationTrustConfig = value; } resetClientValidationTrustConfig() { this._clientValidationTrustConfig = undefined; } // Temporarily expose input value. Use with caution. get clientValidationTrustConfigInput() { return this._clientValidationTrustConfig; } get clientValidationCa() { return this._clientValidationCa; } putClientValidationCa(value) { this._clientValidationCa.internalValue = value; } resetClientValidationCa() { this._clientValidationCa.internalValue = undefined; } // Temporarily expose input value. Use with caution. get clientValidationCaInput() { return this._clientValidationCa.internalValue; } } exports.NetworkSecurityServerTlsPolicyMtlsPolicyOutputReference = NetworkSecurityServerTlsPolicyMtlsPolicyOutputReference; _e = JSII_RTTI_SYMBOL_1; NetworkSecurityServerTlsPolicyMtlsPolicyOutputReference[_e] = { fqn: "@cdktf/provider-google.networkSecurityServerTlsPolicy.NetworkSecurityServerTlsPolicyMtlsPolicyOutputReference", version: "14.12.0" }; function networkSecurityServerTlsPolicyServerCertificateCertificateProviderInstanceToTerraform(struct) { if (!cdktf.canInspect(struct) || cdktf.Tokenization.isResolvable(struct)) { return struct; } if (cdktf.isComplexElement(struct)) { throw new Error("A complex element was used as configuration, this is not supported: https://cdk.tf/complex-object-as-configuration"); } return { plugin_instance: cdktf.stringToTerraform(struct.pluginInstance), }; } exports.networkSecurityServerTlsPolicyServerCertificateCertificateProviderInstanceToTerraform = networkSecurityServerTlsPolicyServerCertificateCertificateProviderInstanceToTerraform; function networkSecurityServerTlsPolicyServerCertificateCertificateProviderInstanceToHclTerraform(struct) { if (!cdktf.canInspect(struct) || cdktf.Tokenization.isResolvable(struct)) { return struct; } if (cdktf.isComplexElement(struct)) { throw new Error("A complex element was used as configuration, this is not supported: https://cdk.tf/complex-object-as-configuration"); } const attrs = { plugin_instance: { value: cdktf.stringToHclTerraform(struct.pluginInstance), isBlock: false, type: "simple", storageClassType: "string", }, }; // remove undefined attributes return Object.fromEntries(Object.entries(attrs).filter(([_, value]) => value !== undefined && value.value !== undefined)); } exports.networkSecurityServerTlsPolicyServerCertificateCertificateProviderInstanceToHclTerraform = networkSecurityServerTlsPolicyServerCertificateCertificateProviderInstanceToHclTerraform; class NetworkSecurityServerTlsPolicyServerCertificateCertificateProviderInstanceOutputReference extends cdktf.ComplexObject { /** * @param terraformResource The parent resource * @param terraformAttribute The attribute on the parent resource this class is referencing */ constructor(terraformResource, terraformAttribute) { super(terraformResource, terraformAttribute, false, 0); this.isEmptyObject = false; } get internalValue() { let hasAnyValues = this.isEmptyObject; const internalValueResult = {}; if (this._pluginInstance !== undefined) { hasAnyValues = true; internalValueResult.pluginInstance = this._pluginInstance; } return hasAnyValues ? internalValueResult : undefined; } set internalValue(value) { if (value === undefined) { this.isEmptyObject = false; this._pluginInstance = undefined; } else { this.isEmptyObject = Object.keys(value).length === 0; this._pluginInstance = value.pluginInstance; } } get pluginInstance() { return this.getStringAttribute('plugin_instance'); } set pluginInstance(value) { this._pluginInstance = value; } // Temporarily expose input value. Use with caution. get pluginInstanceInput() { return this._pluginInstance; } } exports.NetworkSecurityServerTlsPolicyServerCertificateCertificateProviderInstanceOutputReference = NetworkSecurityServerTlsPolicyServerCertificateCertificateProviderInstanceOutputReference; _f = JSII_RTTI_SYMBOL_1; NetworkSecurityServerTlsPolicyServerCertificateCertificateProviderInstanceOutputReference[_f] = { fqn: "@cdktf/provider-google.networkSecurityServerTlsPolicy.NetworkSecurityServerTlsPolicyServerCertificateCertificateProviderInstanceOutputReference", version: "14.12.0" }; function networkSecurityServerTlsPolicyServerCertificateGrpcEndpointToTerraform(struct) { if (!cdktf.canInspect(struct) || cdktf.Tokenization.isResolvable(struct)) { return struct; } if (cdktf.isComplexElement(struct)) { throw new Error("A complex element was used as configuration, this is not supported: https://cdk.tf/complex-object-as-configuration"); } return { target_uri: cdktf.stringToTerraform(struct.targetUri), }; } exports.networkSecurityServerTlsPolicyServerCertificateGrpcEndpointToTerraform = networkSecurityServerTlsPolicyServerCertificateGrpcEndpointToTerraform; function networkSecurityServerTlsPolicyServerCertificateGrpcEndpointToHclTerraform(struct) { if (!cdktf.canInspect(struct) || cdktf.Tokenization.isResolvable(struct)) { return struct; } if (cdktf.isComplexElement(struct)) { throw new Error("A complex element was used as configuration, this is not supported: https://cdk.tf/complex-object-as-configuration"); } const attrs = { target_uri: { value: cdktf.stringToHclTerraform(struct.targetUri), isBlock: false, type: "simple", storageClassType: "string", }, }; // remove undefined attributes return Object.fromEntries(Object.entries(attrs).filter(([_, value]) => value !== undefined && value.value !== undefined)); } exports.networkSecurityServerTlsPolicyServerCertificateGrpcEndpointToHclTerraform = networkSecurityServerTlsPolicyServerCertificateGrpcEndpointToHclTerraform; class NetworkSecurityServerTlsPolicyServerCertificateGrpcEndpointOutputReference extends cdktf.ComplexObject { /** * @param terraformResource The parent resource * @param terraformAttribute The attribute on the parent resource this class is referencing */ constructor(terraformResource, terraformAttribute) { super(terraformResource, terraformAttribute, false, 0); this.isEmptyObject = false; } get internalValue() { let hasAnyValues = this.isEmptyObject; const internalValueResult = {}; if (this._targetUri !== undefined) { hasAnyValues = true; internalValueResult.targetUri = this._targetUri; } return hasAnyValues ? internalValueResult : undefined; } set internalValue(value) { if (value === undefined) { this.isEmptyObject = false; this._targetUri = undefined; } else { this.isEmptyObject = Object.keys(value).length === 0; this._targetUri = value.targetUri; } } get targetUri() { return this.getStringAttribute('target_uri'); } set targetUri(value) { this._targetUri = value; } // Temporarily expose input value. Use with caution. get targetUriInput() { return this._targetUri; } } exports.NetworkSecurityServerTlsPolicyServerCertificateGrpcEndpointOutputReference = NetworkSecurityServerTlsPolicyServerCertificateGrpcEndpointOutputReference; _g = JSII_RTTI_SYMBOL_1; NetworkSecurityServerTlsPolicyServerCertificateGrpcEndpointOutputReference[_g] = { fqn: "@cdktf/provider-google.networkSecurityServerTlsPolicy.NetworkSecurityServerTlsPolicyServerCertificateGrpcEndpointOutputReference", version: "14.12.0" }; function networkSecurityServerTlsPolicyServerCertificateToTerraform(struct) { if (!cdktf.canInspect(struct) || cdktf.Tokenization.isResolvable(struct)) { return struct; } if (cdktf.isComplexElement(struct)) { throw new Error("A complex element was used as configuration, this is not supported: https://cdk.tf/complex-object-as-configuration"); } return { certificate_provider_instance: networkSecurityServerTlsPolicyServerCertificateCertificateProviderInstanceToTerraform(struct.certificateProviderInstance), grpc_endpoint: networkSecurityServerTlsPolicyServerCertificateGrpcEndpointToTerraform(struct.grpcEndpoint), }; } exports.networkSecurityServerTlsPolicyServerCertificateToTerraform = networkSecurityServerTlsPolicyServerCertificateToTerraform; function networkSecurityServerTlsPolicyServerCertificateToHclTerraform(struct) { if (!cdktf.canInspect(struct) || cdktf.Tokenization.isResolvable(struct)) { return struct; } if (cdktf.isComplexElement(struct)) { throw new Error("A complex element was used as configuration, this is not supported: https://cdk.tf/complex-object-as-configuration"); } const attrs = { certificate_provider_instance: { value: networkSecurityServerTlsPolicyServerCertificateCertificateProviderInstanceToHclTerraform(struct.certificateProviderInstance), isBlock: true, type: "list", storageClassType: "NetworkSecurityServerTlsPolicyServerCertificateCertificateProviderInstanceList", }, grpc_endpoint: { value: networkSecurityServerTlsPolicyServerCertificateGrpcEndpointToHclTerraform(struct.grpcEndpoint), isBlock: true, type: "list", storageClassType: "NetworkSecurityServerTlsPolicyServerCertificateGrpcEndpointList", }, }; // remove undefined attributes return Object.fromEntries(Object.entries(attrs).filter(([_, value]) => value !== undefined && value.value !== undefined)); } exports.networkSecurityServerTlsPolicyServerCertificateToHclTerraform = networkSecurityServerTlsPolicyServerCertificateToHclTerraform; class NetworkSecurityServerTlsPolicyServerCertificateOutputReference extends cdktf.ComplexObject { /** * @param terraformResource The parent resource * @param terraformAttribute The attribute on the parent resource this class is referencing */ constructor(terraformResource, terraformAttribute) { super(terraformResource, terraformAttribute, false, 0); this.isEmptyObject = false; // certificate_provider_instance - computed: false, optional: true, required: false this._certificateProviderInstance = new NetworkSecurityServerTlsPolicyServerCertificateCertificateProviderInstanceOutputReference(this, "certificate_provider_instance"); // grpc_endpoint - computed: false, optional: true, required: false this._grpcEndpoint = new NetworkSecurityServerTlsPolicyServerCertificateGrpcEndpointOutputReference(this, "grpc_endpoint"); } get internalValue() { let hasAnyValues = this.isEmptyObject; const internalValueResult = {}; if (this._certificateProviderInstance?.internalValue !== undefined) { hasAnyValues = true; internalValueResult.certificateProviderInstance = this._certificateProviderInstance?.internalValue; } if (this._grpcEndpoint?.internalValue !== undefined) { hasAnyValues = true; internalValueResult.grpcEndpoint = this._grpcEndpoint?.internalValue; } return hasAnyValues ? internalValueResult : undefined; } set internalValue(value) { if (value === undefined) { this.isEmptyObject = false; this._certificateProviderInstance.internalValue = undefined; this._grpcEndpoint.internalValue = undefined; } else { this.isEmptyObject = Object.keys(value).length === 0; this._certificateProviderInstance.internalValue = value.certificateProviderInstance; this._grpcEndpoint.internalValue = value.grpcEndpoint; } } get certificateProviderInstance() { return this._certificateProviderInstance; } putCertificateProviderInstance(value) { this._certificateProviderInstance.internalValue = value; } resetCertificateProviderInstance() { this._certificateProviderInstance.internalValue = undefined; } // Temporarily expose input value. Use with caution. get certificateProviderInstanceInput() { return this._certificateProviderInstance.internalValue; } get grpcEndpoint() { return this._grpcEndpoint; } putGrpcEndpoint(value) { this._grpcEndpoint.internalValue = value; } resetGrpcEndpoint() { this._grpcEndpoint.internalValue = undefined; } // Temporarily expose input value. Use with caution. get grpcEndpointInput() { return this._grpcEndpoint.internalValue; } } exports.NetworkSecurityServerTlsPolicyServerCertificateOutputReference = NetworkSecurityServerTlsPolicyServerCertificateOutputReference; _h = JSII_RTTI_SYMBOL_1; NetworkSecurityServerTlsPolicyServerCertificateOutputReference[_h] = { fqn: "@cdktf/provider-google.networkSecurityServerTlsPolicy.NetworkSecurityServerTlsPolicyServerCertificateOutputReference", version: "14.12.0" }; function networkSecurityServerTlsPolicyTimeoutsToTerraform(struct) { if (!cdktf.canInspect(struct) || cdktf.Tokenization.isResolvable(struct)) { return struct; } if (cdktf.isComplexElement(struct)) { throw new Error("A complex element was used as configuration, this is not supported: https://cdk.tf/complex-object-as-configuration"); } return { create: cdktf.stringToTerraform(struct.create), delete: cdktf.stringToTerraform(struct.delete), update: cdktf.stringToTerraform(struct.update), }; } exports.networkSecurityServerTlsPolicyTimeoutsToTerraform = networkSecurityServerTlsPolicyTimeoutsToTerraform; function networkSecurityServerTlsPolicyTimeoutsToHclTerraform(struct) { if (!cdktf.canInspect(struct) || cdktf.Tokenization.isResolvable(struct)) { return struct; } if (cdktf.isComplexElement(struct)) { throw new Error("A complex element was used as configuration, this is not supported: https://cdk.tf/complex-object-as-configuration"); } const attrs = { create: { value: cdktf.stringToHclTerraform(struct.create), isBlock: false, type: "simple", storageClassType: "string", }, delete: { value: cdktf.stringToHclTerraform(struct.delete), isBlock: false, type: "simple", storageClassType: "string", }, update: { value: cdktf.stringToHclTerraform(struct.update), isBlock: false, type: "simple", storageClassType: "string", }, }; // remove undefined attributes return Object.fromEntries(Object.entries(attrs).filter(([_, value]) => value !== undefined && value.value !== undefined)); } exports.networkSecurityServerTlsPolicyTimeoutsToHclTerraform = networkSecurityServerTlsPolicyTimeoutsToHclTerraform; class NetworkSecurityServerTlsPolicyTimeoutsOutputReference extends cdktf.ComplexObject { /** * @param terraformResource The parent resource * @param terraformAttribute The attribute on the parent resource this class is referencing */ constructor(terraformResource, terraformAttribute) { super(terraformResource, terraformAttribute, false); this.isEmptyObject = false; } get internalValue() { if (this.resolvableValue) { return this.resolvableValue; } let hasAnyValues = this.isEmptyObject; const internalValueResult = {}; if (this._create !== undefined) { hasAnyValues = true; internalValueResult.create = this._create; } if (this._delete !== undefined) { hasAnyValues = true; internalValueResult.delete = this._delete; } if (this._update !== undefined) { hasAnyValues = true; internalValueResult.update = this._update; } return hasAnyValues ? internalValueResult : undefined; } set internalValue(value) { if (value === undefined) { this.isEmptyObject = false; this.resolvableValue = undefined; this._create = undefined; this._delete = undefined; this._update = undefined; } else if (cdktf.Tokenization.isResolvable(value)) { this.isEmptyObject = false; this.resolvableValue = value; } else { this.isEmptyObject = Object.keys(value).length === 0; this.resolvableValue = undefined; this._create = value.create; this._delete = value.delete; this._update = value.update; } } get create() { return this.getStringAttribute('create'); } set create(value) { this._create = value; } resetCreate() { this._create = undefined; } // Temporarily expose input value. Use with caution. get createInput() { return this._create; } get delete() { return this.getStringAttribute('delete'); } set delete(value) { this._delete = value; } resetDelete() { this._delete = undefined; } // Temporarily expose input value. Use with caution. get deleteInput() { return this._delete; } get update() { return this.getStringAttribute('update'); } set update(value) { this._update = value; } resetUpdate() { this._update = undefined; } // Temporarily expose input value. Use with caution. get updateInput() { return this._update; } } exports.NetworkSecurityServerTlsPolicyTimeoutsOutputReference = NetworkSecurityServerTlsPolicyTimeoutsOutputReference; _j = JSII_RTTI_SYMBOL_1; NetworkSecurityServerTlsPolicyTimeoutsOutputReference[_j] = { fqn: "@cdktf/provider-google.networkSecurityServerTlsPolicy.NetworkSecurityServerTlsPolicyTimeoutsOutputReference", version: "14.12.0" }; /** * Represents a {@link https://registry.terraform.io/providers/hashicorp/google/6.13.0/docs/resources/network_security_server_tls_policy google_network_security_server_tls_policy} */ class NetworkSecurityServerTlsPolicy extends cdktf.TerraformResource { // ============== // STATIC Methods // ============== /** * Generates CDKTF code for importing a NetworkSecurityServerTlsPolicy 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 NetworkSecurityServerTlsPolicy to import * @param importFromId The id of the existing NetworkSecurityServerTlsPolicy that should be imported. Refer to the {@link https://registry.terraform.io/providers/hashicorp/google/6.13.0/docs/resources/network_security_server_tls_policy#import import section} in the documentation of this resource for the id to use * @param provider? Optional instance of the provider where the NetworkSecurityServerTlsPolicy to import is found */ static generateConfigForImport(scope, importToId, importFromId, provider) { return new cdktf.ImportableResource(scope, importToId, { terraformResourceType: "google_network_security_server_tls_policy", importId: importFromId, provider }); } // =========== // INITIALIZER // =========== /** * Create a new {@link https://registry.terraform.io/providers/hashicorp/google/6.13.0/docs/resources/network_security_server_tls_policy google_network_security_server_tls_policy} 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 NetworkSecurityServerTlsPolicyConfig */ constructor(scope, id, config) { super(scope, id, { terraformResourceType: 'google_network_security_server_tls_policy', terraformGeneratorMetadata: { providerName: 'google', providerVersion: '6.13.0', providerVersionConstraint: '~> 6.0' }, provider: config.provider, dependsOn: config.dependsOn, count: config.count, lifecycle: config.lifecycle, provisioners: config.provisioners, connection: config.connection, forEach: config.forEach }); // effective_labels - computed: true, optional: false, required: false this._effectiveLabels = new cdktf.StringMap(this, "effective_labels"); // terraform_labels - computed: true, optional: false, required: false this._terraformLabels = new cdktf.StringMap(this, "terraform_labels"); // mtls_policy - computed: false, optional: true, required: false this._mtlsPolicy = new NetworkSecurityServerTlsPolicyMtlsPolicyOutputReference(this, "mtls_policy"); // server_certificate - computed: false, optional: true, required: false this._serverCertificate = new NetworkSecurityServerTlsPolicyServerCertificateOutputReference(this, "server_certificate"); // timeouts - computed: false, optional: true, required: false this._timeouts = new NetworkSecurityServerTlsPolicyTimeoutsOutputReference(this, "timeouts"); this._allowOpen = config.allowOpen; this._description = config.description; this._id = config.id; this._labels = config.labels; this._location = config.location; this._name = config.name; this._project = config.project; this._mtlsPolicy.internalValue = config.mtlsPolicy; this._serverCertificate.internalValue = config.serverCertificate; this._timeouts.internalValue = config.timeouts; } get allowOpen() { return this.getBooleanAttribute('allow_open'); } set allowOpen(value) { this._allowOpen = value; } resetAllowOpen() { this._allowOpen = undefined; } // Temporarily expose input value. Use with caution. get allowOpenInput() { return this._allowOpen; } // create_time - computed: true, optional: false, required: false get createTime() { return this.getStringAttribute('create_time'); } get description() { return this.getStringAttribute('description'); } set description(value) { this._description = value; } resetDescription() { this._description = undefined; } // Temporarily expose input value. Use with caution. get descriptionInput() { return this._description; } get effectiveLabels() { return this._effectiveLabels; } get id() { return this.getStringAttribute('id'); } set id(value) { this._id = value; } resetId() { this._id = undefined; } // Temporarily expose input value. Use with caution. get idInput() { return this._id; } get labels() { return this.getStringMapAttribute('labels'); } set labels(value) { this._labels = value; } resetLabels() { this._labels = undefined; } // Temporarily expose input value. Use with caution. get labelsInput() { return this._labels; } get location() { return this.getStringAttribute('location'); } set location(value) { this._location = value; } resetLocation() { this._location = undefined; } // Temporarily expose input value. Use with caution. get locationInput() { return this._location; } get name() { return this.getStringAttribute('name'); } set name(value) { this._name = value; } // Temporarily expose input value. Use with caution. get nameInput() { return this._name; } get project() { return this.getStringAttribute('project'); } set project(value) { this._project = value; } resetProject() { this._project = undefined; } // Temporarily expose input value. Use with caution. get projectInput() { return this._project; } get terraformLabels() { return this._terraformLabels; } // update_time - computed: true, optional: false, required: false get updateTime() { return this.getStringAttribute('update_time'); } get mtlsPolicy() { return this._mtlsPolicy; } putMtlsPolicy(value) { this._mtlsPolicy.internalValue = value; } resetMtlsPolicy() { this._mtlsPolicy.internalValue = undefined; } // Temporarily expose input value. Use with caution. get mtlsPolicyInput() { return this._mtlsPolicy.internalValue; } get serverCertificate() { return this._serverCertificate; } putServerCertificate(value) { this._serverCertificate.internalValue = value; } resetServerCertificate() { this._serverCertificate.internalValue = undefined; } // Temporarily expose input value. Use with caution. get serverCertificateInput() { return this._serverCertificate.internalValue; } get timeouts() { return this._timeouts; } putTimeouts(value) { this._timeouts.internalValue = value; } resetTimeouts() { this._timeouts.internalValue = undefined; } // Temporarily expose input value. Use with caution. get timeoutsInput() { return this._timeouts.internalValue; } // ========= // SYNTHESIS // ========= synthesizeAttributes() { return { allow_open: cdktf.booleanToTerraform(this._allowOpen), description: cdktf.stringToTerraform(this._description), id: cdktf.stringToTerraform(this._id), labels: cdktf.hashMapper(cdktf.stringToTerraform)(this._labels), location: cdktf.stringToTerraform(this._location), name: cdktf.stringToTerraform(this._name), project: cdktf.stringToTerraform(this._project), mtls_policy: networkSecurityServerTlsPolicyMtlsPolicyToTerraform(this._mtlsPolicy.internalValue), server_certificate: networkSecurityServerTlsPolicyServerCertificateToTerraform(this._serverCertificate.internalValue), timeouts: networkSecurityServerTlsPolicyTimeoutsToTerraform(this._timeouts.internalValue), }; } synthesizeHclAttributes() { const attrs = { allow_open: { value: cdktf.booleanToHclTerraform(this._allowOpen), isBlock: false, type: "simple", storageClassType: "boolean", }, description: { value: cdktf.stringToHclTerraform(this._description), isBlock: false, type: "simple", storageClassType: "string", }, id: { value: cdktf.stringToHclTerraform(this._id), isBlock: false, type: "simple", storageClassType: "string", }, labels: { value: cdktf.hashMapperHcl(cdktf.stringToHclTerraform)(this._labels), isBlock: false, type: "map", storageClassType: "stringMap", }, location: { value: cdktf.stringToHclTerraform(this._location), isBlock: false, type: "simple", storageClassType: "string", },