UNPKG

@aws-cdk/aws-bedrock-agentcore-alpha

Version:

The CDK Construct Library for Amazon Bedrock

213 lines 25.2 kB
"use strict"; Object.defineProperty(exports, "__esModule", { value: true }); exports.S3ToolSchema = exports.InlineToolSchema = exports.AssetToolSchema = exports.ToolSchema = exports.SchemaDefinitionType = void 0; const JSII_RTTI_SYMBOL_1 = Symbol.for("jsii.rtti"); const aws_cdk_lib_1 = require("aws-cdk-lib"); const aws_iam_1 = require("aws-cdk-lib/aws-iam"); const s3_assets = require("aws-cdk-lib/aws-s3-assets"); const base_schema_1 = require("./base-schema"); /** * Schema definition types */ var SchemaDefinitionType; (function (SchemaDefinitionType) { /** String type */ SchemaDefinitionType["STRING"] = "string"; /** Number type */ SchemaDefinitionType["NUMBER"] = "number"; /** Object type */ SchemaDefinitionType["OBJECT"] = "object"; /** Array type */ SchemaDefinitionType["ARRAY"] = "array"; /** Boolean type */ SchemaDefinitionType["BOOLEAN"] = "boolean"; /** Integer type */ SchemaDefinitionType["INTEGER"] = "integer"; })(SchemaDefinitionType || (exports.SchemaDefinitionType = SchemaDefinitionType = {})); /** * Error thrown when a ToolSchema is not properly initialized. */ class ToolSchemaError extends Error { cause; constructor(message, cause) { super(message); this.cause = cause; this.name = 'ToolSchemaError'; } } /****************************************************************************** * TOOL SCHEMA CLASS *****************************************************************************/ class ToolSchema extends base_schema_1.TargetSchema { static [JSII_RTTI_SYMBOL_1] = { fqn: "@aws-cdk/aws-bedrock-agentcore-alpha.ToolSchema", version: "2.227.0-alpha.0" }; /** * Creates a tool Schema from a local file. * @param path - the path to the local file containing the function schema for the tool */ static fromLocalAsset(path) { return new AssetToolSchema(path); } /** * Creates a Tool Schema from an inline string. * @param schema - the JSON or YAML payload defining the OpenAPI schema for the action group */ static fromInline(schema) { return new InlineToolSchema(schema); } /** * Creates a Tool Schema from an S3 File * @param bucket - the bucket containing the local file containing the OpenAPI schema for the action group * @param objectKey - object key in the bucket * @param bucketOwnerAccountId - optional The account ID of the Amazon S3 bucket owner. This ID is used for cross-account access to the bucket. */ static fromS3File(bucket, objectKey, bucketOwnerAccountId) { return new S3ToolSchema({ bucketName: bucket.bucketName, objectKey: objectKey, }, bucketOwnerAccountId); } /** * The S3 location of the tool schema file, if using an S3-based schema. * Contains the bucket name and object key information. */ s3File; /** * The inline tool schema definition as a string, if using an inline schema. * Can be in JSON or YAML format. */ inlineSchema; /** * The account ID of the S3 bucket owner for cross-account access */ bucketOwnerAccountId; constructor(s3File, bucketOwnerAccountId, inlineSchema) { super(); this.s3File = s3File; this.inlineSchema = inlineSchema; this.bucketOwnerAccountId = bucketOwnerAccountId; } } exports.ToolSchema = ToolSchema; /** * Tool Schema from a local asset. * * The asset is uploaded to an S3 staging bucket, then moved to its final location * by CloudFormation during deployment. */ class AssetToolSchema extends ToolSchema { path; options; static [JSII_RTTI_SYMBOL_1] = { fqn: "@aws-cdk/aws-bedrock-agentcore-alpha.AssetToolSchema", version: "2.227.0-alpha.0" }; asset; constructor(path, options = {}) { super(); this.path = path; this.options = options; } /** * Binds this tool schema to a construct scope. * This method initializes the S3 asset if it hasn't been initialized yet. * Must be called before rendering the schema as CFN properties. * * @param scope - The construct scope to bind to */ bind(scope) { // If the same AssetToolSchema is used multiple times, retain only the first instantiation if (!this.asset) { this.asset = new s3_assets.Asset(scope, 'Schema', { path: this.path, ...this.options, }); // Note: Permissions will be granted by the Gateway target construct when adding the target } } /** * Format as CFN properties * @internal This is an internal core function and should not be called directly. */ _render() { if (!this.asset) { throw new ToolSchemaError('ToolSchema must be bound to a scope before rendering. Call bind() first.', 'Asset not initialized'); } return { s3: { uri: `s3://${this.asset.s3BucketName}/${this.asset.s3ObjectKey}`, }, }; } grantPermissionsToRole(role) { if (!this.asset) { throw new ToolSchemaError('ToolSchema must be bound to a scope before rendering. Call bind() first.', 'Asset not initialized'); } this.asset.grantRead(role); } } exports.AssetToolSchema = AssetToolSchema; // ------------------------------------------------------ /** * Class to define a Tool Schema from an inline string. * The schema can be provided directly as a string in either JSON or YAML format. */ class InlineToolSchema extends ToolSchema { schema; static [JSII_RTTI_SYMBOL_1] = { fqn: "@aws-cdk/aws-bedrock-agentcore-alpha.InlineToolSchema", version: "2.227.0-alpha.0" }; constructor(schema) { super(undefined, undefined, schema); this.schema = schema; } /** * @internal This is an internal core function and should not be called directly. */ _render() { return { inlinePayload: this.schema, }; } bind(scope) { if (scope) { } } grantPermissionsToRole(_role) { } } exports.InlineToolSchema = InlineToolSchema; // ------------------------------------------------------ // S3 File // ------------------------------------------------------ /** * Class to define a Tool Schema from an S3 object. */ class S3ToolSchema extends ToolSchema { location; bucketOwnerAccountId; static [JSII_RTTI_SYMBOL_1] = { fqn: "@aws-cdk/aws-bedrock-agentcore-alpha.S3ToolSchema", version: "2.227.0-alpha.0" }; constructor(location, bucketOwnerAccountId) { super(location, bucketOwnerAccountId, undefined); this.location = location; this.bucketOwnerAccountId = bucketOwnerAccountId; } /** * @internal This is an internal core function and should not be called directly. */ _render() { return { s3: { uri: `s3://${this.location.bucketName}/${this.location.objectKey}`, ...(this.bucketOwnerAccountId && { bucketOwnerAccountId: this.bucketOwnerAccountId }), }, }; } bind(scope) { if (scope) { } } grantPermissionsToRole(role) { aws_iam_1.Grant.addToPrincipal({ grantee: role, actions: ['s3:GetObject'], resourceArns: [`arn:${aws_cdk_lib_1.Aws.PARTITION}:s3:::${this.location.bucketName}/${this.location.objectKey}`], }); } } exports.S3ToolSchema = S3ToolSchema; //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"tool-schema.js","sourceRoot":"","sources":["tool-schema.ts"],"names":[],"mappings":"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","sourcesContent":["import { Aws } from 'aws-cdk-lib';\nimport { Grant, IRole } from 'aws-cdk-lib/aws-iam';\nimport { IBucket, Location } from 'aws-cdk-lib/aws-s3';\nimport * as s3_assets from 'aws-cdk-lib/aws-s3-assets';\nimport { Construct } from 'constructs';\nimport { TargetSchema } from './base-schema';\n\n/******************************************************************************\n *                                Tool Schema Configuration\n *****************************************************************************/\n\n/**\n * Abstract interface for tool schema configuration\n * @internal\n */\nexport interface IToolSchemaConfiguration {\n  /**\n   * The tool schema configuration type\n   */\n  readonly toolSchemaType: string;\n\n  /**\n   * The tool schema configuration object\n   */\n  readonly configuration: any;\n}\n\n/**\n * Schema definition types\n */\nexport enum SchemaDefinitionType {\n  /** String type */\n  STRING = 'string',\n  /** Number type */\n  NUMBER = 'number',\n  /** Object type */\n  OBJECT = 'object',\n  /** Array type */\n  ARRAY = 'array',\n  /** Boolean type */\n  BOOLEAN = 'boolean',\n  /** Integer type */\n  INTEGER = 'integer',\n}\n\n/**\n * Schema definition for tool input/output\n */\nexport interface SchemaDefinition {\n  /**\n   * The type of the schema definition. This field specifies the data type of the schema.\n   */\n  readonly type: SchemaDefinitionType;\n\n  /**\n   * The description of the schema definition. This description provides information about the purpose and usage of the schema.\n   */\n  /**\n   * The description of the schema definition. This description provides information about the purpose and usage of the schema.\n   * @default - No description\n   */\n  readonly description?: string;\n\n  /**\n   * The items in the schema definition. This field is used for array types to define the structure of the array elements.\n   */\n  /**\n   * The items in the schema definition. This field is used for array types to define the structure of the array elements.\n   * @default - No items definition\n   */\n  readonly items?: SchemaDefinition;\n\n  /**\n   * The properties of the schema definition. These properties define the fields in the schema.\n   */\n  /**\n   * The properties of the schema definition. These properties define the fields in the schema.\n   * @default - No properties\n   */\n  readonly properties?: Record<string, SchemaDefinition>;\n\n  /**\n   * The required fields in the schema definition. These fields must be provided when using the schema.\n   * @default - No required fields\n   */\n  readonly required?: string[];\n}\n\n/**\n * Tool definition for inline payload\n */\nexport interface ToolDefinition {\n  /**\n   * The name of the tool. This name identifies the tool in the Model Context Protocol.\n   */\n  readonly name: string;\n\n  /**\n   * The description of the tool. This description provides information about the purpose and usage of the tool.\n   */\n  readonly description: string;\n\n  /**\n   * The input schema for the tool. This schema defines the structure of the input that the tool accepts.\n   */\n  readonly inputSchema: SchemaDefinition;\n\n  /**\n   * The output schema for the tool. This schema defines the structure of the output that the tool produces.\n   */\n  /**\n   * The output schema for the tool. This schema defines the structure of the output that the tool produces.\n   * @default - No output schema\n   */\n  readonly outputSchema?: SchemaDefinition;\n}\n\n/**\n * Error thrown when a ToolSchema is not properly initialized.\n */\nclass ToolSchemaError extends Error {\n  constructor(message: string, public readonly cause?: string) {\n    super(message);\n    this.name = 'ToolSchemaError';\n  }\n}\n\n/******************************************************************************\n *                       TOOL SCHEMA CLASS\n *****************************************************************************/\nexport abstract class ToolSchema extends TargetSchema {\n  /**\n   * Creates a tool Schema from a local file.\n   * @param path - the path to the local file containing the function schema for the tool\n   */\n  public static fromLocalAsset(path: string): ToolSchema {\n    return new AssetToolSchema(path);\n  }\n\n  /**\n   * Creates a Tool Schema from an inline string.\n   * @param schema - the JSON or YAML payload defining the OpenAPI schema for the action group\n   */\n  public static fromInline(schema: ToolDefinition[]): InlineToolSchema {\n    return new InlineToolSchema(schema);\n  }\n\n  /**\n   * Creates a Tool Schema from an S3 File\n   * @param bucket - the bucket containing the local file containing the OpenAPI schema for the action group\n   * @param objectKey - object key in the bucket\n   * @param bucketOwnerAccountId - optional The account ID of the Amazon S3 bucket owner. This ID is used for cross-account access to the bucket.\n   */\n  public static fromS3File(bucket: IBucket, objectKey: string, bucketOwnerAccountId?: string): S3ToolSchema {\n    return new S3ToolSchema(\n      {\n        bucketName: bucket.bucketName,\n        objectKey: objectKey,\n      },\n      bucketOwnerAccountId,\n    );\n  }\n\n  /**\n   * The S3 location of the tool schema file, if using an S3-based schema.\n   * Contains the bucket name and object key information.\n   */\n  public readonly s3File?: Location;\n\n  /**\n   * The inline tool schema definition as a string, if using an inline schema.\n   * Can be in JSON or YAML format.\n   */\n  public readonly inlineSchema?: ToolDefinition[];\n\n  /**\n   * The account ID of the S3 bucket owner for cross-account access\n   */\n  public readonly bucketOwnerAccountId?: string;\n\n  protected constructor(s3File?: Location, bucketOwnerAccountId?: string, inlineSchema?: ToolDefinition[]) {\n    super();\n    this.s3File = s3File;\n    this.inlineSchema = inlineSchema;\n    this.bucketOwnerAccountId = bucketOwnerAccountId;\n  }\n\n  /**\n   * Format as CFN properties\n   * @internal This is an internal core function and should not be called directly.\n   */\n  public abstract _render(): any;\n}\n\n/**\n * Tool Schema from a local asset.\n *\n * The asset is uploaded to an S3 staging bucket, then moved to its final location\n * by CloudFormation during deployment.\n */\nexport class AssetToolSchema extends ToolSchema {\n  private asset?: s3_assets.Asset;\n\n  constructor(private readonly path: string, private readonly options: s3_assets.AssetOptions = {}) {\n    super();\n  }\n\n  /**\n   * Binds this tool schema to a construct scope.\n   * This method initializes the S3 asset if it hasn't been initialized yet.\n   * Must be called before rendering the schema as CFN properties.\n   *\n   * @param scope - The construct scope to bind to\n   */\n  public bind(scope: Construct): void {\n    // If the same AssetToolSchema is used multiple times, retain only the first instantiation\n    if (!this.asset) {\n      this.asset = new s3_assets.Asset(scope, 'Schema', {\n        path: this.path,\n        ...this.options,\n      });\n      // Note: Permissions will be granted by the Gateway target construct when adding the target\n    }\n  }\n\n  /**\n   * Format as CFN properties\n   * @internal This is an internal core function and should not be called directly.\n   */\n  public _render(): any {\n    if (!this.asset) {\n      throw new ToolSchemaError(\n        'ToolSchema must be bound to a scope before rendering. Call bind() first.',\n        'Asset not initialized',\n      );\n    }\n\n    return {\n      s3: {\n        uri: `s3://${this.asset.s3BucketName}/${this.asset.s3ObjectKey}`,\n      },\n    };\n  }\n\n  public grantPermissionsToRole(role: IRole): void {\n    if (!this.asset) {\n      throw new ToolSchemaError(\n        'ToolSchema must be bound to a scope before rendering. Call bind() first.',\n        'Asset not initialized',\n      );\n    }\n    this.asset.grantRead(role);\n  }\n}\n\n// ------------------------------------------------------\n/**\n * Class to define a Tool Schema from an inline string.\n * The schema can be provided directly as a string in either JSON or YAML format.\n */\nexport class InlineToolSchema extends ToolSchema {\n  constructor(private readonly schema: ToolDefinition[]) {\n    super(undefined, undefined, schema);\n  }\n\n  /**\n   * @internal This is an internal core function and should not be called directly.\n   */\n  public _render(): any {\n    return {\n      inlinePayload: this.schema,\n    };\n  }\n\n  public bind(scope: Construct): void {\n    if (scope) {\n    }\n    // No-op\n  }\n\n  public grantPermissionsToRole(_role: IRole): void {\n    // No-op - InlineToolSchema doesn't need permissions\n  }\n}\n\n// ------------------------------------------------------\n// S3 File\n// ------------------------------------------------------\n/**\n * Class to define a Tool Schema from an S3 object.\n */\nexport class S3ToolSchema extends ToolSchema {\n  constructor(private readonly location: Location, public readonly bucketOwnerAccountId?: string) {\n    super(location, bucketOwnerAccountId, undefined);\n  }\n  /**\n   * @internal This is an internal core function and should not be called directly.\n   */\n  public _render(): any {\n    return {\n      s3: {\n        uri: `s3://${this.location.bucketName}/${this.location.objectKey}`,\n        ...(this.bucketOwnerAccountId && { bucketOwnerAccountId: this.bucketOwnerAccountId }),\n      },\n    };\n  }\n\n  public bind(scope: Construct): void {\n    if (scope) {\n    }\n    // No-op\n  }\n\n  public grantPermissionsToRole(role: IRole): void {\n    Grant.addToPrincipal({\n      grantee: role,\n      actions: ['s3:GetObject'],\n      resourceArns: [`arn:${Aws.PARTITION}:s3:::${this.location.bucketName}/${this.location.objectKey}`],\n    });\n  }\n}\n"]}