@aws-cdk/aws-bedrock-agentcore-alpha
Version:
The CDK Construct Library for Amazon Bedrock
234 lines • 28.4 kB
JavaScript
;
Object.defineProperty(exports, "__esModule", { value: true });
exports.RuntimeNetworkConfiguration = exports.CodeInterpreterNetworkConfiguration = exports.BrowserNetworkConfiguration = exports.NetworkConfiguration = void 0;
const jsiiDeprecationWarnings = require("../../.warnings.jsii.js");
const JSII_RTTI_SYMBOL_1 = Symbol.for("jsii.rtti");
/* eslint-disable @cdklabs/no-throw-default-error */
const ec2 = require("aws-cdk-lib/aws-ec2");
/**
* Abstract base class for network configuration.
*/
class NetworkConfiguration {
static [JSII_RTTI_SYMBOL_1] = { fqn: "@aws-cdk/aws-bedrock-agentcore-alpha.NetworkConfiguration", version: "2.227.0-alpha.0" };
/**
* The network mode to use.
* Configure the security level for agent
* execution to control access, isolate resources, and protect sensitive data.
*/
networkMode;
/**
* The connections object to the network.
*/
connections;
/**
* The scope to create the resource in.
*/
scope;
/**
* The VPC subnets to use.
*/
vpcSubnets;
/**
* Creates a new network configuration.
* @param mode - the network mode to use for the tool.
*/
constructor(mode, scope, vpcConfig) {
try {
jsiiDeprecationWarnings._aws_cdk_aws_bedrock_agentcore_alpha_VpcConfigProps(vpcConfig);
}
catch (error) {
if (process.env.JSII_DEBUG !== "1" && error.name === "DeprecationError") {
Error.captureStackTrace(error, NetworkConfiguration);
}
throw error;
}
this.scope = scope;
this.networkMode = mode;
// Validate vpc config and configure connections
const networkConfig = this._validateAndConfigureVpcConfig(vpcConfig);
this.connections = networkConfig?.connections;
this.vpcSubnets = networkConfig?.vpcSubnets;
}
/**
* Validates the vpc config.
*/
_validateAndConfigureVpcConfig = (vpcConfig) => {
if ((vpcConfig?.securityGroups || vpcConfig?.allowAllOutbound !== undefined) && !vpcConfig?.vpc) {
throw new Error('Cannot configure \'securityGroups\' or \'allowAllOutbound\' without configuring a VPC');
}
if (!vpcConfig?.vpc) {
return undefined;
}
if ((vpcConfig?.securityGroups && vpcConfig?.securityGroups.length > 0) && vpcConfig?.allowAllOutbound !== undefined) {
throw new Error('Configure \'allowAllOutbound\' directly on the supplied SecurityGroups');
}
if (!this.scope) {
throw new Error('Scope is required to create the security group');
}
let securityGroups;
if (vpcConfig.securityGroups && vpcConfig.securityGroups.length > 0) {
securityGroups = vpcConfig.securityGroups;
}
else {
const securityGroup = new ec2.SecurityGroup(this.scope, 'SecurityGroup', {
vpc: vpcConfig.vpc,
allowAllOutbound: vpcConfig.allowAllOutbound ?? true,
});
securityGroups = [securityGroup];
}
const vpcSubnets = vpcConfig.vpcSubnets ? vpcConfig.vpc.selectSubnets(vpcConfig.vpcSubnets) : vpcConfig.vpc.selectSubnets();
return {
connections: new ec2.Connections({ securityGroups: securityGroups }),
vpcSubnets: vpcSubnets,
};
};
}
exports.NetworkConfiguration = NetworkConfiguration;
/**
* Network configuration for the Browser tool.
*/
class BrowserNetworkConfiguration extends NetworkConfiguration {
static [JSII_RTTI_SYMBOL_1] = { fqn: "@aws-cdk/aws-bedrock-agentcore-alpha.BrowserNetworkConfiguration", version: "2.227.0-alpha.0" };
/**
* Creates a public network configuration. PUBLIC is the default network mode.
* @returns A BrowserNetworkConfiguration.
* Run this tool to operate in a public environment with internet access, suitable for less sensitive or open-use scenarios.
*/
static usingPublicNetwork() {
return new BrowserNetworkConfiguration('PUBLIC');
}
/**
* Creates a network configuration from a VPC configuration.
* @param vpcConfig - The VPC configuration.
* @returns A BrowserNetworkConfiguration.
*/
static usingVpc(scope, vpcConfig) {
try {
jsiiDeprecationWarnings._aws_cdk_aws_bedrock_agentcore_alpha_VpcConfigProps(vpcConfig);
}
catch (error) {
if (process.env.JSII_DEBUG !== "1" && error.name === "DeprecationError") {
Error.captureStackTrace(error, this.usingVpc);
}
throw error;
}
return new BrowserNetworkConfiguration('VPC', scope, vpcConfig);
}
/**
* Renders the network configuration as a CloudFormation property.
* @param browserConnections - The connections object to the browser.
* @internal This is an internal core function and should not be called directly.
*/
_render(browserConnections) {
return {
networkMode: this.networkMode,
vpcConfig: (this.networkMode === 'VPC' && browserConnections) ? {
subnets: this.vpcSubnets?.subnets?.map(subnet => subnet.subnetId) ?? [],
securityGroups: browserConnections?.securityGroups?.map(s => s.securityGroupId) ?? [],
} : undefined,
};
}
}
exports.BrowserNetworkConfiguration = BrowserNetworkConfiguration;
/**
* Network configuration for the Code Interpreter tool.
*/
class CodeInterpreterNetworkConfiguration extends NetworkConfiguration {
static [JSII_RTTI_SYMBOL_1] = { fqn: "@aws-cdk/aws-bedrock-agentcore-alpha.CodeInterpreterNetworkConfiguration", version: "2.227.0-alpha.0" };
/**
* Creates a public network configuration.
* @returns A CodeInterpreterNetworkConfiguration.
* Run this tool to operate in a public environment with internet access, suitable for less sensitive or open-use scenarios.
*/
static usingPublicNetwork() {
return new CodeInterpreterNetworkConfiguration('PUBLIC');
}
/**
* Creates a sandbox network configuration.
* @returns A CodeInterpreterNetworkConfiguration.
* Run this tool in a restricted environment with limited Permissions and Encryption to enhance safety and reduce potential risks.
*/
static usingSandboxNetwork() {
return new CodeInterpreterNetworkConfiguration('SANDBOX');
}
/**
* Creates a network configuration from a VPC configuration.
* @param vpcConfig - The VPC configuration.
* @returns A CodeInterpreterNetworkConfiguration.
*/
static usingVpc(scope, vpcConfig) {
try {
jsiiDeprecationWarnings._aws_cdk_aws_bedrock_agentcore_alpha_VpcConfigProps(vpcConfig);
}
catch (error) {
if (process.env.JSII_DEBUG !== "1" && error.name === "DeprecationError") {
Error.captureStackTrace(error, this.usingVpc);
}
throw error;
}
return new CodeInterpreterNetworkConfiguration('VPC', scope, vpcConfig);
}
/**
* Renders the network configuration as a CloudFormation property.
* @param codeInterpreterConnections - The connections object to the code interpreter.
* @internal This is an internal core function and should not be called directly.
*/
_render(codeInterpreterConnections) {
return {
networkMode: this.networkMode,
vpcConfig: (this.networkMode === 'VPC' && codeInterpreterConnections) ? {
subnets: this.vpcSubnets?.subnets?.map(subnet => subnet.subnetId) ?? [],
securityGroups: codeInterpreterConnections?.securityGroups?.map(s => s.securityGroupId) ?? [],
} : undefined,
};
}
}
exports.CodeInterpreterNetworkConfiguration = CodeInterpreterNetworkConfiguration;
/**
* Network configuration for the Runtime.
*/
class RuntimeNetworkConfiguration extends NetworkConfiguration {
static [JSII_RTTI_SYMBOL_1] = { fqn: "@aws-cdk/aws-bedrock-agentcore-alpha.RuntimeNetworkConfiguration", version: "2.227.0-alpha.0" };
/**
* Creates a public network configuration. PUBLIC is the default network mode.
* @returns A RuntimeNetworkConfiguration.
* Run the runtime in a public environment with internet access, suitable for less sensitive or open-use scenarios.
*/
static usingPublicNetwork() {
return new RuntimeNetworkConfiguration('PUBLIC');
}
/**
* Creates a network configuration from a VPC configuration.
* @param scope - The construct scope for creating resources.
* @param vpcConfig - The VPC configuration.
* @returns A RuntimeNetworkConfiguration.
*/
static usingVpc(scope, vpcConfig) {
try {
jsiiDeprecationWarnings._aws_cdk_aws_bedrock_agentcore_alpha_VpcConfigProps(vpcConfig);
}
catch (error) {
if (process.env.JSII_DEBUG !== "1" && error.name === "DeprecationError") {
Error.captureStackTrace(error, this.usingVpc);
}
throw error;
}
return new RuntimeNetworkConfiguration('VPC', scope, vpcConfig);
}
/**
* Renders the network configuration as a CloudFormation property.
* @param runtimeConnections - The connections object to the runtime.
* @internal This is an internal core function and should not be called directly.
*/
_render(_runtimeConnections) {
return {
networkMode: this.networkMode,
networkModeConfig: (this.networkMode == 'VPC' && _runtimeConnections) ? {
subnets: this.vpcSubnets?.subnets?.map(subnet => subnet.subnetId) ?? [],
securityGroups: _runtimeConnections?.securityGroups?.map(s => s.securityGroupId) ?? [],
} : undefined,
};
}
}
exports.RuntimeNetworkConfiguration = RuntimeNetworkConfiguration;
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"network-configuration.js","sourceRoot":"","sources":["network-configuration.ts"],"names":[],"mappings":";;;;;AAAA,oDAAoD;AACpD,2CAA2C;AA+D3C;;GAEG;AACH,MAAsB,oBAAoB;;IACxC;;;;OAIG;IACM,WAAW,CAAS;IAC7B;;OAEG;IACM,WAAW,CAA8B;IAClD;;OAEG;IACM,KAAK,CAAyB;IACvC;;OAEG;IACM,UAAU,CAAuB;IAC1C;;;OAGG;IACH,YAAuB,IAAY,EAAE,KAAiB,EAAE,SAA0B;;;;;;+CAvB9D,oBAAoB;;;;QAwBtC,IAAI,CAAC,KAAK,GAAG,KAAK,CAAC;QACnB,IAAI,CAAC,WAAW,GAAG,IAAI,CAAC;QAExB,gDAAgD;QAChD,MAAM,aAAa,GAAG,IAAI,CAAC,8BAA8B,CAAC,SAAS,CAAC,CAAC;QACrE,IAAI,CAAC,WAAW,GAAG,aAAa,EAAE,WAAW,CAAC;QAC9C,IAAI,CAAC,UAAU,GAAG,aAAa,EAAE,UAAU,CAAC;KAC7C;IAED;;OAEG;IACK,8BAA8B,GAAG,CAAC,SAA0B,EAA6B,EAAE;QACjG,IAAI,CAAC,SAAS,EAAE,cAAc,IAAI,SAAS,EAAE,gBAAgB,KAAK,SAAS,CAAC,IAAI,CAAC,SAAS,EAAE,GAAG,EAAE,CAAC;YAChG,MAAM,IAAI,KAAK,CAAC,uFAAuF,CAAC,CAAC;QAC3G,CAAC;QAED,IAAI,CAAC,SAAS,EAAE,GAAG,EAAE,CAAC;YACpB,OAAO,SAAS,CAAC;QACnB,CAAC;QAED,IAAI,CAAC,SAAS,EAAE,cAAc,IAAI,SAAS,EAAE,cAAc,CAAC,MAAM,GAAG,CAAC,CAAC,IAAI,SAAS,EAAE,gBAAgB,KAAK,SAAS,EAAE,CAAC;YACrH,MAAM,IAAI,KAAK,CAAC,wEAAwE,CAAC,CAAC;QAC5F,CAAC;QAED,IAAI,CAAC,IAAI,CAAC,KAAK,EAAE,CAAC;YAChB,MAAM,IAAI,KAAK,CAAC,gDAAgD,CAAC,CAAC;QACpE,CAAC;QAED,IAAI,cAAoC,CAAC;QACzC,IAAI,SAAS,CAAC,cAAc,IAAI,SAAS,CAAC,cAAc,CAAC,MAAM,GAAG,CAAC,EAAE,CAAC;YACpE,cAAc,GAAG,SAAS,CAAC,cAAc,CAAC;QAC5C,CAAC;aAAM,CAAC;YACN,MAAM,aAAa,GAAG,IAAI,GAAG,CAAC,aAAa,CAAC,IAAI,CAAC,KAAM,EAAE,eAAe,EAAE;gBACxE,GAAG,EAAE,SAAS,CAAC,GAAG;gBAClB,gBAAgB,EAAE,SAAS,CAAC,gBAAgB,IAAI,IAAI;aACrD,CAAC,CAAC;YACH,cAAc,GAAG,CAAC,aAAa,CAAC,CAAC;QACnC,CAAC;QAED,MAAM,UAAU,GAAG,SAAS,CAAC,UAAU,CAAC,CAAC,CAAC,SAAS,CAAC,GAAG,CAAC,aAAa,CAAC,SAAS,CAAC,UAAU,CAAC,CAAC,CAAC,CAAC,SAAS,CAAC,GAAG,CAAC,aAAa,EAAE,CAAC;QAE5H,OAAO;YACL,WAAW,EAAE,IAAI,GAAG,CAAC,WAAW,CAAC,EAAE,cAAc,EAAE,cAAc,EAAE,CAAC;YACpE,UAAU,EAAE,UAAU;SACvB,CAAC;IACJ,CAAC,CAAC;;AAtEJ,oDAuEC;AAED;;GAEG;AACH,MAAa,2BAA4B,SAAQ,oBAAoB;;IACnE;;;;OAIG;IACI,MAAM,CAAC,kBAAkB;QAC9B,OAAO,IAAI,2BAA2B,CAAC,QAAQ,CAAC,CAAC;KAClD;IAED;;;;OAIG;IACI,MAAM,CAAC,QAAQ,CAAC,KAAgB,EAAE,SAAyB;;;;;;;;;;QAChE,OAAO,IAAI,2BAA2B,CAAC,KAAK,EAAE,KAAK,EAAE,SAAS,CAAC,CAAC;KACjE;IAED;;;;OAIG;IACI,OAAO,CAAC,kBAAoC;QACjD,OAAO;YACL,WAAW,EAAE,IAAI,CAAC,WAAW;YAC7B,SAAS,EAAE,CAAC,IAAI,CAAC,WAAW,KAAK,KAAK,IAAI,kBAAkB,CAAC,CAAC,CAAC,CAAC;gBAC9D,OAAO,EAAE,IAAI,CAAC,UAAU,EAAE,OAAO,EAAE,GAAG,CAAC,MAAM,CAAC,EAAE,CAAC,MAAM,CAAC,QAAQ,CAAC,IAAI,EAAE;gBACvE,cAAc,EAAE,kBAAkB,EAAE,cAAc,EAAE,GAAG,CAAC,CAAC,CAAC,EAAE,CAAC,CAAC,CAAC,eAAe,CAAC,IAAI,EAAE;aACtF,CAAC,CAAC,CAAC,SAAS;SACd,CAAC;KACH;;AAhCH,kEAiCC;AAED;;GAEG;AACH,MAAa,mCAAoC,SAAQ,oBAAoB;;IAC3E;;;;OAIG;IACI,MAAM,CAAC,kBAAkB;QAC9B,OAAO,IAAI,mCAAmC,CAAC,QAAQ,CAAC,CAAC;KAC1D;IAED;;;;OAIG;IACI,MAAM,CAAC,mBAAmB;QAC/B,OAAO,IAAI,mCAAmC,CAAC,SAAS,CAAC,CAAC;KAC3D;IAED;;;;OAIG;IACI,MAAM,CAAC,QAAQ,CAAC,KAAgB,EAAE,SAAyB;;;;;;;;;;QAChE,OAAO,IAAI,mCAAmC,CAAC,KAAK,EAAE,KAAK,EAAE,SAAS,CAAC,CAAC;KACzE;IAED;;;;OAIG;IACI,OAAO,CAAC,0BAA4C;QACzD,OAAO;YACL,WAAW,EAAE,IAAI,CAAC,WAAW;YAC7B,SAAS,EAAE,CAAC,IAAI,CAAC,WAAW,KAAK,KAAK,IAAI,0BAA0B,CAAC,CAAC,CAAC,CAAC;gBACtE,OAAO,EAAE,IAAI,CAAC,UAAU,EAAE,OAAO,EAAE,GAAG,CAAC,MAAM,CAAC,EAAE,CAAC,MAAM,CAAC,QAAQ,CAAC,IAAI,EAAE;gBACvE,cAAc,EAAE,0BAA0B,EAAE,cAAc,EAAE,GAAG,CAAC,CAAC,CAAC,EAAE,CAAC,CAAC,CAAC,eAAe,CAAC,IAAI,EAAE;aAC9F,CAAC,CAAC,CAAC,SAAS;SACd,CAAC;KACH;;AAzCH,kFA0CC;AAED;;GAEG;AACH,MAAa,2BAA4B,SAAQ,oBAAoB;;IACnE;;;;OAIG;IACI,MAAM,CAAC,kBAAkB;QAC9B,OAAO,IAAI,2BAA2B,CAAC,QAAQ,CAAC,CAAC;KAClD;IAED;;;;;OAKG;IACI,MAAM,CAAC,QAAQ,CAAC,KAAgB,EAAE,SAAyB;;;;;;;;;;QAChE,OAAO,IAAI,2BAA2B,CAAC,KAAK,EAAE,KAAK,EAAE,SAAS,CAAC,CAAC;KACjE;IAED;;;;OAIG;IACI,OAAO,CAAC,mBAAqC;QAClD,OAAO;YACL,WAAW,EAAE,IAAI,CAAC,WAAW;YAC7B,iBAAiB,EAAE,CAAC,IAAI,CAAC,WAAW,IAAI,KAAK,IAAI,mBAAmB,CAAC,CAAC,CAAC,CAAC;gBACtE,OAAO,EAAE,IAAI,CAAC,UAAU,EAAE,OAAO,EAAE,GAAG,CAAC,MAAM,CAAC,EAAE,CAAC,MAAM,CAAC,QAAQ,CAAC,IAAI,EAAE;gBACvE,cAAc,EAAE,mBAAmB,EAAE,cAAc,EAAE,GAAG,CAAC,CAAC,CAAA,EAAE,CAAC,CAAC,CAAC,eAAe,CAAC,IAAI,EAAE;aACtF,CAAA,CAAC,CAAC,SAAS;SACb,CAAC;KACH;;AAjCH,kEAkCC","sourcesContent":["/* eslint-disable @cdklabs/no-throw-default-error */\nimport * as ec2 from 'aws-cdk-lib/aws-ec2';\n// Internal Libs\nimport { CfnBrowserCustom, CfnCodeInterpreterCustom, CfnRuntime } from 'aws-cdk-lib/aws-bedrockagentcore';\nimport { Construct } from 'constructs';\n\n/**\n * VPC configuration properties.\n * Only used when network mode is VPC.\n */\nexport interface VpcConfigProps {\n  /**\n   * The VPC to deploy the resource to.\n   */\n  readonly vpc: ec2.IVpc;\n  /**\n   * Where to place the network interfaces within the VPC.\n   *\n   * This requires `vpc` to be specified in order for interfaces to actually be\n   * placed in the subnets. If `vpc` is not specify, this will raise an error.\n   *\n   * @default - the Vpc default strategy if not specified\n   */\n  readonly vpcSubnets?: ec2.SubnetSelection;\n  /**\n   * The list of security groups to associate with the resource's network interfaces.\n   *\n   * Only used if 'vpc' is supplied.\n   *\n   * @default - If the resource is placed within a VPC and a security group is\n   * not specified by this prop, a dedicated security\n   * group will be created for this resource.\n   */\n  readonly securityGroups?: ec2.ISecurityGroup[];\n  /**\n   * Whether to allow the resource to send all network traffic (except ipv6)\n   *\n   * If set to false, you must individually add traffic rules to allow the\n   * resource to connect to network targets.\n   *\n   * Do not specify this property if the `securityGroups` property is set.\n   * Instead, configure `allowAllOutbound` directly on the security group.\n   *\n   * @default true\n   */\n  readonly allowAllOutbound?: boolean;\n}\n\n/**\n * VPC configuration.\n * Only used when network mode is VPC.\n * @internal\n */\ninterface NetworkConfig {\n  /**\n   * The connections to the network.\n   */\n  readonly connections: ec2.Connections | undefined;\n  /**\n   * The VPC subnets to use.\n   */\n  readonly vpcSubnets: ec2.SelectedSubnets | undefined;\n}\n\n/**\n * Abstract base class for network configuration.\n */\nexport abstract class NetworkConfiguration {\n  /**\n   * The network mode to use.\n   * Configure the security level for agent\n   * execution to control access, isolate resources, and protect sensitive data.\n   */\n  readonly networkMode: string;\n  /**\n   * The connections object to the network.\n   */\n  readonly connections: ec2.Connections | undefined;\n  /**\n   * The scope to create the resource in.\n   */\n  readonly scope?: Construct | undefined;\n  /**\n   * The VPC subnets to use.\n   */\n  readonly vpcSubnets?: ec2.SubnetSelection;\n  /**\n   * Creates a new network configuration.\n   * @param mode - the network mode to use for the tool.\n   */\n  protected constructor (mode: string, scope?: Construct, vpcConfig?: VpcConfigProps) {\n    this.scope = scope;\n    this.networkMode = mode;\n\n    // Validate vpc config and configure connections\n    const networkConfig = this._validateAndConfigureVpcConfig(vpcConfig);\n    this.connections = networkConfig?.connections;\n    this.vpcSubnets = networkConfig?.vpcSubnets;\n  }\n\n  /**\n   * Validates the vpc config.\n   */\n  private _validateAndConfigureVpcConfig = (vpcConfig?: VpcConfigProps): NetworkConfig | undefined => {\n    if ((vpcConfig?.securityGroups || vpcConfig?.allowAllOutbound !== undefined) && !vpcConfig?.vpc) {\n      throw new Error('Cannot configure \\'securityGroups\\' or \\'allowAllOutbound\\' without configuring a VPC');\n    }\n\n    if (!vpcConfig?.vpc) {\n      return undefined;\n    }\n\n    if ((vpcConfig?.securityGroups && vpcConfig?.securityGroups.length > 0) && vpcConfig?.allowAllOutbound !== undefined) {\n      throw new Error('Configure \\'allowAllOutbound\\' directly on the supplied SecurityGroups');\n    }\n\n    if (!this.scope) {\n      throw new Error('Scope is required to create the security group');\n    }\n\n    let securityGroups: ec2.ISecurityGroup[];\n    if (vpcConfig.securityGroups && vpcConfig.securityGroups.length > 0) {\n      securityGroups = vpcConfig.securityGroups;\n    } else {\n      const securityGroup = new ec2.SecurityGroup(this.scope!, 'SecurityGroup', {\n        vpc: vpcConfig.vpc,\n        allowAllOutbound: vpcConfig.allowAllOutbound ?? true,\n      });\n      securityGroups = [securityGroup];\n    }\n\n    const vpcSubnets = vpcConfig.vpcSubnets ? vpcConfig.vpc.selectSubnets(vpcConfig.vpcSubnets) : vpcConfig.vpc.selectSubnets();\n\n    return {\n      connections: new ec2.Connections({ securityGroups: securityGroups }),\n      vpcSubnets: vpcSubnets,\n    };\n  };\n}\n\n/**\n * Network configuration for the Browser tool.\n */\nexport class BrowserNetworkConfiguration extends NetworkConfiguration {\n  /**\n   * Creates a public network configuration. PUBLIC is the default network mode.\n   * @returns A BrowserNetworkConfiguration.\n   * Run this tool to operate in a public environment with internet access, suitable for less sensitive or open-use scenarios.\n   */\n  public static usingPublicNetwork(): BrowserNetworkConfiguration {\n    return new BrowserNetworkConfiguration('PUBLIC');\n  }\n\n  /**\n   * Creates a network configuration from a VPC configuration.\n   * @param vpcConfig - The VPC configuration.\n   * @returns A BrowserNetworkConfiguration.\n   */\n  public static usingVpc(scope: Construct, vpcConfig: VpcConfigProps): BrowserNetworkConfiguration {\n    return new BrowserNetworkConfiguration('VPC', scope, vpcConfig);\n  }\n\n  /**\n   * Renders the network configuration as a CloudFormation property.\n   * @param browserConnections - The connections object to the browser.\n   * @internal This is an internal core function and should not be called directly.\n   */\n  public _render(browserConnections?: ec2.Connections): CfnBrowserCustom.BrowserNetworkConfigurationProperty {\n    return {\n      networkMode: this.networkMode,\n      vpcConfig: (this.networkMode === 'VPC' && browserConnections) ? {\n        subnets: this.vpcSubnets?.subnets?.map(subnet => subnet.subnetId) ?? [],\n        securityGroups: browserConnections?.securityGroups?.map(s => s.securityGroupId) ?? [],\n      } : undefined,\n    };\n  }\n}\n\n/**\n * Network configuration for the Code Interpreter tool.\n */\nexport class CodeInterpreterNetworkConfiguration extends NetworkConfiguration {\n  /**\n   * Creates a public network configuration.\n   * @returns A CodeInterpreterNetworkConfiguration.\n   * Run this tool to operate in a public environment with internet access, suitable for less sensitive or open-use scenarios.\n   */\n  public static usingPublicNetwork(): CodeInterpreterNetworkConfiguration {\n    return new CodeInterpreterNetworkConfiguration('PUBLIC');\n  }\n\n  /**\n   * Creates a sandbox network configuration.\n   * @returns A CodeInterpreterNetworkConfiguration.\n   * Run this tool in a restricted environment with limited Permissions and Encryption to enhance safety and reduce potential risks.\n   */\n  public static usingSandboxNetwork(): CodeInterpreterNetworkConfiguration {\n    return new CodeInterpreterNetworkConfiguration('SANDBOX');\n  }\n\n  /**\n   * Creates a network configuration from a VPC configuration.\n   * @param vpcConfig - The VPC configuration.\n   * @returns A CodeInterpreterNetworkConfiguration.\n   */\n  public static usingVpc(scope: Construct, vpcConfig: VpcConfigProps): CodeInterpreterNetworkConfiguration {\n    return new CodeInterpreterNetworkConfiguration('VPC', scope, vpcConfig);\n  }\n\n  /**\n   * Renders the network configuration as a CloudFormation property.\n   * @param codeInterpreterConnections - The connections object to the code interpreter.\n   * @internal This is an internal core function and should not be called directly.\n   */\n  public _render(codeInterpreterConnections?: ec2.Connections): CfnCodeInterpreterCustom.CodeInterpreterNetworkConfigurationProperty {\n    return {\n      networkMode: this.networkMode,\n      vpcConfig: (this.networkMode === 'VPC' && codeInterpreterConnections) ? {\n        subnets: this.vpcSubnets?.subnets?.map(subnet => subnet.subnetId) ?? [],\n        securityGroups: codeInterpreterConnections?.securityGroups?.map(s => s.securityGroupId) ?? [],\n      } : undefined,\n    };\n  }\n}\n\n/**\n * Network configuration for the Runtime.\n */\nexport class RuntimeNetworkConfiguration extends NetworkConfiguration {\n  /**\n   * Creates a public network configuration. PUBLIC is the default network mode.\n   * @returns A RuntimeNetworkConfiguration.\n   * Run the runtime in a public environment with internet access, suitable for less sensitive or open-use scenarios.\n   */\n  public static usingPublicNetwork(): RuntimeNetworkConfiguration {\n    return new RuntimeNetworkConfiguration('PUBLIC');\n  }\n\n  /**\n   * Creates a network configuration from a VPC configuration.\n   * @param scope - The construct scope for creating resources.\n   * @param vpcConfig - The VPC configuration.\n   * @returns A RuntimeNetworkConfiguration.\n   */\n  public static usingVpc(scope: Construct, vpcConfig: VpcConfigProps): RuntimeNetworkConfiguration {\n    return new RuntimeNetworkConfiguration('VPC', scope, vpcConfig);\n  }\n\n  /**\n   * Renders the network configuration as a CloudFormation property.\n   * @param runtimeConnections - The connections object to the runtime.\n   * @internal This is an internal core function and should not be called directly.\n   */\n  public _render(_runtimeConnections?: ec2.Connections): CfnRuntime.NetworkConfigurationProperty {\n    return {\n      networkMode: this.networkMode,\n      networkModeConfig: (this.networkMode == 'VPC' && _runtimeConnections) ? {\n        subnets: this.vpcSubnets?.subnets?.map(subnet => subnet.subnetId) ?? [],\n        securityGroups: _runtimeConnections?.securityGroups?.map(s=> s.securityGroupId) ?? [],\n      }: undefined,\n    };\n  }\n}\n"]}