@aws-cdk/aws-bedrock-agentcore-alpha
Version:
The CDK Construct Library for Amazon Bedrock
213 lines • 25.2 kB
JavaScript
;
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"]}