@aws-cdk/aws-bedrock-agentcore-alpha
Version:
The CDK Construct Library for Amazon Bedrock
174 lines • 23 kB
JavaScript
;
Object.defineProperty(exports, "__esModule", { value: true });
exports.MemoryStrategy = exports.MemoryStrategyType = exports.MEMORY_NAME_MAX_LENGTH = exports.MEMORY_NAME_MIN_LENGTH = void 0;
const jsiiDeprecationWarnings = require("../../.warnings.jsii.js");
const JSII_RTTI_SYMBOL_1 = Symbol.for("jsii.rtti");
// Internal libs
const managed_strategy_1 = require("./strategies/managed-strategy");
const self_managed_strategy_1 = require("./strategies/self-managed-strategy");
/******************************************************************************
* CONSTANTS
*****************************************************************************/
/**
* Minimum length for memory strategy name
* @internal
*/
exports.MEMORY_NAME_MIN_LENGTH = 1;
/**
* Maximum length for memory strategy name
* @internal
*/
exports.MEMORY_NAME_MAX_LENGTH = 48;
/**
* Long-term memory extraction strategy types.
*/
var MemoryStrategyType;
(function (MemoryStrategyType) {
/**
* Summarization strategy - extracts concise summaries to preserve critical context and key insights
*/
MemoryStrategyType["SUMMARIZATION"] = "SUMMARIZATION";
/**
* Semantic memory strategy - extracts general factual knowledge, concepts and meanings from raw conversations
* using vector embeddings for similarity search.
*/
MemoryStrategyType["SEMANTIC"] = "SEMANTIC";
/**
* User preferences strategy - extracts user behavior patterns from raw conversations.
*/
MemoryStrategyType["USER_PREFERENCE"] = "USER_PREFERENCE";
/**
* Customize memory processing through custom foundation model and prompt templates.
*/
MemoryStrategyType["CUSTOM"] = "CUSTOM";
})(MemoryStrategyType || (exports.MemoryStrategyType = MemoryStrategyType = {}));
/******************************************************************************
* Factory
*****************************************************************************/
/**
* Factory class for creating memory strategies
* If you need long-term memory for context recall across sessions, you can setup memory extraction strategies to extract the relevant memory from the raw events.
* Use built-in strategies for quick setup, use built-in strategies with override to specify models and prompt templates.
*
* @see https://docs.aws.amazon.com/bedrock-agentcore/latest/devguide/memory-strategies.html
*/
class MemoryStrategy {
static [JSII_RTTI_SYMBOL_1] = { fqn: "@aws-cdk/aws-bedrock-agentcore-alpha.MemoryStrategy", version: "2.227.0-alpha.0" };
/**
* Default strategies for organizing and extracting memory data, each optimized for specific use cases.
* This strategy compresses conversations into concise overviews, preserving essential context and key insights for quick recall.
* Extracted memory example: Users confused by cloud setup during onboarding.
* @returns A ManagedMemoryStrategy.
*/
static usingBuiltInSummarization() {
return new managed_strategy_1.ManagedMemoryStrategy(MemoryStrategyType.SUMMARIZATION, {
name: 'summary_builtin_cdkGen0001',
description: 'Summarize interactions to preserve critical context and key insights',
namespaces: ['/strategies/{memoryStrategyId}/actors/{actorId}/sessions/{sessionId}'],
});
}
/**
* Default strategies for organizing and extracting memory data, each optimized for specific use cases.
* Distills general facts, concepts, and underlying meanings from raw conversational data, presenting the information in a context-independent format.
* Extracted memory example: In-context learning = task-solving via examples, no training needed.
* @returns A ManagedMemoryStrategy.
*/
static usingBuiltInSemantic() {
return new managed_strategy_1.ManagedMemoryStrategy(MemoryStrategyType.SEMANTIC, {
name: 'semantic_builtin_cdkGen0001',
description: 'Extract general factual knowledge, concepts and meanings from raw conversations in a context-independent format.',
namespaces: ['/strategies/{memoryStrategyId}/actors/{actorId}'],
});
}
/**
* Default strategies for organizing and extracting memory data, each optimized for specific use cases.
* Captures individual preferences, interaction patterns, and personalized settings to enhance future experiences.
* Extracted memory example: User needs clear guidance on cloud storage account connection during onboarding.
* @returns A ManagedMemoryStrategy.
*/
static usingBuiltInUserPreference() {
return new managed_strategy_1.ManagedMemoryStrategy(MemoryStrategyType.USER_PREFERENCE, {
name: 'preference_builtin_cdkGen0001',
description: 'Capture individual preferences, interaction patterns, and personalized settings to enhance future experiences.',
namespaces: ['/strategies/{memoryStrategyId}/actors/{actorId}'],
});
}
/**
* Creates a semantic memory strategy with custom configuration.
* Distills general facts, concepts, and underlying meanings from raw conversational data, presenting the information in a context-independent format.
* Extracted memory example: In-context learning = task-solving via examples, no training needed.
* @param config - The configuration for the semantic memory strategy.
* @returns A ManagedMemoryStrategy.
*/
static usingSemantic(config) {
try {
jsiiDeprecationWarnings._aws_cdk_aws_bedrock_agentcore_alpha_ManagedStrategyProps(config);
}
catch (error) {
if (process.env.JSII_DEBUG !== "1" && error.name === "DeprecationError") {
Error.captureStackTrace(error, this.usingSemantic);
}
throw error;
}
return new managed_strategy_1.ManagedMemoryStrategy(MemoryStrategyType.SEMANTIC, config);
}
/**
* Creates a user preference memory strategy with custom configuration.
* Captures individual preferences, interaction patterns, and personalized settings to enhance future experiences.
* Extracted memory example: User needs clear guidance on cloud storage account connection during onboarding.
* @param config - The configuration for the user preference memory strategy.
* @returns A ManagedMemoryStrategy.
*/
static usingUserPreference(config) {
try {
jsiiDeprecationWarnings._aws_cdk_aws_bedrock_agentcore_alpha_ManagedStrategyProps(config);
}
catch (error) {
if (process.env.JSII_DEBUG !== "1" && error.name === "DeprecationError") {
Error.captureStackTrace(error, this.usingUserPreference);
}
throw error;
}
return new managed_strategy_1.ManagedMemoryStrategy(MemoryStrategyType.USER_PREFERENCE, config);
}
/**
* Creates a summarization memory strategy with custom configuration.
* This strategy compresses conversations into concise overviews, preserving essential context and key insights for quick recall.
* Extracted memory example: Users confused by cloud setup during onboarding.
* @param config - The configuration for the summarization memory strategy.
* @returns A ManagedMemoryStrategy.
*/
static usingSummarization(config) {
try {
jsiiDeprecationWarnings._aws_cdk_aws_bedrock_agentcore_alpha_ManagedStrategyProps(config);
}
catch (error) {
if (process.env.JSII_DEBUG !== "1" && error.name === "DeprecationError") {
Error.captureStackTrace(error, this.usingSummarization);
}
throw error;
}
return new managed_strategy_1.ManagedMemoryStrategy(MemoryStrategyType.SUMMARIZATION, config);
}
/**
* Creates a self-managed memory strategy.
* A self-managed strategy gives you complete control over your memory extraction and consolidation pipelines.
* @param config - The configuration for the self-managed memory strategy.
* @returns A SelfManagedMemoryStrategy.
*/
static usingSelfManaged(config) {
try {
jsiiDeprecationWarnings._aws_cdk_aws_bedrock_agentcore_alpha_SelfManagedStrategyProps(config);
}
catch (error) {
if (process.env.JSII_DEBUG !== "1" && error.name === "DeprecationError") {
Error.captureStackTrace(error, this.usingSelfManaged);
}
throw error;
}
// Scope is passed for future use in permission granting
return new self_managed_strategy_1.SelfManagedMemoryStrategy(MemoryStrategyType.CUSTOM, config);
}
}
exports.MemoryStrategy = MemoryStrategy;
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"memory-strategy.js","sourceRoot":"","sources":["memory-strategy.ts"],"names":[],"mappings":";;;;;AAeA,gBAAgB;AAChB,oEAA4F;AAC5F,8EAAyG;AAEzG;;+EAE+E;AAC/E;;;GAGG;AACU,QAAA,sBAAsB,GAAG,CAAC,CAAC;AACxC;;;GAGG;AACU,QAAA,sBAAsB,GAAG,EAAE,CAAC;AAEzC;;GAEG;AACH,IAAY,kBAkBX;AAlBD,WAAY,kBAAkB;IAC5B;;OAEG;IACH,qDAA+B,CAAA;IAC/B;;;OAGG;IACH,2CAAqB,CAAA;IACrB;;OAEG;IACH,yDAAmC,CAAA;IACnC;;OAEG;IACH,uCAAiB,CAAA;AACnB,CAAC,EAlBW,kBAAkB,kCAAlB,kBAAkB,QAkB7B;AAmDD;;+EAE+E;AAC/E;;;;;;GAMG;AACH,MAAa,cAAc;;IACzB;;;;;OAKG;IACI,MAAM,CAAC,yBAAyB;QACrC,OAAO,IAAI,wCAAqB,CAAC,kBAAkB,CAAC,aAAa,EAAE;YACjE,IAAI,EAAE,4BAA4B;YAClC,WAAW,EAAE,sEAAsE;YACnF,UAAU,EAAE,CAAC,sEAAsE,CAAC;SACrF,CAAC,CAAC;KACJ;IACD;;;;;OAKG;IACI,MAAM,CAAC,oBAAoB;QAChC,OAAO,IAAI,wCAAqB,CAAC,kBAAkB,CAAC,QAAQ,EAAE;YAC5D,IAAI,EAAE,6BAA6B;YACnC,WAAW,EACX,kHAAkH;YAClH,UAAU,EAAE,CAAC,iDAAiD,CAAC;SAChE,CAAC,CAAC;KACJ;IACD;;;;;OAKG;IACI,MAAM,CAAC,0BAA0B;QACtC,OAAO,IAAI,wCAAqB,CAAC,kBAAkB,CAAC,eAAe,EAAE;YACnE,IAAI,EAAE,+BAA+B;YACrC,WAAW,EAAE,gHAAgH;YAC7H,UAAU,EAAE,CAAC,iDAAiD,CAAC;SAChE,CAAC,CAAC;KACJ;IACD;;;;;;OAMG;IACI,MAAM,CAAC,aAAa,CAAC,MAA4B;;;;;;;;;;QACtD,OAAO,IAAI,wCAAqB,CAAC,kBAAkB,CAAC,QAAQ,EAAE,MAAM,CAAC,CAAC;KACvE;IACD;;;;;;OAMG;IACI,MAAM,CAAC,mBAAmB,CAAC,MAA4B;;;;;;;;;;QAC5D,OAAO,IAAI,wCAAqB,CAAC,kBAAkB,CAAC,eAAe,EAAE,MAAM,CAAC,CAAC;KAC9E;IACD;;;;;;OAMG;IACI,MAAM,CAAC,kBAAkB,CAAC,MAA4B;;;;;;;;;;QAC3D,OAAO,IAAI,wCAAqB,CAAC,kBAAkB,CAAC,aAAa,EAAE,MAAM,CAAC,CAAC;KAC5E;IACD;;;;;OAKG;IACI,MAAM,CAAC,gBAAgB,CAAC,MAAgC;;;;;;;;;;QAC7D,wDAAwD;QACxD,OAAO,IAAI,iDAAyB,CAAC,kBAAkB,CAAC,MAAM,EAAE,MAAM,CAAC,CAAC;KACzE;;AAhFH,wCAiFC","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 * as bedrockagentcore from 'aws-cdk-lib/aws-bedrockagentcore';\nimport * as iam from 'aws-cdk-lib/aws-iam';\n// Internal libs\nimport { ManagedMemoryStrategy, ManagedStrategyProps } from './strategies/managed-strategy';\nimport { SelfManagedMemoryStrategy, SelfManagedStrategyProps } from './strategies/self-managed-strategy';\n\n/******************************************************************************\n *                              CONSTANTS\n *****************************************************************************/\n/**\n * Minimum length for memory strategy name\n * @internal\n */\nexport const MEMORY_NAME_MIN_LENGTH = 1;\n/**\n * Maximum length for memory strategy name\n * @internal\n */\nexport const MEMORY_NAME_MAX_LENGTH = 48;\n\n/**\n * Long-term memory extraction strategy types.\n */\nexport enum MemoryStrategyType {\n  /**\n   * Summarization strategy - extracts concise summaries to preserve critical context and key insights\n   */\n  SUMMARIZATION = 'SUMMARIZATION',\n  /**\n   * Semantic memory strategy - extracts general factual knowledge, concepts and meanings from raw conversations\n   * using vector embeddings for similarity search.\n   */\n  SEMANTIC = 'SEMANTIC',\n  /**\n   * User preferences strategy - extracts user behavior patterns from raw conversations.\n   */\n  USER_PREFERENCE = 'USER_PREFERENCE',\n  /**\n   * Customize memory processing through custom foundation model and prompt templates.\n   */\n  CUSTOM = 'CUSTOM',\n}\n\n/******************************************************************************\n *                                 Common\n *****************************************************************************/\n/**\n * Configuration parameters common for any memory strategy\n */\nexport interface MemoryStrategyCommonProps {\n  /**\n   * The name for the strategy\n   */\n  readonly name: string;\n  /**\n   * The description of the strategy\n   * @default - No description\n   */\n  readonly description?: string;\n}\n\n/******************************************************************************\n *                                 Interface\n *****************************************************************************/\n/**\n * Interface for Memory strategies\n */\nexport interface IMemoryStrategy {\n  /**\n   * The name of the memory strategy\n   */\n  readonly name: string;\n  /**\n   * The description of the memory strategy\n   */\n  readonly description?: string;\n  /**\n   * The type of memory strategy\n   */\n  readonly strategyType: MemoryStrategyType;\n  /**\n   * Renders internal attributes to CloudFormation\n   */\n  render(): bedrockagentcore.CfnMemory.MemoryStrategyProperty;\n  /**\n   * Grants the necessary permissions to the role\n   * @param grantee - The grantee to grant permissions to\n   * @returns The Grant object for chaining\n   */\n  grant(grantee: iam.IGrantable): iam.Grant | undefined;\n}\n\n/******************************************************************************\n *                                 Factory\n *****************************************************************************/\n/**\n * Factory class for creating memory strategies\n * If you need long-term memory for context recall across sessions, you can setup memory extraction strategies to extract the relevant memory from the raw events.\n * Use built-in strategies for quick setup, use built-in strategies with override to specify models and prompt templates.\n *\n * @see https://docs.aws.amazon.com/bedrock-agentcore/latest/devguide/memory-strategies.html\n */\nexport class MemoryStrategy {\n  /**\n   * Default strategies for organizing and extracting memory data, each optimized for specific use cases.\n   * This strategy compresses conversations into concise overviews, preserving essential context and key insights for quick recall.\n   * Extracted memory example: Users confused by cloud setup during onboarding.\n   * @returns A ManagedMemoryStrategy.\n   */\n  public static usingBuiltInSummarization(): ManagedMemoryStrategy {\n    return new ManagedMemoryStrategy(MemoryStrategyType.SUMMARIZATION, {\n      name: 'summary_builtin_cdkGen0001',\n      description: 'Summarize interactions to preserve critical context and key insights',\n      namespaces: ['/strategies/{memoryStrategyId}/actors/{actorId}/sessions/{sessionId}'],\n    });\n  }\n  /**\n   * Default strategies for organizing and extracting memory data, each optimized for specific use cases.\n   * Distills general facts, concepts, and underlying meanings from raw conversational data, presenting the information in a context-independent format.\n   * Extracted memory example: In-context learning = task-solving via examples, no training needed.\n   * @returns A ManagedMemoryStrategy.\n   */\n  public static usingBuiltInSemantic(): ManagedMemoryStrategy {\n    return new ManagedMemoryStrategy(MemoryStrategyType.SEMANTIC, {\n      name: 'semantic_builtin_cdkGen0001',\n      description:\n      'Extract general factual knowledge, concepts and meanings from raw conversations in a context-independent format.',\n      namespaces: ['/strategies/{memoryStrategyId}/actors/{actorId}'],\n    });\n  }\n  /**\n   * Default strategies for organizing and extracting memory data, each optimized for specific use cases.\n   * Captures individual preferences, interaction patterns, and personalized settings to enhance future experiences.\n   * Extracted memory example: User needs clear guidance on cloud storage account connection during onboarding.\n   * @returns A ManagedMemoryStrategy.\n   */\n  public static usingBuiltInUserPreference(): ManagedMemoryStrategy {\n    return new ManagedMemoryStrategy(MemoryStrategyType.USER_PREFERENCE, {\n      name: 'preference_builtin_cdkGen0001',\n      description: 'Capture individual preferences, interaction patterns, and personalized settings to enhance future experiences.',\n      namespaces: ['/strategies/{memoryStrategyId}/actors/{actorId}'],\n    });\n  }\n  /**\n   * Creates a semantic memory strategy with custom configuration.\n   * Distills general facts, concepts, and underlying meanings from raw conversational data, presenting the information in a context-independent format.\n   * Extracted memory example: In-context learning = task-solving via examples, no training needed.\n   * @param config - The configuration for the semantic memory strategy.\n   * @returns A ManagedMemoryStrategy.\n   */\n  public static usingSemantic(config: ManagedStrategyProps): ManagedMemoryStrategy {\n    return new ManagedMemoryStrategy(MemoryStrategyType.SEMANTIC, config);\n  }\n  /**\n   * Creates a user preference memory strategy with custom configuration.\n   * Captures individual preferences, interaction patterns, and personalized settings to enhance future experiences.\n   * Extracted memory example: User needs clear guidance on cloud storage account connection during onboarding.\n   * @param config - The configuration for the user preference memory strategy.\n   * @returns A ManagedMemoryStrategy.\n   */\n  public static usingUserPreference(config: ManagedStrategyProps): ManagedMemoryStrategy {\n    return new ManagedMemoryStrategy(MemoryStrategyType.USER_PREFERENCE, config);\n  }\n  /**\n   * Creates a summarization memory strategy with custom configuration.\n   * This strategy compresses conversations into concise overviews, preserving essential context and key insights for quick recall.\n   * Extracted memory example: Users confused by cloud setup during onboarding.\n   * @param config - The configuration for the summarization memory strategy.\n   * @returns A ManagedMemoryStrategy.\n   */\n  public static usingSummarization(config: ManagedStrategyProps): ManagedMemoryStrategy {\n    return new ManagedMemoryStrategy(MemoryStrategyType.SUMMARIZATION, config);\n  }\n  /**\n   * Creates a self-managed memory strategy.\n   * A self-managed strategy gives you complete control over your memory extraction and consolidation pipelines.\n   * @param config - The configuration for the self-managed memory strategy.\n   * @returns A SelfManagedMemoryStrategy.\n   */\n  public static usingSelfManaged(config: SelfManagedStrategyProps): SelfManagedMemoryStrategy {\n    // Scope is passed for future use in permission granting\n    return new SelfManagedMemoryStrategy(MemoryStrategyType.CUSTOM, config);\n  }\n}\n"]}