@aws-cdk/aws-bedrock-agentcore-alpha
Version:
The CDK Construct Library for Amazon Bedrock
197 lines • 31.5 kB
JavaScript
"use strict";
Object.defineProperty(exports, "__esModule", { value: true });
exports.RuntimeBase = void 0;
const JSII_RTTI_SYMBOL_1 = Symbol.for("jsii.rtti");
/**
* Copyright Amazon.com, Inc. or its affiliates. All Rights Reserved.
*
* Licensed under the Apache License, Version 2.0 (the "License"). You may not use this file except in compliance
* with the License. A copy of the License is located at
*
* http://www.apache.org/licenses/LICENSE-2.0
*
* or in the 'license' file accompanying this file. This file is distributed on an 'AS IS' BASIS, WITHOUT WARRANTIES
* OR CONDITIONS OF ANY KIND, express or implied. See the License for the specific language governing permissions
* and limitations under the License.
*/
const aws_cdk_lib_1 = require("aws-cdk-lib");
const aws_cloudwatch_1 = require("aws-cdk-lib/aws-cloudwatch");
const iam = require("aws-cdk-lib/aws-iam");
const perms_1 = require("./perms");
const validation_helpers_1 = require("./validation-helpers");
/******************************************************************************
* Base Class
*****************************************************************************/
/**
* Base class for Agent Runtime
*/
class RuntimeBase extends aws_cdk_lib_1.Resource {
static [JSII_RTTI_SYMBOL_1] = { fqn: "@aws-cdk/aws-bedrock-agentcore-alpha.RuntimeBase", version: "2.227.0-alpha.0" };
/**
* An accessor for the Connections object that will fail if this Runtime does not have a VPC
* configured.
*/
get connections() {
if (!this._connections) {
throw new validation_helpers_1.ValidationError('Cannot manage network access without configuring a VPC');
}
return this._connections;
}
/**
* The actual Connections object for this Runtime. This may be unset in the event that a VPC has not
* been configured.
* @internal
*/
_connections;
constructor(scope, id) {
super(scope, id);
}
/**
* Grant the runtime specific actions on AWS resources
*
* @param actions The actions to grant
* @param resources The resource ARNs to grant access to
* @returns The Grant object for chaining
*/
grant(actions, resources) {
return iam.Grant.addToPrincipal({
grantee: this.role,
actions,
resourceArns: resources,
});
}
/**
* Adds a policy statement to the runtime's execution role
*
* @param statement The IAM policy statement to add
* @returns The runtime instance for chaining
*/
addToRolePolicy(statement) {
this.role.addToPrincipalPolicy(statement);
return this;
}
/**
* Permits an IAM principal to invoke this runtime
* Grants the bedrock-agentcore:InvokeAgentRuntime permission
* @param grantee The principal to grant access to
*/
grantInvokeRuntime(grantee) {
return iam.Grant.addToPrincipal({
grantee,
actions: perms_1.RUNTIME_INVOKE_PERMS,
resourceArns: [this.agentRuntimeArn],
});
}
/**
* Permits an IAM principal to invoke this runtime on behalf of a user
* Grants the bedrock-agentcore:InvokeAgentRuntimeForUser permission
* Required when using the X-Amzn-Bedrock-AgentCore-Runtime-User-Id header
* @param grantee The principal to grant access to
*/
grantInvokeRuntimeForUser(grantee) {
return iam.Grant.addToPrincipal({
grantee,
actions: perms_1.RUNTIME_INVOKE_USER_PERMS,
resourceArns: [this.agentRuntimeArn],
});
}
/**
* Permits an IAM principal to invoke this runtime both directly and on behalf of users
* Grants both bedrock-agentcore:InvokeAgentRuntime and bedrock-agentcore:InvokeAgentRuntimeForUser permissions
* @param grantee The principal to grant access to
*/
grantInvoke(grantee) {
return iam.Grant.addToPrincipal({
grantee,
actions: [...perms_1.RUNTIME_INVOKE_PERMS, ...perms_1.RUNTIME_INVOKE_USER_PERMS],
resourceArns: [this.agentRuntimeArn],
});
}
// ------------------------------------------------------
// Metrics
// ------------------------------------------------------
/**
* Return the given named metric for this agent runtime.
*
* By default, the metric will be calculated as a sum over a period of 5 minutes.
* You can customize this by using the `statistic` and `period` properties.
*/
metric(metricName, dimensions, props) {
const metricProps = {
namespace: 'AWS/Bedrock-AgentCore',
metricName,
dimensionsMap: { ...dimensions, Resource: this.agentRuntimeArn },
...props,
};
return this.configureMetric(metricProps);
}
/**
* Return a metric containing the total number of invocations for this agent runtime.
*/
metricInvocations(props) {
return this.metric('Invocations', {}, { statistic: aws_cloudwatch_1.Stats.SUM, ...props });
}
/**
* Return a metric containing the total number of invocations across all resources.
*/
metricInvocationsAggregated(props) {
return this.metric('Invocations', { Resource: 'All' }, { statistic: aws_cloudwatch_1.Stats.SUM, ...props });
}
/**
* Return a metric containing the number of throttled requests for this agent runtime.
*/
metricThrottles(props) {
return this.metric('Throttles', {}, { statistic: aws_cloudwatch_1.Stats.SUM, ...props });
}
/**
* Return a metric containing the number of system errors for this agent runtime.
*/
metricSystemErrors(props) {
return this.metric('SystemErrors', {}, { statistic: aws_cloudwatch_1.Stats.SUM, ...props });
}
/**
* Return a metric containing the number of user errors for this agent runtime.
*/
metricUserErrors(props) {
return this.metric('UserErrors', {}, { statistic: aws_cloudwatch_1.Stats.SUM, ...props });
}
/**
* Return a metric measuring the latency of requests for this agent runtime.
*
* The latency metric represents the total time elapsed between receiving the request
* and sending the final response token, representing complete end-to-end processing time.
*/
metricLatency(props) {
return this.metric('Latency', {}, { statistic: aws_cloudwatch_1.Stats.AVERAGE, ...props });
}
/**
* Return a metric containing the total number of errors (system + user) for this agent runtime.
*/
metricTotalErrors(props) {
return this.metric('TotalErrors', {}, { statistic: aws_cloudwatch_1.Stats.SUM, ...props });
}
/**
* Return a metric containing the number of agent sessions for this agent runtime.
*/
metricSessionCount(props) {
return this.metric('SessionCount', {}, { statistic: aws_cloudwatch_1.Stats.SUM, ...props });
}
/**
* Return a metric containing the total number of sessions across all resources.
*/
metricSessionsAggregated(props) {
return this.metric('Sessions', { Resource: 'All' }, { statistic: aws_cloudwatch_1.Stats.SUM, ...props });
}
/**
* Internal method to create a metric.
*/
configureMetric(props) {
return new aws_cloudwatch_1.Metric({
...props,
region: props?.region ?? this.stack.region,
account: props?.account ?? this.stack.account,
});
}
}
exports.RuntimeBase = RuntimeBase;
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"runtime-base.js","sourceRoot":"","sources":["runtime-base.ts"],"names":[],"mappings":"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","sourcesContent":["/**\n *  Copyright Amazon.com, Inc. or its affiliates. All Rights Reserved.\n *\n *  Licensed under the Apache License, Version 2.0 (the \"License\"). You may not use this file except in compliance\n *  with the License. A copy of the License is located at\n *\n *      http://www.apache.org/licenses/LICENSE-2.0\n *\n *  or in the 'license' file accompanying this file. This file is distributed on an 'AS IS' BASIS, WITHOUT WARRANTIES\n *  OR CONDITIONS OF ANY KIND, express or implied. See the License for the specific language governing permissions\n *  and limitations under the License.\n */\n\nimport { IResource, Resource } from 'aws-cdk-lib';\nimport {\n  DimensionsMap,\n  Metric,\n  MetricOptions,\n  MetricProps,\n  Stats,\n} from 'aws-cdk-lib/aws-cloudwatch';\nimport * as ec2 from 'aws-cdk-lib/aws-ec2';\nimport * as iam from 'aws-cdk-lib/aws-iam';\nimport { Construct } from 'constructs';\nimport { RUNTIME_INVOKE_PERMS, RUNTIME_INVOKE_USER_PERMS } from './perms';\nimport { ValidationError } from './validation-helpers';\n\n/******************************************************************************\n *                                Interface\n *****************************************************************************/\n\n/**\n * Interface for Agent Runtime resources\n */\nexport interface IBedrockAgentRuntime extends IResource, iam.IGrantable, ec2.IConnectable {\n  /**\n   * The ARN of the agent runtime resource\n   * - Format `arn:${Partition}:bedrock-agentcore:${Region}:${Account}:runtime/${RuntimeId}`\n   *\n   * @attribute\n   * @example \"arn:aws:bedrock-agentcore:us-west-2:123456789012:runtime/runtime-abc123\"\n   */\n  readonly agentRuntimeArn: string;\n\n  /**\n   * The ID of the agent runtime\n   * @attribute\n   * @example \"runtime-abc123\"\n   */\n  readonly agentRuntimeId: string;\n\n  /**\n   * The name of the agent runtime\n   */\n  readonly agentRuntimeName: string;\n\n  /**\n   * The IAM role that provides permissions for the agent runtime\n   *\n   */\n  readonly role: iam.IRole;\n\n  /**\n   * The version of the agent runtime\n   * @attribute\n   */\n  readonly agentRuntimeVersion?: string;\n\n  /**\n   * The current status of the agent runtime\n   */\n  readonly agentStatus?: string;\n\n  /**\n   * The time at which the runtime was created\n   * @attribute\n   * @example \"2024-01-15T10:30:00Z\"\n   */\n  readonly createdAt?: string;\n\n  /**\n   * The time at which the runtime was last updated\n   * @attribute\n   * @example \"2024-01-15T14:45:00Z\"\n   */\n  readonly lastUpdatedAt?: string;\n\n  // ------------------------------------------------------\n  // Metrics\n  // ------------------------------------------------------\n  /**\n   * Return the given named metric for this agent runtime.\n   */\n  metric(metricName: string, dimensions: DimensionsMap, props?: MetricOptions): Metric;\n\n  /**\n   * Return a metric containing the total number of invocations for this agent runtime.\n   */\n  metricInvocations(props?: MetricOptions): Metric;\n\n  /**\n   * Return a metric containing the total number of invocations across all resources.\n   */\n  metricInvocationsAggregated(props?: MetricOptions): Metric;\n\n  /**\n   * Return a metric containing the number of throttled requests for this agent runtime.\n   */\n  metricThrottles(props?: MetricOptions): Metric;\n\n  /**\n   * Return a metric containing the number of system errors for this agent runtime.\n   */\n  metricSystemErrors(props?: MetricOptions): Metric;\n\n  /**\n   * Return a metric containing the number of user errors for this agent runtime.\n   */\n  metricUserErrors(props?: MetricOptions): Metric;\n\n  /**\n   * Return a metric measuring the latency of requests for this agent runtime.\n   */\n  metricLatency(props?: MetricOptions): Metric;\n\n  /**\n   * Return a metric containing the total number of errors (system + user) for this agent runtime.\n   */\n  metricTotalErrors(props?: MetricOptions): Metric;\n\n  /**\n   * Return a metric containing the number of agent sessions for this agent runtime.\n   */\n  metricSessionCount(props?: MetricOptions): Metric;\n\n  /**\n   * Return a metric containing the total number of sessions across all resources.\n   */\n  metricSessionsAggregated(props?: MetricOptions): Metric;\n\n  // ------------------------------------------------------\n  // Grant Methods\n  // ------------------------------------------------------\n\n  /**\n   * Grant the runtime specific actions on AWS resources\n   *\n   * @param actions The actions to grant\n   * @param resources The resource ARNs to grant access to\n   * @returns The Grant object for chaining\n   */\n  grant(actions: string[], resources: string[]): iam.Grant;\n\n  /**\n   * Adds a policy statement to the runtime's execution role\n   *\n   * @param statement The IAM policy statement to add\n   * @returns The runtime instance for chaining\n   */\n  addToRolePolicy(statement: iam.PolicyStatement): IBedrockAgentRuntime;\n\n  /**\n   * Permits an IAM principal to invoke this runtime\n   * Grants the bedrock-agentcore:InvokeAgentRuntime permission\n   * @param grantee The principal to grant access to\n   */\n  grantInvokeRuntime(grantee: iam.IGrantable): iam.Grant;\n\n  /**\n   * Permits an IAM principal to invoke this runtime on behalf of a user\n   * Grants the bedrock-agentcore:InvokeAgentRuntimeForUser permission\n   * Required when using the X-Amzn-Bedrock-AgentCore-Runtime-User-Id header\n   * @param grantee The principal to grant access to\n   */\n  grantInvokeRuntimeForUser(grantee: iam.IGrantable): iam.Grant;\n\n  /**\n   * Permits an IAM principal to invoke this runtime both directly and on behalf of users\n   * Grants both bedrock-agentcore:InvokeAgentRuntime and bedrock-agentcore:InvokeAgentRuntimeForUser permissions\n   * @param grantee The principal to grant access to\n   */\n  grantInvoke(grantee: iam.IGrantable): iam.Grant;\n}\n\n/******************************************************************************\n *                                Base Class\n *****************************************************************************/\n\n/**\n * Base class for Agent Runtime\n */\nexport abstract class RuntimeBase extends Resource implements IBedrockAgentRuntime {\n  // Abstract properties\n  public abstract readonly agentRuntimeArn: string;\n  public abstract readonly agentRuntimeId: string;\n  public abstract readonly agentRuntimeName: string;\n  public abstract readonly role: iam.IRole;\n  public abstract readonly agentRuntimeVersion?: string;\n  public abstract readonly agentStatus?: string;\n  public abstract readonly createdAt?: string;\n  public abstract readonly lastUpdatedAt?: string;\n  public abstract readonly grantPrincipal: iam.IPrincipal;\n\n  /**\n   * An accessor for the Connections object that will fail if this Runtime does not have a VPC\n   * configured.\n   */\n  public get connections(): ec2.Connections {\n    if (!this._connections) {\n      throw new ValidationError('Cannot manage network access without configuring a VPC');\n    }\n    return this._connections;\n  }\n\n  /**\n   * The actual Connections object for this Runtime. This may be unset in the event that a VPC has not\n   * been configured.\n   * @internal\n   */\n  protected _connections: ec2.Connections | undefined;\n\n  constructor(scope: Construct, id: string) {\n    super(scope, id);\n  }\n\n  /**\n   * Grant the runtime specific actions on AWS resources\n   *\n   * @param actions The actions to grant\n   * @param resources The resource ARNs to grant access to\n   * @returns The Grant object for chaining\n   */\n  public grant(actions: string[], resources: string[]): iam.Grant {\n    return iam.Grant.addToPrincipal({\n      grantee: this.role,\n      actions,\n      resourceArns: resources,\n    });\n  }\n\n  /**\n   * Adds a policy statement to the runtime's execution role\n   *\n   * @param statement The IAM policy statement to add\n   * @returns The runtime instance for chaining\n   */\n  public addToRolePolicy(statement: iam.PolicyStatement): IBedrockAgentRuntime {\n    this.role.addToPrincipalPolicy(statement);\n    return this;\n  }\n\n  /**\n   * Permits an IAM principal to invoke this runtime\n   * Grants the bedrock-agentcore:InvokeAgentRuntime permission\n   * @param grantee The principal to grant access to\n   */\n  public grantInvokeRuntime(grantee: iam.IGrantable): iam.Grant {\n    return iam.Grant.addToPrincipal({\n      grantee,\n      actions: RUNTIME_INVOKE_PERMS,\n      resourceArns: [this.agentRuntimeArn],\n    });\n  }\n\n  /**\n   * Permits an IAM principal to invoke this runtime on behalf of a user\n   * Grants the bedrock-agentcore:InvokeAgentRuntimeForUser permission\n   * Required when using the X-Amzn-Bedrock-AgentCore-Runtime-User-Id header\n   * @param grantee The principal to grant access to\n   */\n  public grantInvokeRuntimeForUser(grantee: iam.IGrantable): iam.Grant {\n    return iam.Grant.addToPrincipal({\n      grantee,\n      actions: RUNTIME_INVOKE_USER_PERMS,\n      resourceArns: [this.agentRuntimeArn],\n    });\n  }\n\n  /**\n   * Permits an IAM principal to invoke this runtime both directly and on behalf of users\n   * Grants both bedrock-agentcore:InvokeAgentRuntime and bedrock-agentcore:InvokeAgentRuntimeForUser permissions\n   * @param grantee The principal to grant access to\n   */\n  public grantInvoke(grantee: iam.IGrantable): iam.Grant {\n    return iam.Grant.addToPrincipal({\n      grantee,\n      actions: [...RUNTIME_INVOKE_PERMS, ...RUNTIME_INVOKE_USER_PERMS],\n      resourceArns: [this.agentRuntimeArn],\n    });\n  }\n\n  // ------------------------------------------------------\n  // Metrics\n  // ------------------------------------------------------\n  /**\n   * Return the given named metric for this agent runtime.\n   *\n   * By default, the metric will be calculated as a sum over a period of 5 minutes.\n   * You can customize this by using the `statistic` and `period` properties.\n   */\n  public metric(metricName: string, dimensions: DimensionsMap, props?: MetricOptions): Metric {\n    const metricProps: MetricProps = {\n      namespace: 'AWS/Bedrock-AgentCore',\n      metricName,\n      dimensionsMap: { ...dimensions, Resource: this.agentRuntimeArn },\n      ...props,\n    };\n    return this.configureMetric(metricProps);\n  }\n\n  /**\n   * Return a metric containing the total number of invocations for this agent runtime.\n   */\n  public metricInvocations(props?: MetricOptions): Metric {\n    return this.metric('Invocations', {}, { statistic: Stats.SUM, ...props });\n  }\n\n  /**\n   * Return a metric containing the total number of invocations across all resources.\n   */\n  public metricInvocationsAggregated(props?: MetricOptions): Metric {\n    return this.metric('Invocations', { Resource: 'All' }, { statistic: Stats.SUM, ...props });\n  }\n\n  /**\n   * Return a metric containing the number of throttled requests for this agent runtime.\n   */\n  public metricThrottles(props?: MetricOptions): Metric {\n    return this.metric('Throttles', {}, { statistic: Stats.SUM, ...props });\n  }\n\n  /**\n   * Return a metric containing the number of system errors for this agent runtime.\n   */\n  public metricSystemErrors(props?: MetricOptions): Metric {\n    return this.metric('SystemErrors', {}, { statistic: Stats.SUM, ...props });\n  }\n\n  /**\n   * Return a metric containing the number of user errors for this agent runtime.\n   */\n  public metricUserErrors(props?: MetricOptions): Metric {\n    return this.metric('UserErrors', {}, { statistic: Stats.SUM, ...props });\n  }\n\n  /**\n   * Return a metric measuring the latency of requests for this agent runtime.\n   *\n   * The latency metric represents the total time elapsed between receiving the request\n   * and sending the final response token, representing complete end-to-end processing time.\n   */\n  public metricLatency(props?: MetricOptions): Metric {\n    return this.metric('Latency', {}, { statistic: Stats.AVERAGE, ...props });\n  }\n\n  /**\n   * Return a metric containing the total number of errors (system + user) for this agent runtime.\n   */\n  public metricTotalErrors(props?: MetricOptions): Metric {\n    return this.metric('TotalErrors', {}, { statistic: Stats.SUM, ...props });\n  }\n\n  /**\n   * Return a metric containing the number of agent sessions for this agent runtime.\n   */\n  public metricSessionCount(props?: MetricOptions): Metric {\n    return this.metric('SessionCount', {}, { statistic: Stats.SUM, ...props });\n  }\n\n  /**\n   * Return a metric containing the total number of sessions across all resources.\n   */\n  public metricSessionsAggregated(props?: MetricOptions): Metric {\n    return this.metric('Sessions', { Resource: 'All' }, { statistic: Stats.SUM, ...props });\n  }\n\n  /**\n   * Internal method to create a metric.\n   */\n  private configureMetric(props: MetricProps) {\n    return new Metric({\n      ...props,\n      region: props?.region ?? this.stack.region,\n      account: props?.account ?? this.stack.account,\n    });\n  }\n}\n\n/**\n * Attributes for importing an existing Agent Runtime\n */\nexport interface AgentRuntimeAttributes {\n  /**\n   * The ARN of the agent runtime\n   */\n  readonly agentRuntimeArn: string;\n\n  /**\n   * The ID of the agent runtime\n   */\n  readonly agentRuntimeId: string;\n\n  /**\n   * The name of the agent runtime\n   */\n  readonly agentRuntimeName: string;\n\n  /**\n   * The IAM role ARN\n   */\n  readonly roleArn: string;\n\n  /**\n   * The version of the agent runtime\n   * When importing a runtime and this is not specified or undefined, endpoints created on this runtime\n   * will point to version \"1\" unless explicitly overridden.\n   * @default - undefined\n   */\n  readonly agentRuntimeVersion?: string;\n\n  /**\n   * The description of the agent runtime\n   * @default - No description\n   */\n  readonly description?: string;\n\n  /**\n   * The security groups for this runtime, if in a VPC.\n   * @default - By default, the runtime is not in a VPC.\n   */\n  readonly securityGroups?: ec2.ISecurityGroup[];\n\n  /**\n   * The current status of the agent runtime\n   * @default - Status not available\n   */\n  readonly agentStatus?: string;\n\n  /**\n   * The time at which the runtime was created\n   * @default - Creation time not available\n   */\n  readonly createdAt?: string;\n\n  /**\n   * The time at which the runtime was last updated\n   * @default - Last update time not available\n   */\n  readonly lastUpdatedAt?: string;\n}\n"]}