@langchain/core 1.0.0-alpha.6 → 1.0.0
This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
- package/CHANGELOG.md +131 -0
- package/LICENSE +6 -6
- package/README.md +2 -23
- package/dist/agents.d.ts.map +1 -1
- package/dist/caches/base.d.cts.map +1 -1
- package/dist/callbacks/base.d.cts.map +1 -1
- package/dist/callbacks/base.d.ts.map +1 -1
- package/dist/callbacks/manager.cjs +9 -64
- package/dist/callbacks/manager.cjs.map +1 -1
- package/dist/callbacks/manager.d.cts +1 -23
- package/dist/callbacks/manager.d.cts.map +1 -1
- package/dist/callbacks/manager.d.ts +1 -23
- package/dist/callbacks/manager.d.ts.map +1 -1
- package/dist/callbacks/manager.js +10 -63
- package/dist/callbacks/manager.js.map +1 -1
- package/dist/chat_history.cjs +0 -4
- package/dist/chat_history.cjs.map +1 -1
- package/dist/chat_history.d.cts +1 -3
- package/dist/chat_history.d.cts.map +1 -1
- package/dist/chat_history.d.ts +1 -3
- package/dist/chat_history.d.ts.map +1 -1
- package/dist/chat_history.js +0 -4
- package/dist/chat_history.js.map +1 -1
- package/dist/document_loaders/base.cjs +1 -13
- package/dist/document_loaders/base.cjs.map +1 -1
- package/dist/document_loaders/base.d.cts +0 -9
- package/dist/document_loaders/base.d.cts.map +1 -1
- package/dist/document_loaders/base.d.ts +0 -9
- package/dist/document_loaders/base.d.ts.map +1 -1
- package/dist/document_loaders/base.js +1 -13
- package/dist/document_loaders/base.js.map +1 -1
- package/dist/document_loaders/langsmith.d.cts +1 -1
- package/dist/language_models/base.cjs.map +1 -1
- package/dist/language_models/base.d.cts +0 -16
- package/dist/language_models/base.d.cts.map +1 -1
- package/dist/language_models/base.d.ts +0 -16
- package/dist/language_models/base.d.ts.map +1 -1
- package/dist/language_models/base.js.map +1 -1
- package/dist/language_models/chat_models.cjs +10 -83
- package/dist/language_models/chat_models.cjs.map +1 -1
- package/dist/language_models/chat_models.d.cts +21 -55
- package/dist/language_models/chat_models.d.cts.map +1 -1
- package/dist/language_models/chat_models.d.ts +21 -55
- package/dist/language_models/chat_models.d.ts.map +1 -1
- package/dist/language_models/chat_models.js +11 -83
- package/dist/language_models/chat_models.js.map +1 -1
- package/dist/language_models/llms.cjs +0 -56
- package/dist/language_models/llms.cjs.map +1 -1
- package/dist/language_models/llms.d.cts +1 -43
- package/dist/language_models/llms.d.cts.map +1 -1
- package/dist/language_models/llms.d.ts +1 -43
- package/dist/language_models/llms.d.ts.map +1 -1
- package/dist/language_models/llms.js +0 -56
- package/dist/language_models/llms.js.map +1 -1
- package/dist/load/import_map.cjs +1 -7
- package/dist/load/import_map.cjs.map +1 -1
- package/dist/load/import_map.js +1 -7
- package/dist/load/import_map.js.map +1 -1
- package/dist/messages/ai.cjs +4 -0
- package/dist/messages/ai.cjs.map +1 -1
- package/dist/messages/ai.js +4 -0
- package/dist/messages/ai.js.map +1 -1
- package/dist/messages/block_translators/anthropic.cjs +191 -144
- package/dist/messages/block_translators/anthropic.cjs.map +1 -1
- package/dist/messages/block_translators/anthropic.js +191 -144
- package/dist/messages/block_translators/anthropic.js.map +1 -1
- package/dist/messages/block_translators/index.cjs +2 -2
- package/dist/messages/block_translators/index.cjs.map +1 -1
- package/dist/messages/block_translators/index.js +4 -4
- package/dist/messages/block_translators/index.js.map +1 -1
- package/dist/messages/block_translators/openai.cjs +78 -22
- package/dist/messages/block_translators/openai.cjs.map +1 -1
- package/dist/messages/block_translators/openai.js +78 -22
- package/dist/messages/block_translators/openai.js.map +1 -1
- package/dist/messages/content/tools.cjs +1 -5
- package/dist/messages/content/tools.cjs.map +1 -1
- package/dist/messages/content/tools.d.cts +1 -85
- package/dist/messages/content/tools.d.cts.map +1 -1
- package/dist/messages/content/tools.d.ts +1 -85
- package/dist/messages/content/tools.d.ts.map +1 -1
- package/dist/messages/content/tools.js +1 -5
- package/dist/messages/content/tools.js.map +1 -1
- package/dist/messages/metadata.cjs.map +1 -1
- package/dist/messages/metadata.d.cts +3 -0
- package/dist/messages/metadata.d.cts.map +1 -1
- package/dist/messages/metadata.d.ts +3 -0
- package/dist/messages/metadata.d.ts.map +1 -1
- package/dist/messages/metadata.js.map +1 -1
- package/dist/messages/tool.cjs +2 -0
- package/dist/messages/tool.cjs.map +1 -1
- package/dist/messages/tool.d.cts +2 -0
- package/dist/messages/tool.d.cts.map +1 -1
- package/dist/messages/tool.d.ts +2 -0
- package/dist/messages/tool.d.ts.map +1 -1
- package/dist/messages/tool.js +2 -0
- package/dist/messages/tool.js.map +1 -1
- package/dist/output_parsers/json.cjs +5 -0
- package/dist/output_parsers/json.cjs.map +1 -1
- package/dist/output_parsers/json.d.cts +2 -0
- package/dist/output_parsers/json.d.cts.map +1 -1
- package/dist/output_parsers/json.d.ts +2 -0
- package/dist/output_parsers/json.d.ts.map +1 -1
- package/dist/output_parsers/json.js +5 -0
- package/dist/output_parsers/json.js.map +1 -1
- package/dist/prompts/base.cjs +0 -36
- package/dist/prompts/base.cjs.map +1 -1
- package/dist/prompts/base.d.cts +0 -16
- package/dist/prompts/base.d.cts.map +1 -1
- package/dist/prompts/base.d.ts +0 -16
- package/dist/prompts/base.d.ts.map +1 -1
- package/dist/prompts/base.js +0 -36
- package/dist/prompts/base.js.map +1 -1
- package/dist/prompts/chat.cjs +1 -5
- package/dist/prompts/chat.cjs.map +1 -1
- package/dist/prompts/chat.d.cts +1 -4
- package/dist/prompts/chat.d.cts.map +1 -1
- package/dist/prompts/chat.d.ts +1 -4
- package/dist/prompts/chat.d.ts.map +1 -1
- package/dist/prompts/chat.js +1 -5
- package/dist/prompts/chat.js.map +1 -1
- package/dist/prompts/dict.d.cts +1 -1
- package/dist/prompts/dict.d.ts +1 -1
- package/dist/prompts/few_shot.d.cts +2 -2
- package/dist/prompts/few_shot.d.ts +2 -2
- package/dist/prompts/image.d.cts +1 -1
- package/dist/prompts/image.d.ts +1 -1
- package/dist/prompts/index.d.cts +2 -2
- package/dist/prompts/index.d.ts +2 -2
- package/dist/prompts/pipeline.d.cts +1 -1
- package/dist/prompts/pipeline.d.ts +1 -1
- package/dist/prompts/prompt.d.cts +2 -2
- package/dist/prompts/prompt.d.ts +2 -2
- package/dist/retrievers/index.cjs +3 -18
- package/dist/retrievers/index.cjs.map +1 -1
- package/dist/retrievers/index.d.cts +2 -27
- package/dist/retrievers/index.d.cts.map +1 -1
- package/dist/retrievers/index.d.ts +2 -27
- package/dist/retrievers/index.d.ts.map +1 -1
- package/dist/retrievers/index.js +3 -18
- package/dist/retrievers/index.js.map +1 -1
- package/dist/runnables/base.cjs +24 -63
- package/dist/runnables/base.cjs.map +1 -1
- package/dist/runnables/base.d.cts +10 -39
- package/dist/runnables/base.d.cts.map +1 -1
- package/dist/runnables/base.d.ts +10 -39
- package/dist/runnables/base.d.ts.map +1 -1
- package/dist/runnables/base.js +24 -63
- package/dist/runnables/base.js.map +1 -1
- package/dist/runnables/graph.cjs +1 -1
- package/dist/runnables/graph.cjs.map +1 -1
- package/dist/runnables/graph.js +2 -2
- package/dist/runnables/graph.js.map +1 -1
- package/dist/runnables/graph_mermaid.cjs +1 -10
- package/dist/runnables/graph_mermaid.cjs.map +1 -1
- package/dist/runnables/graph_mermaid.js +1 -10
- package/dist/runnables/graph_mermaid.js.map +1 -1
- package/dist/runnables/history.cjs +1 -1
- package/dist/runnables/history.cjs.map +1 -1
- package/dist/runnables/history.d.cts +2 -2
- package/dist/runnables/history.d.cts.map +1 -1
- package/dist/runnables/history.d.ts +2 -2
- package/dist/runnables/history.d.ts.map +1 -1
- package/dist/runnables/history.js +1 -1
- package/dist/runnables/history.js.map +1 -1
- package/dist/stores.cjs.map +1 -1
- package/dist/stores.d.cts +3 -29
- package/dist/stores.d.cts.map +1 -1
- package/dist/stores.d.ts +3 -29
- package/dist/stores.d.ts.map +1 -1
- package/dist/stores.js.map +1 -1
- package/dist/tools/index.cjs +12 -4
- package/dist/tools/index.cjs.map +1 -1
- package/dist/tools/index.js +12 -4
- package/dist/tools/index.js.map +1 -1
- package/dist/tools/types.cjs.map +1 -1
- package/dist/tools/types.d.cts +4 -0
- package/dist/tools/types.d.cts.map +1 -1
- package/dist/tools/types.d.ts +4 -0
- package/dist/tools/types.d.ts.map +1 -1
- package/dist/tools/types.js.map +1 -1
- package/dist/tracers/base.cjs +1 -1
- package/dist/tracers/base.cjs.map +1 -1
- package/dist/tracers/base.d.cts +1 -1
- package/dist/tracers/base.js +2 -2
- package/dist/tracers/base.js.map +1 -1
- package/dist/tracers/log_stream.d.cts +1 -1
- package/dist/tracers/log_stream.d.ts +1 -1
- package/dist/tracers/tracer_langchain.cjs +1 -0
- package/dist/tracers/tracer_langchain.cjs.map +1 -1
- package/dist/tracers/tracer_langchain.d.cts +2 -2
- package/dist/tracers/tracer_langchain.js +1 -0
- package/dist/tracers/tracer_langchain.js.map +1 -1
- package/dist/utils/env.cjs +1 -9
- package/dist/utils/env.cjs.map +1 -1
- package/dist/utils/env.d.cts +2 -6
- package/dist/utils/env.d.cts.map +1 -1
- package/dist/utils/env.d.ts +2 -6
- package/dist/utils/env.d.ts.map +1 -1
- package/dist/utils/env.js +2 -9
- package/dist/utils/env.js.map +1 -1
- package/dist/utils/testing/message_history.cjs +1 -1
- package/dist/utils/testing/message_history.cjs.map +1 -1
- package/dist/utils/testing/message_history.d.cts +1 -1
- package/dist/utils/testing/message_history.d.cts.map +1 -1
- package/dist/utils/testing/message_history.d.ts +1 -1
- package/dist/utils/testing/message_history.d.ts.map +1 -1
- package/dist/utils/testing/message_history.js +1 -1
- package/dist/utils/testing/message_history.js.map +1 -1
- package/dist/utils/types/index.cjs +6 -0
- package/dist/utils/types/index.d.cts +2 -2
- package/dist/utils/types/index.d.ts +2 -2
- package/dist/utils/types/index.js +5 -2
- package/dist/utils/types/zod.cjs +23 -0
- package/dist/utils/types/zod.cjs.map +1 -1
- package/dist/utils/types/zod.d.cts +11 -1
- package/dist/utils/types/zod.d.cts.map +1 -1
- package/dist/utils/types/zod.d.ts +11 -1
- package/dist/utils/types/zod.d.ts.map +1 -1
- package/dist/utils/types/zod.js +21 -1
- package/dist/utils/types/zod.js.map +1 -1
- package/package.json +121 -154
- package/dist/runnables/remote.cjs +0 -399
- package/dist/runnables/remote.cjs.map +0 -1
- package/dist/runnables/remote.d.cts +0 -73
- package/dist/runnables/remote.d.cts.map +0 -1
- package/dist/runnables/remote.d.ts +0 -73
- package/dist/runnables/remote.d.ts.map +0 -1
- package/dist/runnables/remote.js +0 -393
- package/dist/runnables/remote.js.map +0 -1
- package/dist/tracers/initialize.cjs +0 -46
- package/dist/tracers/initialize.cjs.map +0 -1
- package/dist/tracers/initialize.d.cts +0 -26
- package/dist/tracers/initialize.d.cts.map +0 -1
- package/dist/tracers/initialize.d.ts +0 -26
- package/dist/tracers/initialize.d.ts.map +0 -1
- package/dist/tracers/initialize.js +0 -39
- package/dist/tracers/initialize.js.map +0 -1
- package/dist/tracers/tracer_langchain_v1.cjs +0 -168
- package/dist/tracers/tracer_langchain_v1.cjs.map +0 -1
- package/dist/tracers/tracer_langchain_v1.d.cts +0 -64
- package/dist/tracers/tracer_langchain_v1.d.cts.map +0 -1
- package/dist/tracers/tracer_langchain_v1.d.ts +0 -64
- package/dist/tracers/tracer_langchain_v1.d.ts.map +0 -1
- package/dist/tracers/tracer_langchain_v1.js +0 -162
- package/dist/tracers/tracer_langchain_v1.js.map +0 -1
|
@@ -21,10 +21,8 @@ __export(manager_exports, {
|
|
|
21
21
|
CallbackManagerForLLMRun: () => CallbackManagerForLLMRun,
|
|
22
22
|
CallbackManagerForRetrieverRun: () => CallbackManagerForRetrieverRun,
|
|
23
23
|
CallbackManagerForToolRun: () => CallbackManagerForToolRun,
|
|
24
|
-
TraceGroup: () => TraceGroup,
|
|
25
24
|
ensureHandler: () => ensureHandler,
|
|
26
|
-
parseCallbackConfigArg: () => parseCallbackConfigArg
|
|
27
|
-
traceAsGroup: () => traceAsGroup
|
|
25
|
+
parseCallbackConfigArg: () => parseCallbackConfigArg
|
|
28
26
|
});
|
|
29
27
|
function parseCallbackConfigArg(arg) {
|
|
30
28
|
if (!arg) return {};
|
|
@@ -479,7 +477,14 @@ var CallbackManager = class CallbackManager extends BaseCallbackManager {
|
|
|
479
477
|
if (tracingV2Enabled) {
|
|
480
478
|
const tracerV2 = new LangChainTracer();
|
|
481
479
|
callbackManager.addHandler(tracerV2, true);
|
|
482
|
-
|
|
480
|
+
}
|
|
481
|
+
}
|
|
482
|
+
if (tracingV2Enabled) {
|
|
483
|
+
const implicitRunTree = LangChainTracer.getTraceableRunTree();
|
|
484
|
+
if (implicitRunTree && callbackManager._parentRunId === void 0) {
|
|
485
|
+
callbackManager._parentRunId = implicitRunTree.id;
|
|
486
|
+
const tracerV2 = callbackManager.handlers.find((handler) => handler.name === "langchain_tracer");
|
|
487
|
+
tracerV2?.updateFromRunTree(implicitRunTree);
|
|
483
488
|
}
|
|
484
489
|
}
|
|
485
490
|
}
|
|
@@ -513,65 +518,7 @@ function ensureHandler(handler) {
|
|
|
513
518
|
if ("name" in handler) return handler;
|
|
514
519
|
return BaseCallbackHandler.fromMethods(handler);
|
|
515
520
|
}
|
|
516
|
-
/**
|
|
517
|
-
* @deprecated Use [`traceable`](https://docs.smith.langchain.com/observability/how_to_guides/tracing/annotate_code)
|
|
518
|
-
* from "langsmith" instead.
|
|
519
|
-
*/
|
|
520
|
-
var TraceGroup = class {
|
|
521
|
-
runManager;
|
|
522
|
-
constructor(groupName, options) {
|
|
523
|
-
this.groupName = groupName;
|
|
524
|
-
this.options = options;
|
|
525
|
-
}
|
|
526
|
-
async getTraceGroupCallbackManager(group_name, inputs, options) {
|
|
527
|
-
const cb = new LangChainTracer(options);
|
|
528
|
-
const cm = await CallbackManager.configure([cb]);
|
|
529
|
-
const runManager = await cm?.handleChainStart({
|
|
530
|
-
lc: 1,
|
|
531
|
-
type: "not_implemented",
|
|
532
|
-
id: [
|
|
533
|
-
"langchain",
|
|
534
|
-
"callbacks",
|
|
535
|
-
"groups",
|
|
536
|
-
group_name
|
|
537
|
-
]
|
|
538
|
-
}, inputs ?? {});
|
|
539
|
-
if (!runManager) throw new Error("Failed to create run group callback manager.");
|
|
540
|
-
return runManager;
|
|
541
|
-
}
|
|
542
|
-
async start(inputs) {
|
|
543
|
-
if (!this.runManager) this.runManager = await this.getTraceGroupCallbackManager(this.groupName, inputs, this.options);
|
|
544
|
-
return this.runManager.getChild();
|
|
545
|
-
}
|
|
546
|
-
async error(err) {
|
|
547
|
-
if (this.runManager) {
|
|
548
|
-
await this.runManager.handleChainError(err);
|
|
549
|
-
this.runManager = void 0;
|
|
550
|
-
}
|
|
551
|
-
}
|
|
552
|
-
async end(output) {
|
|
553
|
-
if (this.runManager) {
|
|
554
|
-
await this.runManager.handleChainEnd(output ?? {});
|
|
555
|
-
this.runManager = void 0;
|
|
556
|
-
}
|
|
557
|
-
}
|
|
558
|
-
};
|
|
559
|
-
function _coerceToDict(value, defaultKey) {
|
|
560
|
-
return value && !Array.isArray(value) && typeof value === "object" ? value : { [defaultKey]: value };
|
|
561
|
-
}
|
|
562
|
-
async function traceAsGroup(groupOptions, enclosedCode, ...args) {
|
|
563
|
-
const traceGroup = new TraceGroup(groupOptions.name, groupOptions);
|
|
564
|
-
const callbackManager = await traceGroup.start({ ...args });
|
|
565
|
-
try {
|
|
566
|
-
const result = await enclosedCode(callbackManager, ...args);
|
|
567
|
-
await traceGroup.end(_coerceToDict(result, "output"));
|
|
568
|
-
return result;
|
|
569
|
-
} catch (err) {
|
|
570
|
-
await traceGroup.error(err);
|
|
571
|
-
throw err;
|
|
572
|
-
}
|
|
573
|
-
}
|
|
574
521
|
|
|
575
522
|
//#endregion
|
|
576
|
-
export { BaseCallbackManager, BaseRunManager, CallbackManager, CallbackManagerForChainRun, CallbackManagerForLLMRun, CallbackManagerForRetrieverRun, CallbackManagerForToolRun,
|
|
523
|
+
export { BaseCallbackManager, BaseRunManager, CallbackManager, CallbackManagerForChainRun, CallbackManagerForLLMRun, CallbackManagerForRetrieverRun, CallbackManagerForToolRun, ensureHandler, manager_exports, parseCallbackConfigArg };
|
|
577
524
|
//# sourceMappingURL=manager.js.map
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"manager.js","names":["arg: Callbacks | BaseCallbackConfig | undefined","handler: BaseCallbackHandler","runId: string","handlers: BaseCallbackHandler[]","inheritableHandlers: BaseCallbackHandler[]","tags: string[]","inheritableTags: string[]","metadata: Record<string, unknown>","inheritableMetadata: Record<string, unknown>","_parentRunId?: string","text: string","eventName: string","data: any","_runId?: string","_tags?: string[]","_metadata?: Record<string, any>","tag?: string","documents: DocumentInterface[]","err: Error | unknown","token: string","idx?: NewTokenIndices","fields?: HandleLLMNewTokenCallbackFields","extraParams?: Record<string, unknown>","err","output: LLMResult","kwargs?: { inputs?: Record<string, unknown> }","output: ChainValues","action: AgentAction","action: AgentFinish","output: any","parentRunId?: string","options?: {\n handlers?: BaseCallbackHandler[];\n inheritableHandlers?: BaseCallbackHandler[];\n tags?: string[];\n inheritableTags?: string[];\n metadata?: Record<string, unknown>;\n inheritableMetadata?: Record<string, unknown>;\n }","llm: Serialized","prompts: string[]","runId: string | undefined","_parentRunId: string | undefined","extraParams: Record<string, unknown> | undefined","_tags: string[] | undefined","_metadata: Record<string, unknown> | undefined","runName: string | undefined","uuidv4","messages: BaseMessage[][]","chain: Serialized","inputs: ChainValues","runType: string | undefined","tool: Serialized","input: string","retriever: Serialized","query: string","additionalHandlers: BaseCallbackHandler[]","handlers: CallbackHandlerMethods","inheritableHandlers?: Callbacks","localHandlers?: Callbacks","inheritableTags?: string[]","localTags?: string[]","inheritableMetadata?: Record<string, unknown>","localMetadata?: Record<string, unknown>","options?: CallbackManagerOptions","callbackManager: CallbackManager | undefined","handler: BaseCallbackHandler | undefined","handler: BaseCallbackHandler | CallbackHandlerMethods","groupName: string","options?: {\n projectName?: string;\n exampleId?: string;\n }","group_name: string","inputs?: ChainValues","options?: LangChainTracerFields","output?: ChainValues","value: any","defaultKey: string","groupOptions: {\n name: string;\n } & LangChainTracerFields","enclosedCode: (manager: CallbackManager, ...args: A) => Promise<T>"],"sources":["../../src/callbacks/manager.ts"],"sourcesContent":["import { v4 as uuidv4 } from \"uuid\";\nimport { AgentAction, AgentFinish } from \"../agents.js\";\nimport type { ChainValues } from \"../utils/types/index.js\";\nimport { LLMResult } from \"../outputs.js\";\nimport {\n BaseCallbackHandler,\n CallbackHandlerMethods,\n HandleLLMNewTokenCallbackFields,\n isBaseCallbackHandler,\n NewTokenIndices,\n} from \"./base.js\";\nimport { ConsoleCallbackHandler } from \"../tracers/console.js\";\nimport { type BaseMessage } from \"../messages/base.js\";\nimport { getBufferString } from \"../messages/utils.js\";\nimport { getEnvironmentVariable } from \"../utils/env.js\";\nimport {\n LangChainTracer,\n LangChainTracerFields,\n} from \"../tracers/tracer_langchain.js\";\nimport { consumeCallback } from \"./promises.js\";\nimport { Serialized } from \"../load/serializable.js\";\nimport type { DocumentInterface } from \"../documents/document.js\";\nimport { isTracingEnabled } from \"../utils/callbacks.js\";\nimport { isBaseTracer } from \"../tracers/base.js\";\nimport {\n getContextVariable,\n _getConfigureHooks,\n} from \"../singletons/async_local_storage/context.js\";\n\ntype BaseCallbackManagerMethods = {\n [K in keyof CallbackHandlerMethods]?: (\n ...args: Parameters<Required<CallbackHandlerMethods>[K]>\n ) => Promise<unknown>;\n};\n\nexport interface CallbackManagerOptions {\n verbose?: boolean;\n tracing?: boolean;\n}\n\nexport type Callbacks =\n | CallbackManager\n | (BaseCallbackHandler | CallbackHandlerMethods)[];\n\nexport interface BaseCallbackConfig {\n /**\n * Name for the tracer run for this call. Defaults to the name of the class.\n */\n runName?: string;\n\n /**\n * Tags for this call and any sub-calls (eg. a Chain calling an LLM).\n * You can use these to filter calls.\n */\n tags?: string[];\n\n /**\n * Metadata for this call and any sub-calls (eg. a Chain calling an LLM).\n * Keys should be strings, values should be JSON-serializable.\n */\n metadata?: Record<string, unknown>;\n\n /**\n * Callbacks for this call and any sub-calls (eg. a Chain calling an LLM).\n * Tags are passed to all callbacks, metadata is passed to handle*Start callbacks.\n */\n callbacks?: Callbacks;\n\n /**\n * Unique identifier for the tracer run for this call. If not provided, a new UUID\n * will be generated.\n */\n runId?: string;\n}\n\nexport function parseCallbackConfigArg(\n arg: Callbacks | BaseCallbackConfig | undefined\n): BaseCallbackConfig {\n if (!arg) {\n return {};\n } else if (Array.isArray(arg) || \"name\" in arg) {\n return { callbacks: arg };\n } else {\n return arg;\n }\n}\n\n/**\n * Manage callbacks from different components of LangChain.\n */\nexport abstract class BaseCallbackManager {\n abstract addHandler(handler: BaseCallbackHandler): void;\n\n abstract removeHandler(handler: BaseCallbackHandler): void;\n\n abstract setHandlers(handlers: BaseCallbackHandler[]): void;\n\n setHandler(handler: BaseCallbackHandler): void {\n return this.setHandlers([handler]);\n }\n}\n\n/**\n * Base class for run manager in LangChain.\n */\nexport class BaseRunManager {\n constructor(\n public readonly runId: string,\n public readonly handlers: BaseCallbackHandler[],\n protected readonly inheritableHandlers: BaseCallbackHandler[],\n protected readonly tags: string[],\n protected readonly inheritableTags: string[],\n protected readonly metadata: Record<string, unknown>,\n protected readonly inheritableMetadata: Record<string, unknown>,\n protected readonly _parentRunId?: string\n ) {}\n\n get parentRunId() {\n return this._parentRunId;\n }\n\n async handleText(text: string): Promise<void> {\n await Promise.all(\n this.handlers.map((handler) =>\n consumeCallback(async () => {\n try {\n await handler.handleText?.(\n text,\n this.runId,\n this._parentRunId,\n this.tags\n );\n } catch (err) {\n const logFunction = handler.raiseError\n ? console.error\n : console.warn;\n logFunction(\n `Error in handler ${handler.constructor.name}, handleText: ${err}`\n );\n if (handler.raiseError) {\n throw err;\n }\n }\n }, handler.awaitHandlers)\n )\n );\n }\n\n async handleCustomEvent(\n eventName: string,\n // eslint-disable-next-line @typescript-eslint/no-explicit-any\n data: any,\n _runId?: string,\n _tags?: string[],\n // eslint-disable-next-line @typescript-eslint/no-explicit-any\n _metadata?: Record<string, any>\n ): Promise<void> {\n await Promise.all(\n this.handlers.map((handler) =>\n consumeCallback(async () => {\n try {\n await handler.handleCustomEvent?.(\n eventName,\n data,\n this.runId,\n this.tags,\n this.metadata\n );\n } catch (err) {\n const logFunction = handler.raiseError\n ? console.error\n : console.warn;\n logFunction(\n `Error in handler ${handler.constructor.name}, handleCustomEvent: ${err}`\n );\n if (handler.raiseError) {\n throw err;\n }\n }\n }, handler.awaitHandlers)\n )\n );\n }\n}\n\n/**\n * Manages callbacks for retriever runs.\n */\nexport class CallbackManagerForRetrieverRun\n extends BaseRunManager\n implements BaseCallbackManagerMethods\n{\n getChild(tag?: string): CallbackManager {\n // eslint-disable-next-line @typescript-eslint/no-use-before-define\n const manager = new CallbackManager(this.runId);\n manager.setHandlers(this.inheritableHandlers);\n manager.addTags(this.inheritableTags);\n manager.addMetadata(this.inheritableMetadata);\n if (tag) {\n manager.addTags([tag], false);\n }\n return manager;\n }\n\n async handleRetrieverEnd(documents: DocumentInterface[]): Promise<void> {\n await Promise.all(\n this.handlers.map((handler) =>\n consumeCallback(async () => {\n if (!handler.ignoreRetriever) {\n try {\n await handler.handleRetrieverEnd?.(\n documents,\n this.runId,\n this._parentRunId,\n this.tags\n );\n } catch (err) {\n const logFunction = handler.raiseError\n ? console.error\n : console.warn;\n logFunction(\n `Error in handler ${handler.constructor.name}, handleRetriever`\n );\n if (handler.raiseError) {\n throw err;\n }\n }\n }\n }, handler.awaitHandlers)\n )\n );\n }\n\n async handleRetrieverError(err: Error | unknown): Promise<void> {\n await Promise.all(\n this.handlers.map((handler) =>\n consumeCallback(async () => {\n if (!handler.ignoreRetriever) {\n try {\n await handler.handleRetrieverError?.(\n err,\n this.runId,\n this._parentRunId,\n this.tags\n );\n } catch (error) {\n const logFunction = handler.raiseError\n ? console.error\n : console.warn;\n logFunction(\n `Error in handler ${handler.constructor.name}, handleRetrieverError: ${error}`\n );\n if (handler.raiseError) {\n throw err;\n }\n }\n }\n }, handler.awaitHandlers)\n )\n );\n }\n}\n\nexport class CallbackManagerForLLMRun\n extends BaseRunManager\n implements BaseCallbackManagerMethods\n{\n async handleLLMNewToken(\n token: string,\n idx?: NewTokenIndices,\n _runId?: string,\n _parentRunId?: string,\n _tags?: string[],\n fields?: HandleLLMNewTokenCallbackFields\n ): Promise<void> {\n await Promise.all(\n this.handlers.map((handler) =>\n consumeCallback(async () => {\n if (!handler.ignoreLLM) {\n try {\n await handler.handleLLMNewToken?.(\n token,\n idx ?? { prompt: 0, completion: 0 },\n this.runId,\n this._parentRunId,\n this.tags,\n fields\n );\n } catch (err) {\n const logFunction = handler.raiseError\n ? console.error\n : console.warn;\n logFunction(\n `Error in handler ${handler.constructor.name}, handleLLMNewToken: ${err}`\n );\n if (handler.raiseError) {\n throw err;\n }\n }\n }\n }, handler.awaitHandlers)\n )\n );\n }\n\n async handleLLMError(\n err: Error | unknown,\n _runId?: string,\n _parentRunId?: string,\n _tags?: string[],\n extraParams?: Record<string, unknown>\n ): Promise<void> {\n await Promise.all(\n this.handlers.map((handler) =>\n consumeCallback(async () => {\n if (!handler.ignoreLLM) {\n try {\n await handler.handleLLMError?.(\n err,\n this.runId,\n this._parentRunId,\n this.tags,\n extraParams\n );\n } catch (err) {\n const logFunction = handler.raiseError\n ? console.error\n : console.warn;\n logFunction(\n `Error in handler ${handler.constructor.name}, handleLLMError: ${err}`\n );\n if (handler.raiseError) {\n throw err;\n }\n }\n }\n }, handler.awaitHandlers)\n )\n );\n }\n\n async handleLLMEnd(\n output: LLMResult,\n _runId?: string,\n _parentRunId?: string,\n _tags?: string[],\n extraParams?: Record<string, unknown>\n ): Promise<void> {\n await Promise.all(\n this.handlers.map((handler) =>\n consumeCallback(async () => {\n if (!handler.ignoreLLM) {\n try {\n await handler.handleLLMEnd?.(\n output,\n this.runId,\n this._parentRunId,\n this.tags,\n extraParams\n );\n } catch (err) {\n const logFunction = handler.raiseError\n ? console.error\n : console.warn;\n logFunction(\n `Error in handler ${handler.constructor.name}, handleLLMEnd: ${err}`\n );\n if (handler.raiseError) {\n throw err;\n }\n }\n }\n }, handler.awaitHandlers)\n )\n );\n }\n}\n\nexport class CallbackManagerForChainRun\n extends BaseRunManager\n implements BaseCallbackManagerMethods\n{\n getChild(tag?: string): CallbackManager {\n // eslint-disable-next-line @typescript-eslint/no-use-before-define\n const manager = new CallbackManager(this.runId);\n manager.setHandlers(this.inheritableHandlers);\n manager.addTags(this.inheritableTags);\n manager.addMetadata(this.inheritableMetadata);\n if (tag) {\n manager.addTags([tag], false);\n }\n return manager;\n }\n\n async handleChainError(\n err: Error | unknown,\n _runId?: string,\n _parentRunId?: string,\n _tags?: string[],\n kwargs?: { inputs?: Record<string, unknown> }\n ): Promise<void> {\n await Promise.all(\n this.handlers.map((handler) =>\n consumeCallback(async () => {\n if (!handler.ignoreChain) {\n try {\n await handler.handleChainError?.(\n err,\n this.runId,\n this._parentRunId,\n this.tags,\n kwargs\n );\n } catch (err) {\n const logFunction = handler.raiseError\n ? console.error\n : console.warn;\n logFunction(\n `Error in handler ${handler.constructor.name}, handleChainError: ${err}`\n );\n if (handler.raiseError) {\n throw err;\n }\n }\n }\n }, handler.awaitHandlers)\n )\n );\n }\n\n async handleChainEnd(\n output: ChainValues,\n _runId?: string,\n _parentRunId?: string,\n _tags?: string[],\n kwargs?: { inputs?: Record<string, unknown> }\n ): Promise<void> {\n await Promise.all(\n this.handlers.map((handler) =>\n consumeCallback(async () => {\n if (!handler.ignoreChain) {\n try {\n await handler.handleChainEnd?.(\n output,\n this.runId,\n this._parentRunId,\n this.tags,\n kwargs\n );\n } catch (err) {\n const logFunction = handler.raiseError\n ? console.error\n : console.warn;\n logFunction(\n `Error in handler ${handler.constructor.name}, handleChainEnd: ${err}`\n );\n if (handler.raiseError) {\n throw err;\n }\n }\n }\n }, handler.awaitHandlers)\n )\n );\n }\n\n async handleAgentAction(action: AgentAction): Promise<void> {\n await Promise.all(\n this.handlers.map((handler) =>\n consumeCallback(async () => {\n if (!handler.ignoreAgent) {\n try {\n await handler.handleAgentAction?.(\n action,\n this.runId,\n this._parentRunId,\n this.tags\n );\n } catch (err) {\n const logFunction = handler.raiseError\n ? console.error\n : console.warn;\n logFunction(\n `Error in handler ${handler.constructor.name}, handleAgentAction: ${err}`\n );\n if (handler.raiseError) {\n throw err;\n }\n }\n }\n }, handler.awaitHandlers)\n )\n );\n }\n\n async handleAgentEnd(action: AgentFinish): Promise<void> {\n await Promise.all(\n this.handlers.map((handler) =>\n consumeCallback(async () => {\n if (!handler.ignoreAgent) {\n try {\n await handler.handleAgentEnd?.(\n action,\n this.runId,\n this._parentRunId,\n this.tags\n );\n } catch (err) {\n const logFunction = handler.raiseError\n ? console.error\n : console.warn;\n logFunction(\n `Error in handler ${handler.constructor.name}, handleAgentEnd: ${err}`\n );\n if (handler.raiseError) {\n throw err;\n }\n }\n }\n }, handler.awaitHandlers)\n )\n );\n }\n}\n\nexport class CallbackManagerForToolRun\n extends BaseRunManager\n implements BaseCallbackManagerMethods\n{\n getChild(tag?: string): CallbackManager {\n // eslint-disable-next-line @typescript-eslint/no-use-before-define\n const manager = new CallbackManager(this.runId);\n manager.setHandlers(this.inheritableHandlers);\n manager.addTags(this.inheritableTags);\n manager.addMetadata(this.inheritableMetadata);\n if (tag) {\n manager.addTags([tag], false);\n }\n return manager;\n }\n\n async handleToolError(err: Error | unknown): Promise<void> {\n await Promise.all(\n this.handlers.map((handler) =>\n consumeCallback(async () => {\n if (!handler.ignoreAgent) {\n try {\n await handler.handleToolError?.(\n err,\n this.runId,\n this._parentRunId,\n this.tags\n );\n } catch (err) {\n const logFunction = handler.raiseError\n ? console.error\n : console.warn;\n logFunction(\n `Error in handler ${handler.constructor.name}, handleToolError: ${err}`\n );\n if (handler.raiseError) {\n throw err;\n }\n }\n }\n }, handler.awaitHandlers)\n )\n );\n }\n\n // eslint-disable-next-line @typescript-eslint/no-explicit-any\n async handleToolEnd(output: any): Promise<void> {\n await Promise.all(\n this.handlers.map((handler) =>\n consumeCallback(async () => {\n if (!handler.ignoreAgent) {\n try {\n await handler.handleToolEnd?.(\n output,\n this.runId,\n this._parentRunId,\n this.tags\n );\n } catch (err) {\n const logFunction = handler.raiseError\n ? console.error\n : console.warn;\n logFunction(\n `Error in handler ${handler.constructor.name}, handleToolEnd: ${err}`\n );\n if (handler.raiseError) {\n throw err;\n }\n }\n }\n }, handler.awaitHandlers)\n )\n );\n }\n}\n\n/**\n * @example\n * ```typescript\n * const prompt = PromptTemplate.fromTemplate(\"What is the answer to {question}?\");\n *\n * // Example of using LLMChain with OpenAI and a simple prompt\n * const chain = new LLMChain({\n * llm: new ChatOpenAI({ model: \"gpt-4o-mini\", temperature: 0.9 }),\n * prompt,\n * });\n *\n * // Running the chain with a single question\n * const result = await chain.call({\n * question: \"What is the airspeed velocity of an unladen swallow?\",\n * });\n * console.log(\"The answer is:\", result);\n * ```\n */\nexport class CallbackManager\n extends BaseCallbackManager\n implements BaseCallbackManagerMethods\n{\n handlers: BaseCallbackHandler[] = [];\n\n inheritableHandlers: BaseCallbackHandler[] = [];\n\n tags: string[] = [];\n\n inheritableTags: string[] = [];\n\n metadata: Record<string, unknown> = {};\n\n inheritableMetadata: Record<string, unknown> = {};\n\n name = \"callback_manager\";\n\n public _parentRunId?: string;\n\n constructor(\n parentRunId?: string,\n options?: {\n handlers?: BaseCallbackHandler[];\n inheritableHandlers?: BaseCallbackHandler[];\n tags?: string[];\n inheritableTags?: string[];\n metadata?: Record<string, unknown>;\n inheritableMetadata?: Record<string, unknown>;\n }\n ) {\n super();\n this.handlers = options?.handlers ?? this.handlers;\n this.inheritableHandlers =\n options?.inheritableHandlers ?? this.inheritableHandlers;\n this.tags = options?.tags ?? this.tags;\n this.inheritableTags = options?.inheritableTags ?? this.inheritableTags;\n this.metadata = options?.metadata ?? this.metadata;\n this.inheritableMetadata =\n options?.inheritableMetadata ?? this.inheritableMetadata;\n this._parentRunId = parentRunId;\n }\n\n /**\n * Gets the parent run ID, if any.\n *\n * @returns The parent run ID.\n */\n getParentRunId() {\n return this._parentRunId;\n }\n\n async handleLLMStart(\n llm: Serialized,\n prompts: string[],\n runId: string | undefined = undefined,\n _parentRunId: string | undefined = undefined,\n extraParams: Record<string, unknown> | undefined = undefined,\n _tags: string[] | undefined = undefined,\n _metadata: Record<string, unknown> | undefined = undefined,\n runName: string | undefined = undefined\n ): Promise<CallbackManagerForLLMRun[]> {\n return Promise.all(\n prompts.map(async (prompt, idx) => {\n // Can't have duplicate runs with the same run ID (if provided)\n const runId_ = idx === 0 && runId ? runId : uuidv4();\n\n await Promise.all(\n this.handlers.map((handler) => {\n if (handler.ignoreLLM) {\n return;\n }\n if (isBaseTracer(handler)) {\n // Create and add run to the run map.\n // We do this synchronously to avoid race conditions\n // when callbacks are backgrounded.\n handler._createRunForLLMStart(\n llm,\n [prompt],\n runId_,\n this._parentRunId,\n extraParams,\n this.tags,\n this.metadata,\n runName\n );\n }\n return consumeCallback(async () => {\n try {\n await handler.handleLLMStart?.(\n llm,\n [prompt],\n runId_,\n this._parentRunId,\n extraParams,\n this.tags,\n this.metadata,\n runName\n );\n } catch (err) {\n const logFunction = handler.raiseError\n ? console.error\n : console.warn;\n logFunction(\n `Error in handler ${handler.constructor.name}, handleLLMStart: ${err}`\n );\n if (handler.raiseError) {\n throw err;\n }\n }\n }, handler.awaitHandlers);\n })\n );\n\n return new CallbackManagerForLLMRun(\n runId_,\n this.handlers,\n this.inheritableHandlers,\n this.tags,\n this.inheritableTags,\n this.metadata,\n this.inheritableMetadata,\n this._parentRunId\n );\n })\n );\n }\n\n async handleChatModelStart(\n llm: Serialized,\n messages: BaseMessage[][],\n runId: string | undefined = undefined,\n _parentRunId: string | undefined = undefined,\n extraParams: Record<string, unknown> | undefined = undefined,\n _tags: string[] | undefined = undefined,\n _metadata: Record<string, unknown> | undefined = undefined,\n runName: string | undefined = undefined\n ): Promise<CallbackManagerForLLMRun[]> {\n return Promise.all(\n messages.map(async (messageGroup, idx) => {\n // Can't have duplicate runs with the same run ID (if provided)\n const runId_ = idx === 0 && runId ? runId : uuidv4();\n\n await Promise.all(\n this.handlers.map((handler) => {\n if (handler.ignoreLLM) {\n return;\n }\n if (isBaseTracer(handler)) {\n // Create and add run to the run map.\n // We do this synchronously to avoid race conditions\n // when callbacks are backgrounded.\n handler._createRunForChatModelStart(\n llm,\n [messageGroup],\n runId_,\n this._parentRunId,\n extraParams,\n this.tags,\n this.metadata,\n runName\n );\n }\n return consumeCallback(async () => {\n try {\n if (handler.handleChatModelStart) {\n await handler.handleChatModelStart?.(\n llm,\n [messageGroup],\n runId_,\n this._parentRunId,\n extraParams,\n this.tags,\n this.metadata,\n runName\n );\n } else if (handler.handleLLMStart) {\n const messageString = getBufferString(messageGroup);\n await handler.handleLLMStart?.(\n llm,\n [messageString],\n runId_,\n this._parentRunId,\n extraParams,\n this.tags,\n this.metadata,\n runName\n );\n }\n } catch (err) {\n const logFunction = handler.raiseError\n ? console.error\n : console.warn;\n logFunction(\n `Error in handler ${handler.constructor.name}, handleLLMStart: ${err}`\n );\n if (handler.raiseError) {\n throw err;\n }\n }\n }, handler.awaitHandlers);\n })\n );\n\n return new CallbackManagerForLLMRun(\n runId_,\n this.handlers,\n this.inheritableHandlers,\n this.tags,\n this.inheritableTags,\n this.metadata,\n this.inheritableMetadata,\n this._parentRunId\n );\n })\n );\n }\n\n async handleChainStart(\n chain: Serialized,\n inputs: ChainValues,\n runId = uuidv4(),\n runType: string | undefined = undefined,\n _tags: string[] | undefined = undefined,\n _metadata: Record<string, unknown> | undefined = undefined,\n runName: string | undefined = undefined\n ): Promise<CallbackManagerForChainRun> {\n await Promise.all(\n this.handlers.map((handler) => {\n if (handler.ignoreChain) {\n return;\n }\n if (isBaseTracer(handler)) {\n // Create and add run to the run map.\n // We do this synchronously to avoid race conditions\n // when callbacks are backgrounded.\n handler._createRunForChainStart(\n chain,\n inputs,\n runId,\n this._parentRunId,\n this.tags,\n this.metadata,\n runType,\n runName\n );\n }\n return consumeCallback(async () => {\n try {\n await handler.handleChainStart?.(\n chain,\n inputs,\n runId,\n this._parentRunId,\n this.tags,\n this.metadata,\n runType,\n runName\n );\n } catch (err) {\n const logFunction = handler.raiseError\n ? console.error\n : console.warn;\n logFunction(\n `Error in handler ${handler.constructor.name}, handleChainStart: ${err}`\n );\n if (handler.raiseError) {\n throw err;\n }\n }\n }, handler.awaitHandlers);\n })\n );\n return new CallbackManagerForChainRun(\n runId,\n this.handlers,\n this.inheritableHandlers,\n this.tags,\n this.inheritableTags,\n this.metadata,\n this.inheritableMetadata,\n this._parentRunId\n );\n }\n\n async handleToolStart(\n tool: Serialized,\n input: string,\n runId = uuidv4(),\n _parentRunId: string | undefined = undefined,\n _tags: string[] | undefined = undefined,\n _metadata: Record<string, unknown> | undefined = undefined,\n runName: string | undefined = undefined\n ): Promise<CallbackManagerForToolRun> {\n await Promise.all(\n this.handlers.map((handler) => {\n if (handler.ignoreAgent) {\n return;\n }\n if (isBaseTracer(handler)) {\n // Create and add run to the run map.\n // We do this synchronously to avoid race conditions\n // when callbacks are backgrounded.\n handler._createRunForToolStart(\n tool,\n input,\n runId,\n this._parentRunId,\n this.tags,\n this.metadata,\n runName\n );\n }\n return consumeCallback(async () => {\n try {\n await handler.handleToolStart?.(\n tool,\n input,\n runId,\n this._parentRunId,\n this.tags,\n this.metadata,\n runName\n );\n } catch (err) {\n const logFunction = handler.raiseError\n ? console.error\n : console.warn;\n logFunction(\n `Error in handler ${handler.constructor.name}, handleToolStart: ${err}`\n );\n if (handler.raiseError) {\n throw err;\n }\n }\n }, handler.awaitHandlers);\n })\n );\n return new CallbackManagerForToolRun(\n runId,\n this.handlers,\n this.inheritableHandlers,\n this.tags,\n this.inheritableTags,\n this.metadata,\n this.inheritableMetadata,\n this._parentRunId\n );\n }\n\n async handleRetrieverStart(\n retriever: Serialized,\n query: string,\n runId: string = uuidv4(),\n _parentRunId: string | undefined = undefined,\n _tags: string[] | undefined = undefined,\n _metadata: Record<string, unknown> | undefined = undefined,\n runName: string | undefined = undefined\n ): Promise<CallbackManagerForRetrieverRun> {\n await Promise.all(\n this.handlers.map((handler) => {\n if (handler.ignoreRetriever) {\n return;\n }\n if (isBaseTracer(handler)) {\n // Create and add run to the run map.\n // We do this synchronously to avoid race conditions\n // when callbacks are backgrounded.\n handler._createRunForRetrieverStart(\n retriever,\n query,\n runId,\n this._parentRunId,\n this.tags,\n this.metadata,\n runName\n );\n }\n return consumeCallback(async () => {\n try {\n await handler.handleRetrieverStart?.(\n retriever,\n query,\n runId,\n this._parentRunId,\n this.tags,\n this.metadata,\n runName\n );\n } catch (err) {\n const logFunction = handler.raiseError\n ? console.error\n : console.warn;\n logFunction(\n `Error in handler ${handler.constructor.name}, handleRetrieverStart: ${err}`\n );\n if (handler.raiseError) {\n throw err;\n }\n }\n }, handler.awaitHandlers);\n })\n );\n return new CallbackManagerForRetrieverRun(\n runId,\n this.handlers,\n this.inheritableHandlers,\n this.tags,\n this.inheritableTags,\n this.metadata,\n this.inheritableMetadata,\n this._parentRunId\n );\n }\n\n async handleCustomEvent?(\n eventName: string,\n // eslint-disable-next-line @typescript-eslint/no-explicit-any\n data: any,\n runId: string,\n _tags?: string[],\n // eslint-disable-next-line @typescript-eslint/no-explicit-any\n _metadata?: Record<string, any>\n ): // eslint-disable-next-line @typescript-eslint/no-explicit-any\n Promise<any> {\n await Promise.all(\n this.handlers.map((handler) =>\n consumeCallback(async () => {\n if (!handler.ignoreCustomEvent) {\n try {\n await handler.handleCustomEvent?.(\n eventName,\n data,\n runId,\n this.tags,\n this.metadata\n );\n } catch (err) {\n const logFunction = handler.raiseError\n ? console.error\n : console.warn;\n logFunction(\n `Error in handler ${handler.constructor.name}, handleCustomEvent: ${err}`\n );\n if (handler.raiseError) {\n throw err;\n }\n }\n }\n }, handler.awaitHandlers)\n )\n );\n }\n\n addHandler(handler: BaseCallbackHandler, inherit = true): void {\n this.handlers.push(handler);\n if (inherit) {\n this.inheritableHandlers.push(handler);\n }\n }\n\n removeHandler(handler: BaseCallbackHandler): void {\n this.handlers = this.handlers.filter((_handler) => _handler !== handler);\n this.inheritableHandlers = this.inheritableHandlers.filter(\n (_handler) => _handler !== handler\n );\n }\n\n setHandlers(handlers: BaseCallbackHandler[], inherit = true): void {\n this.handlers = [];\n this.inheritableHandlers = [];\n for (const handler of handlers) {\n this.addHandler(handler, inherit);\n }\n }\n\n addTags(tags: string[], inherit = true): void {\n this.removeTags(tags); // Remove duplicates\n this.tags.push(...tags);\n if (inherit) {\n this.inheritableTags.push(...tags);\n }\n }\n\n removeTags(tags: string[]): void {\n this.tags = this.tags.filter((tag) => !tags.includes(tag));\n this.inheritableTags = this.inheritableTags.filter(\n (tag) => !tags.includes(tag)\n );\n }\n\n addMetadata(metadata: Record<string, unknown>, inherit = true): void {\n this.metadata = { ...this.metadata, ...metadata };\n if (inherit) {\n this.inheritableMetadata = { ...this.inheritableMetadata, ...metadata };\n }\n }\n\n removeMetadata(metadata: Record<string, unknown>): void {\n for (const key of Object.keys(metadata)) {\n delete this.metadata[key];\n delete this.inheritableMetadata[key];\n }\n }\n\n copy(\n additionalHandlers: BaseCallbackHandler[] = [],\n inherit = true\n ): CallbackManager {\n const manager = new CallbackManager(this._parentRunId);\n for (const handler of this.handlers) {\n const inheritable = this.inheritableHandlers.includes(handler);\n manager.addHandler(handler, inheritable);\n }\n for (const tag of this.tags) {\n const inheritable = this.inheritableTags.includes(tag);\n manager.addTags([tag], inheritable);\n }\n for (const key of Object.keys(this.metadata)) {\n const inheritable = Object.keys(this.inheritableMetadata).includes(key);\n manager.addMetadata({ [key]: this.metadata[key] }, inheritable);\n }\n for (const handler of additionalHandlers) {\n if (\n // Prevent multiple copies of console_callback_handler\n manager.handlers\n .filter((h) => h.name === \"console_callback_handler\")\n .some((h) => h.name === handler.name)\n ) {\n continue;\n }\n manager.addHandler(handler, inherit);\n }\n return manager;\n }\n\n static fromHandlers(handlers: CallbackHandlerMethods) {\n class Handler extends BaseCallbackHandler {\n name = uuidv4();\n\n constructor() {\n super();\n Object.assign(this, handlers);\n }\n }\n\n const manager = new this();\n manager.addHandler(new Handler());\n return manager;\n }\n\n static configure(\n inheritableHandlers?: Callbacks,\n localHandlers?: Callbacks,\n inheritableTags?: string[],\n localTags?: string[],\n inheritableMetadata?: Record<string, unknown>,\n localMetadata?: Record<string, unknown>,\n options?: CallbackManagerOptions\n ): CallbackManager | undefined {\n return this._configureSync(\n inheritableHandlers,\n localHandlers,\n inheritableTags,\n localTags,\n inheritableMetadata,\n localMetadata,\n options\n );\n }\n\n // TODO: Deprecate async method in favor of this one.\n static _configureSync(\n inheritableHandlers?: Callbacks,\n localHandlers?: Callbacks,\n inheritableTags?: string[],\n localTags?: string[],\n inheritableMetadata?: Record<string, unknown>,\n localMetadata?: Record<string, unknown>,\n options?: CallbackManagerOptions\n ) {\n let callbackManager: CallbackManager | undefined;\n if (inheritableHandlers || localHandlers) {\n if (Array.isArray(inheritableHandlers) || !inheritableHandlers) {\n callbackManager = new CallbackManager();\n callbackManager.setHandlers(\n inheritableHandlers?.map(ensureHandler) ?? [],\n true\n );\n } else {\n callbackManager = inheritableHandlers;\n }\n\n callbackManager = callbackManager.copy(\n Array.isArray(localHandlers)\n ? localHandlers.map(ensureHandler)\n : localHandlers?.handlers,\n false\n );\n }\n\n const verboseEnabled =\n getEnvironmentVariable(\"LANGCHAIN_VERBOSE\") === \"true\" ||\n options?.verbose;\n\n const tracingV2Enabled =\n LangChainTracer.getTraceableRunTree()?.tracingEnabled ||\n isTracingEnabled();\n\n const tracingEnabled =\n tracingV2Enabled ||\n (getEnvironmentVariable(\"LANGCHAIN_TRACING\") ?? false);\n if (verboseEnabled || tracingEnabled) {\n if (!callbackManager) {\n callbackManager = new CallbackManager();\n }\n if (\n verboseEnabled &&\n !callbackManager.handlers.some(\n (handler) => handler.name === ConsoleCallbackHandler.prototype.name\n )\n ) {\n const consoleHandler = new ConsoleCallbackHandler();\n callbackManager.addHandler(consoleHandler, true);\n }\n if (\n tracingEnabled &&\n !callbackManager.handlers.some(\n (handler) => handler.name === \"langchain_tracer\"\n )\n ) {\n if (tracingV2Enabled) {\n const tracerV2 = new LangChainTracer();\n callbackManager.addHandler(tracerV2, true);\n\n // handoff between langchain and langsmith/traceable\n // override the parent run ID\n callbackManager._parentRunId =\n LangChainTracer.getTraceableRunTree()?.id ??\n callbackManager._parentRunId;\n }\n }\n }\n\n for (const {\n contextVar,\n inheritable = true,\n handlerClass,\n envVar,\n } of _getConfigureHooks()) {\n const createIfNotInContext =\n envVar && getEnvironmentVariable(envVar) === \"true\" && handlerClass;\n let handler: BaseCallbackHandler | undefined;\n const contextVarValue =\n contextVar !== undefined ? getContextVariable(contextVar) : undefined;\n if (contextVarValue && isBaseCallbackHandler(contextVarValue)) {\n handler = contextVarValue;\n } else if (createIfNotInContext) {\n // eslint-disable-next-line @typescript-eslint/no-explicit-any\n handler = new (handlerClass as any)({});\n }\n if (handler !== undefined) {\n if (!callbackManager) {\n callbackManager = new CallbackManager();\n }\n\n if (!callbackManager.handlers.some((h) => h.name === handler!.name)) {\n callbackManager.addHandler(handler, inheritable);\n }\n }\n }\n\n if (inheritableTags || localTags) {\n if (callbackManager) {\n callbackManager.addTags(inheritableTags ?? []);\n callbackManager.addTags(localTags ?? [], false);\n }\n }\n if (inheritableMetadata || localMetadata) {\n if (callbackManager) {\n callbackManager.addMetadata(inheritableMetadata ?? {});\n callbackManager.addMetadata(localMetadata ?? {}, false);\n }\n }\n\n return callbackManager;\n }\n}\n\nexport function ensureHandler(\n handler: BaseCallbackHandler | CallbackHandlerMethods\n): BaseCallbackHandler {\n if (\"name\" in handler) {\n return handler;\n }\n\n return BaseCallbackHandler.fromMethods(handler);\n}\n\n/**\n * @deprecated Use [`traceable`](https://docs.smith.langchain.com/observability/how_to_guides/tracing/annotate_code)\n * from \"langsmith\" instead.\n */\nexport class TraceGroup {\n private runManager?: CallbackManagerForChainRun;\n\n constructor(\n private groupName: string,\n private options?: {\n projectName?: string;\n exampleId?: string;\n }\n ) {}\n\n private async getTraceGroupCallbackManager(\n group_name: string,\n inputs?: ChainValues,\n options?: LangChainTracerFields\n ): Promise<CallbackManagerForChainRun> {\n const cb = new LangChainTracer(options);\n const cm = await CallbackManager.configure([cb]);\n const runManager = await cm?.handleChainStart(\n {\n lc: 1,\n type: \"not_implemented\",\n id: [\"langchain\", \"callbacks\", \"groups\", group_name],\n },\n inputs ?? {}\n );\n if (!runManager) {\n throw new Error(\"Failed to create run group callback manager.\");\n }\n return runManager;\n }\n\n async start(inputs?: ChainValues): Promise<CallbackManager> {\n if (!this.runManager) {\n this.runManager = await this.getTraceGroupCallbackManager(\n this.groupName,\n inputs,\n this.options\n );\n }\n return this.runManager.getChild();\n }\n\n async error(err: Error | unknown): Promise<void> {\n if (this.runManager) {\n await this.runManager.handleChainError(err);\n this.runManager = undefined;\n }\n }\n\n async end(output?: ChainValues): Promise<void> {\n if (this.runManager) {\n await this.runManager.handleChainEnd(output ?? {});\n this.runManager = undefined;\n }\n }\n}\n\n// eslint-disable-next-line @typescript-eslint/no-explicit-any\nfunction _coerceToDict(value: any, defaultKey: string) {\n return value && !Array.isArray(value) && typeof value === \"object\"\n ? value\n : { [defaultKey]: value };\n}\n\n// eslint-disable-next-line @typescript-eslint/no-explicit-any\nexport async function traceAsGroup<T, A extends any[]>(\n groupOptions: {\n name: string;\n } & LangChainTracerFields,\n enclosedCode: (manager: CallbackManager, ...args: A) => Promise<T>,\n ...args: A\n): Promise<T> {\n const traceGroup = new TraceGroup(groupOptions.name, groupOptions);\n const callbackManager = await traceGroup.start({ ...args });\n try {\n const result = await enclosedCode(callbackManager, ...args);\n await traceGroup.end(_coerceToDict(result, \"output\"));\n return result;\n } catch (err) {\n await traceGroup.error(err);\n throw err;\n }\n}\n"],"mappings":"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"}
|
|
1
|
+
{"version":3,"file":"manager.js","names":["arg: Callbacks | BaseCallbackConfig | undefined","handler: BaseCallbackHandler","runId: string","handlers: BaseCallbackHandler[]","inheritableHandlers: BaseCallbackHandler[]","tags: string[]","inheritableTags: string[]","metadata: Record<string, unknown>","inheritableMetadata: Record<string, unknown>","_parentRunId?: string","text: string","eventName: string","data: any","_runId?: string","_tags?: string[]","_metadata?: Record<string, any>","tag?: string","documents: DocumentInterface[]","err: Error | unknown","token: string","idx?: NewTokenIndices","fields?: HandleLLMNewTokenCallbackFields","extraParams?: Record<string, unknown>","err","output: LLMResult","kwargs?: { inputs?: Record<string, unknown> }","output: ChainValues","action: AgentAction","action: AgentFinish","output: any","parentRunId?: string","options?: {\n handlers?: BaseCallbackHandler[];\n inheritableHandlers?: BaseCallbackHandler[];\n tags?: string[];\n inheritableTags?: string[];\n metadata?: Record<string, unknown>;\n inheritableMetadata?: Record<string, unknown>;\n }","llm: Serialized","prompts: string[]","runId: string | undefined","_parentRunId: string | undefined","extraParams: Record<string, unknown> | undefined","_tags: string[] | undefined","_metadata: Record<string, unknown> | undefined","runName: string | undefined","uuidv4","messages: BaseMessage[][]","chain: Serialized","inputs: ChainValues","runType: string | undefined","tool: Serialized","input: string","retriever: Serialized","query: string","additionalHandlers: BaseCallbackHandler[]","handlers: CallbackHandlerMethods","inheritableHandlers?: Callbacks","localHandlers?: Callbacks","inheritableTags?: string[]","localTags?: string[]","inheritableMetadata?: Record<string, unknown>","localMetadata?: Record<string, unknown>","options?: CallbackManagerOptions","callbackManager: CallbackManager | undefined","handler: BaseCallbackHandler | undefined","handler: BaseCallbackHandler | CallbackHandlerMethods"],"sources":["../../src/callbacks/manager.ts"],"sourcesContent":["import { v4 as uuidv4 } from \"uuid\";\nimport { AgentAction, AgentFinish } from \"../agents.js\";\nimport type { ChainValues } from \"../utils/types/index.js\";\nimport { LLMResult } from \"../outputs.js\";\nimport {\n BaseCallbackHandler,\n CallbackHandlerMethods,\n HandleLLMNewTokenCallbackFields,\n isBaseCallbackHandler,\n NewTokenIndices,\n} from \"./base.js\";\nimport { ConsoleCallbackHandler } from \"../tracers/console.js\";\nimport { type BaseMessage } from \"../messages/base.js\";\nimport { getBufferString } from \"../messages/utils.js\";\nimport { getEnvironmentVariable } from \"../utils/env.js\";\nimport { LangChainTracer } from \"../tracers/tracer_langchain.js\";\nimport { consumeCallback } from \"./promises.js\";\nimport { Serialized } from \"../load/serializable.js\";\nimport type { DocumentInterface } from \"../documents/document.js\";\nimport { isTracingEnabled } from \"../utils/callbacks.js\";\nimport { isBaseTracer } from \"../tracers/base.js\";\nimport {\n getContextVariable,\n _getConfigureHooks,\n} from \"../singletons/async_local_storage/context.js\";\n\ntype BaseCallbackManagerMethods = {\n [K in keyof CallbackHandlerMethods]?: (\n ...args: Parameters<Required<CallbackHandlerMethods>[K]>\n ) => Promise<unknown>;\n};\n\nexport interface CallbackManagerOptions {\n verbose?: boolean;\n tracing?: boolean;\n}\n\nexport type Callbacks =\n | CallbackManager\n | (BaseCallbackHandler | CallbackHandlerMethods)[];\n\nexport interface BaseCallbackConfig {\n /**\n * Name for the tracer run for this call. Defaults to the name of the class.\n */\n runName?: string;\n\n /**\n * Tags for this call and any sub-calls (eg. a Chain calling an LLM).\n * You can use these to filter calls.\n */\n tags?: string[];\n\n /**\n * Metadata for this call and any sub-calls (eg. a Chain calling an LLM).\n * Keys should be strings, values should be JSON-serializable.\n */\n metadata?: Record<string, unknown>;\n\n /**\n * Callbacks for this call and any sub-calls (eg. a Chain calling an LLM).\n * Tags are passed to all callbacks, metadata is passed to handle*Start callbacks.\n */\n callbacks?: Callbacks;\n\n /**\n * Unique identifier for the tracer run for this call. If not provided, a new UUID\n * will be generated.\n */\n runId?: string;\n}\n\nexport function parseCallbackConfigArg(\n arg: Callbacks | BaseCallbackConfig | undefined\n): BaseCallbackConfig {\n if (!arg) {\n return {};\n } else if (Array.isArray(arg) || \"name\" in arg) {\n return { callbacks: arg };\n } else {\n return arg;\n }\n}\n\n/**\n * Manage callbacks from different components of LangChain.\n */\nexport abstract class BaseCallbackManager {\n abstract addHandler(handler: BaseCallbackHandler): void;\n\n abstract removeHandler(handler: BaseCallbackHandler): void;\n\n abstract setHandlers(handlers: BaseCallbackHandler[]): void;\n\n setHandler(handler: BaseCallbackHandler): void {\n return this.setHandlers([handler]);\n }\n}\n\n/**\n * Base class for run manager in LangChain.\n */\nexport class BaseRunManager {\n constructor(\n public readonly runId: string,\n public readonly handlers: BaseCallbackHandler[],\n protected readonly inheritableHandlers: BaseCallbackHandler[],\n protected readonly tags: string[],\n protected readonly inheritableTags: string[],\n protected readonly metadata: Record<string, unknown>,\n protected readonly inheritableMetadata: Record<string, unknown>,\n protected readonly _parentRunId?: string\n ) {}\n\n get parentRunId() {\n return this._parentRunId;\n }\n\n async handleText(text: string): Promise<void> {\n await Promise.all(\n this.handlers.map((handler) =>\n consumeCallback(async () => {\n try {\n await handler.handleText?.(\n text,\n this.runId,\n this._parentRunId,\n this.tags\n );\n } catch (err) {\n const logFunction = handler.raiseError\n ? console.error\n : console.warn;\n logFunction(\n `Error in handler ${handler.constructor.name}, handleText: ${err}`\n );\n if (handler.raiseError) {\n throw err;\n }\n }\n }, handler.awaitHandlers)\n )\n );\n }\n\n async handleCustomEvent(\n eventName: string,\n // eslint-disable-next-line @typescript-eslint/no-explicit-any\n data: any,\n _runId?: string,\n _tags?: string[],\n // eslint-disable-next-line @typescript-eslint/no-explicit-any\n _metadata?: Record<string, any>\n ): Promise<void> {\n await Promise.all(\n this.handlers.map((handler) =>\n consumeCallback(async () => {\n try {\n await handler.handleCustomEvent?.(\n eventName,\n data,\n this.runId,\n this.tags,\n this.metadata\n );\n } catch (err) {\n const logFunction = handler.raiseError\n ? console.error\n : console.warn;\n logFunction(\n `Error in handler ${handler.constructor.name}, handleCustomEvent: ${err}`\n );\n if (handler.raiseError) {\n throw err;\n }\n }\n }, handler.awaitHandlers)\n )\n );\n }\n}\n\n/**\n * Manages callbacks for retriever runs.\n */\nexport class CallbackManagerForRetrieverRun\n extends BaseRunManager\n implements BaseCallbackManagerMethods\n{\n getChild(tag?: string): CallbackManager {\n // eslint-disable-next-line @typescript-eslint/no-use-before-define\n const manager = new CallbackManager(this.runId);\n manager.setHandlers(this.inheritableHandlers);\n manager.addTags(this.inheritableTags);\n manager.addMetadata(this.inheritableMetadata);\n if (tag) {\n manager.addTags([tag], false);\n }\n return manager;\n }\n\n async handleRetrieverEnd(documents: DocumentInterface[]): Promise<void> {\n await Promise.all(\n this.handlers.map((handler) =>\n consumeCallback(async () => {\n if (!handler.ignoreRetriever) {\n try {\n await handler.handleRetrieverEnd?.(\n documents,\n this.runId,\n this._parentRunId,\n this.tags\n );\n } catch (err) {\n const logFunction = handler.raiseError\n ? console.error\n : console.warn;\n logFunction(\n `Error in handler ${handler.constructor.name}, handleRetriever`\n );\n if (handler.raiseError) {\n throw err;\n }\n }\n }\n }, handler.awaitHandlers)\n )\n );\n }\n\n async handleRetrieverError(err: Error | unknown): Promise<void> {\n await Promise.all(\n this.handlers.map((handler) =>\n consumeCallback(async () => {\n if (!handler.ignoreRetriever) {\n try {\n await handler.handleRetrieverError?.(\n err,\n this.runId,\n this._parentRunId,\n this.tags\n );\n } catch (error) {\n const logFunction = handler.raiseError\n ? console.error\n : console.warn;\n logFunction(\n `Error in handler ${handler.constructor.name}, handleRetrieverError: ${error}`\n );\n if (handler.raiseError) {\n throw err;\n }\n }\n }\n }, handler.awaitHandlers)\n )\n );\n }\n}\n\nexport class CallbackManagerForLLMRun\n extends BaseRunManager\n implements BaseCallbackManagerMethods\n{\n async handleLLMNewToken(\n token: string,\n idx?: NewTokenIndices,\n _runId?: string,\n _parentRunId?: string,\n _tags?: string[],\n fields?: HandleLLMNewTokenCallbackFields\n ): Promise<void> {\n await Promise.all(\n this.handlers.map((handler) =>\n consumeCallback(async () => {\n if (!handler.ignoreLLM) {\n try {\n await handler.handleLLMNewToken?.(\n token,\n idx ?? { prompt: 0, completion: 0 },\n this.runId,\n this._parentRunId,\n this.tags,\n fields\n );\n } catch (err) {\n const logFunction = handler.raiseError\n ? console.error\n : console.warn;\n logFunction(\n `Error in handler ${handler.constructor.name}, handleLLMNewToken: ${err}`\n );\n if (handler.raiseError) {\n throw err;\n }\n }\n }\n }, handler.awaitHandlers)\n )\n );\n }\n\n async handleLLMError(\n err: Error | unknown,\n _runId?: string,\n _parentRunId?: string,\n _tags?: string[],\n extraParams?: Record<string, unknown>\n ): Promise<void> {\n await Promise.all(\n this.handlers.map((handler) =>\n consumeCallback(async () => {\n if (!handler.ignoreLLM) {\n try {\n await handler.handleLLMError?.(\n err,\n this.runId,\n this._parentRunId,\n this.tags,\n extraParams\n );\n } catch (err) {\n const logFunction = handler.raiseError\n ? console.error\n : console.warn;\n logFunction(\n `Error in handler ${handler.constructor.name}, handleLLMError: ${err}`\n );\n if (handler.raiseError) {\n throw err;\n }\n }\n }\n }, handler.awaitHandlers)\n )\n );\n }\n\n async handleLLMEnd(\n output: LLMResult,\n _runId?: string,\n _parentRunId?: string,\n _tags?: string[],\n extraParams?: Record<string, unknown>\n ): Promise<void> {\n await Promise.all(\n this.handlers.map((handler) =>\n consumeCallback(async () => {\n if (!handler.ignoreLLM) {\n try {\n await handler.handleLLMEnd?.(\n output,\n this.runId,\n this._parentRunId,\n this.tags,\n extraParams\n );\n } catch (err) {\n const logFunction = handler.raiseError\n ? console.error\n : console.warn;\n logFunction(\n `Error in handler ${handler.constructor.name}, handleLLMEnd: ${err}`\n );\n if (handler.raiseError) {\n throw err;\n }\n }\n }\n }, handler.awaitHandlers)\n )\n );\n }\n}\n\nexport class CallbackManagerForChainRun\n extends BaseRunManager\n implements BaseCallbackManagerMethods\n{\n getChild(tag?: string): CallbackManager {\n // eslint-disable-next-line @typescript-eslint/no-use-before-define\n const manager = new CallbackManager(this.runId);\n manager.setHandlers(this.inheritableHandlers);\n manager.addTags(this.inheritableTags);\n manager.addMetadata(this.inheritableMetadata);\n if (tag) {\n manager.addTags([tag], false);\n }\n return manager;\n }\n\n async handleChainError(\n err: Error | unknown,\n _runId?: string,\n _parentRunId?: string,\n _tags?: string[],\n kwargs?: { inputs?: Record<string, unknown> }\n ): Promise<void> {\n await Promise.all(\n this.handlers.map((handler) =>\n consumeCallback(async () => {\n if (!handler.ignoreChain) {\n try {\n await handler.handleChainError?.(\n err,\n this.runId,\n this._parentRunId,\n this.tags,\n kwargs\n );\n } catch (err) {\n const logFunction = handler.raiseError\n ? console.error\n : console.warn;\n logFunction(\n `Error in handler ${handler.constructor.name}, handleChainError: ${err}`\n );\n if (handler.raiseError) {\n throw err;\n }\n }\n }\n }, handler.awaitHandlers)\n )\n );\n }\n\n async handleChainEnd(\n output: ChainValues,\n _runId?: string,\n _parentRunId?: string,\n _tags?: string[],\n kwargs?: { inputs?: Record<string, unknown> }\n ): Promise<void> {\n await Promise.all(\n this.handlers.map((handler) =>\n consumeCallback(async () => {\n if (!handler.ignoreChain) {\n try {\n await handler.handleChainEnd?.(\n output,\n this.runId,\n this._parentRunId,\n this.tags,\n kwargs\n );\n } catch (err) {\n const logFunction = handler.raiseError\n ? console.error\n : console.warn;\n logFunction(\n `Error in handler ${handler.constructor.name}, handleChainEnd: ${err}`\n );\n if (handler.raiseError) {\n throw err;\n }\n }\n }\n }, handler.awaitHandlers)\n )\n );\n }\n\n async handleAgentAction(action: AgentAction): Promise<void> {\n await Promise.all(\n this.handlers.map((handler) =>\n consumeCallback(async () => {\n if (!handler.ignoreAgent) {\n try {\n await handler.handleAgentAction?.(\n action,\n this.runId,\n this._parentRunId,\n this.tags\n );\n } catch (err) {\n const logFunction = handler.raiseError\n ? console.error\n : console.warn;\n logFunction(\n `Error in handler ${handler.constructor.name}, handleAgentAction: ${err}`\n );\n if (handler.raiseError) {\n throw err;\n }\n }\n }\n }, handler.awaitHandlers)\n )\n );\n }\n\n async handleAgentEnd(action: AgentFinish): Promise<void> {\n await Promise.all(\n this.handlers.map((handler) =>\n consumeCallback(async () => {\n if (!handler.ignoreAgent) {\n try {\n await handler.handleAgentEnd?.(\n action,\n this.runId,\n this._parentRunId,\n this.tags\n );\n } catch (err) {\n const logFunction = handler.raiseError\n ? console.error\n : console.warn;\n logFunction(\n `Error in handler ${handler.constructor.name}, handleAgentEnd: ${err}`\n );\n if (handler.raiseError) {\n throw err;\n }\n }\n }\n }, handler.awaitHandlers)\n )\n );\n }\n}\n\nexport class CallbackManagerForToolRun\n extends BaseRunManager\n implements BaseCallbackManagerMethods\n{\n getChild(tag?: string): CallbackManager {\n // eslint-disable-next-line @typescript-eslint/no-use-before-define\n const manager = new CallbackManager(this.runId);\n manager.setHandlers(this.inheritableHandlers);\n manager.addTags(this.inheritableTags);\n manager.addMetadata(this.inheritableMetadata);\n if (tag) {\n manager.addTags([tag], false);\n }\n return manager;\n }\n\n async handleToolError(err: Error | unknown): Promise<void> {\n await Promise.all(\n this.handlers.map((handler) =>\n consumeCallback(async () => {\n if (!handler.ignoreAgent) {\n try {\n await handler.handleToolError?.(\n err,\n this.runId,\n this._parentRunId,\n this.tags\n );\n } catch (err) {\n const logFunction = handler.raiseError\n ? console.error\n : console.warn;\n logFunction(\n `Error in handler ${handler.constructor.name}, handleToolError: ${err}`\n );\n if (handler.raiseError) {\n throw err;\n }\n }\n }\n }, handler.awaitHandlers)\n )\n );\n }\n\n // eslint-disable-next-line @typescript-eslint/no-explicit-any\n async handleToolEnd(output: any): Promise<void> {\n await Promise.all(\n this.handlers.map((handler) =>\n consumeCallback(async () => {\n if (!handler.ignoreAgent) {\n try {\n await handler.handleToolEnd?.(\n output,\n this.runId,\n this._parentRunId,\n this.tags\n );\n } catch (err) {\n const logFunction = handler.raiseError\n ? console.error\n : console.warn;\n logFunction(\n `Error in handler ${handler.constructor.name}, handleToolEnd: ${err}`\n );\n if (handler.raiseError) {\n throw err;\n }\n }\n }\n }, handler.awaitHandlers)\n )\n );\n }\n}\n\n/**\n * @example\n * ```typescript\n * const prompt = PromptTemplate.fromTemplate(\"What is the answer to {question}?\");\n *\n * // Example of using LLMChain with OpenAI and a simple prompt\n * const chain = new LLMChain({\n * llm: new ChatOpenAI({ model: \"gpt-4o-mini\", temperature: 0.9 }),\n * prompt,\n * });\n *\n * // Running the chain with a single question\n * const result = await chain.call({\n * question: \"What is the airspeed velocity of an unladen swallow?\",\n * });\n * console.log(\"The answer is:\", result);\n * ```\n */\nexport class CallbackManager\n extends BaseCallbackManager\n implements BaseCallbackManagerMethods\n{\n handlers: BaseCallbackHandler[] = [];\n\n inheritableHandlers: BaseCallbackHandler[] = [];\n\n tags: string[] = [];\n\n inheritableTags: string[] = [];\n\n metadata: Record<string, unknown> = {};\n\n inheritableMetadata: Record<string, unknown> = {};\n\n name = \"callback_manager\";\n\n public _parentRunId?: string;\n\n constructor(\n parentRunId?: string,\n options?: {\n handlers?: BaseCallbackHandler[];\n inheritableHandlers?: BaseCallbackHandler[];\n tags?: string[];\n inheritableTags?: string[];\n metadata?: Record<string, unknown>;\n inheritableMetadata?: Record<string, unknown>;\n }\n ) {\n super();\n this.handlers = options?.handlers ?? this.handlers;\n this.inheritableHandlers =\n options?.inheritableHandlers ?? this.inheritableHandlers;\n this.tags = options?.tags ?? this.tags;\n this.inheritableTags = options?.inheritableTags ?? this.inheritableTags;\n this.metadata = options?.metadata ?? this.metadata;\n this.inheritableMetadata =\n options?.inheritableMetadata ?? this.inheritableMetadata;\n this._parentRunId = parentRunId;\n }\n\n /**\n * Gets the parent run ID, if any.\n *\n * @returns The parent run ID.\n */\n getParentRunId() {\n return this._parentRunId;\n }\n\n async handleLLMStart(\n llm: Serialized,\n prompts: string[],\n runId: string | undefined = undefined,\n _parentRunId: string | undefined = undefined,\n extraParams: Record<string, unknown> | undefined = undefined,\n _tags: string[] | undefined = undefined,\n _metadata: Record<string, unknown> | undefined = undefined,\n runName: string | undefined = undefined\n ): Promise<CallbackManagerForLLMRun[]> {\n return Promise.all(\n prompts.map(async (prompt, idx) => {\n // Can't have duplicate runs with the same run ID (if provided)\n const runId_ = idx === 0 && runId ? runId : uuidv4();\n\n await Promise.all(\n this.handlers.map((handler) => {\n if (handler.ignoreLLM) {\n return;\n }\n if (isBaseTracer(handler)) {\n // Create and add run to the run map.\n // We do this synchronously to avoid race conditions\n // when callbacks are backgrounded.\n handler._createRunForLLMStart(\n llm,\n [prompt],\n runId_,\n this._parentRunId,\n extraParams,\n this.tags,\n this.metadata,\n runName\n );\n }\n return consumeCallback(async () => {\n try {\n await handler.handleLLMStart?.(\n llm,\n [prompt],\n runId_,\n this._parentRunId,\n extraParams,\n this.tags,\n this.metadata,\n runName\n );\n } catch (err) {\n const logFunction = handler.raiseError\n ? console.error\n : console.warn;\n logFunction(\n `Error in handler ${handler.constructor.name}, handleLLMStart: ${err}`\n );\n if (handler.raiseError) {\n throw err;\n }\n }\n }, handler.awaitHandlers);\n })\n );\n\n return new CallbackManagerForLLMRun(\n runId_,\n this.handlers,\n this.inheritableHandlers,\n this.tags,\n this.inheritableTags,\n this.metadata,\n this.inheritableMetadata,\n this._parentRunId\n );\n })\n );\n }\n\n async handleChatModelStart(\n llm: Serialized,\n messages: BaseMessage[][],\n runId: string | undefined = undefined,\n _parentRunId: string | undefined = undefined,\n extraParams: Record<string, unknown> | undefined = undefined,\n _tags: string[] | undefined = undefined,\n _metadata: Record<string, unknown> | undefined = undefined,\n runName: string | undefined = undefined\n ): Promise<CallbackManagerForLLMRun[]> {\n return Promise.all(\n messages.map(async (messageGroup, idx) => {\n // Can't have duplicate runs with the same run ID (if provided)\n const runId_ = idx === 0 && runId ? runId : uuidv4();\n\n await Promise.all(\n this.handlers.map((handler) => {\n if (handler.ignoreLLM) {\n return;\n }\n if (isBaseTracer(handler)) {\n // Create and add run to the run map.\n // We do this synchronously to avoid race conditions\n // when callbacks are backgrounded.\n handler._createRunForChatModelStart(\n llm,\n [messageGroup],\n runId_,\n this._parentRunId,\n extraParams,\n this.tags,\n this.metadata,\n runName\n );\n }\n return consumeCallback(async () => {\n try {\n if (handler.handleChatModelStart) {\n await handler.handleChatModelStart?.(\n llm,\n [messageGroup],\n runId_,\n this._parentRunId,\n extraParams,\n this.tags,\n this.metadata,\n runName\n );\n } else if (handler.handleLLMStart) {\n const messageString = getBufferString(messageGroup);\n await handler.handleLLMStart?.(\n llm,\n [messageString],\n runId_,\n this._parentRunId,\n extraParams,\n this.tags,\n this.metadata,\n runName\n );\n }\n } catch (err) {\n const logFunction = handler.raiseError\n ? console.error\n : console.warn;\n logFunction(\n `Error in handler ${handler.constructor.name}, handleLLMStart: ${err}`\n );\n if (handler.raiseError) {\n throw err;\n }\n }\n }, handler.awaitHandlers);\n })\n );\n\n return new CallbackManagerForLLMRun(\n runId_,\n this.handlers,\n this.inheritableHandlers,\n this.tags,\n this.inheritableTags,\n this.metadata,\n this.inheritableMetadata,\n this._parentRunId\n );\n })\n );\n }\n\n async handleChainStart(\n chain: Serialized,\n inputs: ChainValues,\n runId = uuidv4(),\n runType: string | undefined = undefined,\n _tags: string[] | undefined = undefined,\n _metadata: Record<string, unknown> | undefined = undefined,\n runName: string | undefined = undefined\n ): Promise<CallbackManagerForChainRun> {\n await Promise.all(\n this.handlers.map((handler) => {\n if (handler.ignoreChain) {\n return;\n }\n if (isBaseTracer(handler)) {\n // Create and add run to the run map.\n // We do this synchronously to avoid race conditions\n // when callbacks are backgrounded.\n handler._createRunForChainStart(\n chain,\n inputs,\n runId,\n this._parentRunId,\n this.tags,\n this.metadata,\n runType,\n runName\n );\n }\n return consumeCallback(async () => {\n try {\n await handler.handleChainStart?.(\n chain,\n inputs,\n runId,\n this._parentRunId,\n this.tags,\n this.metadata,\n runType,\n runName\n );\n } catch (err) {\n const logFunction = handler.raiseError\n ? console.error\n : console.warn;\n logFunction(\n `Error in handler ${handler.constructor.name}, handleChainStart: ${err}`\n );\n if (handler.raiseError) {\n throw err;\n }\n }\n }, handler.awaitHandlers);\n })\n );\n return new CallbackManagerForChainRun(\n runId,\n this.handlers,\n this.inheritableHandlers,\n this.tags,\n this.inheritableTags,\n this.metadata,\n this.inheritableMetadata,\n this._parentRunId\n );\n }\n\n async handleToolStart(\n tool: Serialized,\n input: string,\n runId = uuidv4(),\n _parentRunId: string | undefined = undefined,\n _tags: string[] | undefined = undefined,\n _metadata: Record<string, unknown> | undefined = undefined,\n runName: string | undefined = undefined\n ): Promise<CallbackManagerForToolRun> {\n await Promise.all(\n this.handlers.map((handler) => {\n if (handler.ignoreAgent) {\n return;\n }\n if (isBaseTracer(handler)) {\n // Create and add run to the run map.\n // We do this synchronously to avoid race conditions\n // when callbacks are backgrounded.\n handler._createRunForToolStart(\n tool,\n input,\n runId,\n this._parentRunId,\n this.tags,\n this.metadata,\n runName\n );\n }\n return consumeCallback(async () => {\n try {\n await handler.handleToolStart?.(\n tool,\n input,\n runId,\n this._parentRunId,\n this.tags,\n this.metadata,\n runName\n );\n } catch (err) {\n const logFunction = handler.raiseError\n ? console.error\n : console.warn;\n logFunction(\n `Error in handler ${handler.constructor.name}, handleToolStart: ${err}`\n );\n if (handler.raiseError) {\n throw err;\n }\n }\n }, handler.awaitHandlers);\n })\n );\n return new CallbackManagerForToolRun(\n runId,\n this.handlers,\n this.inheritableHandlers,\n this.tags,\n this.inheritableTags,\n this.metadata,\n this.inheritableMetadata,\n this._parentRunId\n );\n }\n\n async handleRetrieverStart(\n retriever: Serialized,\n query: string,\n runId: string = uuidv4(),\n _parentRunId: string | undefined = undefined,\n _tags: string[] | undefined = undefined,\n _metadata: Record<string, unknown> | undefined = undefined,\n runName: string | undefined = undefined\n ): Promise<CallbackManagerForRetrieverRun> {\n await Promise.all(\n this.handlers.map((handler) => {\n if (handler.ignoreRetriever) {\n return;\n }\n if (isBaseTracer(handler)) {\n // Create and add run to the run map.\n // We do this synchronously to avoid race conditions\n // when callbacks are backgrounded.\n handler._createRunForRetrieverStart(\n retriever,\n query,\n runId,\n this._parentRunId,\n this.tags,\n this.metadata,\n runName\n );\n }\n return consumeCallback(async () => {\n try {\n await handler.handleRetrieverStart?.(\n retriever,\n query,\n runId,\n this._parentRunId,\n this.tags,\n this.metadata,\n runName\n );\n } catch (err) {\n const logFunction = handler.raiseError\n ? console.error\n : console.warn;\n logFunction(\n `Error in handler ${handler.constructor.name}, handleRetrieverStart: ${err}`\n );\n if (handler.raiseError) {\n throw err;\n }\n }\n }, handler.awaitHandlers);\n })\n );\n return new CallbackManagerForRetrieverRun(\n runId,\n this.handlers,\n this.inheritableHandlers,\n this.tags,\n this.inheritableTags,\n this.metadata,\n this.inheritableMetadata,\n this._parentRunId\n );\n }\n\n async handleCustomEvent?(\n eventName: string,\n // eslint-disable-next-line @typescript-eslint/no-explicit-any\n data: any,\n runId: string,\n _tags?: string[],\n // eslint-disable-next-line @typescript-eslint/no-explicit-any\n _metadata?: Record<string, any>\n ): // eslint-disable-next-line @typescript-eslint/no-explicit-any\n Promise<any> {\n await Promise.all(\n this.handlers.map((handler) =>\n consumeCallback(async () => {\n if (!handler.ignoreCustomEvent) {\n try {\n await handler.handleCustomEvent?.(\n eventName,\n data,\n runId,\n this.tags,\n this.metadata\n );\n } catch (err) {\n const logFunction = handler.raiseError\n ? console.error\n : console.warn;\n logFunction(\n `Error in handler ${handler.constructor.name}, handleCustomEvent: ${err}`\n );\n if (handler.raiseError) {\n throw err;\n }\n }\n }\n }, handler.awaitHandlers)\n )\n );\n }\n\n addHandler(handler: BaseCallbackHandler, inherit = true): void {\n this.handlers.push(handler);\n if (inherit) {\n this.inheritableHandlers.push(handler);\n }\n }\n\n removeHandler(handler: BaseCallbackHandler): void {\n this.handlers = this.handlers.filter((_handler) => _handler !== handler);\n this.inheritableHandlers = this.inheritableHandlers.filter(\n (_handler) => _handler !== handler\n );\n }\n\n setHandlers(handlers: BaseCallbackHandler[], inherit = true): void {\n this.handlers = [];\n this.inheritableHandlers = [];\n for (const handler of handlers) {\n this.addHandler(handler, inherit);\n }\n }\n\n addTags(tags: string[], inherit = true): void {\n this.removeTags(tags); // Remove duplicates\n this.tags.push(...tags);\n if (inherit) {\n this.inheritableTags.push(...tags);\n }\n }\n\n removeTags(tags: string[]): void {\n this.tags = this.tags.filter((tag) => !tags.includes(tag));\n this.inheritableTags = this.inheritableTags.filter(\n (tag) => !tags.includes(tag)\n );\n }\n\n addMetadata(metadata: Record<string, unknown>, inherit = true): void {\n this.metadata = { ...this.metadata, ...metadata };\n if (inherit) {\n this.inheritableMetadata = { ...this.inheritableMetadata, ...metadata };\n }\n }\n\n removeMetadata(metadata: Record<string, unknown>): void {\n for (const key of Object.keys(metadata)) {\n delete this.metadata[key];\n delete this.inheritableMetadata[key];\n }\n }\n\n copy(\n additionalHandlers: BaseCallbackHandler[] = [],\n inherit = true\n ): CallbackManager {\n const manager = new CallbackManager(this._parentRunId);\n for (const handler of this.handlers) {\n const inheritable = this.inheritableHandlers.includes(handler);\n manager.addHandler(handler, inheritable);\n }\n for (const tag of this.tags) {\n const inheritable = this.inheritableTags.includes(tag);\n manager.addTags([tag], inheritable);\n }\n for (const key of Object.keys(this.metadata)) {\n const inheritable = Object.keys(this.inheritableMetadata).includes(key);\n manager.addMetadata({ [key]: this.metadata[key] }, inheritable);\n }\n for (const handler of additionalHandlers) {\n if (\n // Prevent multiple copies of console_callback_handler\n manager.handlers\n .filter((h) => h.name === \"console_callback_handler\")\n .some((h) => h.name === handler.name)\n ) {\n continue;\n }\n manager.addHandler(handler, inherit);\n }\n return manager;\n }\n\n static fromHandlers(handlers: CallbackHandlerMethods) {\n class Handler extends BaseCallbackHandler {\n name = uuidv4();\n\n constructor() {\n super();\n Object.assign(this, handlers);\n }\n }\n\n const manager = new this();\n manager.addHandler(new Handler());\n return manager;\n }\n\n static configure(\n inheritableHandlers?: Callbacks,\n localHandlers?: Callbacks,\n inheritableTags?: string[],\n localTags?: string[],\n inheritableMetadata?: Record<string, unknown>,\n localMetadata?: Record<string, unknown>,\n options?: CallbackManagerOptions\n ): CallbackManager | undefined {\n return this._configureSync(\n inheritableHandlers,\n localHandlers,\n inheritableTags,\n localTags,\n inheritableMetadata,\n localMetadata,\n options\n );\n }\n\n // TODO: Deprecate async method in favor of this one.\n static _configureSync(\n inheritableHandlers?: Callbacks,\n localHandlers?: Callbacks,\n inheritableTags?: string[],\n localTags?: string[],\n inheritableMetadata?: Record<string, unknown>,\n localMetadata?: Record<string, unknown>,\n options?: CallbackManagerOptions\n ) {\n let callbackManager: CallbackManager | undefined;\n if (inheritableHandlers || localHandlers) {\n if (Array.isArray(inheritableHandlers) || !inheritableHandlers) {\n callbackManager = new CallbackManager();\n callbackManager.setHandlers(\n inheritableHandlers?.map(ensureHandler) ?? [],\n true\n );\n } else {\n callbackManager = inheritableHandlers;\n }\n\n callbackManager = callbackManager.copy(\n Array.isArray(localHandlers)\n ? localHandlers.map(ensureHandler)\n : localHandlers?.handlers,\n false\n );\n }\n\n const verboseEnabled =\n getEnvironmentVariable(\"LANGCHAIN_VERBOSE\") === \"true\" ||\n options?.verbose;\n\n const tracingV2Enabled =\n LangChainTracer.getTraceableRunTree()?.tracingEnabled ||\n isTracingEnabled();\n\n const tracingEnabled =\n tracingV2Enabled ||\n (getEnvironmentVariable(\"LANGCHAIN_TRACING\") ?? false);\n if (verboseEnabled || tracingEnabled) {\n if (!callbackManager) {\n callbackManager = new CallbackManager();\n }\n if (\n verboseEnabled &&\n !callbackManager.handlers.some(\n (handler) => handler.name === ConsoleCallbackHandler.prototype.name\n )\n ) {\n const consoleHandler = new ConsoleCallbackHandler();\n callbackManager.addHandler(consoleHandler, true);\n }\n if (\n tracingEnabled &&\n !callbackManager.handlers.some(\n (handler) => handler.name === \"langchain_tracer\"\n )\n ) {\n if (tracingV2Enabled) {\n const tracerV2 = new LangChainTracer();\n callbackManager.addHandler(tracerV2, true);\n }\n }\n if (tracingV2Enabled) {\n // handoff between langchain and langsmith/traceable\n // override the parent run ID\n const implicitRunTree = LangChainTracer.getTraceableRunTree();\n if (implicitRunTree && callbackManager._parentRunId === undefined) {\n callbackManager._parentRunId = implicitRunTree.id;\n const tracerV2 = callbackManager.handlers.find(\n (handler) => handler.name === \"langchain_tracer\"\n ) as LangChainTracer | undefined;\n tracerV2?.updateFromRunTree(implicitRunTree);\n }\n }\n }\n\n for (const {\n contextVar,\n inheritable = true,\n handlerClass,\n envVar,\n } of _getConfigureHooks()) {\n const createIfNotInContext =\n envVar && getEnvironmentVariable(envVar) === \"true\" && handlerClass;\n let handler: BaseCallbackHandler | undefined;\n const contextVarValue =\n contextVar !== undefined ? getContextVariable(contextVar) : undefined;\n if (contextVarValue && isBaseCallbackHandler(contextVarValue)) {\n handler = contextVarValue;\n } else if (createIfNotInContext) {\n // eslint-disable-next-line @typescript-eslint/no-explicit-any\n handler = new (handlerClass as any)({});\n }\n if (handler !== undefined) {\n if (!callbackManager) {\n callbackManager = new CallbackManager();\n }\n\n if (!callbackManager.handlers.some((h) => h.name === handler!.name)) {\n callbackManager.addHandler(handler, inheritable);\n }\n }\n }\n\n if (inheritableTags || localTags) {\n if (callbackManager) {\n callbackManager.addTags(inheritableTags ?? []);\n callbackManager.addTags(localTags ?? [], false);\n }\n }\n if (inheritableMetadata || localMetadata) {\n if (callbackManager) {\n callbackManager.addMetadata(inheritableMetadata ?? {});\n callbackManager.addMetadata(localMetadata ?? {}, false);\n }\n }\n\n return callbackManager;\n }\n}\n\nexport function ensureHandler(\n handler: BaseCallbackHandler | CallbackHandlerMethods\n): BaseCallbackHandler {\n if (\"name\" in handler) {\n return handler;\n }\n\n return BaseCallbackHandler.fromMethods(handler);\n}\n"],"mappings":"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"}
|
package/dist/chat_history.cjs
CHANGED
|
@@ -43,10 +43,6 @@ var BaseListChatMessageHistory = class extends require_load_serializable.Seriali
|
|
|
43
43
|
addUserMessage(message) {
|
|
44
44
|
return this.addMessage(new require_human.HumanMessage(message));
|
|
45
45
|
}
|
|
46
|
-
/** @deprecated Use addAIMessage instead */
|
|
47
|
-
addAIChatMessage(message) {
|
|
48
|
-
return this.addMessage(new require_ai.AIMessage(message));
|
|
49
|
-
}
|
|
50
46
|
/**
|
|
51
47
|
* This is a convenience method for adding an AI message string to the store.
|
|
52
48
|
* Please note that this is a convenience method. Code should favor the bulk
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"chat_history.cjs","names":["Serializable","messages: BaseMessage[]","message: string","HumanMessage","AIMessage","messages?: BaseMessage[]","message: BaseMessage"],"sources":["../src/chat_history.ts"],"sourcesContent":["import { Serializable } from \"./load/serializable.js\";\nimport { type BaseMessage, HumanMessage, AIMessage } from \"./messages/index.js\";\n\n// TODO: Combine into one class for 0.2\n\n/**\n * Base class for all chat message histories. All chat message histories\n * should extend this class.\n */\nexport abstract class BaseChatMessageHistory extends Serializable {\n public abstract getMessages(): Promise<BaseMessage[]>;\n\n public abstract addMessage(message: BaseMessage): Promise<void>;\n\n public abstract addUserMessage(message: string): Promise<void>;\n\n public abstract
|
|
1
|
+
{"version":3,"file":"chat_history.cjs","names":["Serializable","messages: BaseMessage[]","message: string","HumanMessage","AIMessage","messages?: BaseMessage[]","message: BaseMessage"],"sources":["../src/chat_history.ts"],"sourcesContent":["import { Serializable } from \"./load/serializable.js\";\nimport { type BaseMessage, HumanMessage, AIMessage } from \"./messages/index.js\";\n\n// TODO: Combine into one class for 0.2\n\n/**\n * Base class for all chat message histories. All chat message histories\n * should extend this class.\n */\nexport abstract class BaseChatMessageHistory extends Serializable {\n public abstract getMessages(): Promise<BaseMessage[]>;\n\n public abstract addMessage(message: BaseMessage): Promise<void>;\n\n public abstract addUserMessage(message: string): Promise<void>;\n\n public abstract addAIMessage(message: string): Promise<void>;\n\n /**\n * Add a list of messages.\n *\n * Implementations should override this method to handle bulk addition of messages\n * in an efficient manner to avoid unnecessary round-trips to the underlying store.\n *\n * @param messages - A list of BaseMessage objects to store.\n */\n public async addMessages(messages: BaseMessage[]): Promise<void> {\n for (const message of messages) {\n await this.addMessage(message);\n }\n }\n\n public abstract clear(): Promise<void>;\n}\n\n/**\n * Base class for all list chat message histories. All list chat message\n * histories should extend this class.\n */\nexport abstract class BaseListChatMessageHistory extends Serializable {\n /** Returns a list of messages stored in the store. */\n public abstract getMessages(): Promise<BaseMessage[]>;\n\n /**\n * Add a message object to the store.\n */\n public abstract addMessage(message: BaseMessage): Promise<void>;\n\n /**\n * This is a convenience method for adding a human message string to the store.\n * Please note that this is a convenience method. Code should favor the\n * bulk addMessages interface instead to save on round-trips to the underlying\n * persistence layer.\n * This method may be deprecated in a future release.\n */\n public addUserMessage(message: string): Promise<void> {\n return this.addMessage(new HumanMessage(message));\n }\n\n /**\n * This is a convenience method for adding an AI message string to the store.\n * Please note that this is a convenience method. Code should favor the bulk\n * addMessages interface instead to save on round-trips to the underlying\n * persistence layer.\n * This method may be deprecated in a future release.\n */\n public addAIMessage(message: string): Promise<void> {\n return this.addMessage(new AIMessage(message));\n }\n\n /**\n * Add a list of messages.\n *\n * Implementations should override this method to handle bulk addition of messages\n * in an efficient manner to avoid unnecessary round-trips to the underlying store.\n *\n * @param messages - A list of BaseMessage objects to store.\n */\n public async addMessages(messages: BaseMessage[]): Promise<void> {\n for (const message of messages) {\n await this.addMessage(message);\n }\n }\n\n /**\n * Remove all messages from the store.\n */\n public clear(): Promise<void> {\n throw new Error(\"Not implemented.\");\n }\n}\n\n/**\n * Class for storing chat message history in-memory. It extends the\n * BaseListChatMessageHistory class and provides methods to get, add, and\n * clear messages.\n */\nexport class InMemoryChatMessageHistory extends BaseListChatMessageHistory {\n lc_namespace = [\"langchain\", \"stores\", \"message\", \"in_memory\"];\n\n private messages: BaseMessage[] = [];\n\n constructor(messages?: BaseMessage[]) {\n super(...arguments);\n this.messages = messages ?? [];\n }\n\n /**\n * Method to get all the messages stored in the ChatMessageHistory\n * instance.\n * @returns Array of stored BaseMessage instances.\n */\n async getMessages(): Promise<BaseMessage[]> {\n return this.messages;\n }\n\n /**\n * Method to add a new message to the ChatMessageHistory instance.\n * @param message The BaseMessage instance to add.\n * @returns A promise that resolves when the message has been added.\n */\n async addMessage(message: BaseMessage) {\n this.messages.push(message);\n }\n\n /**\n * Method to clear all the messages from the ChatMessageHistory instance.\n * @returns A promise that resolves when all messages have been cleared.\n */\n async clear() {\n this.messages = [];\n }\n}\n"],"mappings":";;;;;;;;;;;;;;;;;AASA,IAAsB,yBAAtB,cAAqDA,uCAAa;;;;;;;;;CAiBhE,MAAa,YAAYC,UAAwC;AAC/D,OAAK,MAAM,WAAW,UACpB,MAAM,KAAK,WAAW,QAAQ;CAEjC;AAGF;;;;;AAMD,IAAsB,6BAAtB,cAAyDD,uCAAa;;;;;;;;CAgBpE,AAAO,eAAeE,SAAgC;AACpD,SAAO,KAAK,WAAW,IAAIC,2BAAa,SAAS;CAClD;;;;;;;;CASD,AAAO,aAAaD,SAAgC;AAClD,SAAO,KAAK,WAAW,IAAIE,qBAAU,SAAS;CAC/C;;;;;;;;;CAUD,MAAa,YAAYH,UAAwC;AAC/D,OAAK,MAAM,WAAW,UACpB,MAAM,KAAK,WAAW,QAAQ;CAEjC;;;;CAKD,AAAO,QAAuB;AAC5B,QAAM,IAAI,MAAM;CACjB;AACF;;;;;;AAOD,IAAa,6BAAb,cAAgD,2BAA2B;CACzE,eAAe;EAAC;EAAa;EAAU;EAAW;CAAY;CAE9D,AAAQ,WAA0B,CAAE;CAEpC,YAAYI,UAA0B;EACpC,MAAM,GAAG,UAAU;EACnB,KAAK,WAAW,YAAY,CAAE;CAC/B;;;;;;CAOD,MAAM,cAAsC;AAC1C,SAAO,KAAK;CACb;;;;;;CAOD,MAAM,WAAWC,SAAsB;EACrC,KAAK,SAAS,KAAK,QAAQ;CAC5B;;;;;CAMD,MAAM,QAAQ;EACZ,KAAK,WAAW,CAAE;CACnB;AACF"}
|
package/dist/chat_history.d.cts
CHANGED
|
@@ -12,7 +12,7 @@ declare abstract class BaseChatMessageHistory extends Serializable {
|
|
|
12
12
|
abstract getMessages(): Promise<BaseMessage[]>;
|
|
13
13
|
abstract addMessage(message: BaseMessage): Promise<void>;
|
|
14
14
|
abstract addUserMessage(message: string): Promise<void>;
|
|
15
|
-
abstract
|
|
15
|
+
abstract addAIMessage(message: string): Promise<void>;
|
|
16
16
|
/**
|
|
17
17
|
* Add a list of messages.
|
|
18
18
|
*
|
|
@@ -43,8 +43,6 @@ declare abstract class BaseListChatMessageHistory extends Serializable {
|
|
|
43
43
|
* This method may be deprecated in a future release.
|
|
44
44
|
*/
|
|
45
45
|
addUserMessage(message: string): Promise<void>;
|
|
46
|
-
/** @deprecated Use addAIMessage instead */
|
|
47
|
-
addAIChatMessage(message: string): Promise<void>;
|
|
48
46
|
/**
|
|
49
47
|
* This is a convenience method for adding an AI message string to the store.
|
|
50
48
|
* Please note that this is a convenience method. Code should favor the bulk
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"chat_history.d.cts","names":["Serializable","BaseMessage","BaseChatMessageHistory","Promise","BaseListChatMessageHistory","InMemoryChatMessageHistory"],"sources":["../src/chat_history.d.ts"],"sourcesContent":["import { Serializable } from \"./load/serializable.js\";\nimport { type BaseMessage } from \"./messages/index.js\";\n// TODO: Combine into one class for 0.2\n/**\n * Base class for all chat message histories. All chat message histories\n * should extend this class.\n */\nexport declare abstract class BaseChatMessageHistory extends Serializable {\n abstract getMessages(): Promise<BaseMessage[]>;\n abstract addMessage(message: BaseMessage): Promise<void>;\n abstract addUserMessage(message: string): Promise<void>;\n abstract
|
|
1
|
+
{"version":3,"file":"chat_history.d.cts","names":["Serializable","BaseMessage","BaseChatMessageHistory","Promise","BaseListChatMessageHistory","InMemoryChatMessageHistory"],"sources":["../src/chat_history.d.ts"],"sourcesContent":["import { Serializable } from \"./load/serializable.js\";\nimport { type BaseMessage } from \"./messages/index.js\";\n// TODO: Combine into one class for 0.2\n/**\n * Base class for all chat message histories. All chat message histories\n * should extend this class.\n */\nexport declare abstract class BaseChatMessageHistory extends Serializable {\n abstract getMessages(): Promise<BaseMessage[]>;\n abstract addMessage(message: BaseMessage): Promise<void>;\n abstract addUserMessage(message: string): Promise<void>;\n abstract addAIMessage(message: string): Promise<void>;\n /**\n * Add a list of messages.\n *\n * Implementations should override this method to handle bulk addition of messages\n * in an efficient manner to avoid unnecessary round-trips to the underlying store.\n *\n * @param messages - A list of BaseMessage objects to store.\n */\n addMessages(messages: BaseMessage[]): Promise<void>;\n abstract clear(): Promise<void>;\n}\n/**\n * Base class for all list chat message histories. All list chat message\n * histories should extend this class.\n */\nexport declare abstract class BaseListChatMessageHistory extends Serializable {\n /** Returns a list of messages stored in the store. */\n abstract getMessages(): Promise<BaseMessage[]>;\n /**\n * Add a message object to the store.\n */\n abstract addMessage(message: BaseMessage): Promise<void>;\n /**\n * This is a convenience method for adding a human message string to the store.\n * Please note that this is a convenience method. Code should favor the\n * bulk addMessages interface instead to save on round-trips to the underlying\n * persistence layer.\n * This method may be deprecated in a future release.\n */\n addUserMessage(message: string): Promise<void>;\n /**\n * This is a convenience method for adding an AI message string to the store.\n * Please note that this is a convenience method. Code should favor the bulk\n * addMessages interface instead to save on round-trips to the underlying\n * persistence layer.\n * This method may be deprecated in a future release.\n */\n addAIMessage(message: string): Promise<void>;\n /**\n * Add a list of messages.\n *\n * Implementations should override this method to handle bulk addition of messages\n * in an efficient manner to avoid unnecessary round-trips to the underlying store.\n *\n * @param messages - A list of BaseMessage objects to store.\n */\n addMessages(messages: BaseMessage[]): Promise<void>;\n /**\n * Remove all messages from the store.\n */\n clear(): Promise<void>;\n}\n/**\n * Class for storing chat message history in-memory. It extends the\n * BaseListChatMessageHistory class and provides methods to get, add, and\n * clear messages.\n */\nexport declare class InMemoryChatMessageHistory extends BaseListChatMessageHistory {\n lc_namespace: string[];\n private messages;\n constructor(messages?: BaseMessage[]);\n /**\n * Method to get all the messages stored in the ChatMessageHistory\n * instance.\n * @returns Array of stored BaseMessage instances.\n */\n getMessages(): Promise<BaseMessage[]>;\n /**\n * Method to add a new message to the ChatMessageHistory instance.\n * @param message The BaseMessage instance to add.\n * @returns A promise that resolves when the message has been added.\n */\n addMessage(message: BaseMessage): Promise<void>;\n /**\n * Method to clear all the messages from the ChatMessageHistory instance.\n * @returns A promise that resolves when all messages have been cleared.\n */\n clear(): Promise<void>;\n}\n"],"mappings":";;;;;;;AAOA;;;AAC4BG,uBADED,sBAAAA,SAA+BF,YAAAA,CACjCG;EAAO,SACFF,WAAAA,CAAAA,CAAAA,EADLE,OACKF,CADGA,WACHA,EAAAA,CAAAA;EAAW,SAAGE,UAAAA,CAAAA,OAAAA,EAAdF,WAAcE,CAAAA,EAAAA,OAAAA,CAAAA,IAAAA,CAAAA;EAAO,SACRA,cAAAA,CAAAA,OAAAA,EAAAA,MAAAA,CAAAA,EAAAA,OAAAA,CAAAA,IAAAA,CAAAA;EAAO,SACTA,YAAAA,CAAAA,OAAAA,EAAAA,MAAAA,CAAAA,EAAAA,OAAAA,CAAAA,IAAAA,CAAAA;EAAO;;;;AAJsB;AAoBzE;;;EAE+C,WAAnBA,CAAAA,QAAAA,EATFF,WASEE,EAAAA,CAAAA,EATcA,OASdA,CAAAA,IAAAA,CAAAA;EAAO,SAIFF,KAAAA,CAAAA,CAAAA,EAZXE,OAYWF,CAAAA,IAAAA,CAAAA;;;;;;AA6BpBE,uBAnCiBC,0BAAAA,SAAmCJ,YAAAA,CAmCpDG;EAAO;EAnCyD,SAAA,WAAA,CAAA,CAAA,EAEjDA,OAFiD,CAEzCF,WAFyC,EAAA,CAAA;EA0CxDI;;;EAGiB,SAMXJ,UAAAA,CAAAA,OAAAA,EA7CMA,WA6CNA,CAAAA,EA7CoBE,OA6CpBF,CAAAA,IAAAA,CAAAA;EAAW;;;;;AAT4C;;mCA5B7CE;;;;;;;;iCAQFA;;;;;;;;;wBASTF,gBAAgBE;;;;WAI7BA;;;;;;;cAOQE,0BAAAA,SAAmCD,0BAAAA;;;yBAG7BH;;;;;;iBAMRE,QAAQF;;;;;;sBAMHA,cAAcE;;;;;WAKzBA"}
|
package/dist/chat_history.d.ts
CHANGED
|
@@ -12,7 +12,7 @@ declare abstract class BaseChatMessageHistory extends Serializable {
|
|
|
12
12
|
abstract getMessages(): Promise<BaseMessage[]>;
|
|
13
13
|
abstract addMessage(message: BaseMessage): Promise<void>;
|
|
14
14
|
abstract addUserMessage(message: string): Promise<void>;
|
|
15
|
-
abstract
|
|
15
|
+
abstract addAIMessage(message: string): Promise<void>;
|
|
16
16
|
/**
|
|
17
17
|
* Add a list of messages.
|
|
18
18
|
*
|
|
@@ -43,8 +43,6 @@ declare abstract class BaseListChatMessageHistory extends Serializable {
|
|
|
43
43
|
* This method may be deprecated in a future release.
|
|
44
44
|
*/
|
|
45
45
|
addUserMessage(message: string): Promise<void>;
|
|
46
|
-
/** @deprecated Use addAIMessage instead */
|
|
47
|
-
addAIChatMessage(message: string): Promise<void>;
|
|
48
46
|
/**
|
|
49
47
|
* This is a convenience method for adding an AI message string to the store.
|
|
50
48
|
* Please note that this is a convenience method. Code should favor the bulk
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"chat_history.d.ts","names":["Serializable","BaseMessage","BaseChatMessageHistory","Promise","BaseListChatMessageHistory","InMemoryChatMessageHistory"],"sources":["../src/chat_history.d.ts"],"sourcesContent":["import { Serializable } from \"./load/serializable.js\";\nimport { type BaseMessage } from \"./messages/index.js\";\n// TODO: Combine into one class for 0.2\n/**\n * Base class for all chat message histories. All chat message histories\n * should extend this class.\n */\nexport declare abstract class BaseChatMessageHistory extends Serializable {\n abstract getMessages(): Promise<BaseMessage[]>;\n abstract addMessage(message: BaseMessage): Promise<void>;\n abstract addUserMessage(message: string): Promise<void>;\n abstract
|
|
1
|
+
{"version":3,"file":"chat_history.d.ts","names":["Serializable","BaseMessage","BaseChatMessageHistory","Promise","BaseListChatMessageHistory","InMemoryChatMessageHistory"],"sources":["../src/chat_history.d.ts"],"sourcesContent":["import { Serializable } from \"./load/serializable.js\";\nimport { type BaseMessage } from \"./messages/index.js\";\n// TODO: Combine into one class for 0.2\n/**\n * Base class for all chat message histories. All chat message histories\n * should extend this class.\n */\nexport declare abstract class BaseChatMessageHistory extends Serializable {\n abstract getMessages(): Promise<BaseMessage[]>;\n abstract addMessage(message: BaseMessage): Promise<void>;\n abstract addUserMessage(message: string): Promise<void>;\n abstract addAIMessage(message: string): Promise<void>;\n /**\n * Add a list of messages.\n *\n * Implementations should override this method to handle bulk addition of messages\n * in an efficient manner to avoid unnecessary round-trips to the underlying store.\n *\n * @param messages - A list of BaseMessage objects to store.\n */\n addMessages(messages: BaseMessage[]): Promise<void>;\n abstract clear(): Promise<void>;\n}\n/**\n * Base class for all list chat message histories. All list chat message\n * histories should extend this class.\n */\nexport declare abstract class BaseListChatMessageHistory extends Serializable {\n /** Returns a list of messages stored in the store. */\n abstract getMessages(): Promise<BaseMessage[]>;\n /**\n * Add a message object to the store.\n */\n abstract addMessage(message: BaseMessage): Promise<void>;\n /**\n * This is a convenience method for adding a human message string to the store.\n * Please note that this is a convenience method. Code should favor the\n * bulk addMessages interface instead to save on round-trips to the underlying\n * persistence layer.\n * This method may be deprecated in a future release.\n */\n addUserMessage(message: string): Promise<void>;\n /**\n * This is a convenience method for adding an AI message string to the store.\n * Please note that this is a convenience method. Code should favor the bulk\n * addMessages interface instead to save on round-trips to the underlying\n * persistence layer.\n * This method may be deprecated in a future release.\n */\n addAIMessage(message: string): Promise<void>;\n /**\n * Add a list of messages.\n *\n * Implementations should override this method to handle bulk addition of messages\n * in an efficient manner to avoid unnecessary round-trips to the underlying store.\n *\n * @param messages - A list of BaseMessage objects to store.\n */\n addMessages(messages: BaseMessage[]): Promise<void>;\n /**\n * Remove all messages from the store.\n */\n clear(): Promise<void>;\n}\n/**\n * Class for storing chat message history in-memory. It extends the\n * BaseListChatMessageHistory class and provides methods to get, add, and\n * clear messages.\n */\nexport declare class InMemoryChatMessageHistory extends BaseListChatMessageHistory {\n lc_namespace: string[];\n private messages;\n constructor(messages?: BaseMessage[]);\n /**\n * Method to get all the messages stored in the ChatMessageHistory\n * instance.\n * @returns Array of stored BaseMessage instances.\n */\n getMessages(): Promise<BaseMessage[]>;\n /**\n * Method to add a new message to the ChatMessageHistory instance.\n * @param message The BaseMessage instance to add.\n * @returns A promise that resolves when the message has been added.\n */\n addMessage(message: BaseMessage): Promise<void>;\n /**\n * Method to clear all the messages from the ChatMessageHistory instance.\n * @returns A promise that resolves when all messages have been cleared.\n */\n clear(): Promise<void>;\n}\n"],"mappings":";;;;;;;AAOA;;;AAC4BG,uBADED,sBAAAA,SAA+BF,YAAAA,CACjCG;EAAO,SACFF,WAAAA,CAAAA,CAAAA,EADLE,OACKF,CADGA,WACHA,EAAAA,CAAAA;EAAW,SAAGE,UAAAA,CAAAA,OAAAA,EAAdF,WAAcE,CAAAA,EAAAA,OAAAA,CAAAA,IAAAA,CAAAA;EAAO,SACRA,cAAAA,CAAAA,OAAAA,EAAAA,MAAAA,CAAAA,EAAAA,OAAAA,CAAAA,IAAAA,CAAAA;EAAO,SACTA,YAAAA,CAAAA,OAAAA,EAAAA,MAAAA,CAAAA,EAAAA,OAAAA,CAAAA,IAAAA,CAAAA;EAAO;;;;AAJsB;AAoBzE;;;EAE+C,WAAnBA,CAAAA,QAAAA,EATFF,WASEE,EAAAA,CAAAA,EATcA,OASdA,CAAAA,IAAAA,CAAAA;EAAO,SAIFF,KAAAA,CAAAA,CAAAA,EAZXE,OAYWF,CAAAA,IAAAA,CAAAA;;;;;;AA6BpBE,uBAnCiBC,0BAAAA,SAAmCJ,YAAAA,CAmCpDG;EAAO;EAnCyD,SAAA,WAAA,CAAA,CAAA,EAEjDA,OAFiD,CAEzCF,WAFyC,EAAA,CAAA;EA0CxDI;;;EAGiB,SAMXJ,UAAAA,CAAAA,OAAAA,EA7CMA,WA6CNA,CAAAA,EA7CoBE,OA6CpBF,CAAAA,IAAAA,CAAAA;EAAW;;;;;AAT4C;;mCA5B7CE;;;;;;;;iCAQFA;;;;;;;;;wBASTF,gBAAgBE;;;;WAI7BA;;;;;;;cAOQE,0BAAAA,SAAmCD,0BAAAA;;;yBAG7BH;;;;;;iBAMRE,QAAQF;;;;;;sBAMHA,cAAcE;;;;;WAKzBA"}
|
package/dist/chat_history.js
CHANGED
|
@@ -43,10 +43,6 @@ var BaseListChatMessageHistory = class extends Serializable {
|
|
|
43
43
|
addUserMessage(message) {
|
|
44
44
|
return this.addMessage(new HumanMessage(message));
|
|
45
45
|
}
|
|
46
|
-
/** @deprecated Use addAIMessage instead */
|
|
47
|
-
addAIChatMessage(message) {
|
|
48
|
-
return this.addMessage(new AIMessage(message));
|
|
49
|
-
}
|
|
50
46
|
/**
|
|
51
47
|
* This is a convenience method for adding an AI message string to the store.
|
|
52
48
|
* Please note that this is a convenience method. Code should favor the bulk
|
package/dist/chat_history.js.map
CHANGED
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"chat_history.js","names":["messages: BaseMessage[]","message: string","messages?: BaseMessage[]","message: BaseMessage"],"sources":["../src/chat_history.ts"],"sourcesContent":["import { Serializable } from \"./load/serializable.js\";\nimport { type BaseMessage, HumanMessage, AIMessage } from \"./messages/index.js\";\n\n// TODO: Combine into one class for 0.2\n\n/**\n * Base class for all chat message histories. All chat message histories\n * should extend this class.\n */\nexport abstract class BaseChatMessageHistory extends Serializable {\n public abstract getMessages(): Promise<BaseMessage[]>;\n\n public abstract addMessage(message: BaseMessage): Promise<void>;\n\n public abstract addUserMessage(message: string): Promise<void>;\n\n public abstract
|
|
1
|
+
{"version":3,"file":"chat_history.js","names":["messages: BaseMessage[]","message: string","messages?: BaseMessage[]","message: BaseMessage"],"sources":["../src/chat_history.ts"],"sourcesContent":["import { Serializable } from \"./load/serializable.js\";\nimport { type BaseMessage, HumanMessage, AIMessage } from \"./messages/index.js\";\n\n// TODO: Combine into one class for 0.2\n\n/**\n * Base class for all chat message histories. All chat message histories\n * should extend this class.\n */\nexport abstract class BaseChatMessageHistory extends Serializable {\n public abstract getMessages(): Promise<BaseMessage[]>;\n\n public abstract addMessage(message: BaseMessage): Promise<void>;\n\n public abstract addUserMessage(message: string): Promise<void>;\n\n public abstract addAIMessage(message: string): Promise<void>;\n\n /**\n * Add a list of messages.\n *\n * Implementations should override this method to handle bulk addition of messages\n * in an efficient manner to avoid unnecessary round-trips to the underlying store.\n *\n * @param messages - A list of BaseMessage objects to store.\n */\n public async addMessages(messages: BaseMessage[]): Promise<void> {\n for (const message of messages) {\n await this.addMessage(message);\n }\n }\n\n public abstract clear(): Promise<void>;\n}\n\n/**\n * Base class for all list chat message histories. All list chat message\n * histories should extend this class.\n */\nexport abstract class BaseListChatMessageHistory extends Serializable {\n /** Returns a list of messages stored in the store. */\n public abstract getMessages(): Promise<BaseMessage[]>;\n\n /**\n * Add a message object to the store.\n */\n public abstract addMessage(message: BaseMessage): Promise<void>;\n\n /**\n * This is a convenience method for adding a human message string to the store.\n * Please note that this is a convenience method. Code should favor the\n * bulk addMessages interface instead to save on round-trips to the underlying\n * persistence layer.\n * This method may be deprecated in a future release.\n */\n public addUserMessage(message: string): Promise<void> {\n return this.addMessage(new HumanMessage(message));\n }\n\n /**\n * This is a convenience method for adding an AI message string to the store.\n * Please note that this is a convenience method. Code should favor the bulk\n * addMessages interface instead to save on round-trips to the underlying\n * persistence layer.\n * This method may be deprecated in a future release.\n */\n public addAIMessage(message: string): Promise<void> {\n return this.addMessage(new AIMessage(message));\n }\n\n /**\n * Add a list of messages.\n *\n * Implementations should override this method to handle bulk addition of messages\n * in an efficient manner to avoid unnecessary round-trips to the underlying store.\n *\n * @param messages - A list of BaseMessage objects to store.\n */\n public async addMessages(messages: BaseMessage[]): Promise<void> {\n for (const message of messages) {\n await this.addMessage(message);\n }\n }\n\n /**\n * Remove all messages from the store.\n */\n public clear(): Promise<void> {\n throw new Error(\"Not implemented.\");\n }\n}\n\n/**\n * Class for storing chat message history in-memory. It extends the\n * BaseListChatMessageHistory class and provides methods to get, add, and\n * clear messages.\n */\nexport class InMemoryChatMessageHistory extends BaseListChatMessageHistory {\n lc_namespace = [\"langchain\", \"stores\", \"message\", \"in_memory\"];\n\n private messages: BaseMessage[] = [];\n\n constructor(messages?: BaseMessage[]) {\n super(...arguments);\n this.messages = messages ?? [];\n }\n\n /**\n * Method to get all the messages stored in the ChatMessageHistory\n * instance.\n * @returns Array of stored BaseMessage instances.\n */\n async getMessages(): Promise<BaseMessage[]> {\n return this.messages;\n }\n\n /**\n * Method to add a new message to the ChatMessageHistory instance.\n * @param message The BaseMessage instance to add.\n * @returns A promise that resolves when the message has been added.\n */\n async addMessage(message: BaseMessage) {\n this.messages.push(message);\n }\n\n /**\n * Method to clear all the messages from the ChatMessageHistory instance.\n * @returns A promise that resolves when all messages have been cleared.\n */\n async clear() {\n this.messages = [];\n }\n}\n"],"mappings":";;;;;;;;;;;;;;;;;AASA,IAAsB,yBAAtB,cAAqD,aAAa;;;;;;;;;CAiBhE,MAAa,YAAYA,UAAwC;AAC/D,OAAK,MAAM,WAAW,UACpB,MAAM,KAAK,WAAW,QAAQ;CAEjC;AAGF;;;;;AAMD,IAAsB,6BAAtB,cAAyD,aAAa;;;;;;;;CAgBpE,AAAO,eAAeC,SAAgC;AACpD,SAAO,KAAK,WAAW,IAAI,aAAa,SAAS;CAClD;;;;;;;;CASD,AAAO,aAAaA,SAAgC;AAClD,SAAO,KAAK,WAAW,IAAI,UAAU,SAAS;CAC/C;;;;;;;;;CAUD,MAAa,YAAYD,UAAwC;AAC/D,OAAK,MAAM,WAAW,UACpB,MAAM,KAAK,WAAW,QAAQ;CAEjC;;;;CAKD,AAAO,QAAuB;AAC5B,QAAM,IAAI,MAAM;CACjB;AACF;;;;;;AAOD,IAAa,6BAAb,cAAgD,2BAA2B;CACzE,eAAe;EAAC;EAAa;EAAU;EAAW;CAAY;CAE9D,AAAQ,WAA0B,CAAE;CAEpC,YAAYE,UAA0B;EACpC,MAAM,GAAG,UAAU;EACnB,KAAK,WAAW,YAAY,CAAE;CAC/B;;;;;;CAOD,MAAM,cAAsC;AAC1C,SAAO,KAAK;CACb;;;;;;CAOD,MAAM,WAAWC,SAAsB;EACrC,KAAK,SAAS,KAAK,QAAQ;CAC5B;;;;;CAMD,MAAM,QAAQ;EACZ,KAAK,WAAW,CAAE;CACnB;AACF"}
|
|
@@ -8,19 +8,7 @@ require_rolldown_runtime.__export(base_exports, { BaseDocumentLoader: () => Base
|
|
|
8
8
|
* loadAndSplit() method from the DocumentLoader interface. The load()
|
|
9
9
|
* method is left abstract and needs to be implemented by subclasses.
|
|
10
10
|
*/
|
|
11
|
-
var BaseDocumentLoader = class {
|
|
12
|
-
/**
|
|
13
|
-
* @deprecated Use `this.load()` and `splitter.splitDocuments()` individually.
|
|
14
|
-
* Loads the documents and splits them using a specified text splitter.
|
|
15
|
-
* @param textSplitter The TextSplitter instance to use for splitting the loaded documents. Defaults to a RecursiveCharacterTextSplitter instance.
|
|
16
|
-
* @returns A Promise that resolves with an array of Document instances, each split according to the provided TextSplitter.
|
|
17
|
-
*/
|
|
18
|
-
async loadAndSplit(splitter) {
|
|
19
|
-
if (splitter === void 0) throw new Error("You must pass a text splitter to use this method.");
|
|
20
|
-
const docs = await this.load();
|
|
21
|
-
return splitter.invoke(docs);
|
|
22
|
-
}
|
|
23
|
-
};
|
|
11
|
+
var BaseDocumentLoader = class {};
|
|
24
12
|
|
|
25
13
|
//#endregion
|
|
26
14
|
exports.BaseDocumentLoader = BaseDocumentLoader;
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"base.cjs","names":[
|
|
1
|
+
{"version":3,"file":"base.cjs","names":[],"sources":["../../src/document_loaders/base.ts"],"sourcesContent":["import { Document } from \"../documents/document.js\";\n\n/**\n * Interface that defines the methods for loading and splitting documents.\n */\nexport interface DocumentLoader {\n load(): Promise<Document[]>;\n}\n\n/**\n * Abstract class that provides a default implementation for the\n * loadAndSplit() method from the DocumentLoader interface. The load()\n * method is left abstract and needs to be implemented by subclasses.\n */\nexport abstract class BaseDocumentLoader implements DocumentLoader {\n /**\n * Loads the documents.\n * @returns A Promise that resolves with an array of Document instances.\n */\n abstract load(): Promise<Document[]>;\n}\n"],"mappings":";;;;;;;;;;AAcA,IAAsB,qBAAtB,MAAmE,CAMlE"}
|