@aws-cdk/aws-bedrock-agentcore-alpha
Version:
The CDK Construct Library for Amazon Bedrock
407 lines • 39.9 kB
JavaScript
"use strict";
Object.defineProperty(exports, "__esModule", { value: true });
exports.McpServerTargetConfiguration = exports.SmithyTargetConfiguration = exports.OpenApiTargetConfiguration = exports.LambdaTargetConfiguration = exports.McpTargetConfiguration = void 0;
const jsiiDeprecationWarnings = require("../../../.warnings.jsii.js");
const JSII_RTTI_SYMBOL_1 = Symbol.for("jsii.rtti");
const aws_cdk_lib_1 = require("aws-cdk-lib");
const fs = require("fs");
const api_schema_1 = require("./schema/api-schema");
const target_base_1 = require("./target-base");
const validation_helpers_1 = require("../validation-helpers");
/******************************************************************************
* MCP Target Configuration Base
*****************************************************************************/
/**
* Abstract base class for MCP target configurations
* Provides common functionality for all MCP target types
*/
class McpTargetConfiguration {
static [JSII_RTTI_SYMBOL_1] = { fqn: "@aws-cdk/aws-bedrock-agentcore-alpha.McpTargetConfiguration", version: "2.227.0-alpha.0" };
/**
* Renders the configuration as CloudFormation properties
* @internal
*/
_render() {
return {
mcp: this.renderMcpConfiguration(),
};
}
}
exports.McpTargetConfiguration = McpTargetConfiguration;
/******************************************************************************
* Lambda Target Configuration
*****************************************************************************/
/**
* Configuration for Lambda-based MCP targets
*
* This configuration wraps a Lambda function as MCP tools,
* allowing the gateway to invoke the function to provide tool capabilities.
*/
class LambdaTargetConfiguration extends McpTargetConfiguration {
static [JSII_RTTI_SYMBOL_1] = { fqn: "@aws-cdk/aws-bedrock-agentcore-alpha.LambdaTargetConfiguration", version: "2.227.0-alpha.0" };
/**
* Create a Lambda target configuration
*
* @param lambdaFunction The Lambda function to invoke
* @param toolSchema The schema defining the tools
* @returns A new LambdaTargetConfiguration instance
*/
static create(lambdaFunction, toolSchema) {
try {
jsiiDeprecationWarnings._aws_cdk_aws_bedrock_agentcore_alpha_ToolSchema(toolSchema);
}
catch (error) {
if (process.env.JSII_DEBUG !== "1" && error.name === "DeprecationError") {
Error.captureStackTrace(error, this.create);
}
throw error;
}
return new LambdaTargetConfiguration(lambdaFunction, toolSchema);
}
targetType = target_base_1.McpTargetType.LAMBDA;
/**
* The Lambda function that implements the MCP server logic
*/
lambdaFunction;
/**
* The tool schema that defines the available tools
*/
toolSchema;
constructor(lambdaFunction, toolSchema) {
super();
try {
jsiiDeprecationWarnings._aws_cdk_aws_bedrock_agentcore_alpha_ToolSchema(toolSchema);
}
catch (error) {
if (process.env.JSII_DEBUG !== "1" && error.name === "DeprecationError") {
Error.captureStackTrace(error, LambdaTargetConfiguration);
}
throw error;
}
this.lambdaFunction = lambdaFunction;
this.toolSchema = toolSchema;
}
/**
* Binds this configuration to a construct scope
* Sets up necessary permissions for the gateway to invoke the Lambda function
*
* @param scope The construct scope
* @param gateway The gateway that will use this target
*/
bind(scope, gateway) {
try {
jsiiDeprecationWarnings._aws_cdk_aws_bedrock_agentcore_alpha_IGateway(gateway);
}
catch (error) {
if (process.env.JSII_DEBUG !== "1" && error.name === "DeprecationError") {
Error.captureStackTrace(error, this.bind);
}
throw error;
}
// Bind the tool schema
this.toolSchema.bind(scope);
// Grant permissions to gateway role
this.toolSchema.grantPermissionsToRole(gateway.role);
this.lambdaFunction.grantInvoke(gateway.role);
return { bound: true };
}
/**
* Renders the MCP-specific configuration
*/
renderMcpConfiguration() {
return {
lambda: {
lambdaArn: this.lambdaFunction.functionArn,
toolSchema: this.toolSchema._render(),
},
};
}
}
exports.LambdaTargetConfiguration = LambdaTargetConfiguration;
/******************************************************************************
* OpenAPI Target Configuration
*****************************************************************************/
/**
* Configuration for OpenAPI-based MCP targets
*
* This configuration exposes an OpenAPI/REST API as MCP tools,
* allowing the gateway to transform API operations into tool calls.
*/
class OpenApiTargetConfiguration extends McpTargetConfiguration {
static [JSII_RTTI_SYMBOL_1] = { fqn: "@aws-cdk/aws-bedrock-agentcore-alpha.OpenApiTargetConfiguration", version: "2.227.0-alpha.0" };
/**
* Create an OpenAPI target configuration
*
* @param apiSchema The OpenAPI schema
* @param validateSchema Whether to validate the OpenAPI schema (only applies to inline schemas)
* @returns A new OpenApiTargetConfiguration instance
*/
static create(apiSchema, validateSchema) {
try {
jsiiDeprecationWarnings._aws_cdk_aws_bedrock_agentcore_alpha_ApiSchema(apiSchema);
}
catch (error) {
if (process.env.JSII_DEBUG !== "1" && error.name === "DeprecationError") {
Error.captureStackTrace(error, this.create);
}
throw error;
}
return new OpenApiTargetConfiguration(apiSchema, validateSchema);
}
targetType = target_base_1.McpTargetType.OPENAPI_SCHEMA;
/**
* The OpenAPI schema that defines the API
*/
apiSchema;
/**
* Whether to validate the OpenAPI schema
*/
shouldValidateSchema;
constructor(apiSchema, validateSchema) {
super();
try {
jsiiDeprecationWarnings._aws_cdk_aws_bedrock_agentcore_alpha_ApiSchema(apiSchema);
}
catch (error) {
if (process.env.JSII_DEBUG !== "1" && error.name === "DeprecationError") {
Error.captureStackTrace(error, OpenApiTargetConfiguration);
}
throw error;
}
this.apiSchema = apiSchema;
this.shouldValidateSchema = validateSchema ?? true;
}
/**
* Binds this configuration to a construct scope
* Sets up necessary permissions for the gateway to access the API schema
*
* @param scope The construct scope
* @param gateway The gateway that will use this target
*/
bind(scope, gateway) {
try {
jsiiDeprecationWarnings._aws_cdk_aws_bedrock_agentcore_alpha_IGateway(gateway);
}
catch (error) {
if (process.env.JSII_DEBUG !== "1" && error.name === "DeprecationError") {
Error.captureStackTrace(error, this.bind);
}
throw error;
}
if (this.shouldValidateSchema) {
// For inline schemas
if (this.apiSchema.inlineSchema) {
const errors = (0, validation_helpers_1.validateOpenApiSchema)({
schema: this.apiSchema.inlineSchema,
schemaName: 'OpenAPI schema for target',
});
if (errors.length > 0) {
throw new validation_helpers_1.ValidationError(`OpenAPI schema validation failed:\n${errors.join('\n')}`);
}
}
else if (this.apiSchema instanceof api_schema_1.AssetApiSchema) {
// For asset schemas (local files)
try {
const schemaContent = fs.readFileSync(this.apiSchema._getFilePath(), 'utf-8');
const errors = (0, validation_helpers_1.validateOpenApiSchema)({
schema: schemaContent,
schemaName: `OpenAPI schema from file ${this.apiSchema._getFilePath()}`,
});
if (errors.length > 0) {
throw new validation_helpers_1.ValidationError(`OpenAPI schema validation failed:\n${errors.join('\n')}`);
}
}
catch (e) {
if (e instanceof validation_helpers_1.ValidationError) {
throw e;
}
throw new validation_helpers_1.ValidationError(`Failed to read OpenAPI schema from ${this.apiSchema._getFilePath()}: ${e instanceof Error ? e.message : String(e)}`);
}
}
// S3 schemas cannot be validated at synthesis time
}
// Bind the API schema
this.apiSchema.bind(scope);
// Grant permissions to gateway role if schema is in S3
this.apiSchema.grantPermissionsToRole(gateway.role);
return { bound: true };
}
/**
* Renders the MCP-specific configuration
*/
renderMcpConfiguration() {
return {
openApiSchema: this.apiSchema._render(),
};
}
}
exports.OpenApiTargetConfiguration = OpenApiTargetConfiguration;
/******************************************************************************
* Smithy Target Configuration
*****************************************************************************/
/**
* Configuration for Smithy-based MCP targets
*
* This configuration exposes a Smithy-modeled API as MCP tools,
* allowing the gateway to transform Smithy operations into tool calls.
*/
class SmithyTargetConfiguration extends McpTargetConfiguration {
static [JSII_RTTI_SYMBOL_1] = { fqn: "@aws-cdk/aws-bedrock-agentcore-alpha.SmithyTargetConfiguration", version: "2.227.0-alpha.0" };
/**
* Create a Smithy target configuration
*
* @param smithyModel The Smithy model schema
* @returns A new SmithyTargetConfiguration instance
*/
static create(smithyModel) {
try {
jsiiDeprecationWarnings._aws_cdk_aws_bedrock_agentcore_alpha_ApiSchema(smithyModel);
}
catch (error) {
if (process.env.JSII_DEBUG !== "1" && error.name === "DeprecationError") {
Error.captureStackTrace(error, this.create);
}
throw error;
}
return new SmithyTargetConfiguration(smithyModel);
}
targetType = target_base_1.McpTargetType.SMITHY_MODEL;
/**
* The Smithy model that defines the API
*/
smithyModel;
constructor(smithyModel) {
super();
try {
jsiiDeprecationWarnings._aws_cdk_aws_bedrock_agentcore_alpha_ApiSchema(smithyModel);
}
catch (error) {
if (process.env.JSII_DEBUG !== "1" && error.name === "DeprecationError") {
Error.captureStackTrace(error, SmithyTargetConfiguration);
}
throw error;
}
this.smithyModel = smithyModel;
}
/**
* Binds this configuration to a construct scope
* Sets up necessary permissions for the gateway to access the Smithy model
*
* @param scope The construct scope
* @param gateway The gateway that will use this target
*/
bind(scope, gateway) {
try {
jsiiDeprecationWarnings._aws_cdk_aws_bedrock_agentcore_alpha_IGateway(gateway);
}
catch (error) {
if (process.env.JSII_DEBUG !== "1" && error.name === "DeprecationError") {
Error.captureStackTrace(error, this.bind);
}
throw error;
}
// Bind the Smithy model
this.smithyModel.bind(scope);
// Grant permissions to gateway role if schema is in S3
this.smithyModel.grantPermissionsToRole(gateway.role);
return { bound: true };
}
/**
* Renders the MCP-specific configuration
*/
renderMcpConfiguration() {
return {
smithyModel: this.smithyModel._render(),
};
}
}
exports.SmithyTargetConfiguration = SmithyTargetConfiguration;
/******************************************************************************
* MCP Server Target Configuration
*****************************************************************************/
/**
* Configuration for MCP Server-based targets
*
* MCP (Model Context Protocol) servers provide tools, data access, and custom
* functions for AI agents. When you configure an MCP server as a gateway target,
* the gateway automatically discovers and indexes available tools through
* synchronization.
*/
class McpServerTargetConfiguration extends McpTargetConfiguration {
static [JSII_RTTI_SYMBOL_1] = { fqn: "@aws-cdk/aws-bedrock-agentcore-alpha.McpServerTargetConfiguration", version: "2.227.0-alpha.0" };
/**
* Create an MCP server target configuration
*
* @param endpoint The HTTPS endpoint URL of the MCP server
* @returns A new McpServerTargetConfiguration instance
*/
static create(endpoint) {
return new McpServerTargetConfiguration(endpoint);
}
targetType = target_base_1.McpTargetType.MCP_SERVER;
/**
* The HTTPS endpoint URL of the MCP server
*/
endpoint;
constructor(endpoint) {
super();
this.endpoint = endpoint;
this.validateEndpoint(endpoint);
}
/**
* Binds this configuration to a construct scope
* No additional permissions are needed for MCP server targets
*
* @param _scope The construct scope
* @param _gateway The gateway that will use this target
*/
bind(_scope, _gateway) {
try {
jsiiDeprecationWarnings._aws_cdk_aws_bedrock_agentcore_alpha_IGateway(_gateway);
}
catch (error) {
if (process.env.JSII_DEBUG !== "1" && error.name === "DeprecationError") {
Error.captureStackTrace(error, this.bind);
}
throw error;
}
// MCP server targets don't require additional permissions setup
// Authentication is handled through credential provider configurations
return { bound: true };
}
/**
* Renders the MCP-specific configuration
*/
renderMcpConfiguration() {
return {
mcpServer: {
endpoint: this.endpoint,
},
};
}
/**
* Validates the MCP server endpoint
* - Must use HTTPS protocol
* - Should be properly URL encoded
*
* @param endpoint The endpoint URL to validate
* @throws ValidationError if the endpoint is invalid
* @internal
*/
validateEndpoint(endpoint) {
if (aws_cdk_lib_1.Token.isUnresolved(endpoint)) {
return;
}
const errors = (0, validation_helpers_1.validateFieldPattern)(endpoint, 'MCP server endpoint', /^https:\/\/.+/, 'MCP server endpoint must use HTTPS protocol (e.g., https://my-server.example.com). Ensure the URL is properly encoded.');
if (errors.length > 0) {
throw new validation_helpers_1.ValidationError(errors.join('\n'));
}
// Additional helpful validation for common URL encoding issues
if (endpoint.includes(' ') || endpoint.includes('<') || endpoint.includes('>')) {
throw new validation_helpers_1.ValidationError('MCP server endpoint contains characters that should be URL-encoded. ' +
'Please ensure the URL is properly encoded before passing to the construct.');
}
}
}
exports.McpServerTargetConfiguration = McpServerTargetConfiguration;
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"target-configuration.js","sourceRoot":"","sources":["target-configuration.ts"],"names":[],"mappings":"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","sourcesContent":["import { Token } from 'aws-cdk-lib';\nimport { IFunction } from 'aws-cdk-lib/aws-lambda';\nimport { Construct } from 'constructs';\nimport * as fs from 'fs';\nimport { IGateway } from '../gateway-base';\nimport { ApiSchema, AssetApiSchema } from './schema/api-schema';\nimport { ToolSchema } from './schema/tool-schema';\nimport { McpTargetType } from './target-base';\nimport { validateOpenApiSchema, validateFieldPattern, ValidationError } from '../validation-helpers';\n\n/******************************************************************************\n *                          Interface\n *****************************************************************************/\n\n/**\n * Configuration returned by binding a target configuration\n */\nexport interface TargetConfigurationConfig {\n  /**\n   * Indicates that the configuration has been successfully bound\n   */\n  readonly bound: boolean;\n}\n\n/**\n * Base interface for target configurations\n */\nexport interface ITargetConfiguration {\n  /**\n   * The target type\n   */\n  readonly targetType: McpTargetType;\n\n  /**\n   * Binds the configuration to a construct scope\n   * Sets up permissions and dependencies\n   */\n  bind(scope: Construct, gateway: IGateway): TargetConfigurationConfig;\n\n  /**\n   * Renders the configuration as CloudFormation properties\n   * @internal\n   */\n  _render(): any;\n}\n\n/******************************************************************************\n *                     MCP Target Configuration Base\n *****************************************************************************/\n\n/**\n * Abstract base class for MCP target configurations\n * Provides common functionality for all MCP target types\n */\nexport abstract class McpTargetConfiguration implements ITargetConfiguration {\n  /**\n   * The target type\n   */\n  public abstract readonly targetType: McpTargetType;\n\n  /**\n   * Binds the configuration to a construct scope\n   * Sets up permissions and dependencies\n   */\n  public abstract bind(scope: Construct, gateway: IGateway): TargetConfigurationConfig;\n\n  /**\n   * Renders the MCP-specific configuration\n   */\n  protected abstract renderMcpConfiguration(): any;\n\n  /**\n   * Renders the configuration as CloudFormation properties\n   * @internal\n   */\n  public _render(): any {\n    return {\n      mcp: this.renderMcpConfiguration(),\n    };\n  }\n}\n\n/******************************************************************************\n *                     Lambda Target Configuration\n *****************************************************************************/\n\n/**\n * Configuration for Lambda-based MCP targets\n *\n * This configuration wraps a Lambda function as MCP tools,\n * allowing the gateway to invoke the function to provide tool capabilities.\n */\nexport class LambdaTargetConfiguration extends McpTargetConfiguration {\n  /**\n   * Create a Lambda target configuration\n   *\n   * @param lambdaFunction The Lambda function to invoke\n   * @param toolSchema The schema defining the tools\n   * @returns A new LambdaTargetConfiguration instance\n   */\n  public static create(\n    lambdaFunction: IFunction,\n    toolSchema: ToolSchema,\n  ): LambdaTargetConfiguration {\n    return new LambdaTargetConfiguration(lambdaFunction, toolSchema);\n  }\n\n  public readonly targetType = McpTargetType.LAMBDA;\n\n  /**\n   * The Lambda function that implements the MCP server logic\n   */\n  public readonly lambdaFunction: IFunction;\n\n  /**\n   * The tool schema that defines the available tools\n   */\n  public readonly toolSchema: ToolSchema;\n\n  constructor(lambdaFunction: IFunction, toolSchema: ToolSchema) {\n    super();\n    this.lambdaFunction = lambdaFunction;\n    this.toolSchema = toolSchema;\n  }\n\n  /**\n   * Binds this configuration to a construct scope\n   * Sets up necessary permissions for the gateway to invoke the Lambda function\n   *\n   * @param scope The construct scope\n   * @param gateway The gateway that will use this target\n   */\n  public bind(scope: Construct, gateway: IGateway): TargetConfigurationConfig {\n    // Bind the tool schema\n    this.toolSchema.bind(scope);\n    // Grant permissions to gateway role\n    this.toolSchema.grantPermissionsToRole(gateway.role);\n    this.lambdaFunction.grantInvoke(gateway.role);\n\n    return { bound: true };\n  }\n\n  /**\n   * Renders the MCP-specific configuration\n   */\n  protected renderMcpConfiguration(): any {\n    return {\n      lambda: {\n        lambdaArn: this.lambdaFunction.functionArn,\n        toolSchema: this.toolSchema._render(),\n      },\n    };\n  }\n}\n\n/******************************************************************************\n *                     OpenAPI Target Configuration\n *****************************************************************************/\n\n/**\n * Configuration for OpenAPI-based MCP targets\n *\n * This configuration exposes an OpenAPI/REST API as MCP tools,\n * allowing the gateway to transform API operations into tool calls.\n */\nexport class OpenApiTargetConfiguration extends McpTargetConfiguration {\n  /**\n   * Create an OpenAPI target configuration\n   *\n   * @param apiSchema The OpenAPI schema\n   * @param validateSchema Whether to validate the OpenAPI schema (only applies to inline schemas)\n   * @returns A new OpenApiTargetConfiguration instance\n   */\n  public static create(apiSchema: ApiSchema, validateSchema?: boolean): OpenApiTargetConfiguration {\n    return new OpenApiTargetConfiguration(apiSchema, validateSchema);\n  }\n\n  public readonly targetType = McpTargetType.OPENAPI_SCHEMA;\n\n  /**\n   * The OpenAPI schema that defines the API\n   */\n  public readonly apiSchema: ApiSchema;\n\n  /**\n   * Whether to validate the OpenAPI schema\n   */\n  private readonly shouldValidateSchema: boolean;\n\n  constructor(apiSchema: ApiSchema, validateSchema?: boolean) {\n    super();\n    this.apiSchema = apiSchema;\n    this.shouldValidateSchema = validateSchema ?? true;\n  }\n\n  /**\n   * Binds this configuration to a construct scope\n   * Sets up necessary permissions for the gateway to access the API schema\n   *\n   * @param scope The construct scope\n   * @param gateway The gateway that will use this target\n   */\n  public bind(scope: Construct, gateway: IGateway): TargetConfigurationConfig {\n    if (this.shouldValidateSchema) {\n      // For inline schemas\n      if (this.apiSchema.inlineSchema) {\n        const errors = validateOpenApiSchema({\n          schema: this.apiSchema.inlineSchema,\n          schemaName: 'OpenAPI schema for target',\n        });\n        if (errors.length > 0) {\n          throw new ValidationError(`OpenAPI schema validation failed:\\n${errors.join('\\n')}`);\n        }\n      } else if (this.apiSchema instanceof AssetApiSchema) {\n        // For asset schemas (local files)\n        try {\n          const schemaContent = fs.readFileSync(this.apiSchema._getFilePath(), 'utf-8');\n          const errors = validateOpenApiSchema({\n            schema: schemaContent,\n            schemaName: `OpenAPI schema from file ${this.apiSchema._getFilePath()}`,\n          });\n          if (errors.length > 0) {\n            throw new ValidationError(`OpenAPI schema validation failed:\\n${errors.join('\\n')}`);\n          }\n        } catch (e) {\n          if (e instanceof ValidationError) {\n            throw e;\n          }\n          throw new ValidationError(\n            `Failed to read OpenAPI schema from ${this.apiSchema._getFilePath()}: ${e instanceof Error ? e.message : String(e)}`,\n          );\n        }\n      }\n      // S3 schemas cannot be validated at synthesis time\n    }\n\n    // Bind the API schema\n    this.apiSchema.bind(scope);\n    // Grant permissions to gateway role if schema is in S3\n    this.apiSchema.grantPermissionsToRole(gateway.role);\n\n    return { bound: true };\n  }\n\n  /**\n   * Renders the MCP-specific configuration\n   */\n  protected renderMcpConfiguration(): any {\n    return {\n      openApiSchema: this.apiSchema._render(),\n    };\n  }\n}\n\n/******************************************************************************\n *                     Smithy Target Configuration\n *****************************************************************************/\n\n/**\n * Configuration for Smithy-based MCP targets\n *\n * This configuration exposes a Smithy-modeled API as MCP tools,\n * allowing the gateway to transform Smithy operations into tool calls.\n */\nexport class SmithyTargetConfiguration extends McpTargetConfiguration {\n  /**\n   * Create a Smithy target configuration\n   *\n   * @param smithyModel The Smithy model schema\n   * @returns A new SmithyTargetConfiguration instance\n   */\n  public static create(smithyModel: ApiSchema): SmithyTargetConfiguration {\n    return new SmithyTargetConfiguration(smithyModel);\n  }\n\n  public readonly targetType = McpTargetType.SMITHY_MODEL;\n\n  /**\n   * The Smithy model that defines the API\n   */\n  public readonly smithyModel: ApiSchema;\n\n  constructor(smithyModel: ApiSchema) {\n    super();\n    this.smithyModel = smithyModel;\n  }\n\n  /**\n   * Binds this configuration to a construct scope\n   * Sets up necessary permissions for the gateway to access the Smithy model\n   *\n   * @param scope The construct scope\n   * @param gateway The gateway that will use this target\n   */\n  public bind(scope: Construct, gateway: IGateway): TargetConfigurationConfig {\n    // Bind the Smithy model\n    this.smithyModel.bind(scope);\n    // Grant permissions to gateway role if schema is in S3\n    this.smithyModel.grantPermissionsToRole(gateway.role);\n\n    return { bound: true };\n  }\n\n  /**\n   * Renders the MCP-specific configuration\n   */\n  protected renderMcpConfiguration(): any {\n    return {\n      smithyModel: this.smithyModel._render(),\n    };\n  }\n}\n\n/******************************************************************************\n *                     MCP Server Target Configuration\n *****************************************************************************/\n\n/**\n * Configuration for MCP Server-based targets\n *\n * MCP (Model Context Protocol) servers provide tools, data access, and custom\n * functions for AI agents. When you configure an MCP server as a gateway target,\n * the gateway automatically discovers and indexes available tools through\n * synchronization.\n */\nexport class McpServerTargetConfiguration extends McpTargetConfiguration {\n  /**\n   * Create an MCP server target configuration\n   *\n   * @param endpoint The HTTPS endpoint URL of the MCP server\n   * @returns A new McpServerTargetConfiguration instance\n   */\n  public static create(endpoint: string): McpServerTargetConfiguration {\n    return new McpServerTargetConfiguration(endpoint);\n  }\n\n  public readonly targetType = McpTargetType.MCP_SERVER;\n\n  /**\n   * The HTTPS endpoint URL of the MCP server\n   */\n  public readonly endpoint: string;\n\n  constructor(endpoint: string) {\n    super();\n    this.endpoint = endpoint;\n    this.validateEndpoint(endpoint);\n  }\n\n  /**\n   * Binds this configuration to a construct scope\n   * No additional permissions are needed for MCP server targets\n   *\n   * @param _scope The construct scope\n   * @param _gateway The gateway that will use this target\n   */\n  public bind(_scope: Construct, _gateway: IGateway): TargetConfigurationConfig {\n    // MCP server targets don't require additional permissions setup\n    // Authentication is handled through credential provider configurations\n    return { bound: true };\n  }\n\n  /**\n   * Renders the MCP-specific configuration\n   */\n  protected renderMcpConfiguration(): any {\n    return {\n      mcpServer: {\n        endpoint: this.endpoint,\n      },\n    };\n  }\n\n  /**\n   * Validates the MCP server endpoint\n   * - Must use HTTPS protocol\n   * - Should be properly URL encoded\n   *\n   * @param endpoint The endpoint URL to validate\n   * @throws ValidationError if the endpoint is invalid\n   * @internal\n   */\n  private validateEndpoint(endpoint: string): void {\n    if (Token.isUnresolved(endpoint)) {\n      return;\n    }\n\n    const errors = validateFieldPattern(\n      endpoint,\n      'MCP server endpoint',\n      /^https:\\/\\/.+/,\n      'MCP server endpoint must use HTTPS protocol (e.g., https://my-server.example.com). Ensure the URL is properly encoded.',\n    );\n\n    if (errors.length > 0) {\n      throw new ValidationError(errors.join('\\n'));\n    }\n\n    // Additional helpful validation for common URL encoding issues\n    if (endpoint.includes(' ') || endpoint.includes('<') || endpoint.includes('>')) {\n      throw new ValidationError(\n        'MCP server endpoint contains characters that should be URL-encoded. ' +\n        'Please ensure the URL is properly encoded before passing to the construct.',\n      );\n    }\n  }\n}\n"]}