@langchain/core 1.1.6 → 1.1.8

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.
Files changed (91) hide show
  1. package/CHANGELOG.md +20 -0
  2. package/dist/caches/index.d.ts.map +1 -1
  3. package/dist/callbacks/base.cjs.map +1 -1
  4. package/dist/callbacks/base.d.cts +2 -2
  5. package/dist/callbacks/base.d.cts.map +1 -1
  6. package/dist/callbacks/base.d.ts +2 -2
  7. package/dist/callbacks/base.d.ts.map +1 -1
  8. package/dist/callbacks/base.js.map +1 -1
  9. package/dist/callbacks/manager.cjs +3 -3
  10. package/dist/callbacks/manager.cjs.map +1 -1
  11. package/dist/callbacks/manager.d.cts +1 -1
  12. package/dist/callbacks/manager.d.cts.map +1 -1
  13. package/dist/callbacks/manager.d.ts +1 -1
  14. package/dist/callbacks/manager.d.ts.map +1 -1
  15. package/dist/callbacks/manager.js +3 -3
  16. package/dist/callbacks/manager.js.map +1 -1
  17. package/dist/language_models/chat_models.d.ts.map +1 -1
  18. package/dist/load/import_map.cjs +2 -0
  19. package/dist/load/import_map.cjs.map +1 -1
  20. package/dist/load/import_map.js +2 -0
  21. package/dist/load/import_map.js.map +1 -1
  22. package/dist/load/index.cjs +85 -25
  23. package/dist/load/index.cjs.map +1 -1
  24. package/dist/load/index.d.cts +113 -3
  25. package/dist/load/index.d.cts.map +1 -1
  26. package/dist/load/index.d.ts +113 -3
  27. package/dist/load/index.d.ts.map +1 -1
  28. package/dist/load/index.js +85 -25
  29. package/dist/load/index.js.map +1 -1
  30. package/dist/load/serializable.cjs +6 -1
  31. package/dist/load/serializable.cjs.map +1 -1
  32. package/dist/load/serializable.d.cts +15 -1
  33. package/dist/load/serializable.d.cts.map +1 -1
  34. package/dist/load/serializable.d.ts +15 -1
  35. package/dist/load/serializable.d.ts.map +1 -1
  36. package/dist/load/serializable.js +6 -1
  37. package/dist/load/serializable.js.map +1 -1
  38. package/dist/load/validation.cjs +98 -0
  39. package/dist/load/validation.cjs.map +1 -0
  40. package/dist/load/validation.js +95 -0
  41. package/dist/load/validation.js.map +1 -0
  42. package/dist/messages/base.cjs +1 -0
  43. package/dist/messages/base.cjs.map +1 -1
  44. package/dist/messages/base.d.cts +2 -3
  45. package/dist/messages/base.d.cts.map +1 -1
  46. package/dist/messages/base.d.ts +2 -3
  47. package/dist/messages/base.d.ts.map +1 -1
  48. package/dist/messages/base.js +1 -0
  49. package/dist/messages/base.js.map +1 -1
  50. package/dist/messages/message.cjs.map +1 -1
  51. package/dist/messages/message.d.cts +34 -1
  52. package/dist/messages/message.d.cts.map +1 -1
  53. package/dist/messages/message.d.ts +34 -1
  54. package/dist/messages/message.d.ts.map +1 -1
  55. package/dist/messages/message.js.map +1 -1
  56. package/dist/runnables/base.cjs +1 -1
  57. package/dist/runnables/base.cjs.map +1 -1
  58. package/dist/runnables/base.js +1 -1
  59. package/dist/runnables/base.js.map +1 -1
  60. package/dist/tracers/base.cjs +5 -2
  61. package/dist/tracers/base.cjs.map +1 -1
  62. package/dist/tracers/base.d.cts +1 -1
  63. package/dist/tracers/base.d.cts.map +1 -1
  64. package/dist/tracers/base.d.ts +1 -1
  65. package/dist/tracers/base.d.ts.map +1 -1
  66. package/dist/tracers/base.js +5 -2
  67. package/dist/tracers/base.js.map +1 -1
  68. package/dist/tracers/tracer_langchain.cjs +31 -3
  69. package/dist/tracers/tracer_langchain.cjs.map +1 -1
  70. package/dist/tracers/tracer_langchain.d.cts +8 -7
  71. package/dist/tracers/tracer_langchain.d.cts.map +1 -1
  72. package/dist/tracers/tracer_langchain.d.ts +8 -7
  73. package/dist/tracers/tracer_langchain.d.ts.map +1 -1
  74. package/dist/tracers/tracer_langchain.js +31 -3
  75. package/dist/tracers/tracer_langchain.js.map +1 -1
  76. package/dist/utils/context.cjs +107 -0
  77. package/dist/utils/context.cjs.map +1 -0
  78. package/dist/utils/context.d.cts +44 -0
  79. package/dist/utils/context.d.cts.map +1 -0
  80. package/dist/utils/context.d.ts +44 -0
  81. package/dist/utils/context.d.ts.map +1 -0
  82. package/dist/utils/context.js +101 -0
  83. package/dist/utils/context.js.map +1 -0
  84. package/dist/utils/event_source_parse.d.cts.map +1 -1
  85. package/dist/utils/stream.d.cts.map +1 -1
  86. package/dist/vectorstores.d.cts.map +1 -1
  87. package/package.json +13 -2
  88. package/utils/context.cjs +1 -0
  89. package/utils/context.d.cts +1 -0
  90. package/utils/context.d.ts +1 -0
  91. package/utils/context.js +1 -0
