@cdktf/provider-google
Version:
Prebuilt google Provider for Terraform CDK (cdktf)
1,042 lines • 161 kB
JavaScript
"use strict";
var _a, _b, _c, _d, _e, _f, _g, _h, _j, _k;
Object.defineProperty(exports, "__esModule", { value: true });
exports.AccessContextManagerServicePerimeterDryRunEgressPolicy = exports.AccessContextManagerServicePerimeterDryRunEgressPolicyTimeoutsOutputReference = exports.AccessContextManagerServicePerimeterDryRunEgressPolicyEgressToOutputReference = exports.AccessContextManagerServicePerimeterDryRunEgressPolicyEgressToOperationsList = exports.AccessContextManagerServicePerimeterDryRunEgressPolicyEgressToOperationsOutputReference = exports.AccessContextManagerServicePerimeterDryRunEgressPolicyEgressToOperationsMethodSelectorsList = exports.AccessContextManagerServicePerimeterDryRunEgressPolicyEgressToOperationsMethodSelectorsOutputReference = exports.AccessContextManagerServicePerimeterDryRunEgressPolicyEgressFromOutputReference = exports.AccessContextManagerServicePerimeterDryRunEgressPolicyEgressFromSourcesList = exports.AccessContextManagerServicePerimeterDryRunEgressPolicyEgressFromSourcesOutputReference = void 0;
exports.accessContextManagerServicePerimeterDryRunEgressPolicyEgressFromSourcesToTerraform = accessContextManagerServicePerimeterDryRunEgressPolicyEgressFromSourcesToTerraform;
exports.accessContextManagerServicePerimeterDryRunEgressPolicyEgressFromSourcesToHclTerraform = accessContextManagerServicePerimeterDryRunEgressPolicyEgressFromSourcesToHclTerraform;
exports.accessContextManagerServicePerimeterDryRunEgressPolicyEgressFromToTerraform = accessContextManagerServicePerimeterDryRunEgressPolicyEgressFromToTerraform;
exports.accessContextManagerServicePerimeterDryRunEgressPolicyEgressFromToHclTerraform = accessContextManagerServicePerimeterDryRunEgressPolicyEgressFromToHclTerraform;
exports.accessContextManagerServicePerimeterDryRunEgressPolicyEgressToOperationsMethodSelectorsToTerraform = accessContextManagerServicePerimeterDryRunEgressPolicyEgressToOperationsMethodSelectorsToTerraform;
exports.accessContextManagerServicePerimeterDryRunEgressPolicyEgressToOperationsMethodSelectorsToHclTerraform = accessContextManagerServicePerimeterDryRunEgressPolicyEgressToOperationsMethodSelectorsToHclTerraform;
exports.accessContextManagerServicePerimeterDryRunEgressPolicyEgressToOperationsToTerraform = accessContextManagerServicePerimeterDryRunEgressPolicyEgressToOperationsToTerraform;
exports.accessContextManagerServicePerimeterDryRunEgressPolicyEgressToOperationsToHclTerraform = accessContextManagerServicePerimeterDryRunEgressPolicyEgressToOperationsToHclTerraform;
exports.accessContextManagerServicePerimeterDryRunEgressPolicyEgressToToTerraform = accessContextManagerServicePerimeterDryRunEgressPolicyEgressToToTerraform;
exports.accessContextManagerServicePerimeterDryRunEgressPolicyEgressToToHclTerraform = accessContextManagerServicePerimeterDryRunEgressPolicyEgressToToHclTerraform;
exports.accessContextManagerServicePerimeterDryRunEgressPolicyTimeoutsToTerraform = accessContextManagerServicePerimeterDryRunEgressPolicyTimeoutsToTerraform;
exports.accessContextManagerServicePerimeterDryRunEgressPolicyTimeoutsToHclTerraform = accessContextManagerServicePerimeterDryRunEgressPolicyTimeoutsToHclTerraform;
const JSII_RTTI_SYMBOL_1 = Symbol.for("jsii.rtti");
const cdktf = require("cdktf");
function accessContextManagerServicePerimeterDryRunEgressPolicyEgressFromSourcesToTerraform(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 {
access_level: cdktf.stringToTerraform(struct.accessLevel),
resource: cdktf.stringToTerraform(struct.resource),
};
}
function accessContextManagerServicePerimeterDryRunEgressPolicyEgressFromSourcesToHclTerraform(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 = {
access_level: {
value: cdktf.stringToHclTerraform(struct.accessLevel),
isBlock: false,
type: "simple",
storageClassType: "string",
},
resource: {
value: cdktf.stringToHclTerraform(struct.resource),
isBlock: false,
type: "simple",
storageClassType: "string",
},
};
// remove undefined attributes
return Object.fromEntries(Object.entries(attrs).filter(([_, value]) => value !== undefined && value.value !== undefined));
}
class AccessContextManagerServicePerimeterDryRunEgressPolicyEgressFromSourcesOutputReference 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;
}
get internalValue() {
if (this.resolvableValue) {
return this.resolvableValue;
}
let hasAnyValues = this.isEmptyObject;
const internalValueResult = {};
if (this._accessLevel !== undefined) {
hasAnyValues = true;
internalValueResult.accessLevel = this._accessLevel;
}
if (this._resource !== undefined) {
hasAnyValues = true;
internalValueResult.resource = this._resource;
}
return hasAnyValues ? internalValueResult : undefined;
}
set internalValue(value) {
if (value === undefined) {
this.isEmptyObject = false;
this.resolvableValue = undefined;
this._accessLevel = undefined;
this._resource = 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._accessLevel = value.accessLevel;
this._resource = value.resource;
}
}
get accessLevel() {
return this.getStringAttribute('access_level');
}
set accessLevel(value) {
this._accessLevel = value;
}
resetAccessLevel() {
this._accessLevel = undefined;
}
// Temporarily expose input value. Use with caution.
get accessLevelInput() {
return this._accessLevel;
}
get resource() {
return this.getStringAttribute('resource');
}
set resource(value) {
this._resource = value;
}
resetResource() {
this._resource = undefined;
}
// Temporarily expose input value. Use with caution.
get resourceInput() {
return this._resource;
}
}
exports.AccessContextManagerServicePerimeterDryRunEgressPolicyEgressFromSourcesOutputReference = AccessContextManagerServicePerimeterDryRunEgressPolicyEgressFromSourcesOutputReference;
_a = JSII_RTTI_SYMBOL_1;
AccessContextManagerServicePerimeterDryRunEgressPolicyEgressFromSourcesOutputReference[_a] = { fqn: "@cdktf/provider-google.accessContextManagerServicePerimeterDryRunEgressPolicy.AccessContextManagerServicePerimeterDryRunEgressPolicyEgressFromSourcesOutputReference", version: "14.35.1" };
class AccessContextManagerServicePerimeterDryRunEgressPolicyEgressFromSourcesList 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 AccessContextManagerServicePerimeterDryRunEgressPolicyEgressFromSourcesOutputReference(this.terraformResource, this.terraformAttribute, index, this.wrapsSet);
}
}
exports.AccessContextManagerServicePerimeterDryRunEgressPolicyEgressFromSourcesList = AccessContextManagerServicePerimeterDryRunEgressPolicyEgressFromSourcesList;
_b = JSII_RTTI_SYMBOL_1;
AccessContextManagerServicePerimeterDryRunEgressPolicyEgressFromSourcesList[_b] = { fqn: "@cdktf/provider-google.accessContextManagerServicePerimeterDryRunEgressPolicy.AccessContextManagerServicePerimeterDryRunEgressPolicyEgressFromSourcesList", version: "14.35.1" };
function accessContextManagerServicePerimeterDryRunEgressPolicyEgressFromToTerraform(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 {
identities: cdktf.listMapper(cdktf.stringToTerraform, false)(struct.identities),
identity_type: cdktf.stringToTerraform(struct.identityType),
source_restriction: cdktf.stringToTerraform(struct.sourceRestriction),
sources: cdktf.listMapper(accessContextManagerServicePerimeterDryRunEgressPolicyEgressFromSourcesToTerraform, true)(struct.sources),
};
}
function accessContextManagerServicePerimeterDryRunEgressPolicyEgressFromToHclTerraform(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 = {
identities: {
value: cdktf.listMapperHcl(cdktf.stringToHclTerraform, false)(struct.identities),
isBlock: false,
type: "list",
storageClassType: "stringList",
},
identity_type: {
value: cdktf.stringToHclTerraform(struct.identityType),
isBlock: false,
type: "simple",
storageClassType: "string",
},
source_restriction: {
value: cdktf.stringToHclTerraform(struct.sourceRestriction),
isBlock: false,
type: "simple",
storageClassType: "string",
},
sources: {
value: cdktf.listMapperHcl(accessContextManagerServicePerimeterDryRunEgressPolicyEgressFromSourcesToHclTerraform, true)(struct.sources),
isBlock: true,
type: "list",
storageClassType: "AccessContextManagerServicePerimeterDryRunEgressPolicyEgressFromSourcesList",
},
};
// remove undefined attributes
return Object.fromEntries(Object.entries(attrs).filter(([_, value]) => value !== undefined && value.value !== undefined));
}
class AccessContextManagerServicePerimeterDryRunEgressPolicyEgressFromOutputReference 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;
// sources - computed: false, optional: true, required: false
this._sources = new AccessContextManagerServicePerimeterDryRunEgressPolicyEgressFromSourcesList(this, "sources", false);
}
get internalValue() {
let hasAnyValues = this.isEmptyObject;
const internalValueResult = {};
if (this._identities !== undefined) {
hasAnyValues = true;
internalValueResult.identities = this._identities;
}
if (this._identityType !== undefined) {
hasAnyValues = true;
internalValueResult.identityType = this._identityType;
}
if (this._sourceRestriction !== undefined) {
hasAnyValues = true;
internalValueResult.sourceRestriction = this._sourceRestriction;
}
if (this._sources?.internalValue !== undefined) {
hasAnyValues = true;
internalValueResult.sources = this._sources?.internalValue;
}
return hasAnyValues ? internalValueResult : undefined;
}
set internalValue(value) {
if (value === undefined) {
this.isEmptyObject = false;
this._identities = undefined;
this._identityType = undefined;
this._sourceRestriction = undefined;
this._sources.internalValue = undefined;
}
else {
this.isEmptyObject = Object.keys(value).length === 0;
this._identities = value.identities;
this._identityType = value.identityType;
this._sourceRestriction = value.sourceRestriction;
this._sources.internalValue = value.sources;
}
}
get identities() {
return this.getListAttribute('identities');
}
set identities(value) {
this._identities = value;
}
resetIdentities() {
this._identities = undefined;
}
// Temporarily expose input value. Use with caution.
get identitiesInput() {
return this._identities;
}
get identityType() {
return this.getStringAttribute('identity_type');
}
set identityType(value) {
this._identityType = value;
}
resetIdentityType() {
this._identityType = undefined;
}
// Temporarily expose input value. Use with caution.
get identityTypeInput() {
return this._identityType;
}
get sourceRestriction() {
return this.getStringAttribute('source_restriction');
}
set sourceRestriction(value) {
this._sourceRestriction = value;
}
resetSourceRestriction() {
this._sourceRestriction = undefined;
}
// Temporarily expose input value. Use with caution.
get sourceRestrictionInput() {
return this._sourceRestriction;
}
get sources() {
return this._sources;
}
putSources(value) {
this._sources.internalValue = value;
}
resetSources() {
this._sources.internalValue = undefined;
}
// Temporarily expose input value. Use with caution.
get sourcesInput() {
return this._sources.internalValue;
}
}
exports.AccessContextManagerServicePerimeterDryRunEgressPolicyEgressFromOutputReference = AccessContextManagerServicePerimeterDryRunEgressPolicyEgressFromOutputReference;
_c = JSII_RTTI_SYMBOL_1;
AccessContextManagerServicePerimeterDryRunEgressPolicyEgressFromOutputReference[_c] = { fqn: "@cdktf/provider-google.accessContextManagerServicePerimeterDryRunEgressPolicy.AccessContextManagerServicePerimeterDryRunEgressPolicyEgressFromOutputReference", version: "14.35.1" };
function accessContextManagerServicePerimeterDryRunEgressPolicyEgressToOperationsMethodSelectorsToTerraform(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 {
method: cdktf.stringToTerraform(struct.method),
permission: cdktf.stringToTerraform(struct.permission),
};
}
function accessContextManagerServicePerimeterDryRunEgressPolicyEgressToOperationsMethodSelectorsToHclTerraform(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 = {
method: {
value: cdktf.stringToHclTerraform(struct.method),
isBlock: false,
type: "simple",
storageClassType: "string",
},
permission: {
value: cdktf.stringToHclTerraform(struct.permission),
isBlock: false,
type: "simple",
storageClassType: "string",
},
};
// remove undefined attributes
return Object.fromEntries(Object.entries(attrs).filter(([_, value]) => value !== undefined && value.value !== undefined));
}
class AccessContextManagerServicePerimeterDryRunEgressPolicyEgressToOperationsMethodSelectorsOutputReference 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;
}
get internalValue() {
if (this.resolvableValue) {
return this.resolvableValue;
}
let hasAnyValues = this.isEmptyObject;
const internalValueResult = {};
if (this._method !== undefined) {
hasAnyValues = true;
internalValueResult.method = this._method;
}
if (this._permission !== undefined) {
hasAnyValues = true;
internalValueResult.permission = this._permission;
}
return hasAnyValues ? internalValueResult : undefined;
}
set internalValue(value) {
if (value === undefined) {
this.isEmptyObject = false;
this.resolvableValue = undefined;
this._method = undefined;
this._permission = 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._method = value.method;
this._permission = value.permission;
}
}
get method() {
return this.getStringAttribute('method');
}
set method(value) {
this._method = value;
}
resetMethod() {
this._method = undefined;
}
// Temporarily expose input value. Use with caution.
get methodInput() {
return this._method;
}
get permission() {
return this.getStringAttribute('permission');
}
set permission(value) {
this._permission = value;
}
resetPermission() {
this._permission = undefined;
}
// Temporarily expose input value. Use with caution.
get permissionInput() {
return this._permission;
}
}
exports.AccessContextManagerServicePerimeterDryRunEgressPolicyEgressToOperationsMethodSelectorsOutputReference = AccessContextManagerServicePerimeterDryRunEgressPolicyEgressToOperationsMethodSelectorsOutputReference;
_d = JSII_RTTI_SYMBOL_1;
AccessContextManagerServicePerimeterDryRunEgressPolicyEgressToOperationsMethodSelectorsOutputReference[_d] = { fqn: "@cdktf/provider-google.accessContextManagerServicePerimeterDryRunEgressPolicy.AccessContextManagerServicePerimeterDryRunEgressPolicyEgressToOperationsMethodSelectorsOutputReference", version: "14.35.1" };
class AccessContextManagerServicePerimeterDryRunEgressPolicyEgressToOperationsMethodSelectorsList 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 AccessContextManagerServicePerimeterDryRunEgressPolicyEgressToOperationsMethodSelectorsOutputReference(this.terraformResource, this.terraformAttribute, index, this.wrapsSet);
}
}
exports.AccessContextManagerServicePerimeterDryRunEgressPolicyEgressToOperationsMethodSelectorsList = AccessContextManagerServicePerimeterDryRunEgressPolicyEgressToOperationsMethodSelectorsList;
_e = JSII_RTTI_SYMBOL_1;
AccessContextManagerServicePerimeterDryRunEgressPolicyEgressToOperationsMethodSelectorsList[_e] = { fqn: "@cdktf/provider-google.accessContextManagerServicePerimeterDryRunEgressPolicy.AccessContextManagerServicePerimeterDryRunEgressPolicyEgressToOperationsMethodSelectorsList", version: "14.35.1" };
function accessContextManagerServicePerimeterDryRunEgressPolicyEgressToOperationsToTerraform(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 {
service_name: cdktf.stringToTerraform(struct.serviceName),
method_selectors: cdktf.listMapper(accessContextManagerServicePerimeterDryRunEgressPolicyEgressToOperationsMethodSelectorsToTerraform, true)(struct.methodSelectors),
};
}
function accessContextManagerServicePerimeterDryRunEgressPolicyEgressToOperationsToHclTerraform(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 = {
service_name: {
value: cdktf.stringToHclTerraform(struct.serviceName),
isBlock: false,
type: "simple",
storageClassType: "string",
},
method_selectors: {
value: cdktf.listMapperHcl(accessContextManagerServicePerimeterDryRunEgressPolicyEgressToOperationsMethodSelectorsToHclTerraform, true)(struct.methodSelectors),
isBlock: true,
type: "list",
storageClassType: "AccessContextManagerServicePerimeterDryRunEgressPolicyEgressToOperationsMethodSelectorsList",
},
};
// remove undefined attributes
return Object.fromEntries(Object.entries(attrs).filter(([_, value]) => value !== undefined && value.value !== undefined));
}
class AccessContextManagerServicePerimeterDryRunEgressPolicyEgressToOperationsOutputReference 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;
// method_selectors - computed: false, optional: true, required: false
this._methodSelectors = new AccessContextManagerServicePerimeterDryRunEgressPolicyEgressToOperationsMethodSelectorsList(this, "method_selectors", false);
}
get internalValue() {
if (this.resolvableValue) {
return this.resolvableValue;
}
let hasAnyValues = this.isEmptyObject;
const internalValueResult = {};
if (this._serviceName !== undefined) {
hasAnyValues = true;
internalValueResult.serviceName = this._serviceName;
}
if (this._methodSelectors?.internalValue !== undefined) {
hasAnyValues = true;
internalValueResult.methodSelectors = this._methodSelectors?.internalValue;
}
return hasAnyValues ? internalValueResult : undefined;
}
set internalValue(value) {
if (value === undefined) {
this.isEmptyObject = false;
this.resolvableValue = undefined;
this._serviceName = undefined;
this._methodSelectors.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._serviceName = value.serviceName;
this._methodSelectors.internalValue = value.methodSelectors;
}
}
get serviceName() {
return this.getStringAttribute('service_name');
}
set serviceName(value) {
this._serviceName = value;
}
resetServiceName() {
this._serviceName = undefined;
}
// Temporarily expose input value. Use with caution.
get serviceNameInput() {
return this._serviceName;
}
get methodSelectors() {
return this._methodSelectors;
}
putMethodSelectors(value) {
this._methodSelectors.internalValue = value;
}
resetMethodSelectors() {
this._methodSelectors.internalValue = undefined;
}
// Temporarily expose input value. Use with caution.
get methodSelectorsInput() {
return this._methodSelectors.internalValue;
}
}
exports.AccessContextManagerServicePerimeterDryRunEgressPolicyEgressToOperationsOutputReference = AccessContextManagerServicePerimeterDryRunEgressPolicyEgressToOperationsOutputReference;
_f = JSII_RTTI_SYMBOL_1;
AccessContextManagerServicePerimeterDryRunEgressPolicyEgressToOperationsOutputReference[_f] = { fqn: "@cdktf/provider-google.accessContextManagerServicePerimeterDryRunEgressPolicy.AccessContextManagerServicePerimeterDryRunEgressPolicyEgressToOperationsOutputReference", version: "14.35.1" };
class AccessContextManagerServicePerimeterDryRunEgressPolicyEgressToOperationsList 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 AccessContextManagerServicePerimeterDryRunEgressPolicyEgressToOperationsOutputReference(this.terraformResource, this.terraformAttribute, index, this.wrapsSet);
}
}
exports.AccessContextManagerServicePerimeterDryRunEgressPolicyEgressToOperationsList = AccessContextManagerServicePerimeterDryRunEgressPolicyEgressToOperationsList;
_g = JSII_RTTI_SYMBOL_1;
AccessContextManagerServicePerimeterDryRunEgressPolicyEgressToOperationsList[_g] = { fqn: "@cdktf/provider-google.accessContextManagerServicePerimeterDryRunEgressPolicy.AccessContextManagerServicePerimeterDryRunEgressPolicyEgressToOperationsList", version: "14.35.1" };
function accessContextManagerServicePerimeterDryRunEgressPolicyEgressToToTerraform(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 {
external_resources: cdktf.listMapper(cdktf.stringToTerraform, false)(struct.externalResources),
resources: cdktf.listMapper(cdktf.stringToTerraform, false)(struct.resources),
roles: cdktf.listMapper(cdktf.stringToTerraform, false)(struct.roles),
operations: cdktf.listMapper(accessContextManagerServicePerimeterDryRunEgressPolicyEgressToOperationsToTerraform, true)(struct.operations),
};
}
function accessContextManagerServicePerimeterDryRunEgressPolicyEgressToToHclTerraform(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 = {
external_resources: {
value: cdktf.listMapperHcl(cdktf.stringToHclTerraform, false)(struct.externalResources),
isBlock: false,
type: "list",
storageClassType: "stringList",
},
resources: {
value: cdktf.listMapperHcl(cdktf.stringToHclTerraform, false)(struct.resources),
isBlock: false,
type: "list",
storageClassType: "stringList",
},
roles: {
value: cdktf.listMapperHcl(cdktf.stringToHclTerraform, false)(struct.roles),
isBlock: false,
type: "list",
storageClassType: "stringList",
},
operations: {
value: cdktf.listMapperHcl(accessContextManagerServicePerimeterDryRunEgressPolicyEgressToOperationsToHclTerraform, true)(struct.operations),
isBlock: true,
type: "list",
storageClassType: "AccessContextManagerServicePerimeterDryRunEgressPolicyEgressToOperationsList",
},
};
// remove undefined attributes
return Object.fromEntries(Object.entries(attrs).filter(([_, value]) => value !== undefined && value.value !== undefined));
}
class AccessContextManagerServicePerimeterDryRunEgressPolicyEgressToOutputReference 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;
// operations - computed: false, optional: true, required: false
this._operations = new AccessContextManagerServicePerimeterDryRunEgressPolicyEgressToOperationsList(this, "operations", false);
}
get internalValue() {
let hasAnyValues = this.isEmptyObject;
const internalValueResult = {};
if (this._externalResources !== undefined) {
hasAnyValues = true;
internalValueResult.externalResources = this._externalResources;
}
if (this._resources !== undefined) {
hasAnyValues = true;
internalValueResult.resources = this._resources;
}
if (this._roles !== undefined) {
hasAnyValues = true;
internalValueResult.roles = this._roles;
}
if (this._operations?.internalValue !== undefined) {
hasAnyValues = true;
internalValueResult.operations = this._operations?.internalValue;
}
return hasAnyValues ? internalValueResult : undefined;
}
set internalValue(value) {
if (value === undefined) {
this.isEmptyObject = false;
this._externalResources = undefined;
this._resources = undefined;
this._roles = undefined;
this._operations.internalValue = undefined;
}
else {
this.isEmptyObject = Object.keys(value).length === 0;
this._externalResources = value.externalResources;
this._resources = value.resources;
this._roles = value.roles;
this._operations.internalValue = value.operations;
}
}
get externalResources() {
return this.getListAttribute('external_resources');
}
set externalResources(value) {
this._externalResources = value;
}
resetExternalResources() {
this._externalResources = undefined;
}
// Temporarily expose input value. Use with caution.
get externalResourcesInput() {
return this._externalResources;
}
get resources() {
return this.getListAttribute('resources');
}
set resources(value) {
this._resources = value;
}
resetResources() {
this._resources = undefined;
}
// Temporarily expose input value. Use with caution.
get resourcesInput() {
return this._resources;
}
get roles() {
return this.getListAttribute('roles');
}
set roles(value) {
this._roles = value;
}
resetRoles() {
this._roles = undefined;
}
// Temporarily expose input value. Use with caution.
get rolesInput() {
return this._roles;
}
get operations() {
return this._operations;
}
putOperations(value) {
this._operations.internalValue = value;
}
resetOperations() {
this._operations.internalValue = undefined;
}
// Temporarily expose input value. Use with caution.
get operationsInput() {
return this._operations.internalValue;
}
}
exports.AccessContextManagerServicePerimeterDryRunEgressPolicyEgressToOutputReference = AccessContextManagerServicePerimeterDryRunEgressPolicyEgressToOutputReference;
_h = JSII_RTTI_SYMBOL_1;
AccessContextManagerServicePerimeterDryRunEgressPolicyEgressToOutputReference[_h] = { fqn: "@cdktf/provider-google.accessContextManagerServicePerimeterDryRunEgressPolicy.AccessContextManagerServicePerimeterDryRunEgressPolicyEgressToOutputReference", version: "14.35.1" };
function accessContextManagerServicePerimeterDryRunEgressPolicyTimeoutsToTerraform(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),
};
}
function accessContextManagerServicePerimeterDryRunEgressPolicyTimeoutsToHclTerraform(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",
},
};
// remove undefined attributes
return Object.fromEntries(Object.entries(attrs).filter(([_, value]) => value !== undefined && value.value !== undefined));
}
class AccessContextManagerServicePerimeterDryRunEgressPolicyTimeoutsOutputReference 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;
}
return hasAnyValues ? internalValueResult : undefined;
}
set internalValue(value) {
if (value === undefined) {
this.isEmptyObject = false;
this.resolvableValue = undefined;
this._create = undefined;
this._delete = 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;
}
}
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;
}
}
exports.AccessContextManagerServicePerimeterDryRunEgressPolicyTimeoutsOutputReference = AccessContextManagerServicePerimeterDryRunEgressPolicyTimeoutsOutputReference;
_j = JSII_RTTI_SYMBOL_1;
AccessContextManagerServicePerimeterDryRunEgressPolicyTimeoutsOutputReference[_j] = { fqn: "@cdktf/provider-google.accessContextManagerServicePerimeterDryRunEgressPolicy.AccessContextManagerServicePerimeterDryRunEgressPolicyTimeoutsOutputReference", version: "14.35.1" };
/**
* Represents a {@link https://registry.terraform.io/providers/hashicorp/google/6.36.1/docs/resources/access_context_manager_service_perimeter_dry_run_egress_policy google_access_context_manager_service_perimeter_dry_run_egress_policy}
*/
class AccessContextManagerServicePerimeterDryRunEgressPolicy extends cdktf.TerraformResource {
// ==============
// STATIC Methods
// ==============
/**
* Generates CDKTF code for importing a AccessContextManagerServicePerimeterDryRunEgressPolicy 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 AccessContextManagerServicePerimeterDryRunEgressPolicy to import
* @param importFromId The id of the existing AccessContextManagerServicePerimeterDryRunEgressPolicy that should be imported. Refer to the {@link https://registry.terraform.io/providers/hashicorp/google/6.36.1/docs/resources/access_context_manager_service_perimeter_dry_run_egress_policy#import import section} in the documentation of this resource for the id to use
* @param provider? Optional instance of the provider where the AccessContextManagerServicePerimeterDryRunEgressPolicy to import is found
*/
static generateConfigForImport(scope, importToId, importFromId, provider) {
return new cdktf.ImportableResource(scope, importToId, { terraformResourceType: "google_access_context_manager_service_perimeter_dry_run_egress_policy", importId: importFromId, provider });
}
// ===========
// INITIALIZER
// ===========
/**
* Create a new {@link https://registry.terraform.io/providers/hashicorp/google/6.36.1/docs/resources/access_context_manager_service_perimeter_dry_run_egress_policy google_access_context_manager_service_perimeter_dry_run_egress_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 AccessContextManagerServicePerimeterDryRunEgressPolicyConfig
*/
constructor(scope, id, config) {
super(scope, id, {
terraformResourceType: 'google_access_context_manager_service_perimeter_dry_run_egress_policy',
terraformGeneratorMetadata: {
providerName: 'google',
providerVersion: '6.36.1',
providerVersionConstraint: '~> 6.0'
},
provider: config.provider,
dependsOn: config.dependsOn,
count: config.count,
lifecycle: config.lifecycle,
provisioners: config.provisioners,
connection: config.connection,
forEach: config.forEach
});
// egress_from - computed: false, optional: true, required: false
this._egressFrom = new AccessContextManagerServicePerimeterDryRunEgressPolicyEgressFromOutputReference(this, "egress_from");
// egress_to - computed: false, optional: true, required: false
this._egressTo = new AccessContextManagerServicePerimeterDryRunEgressPolicyEgressToOutputReference(this, "egress_to");
// timeouts - computed: false, optional: true, required: false
this._timeouts = new AccessContextManagerServicePerimeterDryRunEgressPolicyTimeoutsOutputReference(this, "timeouts");
this._id = config.id;
this._perimeter = config.perimeter;
this._title = config.title;
this._egressFrom.internalValue = config.egressFrom;
this._egressTo.internalValue = config.egressTo;
this._timeouts.internalValue = config.timeouts;
}
// ==========
// ATTRIBUTES
// ==========
// access_policy_id - computed: true, optional: false, required: false
get accessPolicyId() {
return this.getStringAttribute('access_policy_id');
}
// etag - computed: true, optional: false, required: false
get etag() {
return this.getStringAttribute('etag');
}
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 perimeter() {
return this.getStringAttribute('perimeter');
}
set perimeter(value) {
this._perimeter = value;
}
// Temporarily expose input value. Use with caution.
get perimeterInput() {
return this._perimeter;
}
get title() {
return this.getStringAttribute('title');
}
set title(value) {
this._title = value;
}
resetTitle() {
this._title = undefined;
}
// Temporarily expose input value. Use with caution.
get titleInput() {
return this._title;
}
get egressFrom() {
return this._egressFrom;
}
putEgressFrom(value) {
this._egressFrom.internalValue = value;
}
resetEgressFrom() {
this._egressFrom.internalValue = undefined;
}
// Temporarily expose input value. Use with caution.
get egressFromInput() {
return this._egressFrom.internalValue;
}
get egressTo() {
return this._egressTo;
}
putEgressTo(value) {
this._egressTo.internalValue = value;
}
resetEgressTo() {
this._egressTo.internalValue = undefined;
}
// Temporarily expose input value. Use with caution.
get egressToInput() {
return this._egressTo.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 {
id: cdktf.stringToTerraform(this._id),
perimeter: cdktf.stringToTerraform(this._perimeter),
title: cdktf.stringToTerraform(this._title),
egress_from: accessContextManagerServicePerimeterDryRunEgressPolicyEgressFromToTerraform(this._egressFrom.internalValue),
egress_to: accessContextManagerServicePerimeterDryRunEgressPolicyEgressToToTerraform(this._egressTo.internalValue),
timeouts: accessContextManagerServicePerimeterDryRunEgressPolicyTimeoutsToTerraform(this._timeouts.internalValue),
};
}
synthesizeHclAttributes() {
const attrs = {
id: {
value: cdktf.stringToHclTerraform(this._id),
isBlock: false,
type: "simple",
storageClassType: "string",
},
perimeter: {
value: cdktf.stringToHclTerraform(this._perimeter),
isBlock: false,
type: "simple",
storageClassType: "string",
},
title: {
value: cdktf.stringToHclTerraform(this._title),
isBlock: false,
type: "simple",
storageClassType: "string",
},
egress_from: {
value: accessContextManagerServicePerimeterDryRunEgressPolicyEgressFromToHclTerraform(this._egressFrom.internalValue),
isBlock: true,
type: "list",
storageClassType: "AccessContextManagerServicePerimeterDryRunEgressPolicyEgressFromList",
},
egress_to: {
value: accessContextManagerServicePerimeterDryRunEgressPolicyEgressToToHclTerraform(this._egressTo.internalValue),
isBlock: true,
type: "list",
storageClassType: "AccessContextManagerServicePerimeterDryRunEgressPolicyEgressToList",
},
timeouts: {
value: accessContextManagerServicePerimeterDryRunEgressPolicyTimeoutsToHclTerraform(this._timeouts.internalValue),
isBlock: true,
type: "struct",
storageClassType: "AccessContextManagerServicePerimeterDryRunEgressPolicyTimeouts",
},
};
// remove undefined attributes
return Object.fromEntries(Object.entries(attrs).filter(([_, value]) => value !== undefined && value.value !== undefined));
}
}
exports.AccessContextManagerServicePerimeterDryRunEgressPolicy = AccessContextManagerServicePerimeterDryRunEgressPolicy;
_k = JSII_RTTI_SYMBOL_1;
AccessContextManagerServicePerimeterDryRunEgressPolicy[_k] = { fqn: "@cdktf/provider-google.accessContextManagerServicePerimeterDryRunEgressPolicy.AccessContextManagerServicePerimeterDryRunEgressPolicy", version: "14.35.1" };
// =================
// STATIC PROPERTIES
// =================
AccessContextManagerServicePerimeterDryRunEgressPolicy.tfResourceType = "google_access_context_manager_service_perimeter_dry_run_egress_policy";
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiaW5kZXguanMiLCJzb3VyY2VSb290IjoiIiwic291cmNlcyI6WyIuLi8uLi9zcmMvYWNjZXNzLWNvbnRleHQtbWFuYWdlci1zZXJ2aWNlLXBlcmltZXRlci1kcnktcnVuLWVncmVzcy1wb2xpY3kvaW5kZXgudHMiXSwibmFtZXMiOltdLCJtYXBwaW5ncyI6Ijs7OztBQXdFQSxnTEFTQztBQUdELHNMQXNCQztBQXlJRCxrS0FXQztBQUdELHdLQWtDQztBQXNJRCxnTkFTQztBQUdELHNOQXNCQztBQXlIRCxrTEFTQztBQUdELHdMQXNCQztBQTJJRCw4SkFXQztBQUdELG9LQWtDQztBQStIRCw4SkFTQztBQUdELG9LQXNCQzs7QUF6N0JELCtCQUErQjtBQStEL0IsU0FBZ0Isa0ZBQWtGLENBQUMsTUFBb0c7SUFDck0sSUFBSSxDQUFDLEtBQUssQ0FBQyxVQUFVLENBQUMsTUFBTSxDQUFDLElBQUksS0FBSyxDQUFDLFlBQVksQ0FBQyxZQUFZLENBQUMsTUFBTSxDQUFDLEVBQUUsQ0FBQztRQUFDLE9BQU8sTUFBTSxDQUFDO0lBQUMsQ0FBQztJQUM1RixJQUFJLEtBQUssQ0FBQyxnQkFBZ0IsQ0FBQyxNQUFNLENBQUMsRUFBRSxDQUFDO1FBQ25DLE1BQU0sSUFBSSxLQUFLLENBQUMsb0hBQW9ILENBQUMsQ0FBQztJQUN4SSxDQUFDO0lBQ0QsT0FBTztRQUNMLFlBQVksRUFBRSxLQUFLLENBQUMsaUJBQWlCLENBQUMsTUFBTyxDQUFDLFdBQVcsQ0FBQztRQUMxRCxRQUFRLEVBQUUsS0FBSyxDQUFDLGlCQUFpQixDQUFDLE1BQU8sQ0FBQyxRQUFRLENBQUM7S0FDcEQsQ0FBQTtBQUNILENBQUM7QUFHRCxTQUFnQixxRkFBcUYsQ0FBQyxNQUFvRztJQUN4TSxJQUFJLENBQUMsS0FBSyxDQUFDLFVBQVUsQ0FBQyxNQUFNLENBQUMsSUFBSSxLQUFLLENBQUMsWUFBWSxDQUFDLFlBQVksQ0FBQyxNQUFNLENBQUMsRUFBRSxDQUFDO1FBQUMsT0FBTyxNQUFNLENBQUM7SUFBQyxDQUFDO0lBQzVGLElBQUksS0FBSyxDQUFDLGdCQUFnQixDQUFDLE1BQU0sQ0FBQyxFQUFFLENBQUM7UUFDbkMsTUFBTSxJQUFJLEtBQUssQ0FBQyxvSEFBb0gsQ0FBQyxDQUFDO0lBQ3hJLENBQUM7SUFDRCxNQUFNLEtBQUssR0FBRztRQUNaLFlBQVksRUFBRTtZQUNaLEtBQUssRUFBRSxLQUFLLENBQUMsb0JBQW9CLENBQUMsTUFBTyxDQUFDLFdBQVcsQ0FBQztZQUN0RCxPQUFPLEVBQUUsS0FBSztZQUNkLElBQUksRUFBRSxRQUFRO1lBQ2QsZ0JBQWdCLEVBQUUsUUFBUTtTQUMzQjtRQUNELFFBQVEsRUFBRTtZQUNSLEtBQUssRUFBRSxLQUFLLENBQUMsb0JBQW9CLENBQUMsTUFBTyxDQUFDLFFBQVEsQ0FBQztZQUNuRCxPQUFP