UNPKG

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

Version:

The CDK Construct Library for Amazon Bedrock

207 lines 20.6 kB
"use strict"; Object.defineProperty(exports, "__esModule", { value: true }); exports.S3ApiSchema = exports.InlineApiSchema = exports.AssetApiSchema = exports.ApiSchema = 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"); /** * Error thrown when an ApiSchema is not properly initialized. */ class ApiSchemaError extends Error { cause; constructor(message, cause) { super(message); this.cause = cause; this.name = 'ApiSchemaError'; } } /****************************************************************************** * API SCHEMA CLASS *****************************************************************************/ /** * Represents the concept of an API Schema for a Gateway Target. */ class ApiSchema extends base_schema_1.TargetSchema { static [JSII_RTTI_SYMBOL_1] = { fqn: "@aws-cdk/aws-bedrock-agentcore-alpha.ApiSchema", version: "2.227.0-alpha.0" }; /** * Creates an API Schema from a local file. * @param path - the path to the local file containing the OpenAPI schema for the action group */ static fromLocalAsset(path) { return new AssetApiSchema(path); } /** * Creates an API Schema from an inline string. * @param schema - the JSON or YAML payload defining the schema (OpenAPI or Smithy) */ static fromInline(schema) { return new InlineApiSchema(schema); } /** * Creates an API 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 S3ApiSchema({ bucketName: bucket.bucketName, objectKey: objectKey, }, bucketOwnerAccountId); } /** * The S3 location of the API schema file, if using an S3-based schema. * Contains the bucket name and object key information. */ s3File; /** * The inline OpenAPI 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.ApiSchema = ApiSchema; /** * API 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 AssetApiSchema extends ApiSchema { path; options; static [JSII_RTTI_SYMBOL_1] = { fqn: "@aws-cdk/aws-bedrock-agentcore-alpha.AssetApiSchema", version: "2.227.0-alpha.0" }; asset; constructor(path, options = {}) { super(); this.path = path; this.options = options; } /** * Gets the file path for internal validation purposes * @internal */ _getFilePath() { return this.path; } /** * Binds this API 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 AssetApiSchema is used multiple times, retain only the first instantiation if (!this.asset) { // Note: Validation is handled at the target configuration level where we know the schema type // and whether validation is enabled 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 ApiSchemaError('ApiSchema 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) { this.asset.grantRead(role); } } } exports.AssetApiSchema = AssetApiSchema; // ------------------------------------------------------ /** * Class to define an API Schema from an inline string. * The schema can be provided directly as a string. * Validation is performed at the target configuration level where the schema type is known. */ class InlineApiSchema extends ApiSchema { schema; static [JSII_RTTI_SYMBOL_1] = { fqn: "@aws-cdk/aws-bedrock-agentcore-alpha.InlineApiSchema", 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, }; } grantPermissionsToRole(_role) { } bind(scope) { if (scope) { } } } exports.InlineApiSchema = InlineApiSchema; // ------------------------------------------------------ // S3 File // ------------------------------------------------------ /** * Class to define an API Schema from an S3 object. */ class S3ApiSchema extends ApiSchema { location; bucketOwnerAccountId; static [JSII_RTTI_SYMBOL_1] = { fqn: "@aws-cdk/aws-bedrock-agentcore-alpha.S3ApiSchema", 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.S3ApiSchema = S3ApiSchema; //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"api-schema.js","sourceRoot":"","sources":["api-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 * Error thrown when an ApiSchema is not properly initialized.\n */\nclass ApiSchemaError extends Error {\n  constructor(message: string, public readonly cause?: string) {\n    super(message);\n    this.name = 'ApiSchemaError';\n  }\n}\n\n/******************************************************************************\n *                       API SCHEMA CLASS\n *****************************************************************************/\n/**\n * Represents the concept of an API Schema for a Gateway Target.\n */\nexport abstract class ApiSchema extends TargetSchema {\n  /**\n   * Creates an API Schema from a local file.\n   * @param path - the path to the local file containing the OpenAPI schema for the action group\n   */\n  public static fromLocalAsset(path: string): AssetApiSchema {\n    return new AssetApiSchema(path);\n  }\n\n  /**\n   * Creates an API Schema from an inline string.\n   * @param schema - the JSON or YAML payload defining the schema (OpenAPI or Smithy)\n   */\n  public static fromInline(schema: string): InlineApiSchema {\n    return new InlineApiSchema(schema);\n  }\n\n  /**\n   * Creates an API 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): S3ApiSchema {\n    return new S3ApiSchema(\n      {\n        bucketName: bucket.bucketName,\n        objectKey: objectKey,\n      },\n      bucketOwnerAccountId,\n    );\n  }\n\n  /**\n   * The S3 location of the API 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 OpenAPI schema definition as a string, if using an inline schema.\n   * Can be in JSON or YAML format.\n   */\n  public readonly inlineSchema?: string;\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?: string) {\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 * API 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 AssetApiSchema extends ApiSchema {\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   * Gets the file path for internal validation purposes\n   * @internal\n   */\n  public _getFilePath(): string {\n    return this.path;\n  }\n\n  /**\n   * Binds this API 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 AssetApiSchema is used multiple times, retain only the first instantiation\n    if (!this.asset) {\n      // Note: Validation is handled at the target configuration level where we know the schema type\n      // and whether validation is enabled\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 ApiSchemaError(\n        'ApiSchema 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      this.asset.grantRead(role);\n    }\n  }\n}\n\n// ------------------------------------------------------\n/**\n * Class to define an API Schema from an inline string.\n * The schema can be provided directly as a string.\n * Validation is performed at the target configuration level where the schema type is known.\n */\nexport class InlineApiSchema extends ApiSchema {\n  constructor(private readonly schema: string) {\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 grantPermissionsToRole(_role: IRole): void {\n    // No-op - InlineApiSchema doesn't need permissions\n  }\n\n  public bind(scope: Construct): void {\n    if (scope) {\n    }\n    // No-op - validation is handled at the target configuration level\n    // where we know whether this is OpenAPI or Smithy\n  }\n}\n\n// ------------------------------------------------------\n// S3 File\n// ------------------------------------------------------\n/**\n * Class to define an API Schema from an S3 object.\n */\nexport class S3ApiSchema extends ApiSchema {\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"]}