@@ -210,7 +210,7 @@ var BaseTracer = class extends require_callbacks_base.BaseCallbackHandler {
210
210
  * This must sometimes be done synchronously to avoid race conditions
211
211
  * when callbacks are backgrounded, so we expose it as a separate method here.
212
212
  */
213
- _createRunForChainStart(chain, inputs, runId, parentRunId, tags, metadata, runType, name) {
213
+ _createRunForChainStart(chain, inputs, runId, parentRunId, tags, metadata, runType, name, extra) {
214
214
  const execution_order = this._getExecutionOrder(parentRunId);
215
215
  const start_time = Date.now();
216
216
  const run = {
@@ -228,7 +228,10 @@ var BaseTracer = class extends require_callbacks_base.BaseCallbackHandler {
228
228
  child_execution_order: execution_order,
229
229
  run_type: runType ?? "chain",
230
230
  child_runs: [],
231
- extra: metadata ? { metadata } : {},
231
+ extra: metadata ? {
232
+ ...extra,
233
+ metadata
234
+ } : { ...extra },
232
235
  tags: tags || []
233
236
  };
234
237
  return this._addRunToRunMap(run);
@@ -1 +1 @@
1
- {"version":3,"file":"base.cjs","names":["runTree?: RunTree","run?: Run","parentRun?: Run","RunTree","getRuntimeEnvironment","value: any","defaultKey: string","x: BaseCallbackHandler","BaseCallbackHandler","_fields?: BaseCallbackHandlerInput","runId?: string","error: unknown","parentRun: Run","childRun: Run","run: Run","parentRunId: string | undefined","llm: Serialized","prompts: string[]","runId: string","parentRunId?: string","extraParams?: KVMap","tags?: string[]","metadata?: KVMap","name?: string","messages: BaseMessage[][]","output: LLMResult","_parentRunId?: string","_tags?: string[]","extraParams?: Record<string, unknown>","chain: Serialized","inputs: ChainValues","runType?: string","outputs: ChainValues","kwargs?: { inputs?: Record<string, unknown> }","tool: Serialized","input: string","output: any","action: AgentAction","action: AgentFinish","retriever: Serialized","query: string","documents: Document<Record<string, unknown>>[]","text: string","token: string","idx: NewTokenIndices","fields?: HandleLLMNewTokenCallbackFields"],"sources":["../../src/tracers/base.ts"],"sourcesContent":["import { KVMap, BaseRun } from \"langsmith/schemas\";\nimport { RunTree, convertToDottedOrderFormat } from \"langsmith/run_trees\";\n\nimport type { ChainValues } from \"../utils/types/index.js\";\nimport type { AgentAction, AgentFinish } from \"../agents.js\";\nimport type { LLMResult } from \"../outputs.js\";\nimport type { BaseMessage } from \"../messages/base.js\";\nimport { Serialized } from \"../load/serializable.js\";\nimport {\n BaseCallbackHandler,\n BaseCallbackHandlerInput,\n HandleLLMNewTokenCallbackFields,\n NewTokenIndices,\n} from \"../callbacks/base.js\";\nimport type { Document } from \"../documents/document.js\";\nimport { getRuntimeEnvironment } from \"../utils/env.js\";\n\nexport type RunType = string;\n\n// TODO: Remove this type and just use the base LangSmith Run type.\nexport interface Run extends BaseRun {\n // some optional fields are always present here\n id: string;\n start_time: number;\n end_time?: number;\n execution_order: number;\n // some additional fields that don't exist in sdk runs\n child_runs: this[];\n child_execution_order: number;\n events: Array<{\n name: string;\n time: string;\n kwargs?: Record<string, unknown>;\n }>;\n trace_id?: string;\n dotted_order?: string;\n /** @internal */\n _serialized_start_time?: string;\n}\n\n// TODO: Remove and just use base LangSmith Run type\nconst convertRunTreeToRun = (runTree?: RunTree): Run | undefined => {\n if (!runTree) {\n return undefined;\n }\n // Important that we return the raw run tree object since the reference\n // is mutated in other places.\n // TODO: Remove places where this is being done.\n\n runTree.events = runTree.events ?? [];\n runTree.child_runs = runTree.child_runs ?? [];\n // TODO: Remove this cast and just use the LangSmith RunTree type.\n return runTree as unknown as Run;\n};\n\nfunction convertRunToRunTree(run?: Run, parentRun?: Run): RunTree | undefined {\n if (!run) {\n return undefined;\n }\n return new RunTree({\n ...run,\n start_time: run._serialized_start_time ?? run.start_time,\n parent_run: convertRunToRunTree(parentRun),\n child_runs: run.child_runs\n .map((r) => convertRunToRunTree(r))\n .filter((r): r is RunTree => r !== undefined),\n extra: {\n ...run.extra,\n runtime: getRuntimeEnvironment(),\n },\n tracingEnabled: false,\n });\n}\n\nexport interface AgentRun extends Run {\n actions: AgentAction[];\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\nexport function isBaseTracer(x: BaseCallbackHandler): x is BaseTracer {\n return typeof (x as BaseTracer)._addRunToRunMap === \"function\";\n}\n\nexport abstract class BaseTracer extends BaseCallbackHandler {\n /** @deprecated Use `runTreeMap` instead. */\n protected runMap: Map<string, Run> = new Map();\n\n protected runTreeMap: Map<string, RunTree> = new Map();\n\n protected usesRunTreeMap = false;\n\n constructor(_fields?: BaseCallbackHandlerInput) {\n super(...arguments);\n }\n\n copy(): this {\n return this;\n }\n\n protected getRunById(runId?: string): Run | undefined {\n if (runId === undefined) {\n return undefined;\n }\n return this.usesRunTreeMap\n ? convertRunTreeToRun(this.runTreeMap.get(runId))\n : this.runMap.get(runId);\n }\n\n protected stringifyError(error: unknown) {\n // eslint-disable-next-line no-instanceof/no-instanceof\n if (error instanceof Error) {\n return error.message + (error?.stack ? `\\n\\n${error.stack}` : \"\");\n }\n\n if (typeof error === \"string\") {\n return error;\n }\n\n return `${error}`;\n }\n\n protected abstract persistRun(run: Run): Promise<void>;\n\n protected _addChildRun(parentRun: Run, childRun: Run) {\n parentRun.child_runs.push(childRun);\n }\n\n _addRunToRunMap(run: Run) {\n const { dottedOrder: currentDottedOrder, microsecondPrecisionDatestring } =\n convertToDottedOrderFormat(\n new Date(run.start_time).getTime(),\n run.id,\n run.execution_order\n );\n const storedRun = { ...run };\n const parentRun = this.getRunById(storedRun.parent_run_id);\n if (storedRun.parent_run_id !== undefined) {\n if (parentRun) {\n this._addChildRun(parentRun, storedRun);\n parentRun.child_execution_order = Math.max(\n parentRun.child_execution_order,\n storedRun.child_execution_order\n );\n storedRun.trace_id = parentRun.trace_id;\n if (parentRun.dotted_order !== undefined) {\n storedRun.dotted_order = [\n parentRun.dotted_order,\n currentDottedOrder,\n ].join(\".\");\n storedRun._serialized_start_time = microsecondPrecisionDatestring;\n } else {\n // This can happen naturally for callbacks added within a run\n // console.debug(`Parent run with UUID ${storedRun.parent_run_id} has no dotted order.`);\n }\n } else {\n // This can happen naturally for callbacks added within a run\n // console.debug(\n // `Parent run with UUID ${storedRun.parent_run_id} not found.`\n // );\n\n // Child run with no trace_id and dotted_order causes 400 error on LangSmith.\n // So we set the parent_run_id to undefined as a workaround.\n // This run will be shown as isolated run on LangSmith.\n storedRun.parent_run_id = undefined;\n }\n } else {\n storedRun.trace_id = storedRun.id;\n storedRun.dotted_order = currentDottedOrder;\n storedRun._serialized_start_time = microsecondPrecisionDatestring;\n }\n if (this.usesRunTreeMap) {\n const runTree = convertRunToRunTree(storedRun, parentRun);\n if (runTree !== undefined) {\n this.runTreeMap.set(storedRun.id, runTree);\n }\n } else {\n this.runMap.set(storedRun.id, storedRun);\n }\n return storedRun;\n }\n\n protected async _endTrace(run: Run): Promise<void> {\n const parentRun =\n run.parent_run_id !== undefined && this.getRunById(run.parent_run_id);\n if (parentRun) {\n parentRun.child_execution_order = Math.max(\n parentRun.child_execution_order,\n run.child_execution_order\n );\n } else {\n await this.persistRun(run);\n }\n await this.onRunUpdate?.(run);\n if (this.usesRunTreeMap) {\n this.runTreeMap.delete(run.id);\n } else {\n this.runMap.delete(run.id);\n }\n }\n\n protected _getExecutionOrder(parentRunId: string | undefined): number {\n const parentRun = parentRunId !== undefined && this.getRunById(parentRunId);\n // If a run has no parent then execution order is 1\n if (!parentRun) {\n return 1;\n }\n\n return parentRun.child_execution_order + 1;\n }\n\n /**\n * Create and add a run to the run map for LLM start events.\n * This must sometimes be done synchronously to avoid race conditions\n * when callbacks are backgrounded, so we expose it as a separate method here.\n */\n _createRunForLLMStart(\n llm: Serialized,\n prompts: string[],\n runId: string,\n parentRunId?: string,\n extraParams?: KVMap,\n tags?: string[],\n metadata?: KVMap,\n name?: string\n ) {\n const execution_order = this._getExecutionOrder(parentRunId);\n const start_time = Date.now();\n const finalExtraParams = metadata\n ? { ...extraParams, metadata }\n : extraParams;\n const run: Run = {\n id: runId,\n name: name ?? llm.id[llm.id.length - 1],\n parent_run_id: parentRunId,\n start_time,\n serialized: llm,\n events: [\n {\n name: \"start\",\n time: new Date(start_time).toISOString(),\n },\n ],\n inputs: { prompts },\n execution_order,\n child_runs: [],\n child_execution_order: execution_order,\n run_type: \"llm\",\n extra: finalExtraParams ?? {},\n tags: tags || [],\n };\n return this._addRunToRunMap(run);\n }\n\n async handleLLMStart(\n llm: Serialized,\n prompts: string[],\n runId: string,\n parentRunId?: string,\n extraParams?: KVMap,\n tags?: string[],\n metadata?: KVMap,\n name?: string\n ): Promise<Run> {\n const run =\n this.getRunById(runId) ??\n this._createRunForLLMStart(\n llm,\n prompts,\n runId,\n parentRunId,\n extraParams,\n tags,\n metadata,\n name\n );\n await this.onRunCreate?.(run);\n await this.onLLMStart?.(run);\n return run;\n }\n\n /**\n * Create and add a run to the run map for chat model start events.\n * This must sometimes be done synchronously to avoid race conditions\n * when callbacks are backgrounded, so we expose it as a separate method here.\n */\n _createRunForChatModelStart(\n llm: Serialized,\n messages: BaseMessage[][],\n runId: string,\n parentRunId?: string,\n extraParams?: KVMap,\n tags?: string[],\n metadata?: KVMap,\n name?: string\n ) {\n const execution_order = this._getExecutionOrder(parentRunId);\n const start_time = Date.now();\n const finalExtraParams = metadata\n ? { ...extraParams, metadata }\n : extraParams;\n const run: Run = {\n id: runId,\n name: name ?? llm.id[llm.id.length - 1],\n parent_run_id: parentRunId,\n start_time,\n serialized: llm,\n events: [\n {\n name: \"start\",\n time: new Date(start_time).toISOString(),\n },\n ],\n inputs: { messages },\n execution_order,\n child_runs: [],\n child_execution_order: execution_order,\n run_type: \"llm\",\n extra: finalExtraParams ?? {},\n tags: tags || [],\n };\n return this._addRunToRunMap(run);\n }\n\n async handleChatModelStart(\n llm: Serialized,\n messages: BaseMessage[][],\n runId: string,\n parentRunId?: string,\n extraParams?: KVMap,\n tags?: string[],\n metadata?: KVMap,\n name?: string\n ): Promise<Run> {\n const run =\n this.getRunById(runId) ??\n this._createRunForChatModelStart(\n llm,\n messages,\n runId,\n parentRunId,\n extraParams,\n tags,\n metadata,\n name\n );\n await this.onRunCreate?.(run);\n await this.onLLMStart?.(run);\n return run;\n }\n\n async handleLLMEnd(\n output: LLMResult,\n runId: string,\n _parentRunId?: string,\n _tags?: string[],\n extraParams?: Record<string, unknown>\n ): Promise<Run> {\n const run = this.getRunById(runId);\n if (!run || run?.run_type !== \"llm\") {\n throw new Error(\"No LLM run to end.\");\n }\n run.end_time = Date.now();\n run.outputs = output;\n run.events.push({\n name: \"end\",\n time: new Date(run.end_time).toISOString(),\n });\n run.extra = { ...run.extra, ...extraParams };\n await this.onLLMEnd?.(run);\n await this._endTrace(run);\n return run;\n }\n\n async handleLLMError(\n error: unknown,\n runId: string,\n _parentRunId?: string,\n _tags?: string[],\n extraParams?: Record<string, unknown>\n ): Promise<Run> {\n const run = this.getRunById(runId);\n if (!run || run?.run_type !== \"llm\") {\n throw new Error(\"No LLM run to end.\");\n }\n run.end_time = Date.now();\n run.error = this.stringifyError(error);\n run.events.push({\n name: \"error\",\n time: new Date(run.end_time).toISOString(),\n });\n run.extra = { ...run.extra, ...extraParams };\n await this.onLLMError?.(run);\n await this._endTrace(run);\n return run;\n }\n\n /**\n * Create and add a run to the run map for chain start events.\n * This must sometimes be done synchronously to avoid race conditions\n * when callbacks are backgrounded, so we expose it as a separate method here.\n */\n _createRunForChainStart(\n chain: Serialized,\n inputs: ChainValues,\n runId: string,\n parentRunId?: string,\n tags?: string[],\n metadata?: KVMap,\n runType?: string,\n name?: string\n ) {\n const execution_order = this._getExecutionOrder(parentRunId);\n const start_time = Date.now();\n const run: Run = {\n id: runId,\n name: name ?? chain.id[chain.id.length - 1],\n parent_run_id: parentRunId,\n start_time,\n serialized: chain,\n events: [\n {\n name: \"start\",\n time: new Date(start_time).toISOString(),\n },\n ],\n inputs,\n execution_order,\n child_execution_order: execution_order,\n run_type: runType ?? \"chain\",\n child_runs: [],\n extra: metadata ? { metadata } : {},\n tags: tags || [],\n };\n return this._addRunToRunMap(run);\n }\n\n async handleChainStart(\n chain: Serialized,\n inputs: ChainValues,\n runId: string,\n parentRunId?: string,\n tags?: string[],\n metadata?: KVMap,\n runType?: string,\n name?: string\n ): Promise<Run> {\n const run =\n this.getRunById(runId) ??\n this._createRunForChainStart(\n chain,\n inputs,\n runId,\n parentRunId,\n tags,\n metadata,\n runType,\n name\n );\n await this.onRunCreate?.(run);\n await this.onChainStart?.(run);\n return run;\n }\n\n async handleChainEnd(\n outputs: ChainValues,\n runId: string,\n _parentRunId?: string,\n _tags?: string[],\n kwargs?: { inputs?: Record<string, unknown> }\n ): Promise<Run> {\n const run = this.getRunById(runId);\n if (!run) {\n throw new Error(\"No chain run to end.\");\n }\n run.end_time = Date.now();\n run.outputs = _coerceToDict(outputs, \"output\");\n run.events.push({\n name: \"end\",\n time: new Date(run.end_time).toISOString(),\n });\n if (kwargs?.inputs !== undefined) {\n run.inputs = _coerceToDict(kwargs.inputs, \"input\");\n }\n await this.onChainEnd?.(run);\n await this._endTrace(run);\n return run;\n }\n\n async handleChainError(\n error: unknown,\n runId: string,\n _parentRunId?: string,\n _tags?: string[],\n kwargs?: { inputs?: Record<string, unknown> }\n ): Promise<Run> {\n const run = this.getRunById(runId);\n if (!run) {\n throw new Error(\"No chain run to end.\");\n }\n run.end_time = Date.now();\n run.error = this.stringifyError(error);\n run.events.push({\n name: \"error\",\n time: new Date(run.end_time).toISOString(),\n });\n if (kwargs?.inputs !== undefined) {\n run.inputs = _coerceToDict(kwargs.inputs, \"input\");\n }\n await this.onChainError?.(run);\n await this._endTrace(run);\n return run;\n }\n\n /**\n * Create and add a run to the run map for tool start events.\n * This must sometimes be done synchronously to avoid race conditions\n * when callbacks are backgrounded, so we expose it as a separate method here.\n */\n _createRunForToolStart(\n tool: Serialized,\n input: string,\n runId: string,\n parentRunId?: string,\n tags?: string[],\n metadata?: KVMap,\n name?: string\n ) {\n const execution_order = this._getExecutionOrder(parentRunId);\n const start_time = Date.now();\n const run: Run = {\n id: runId,\n name: name ?? tool.id[tool.id.length - 1],\n parent_run_id: parentRunId,\n start_time,\n serialized: tool,\n events: [\n {\n name: \"start\",\n time: new Date(start_time).toISOString(),\n },\n ],\n inputs: { input },\n execution_order,\n child_execution_order: execution_order,\n run_type: \"tool\",\n child_runs: [],\n extra: metadata ? { metadata } : {},\n tags: tags || [],\n };\n return this._addRunToRunMap(run);\n }\n\n async handleToolStart(\n tool: Serialized,\n input: string,\n runId: string,\n parentRunId?: string,\n tags?: string[],\n metadata?: KVMap,\n name?: string\n ): Promise<Run> {\n const run =\n this.getRunById(runId) ??\n this._createRunForToolStart(\n tool,\n input,\n runId,\n parentRunId,\n tags,\n metadata,\n name\n );\n await this.onRunCreate?.(run);\n await this.onToolStart?.(run);\n return run;\n }\n\n // eslint-disable-next-line @typescript-eslint/no-explicit-any\n async handleToolEnd(output: any, runId: string): Promise<Run> {\n const run = this.getRunById(runId);\n if (!run || run?.run_type !== \"tool\") {\n throw new Error(\"No tool run to end\");\n }\n run.end_time = Date.now();\n run.outputs = { output };\n run.events.push({\n name: \"end\",\n time: new Date(run.end_time).toISOString(),\n });\n await this.onToolEnd?.(run);\n await this._endTrace(run);\n return run;\n }\n\n async handleToolError(error: unknown, runId: string): Promise<Run> {\n const run = this.getRunById(runId);\n if (!run || run?.run_type !== \"tool\") {\n throw new Error(\"No tool run to end\");\n }\n run.end_time = Date.now();\n run.error = this.stringifyError(error);\n run.events.push({\n name: \"error\",\n time: new Date(run.end_time).toISOString(),\n });\n await this.onToolError?.(run);\n await this._endTrace(run);\n return run;\n }\n\n async handleAgentAction(action: AgentAction, runId: string): Promise<void> {\n const run = this.getRunById(runId);\n if (!run || run?.run_type !== \"chain\") {\n return;\n }\n const agentRun = run as AgentRun;\n agentRun.actions = agentRun.actions || [];\n agentRun.actions.push(action);\n agentRun.events.push({\n name: \"agent_action\",\n time: new Date().toISOString(),\n kwargs: { action },\n });\n await this.onAgentAction?.(run as AgentRun);\n }\n\n async handleAgentEnd(action: AgentFinish, runId: string): Promise<void> {\n const run = this.getRunById(runId);\n if (!run || run?.run_type !== \"chain\") {\n return;\n }\n run.events.push({\n name: \"agent_end\",\n time: new Date().toISOString(),\n kwargs: { action },\n });\n await this.onAgentEnd?.(run);\n }\n\n /**\n * Create and add a run to the run map for retriever start events.\n * This must sometimes be done synchronously to avoid race conditions\n * when callbacks are backgrounded, so we expose it as a separate method here.\n */\n _createRunForRetrieverStart(\n retriever: Serialized,\n query: string,\n runId: string,\n parentRunId?: string,\n tags?: string[],\n metadata?: KVMap,\n name?: string\n ) {\n const execution_order = this._getExecutionOrder(parentRunId);\n const start_time = Date.now();\n const run: Run = {\n id: runId,\n name: name ?? retriever.id[retriever.id.length - 1],\n parent_run_id: parentRunId,\n start_time,\n serialized: retriever,\n events: [\n {\n name: \"start\",\n time: new Date(start_time).toISOString(),\n },\n ],\n inputs: { query },\n execution_order,\n child_execution_order: execution_order,\n run_type: \"retriever\",\n child_runs: [],\n extra: metadata ? { metadata } : {},\n tags: tags || [],\n };\n return this._addRunToRunMap(run);\n }\n\n async handleRetrieverStart(\n retriever: Serialized,\n query: string,\n runId: string,\n parentRunId?: string,\n tags?: string[],\n metadata?: KVMap,\n name?: string\n ): Promise<Run> {\n const run =\n this.getRunById(runId) ??\n this._createRunForRetrieverStart(\n retriever,\n query,\n runId,\n parentRunId,\n tags,\n metadata,\n name\n );\n await this.onRunCreate?.(run);\n await this.onRetrieverStart?.(run);\n return run;\n }\n\n async handleRetrieverEnd(\n documents: Document<Record<string, unknown>>[],\n runId: string\n ): Promise<Run> {\n const run = this.getRunById(runId);\n if (!run || run?.run_type !== \"retriever\") {\n throw new Error(\"No retriever run to end\");\n }\n run.end_time = Date.now();\n run.outputs = { documents };\n run.events.push({\n name: \"end\",\n time: new Date(run.end_time).toISOString(),\n });\n await this.onRetrieverEnd?.(run);\n await this._endTrace(run);\n return run;\n }\n\n async handleRetrieverError(error: unknown, runId: string): Promise<Run> {\n const run = this.getRunById(runId);\n if (!run || run?.run_type !== \"retriever\") {\n throw new Error(\"No retriever run to end\");\n }\n run.end_time = Date.now();\n run.error = this.stringifyError(error);\n run.events.push({\n name: \"error\",\n time: new Date(run.end_time).toISOString(),\n });\n await this.onRetrieverError?.(run);\n await this._endTrace(run);\n return run;\n }\n\n async handleText(text: string, runId: string): Promise<void> {\n const run = this.getRunById(runId);\n if (!run || run?.run_type !== \"chain\") {\n return;\n }\n run.events.push({\n name: \"text\",\n time: new Date().toISOString(),\n kwargs: { text },\n });\n await this.onText?.(run);\n }\n\n async handleLLMNewToken(\n token: string,\n idx: NewTokenIndices,\n runId: string,\n _parentRunId?: string,\n _tags?: string[],\n fields?: HandleLLMNewTokenCallbackFields\n ): Promise<Run> {\n const run = this.getRunById(runId);\n if (!run || run?.run_type !== \"llm\") {\n throw new Error(\n `Invalid \"runId\" provided to \"handleLLMNewToken\" callback.`\n );\n }\n run.events.push({\n name: \"new_token\",\n time: new Date().toISOString(),\n kwargs: { token, idx, chunk: fields?.chunk },\n });\n await this.onLLMNewToken?.(run, token, { chunk: fields?.chunk });\n return run;\n }\n\n // custom event handlers\n\n onRunCreate?(run: Run): void | Promise<void>;\n\n onRunUpdate?(run: Run): void | Promise<void>;\n\n onLLMStart?(run: Run): void | Promise<void>;\n\n onLLMEnd?(run: Run): void | Promise<void>;\n\n onLLMError?(run: Run): void | Promise<void>;\n\n onChainStart?(run: Run): void | Promise<void>;\n\n onChainEnd?(run: Run): void | Promise<void>;\n\n onChainError?(run: Run): void | Promise<void>;\n\n onToolStart?(run: Run): void | Promise<void>;\n\n onToolEnd?(run: Run): void | Promise<void>;\n\n onToolError?(run: Run): void | Promise<void>;\n\n onAgentAction?(run: Run): void | Promise<void>;\n\n onAgentEnd?(run: Run): void | Promise<void>;\n\n onRetrieverStart?(run: Run): void | Promise<void>;\n\n onRetrieverEnd?(run: Run): void | Promise<void>;\n\n onRetrieverError?(run: Run): void | Promise<void>;\n\n onText?(run: Run): void | Promise<void>;\n\n onLLMNewToken?(\n run: Run,\n token: string,\n // eslint-disable-next-line @typescript-eslint/no-explicit-any\n kwargs?: { chunk: any }\n ): void | Promise<void>;\n}\n"],"mappings":"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"}
1
+ {"version":3,"file":"base.cjs","names":["runTree?: RunTree","run?: Run","parentRun?: Run","RunTree","getRuntimeEnvironment","value: any","defaultKey: string","x: BaseCallbackHandler","BaseCallbackHandler","_fields?: BaseCallbackHandlerInput","runId?: string","error: unknown","parentRun: Run","childRun: Run","run: Run","parentRunId: string | undefined","llm: Serialized","prompts: string[]","runId: string","parentRunId?: string","extraParams?: KVMap","tags?: string[]","metadata?: KVMap","name?: string","messages: BaseMessage[][]","output: LLMResult","_parentRunId?: string","_tags?: string[]","extraParams?: Record<string, unknown>","chain: Serialized","inputs: ChainValues","runType?: string","extra?: Record<string, unknown>","outputs: ChainValues","kwargs?: { inputs?: Record<string, unknown> }","tool: Serialized","input: string","output: any","action: AgentAction","action: AgentFinish","retriever: Serialized","query: string","documents: Document<Record<string, unknown>>[]","text: string","token: string","idx: NewTokenIndices","fields?: HandleLLMNewTokenCallbackFields"],"sources":["../../src/tracers/base.ts"],"sourcesContent":["import { KVMap, BaseRun } from \"langsmith/schemas\";\nimport { RunTree, convertToDottedOrderFormat } from \"langsmith/run_trees\";\n\nimport type { ChainValues } from \"../utils/types/index.js\";\nimport type { AgentAction, AgentFinish } from \"../agents.js\";\nimport type { LLMResult } from \"../outputs.js\";\nimport type { BaseMessage } from \"../messages/base.js\";\nimport { Serialized } from \"../load/serializable.js\";\nimport {\n BaseCallbackHandler,\n BaseCallbackHandlerInput,\n HandleLLMNewTokenCallbackFields,\n NewTokenIndices,\n} from \"../callbacks/base.js\";\nimport type { Document } from \"../documents/document.js\";\nimport { getRuntimeEnvironment } from \"../utils/env.js\";\n\nexport type RunType = string;\n\n// TODO: Remove this type and just use the base LangSmith Run type.\nexport interface Run extends BaseRun {\n // some optional fields are always present here\n id: string;\n start_time: number;\n end_time?: number;\n execution_order: number;\n // some additional fields that don't exist in sdk runs\n child_runs: this[];\n child_execution_order: number;\n events: Array<{\n name: string;\n time: string;\n kwargs?: Record<string, unknown>;\n }>;\n trace_id?: string;\n dotted_order?: string;\n /** @internal */\n _serialized_start_time?: string;\n}\n\n// TODO: Remove and just use base LangSmith Run type\nconst convertRunTreeToRun = (runTree?: RunTree): Run | undefined => {\n if (!runTree) {\n return undefined;\n }\n // Important that we return the raw run tree object since the reference\n // is mutated in other places.\n // TODO: Remove places where this is being done.\n\n runTree.events = runTree.events ?? [];\n runTree.child_runs = runTree.child_runs ?? [];\n // TODO: Remove this cast and just use the LangSmith RunTree type.\n return runTree as unknown as Run;\n};\n\nfunction convertRunToRunTree(run?: Run, parentRun?: Run): RunTree | undefined {\n if (!run) {\n return undefined;\n }\n return new RunTree({\n ...run,\n start_time: run._serialized_start_time ?? run.start_time,\n parent_run: convertRunToRunTree(parentRun),\n child_runs: run.child_runs\n .map((r) => convertRunToRunTree(r))\n .filter((r): r is RunTree => r !== undefined),\n extra: {\n ...run.extra,\n runtime: getRuntimeEnvironment(),\n },\n tracingEnabled: false,\n });\n}\n\nexport interface AgentRun extends Run {\n actions: AgentAction[];\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\nexport function isBaseTracer(x: BaseCallbackHandler): x is BaseTracer {\n return typeof (x as BaseTracer)._addRunToRunMap === \"function\";\n}\n\nexport abstract class BaseTracer extends BaseCallbackHandler {\n /** @deprecated Use `runTreeMap` instead. */\n protected runMap: Map<string, Run> = new Map();\n\n protected runTreeMap: Map<string, RunTree> = new Map();\n\n protected usesRunTreeMap = false;\n\n constructor(_fields?: BaseCallbackHandlerInput) {\n super(...arguments);\n }\n\n copy(): this {\n return this;\n }\n\n protected getRunById(runId?: string): Run | undefined {\n if (runId === undefined) {\n return undefined;\n }\n return this.usesRunTreeMap\n ? convertRunTreeToRun(this.runTreeMap.get(runId))\n : this.runMap.get(runId);\n }\n\n protected stringifyError(error: unknown) {\n // eslint-disable-next-line no-instanceof/no-instanceof\n if (error instanceof Error) {\n return error.message + (error?.stack ? `\\n\\n${error.stack}` : \"\");\n }\n\n if (typeof error === \"string\") {\n return error;\n }\n\n return `${error}`;\n }\n\n protected abstract persistRun(run: Run): Promise<void>;\n\n protected _addChildRun(parentRun: Run, childRun: Run) {\n parentRun.child_runs.push(childRun);\n }\n\n _addRunToRunMap(run: Run) {\n const { dottedOrder: currentDottedOrder, microsecondPrecisionDatestring } =\n convertToDottedOrderFormat(\n new Date(run.start_time).getTime(),\n run.id,\n run.execution_order\n );\n const storedRun = { ...run };\n const parentRun = this.getRunById(storedRun.parent_run_id);\n if (storedRun.parent_run_id !== undefined) {\n if (parentRun) {\n this._addChildRun(parentRun, storedRun);\n parentRun.child_execution_order = Math.max(\n parentRun.child_execution_order,\n storedRun.child_execution_order\n );\n storedRun.trace_id = parentRun.trace_id;\n if (parentRun.dotted_order !== undefined) {\n storedRun.dotted_order = [\n parentRun.dotted_order,\n currentDottedOrder,\n ].join(\".\");\n storedRun._serialized_start_time = microsecondPrecisionDatestring;\n } else {\n // This can happen naturally for callbacks added within a run\n // console.debug(`Parent run with UUID ${storedRun.parent_run_id} has no dotted order.`);\n }\n } else {\n // This can happen naturally for callbacks added within a run\n // console.debug(\n // `Parent run with UUID ${storedRun.parent_run_id} not found.`\n // );\n\n // Child run with no trace_id and dotted_order causes 400 error on LangSmith.\n // So we set the parent_run_id to undefined as a workaround.\n // This run will be shown as isolated run on LangSmith.\n storedRun.parent_run_id = undefined;\n }\n } else {\n storedRun.trace_id = storedRun.id;\n storedRun.dotted_order = currentDottedOrder;\n storedRun._serialized_start_time = microsecondPrecisionDatestring;\n }\n if (this.usesRunTreeMap) {\n const runTree = convertRunToRunTree(storedRun, parentRun);\n if (runTree !== undefined) {\n this.runTreeMap.set(storedRun.id, runTree);\n }\n } else {\n this.runMap.set(storedRun.id, storedRun);\n }\n return storedRun;\n }\n\n protected async _endTrace(run: Run): Promise<void> {\n const parentRun =\n run.parent_run_id !== undefined && this.getRunById(run.parent_run_id);\n if (parentRun) {\n parentRun.child_execution_order = Math.max(\n parentRun.child_execution_order,\n run.child_execution_order\n );\n } else {\n await this.persistRun(run);\n }\n await this.onRunUpdate?.(run);\n if (this.usesRunTreeMap) {\n this.runTreeMap.delete(run.id);\n } else {\n this.runMap.delete(run.id);\n }\n }\n\n protected _getExecutionOrder(parentRunId: string | undefined): number {\n const parentRun = parentRunId !== undefined && this.getRunById(parentRunId);\n // If a run has no parent then execution order is 1\n if (!parentRun) {\n return 1;\n }\n\n return parentRun.child_execution_order + 1;\n }\n\n /**\n * Create and add a run to the run map for LLM start events.\n * This must sometimes be done synchronously to avoid race conditions\n * when callbacks are backgrounded, so we expose it as a separate method here.\n */\n _createRunForLLMStart(\n llm: Serialized,\n prompts: string[],\n runId: string,\n parentRunId?: string,\n extraParams?: KVMap,\n tags?: string[],\n metadata?: KVMap,\n name?: string\n ) {\n const execution_order = this._getExecutionOrder(parentRunId);\n const start_time = Date.now();\n const finalExtraParams = metadata\n ? { ...extraParams, metadata }\n : extraParams;\n const run: Run = {\n id: runId,\n name: name ?? llm.id[llm.id.length - 1],\n parent_run_id: parentRunId,\n start_time,\n serialized: llm,\n events: [\n {\n name: \"start\",\n time: new Date(start_time).toISOString(),\n },\n ],\n inputs: { prompts },\n execution_order,\n child_runs: [],\n child_execution_order: execution_order,\n run_type: \"llm\",\n extra: finalExtraParams ?? {},\n tags: tags || [],\n };\n return this._addRunToRunMap(run);\n }\n\n async handleLLMStart(\n llm: Serialized,\n prompts: string[],\n runId: string,\n parentRunId?: string,\n extraParams?: KVMap,\n tags?: string[],\n metadata?: KVMap,\n name?: string\n ): Promise<Run> {\n const run =\n this.getRunById(runId) ??\n this._createRunForLLMStart(\n llm,\n prompts,\n runId,\n parentRunId,\n extraParams,\n tags,\n metadata,\n name\n );\n await this.onRunCreate?.(run);\n await this.onLLMStart?.(run);\n return run;\n }\n\n /**\n * Create and add a run to the run map for chat model start events.\n * This must sometimes be done synchronously to avoid race conditions\n * when callbacks are backgrounded, so we expose it as a separate method here.\n */\n _createRunForChatModelStart(\n llm: Serialized,\n messages: BaseMessage[][],\n runId: string,\n parentRunId?: string,\n extraParams?: KVMap,\n tags?: string[],\n metadata?: KVMap,\n name?: string\n ) {\n const execution_order = this._getExecutionOrder(parentRunId);\n const start_time = Date.now();\n const finalExtraParams = metadata\n ? { ...extraParams, metadata }\n : extraParams;\n const run: Run = {\n id: runId,\n name: name ?? llm.id[llm.id.length - 1],\n parent_run_id: parentRunId,\n start_time,\n serialized: llm,\n events: [\n {\n name: \"start\",\n time: new Date(start_time).toISOString(),\n },\n ],\n inputs: { messages },\n execution_order,\n child_runs: [],\n child_execution_order: execution_order,\n run_type: \"llm\",\n extra: finalExtraParams ?? {},\n tags: tags || [],\n };\n return this._addRunToRunMap(run);\n }\n\n async handleChatModelStart(\n llm: Serialized,\n messages: BaseMessage[][],\n runId: string,\n parentRunId?: string,\n extraParams?: KVMap,\n tags?: string[],\n metadata?: KVMap,\n name?: string\n ): Promise<Run> {\n const run =\n this.getRunById(runId) ??\n this._createRunForChatModelStart(\n llm,\n messages,\n runId,\n parentRunId,\n extraParams,\n tags,\n metadata,\n name\n );\n await this.onRunCreate?.(run);\n await this.onLLMStart?.(run);\n return run;\n }\n\n async handleLLMEnd(\n output: LLMResult,\n runId: string,\n _parentRunId?: string,\n _tags?: string[],\n extraParams?: Record<string, unknown>\n ): Promise<Run> {\n const run = this.getRunById(runId);\n if (!run || run?.run_type !== \"llm\") {\n throw new Error(\"No LLM run to end.\");\n }\n run.end_time = Date.now();\n run.outputs = output;\n run.events.push({\n name: \"end\",\n time: new Date(run.end_time).toISOString(),\n });\n run.extra = { ...run.extra, ...extraParams };\n await this.onLLMEnd?.(run);\n await this._endTrace(run);\n return run;\n }\n\n async handleLLMError(\n error: unknown,\n runId: string,\n _parentRunId?: string,\n _tags?: string[],\n extraParams?: Record<string, unknown>\n ): Promise<Run> {\n const run = this.getRunById(runId);\n if (!run || run?.run_type !== \"llm\") {\n throw new Error(\"No LLM run to end.\");\n }\n run.end_time = Date.now();\n run.error = this.stringifyError(error);\n run.events.push({\n name: \"error\",\n time: new Date(run.end_time).toISOString(),\n });\n run.extra = { ...run.extra, ...extraParams };\n await this.onLLMError?.(run);\n await this._endTrace(run);\n return run;\n }\n\n /**\n * Create and add a run to the run map for chain start events.\n * This must sometimes be done synchronously to avoid race conditions\n * when callbacks are backgrounded, so we expose it as a separate method here.\n */\n _createRunForChainStart(\n chain: Serialized,\n inputs: ChainValues,\n runId: string,\n parentRunId?: string,\n tags?: string[],\n metadata?: KVMap,\n runType?: string,\n name?: string,\n extra?: Record<string, unknown>\n ) {\n const execution_order = this._getExecutionOrder(parentRunId);\n const start_time = Date.now();\n const run: Run = {\n id: runId,\n name: name ?? chain.id[chain.id.length - 1],\n parent_run_id: parentRunId,\n start_time,\n serialized: chain,\n events: [\n {\n name: \"start\",\n time: new Date(start_time).toISOString(),\n },\n ],\n inputs,\n execution_order,\n child_execution_order: execution_order,\n run_type: runType ?? \"chain\",\n child_runs: [],\n extra: metadata ? { ...extra, metadata } : { ...extra },\n tags: tags || [],\n };\n return this._addRunToRunMap(run);\n }\n\n async handleChainStart(\n chain: Serialized,\n inputs: ChainValues,\n runId: string,\n parentRunId?: string,\n tags?: string[],\n metadata?: KVMap,\n runType?: string,\n name?: string\n ): Promise<Run> {\n const run =\n this.getRunById(runId) ??\n this._createRunForChainStart(\n chain,\n inputs,\n runId,\n parentRunId,\n tags,\n metadata,\n runType,\n name\n );\n await this.onRunCreate?.(run);\n await this.onChainStart?.(run);\n return run;\n }\n\n async handleChainEnd(\n outputs: ChainValues,\n runId: string,\n _parentRunId?: string,\n _tags?: string[],\n kwargs?: { inputs?: Record<string, unknown> }\n ): Promise<Run> {\n const run = this.getRunById(runId);\n if (!run) {\n throw new Error(\"No chain run to end.\");\n }\n run.end_time = Date.now();\n run.outputs = _coerceToDict(outputs, \"output\");\n run.events.push({\n name: \"end\",\n time: new Date(run.end_time).toISOString(),\n });\n if (kwargs?.inputs !== undefined) {\n run.inputs = _coerceToDict(kwargs.inputs, \"input\");\n }\n await this.onChainEnd?.(run);\n await this._endTrace(run);\n return run;\n }\n\n async handleChainError(\n error: unknown,\n runId: string,\n _parentRunId?: string,\n _tags?: string[],\n kwargs?: { inputs?: Record<string, unknown> }\n ): Promise<Run> {\n const run = this.getRunById(runId);\n if (!run) {\n throw new Error(\"No chain run to end.\");\n }\n run.end_time = Date.now();\n run.error = this.stringifyError(error);\n run.events.push({\n name: \"error\",\n time: new Date(run.end_time).toISOString(),\n });\n if (kwargs?.inputs !== undefined) {\n run.inputs = _coerceToDict(kwargs.inputs, \"input\");\n }\n await this.onChainError?.(run);\n await this._endTrace(run);\n return run;\n }\n\n /**\n * Create and add a run to the run map for tool start events.\n * This must sometimes be done synchronously to avoid race conditions\n * when callbacks are backgrounded, so we expose it as a separate method here.\n */\n _createRunForToolStart(\n tool: Serialized,\n input: string,\n runId: string,\n parentRunId?: string,\n tags?: string[],\n metadata?: KVMap,\n name?: string\n ) {\n const execution_order = this._getExecutionOrder(parentRunId);\n const start_time = Date.now();\n const run: Run = {\n id: runId,\n name: name ?? tool.id[tool.id.length - 1],\n parent_run_id: parentRunId,\n start_time,\n serialized: tool,\n events: [\n {\n name: \"start\",\n time: new Date(start_time).toISOString(),\n },\n ],\n inputs: { input },\n execution_order,\n child_execution_order: execution_order,\n run_type: \"tool\",\n child_runs: [],\n extra: metadata ? { metadata } : {},\n tags: tags || [],\n };\n return this._addRunToRunMap(run);\n }\n\n async handleToolStart(\n tool: Serialized,\n input: string,\n runId: string,\n parentRunId?: string,\n tags?: string[],\n metadata?: KVMap,\n name?: string\n ): Promise<Run> {\n const run =\n this.getRunById(runId) ??\n this._createRunForToolStart(\n tool,\n input,\n runId,\n parentRunId,\n tags,\n metadata,\n name\n );\n await this.onRunCreate?.(run);\n await this.onToolStart?.(run);\n return run;\n }\n\n // eslint-disable-next-line @typescript-eslint/no-explicit-any\n async handleToolEnd(output: any, runId: string): Promise<Run> {\n const run = this.getRunById(runId);\n if (!run || run?.run_type !== \"tool\") {\n throw new Error(\"No tool run to end\");\n }\n run.end_time = Date.now();\n run.outputs = { output };\n run.events.push({\n name: \"end\",\n time: new Date(run.end_time).toISOString(),\n });\n await this.onToolEnd?.(run);\n await this._endTrace(run);\n return run;\n }\n\n async handleToolError(error: unknown, runId: string): Promise<Run> {\n const run = this.getRunById(runId);\n if (!run || run?.run_type !== \"tool\") {\n throw new Error(\"No tool run to end\");\n }\n run.end_time = Date.now();\n run.error = this.stringifyError(error);\n run.events.push({\n name: \"error\",\n time: new Date(run.end_time).toISOString(),\n });\n await this.onToolError?.(run);\n await this._endTrace(run);\n return run;\n }\n\n async handleAgentAction(action: AgentAction, runId: string): Promise<void> {\n const run = this.getRunById(runId);\n if (!run || run?.run_type !== \"chain\") {\n return;\n }\n const agentRun = run as AgentRun;\n agentRun.actions = agentRun.actions || [];\n agentRun.actions.push(action);\n agentRun.events.push({\n name: \"agent_action\",\n time: new Date().toISOString(),\n kwargs: { action },\n });\n await this.onAgentAction?.(run as AgentRun);\n }\n\n async handleAgentEnd(action: AgentFinish, runId: string): Promise<void> {\n const run = this.getRunById(runId);\n if (!run || run?.run_type !== \"chain\") {\n return;\n }\n run.events.push({\n name: \"agent_end\",\n time: new Date().toISOString(),\n kwargs: { action },\n });\n await this.onAgentEnd?.(run);\n }\n\n /**\n * Create and add a run to the run map for retriever start events.\n * This must sometimes be done synchronously to avoid race conditions\n * when callbacks are backgrounded, so we expose it as a separate method here.\n */\n _createRunForRetrieverStart(\n retriever: Serialized,\n query: string,\n runId: string,\n parentRunId?: string,\n tags?: string[],\n metadata?: KVMap,\n name?: string\n ) {\n const execution_order = this._getExecutionOrder(parentRunId);\n const start_time = Date.now();\n const run: Run = {\n id: runId,\n name: name ?? retriever.id[retriever.id.length - 1],\n parent_run_id: parentRunId,\n start_time,\n serialized: retriever,\n events: [\n {\n name: \"start\",\n time: new Date(start_time).toISOString(),\n },\n ],\n inputs: { query },\n execution_order,\n child_execution_order: execution_order,\n run_type: \"retriever\",\n child_runs: [],\n extra: metadata ? { metadata } : {},\n tags: tags || [],\n };\n return this._addRunToRunMap(run);\n }\n\n async handleRetrieverStart(\n retriever: Serialized,\n query: string,\n runId: string,\n parentRunId?: string,\n tags?: string[],\n metadata?: KVMap,\n name?: string\n ): Promise<Run> {\n const run =\n this.getRunById(runId) ??\n this._createRunForRetrieverStart(\n retriever,\n query,\n runId,\n parentRunId,\n tags,\n metadata,\n name\n );\n await this.onRunCreate?.(run);\n await this.onRetrieverStart?.(run);\n return run;\n }\n\n async handleRetrieverEnd(\n documents: Document<Record<string, unknown>>[],\n runId: string\n ): Promise<Run> {\n const run = this.getRunById(runId);\n if (!run || run?.run_type !== \"retriever\") {\n throw new Error(\"No retriever run to end\");\n }\n run.end_time = Date.now();\n run.outputs = { documents };\n run.events.push({\n name: \"end\",\n time: new Date(run.end_time).toISOString(),\n });\n await this.onRetrieverEnd?.(run);\n await this._endTrace(run);\n return run;\n }\n\n async handleRetrieverError(error: unknown, runId: string): Promise<Run> {\n const run = this.getRunById(runId);\n if (!run || run?.run_type !== \"retriever\") {\n throw new Error(\"No retriever run to end\");\n }\n run.end_time = Date.now();\n run.error = this.stringifyError(error);\n run.events.push({\n name: \"error\",\n time: new Date(run.end_time).toISOString(),\n });\n await this.onRetrieverError?.(run);\n await this._endTrace(run);\n return run;\n }\n\n async handleText(text: string, runId: string): Promise<void> {\n const run = this.getRunById(runId);\n if (!run || run?.run_type !== \"chain\") {\n return;\n }\n run.events.push({\n name: \"text\",\n time: new Date().toISOString(),\n kwargs: { text },\n });\n await this.onText?.(run);\n }\n\n async handleLLMNewToken(\n token: string,\n idx: NewTokenIndices,\n runId: string,\n _parentRunId?: string,\n _tags?: string[],\n fields?: HandleLLMNewTokenCallbackFields\n ): Promise<Run> {\n const run = this.getRunById(runId);\n if (!run || run?.run_type !== \"llm\") {\n throw new Error(\n `Invalid \"runId\" provided to \"handleLLMNewToken\" callback.`\n );\n }\n run.events.push({\n name: \"new_token\",\n time: new Date().toISOString(),\n kwargs: { token, idx, chunk: fields?.chunk },\n });\n await this.onLLMNewToken?.(run, token, { chunk: fields?.chunk });\n return run;\n }\n\n // custom event handlers\n\n onRunCreate?(run: Run): void | Promise<void>;\n\n onRunUpdate?(run: Run): void | Promise<void>;\n\n onLLMStart?(run: Run): void | Promise<void>;\n\n onLLMEnd?(run: Run): void | Promise<void>;\n\n onLLMError?(run: Run): void | Promise<void>;\n\n onChainStart?(run: Run): void | Promise<void>;\n\n onChainEnd?(run: Run): void | Promise<void>;\n\n onChainError?(run: Run): void | Promise<void>;\n\n onToolStart?(run: Run): void | Promise<void>;\n\n onToolEnd?(run: Run): void | Promise<void>;\n\n onToolError?(run: Run): void | Promise<void>;\n\n onAgentAction?(run: Run): void | Promise<void>;\n\n onAgentEnd?(run: Run): void | Promise<void>;\n\n onRetrieverStart?(run: Run): void | Promise<void>;\n\n onRetrieverEnd?(run: Run): void | Promise<void>;\n\n onRetrieverError?(run: Run): void | Promise<void>;\n\n onText?(run: Run): void | Promise<void>;\n\n onLLMNewToken?(\n run: Run,\n token: string,\n // eslint-disable-next-line @typescript-eslint/no-explicit-any\n kwargs?: { chunk: any }\n ): void | Promise<void>;\n}\n"],"mappings":"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"}
@@ -148,7 +148,7 @@ declare abstract class BaseTracer extends BaseCallbackHandler {
148
148
  * This must sometimes be done synchronously to avoid race conditions
149
149
  * when callbacks are backgrounded, so we expose it as a separate method here.
150
150
  */
151
- _createRunForChainStart(chain: Serialized, inputs: ChainValues, runId: string, parentRunId?: string, tags?: string[], metadata?: KVMap, runType?: string, name?: string): {
151
+ _createRunForChainStart(chain: Serialized, inputs: ChainValues, runId: string, parentRunId?: string, tags?: string[], metadata?: KVMap, runType?: string, name?: string, extra?: Record<string, unknown>): {
152
152
  name: string;
153
153
  run_type: string;
154
154
  extra?: KVMap | undefined;
@@ -1 +1 @@
1
- {"version":3,"file":"base.d.cts","names":["KVMap","BaseRun","RunTree","ChainValues","AgentAction","AgentFinish","LLMResult","BaseMessage","Serialized","BaseCallbackHandler","BaseCallbackHandlerInput","HandleLLMNewTokenCallbackFields","NewTokenIndices","Document","RunType","Run","Record","Array","AgentRun","isBaseTracer","BaseTracer","Map","Promise","langsmith_schemas0","Attachments"],"sources":["../../src/tracers/base.d.ts"],"sourcesContent":["import { KVMap, BaseRun } from \"langsmith/schemas\";\nimport { RunTree } from \"langsmith/run_trees\";\nimport type { ChainValues } from \"../utils/types/index.js\";\nimport type { AgentAction, AgentFinish } from \"../agents.js\";\nimport type { LLMResult } from \"../outputs.js\";\nimport type { BaseMessage } from \"../messages/base.js\";\nimport { Serialized } from \"../load/serializable.js\";\nimport { BaseCallbackHandler, BaseCallbackHandlerInput, HandleLLMNewTokenCallbackFields, NewTokenIndices } from \"../callbacks/base.js\";\nimport type { Document } from \"../documents/document.js\";\nexport type RunType = string;\nexport interface Run extends BaseRun {\n id: string;\n start_time: number;\n end_time?: number;\n execution_order: number;\n child_runs: this[];\n child_execution_order: number;\n events: Array<{\n name: string;\n time: string;\n kwargs?: Record<string, unknown>;\n }>;\n trace_id?: string;\n dotted_order?: string;\n /** @internal */\n _serialized_start_time?: string;\n}\nexport interface AgentRun extends Run {\n actions: AgentAction[];\n}\nexport declare function isBaseTracer(x: BaseCallbackHandler): x is BaseTracer;\nexport declare abstract class BaseTracer extends BaseCallbackHandler {\n /** @deprecated Use `runTreeMap` instead. */\n protected runMap: Map<string, Run>;\n protected runTreeMap: Map<string, RunTree>;\n protected usesRunTreeMap: boolean;\n constructor(_fields?: BaseCallbackHandlerInput);\n copy(): this;\n protected getRunById(runId?: string): Run | undefined;\n protected stringifyError(error: unknown): string;\n protected abstract persistRun(run: Run): Promise<void>;\n protected _addChildRun(parentRun: Run, childRun: Run): void;\n _addRunToRunMap(run: Run): {\n name: string;\n run_type: string;\n extra?: KVMap | undefined;\n error?: string | undefined;\n serialized?: object | undefined;\n inputs: KVMap;\n outputs?: KVMap | undefined;\n reference_example_id?: string | undefined;\n parent_run_id?: string | undefined;\n tags?: string[] | undefined;\n attachments?: import(\"langsmith/schemas\").Attachments | undefined;\n id: string;\n start_time: number;\n end_time?: number | undefined;\n execution_order: number;\n child_runs: Run[];\n child_execution_order: number;\n events: {\n name: string;\n time: string;\n kwargs?: Record<string, unknown> | undefined;\n }[];\n trace_id?: string | undefined;\n dotted_order?: string | undefined;\n /** @internal */\n _serialized_start_time?: string | undefined;\n };\n protected _endTrace(run: Run): Promise<void>;\n protected _getExecutionOrder(parentRunId: string | undefined): number;\n /**\n * Create and add a run to the run map for LLM start events.\n * This must sometimes be done synchronously to avoid race conditions\n * when callbacks are backgrounded, so we expose it as a separate method here.\n */\n _createRunForLLMStart(llm: Serialized, prompts: string[], runId: string, parentRunId?: string, extraParams?: KVMap, tags?: string[], metadata?: KVMap, name?: string): {\n name: string;\n run_type: string;\n extra?: KVMap | undefined;\n error?: string | undefined;\n serialized?: object | undefined;\n inputs: KVMap;\n outputs?: KVMap | undefined;\n reference_example_id?: string | undefined;\n parent_run_id?: string | undefined;\n tags?: string[] | undefined;\n attachments?: import(\"langsmith/schemas\").Attachments | undefined;\n id: string;\n start_time: number;\n end_time?: number | undefined;\n execution_order: number;\n child_runs: Run[];\n child_execution_order: number;\n events: {\n name: string;\n time: string;\n kwargs?: Record<string, unknown> | undefined;\n }[];\n trace_id?: string | undefined;\n dotted_order?: string | undefined;\n /** @internal */\n _serialized_start_time?: string | undefined;\n };\n handleLLMStart(llm: Serialized, prompts: string[], runId: string, parentRunId?: string, extraParams?: KVMap, tags?: string[], metadata?: KVMap, name?: string): Promise<Run>;\n /**\n * Create and add a run to the run map for chat model start events.\n * This must sometimes be done synchronously to avoid race conditions\n * when callbacks are backgrounded, so we expose it as a separate method here.\n */\n _createRunForChatModelStart(llm: Serialized, messages: BaseMessage[][], runId: string, parentRunId?: string, extraParams?: KVMap, tags?: string[], metadata?: KVMap, name?: string): {\n name: string;\n run_type: string;\n extra?: KVMap | undefined;\n error?: string | undefined;\n serialized?: object | undefined;\n inputs: KVMap;\n outputs?: KVMap | undefined;\n reference_example_id?: string | undefined;\n parent_run_id?: string | undefined;\n tags?: string[] | undefined;\n attachments?: import(\"langsmith/schemas\").Attachments | undefined;\n id: string;\n start_time: number;\n end_time?: number | undefined;\n execution_order: number;\n child_runs: Run[];\n child_execution_order: number;\n events: {\n name: string;\n time: string;\n kwargs?: Record<string, unknown> | undefined;\n }[];\n trace_id?: string | undefined;\n dotted_order?: string | undefined;\n /** @internal */\n _serialized_start_time?: string | undefined;\n };\n handleChatModelStart(llm: Serialized, messages: BaseMessage[][], runId: string, parentRunId?: string, extraParams?: KVMap, tags?: string[], metadata?: KVMap, name?: string): Promise<Run>;\n handleLLMEnd(output: LLMResult, runId: string, _parentRunId?: string, _tags?: string[], extraParams?: Record<string, unknown>): Promise<Run>;\n handleLLMError(error: unknown, runId: string, _parentRunId?: string, _tags?: string[], extraParams?: Record<string, unknown>): Promise<Run>;\n /**\n * Create and add a run to the run map for chain start events.\n * This must sometimes be done synchronously to avoid race conditions\n * when callbacks are backgrounded, so we expose it as a separate method here.\n */\n _createRunForChainStart(chain: Serialized, inputs: ChainValues, runId: string, parentRunId?: string, tags?: string[], metadata?: KVMap, runType?: string, name?: string): {\n name: string;\n run_type: string;\n extra?: KVMap | undefined;\n error?: string | undefined;\n serialized?: object | undefined;\n inputs: KVMap;\n outputs?: KVMap | undefined;\n reference_example_id?: string | undefined;\n parent_run_id?: string | undefined;\n tags?: string[] | undefined;\n attachments?: import(\"langsmith/schemas\").Attachments | undefined;\n id: string;\n start_time: number;\n end_time?: number | undefined;\n execution_order: number;\n child_runs: Run[];\n child_execution_order: number;\n events: {\n name: string;\n time: string;\n kwargs?: Record<string, unknown> | undefined;\n }[];\n trace_id?: string | undefined;\n dotted_order?: string | undefined;\n /** @internal */\n _serialized_start_time?: string | undefined;\n };\n handleChainStart(chain: Serialized, inputs: ChainValues, runId: string, parentRunId?: string, tags?: string[], metadata?: KVMap, runType?: string, name?: string): Promise<Run>;\n handleChainEnd(outputs: ChainValues, runId: string, _parentRunId?: string, _tags?: string[], kwargs?: {\n inputs?: Record<string, unknown>;\n }): Promise<Run>;\n handleChainError(error: unknown, runId: string, _parentRunId?: string, _tags?: string[], kwargs?: {\n inputs?: Record<string, unknown>;\n }): Promise<Run>;\n /**\n * Create and add a run to the run map for tool start events.\n * This must sometimes be done synchronously to avoid race conditions\n * when callbacks are backgrounded, so we expose it as a separate method here.\n */\n _createRunForToolStart(tool: Serialized, input: string, runId: string, parentRunId?: string, tags?: string[], metadata?: KVMap, name?: string): {\n name: string;\n run_type: string;\n extra?: KVMap | undefined;\n error?: string | undefined;\n serialized?: object | undefined;\n inputs: KVMap;\n outputs?: KVMap | undefined;\n reference_example_id?: string | undefined;\n parent_run_id?: string | undefined;\n tags?: string[] | undefined;\n attachments?: import(\"langsmith/schemas\").Attachments | undefined;\n id: string;\n start_time: number;\n end_time?: number | undefined;\n execution_order: number;\n child_runs: Run[];\n child_execution_order: number;\n events: {\n name: string;\n time: string;\n kwargs?: Record<string, unknown> | undefined;\n }[];\n trace_id?: string | undefined;\n dotted_order?: string | undefined;\n /** @internal */\n _serialized_start_time?: string | undefined;\n };\n handleToolStart(tool: Serialized, input: string, runId: string, parentRunId?: string, tags?: string[], metadata?: KVMap, name?: string): Promise<Run>;\n handleToolEnd(output: any, runId: string): Promise<Run>;\n handleToolError(error: unknown, runId: string): Promise<Run>;\n handleAgentAction(action: AgentAction, runId: string): Promise<void>;\n handleAgentEnd(action: AgentFinish, runId: string): Promise<void>;\n /**\n * Create and add a run to the run map for retriever start events.\n * This must sometimes be done synchronously to avoid race conditions\n * when callbacks are backgrounded, so we expose it as a separate method here.\n */\n _createRunForRetrieverStart(retriever: Serialized, query: string, runId: string, parentRunId?: string, tags?: string[], metadata?: KVMap, name?: string): {\n name: string;\n run_type: string;\n extra?: KVMap | undefined;\n error?: string | undefined;\n serialized?: object | undefined;\n inputs: KVMap;\n outputs?: KVMap | undefined;\n reference_example_id?: string | undefined;\n parent_run_id?: string | undefined;\n tags?: string[] | undefined;\n attachments?: import(\"langsmith/schemas\").Attachments | undefined;\n id: string;\n start_time: number;\n end_time?: number | undefined;\n execution_order: number;\n child_runs: Run[];\n child_execution_order: number;\n events: {\n name: string;\n time: string;\n kwargs?: Record<string, unknown> | undefined;\n }[];\n trace_id?: string | undefined;\n dotted_order?: string | undefined;\n /** @internal */\n _serialized_start_time?: string | undefined;\n };\n handleRetrieverStart(retriever: Serialized, query: string, runId: string, parentRunId?: string, tags?: string[], metadata?: KVMap, name?: string): Promise<Run>;\n handleRetrieverEnd(documents: Document<Record<string, unknown>>[], runId: string): Promise<Run>;\n handleRetrieverError(error: unknown, runId: string): Promise<Run>;\n handleText(text: string, runId: string): Promise<void>;\n handleLLMNewToken(token: string, idx: NewTokenIndices, runId: string, _parentRunId?: string, _tags?: string[], fields?: HandleLLMNewTokenCallbackFields): Promise<Run>;\n onRunCreate?(run: Run): void | Promise<void>;\n onRunUpdate?(run: Run): void | Promise<void>;\n onLLMStart?(run: Run): void | Promise<void>;\n onLLMEnd?(run: Run): void | Promise<void>;\n onLLMError?(run: Run): void | Promise<void>;\n onChainStart?(run: Run): void | Promise<void>;\n onChainEnd?(run: Run): void | Promise<void>;\n onChainError?(run: Run): void | Promise<void>;\n onToolStart?(run: Run): void | Promise<void>;\n onToolEnd?(run: Run): void | Promise<void>;\n onToolError?(run: Run): void | Promise<void>;\n onAgentAction?(run: Run): void | Promise<void>;\n onAgentEnd?(run: Run): void | Promise<void>;\n onRetrieverStart?(run: Run): void | Promise<void>;\n onRetrieverEnd?(run: Run): void | Promise<void>;\n onRetrieverError?(run: Run): void | Promise<void>;\n onText?(run: Run): void | Promise<void>;\n onLLMNewToken?(run: Run, token: string, kwargs?: {\n chunk: any;\n }): void | Promise<void>;\n}\n//# sourceMappingURL=base.d.ts.map"],"mappings":"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"}
1
+ {"version":3,"file":"base.d.cts","names":["KVMap","BaseRun","RunTree","ChainValues","AgentAction","AgentFinish","LLMResult","BaseMessage","Serialized","BaseCallbackHandler","BaseCallbackHandlerInput","HandleLLMNewTokenCallbackFields","NewTokenIndices","Document","RunType","Run","Record","Array","AgentRun","isBaseTracer","BaseTracer","Map","Promise","langsmith_schemas0","Attachments"],"sources":["../../src/tracers/base.d.ts"],"sourcesContent":["import { KVMap, BaseRun } from \"langsmith/schemas\";\nimport { RunTree } from \"langsmith/run_trees\";\nimport type { ChainValues } from \"../utils/types/index.js\";\nimport type { AgentAction, AgentFinish } from \"../agents.js\";\nimport type { LLMResult } from \"../outputs.js\";\nimport type { BaseMessage } from \"../messages/base.js\";\nimport { Serialized } from \"../load/serializable.js\";\nimport { BaseCallbackHandler, BaseCallbackHandlerInput, HandleLLMNewTokenCallbackFields, NewTokenIndices } from \"../callbacks/base.js\";\nimport type { Document } from \"../documents/document.js\";\nexport type RunType = string;\nexport interface Run extends BaseRun {\n id: string;\n start_time: number;\n end_time?: number;\n execution_order: number;\n child_runs: this[];\n child_execution_order: number;\n events: Array<{\n name: string;\n time: string;\n kwargs?: Record<string, unknown>;\n }>;\n trace_id?: string;\n dotted_order?: string;\n /** @internal */\n _serialized_start_time?: string;\n}\nexport interface AgentRun extends Run {\n actions: AgentAction[];\n}\nexport declare function isBaseTracer(x: BaseCallbackHandler): x is BaseTracer;\nexport declare abstract class BaseTracer extends BaseCallbackHandler {\n /** @deprecated Use `runTreeMap` instead. */\n protected runMap: Map<string, Run>;\n protected runTreeMap: Map<string, RunTree>;\n protected usesRunTreeMap: boolean;\n constructor(_fields?: BaseCallbackHandlerInput);\n copy(): this;\n protected getRunById(runId?: string): Run | undefined;\n protected stringifyError(error: unknown): string;\n protected abstract persistRun(run: Run): Promise<void>;\n protected _addChildRun(parentRun: Run, childRun: Run): void;\n _addRunToRunMap(run: Run): {\n name: string;\n run_type: string;\n extra?: KVMap | undefined;\n error?: string | undefined;\n serialized?: object | undefined;\n inputs: KVMap;\n outputs?: KVMap | undefined;\n reference_example_id?: string | undefined;\n parent_run_id?: string | undefined;\n tags?: string[] | undefined;\n attachments?: import(\"langsmith/schemas\").Attachments | undefined;\n id: string;\n start_time: number;\n end_time?: number | undefined;\n execution_order: number;\n child_runs: Run[];\n child_execution_order: number;\n events: {\n name: string;\n time: string;\n kwargs?: Record<string, unknown> | undefined;\n }[];\n trace_id?: string | undefined;\n dotted_order?: string | undefined;\n /** @internal */\n _serialized_start_time?: string | undefined;\n };\n protected _endTrace(run: Run): Promise<void>;\n protected _getExecutionOrder(parentRunId: string | undefined): number;\n /**\n * Create and add a run to the run map for LLM start events.\n * This must sometimes be done synchronously to avoid race conditions\n * when callbacks are backgrounded, so we expose it as a separate method here.\n */\n _createRunForLLMStart(llm: Serialized, prompts: string[], runId: string, parentRunId?: string, extraParams?: KVMap, tags?: string[], metadata?: KVMap, name?: string): {\n name: string;\n run_type: string;\n extra?: KVMap | undefined;\n error?: string | undefined;\n serialized?: object | undefined;\n inputs: KVMap;\n outputs?: KVMap | undefined;\n reference_example_id?: string | undefined;\n parent_run_id?: string | undefined;\n tags?: string[] | undefined;\n attachments?: import(\"langsmith/schemas\").Attachments | undefined;\n id: string;\n start_time: number;\n end_time?: number | undefined;\n execution_order: number;\n child_runs: Run[];\n child_execution_order: number;\n events: {\n name: string;\n time: string;\n kwargs?: Record<string, unknown> | undefined;\n }[];\n trace_id?: string | undefined;\n dotted_order?: string | undefined;\n /** @internal */\n _serialized_start_time?: string | undefined;\n };\n handleLLMStart(llm: Serialized, prompts: string[], runId: string, parentRunId?: string, extraParams?: KVMap, tags?: string[], metadata?: KVMap, name?: string): Promise<Run>;\n /**\n * Create and add a run to the run map for chat model start events.\n * This must sometimes be done synchronously to avoid race conditions\n * when callbacks are backgrounded, so we expose it as a separate method here.\n */\n _createRunForChatModelStart(llm: Serialized, messages: BaseMessage[][], runId: string, parentRunId?: string, extraParams?: KVMap, tags?: string[], metadata?: KVMap, name?: string): {\n name: string;\n run_type: string;\n extra?: KVMap | undefined;\n error?: string | undefined;\n serialized?: object | undefined;\n inputs: KVMap;\n outputs?: KVMap | undefined;\n reference_example_id?: string | undefined;\n parent_run_id?: string | undefined;\n tags?: string[] | undefined;\n attachments?: import(\"langsmith/schemas\").Attachments | undefined;\n id: string;\n start_time: number;\n end_time?: number | undefined;\n execution_order: number;\n child_runs: Run[];\n child_execution_order: number;\n events: {\n name: string;\n time: string;\n kwargs?: Record<string, unknown> | undefined;\n }[];\n trace_id?: string | undefined;\n dotted_order?: string | undefined;\n /** @internal */\n _serialized_start_time?: string | undefined;\n };\n handleChatModelStart(llm: Serialized, messages: BaseMessage[][], runId: string, parentRunId?: string, extraParams?: KVMap, tags?: string[], metadata?: KVMap, name?: string): Promise<Run>;\n handleLLMEnd(output: LLMResult, runId: string, _parentRunId?: string, _tags?: string[], extraParams?: Record<string, unknown>): Promise<Run>;\n handleLLMError(error: unknown, runId: string, _parentRunId?: string, _tags?: string[], extraParams?: Record<string, unknown>): Promise<Run>;\n /**\n * Create and add a run to the run map for chain start events.\n * This must sometimes be done synchronously to avoid race conditions\n * when callbacks are backgrounded, so we expose it as a separate method here.\n */\n _createRunForChainStart(chain: Serialized, inputs: ChainValues, runId: string, parentRunId?: string, tags?: string[], metadata?: KVMap, runType?: string, name?: string, extra?: Record<string, unknown>): {\n name: string;\n run_type: string;\n extra?: KVMap | undefined;\n error?: string | undefined;\n serialized?: object | undefined;\n inputs: KVMap;\n outputs?: KVMap | undefined;\n reference_example_id?: string | undefined;\n parent_run_id?: string | undefined;\n tags?: string[] | undefined;\n attachments?: import(\"langsmith/schemas\").Attachments | undefined;\n id: string;\n start_time: number;\n end_time?: number | undefined;\n execution_order: number;\n child_runs: Run[];\n child_execution_order: number;\n events: {\n name: string;\n time: string;\n kwargs?: Record<string, unknown> | undefined;\n }[];\n trace_id?: string | undefined;\n dotted_order?: string | undefined;\n /** @internal */\n _serialized_start_time?: string | undefined;\n };\n handleChainStart(chain: Serialized, inputs: ChainValues, runId: string, parentRunId?: string, tags?: string[], metadata?: KVMap, runType?: string, name?: string): Promise<Run>;\n handleChainEnd(outputs: ChainValues, runId: string, _parentRunId?: string, _tags?: string[], kwargs?: {\n inputs?: Record<string, unknown>;\n }): Promise<Run>;\n handleChainError(error: unknown, runId: string, _parentRunId?: string, _tags?: string[], kwargs?: {\n inputs?: Record<string, unknown>;\n }): Promise<Run>;\n /**\n * Create and add a run to the run map for tool start events.\n * This must sometimes be done synchronously to avoid race conditions\n * when callbacks are backgrounded, so we expose it as a separate method here.\n */\n _createRunForToolStart(tool: Serialized, input: string, runId: string, parentRunId?: string, tags?: string[], metadata?: KVMap, name?: string): {\n name: string;\n run_type: string;\n extra?: KVMap | undefined;\n error?: string | undefined;\n serialized?: object | undefined;\n inputs: KVMap;\n outputs?: KVMap | undefined;\n reference_example_id?: string | undefined;\n parent_run_id?: string | undefined;\n tags?: string[] | undefined;\n attachments?: import(\"langsmith/schemas\").Attachments | undefined;\n id: string;\n start_time: number;\n end_time?: number | undefined;\n execution_order: number;\n child_runs: Run[];\n child_execution_order: number;\n events: {\n name: string;\n time: string;\n kwargs?: Record<string, unknown> | undefined;\n }[];\n trace_id?: string | undefined;\n dotted_order?: string | undefined;\n /** @internal */\n _serialized_start_time?: string | undefined;\n };\n handleToolStart(tool: Serialized, input: string, runId: string, parentRunId?: string, tags?: string[], metadata?: KVMap, name?: string): Promise<Run>;\n handleToolEnd(output: any, runId: string): Promise<Run>;\n handleToolError(error: unknown, runId: string): Promise<Run>;\n handleAgentAction(action: AgentAction, runId: string): Promise<void>;\n handleAgentEnd(action: AgentFinish, runId: string): Promise<void>;\n /**\n * Create and add a run to the run map for retriever start events.\n * This must sometimes be done synchronously to avoid race conditions\n * when callbacks are backgrounded, so we expose it as a separate method here.\n */\n _createRunForRetrieverStart(retriever: Serialized, query: string, runId: string, parentRunId?: string, tags?: string[], metadata?: KVMap, name?: string): {\n name: string;\n run_type: string;\n extra?: KVMap | undefined;\n error?: string | undefined;\n serialized?: object | undefined;\n inputs: KVMap;\n outputs?: KVMap | undefined;\n reference_example_id?: string | undefined;\n parent_run_id?: string | undefined;\n tags?: string[] | undefined;\n attachments?: import(\"langsmith/schemas\").Attachments | undefined;\n id: string;\n start_time: number;\n end_time?: number | undefined;\n execution_order: number;\n child_runs: Run[];\n child_execution_order: number;\n events: {\n name: string;\n time: string;\n kwargs?: Record<string, unknown> | undefined;\n }[];\n trace_id?: string | undefined;\n dotted_order?: string | undefined;\n /** @internal */\n _serialized_start_time?: string | undefined;\n };\n handleRetrieverStart(retriever: Serialized, query: string, runId: string, parentRunId?: string, tags?: string[], metadata?: KVMap, name?: string): Promise<Run>;\n handleRetrieverEnd(documents: Document<Record<string, unknown>>[], runId: string): Promise<Run>;\n handleRetrieverError(error: unknown, runId: string): Promise<Run>;\n handleText(text: string, runId: string): Promise<void>;\n handleLLMNewToken(token: string, idx: NewTokenIndices, runId: string, _parentRunId?: string, _tags?: string[], fields?: HandleLLMNewTokenCallbackFields): Promise<Run>;\n onRunCreate?(run: Run): void | Promise<void>;\n onRunUpdate?(run: Run): void | Promise<void>;\n onLLMStart?(run: Run): void | Promise<void>;\n onLLMEnd?(run: Run): void | Promise<void>;\n onLLMError?(run: Run): void | Promise<void>;\n onChainStart?(run: Run): void | Promise<void>;\n onChainEnd?(run: Run): void | Promise<void>;\n onChainError?(run: Run): void | Promise<void>;\n onToolStart?(run: Run): void | Promise<void>;\n onToolEnd?(run: Run): void | Promise<void>;\n onToolError?(run: Run): void | Promise<void>;\n onAgentAction?(run: Run): void | Promise<void>;\n onAgentEnd?(run: Run): void | Promise<void>;\n onRetrieverStart?(run: Run): void | Promise<void>;\n onRetrieverEnd?(run: Run): void | Promise<void>;\n onRetrieverError?(run: Run): void | Promise<void>;\n onText?(run: Run): void | Promise<void>;\n onLLMNewToken?(run: Run, token: string, kwargs?: {\n chunk: any;\n }): void | Promise<void>;\n}\n//# sourceMappingURL=base.d.ts.map"],"mappings":"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"}
@@ -148,7 +148,7 @@ declare abstract class BaseTracer extends BaseCallbackHandler {
148
148
  * This must sometimes be done synchronously to avoid race conditions
149
149
  * when callbacks are backgrounded, so we expose it as a separate method here.
150
150
  */
151
- _createRunForChainStart(chain: Serialized, inputs: ChainValues, runId: string, parentRunId?: string, tags?: string[], metadata?: KVMap, runType?: string, name?: string): {
151
+ _createRunForChainStart(chain: Serialized, inputs: ChainValues, runId: string, parentRunId?: string, tags?: string[], metadata?: KVMap, runType?: string, name?: string, extra?: Record<string, unknown>): {
152
152
  name: string;
153
153
  run_type: string;
154
154
  extra?: KVMap | undefined;
@@ -1 +1 @@
1
- {"version":3,"file":"base.d.ts","names":["KVMap","BaseRun","RunTree","ChainValues","AgentAction","AgentFinish","LLMResult","BaseMessage","Serialized","BaseCallbackHandler","BaseCallbackHandlerInput","HandleLLMNewTokenCallbackFields","NewTokenIndices","Document","RunType","Run","Record","Array","AgentRun","isBaseTracer","BaseTracer","Map","Promise","langsmith_schemas0","Attachments"],"sources":["../../src/tracers/base.d.ts"],"sourcesContent":["import { KVMap, BaseRun } from \"langsmith/schemas\";\nimport { RunTree } from \"langsmith/run_trees\";\nimport type { ChainValues } from \"../utils/types/index.js\";\nimport type { AgentAction, AgentFinish } from \"../agents.js\";\nimport type { LLMResult } from \"../outputs.js\";\nimport type { BaseMessage } from \"../messages/base.js\";\nimport { Serialized } from \"../load/serializable.js\";\nimport { BaseCallbackHandler, BaseCallbackHandlerInput, HandleLLMNewTokenCallbackFields, NewTokenIndices } from \"../callbacks/base.js\";\nimport type { Document } from \"../documents/document.js\";\nexport type RunType = string;\nexport interface Run extends BaseRun {\n id: string;\n start_time: number;\n end_time?: number;\n execution_order: number;\n child_runs: this[];\n child_execution_order: number;\n events: Array<{\n name: string;\n time: string;\n kwargs?: Record<string, unknown>;\n }>;\n trace_id?: string;\n dotted_order?: string;\n /** @internal */\n _serialized_start_time?: string;\n}\nexport interface AgentRun extends Run {\n actions: AgentAction[];\n}\nexport declare function isBaseTracer(x: BaseCallbackHandler): x is BaseTracer;\nexport declare abstract class BaseTracer extends BaseCallbackHandler {\n /** @deprecated Use `runTreeMap` instead. */\n protected runMap: Map<string, Run>;\n protected runTreeMap: Map<string, RunTree>;\n protected usesRunTreeMap: boolean;\n constructor(_fields?: BaseCallbackHandlerInput);\n copy(): this;\n protected getRunById(runId?: string): Run | undefined;\n protected stringifyError(error: unknown): string;\n protected abstract persistRun(run: Run): Promise<void>;\n protected _addChildRun(parentRun: Run, childRun: Run): void;\n _addRunToRunMap(run: Run): {\n name: string;\n run_type: string;\n extra?: KVMap | undefined;\n error?: string | undefined;\n serialized?: object | undefined;\n inputs: KVMap;\n outputs?: KVMap | undefined;\n reference_example_id?: string | undefined;\n parent_run_id?: string | undefined;\n tags?: string[] | undefined;\n attachments?: import(\"langsmith/schemas\").Attachments | undefined;\n id: string;\n start_time: number;\n end_time?: number | undefined;\n execution_order: number;\n child_runs: Run[];\n child_execution_order: number;\n events: {\n name: string;\n time: string;\n kwargs?: Record<string, unknown> | undefined;\n }[];\n trace_id?: string | undefined;\n dotted_order?: string | undefined;\n /** @internal */\n _serialized_start_time?: string | undefined;\n };\n protected _endTrace(run: Run): Promise<void>;\n protected _getExecutionOrder(parentRunId: string | undefined): number;\n /**\n * Create and add a run to the run map for LLM start events.\n * This must sometimes be done synchronously to avoid race conditions\n * when callbacks are backgrounded, so we expose it as a separate method here.\n */\n _createRunForLLMStart(llm: Serialized, prompts: string[], runId: string, parentRunId?: string, extraParams?: KVMap, tags?: string[], metadata?: KVMap, name?: string): {\n name: string;\n run_type: string;\n extra?: KVMap | undefined;\n error?: string | undefined;\n serialized?: object | undefined;\n inputs: KVMap;\n outputs?: KVMap | undefined;\n reference_example_id?: string | undefined;\n parent_run_id?: string | undefined;\n tags?: string[] | undefined;\n attachments?: import(\"langsmith/schemas\").Attachments | undefined;\n id: string;\n start_time: number;\n end_time?: number | undefined;\n execution_order: number;\n child_runs: Run[];\n child_execution_order: number;\n events: {\n name: string;\n time: string;\n kwargs?: Record<string, unknown> | undefined;\n }[];\n trace_id?: string | undefined;\n dotted_order?: string | undefined;\n /** @internal */\n _serialized_start_time?: string | undefined;\n };\n handleLLMStart(llm: Serialized, prompts: string[], runId: string, parentRunId?: string, extraParams?: KVMap, tags?: string[], metadata?: KVMap, name?: string): Promise<Run>;\n /**\n * Create and add a run to the run map for chat model start events.\n * This must sometimes be done synchronously to avoid race conditions\n * when callbacks are backgrounded, so we expose it as a separate method here.\n */\n _createRunForChatModelStart(llm: Serialized, messages: BaseMessage[][], runId: string, parentRunId?: string, extraParams?: KVMap, tags?: string[], metadata?: KVMap, name?: string): {\n name: string;\n run_type: string;\n extra?: KVMap | undefined;\n error?: string | undefined;\n serialized?: object | undefined;\n inputs: KVMap;\n outputs?: KVMap | undefined;\n reference_example_id?: string | undefined;\n parent_run_id?: string | undefined;\n tags?: string[] | undefined;\n attachments?: import(\"langsmith/schemas\").Attachments | undefined;\n id: string;\n start_time: number;\n end_time?: number | undefined;\n execution_order: number;\n child_runs: Run[];\n child_execution_order: number;\n events: {\n name: string;\n time: string;\n kwargs?: Record<string, unknown> | undefined;\n }[];\n trace_id?: string | undefined;\n dotted_order?: string | undefined;\n /** @internal */\n _serialized_start_time?: string | undefined;\n };\n handleChatModelStart(llm: Serialized, messages: BaseMessage[][], runId: string, parentRunId?: string, extraParams?: KVMap, tags?: string[], metadata?: KVMap, name?: string): Promise<Run>;\n handleLLMEnd(output: LLMResult, runId: string, _parentRunId?: string, _tags?: string[], extraParams?: Record<string, unknown>): Promise<Run>;\n handleLLMError(error: unknown, runId: string, _parentRunId?: string, _tags?: string[], extraParams?: Record<string, unknown>): Promise<Run>;\n /**\n * Create and add a run to the run map for chain start events.\n * This must sometimes be done synchronously to avoid race conditions\n * when callbacks are backgrounded, so we expose it as a separate method here.\n */\n _createRunForChainStart(chain: Serialized, inputs: ChainValues, runId: string, parentRunId?: string, tags?: string[], metadata?: KVMap, runType?: string, name?: string): {\n name: string;\n run_type: string;\n extra?: KVMap | undefined;\n error?: string | undefined;\n serialized?: object | undefined;\n inputs: KVMap;\n outputs?: KVMap | undefined;\n reference_example_id?: string | undefined;\n parent_run_id?: string | undefined;\n tags?: string[] | undefined;\n attachments?: import(\"langsmith/schemas\").Attachments | undefined;\n id: string;\n start_time: number;\n end_time?: number | undefined;\n execution_order: number;\n child_runs: Run[];\n child_execution_order: number;\n events: {\n name: string;\n time: string;\n kwargs?: Record<string, unknown> | undefined;\n }[];\n trace_id?: string | undefined;\n dotted_order?: string | undefined;\n /** @internal */\n _serialized_start_time?: string | undefined;\n };\n handleChainStart(chain: Serialized, inputs: ChainValues, runId: string, parentRunId?: string, tags?: string[], metadata?: KVMap, runType?: string, name?: string): Promise<Run>;\n handleChainEnd(outputs: ChainValues, runId: string, _parentRunId?: string, _tags?: string[], kwargs?: {\n inputs?: Record<string, unknown>;\n }): Promise<Run>;\n handleChainError(error: unknown, runId: string, _parentRunId?: string, _tags?: string[], kwargs?: {\n inputs?: Record<string, unknown>;\n }): Promise<Run>;\n /**\n * Create and add a run to the run map for tool start events.\n * This must sometimes be done synchronously to avoid race conditions\n * when callbacks are backgrounded, so we expose it as a separate method here.\n */\n _createRunForToolStart(tool: Serialized, input: string, runId: string, parentRunId?: string, tags?: string[], metadata?: KVMap, name?: string): {\n name: string;\n run_type: string;\n extra?: KVMap | undefined;\n error?: string | undefined;\n serialized?: object | undefined;\n inputs: KVMap;\n outputs?: KVMap | undefined;\n reference_example_id?: string | undefined;\n parent_run_id?: string | undefined;\n tags?: string[] | undefined;\n attachments?: import(\"langsmith/schemas\").Attachments | undefined;\n id: string;\n start_time: number;\n end_time?: number | undefined;\n execution_order: number;\n child_runs: Run[];\n child_execution_order: number;\n events: {\n name: string;\n time: string;\n kwargs?: Record<string, unknown> | undefined;\n }[];\n trace_id?: string | undefined;\n dotted_order?: string | undefined;\n /** @internal */\n _serialized_start_time?: string | undefined;\n };\n handleToolStart(tool: Serialized, input: string, runId: string, parentRunId?: string, tags?: string[], metadata?: KVMap, name?: string): Promise<Run>;\n handleToolEnd(output: any, runId: string): Promise<Run>;\n handleToolError(error: unknown, runId: string): Promise<Run>;\n handleAgentAction(action: AgentAction, runId: string): Promise<void>;\n handleAgentEnd(action: AgentFinish, runId: string): Promise<void>;\n /**\n * Create and add a run to the run map for retriever start events.\n * This must sometimes be done synchronously to avoid race conditions\n * when callbacks are backgrounded, so we expose it as a separate method here.\n */\n _createRunForRetrieverStart(retriever: Serialized, query: string, runId: string, parentRunId?: string, tags?: string[], metadata?: KVMap, name?: string): {\n name: string;\n run_type: string;\n extra?: KVMap | undefined;\n error?: string | undefined;\n serialized?: object | undefined;\n inputs: KVMap;\n outputs?: KVMap | undefined;\n reference_example_id?: string | undefined;\n parent_run_id?: string | undefined;\n tags?: string[] | undefined;\n attachments?: import(\"langsmith/schemas\").Attachments | undefined;\n id: string;\n start_time: number;\n end_time?: number | undefined;\n execution_order: number;\n child_runs: Run[];\n child_execution_order: number;\n events: {\n name: string;\n time: string;\n kwargs?: Record<string, unknown> | undefined;\n }[];\n trace_id?: string | undefined;\n dotted_order?: string | undefined;\n /** @internal */\n _serialized_start_time?: string | undefined;\n };\n handleRetrieverStart(retriever: Serialized, query: string, runId: string, parentRunId?: string, tags?: string[], metadata?: KVMap, name?: string): Promise<Run>;\n handleRetrieverEnd(documents: Document<Record<string, unknown>>[], runId: string): Promise<Run>;\n handleRetrieverError(error: unknown, runId: string): Promise<Run>;\n handleText(text: string, runId: string): Promise<void>;\n handleLLMNewToken(token: string, idx: NewTokenIndices, runId: string, _parentRunId?: string, _tags?: string[], fields?: HandleLLMNewTokenCallbackFields): Promise<Run>;\n onRunCreate?(run: Run): void | Promise<void>;\n onRunUpdate?(run: Run): void | Promise<void>;\n onLLMStart?(run: Run): void | Promise<void>;\n onLLMEnd?(run: Run): void | Promise<void>;\n onLLMError?(run: Run): void | Promise<void>;\n onChainStart?(run: Run): void | Promise<void>;\n onChainEnd?(run: Run): void | Promise<void>;\n onChainError?(run: Run): void | Promise<void>;\n onToolStart?(run: Run): void | Promise<void>;\n onToolEnd?(run: Run): void | Promise<void>;\n onToolError?(run: Run): void | Promise<void>;\n onAgentAction?(run: Run): void | Promise<void>;\n onAgentEnd?(run: Run): void | Promise<void>;\n onRetrieverStart?(run: Run): void | Promise<void>;\n onRetrieverEnd?(run: Run): void | Promise<void>;\n onRetrieverError?(run: Run): void | Promise<void>;\n onText?(run: Run): void | Promise<void>;\n onLLMNewToken?(run: Run, token: string, kwargs?: {\n chunk: any;\n }): void | Promise<void>;\n}\n//# sourceMappingURL=base.d.ts.map"],"mappings":"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"}
1
+ {"version":3,"file":"base.d.ts","names":["KVMap","BaseRun","RunTree","ChainValues","AgentAction","AgentFinish","LLMResult","BaseMessage","Serialized","BaseCallbackHandler","BaseCallbackHandlerInput","HandleLLMNewTokenCallbackFields","NewTokenIndices","Document","RunType","Run","Record","Array","AgentRun","isBaseTracer","BaseTracer","Map","Promise","langsmith_schemas0","Attachments"],"sources":["../../src/tracers/base.d.ts"],"sourcesContent":["import { KVMap, BaseRun } from \"langsmith/schemas\";\nimport { RunTree } from \"langsmith/run_trees\";\nimport type { ChainValues } from \"../utils/types/index.js\";\nimport type { AgentAction, AgentFinish } from \"../agents.js\";\nimport type { LLMResult } from \"../outputs.js\";\nimport type { BaseMessage } from \"../messages/base.js\";\nimport { Serialized } from \"../load/serializable.js\";\nimport { BaseCallbackHandler, BaseCallbackHandlerInput, HandleLLMNewTokenCallbackFields, NewTokenIndices } from \"../callbacks/base.js\";\nimport type { Document } from \"../documents/document.js\";\nexport type RunType = string;\nexport interface Run extends BaseRun {\n id: string;\n start_time: number;\n end_time?: number;\n execution_order: number;\n child_runs: this[];\n child_execution_order: number;\n events: Array<{\n name: string;\n time: string;\n kwargs?: Record<string, unknown>;\n }>;\n trace_id?: string;\n dotted_order?: string;\n /** @internal */\n _serialized_start_time?: string;\n}\nexport interface AgentRun extends Run {\n actions: AgentAction[];\n}\nexport declare function isBaseTracer(x: BaseCallbackHandler): x is BaseTracer;\nexport declare abstract class BaseTracer extends BaseCallbackHandler {\n /** @deprecated Use `runTreeMap` instead. */\n protected runMap: Map<string, Run>;\n protected runTreeMap: Map<string, RunTree>;\n protected usesRunTreeMap: boolean;\n constructor(_fields?: BaseCallbackHandlerInput);\n copy(): this;\n protected getRunById(runId?: string): Run | undefined;\n protected stringifyError(error: unknown): string;\n protected abstract persistRun(run: Run): Promise<void>;\n protected _addChildRun(parentRun: Run, childRun: Run): void;\n _addRunToRunMap(run: Run): {\n name: string;\n run_type: string;\n extra?: KVMap | undefined;\n error?: string | undefined;\n serialized?: object | undefined;\n inputs: KVMap;\n outputs?: KVMap | undefined;\n reference_example_id?: string | undefined;\n parent_run_id?: string | undefined;\n tags?: string[] | undefined;\n attachments?: import(\"langsmith/schemas\").Attachments | undefined;\n id: string;\n start_time: number;\n end_time?: number | undefined;\n execution_order: number;\n child_runs: Run[];\n child_execution_order: number;\n events: {\n name: string;\n time: string;\n kwargs?: Record<string, unknown> | undefined;\n }[];\n trace_id?: string | undefined;\n dotted_order?: string | undefined;\n /** @internal */\n _serialized_start_time?: string | undefined;\n };\n protected _endTrace(run: Run): Promise<void>;\n protected _getExecutionOrder(parentRunId: string | undefined): number;\n /**\n * Create and add a run to the run map for LLM start events.\n * This must sometimes be done synchronously to avoid race conditions\n * when callbacks are backgrounded, so we expose it as a separate method here.\n */\n _createRunForLLMStart(llm: Serialized, prompts: string[], runId: string, parentRunId?: string, extraParams?: KVMap, tags?: string[], metadata?: KVMap, name?: string): {\n name: string;\n run_type: string;\n extra?: KVMap | undefined;\n error?: string | undefined;\n serialized?: object | undefined;\n inputs: KVMap;\n outputs?: KVMap | undefined;\n reference_example_id?: string | undefined;\n parent_run_id?: string | undefined;\n tags?: string[] | undefined;\n attachments?: import(\"langsmith/schemas\").Attachments | undefined;\n id: string;\n start_time: number;\n end_time?: number | undefined;\n execution_order: number;\n child_runs: Run[];\n child_execution_order: number;\n events: {\n name: string;\n time: string;\n kwargs?: Record<string, unknown> | undefined;\n }[];\n trace_id?: string | undefined;\n dotted_order?: string | undefined;\n /** @internal */\n _serialized_start_time?: string | undefined;\n };\n handleLLMStart(llm: Serialized, prompts: string[], runId: string, parentRunId?: string, extraParams?: KVMap, tags?: string[], metadata?: KVMap, name?: string): Promise<Run>;\n /**\n * Create and add a run to the run map for chat model start events.\n * This must sometimes be done synchronously to avoid race conditions\n * when callbacks are backgrounded, so we expose it as a separate method here.\n */\n _createRunForChatModelStart(llm: Serialized, messages: BaseMessage[][], runId: string, parentRunId?: string, extraParams?: KVMap, tags?: string[], metadata?: KVMap, name?: string): {\n name: string;\n run_type: string;\n extra?: KVMap | undefined;\n error?: string | undefined;\n serialized?: object | undefined;\n inputs: KVMap;\n outputs?: KVMap | undefined;\n reference_example_id?: string | undefined;\n parent_run_id?: string | undefined;\n tags?: string[] | undefined;\n attachments?: import(\"langsmith/schemas\").Attachments | undefined;\n id: string;\n start_time: number;\n end_time?: number | undefined;\n execution_order: number;\n child_runs: Run[];\n child_execution_order: number;\n events: {\n name: string;\n time: string;\n kwargs?: Record<string, unknown> | undefined;\n }[];\n trace_id?: string | undefined;\n dotted_order?: string | undefined;\n /** @internal */\n _serialized_start_time?: string | undefined;\n };\n handleChatModelStart(llm: Serialized, messages: BaseMessage[][], runId: string, parentRunId?: string, extraParams?: KVMap, tags?: string[], metadata?: KVMap, name?: string): Promise<Run>;\n handleLLMEnd(output: LLMResult, runId: string, _parentRunId?: string, _tags?: string[], extraParams?: Record<string, unknown>): Promise<Run>;\n handleLLMError(error: unknown, runId: string, _parentRunId?: string, _tags?: string[], extraParams?: Record<string, unknown>): Promise<Run>;\n /**\n * Create and add a run to the run map for chain start events.\n * This must sometimes be done synchronously to avoid race conditions\n * when callbacks are backgrounded, so we expose it as a separate method here.\n */\n _createRunForChainStart(chain: Serialized, inputs: ChainValues, runId: string, parentRunId?: string, tags?: string[], metadata?: KVMap, runType?: string, name?: string, extra?: Record<string, unknown>): {\n name: string;\n run_type: string;\n extra?: KVMap | undefined;\n error?: string | undefined;\n serialized?: object | undefined;\n inputs: KVMap;\n outputs?: KVMap | undefined;\n reference_example_id?: string | undefined;\n parent_run_id?: string | undefined;\n tags?: string[] | undefined;\n attachments?: import(\"langsmith/schemas\").Attachments | undefined;\n id: string;\n start_time: number;\n end_time?: number | undefined;\n execution_order: number;\n child_runs: Run[];\n child_execution_order: number;\n events: {\n name: string;\n time: string;\n kwargs?: Record<string, unknown> | undefined;\n }[];\n trace_id?: string | undefined;\n dotted_order?: string | undefined;\n /** @internal */\n _serialized_start_time?: string | undefined;\n };\n handleChainStart(chain: Serialized, inputs: ChainValues, runId: string, parentRunId?: string, tags?: string[], metadata?: KVMap, runType?: string, name?: string): Promise<Run>;\n handleChainEnd(outputs: ChainValues, runId: string, _parentRunId?: string, _tags?: string[], kwargs?: {\n inputs?: Record<string, unknown>;\n }): Promise<Run>;\n handleChainError(error: unknown, runId: string, _parentRunId?: string, _tags?: string[], kwargs?: {\n inputs?: Record<string, unknown>;\n }): Promise<Run>;\n /**\n * Create and add a run to the run map for tool start events.\n * This must sometimes be done synchronously to avoid race conditions\n * when callbacks are backgrounded, so we expose it as a separate method here.\n */\n _createRunForToolStart(tool: Serialized, input: string, runId: string, parentRunId?: string, tags?: string[], metadata?: KVMap, name?: string): {\n name: string;\n run_type: string;\n extra?: KVMap | undefined;\n error?: string | undefined;\n serialized?: object | undefined;\n inputs: KVMap;\n outputs?: KVMap | undefined;\n reference_example_id?: string | undefined;\n parent_run_id?: string | undefined;\n tags?: string[] | undefined;\n attachments?: import(\"langsmith/schemas\").Attachments | undefined;\n id: string;\n start_time: number;\n end_time?: number | undefined;\n execution_order: number;\n child_runs: Run[];\n child_execution_order: number;\n events: {\n name: string;\n time: string;\n kwargs?: Record<string, unknown> | undefined;\n }[];\n trace_id?: string | undefined;\n dotted_order?: string | undefined;\n /** @internal */\n _serialized_start_time?: string | undefined;\n };\n handleToolStart(tool: Serialized, input: string, runId: string, parentRunId?: string, tags?: string[], metadata?: KVMap, name?: string): Promise<Run>;\n handleToolEnd(output: any, runId: string): Promise<Run>;\n handleToolError(error: unknown, runId: string): Promise<Run>;\n handleAgentAction(action: AgentAction, runId: string): Promise<void>;\n handleAgentEnd(action: AgentFinish, runId: string): Promise<void>;\n /**\n * Create and add a run to the run map for retriever start events.\n * This must sometimes be done synchronously to avoid race conditions\n * when callbacks are backgrounded, so we expose it as a separate method here.\n */\n _createRunForRetrieverStart(retriever: Serialized, query: string, runId: string, parentRunId?: string, tags?: string[], metadata?: KVMap, name?: string): {\n name: string;\n run_type: string;\n extra?: KVMap | undefined;\n error?: string | undefined;\n serialized?: object | undefined;\n inputs: KVMap;\n outputs?: KVMap | undefined;\n reference_example_id?: string | undefined;\n parent_run_id?: string | undefined;\n tags?: string[] | undefined;\n attachments?: import(\"langsmith/schemas\").Attachments | undefined;\n id: string;\n start_time: number;\n end_time?: number | undefined;\n execution_order: number;\n child_runs: Run[];\n child_execution_order: number;\n events: {\n name: string;\n time: string;\n kwargs?: Record<string, unknown> | undefined;\n }[];\n trace_id?: string | undefined;\n dotted_order?: string | undefined;\n /** @internal */\n _serialized_start_time?: string | undefined;\n };\n handleRetrieverStart(retriever: Serialized, query: string, runId: string, parentRunId?: string, tags?: string[], metadata?: KVMap, name?: string): Promise<Run>;\n handleRetrieverEnd(documents: Document<Record<string, unknown>>[], runId: string): Promise<Run>;\n handleRetrieverError(error: unknown, runId: string): Promise<Run>;\n handleText(text: string, runId: string): Promise<void>;\n handleLLMNewToken(token: string, idx: NewTokenIndices, runId: string, _parentRunId?: string, _tags?: string[], fields?: HandleLLMNewTokenCallbackFields): Promise<Run>;\n onRunCreate?(run: Run): void | Promise<void>;\n onRunUpdate?(run: Run): void | Promise<void>;\n onLLMStart?(run: Run): void | Promise<void>;\n onLLMEnd?(run: Run): void | Promise<void>;\n onLLMError?(run: Run): void | Promise<void>;\n onChainStart?(run: Run): void | Promise<void>;\n onChainEnd?(run: Run): void | Promise<void>;\n onChainError?(run: Run): void | Promise<void>;\n onToolStart?(run: Run): void | Promise<void>;\n onToolEnd?(run: Run): void | Promise<void>;\n onToolError?(run: Run): void | Promise<void>;\n onAgentAction?(run: Run): void | Promise<void>;\n onAgentEnd?(run: Run): void | Promise<void>;\n onRetrieverStart?(run: Run): void | Promise<void>;\n onRetrieverEnd?(run: Run): void | Promise<void>;\n onRetrieverError?(run: Run): void | Promise<void>;\n onText?(run: Run): void | Promise<void>;\n onLLMNewToken?(run: Run, token: string, kwargs?: {\n chunk: any;\n }): void | Promise<void>;\n}\n//# sourceMappingURL=base.d.ts.map"],"mappings":"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"}
@@ -210,7 +210,7 @@ var BaseTracer = class extends BaseCallbackHandler {
210
210
  * This must sometimes be done synchronously to avoid race conditions
211
211
  * when callbacks are backgrounded, so we expose it as a separate method here.
212
212
  */
213
- _createRunForChainStart(chain, inputs, runId, parentRunId, tags, metadata, runType, name) {
213
+ _createRunForChainStart(chain, inputs, runId, parentRunId, tags, metadata, runType, name, extra) {
214
214
  const execution_order = this._getExecutionOrder(parentRunId);
215
215
  const start_time = Date.now();
216
216
  const run = {
@@ -228,7 +228,10 @@ var BaseTracer = class extends BaseCallbackHandler {
228
228
  child_execution_order: execution_order,
229
229
  run_type: runType ?? "chain",
230
230
  child_runs: [],
231
- extra: metadata ? { metadata } : {},
231
+ extra: metadata ? {
232
+ ...extra,
233
+ metadata
234
+ } : { ...extra },
232
235
  tags: tags || []
233
236
  };
234
237
  return this._addRunToRunMap(run);