@langchain/core 1.0.0-alpha.6 → 1.0.0

This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
Files changed (245) hide show
  1. package/CHANGELOG.md +131 -0
  2. package/LICENSE +6 -6
  3. package/README.md +2 -23
  4. package/dist/agents.d.ts.map +1 -1
  5. package/dist/caches/base.d.cts.map +1 -1
  6. package/dist/callbacks/base.d.cts.map +1 -1
  7. package/dist/callbacks/base.d.ts.map +1 -1
  8. package/dist/callbacks/manager.cjs +9 -64
  9. package/dist/callbacks/manager.cjs.map +1 -1
  10. package/dist/callbacks/manager.d.cts +1 -23
  11. package/dist/callbacks/manager.d.cts.map +1 -1
  12. package/dist/callbacks/manager.d.ts +1 -23
  13. package/dist/callbacks/manager.d.ts.map +1 -1
  14. package/dist/callbacks/manager.js +10 -63
  15. package/dist/callbacks/manager.js.map +1 -1
  16. package/dist/chat_history.cjs +0 -4
  17. package/dist/chat_history.cjs.map +1 -1
  18. package/dist/chat_history.d.cts +1 -3
  19. package/dist/chat_history.d.cts.map +1 -1
  20. package/dist/chat_history.d.ts +1 -3
  21. package/dist/chat_history.d.ts.map +1 -1
  22. package/dist/chat_history.js +0 -4
  23. package/dist/chat_history.js.map +1 -1
  24. package/dist/document_loaders/base.cjs +1 -13
  25. package/dist/document_loaders/base.cjs.map +1 -1
  26. package/dist/document_loaders/base.d.cts +0 -9
  27. package/dist/document_loaders/base.d.cts.map +1 -1
  28. package/dist/document_loaders/base.d.ts +0 -9
  29. package/dist/document_loaders/base.d.ts.map +1 -1
  30. package/dist/document_loaders/base.js +1 -13
  31. package/dist/document_loaders/base.js.map +1 -1
  32. package/dist/document_loaders/langsmith.d.cts +1 -1
  33. package/dist/language_models/base.cjs.map +1 -1
  34. package/dist/language_models/base.d.cts +0 -16
  35. package/dist/language_models/base.d.cts.map +1 -1
  36. package/dist/language_models/base.d.ts +0 -16
  37. package/dist/language_models/base.d.ts.map +1 -1
  38. package/dist/language_models/base.js.map +1 -1
  39. package/dist/language_models/chat_models.cjs +10 -83
  40. package/dist/language_models/chat_models.cjs.map +1 -1
  41. package/dist/language_models/chat_models.d.cts +21 -55
  42. package/dist/language_models/chat_models.d.cts.map +1 -1
  43. package/dist/language_models/chat_models.d.ts +21 -55
  44. package/dist/language_models/chat_models.d.ts.map +1 -1
  45. package/dist/language_models/chat_models.js +11 -83
  46. package/dist/language_models/chat_models.js.map +1 -1
  47. package/dist/language_models/llms.cjs +0 -56
  48. package/dist/language_models/llms.cjs.map +1 -1
  49. package/dist/language_models/llms.d.cts +1 -43
  50. package/dist/language_models/llms.d.cts.map +1 -1
  51. package/dist/language_models/llms.d.ts +1 -43
  52. package/dist/language_models/llms.d.ts.map +1 -1
  53. package/dist/language_models/llms.js +0 -56
  54. package/dist/language_models/llms.js.map +1 -1
  55. package/dist/load/import_map.cjs +1 -7
  56. package/dist/load/import_map.cjs.map +1 -1
  57. package/dist/load/import_map.js +1 -7
  58. package/dist/load/import_map.js.map +1 -1
  59. package/dist/messages/ai.cjs +4 -0
  60. package/dist/messages/ai.cjs.map +1 -1
  61. package/dist/messages/ai.js +4 -0
  62. package/dist/messages/ai.js.map +1 -1
  63. package/dist/messages/block_translators/anthropic.cjs +191 -144
  64. package/dist/messages/block_translators/anthropic.cjs.map +1 -1
  65. package/dist/messages/block_translators/anthropic.js +191 -144
  66. package/dist/messages/block_translators/anthropic.js.map +1 -1
  67. package/dist/messages/block_translators/index.cjs +2 -2
  68. package/dist/messages/block_translators/index.cjs.map +1 -1
  69. package/dist/messages/block_translators/index.js +4 -4
  70. package/dist/messages/block_translators/index.js.map +1 -1
  71. package/dist/messages/block_translators/openai.cjs +78 -22
  72. package/dist/messages/block_translators/openai.cjs.map +1 -1
  73. package/dist/messages/block_translators/openai.js +78 -22
  74. package/dist/messages/block_translators/openai.js.map +1 -1
  75. package/dist/messages/content/tools.cjs +1 -5
  76. package/dist/messages/content/tools.cjs.map +1 -1
  77. package/dist/messages/content/tools.d.cts +1 -85
  78. package/dist/messages/content/tools.d.cts.map +1 -1
  79. package/dist/messages/content/tools.d.ts +1 -85
  80. package/dist/messages/content/tools.d.ts.map +1 -1
  81. package/dist/messages/content/tools.js +1 -5
  82. package/dist/messages/content/tools.js.map +1 -1
  83. package/dist/messages/metadata.cjs.map +1 -1
  84. package/dist/messages/metadata.d.cts +3 -0
  85. package/dist/messages/metadata.d.cts.map +1 -1
  86. package/dist/messages/metadata.d.ts +3 -0
  87. package/dist/messages/metadata.d.ts.map +1 -1
  88. package/dist/messages/metadata.js.map +1 -1
  89. package/dist/messages/tool.cjs +2 -0
  90. package/dist/messages/tool.cjs.map +1 -1
  91. package/dist/messages/tool.d.cts +2 -0
  92. package/dist/messages/tool.d.cts.map +1 -1
  93. package/dist/messages/tool.d.ts +2 -0
  94. package/dist/messages/tool.d.ts.map +1 -1
  95. package/dist/messages/tool.js +2 -0
  96. package/dist/messages/tool.js.map +1 -1
  97. package/dist/output_parsers/json.cjs +5 -0
  98. package/dist/output_parsers/json.cjs.map +1 -1
  99. package/dist/output_parsers/json.d.cts +2 -0
  100. package/dist/output_parsers/json.d.cts.map +1 -1
  101. package/dist/output_parsers/json.d.ts +2 -0
  102. package/dist/output_parsers/json.d.ts.map +1 -1
  103. package/dist/output_parsers/json.js +5 -0
  104. package/dist/output_parsers/json.js.map +1 -1
  105. package/dist/prompts/base.cjs +0 -36
  106. package/dist/prompts/base.cjs.map +1 -1
  107. package/dist/prompts/base.d.cts +0 -16
  108. package/dist/prompts/base.d.cts.map +1 -1
  109. package/dist/prompts/base.d.ts +0 -16
  110. package/dist/prompts/base.d.ts.map +1 -1
  111. package/dist/prompts/base.js +0 -36
  112. package/dist/prompts/base.js.map +1 -1
  113. package/dist/prompts/chat.cjs +1 -5
  114. package/dist/prompts/chat.cjs.map +1 -1
  115. package/dist/prompts/chat.d.cts +1 -4
  116. package/dist/prompts/chat.d.cts.map +1 -1
  117. package/dist/prompts/chat.d.ts +1 -4
  118. package/dist/prompts/chat.d.ts.map +1 -1
  119. package/dist/prompts/chat.js +1 -5
  120. package/dist/prompts/chat.js.map +1 -1
  121. package/dist/prompts/dict.d.cts +1 -1
  122. package/dist/prompts/dict.d.ts +1 -1
  123. package/dist/prompts/few_shot.d.cts +2 -2
  124. package/dist/prompts/few_shot.d.ts +2 -2
  125. package/dist/prompts/image.d.cts +1 -1
  126. package/dist/prompts/image.d.ts +1 -1
  127. package/dist/prompts/index.d.cts +2 -2
  128. package/dist/prompts/index.d.ts +2 -2
  129. package/dist/prompts/pipeline.d.cts +1 -1
  130. package/dist/prompts/pipeline.d.ts +1 -1
  131. package/dist/prompts/prompt.d.cts +2 -2
  132. package/dist/prompts/prompt.d.ts +2 -2
  133. package/dist/retrievers/index.cjs +3 -18
  134. package/dist/retrievers/index.cjs.map +1 -1
  135. package/dist/retrievers/index.d.cts +2 -27
  136. package/dist/retrievers/index.d.cts.map +1 -1
  137. package/dist/retrievers/index.d.ts +2 -27
  138. package/dist/retrievers/index.d.ts.map +1 -1
  139. package/dist/retrievers/index.js +3 -18
  140. package/dist/retrievers/index.js.map +1 -1
  141. package/dist/runnables/base.cjs +24 -63
  142. package/dist/runnables/base.cjs.map +1 -1
  143. package/dist/runnables/base.d.cts +10 -39
  144. package/dist/runnables/base.d.cts.map +1 -1
  145. package/dist/runnables/base.d.ts +10 -39
  146. package/dist/runnables/base.d.ts.map +1 -1
  147. package/dist/runnables/base.js +24 -63
  148. package/dist/runnables/base.js.map +1 -1
  149. package/dist/runnables/graph.cjs +1 -1
  150. package/dist/runnables/graph.cjs.map +1 -1
  151. package/dist/runnables/graph.js +2 -2
  152. package/dist/runnables/graph.js.map +1 -1
  153. package/dist/runnables/graph_mermaid.cjs +1 -10
  154. package/dist/runnables/graph_mermaid.cjs.map +1 -1
  155. package/dist/runnables/graph_mermaid.js +1 -10
  156. package/dist/runnables/graph_mermaid.js.map +1 -1
  157. package/dist/runnables/history.cjs +1 -1
  158. package/dist/runnables/history.cjs.map +1 -1
  159. package/dist/runnables/history.d.cts +2 -2
  160. package/dist/runnables/history.d.cts.map +1 -1
  161. package/dist/runnables/history.d.ts +2 -2
  162. package/dist/runnables/history.d.ts.map +1 -1
  163. package/dist/runnables/history.js +1 -1
  164. package/dist/runnables/history.js.map +1 -1
  165. package/dist/stores.cjs.map +1 -1
  166. package/dist/stores.d.cts +3 -29
  167. package/dist/stores.d.cts.map +1 -1
  168. package/dist/stores.d.ts +3 -29
  169. package/dist/stores.d.ts.map +1 -1
  170. package/dist/stores.js.map +1 -1
  171. package/dist/tools/index.cjs +12 -4
  172. package/dist/tools/index.cjs.map +1 -1
  173. package/dist/tools/index.js +12 -4
  174. package/dist/tools/index.js.map +1 -1
  175. package/dist/tools/types.cjs.map +1 -1
  176. package/dist/tools/types.d.cts +4 -0
  177. package/dist/tools/types.d.cts.map +1 -1
  178. package/dist/tools/types.d.ts +4 -0
  179. package/dist/tools/types.d.ts.map +1 -1
  180. package/dist/tools/types.js.map +1 -1
  181. package/dist/tracers/base.cjs +1 -1
  182. package/dist/tracers/base.cjs.map +1 -1
  183. package/dist/tracers/base.d.cts +1 -1
  184. package/dist/tracers/base.js +2 -2
  185. package/dist/tracers/base.js.map +1 -1
  186. package/dist/tracers/log_stream.d.cts +1 -1
  187. package/dist/tracers/log_stream.d.ts +1 -1
  188. package/dist/tracers/tracer_langchain.cjs +1 -0
  189. package/dist/tracers/tracer_langchain.cjs.map +1 -1
  190. package/dist/tracers/tracer_langchain.d.cts +2 -2
  191. package/dist/tracers/tracer_langchain.js +1 -0
  192. package/dist/tracers/tracer_langchain.js.map +1 -1
  193. package/dist/utils/env.cjs +1 -9
  194. package/dist/utils/env.cjs.map +1 -1
  195. package/dist/utils/env.d.cts +2 -6
  196. package/dist/utils/env.d.cts.map +1 -1
  197. package/dist/utils/env.d.ts +2 -6
  198. package/dist/utils/env.d.ts.map +1 -1
  199. package/dist/utils/env.js +2 -9
  200. package/dist/utils/env.js.map +1 -1
  201. package/dist/utils/testing/message_history.cjs +1 -1
  202. package/dist/utils/testing/message_history.cjs.map +1 -1
  203. package/dist/utils/testing/message_history.d.cts +1 -1
  204. package/dist/utils/testing/message_history.d.cts.map +1 -1
  205. package/dist/utils/testing/message_history.d.ts +1 -1
  206. package/dist/utils/testing/message_history.d.ts.map +1 -1
  207. package/dist/utils/testing/message_history.js +1 -1
  208. package/dist/utils/testing/message_history.js.map +1 -1
  209. package/dist/utils/types/index.cjs +6 -0
  210. package/dist/utils/types/index.d.cts +2 -2
  211. package/dist/utils/types/index.d.ts +2 -2
  212. package/dist/utils/types/index.js +5 -2
  213. package/dist/utils/types/zod.cjs +23 -0
  214. package/dist/utils/types/zod.cjs.map +1 -1
  215. package/dist/utils/types/zod.d.cts +11 -1
  216. package/dist/utils/types/zod.d.cts.map +1 -1
  217. package/dist/utils/types/zod.d.ts +11 -1
  218. package/dist/utils/types/zod.d.ts.map +1 -1
  219. package/dist/utils/types/zod.js +21 -1
  220. package/dist/utils/types/zod.js.map +1 -1
  221. package/package.json +121 -154
  222. package/dist/runnables/remote.cjs +0 -399
  223. package/dist/runnables/remote.cjs.map +0 -1
  224. package/dist/runnables/remote.d.cts +0 -73
  225. package/dist/runnables/remote.d.cts.map +0 -1
  226. package/dist/runnables/remote.d.ts +0 -73
  227. package/dist/runnables/remote.d.ts.map +0 -1
  228. package/dist/runnables/remote.js +0 -393
  229. package/dist/runnables/remote.js.map +0 -1
  230. package/dist/tracers/initialize.cjs +0 -46
  231. package/dist/tracers/initialize.cjs.map +0 -1
  232. package/dist/tracers/initialize.d.cts +0 -26
  233. package/dist/tracers/initialize.d.cts.map +0 -1
  234. package/dist/tracers/initialize.d.ts +0 -26
  235. package/dist/tracers/initialize.d.ts.map +0 -1
  236. package/dist/tracers/initialize.js +0 -39
  237. package/dist/tracers/initialize.js.map +0 -1
  238. package/dist/tracers/tracer_langchain_v1.cjs +0 -168
  239. package/dist/tracers/tracer_langchain_v1.cjs.map +0 -1
  240. package/dist/tracers/tracer_langchain_v1.d.cts +0 -64
  241. package/dist/tracers/tracer_langchain_v1.d.cts.map +0 -1
  242. package/dist/tracers/tracer_langchain_v1.d.ts +0 -64
  243. package/dist/tracers/tracer_langchain_v1.d.ts.map +0 -1
  244. package/dist/tracers/tracer_langchain_v1.js +0 -162
  245. package/dist/tracers/tracer_langchain_v1.js.map +0 -1
@@ -278,7 +278,7 @@ var _StringImageMessagePromptTemplate = class extends BaseMessagePromptTemplate
278
278
  const formatted = await prompt.format(inputs);
279
279
  let additionalContentFields;
280
280
  if ("additionalContentFields" in prompt) additionalContentFields = prompt.additionalContentFields;
281
- content.push({
281
+ if (formatted !== "") content.push({
282
282
  ...additionalContentFields,
283
283
  type: "text",
284
284
  text: formatted
@@ -536,10 +536,6 @@ var ChatPromptTemplate = class ChatPromptTemplate extends BaseChatPromptTemplate
536
536
  templateFormat: extra?.templateFormat
537
537
  });
538
538
  }
539
- /** @deprecated Renamed to .fromMessages */
540
- static fromPromptMessages(promptMessages) {
541
- return this.fromMessages(promptMessages);
542
- }
543
539
  };
544
540
 
545
541
  //#endregion
@@ -1 +1 @@
1
- {"version":3,"file":"chat.js","names":["input: RunInput","options?: BaseCallbackConfig","input","fields:\n | Extract<keyof RunInput, string>\n | MessagesPlaceholderFields<Extract<keyof RunInput, string>>","values: TypedPromptInputValues<RunInput>","e: any","fields:\n | MessageStringPromptTemplateFields<\n InputValues<Extract<keyof RunInput, string>>\n >\n | BaseStringPromptTemplate<\n InputValues<Extract<keyof RunInput, string>>,\n string\n >","input: BasePromptTemplateInput<RunInput, PartialVariableName>","fields:\n | ChatMessagePromptTemplateFields<\n InputValues<Extract<keyof RunInput, string>>\n >\n | BaseStringPromptTemplate<InputValues<Extract<keyof RunInput, string>>>","role?: string","values: RunInput","template: T","role: string","options?: { templateFormat?: TemplateFormat }","param: unknown","fields: any","additionalOptions?: _StringImageMessagePromptTemplateOptions","inputVariables: Extract<keyof RunInput, string>[]","content: MessageContent","name: string","template:\n | string\n | Array<\n | string\n | _TextTemplateParam\n | _ImageTemplateParam\n | Record<string, unknown>\n >","prompt: Array<\n | PromptTemplate<InputValues>\n | ImagePromptTemplate<InputValues>\n | DictPromptTemplate\n >","imgTemplateObject: ImagePromptTemplate<InputValues>","inputVariables: string[]","parsedTemplate: ParsedTemplateNode[]","item","input: TypedPromptInputValues<RunInput>","inputs: Record<string, any>","additionalContentFields: ContentBlock | undefined","baseMessagePromptTemplateLike: BaseMessagePromptTemplateLike","messagePromptTemplateLike: BaseMessagePromptTemplateLike","extra?: Extra","templateData:\n | string\n | (\n | string\n | _TextTemplateParam\n | _ImageTemplateParam\n // eslint-disable-next-line @typescript-eslint/no-explicit-any\n | Record<string, any>\n )[]","x: BaseMessagePromptTemplate | BaseMessage","input: ChatPromptTemplateInput<RunInput, PartialVariableName>","message: BaseMessage","inputValues: InputValues<\n PartialVariableName | Extract<keyof RunInput, string>\n >","resultMessages: BaseMessage[]","inputValues: InputValues","values: PartialValues<NewPartialVariableName>","options?: Omit<\n PromptTemplateInput<RunInput, string, TemplateFormat>,\n \"template\" | \"inputVariables\"\n >","promptMessages: (\n | ChatPromptTemplate<InputValues, string>\n | BaseMessagePromptTemplateLike\n )[]","extra?: Omit<\n Extra,\n \"inputVariables\" | \"promptMessages\" | \"partialVariables\"\n >","acc: Array<BaseMessagePromptTemplate | BaseMessage>"],"sources":["../../src/prompts/chat.ts"],"sourcesContent":["// Default generic \"any\" values are for backwards compatibility.\n// Replace with \"string\" when we are comfortable with a breaking change.\n\nimport type { BaseCallbackConfig } from \"../callbacks/manager.js\";\nimport {\n AIMessage,\n HumanMessage,\n SystemMessage,\n BaseMessage,\n ChatMessage,\n type BaseMessageLike,\n coerceMessageLikeToMessage,\n isBaseMessage,\n MessageContent,\n ContentBlock,\n} from \"../messages/index.js\";\nimport {\n type ChatPromptValueInterface,\n ChatPromptValue,\n} from \"../prompt_values.js\";\nimport type { InputValues, PartialValues } from \"../utils/types/index.js\";\nimport { Runnable } from \"../runnables/base.js\";\nimport { BaseStringPromptTemplate } from \"./string.js\";\nimport {\n BasePromptTemplate,\n type BasePromptTemplateInput,\n type TypedPromptInputValues,\n} from \"./base.js\";\nimport {\n PromptTemplate,\n type ParamsFromFString,\n PromptTemplateInput,\n ExtractedFStringParams,\n} from \"./prompt.js\";\nimport { ImagePromptTemplate } from \"./image.js\";\nimport {\n ParsedTemplateNode,\n TemplateFormat,\n parseFString,\n parseMustache,\n} from \"./template.js\";\nimport { addLangChainErrorFields } from \"../errors/index.js\";\nimport { DictPromptTemplate } from \"./dict.js\";\n\n/**\n * Abstract class that serves as a base for creating message prompt\n * templates. It defines how to format messages for different roles in a\n * conversation.\n */\nexport abstract class BaseMessagePromptTemplate<\n // eslint-disable-next-line @typescript-eslint/no-explicit-any\n RunInput extends InputValues = any,\n RunOutput extends BaseMessage[] = BaseMessage[]\n> extends Runnable<RunInput, RunOutput> {\n lc_namespace = [\"langchain_core\", \"prompts\", \"chat\"];\n\n lc_serializable = true;\n\n abstract inputVariables: Array<Extract<keyof RunInput, string>>;\n\n /**\n * Method that takes an object of TypedPromptInputValues and returns a\n * promise that resolves to an array of BaseMessage instances.\n * @param values Object of TypedPromptInputValues\n * @returns Formatted array of BaseMessages\n */\n abstract formatMessages(\n values: TypedPromptInputValues<RunInput>\n ): Promise<RunOutput>;\n\n /**\n * Calls the formatMessages method with the provided input and options.\n * @param input Input for the formatMessages method\n * @param options Optional BaseCallbackConfig\n * @returns Formatted output messages\n */\n async invoke(\n input: RunInput,\n options?: BaseCallbackConfig\n ): Promise<RunOutput> {\n return this._callWithConfig(\n (input: RunInput) => this.formatMessages(input),\n input,\n { ...options, runType: \"prompt\" }\n );\n }\n}\n\n/**\n * Interface for the fields of a MessagePlaceholder.\n */\nexport interface MessagesPlaceholderFields<T extends string> {\n variableName: T;\n optional?: boolean;\n}\n\n/**\n * Class that represents a placeholder for messages in a chat prompt. It\n * extends the BaseMessagePromptTemplate.\n */\nexport class MessagesPlaceholder<\n // eslint-disable-next-line @typescript-eslint/no-explicit-any\n RunInput extends InputValues = any\n >\n extends BaseMessagePromptTemplate<RunInput>\n implements MessagesPlaceholderFields<Extract<keyof RunInput, string>>\n{\n static lc_name() {\n return \"MessagesPlaceholder\";\n }\n\n variableName: Extract<keyof RunInput, string>;\n\n optional: boolean;\n\n constructor(variableName: Extract<keyof RunInput, string>);\n\n constructor(\n fields: MessagesPlaceholderFields<Extract<keyof RunInput, string>>\n );\n\n constructor(\n fields:\n | Extract<keyof RunInput, string>\n | MessagesPlaceholderFields<Extract<keyof RunInput, string>>\n ) {\n if (typeof fields === \"string\") {\n // eslint-disable-next-line no-param-reassign\n fields = { variableName: fields };\n }\n super(fields);\n this.variableName = fields.variableName;\n this.optional = fields.optional ?? false;\n }\n\n get inputVariables() {\n return [this.variableName];\n }\n\n async formatMessages(\n values: TypedPromptInputValues<RunInput>\n ): Promise<BaseMessage[]> {\n const input = values[this.variableName];\n if (this.optional && !input) {\n return [];\n } else if (!input) {\n const error = new Error(\n `Field \"${this.variableName}\" in prompt uses a MessagesPlaceholder, which expects an array of BaseMessages as an input value. Received: undefined`\n );\n error.name = \"InputFormatError\";\n throw error;\n }\n\n let formattedMessages;\n try {\n if (Array.isArray(input)) {\n formattedMessages = input.map(coerceMessageLikeToMessage);\n } else {\n formattedMessages = [coerceMessageLikeToMessage(input)];\n }\n // eslint-disable-next-line @typescript-eslint/no-explicit-any\n } catch (e: any) {\n const readableInput =\n typeof input === \"string\" ? input : JSON.stringify(input, null, 2);\n const error = new Error(\n [\n `Field \"${this.variableName}\" in prompt uses a MessagesPlaceholder, which expects an array of BaseMessages or coerceable values as input.`,\n `Received value: ${readableInput}`,\n `Additional message: ${e.message}`,\n ].join(\"\\n\\n\")\n );\n error.name = \"InputFormatError\";\n // eslint-disable-next-line @typescript-eslint/no-explicit-any\n (error as any).lc_error_code = e.lc_error_code;\n throw error;\n }\n\n return formattedMessages;\n }\n}\n\n/**\n * Interface for the fields of a MessageStringPromptTemplate.\n */\nexport interface MessageStringPromptTemplateFields<\n // eslint-disable-next-line @typescript-eslint/no-explicit-any\n T extends InputValues = any\n> {\n prompt: BaseStringPromptTemplate<T, string>;\n}\n\n/**\n * Abstract class that serves as a base for creating message string prompt\n * templates. It extends the BaseMessagePromptTemplate.\n */\nexport abstract class BaseMessageStringPromptTemplate<\n // eslint-disable-next-line @typescript-eslint/no-explicit-any\n RunInput extends InputValues = any\n> extends BaseMessagePromptTemplate<RunInput> {\n prompt: BaseStringPromptTemplate<\n InputValues<Extract<keyof RunInput, string>>,\n string\n >;\n\n constructor(\n prompt: BaseStringPromptTemplate<\n InputValues<Extract<keyof RunInput, string>>\n >\n );\n\n constructor(\n fields: MessageStringPromptTemplateFields<\n InputValues<Extract<keyof RunInput, string>>\n >\n );\n\n constructor(\n fields:\n | MessageStringPromptTemplateFields<\n InputValues<Extract<keyof RunInput, string>>\n >\n | BaseStringPromptTemplate<\n InputValues<Extract<keyof RunInput, string>>,\n string\n >\n ) {\n if (!(\"prompt\" in fields)) {\n // eslint-disable-next-line no-param-reassign\n fields = { prompt: fields };\n }\n super(fields);\n this.prompt = fields.prompt;\n }\n\n get inputVariables() {\n return this.prompt.inputVariables;\n }\n\n abstract format(\n values: TypedPromptInputValues<RunInput>\n ): Promise<BaseMessage>;\n\n async formatMessages(\n values: TypedPromptInputValues<RunInput>\n ): Promise<BaseMessage[]> {\n return [await this.format(values)];\n }\n}\n\n/**\n * Abstract class that serves as a base for creating chat prompt\n * templates. It extends the BasePromptTemplate.\n */\nexport abstract class BaseChatPromptTemplate<\n // eslint-disable-next-line @typescript-eslint/no-explicit-any\n RunInput extends InputValues = any,\n // eslint-disable-next-line @typescript-eslint/no-explicit-any\n PartialVariableName extends string = any\n> extends BasePromptTemplate<\n RunInput,\n ChatPromptValueInterface,\n PartialVariableName\n> {\n constructor(input: BasePromptTemplateInput<RunInput, PartialVariableName>) {\n super(input);\n }\n\n abstract formatMessages(\n values: TypedPromptInputValues<RunInput>\n ): Promise<BaseMessage[]>;\n\n async format(values: TypedPromptInputValues<RunInput>): Promise<string> {\n return (await this.formatPromptValue(values)).toString();\n }\n\n async formatPromptValue(\n values: TypedPromptInputValues<RunInput>\n ): Promise<ChatPromptValueInterface> {\n const resultMessages = await this.formatMessages(values);\n return new ChatPromptValue(resultMessages);\n }\n}\n\n/**\n * Interface for the fields of a ChatMessagePromptTemplate.\n */\n// eslint-disable-next-line @typescript-eslint/no-explicit-any\nexport interface ChatMessagePromptTemplateFields<T extends InputValues = any>\n extends MessageStringPromptTemplateFields<T> {\n role: string;\n}\n\n/**\n * Class that represents a chat message prompt template. It extends the\n * BaseMessageStringPromptTemplate.\n */\nexport class ChatMessagePromptTemplate<\n // eslint-disable-next-line @typescript-eslint/no-explicit-any\n RunInput extends InputValues = any\n> extends BaseMessageStringPromptTemplate<RunInput> {\n static lc_name() {\n return \"ChatMessagePromptTemplate\";\n }\n\n role: string;\n\n constructor(\n prompt: BaseStringPromptTemplate<\n InputValues<Extract<keyof RunInput, string>>\n >,\n role: string\n );\n\n constructor(\n fields: ChatMessagePromptTemplateFields<\n InputValues<Extract<keyof RunInput, string>>\n >\n );\n\n constructor(\n fields:\n | ChatMessagePromptTemplateFields<\n InputValues<Extract<keyof RunInput, string>>\n >\n | BaseStringPromptTemplate<InputValues<Extract<keyof RunInput, string>>>,\n role?: string\n ) {\n if (!(\"prompt\" in fields)) {\n // eslint-disable-next-line no-param-reassign\n fields = { prompt: fields, role: role! };\n }\n super(fields);\n this.role = fields.role;\n }\n\n async format(values: RunInput): Promise<BaseMessage> {\n return new ChatMessage(await this.prompt.format(values), this.role);\n }\n\n static fromTemplate<\n RunInput extends InputValues = Symbol,\n T extends string = string\n >(template: T, role: string, options?: { templateFormat?: TemplateFormat }) {\n return new this(\n PromptTemplate.fromTemplate<RunInput, T>(template, {\n templateFormat: options?.templateFormat,\n }),\n role\n );\n }\n}\n\ninterface _TextTemplateParam {\n // eslint-disable-next-line @typescript-eslint/no-explicit-any\n text?: string | Record<string, any>;\n}\n\nfunction isTextTemplateParam(param: unknown): param is _TextTemplateParam {\n if (param === null || typeof param !== \"object\" || Array.isArray(param)) {\n return false;\n }\n return (\n Object.keys(param).length === 1 &&\n \"text\" in param &&\n typeof param.text === \"string\"\n );\n}\n\ninterface _ImageTemplateParam {\n // eslint-disable-next-line @typescript-eslint/no-explicit-any\n image_url?: string | Record<string, any>;\n}\n\nfunction isImageTemplateParam(param: unknown): param is _ImageTemplateParam {\n if (param === null || typeof param !== \"object\" || Array.isArray(param)) {\n return false;\n }\n return (\n \"image_url\" in param &&\n (typeof param.image_url === \"string\" ||\n (typeof param.image_url === \"object\" &&\n param.image_url !== null &&\n \"url\" in param.image_url &&\n typeof param.image_url.url === \"string\"))\n );\n}\n\ntype MessageClass =\n | typeof HumanMessage\n | typeof AIMessage\n | typeof SystemMessage;\n\ntype ChatMessageClass = typeof ChatMessage;\n\ninterface _StringImageMessagePromptTemplateOptions<\n Format extends TemplateFormat = TemplateFormat\n> extends Record<string, unknown> {\n templateFormat?: Format;\n}\n\nclass _StringImageMessagePromptTemplate<\n // eslint-disable-next-line @typescript-eslint/no-explicit-any\n RunInput extends InputValues = any,\n RunOutput extends BaseMessage[] = BaseMessage[]\n> extends BaseMessagePromptTemplate<RunInput, RunOutput> {\n lc_namespace = [\"langchain_core\", \"prompts\", \"chat\"];\n\n lc_serializable = true;\n\n inputVariables: Array<Extract<keyof RunInput, string>> = [];\n\n additionalOptions: _StringImageMessagePromptTemplateOptions = {};\n\n prompt:\n | BaseStringPromptTemplate<\n InputValues<Extract<keyof RunInput, string>>,\n string\n >\n | Array<\n | BaseStringPromptTemplate<\n InputValues<Extract<keyof RunInput, string>>,\n string\n >\n | ImagePromptTemplate<\n InputValues<Extract<keyof RunInput, string>>,\n string\n >\n | MessageStringPromptTemplateFields<\n InputValues<Extract<keyof RunInput, string>>\n >\n | DictPromptTemplate<InputValues<Extract<keyof RunInput, string>>>\n >;\n\n protected messageClass?: MessageClass;\n\n static _messageClass(): MessageClass {\n throw new Error(\n \"Can not invoke _messageClass from inside _StringImageMessagePromptTemplate\"\n );\n }\n\n // ChatMessage contains role field, others don't.\n // Because of this, we have a separate class property for ChatMessage.\n protected chatMessageClass?: ChatMessageClass;\n\n constructor(\n /** @TODO When we come up with a better way to type prompt templates, fix this */\n // eslint-disable-next-line @typescript-eslint/no-explicit-any\n fields: any,\n additionalOptions?: _StringImageMessagePromptTemplateOptions\n ) {\n if (!(\"prompt\" in fields)) {\n // eslint-disable-next-line no-param-reassign\n fields = { prompt: fields };\n }\n super(fields);\n this.prompt = fields.prompt;\n if (Array.isArray(this.prompt)) {\n let inputVariables: Extract<keyof RunInput, string>[] = [];\n this.prompt.forEach((prompt) => {\n if (\"inputVariables\" in prompt) {\n inputVariables = inputVariables.concat(prompt.inputVariables);\n }\n });\n this.inputVariables = inputVariables;\n } else {\n this.inputVariables = this.prompt.inputVariables;\n }\n this.additionalOptions = additionalOptions ?? this.additionalOptions;\n }\n\n createMessage(content: MessageContent) {\n // eslint-disable-next-line @typescript-eslint/no-explicit-any\n const constructor = this.constructor as any;\n if (constructor._messageClass()) {\n const MsgClass = constructor._messageClass();\n return new MsgClass({ content });\n } else if (constructor.chatMessageClass) {\n const MsgClass = constructor.chatMessageClass();\n // Assuming ChatMessage constructor also takes a content argument\n return new MsgClass({\n content,\n role: this.getRoleFromMessageClass(MsgClass.lc_name()),\n });\n } else {\n throw new Error(\"No message class defined\");\n }\n }\n\n getRoleFromMessageClass(name: string) {\n switch (name) {\n case \"HumanMessage\":\n return \"human\";\n case \"AIMessage\":\n return \"ai\";\n case \"SystemMessage\":\n return \"system\";\n case \"ChatMessage\":\n return \"chat\";\n default:\n throw new Error(\"Invalid message class name\");\n }\n }\n\n static fromTemplate(\n template:\n | string\n | Array<\n | string\n | _TextTemplateParam\n | _ImageTemplateParam\n | Record<string, unknown>\n >,\n additionalOptions?: _StringImageMessagePromptTemplateOptions\n ) {\n if (typeof template === \"string\") {\n return new this(PromptTemplate.fromTemplate(template, additionalOptions));\n }\n const prompt: Array<\n | PromptTemplate<InputValues>\n | ImagePromptTemplate<InputValues>\n | DictPromptTemplate\n > = [];\n for (const item of template) {\n // handle string cases\n if (typeof item === \"string\") {\n prompt.push(PromptTemplate.fromTemplate(item, additionalOptions));\n } else if (item === null) {\n // pass\n } else if (isTextTemplateParam(item)) {\n let text = \"\";\n if (typeof item.text === \"string\") {\n text = item.text ?? \"\";\n }\n\n const options = {\n ...additionalOptions,\n additionalContentFields: item as ContentBlock,\n };\n prompt.push(PromptTemplate.fromTemplate(text, options));\n } else if (isImageTemplateParam(item)) {\n let imgTemplate = item.image_url ?? \"\";\n let imgTemplateObject: ImagePromptTemplate<InputValues>;\n let inputVariables: string[] = [];\n if (typeof imgTemplate === \"string\") {\n let parsedTemplate: ParsedTemplateNode[];\n if (additionalOptions?.templateFormat === \"mustache\") {\n parsedTemplate = parseMustache(imgTemplate);\n } else {\n parsedTemplate = parseFString(imgTemplate);\n }\n\n const variables = parsedTemplate.flatMap((item) =>\n item.type === \"variable\" ? [item.name] : []\n );\n\n if ((variables?.length ?? 0) > 0) {\n if (variables.length > 1) {\n throw new Error(\n `Only one format variable allowed per image template.\\nGot: ${variables}\\nFrom: ${imgTemplate}`\n );\n }\n inputVariables = [variables[0]];\n } else {\n inputVariables = [];\n }\n\n imgTemplate = { url: imgTemplate };\n imgTemplateObject = new ImagePromptTemplate<InputValues>({\n template: imgTemplate,\n inputVariables,\n templateFormat: additionalOptions?.templateFormat,\n additionalContentFields: item as ContentBlock,\n });\n } else if (typeof imgTemplate === \"object\") {\n if (\"url\" in imgTemplate) {\n let parsedTemplate: ParsedTemplateNode[];\n if (additionalOptions?.templateFormat === \"mustache\") {\n parsedTemplate = parseMustache(imgTemplate.url);\n } else {\n parsedTemplate = parseFString(imgTemplate.url);\n }\n\n inputVariables = parsedTemplate.flatMap((item) =>\n item.type === \"variable\" ? [item.name] : []\n );\n } else {\n inputVariables = [];\n }\n imgTemplateObject = new ImagePromptTemplate<InputValues>({\n template: imgTemplate,\n inputVariables,\n templateFormat: additionalOptions?.templateFormat,\n additionalContentFields: item as ContentBlock,\n });\n } else {\n throw new Error(\"Invalid image template\");\n }\n prompt.push(imgTemplateObject);\n } else if (typeof item === \"object\") {\n prompt.push(\n new DictPromptTemplate({\n template: item,\n templateFormat: additionalOptions?.templateFormat,\n })\n );\n }\n }\n return new this({ prompt, additionalOptions });\n }\n\n async format(input: TypedPromptInputValues<RunInput>): Promise<BaseMessage> {\n // eslint-disable-next-line no-instanceof/no-instanceof\n if (this.prompt instanceof BaseStringPromptTemplate) {\n const text = await this.prompt.format(input);\n\n return this.createMessage(text);\n } else {\n const content: MessageContent = [];\n for (const prompt of this.prompt) {\n // eslint-disable-next-line @typescript-eslint/no-explicit-any\n let inputs: Record<string, any> = {};\n if (!(\"inputVariables\" in prompt)) {\n throw new Error(\n `Prompt ${prompt} does not have inputVariables defined.`\n );\n }\n for (const item of prompt.inputVariables) {\n if (!inputs) {\n inputs = { [item]: input[item] };\n }\n inputs = { ...inputs, [item]: input[item] };\n }\n // eslint-disable-next-line no-instanceof/no-instanceof\n if (prompt instanceof BaseStringPromptTemplate) {\n const formatted = await prompt.format(\n inputs as TypedPromptInputValues<RunInput>\n );\n let additionalContentFields: ContentBlock | undefined;\n if (\"additionalContentFields\" in prompt) {\n // eslint-disable-next-line @typescript-eslint/no-explicit-any\n additionalContentFields = prompt.additionalContentFields as any;\n }\n content.push({\n ...additionalContentFields,\n type: \"text\",\n text: formatted,\n });\n /** @TODO replace this */\n // eslint-disable-next-line no-instanceof/no-instanceof\n } else if (prompt instanceof ImagePromptTemplate) {\n const formatted = await prompt.format(\n inputs as TypedPromptInputValues<RunInput>\n );\n let additionalContentFields: ContentBlock | undefined;\n if (\"additionalContentFields\" in prompt) {\n // eslint-disable-next-line @typescript-eslint/no-explicit-any\n additionalContentFields = prompt.additionalContentFields as any;\n }\n content.push({\n ...additionalContentFields,\n type: \"image_url\",\n image_url: formatted,\n });\n // eslint-disable-next-line no-instanceof/no-instanceof\n } else if (prompt instanceof DictPromptTemplate) {\n const formatted = await prompt.format(\n inputs as TypedPromptInputValues<RunInput>\n );\n let additionalContentFields: ContentBlock | undefined;\n if (\"additionalContentFields\" in prompt) {\n // eslint-disable-next-line @typescript-eslint/no-explicit-any\n additionalContentFields = prompt.additionalContentFields as any;\n }\n content.push({\n ...additionalContentFields,\n ...formatted,\n } as ContentBlock);\n }\n }\n return this.createMessage(content);\n }\n }\n\n async formatMessages(values: RunInput): Promise<RunOutput> {\n return [await this.format(values)] as BaseMessage[] as RunOutput;\n }\n}\n\n/**\n * Class that represents a human message prompt template. It extends the\n * BaseMessageStringPromptTemplate.\n * @example\n * ```typescript\n * const message = HumanMessagePromptTemplate.fromTemplate(\"{text}\");\n * const formatted = await message.format({ text: \"Hello world!\" });\n *\n * const chatPrompt = ChatPromptTemplate.fromMessages([message]);\n * const formattedChatPrompt = await chatPrompt.invoke({\n * text: \"Hello world!\",\n * });\n * ```\n */\nexport class HumanMessagePromptTemplate<\n // eslint-disable-next-line @typescript-eslint/no-explicit-any\n RunInput extends InputValues = any\n> extends _StringImageMessagePromptTemplate<RunInput> {\n static _messageClass(): typeof HumanMessage {\n return HumanMessage;\n }\n\n static lc_name() {\n return \"HumanMessagePromptTemplate\";\n }\n}\n\n/**\n * Class that represents an AI message prompt template. It extends the\n * BaseMessageStringPromptTemplate.\n */\nexport class AIMessagePromptTemplate<\n // eslint-disable-next-line @typescript-eslint/no-explicit-any\n RunInput extends InputValues = any\n> extends _StringImageMessagePromptTemplate<RunInput> {\n static _messageClass(): typeof AIMessage {\n return AIMessage;\n }\n\n static lc_name() {\n return \"AIMessagePromptTemplate\";\n }\n}\n\n/**\n * Class that represents a system message prompt template. It extends the\n * BaseMessageStringPromptTemplate.\n * @example\n * ```typescript\n * const message = SystemMessagePromptTemplate.fromTemplate(\"{text}\");\n * const formatted = await message.format({ text: \"Hello world!\" });\n *\n * const chatPrompt = ChatPromptTemplate.fromMessages([message]);\n * const formattedChatPrompt = await chatPrompt.invoke({\n * text: \"Hello world!\",\n * });\n * ```\n */\nexport class SystemMessagePromptTemplate<\n // eslint-disable-next-line @typescript-eslint/no-explicit-any\n RunInput extends InputValues = any\n> extends _StringImageMessagePromptTemplate<RunInput> {\n static _messageClass(): typeof SystemMessage {\n return SystemMessage;\n }\n\n static lc_name() {\n return \"SystemMessagePromptTemplate\";\n }\n}\n\n/**\n * Interface for the input of a ChatPromptTemplate.\n */\nexport interface ChatPromptTemplateInput<\n // eslint-disable-next-line @typescript-eslint/no-explicit-any\n RunInput extends InputValues = any,\n // eslint-disable-next-line @typescript-eslint/no-explicit-any\n PartialVariableName extends string = any\n> extends BasePromptTemplateInput<RunInput, PartialVariableName> {\n /**\n * The prompt messages\n */\n promptMessages: Array<BaseMessagePromptTemplate | BaseMessage>;\n\n /**\n * Whether to try validating the template on initialization\n *\n * @defaultValue `true`\n */\n validateTemplate?: boolean;\n\n /**\n * The formatting method to use on the prompt.\n * @default \"f-string\"\n */\n templateFormat?: TemplateFormat;\n}\n\nexport type BaseMessagePromptTemplateLike =\n | BaseMessagePromptTemplate\n | BaseMessageLike;\n\nfunction _isBaseMessagePromptTemplate(\n baseMessagePromptTemplateLike: BaseMessagePromptTemplateLike\n): baseMessagePromptTemplateLike is BaseMessagePromptTemplate {\n return (\n typeof (baseMessagePromptTemplateLike as BaseMessagePromptTemplate)\n .formatMessages === \"function\"\n );\n}\n\nfunction _coerceMessagePromptTemplateLike<\n // eslint-disable-next-line @typescript-eslint/no-explicit-any\n RunInput extends InputValues = any,\n Extra extends Omit<\n ChatPromptTemplateInput<RunInput>,\n \"inputVariables\" | \"promptMessages\" | \"partialVariables\"\n > = Omit<\n ChatPromptTemplateInput<RunInput>,\n \"inputVariables\" | \"promptMessages\" | \"partialVariables\"\n >\n>(\n messagePromptTemplateLike: BaseMessagePromptTemplateLike,\n extra?: Extra\n): BaseMessagePromptTemplate | BaseMessage {\n if (\n _isBaseMessagePromptTemplate(messagePromptTemplateLike) ||\n isBaseMessage(messagePromptTemplateLike)\n ) {\n return messagePromptTemplateLike;\n }\n if (\n Array.isArray(messagePromptTemplateLike) &&\n messagePromptTemplateLike[0] === \"placeholder\"\n ) {\n const messageContent = messagePromptTemplateLike[1];\n if (\n extra?.templateFormat === \"mustache\" &&\n typeof messageContent === \"string\" &&\n messageContent.slice(0, 2) === \"{{\" &&\n messageContent.slice(-2) === \"}}\"\n ) {\n const variableName = messageContent.slice(2, -2);\n return new MessagesPlaceholder({ variableName, optional: true });\n } else if (\n typeof messageContent === \"string\" &&\n messageContent[0] === \"{\" &&\n messageContent[messageContent.length - 1] === \"}\"\n ) {\n const variableName = messageContent.slice(1, -1);\n return new MessagesPlaceholder({ variableName, optional: true });\n }\n throw new Error(\n `Invalid placeholder template for format ${\n extra?.templateFormat ?? `\"f-string\"`\n }: \"${\n messagePromptTemplateLike[1]\n }\". Expected a variable name surrounded by ${\n extra?.templateFormat === \"mustache\" ? \"double\" : \"single\"\n } curly braces.`\n );\n }\n const message = coerceMessageLikeToMessage(messagePromptTemplateLike);\n let templateData:\n | string\n | (\n | string\n | _TextTemplateParam\n | _ImageTemplateParam\n // eslint-disable-next-line @typescript-eslint/no-explicit-any\n | Record<string, any>\n )[];\n\n if (typeof message.content === \"string\") {\n templateData = message.content;\n } else {\n // Assuming message.content is an array of complex objects, transform it.\n templateData = message.content.map((item) => {\n if (\"text\" in item) {\n return { ...item, text: item.text };\n } else if (\"image_url\" in item) {\n return { ...item, image_url: item.image_url };\n } else {\n return item;\n }\n });\n }\n\n if (message._getType() === \"human\") {\n return HumanMessagePromptTemplate.fromTemplate(templateData, extra);\n } else if (message._getType() === \"ai\") {\n return AIMessagePromptTemplate.fromTemplate(templateData, extra);\n } else if (message._getType() === \"system\") {\n return SystemMessagePromptTemplate.fromTemplate(templateData, extra);\n } else if (ChatMessage.isInstance(message)) {\n return ChatMessagePromptTemplate.fromTemplate(\n message.content as string,\n message.role,\n extra\n );\n } else {\n throw new Error(\n `Could not coerce message prompt template from input. Received message type: \"${message._getType()}\".`\n );\n }\n}\n\nfunction isMessagesPlaceholder(\n x: BaseMessagePromptTemplate | BaseMessage\n): x is MessagesPlaceholder {\n // eslint-disable-next-line @typescript-eslint/no-explicit-any\n return (x.constructor as any).lc_name() === \"MessagesPlaceholder\";\n}\n\n/**\n * Class that represents a chat prompt. It extends the\n * BaseChatPromptTemplate and uses an array of BaseMessagePromptTemplate\n * instances to format a series of messages for a conversation.\n * @example\n * ```typescript\n * const message = SystemMessagePromptTemplate.fromTemplate(\"{text}\");\n * const chatPrompt = ChatPromptTemplate.fromMessages([\n * [\"ai\", \"You are a helpful assistant.\"],\n * message,\n * ]);\n * const formattedChatPrompt = await chatPrompt.invoke({\n * text: \"Hello world!\",\n * });\n * ```\n */\nexport class ChatPromptTemplate<\n // eslint-disable-next-line @typescript-eslint/no-explicit-any\n RunInput extends InputValues = any,\n // eslint-disable-next-line @typescript-eslint/no-explicit-any\n PartialVariableName extends string = any\n >\n extends BaseChatPromptTemplate<RunInput, PartialVariableName>\n implements ChatPromptTemplateInput<RunInput, PartialVariableName>\n{\n static lc_name() {\n return \"ChatPromptTemplate\";\n }\n\n get lc_aliases(): Record<string, string> {\n return {\n promptMessages: \"messages\",\n };\n }\n\n promptMessages: Array<BaseMessagePromptTemplate | BaseMessage>;\n\n validateTemplate = true;\n\n templateFormat: TemplateFormat = \"f-string\";\n\n constructor(input: ChatPromptTemplateInput<RunInput, PartialVariableName>) {\n super(input);\n // If input is mustache and validateTemplate is not defined, set it to false\n if (\n input.templateFormat === \"mustache\" &&\n input.validateTemplate === undefined\n ) {\n this.validateTemplate = false;\n }\n Object.assign(this, input);\n\n if (this.validateTemplate) {\n const inputVariablesMessages = new Set<string>();\n for (const promptMessage of this.promptMessages) {\n // eslint-disable-next-line no-instanceof/no-instanceof\n if (promptMessage instanceof BaseMessage) continue;\n for (const inputVariable of promptMessage.inputVariables) {\n inputVariablesMessages.add(inputVariable);\n }\n }\n\n const totalInputVariables = this.inputVariables as string[];\n const inputVariablesInstance = new Set(\n this.partialVariables\n ? totalInputVariables.concat(Object.keys(this.partialVariables))\n : totalInputVariables\n );\n const difference = new Set(\n [...inputVariablesInstance].filter(\n (x) => !inputVariablesMessages.has(x)\n )\n );\n if (difference.size > 0) {\n throw new Error(\n `Input variables \\`${[\n ...difference,\n ]}\\` are not used in any of the prompt messages.`\n );\n }\n const otherDifference = new Set(\n [...inputVariablesMessages].filter(\n (x) => !inputVariablesInstance.has(x)\n )\n );\n if (otherDifference.size > 0) {\n throw new Error(\n `Input variables \\`${[\n ...otherDifference,\n ]}\\` are used in prompt messages but not in the prompt template.`\n );\n }\n }\n }\n\n _getPromptType(): \"chat\" {\n return \"chat\";\n }\n\n private async _parseImagePrompts(\n message: BaseMessage,\n inputValues: InputValues<\n PartialVariableName | Extract<keyof RunInput, string>\n >\n ): Promise<BaseMessage> {\n if (typeof message.content === \"string\") {\n return message;\n }\n const formattedMessageContent = await Promise.all(\n message.content.map(async (item) => {\n if (item.type !== \"image_url\") {\n return item;\n }\n\n let imageUrl = \"\";\n if (typeof item.image_url === \"string\") {\n imageUrl = item.image_url;\n } else if (\n typeof item.image_url === \"object\" &&\n item.image_url !== null &&\n \"url\" in item.image_url &&\n typeof item.image_url.url === \"string\"\n ) {\n imageUrl = item.image_url.url;\n }\n\n const promptTemplatePlaceholder = PromptTemplate.fromTemplate(\n imageUrl,\n {\n templateFormat: this.templateFormat,\n }\n );\n const formattedUrl = await promptTemplatePlaceholder.format(\n inputValues\n );\n\n if (\n typeof item.image_url === \"object\" &&\n item.image_url !== null &&\n \"url\" in item.image_url\n ) {\n // eslint-disable-next-line no-param-reassign\n item.image_url.url = formattedUrl;\n } else {\n item.image_url = formattedUrl;\n }\n return item;\n })\n );\n message.content = formattedMessageContent;\n return message;\n }\n\n async formatMessages(\n values: TypedPromptInputValues<RunInput>\n ): Promise<BaseMessage[]> {\n const allValues = await this.mergePartialAndUserVariables(values);\n let resultMessages: BaseMessage[] = [];\n\n for (const promptMessage of this.promptMessages) {\n // eslint-disable-next-line no-instanceof/no-instanceof\n if (promptMessage instanceof BaseMessage) {\n resultMessages.push(\n await this._parseImagePrompts(promptMessage, allValues)\n );\n } else {\n let inputValues: InputValues;\n\n if (this.templateFormat === \"mustache\") {\n inputValues = { ...allValues };\n } else {\n inputValues = promptMessage.inputVariables.reduce(\n (acc, inputVariable) => {\n if (\n !(inputVariable in allValues) &&\n !(\n isMessagesPlaceholder(promptMessage) && promptMessage.optional\n )\n ) {\n const error = addLangChainErrorFields(\n new Error(\n `Missing value for input variable \\`${inputVariable.toString()}\\``\n ),\n \"INVALID_PROMPT_INPUT\"\n );\n throw error;\n }\n acc[inputVariable] = allValues[inputVariable];\n return acc;\n },\n {} as InputValues\n );\n }\n const message = await promptMessage.formatMessages(inputValues);\n resultMessages = resultMessages.concat(message);\n }\n }\n return resultMessages;\n }\n\n async partial<NewPartialVariableName extends string>(\n values: PartialValues<NewPartialVariableName>\n ) {\n // This is implemented in a way it doesn't require making\n // BaseMessagePromptTemplate aware of .partial()\n const newInputVariables = this.inputVariables.filter(\n (iv) => !(iv in values)\n ) as Exclude<Extract<keyof RunInput, string>, NewPartialVariableName>[];\n const newPartialVariables = {\n ...(this.partialVariables ?? {}),\n ...values,\n } as PartialValues<PartialVariableName | NewPartialVariableName>;\n const promptDict = {\n ...this,\n inputVariables: newInputVariables,\n partialVariables: newPartialVariables,\n };\n return new ChatPromptTemplate<\n InputValues<\n Exclude<Extract<keyof RunInput, string>, NewPartialVariableName>\n >\n >(promptDict);\n }\n\n /**\n * Load prompt template from a template f-string\n */\n static fromTemplate<\n RunInput extends InputValues = Symbol,\n T extends string = string\n >(\n template: T,\n options?: Omit<\n PromptTemplateInput<RunInput, string, \"f-string\">,\n \"template\" | \"inputVariables\"\n >\n ): ChatPromptTemplate<ExtractedFStringParams<T, RunInput>>;\n\n static fromTemplate<\n RunInput extends InputValues = Symbol,\n T extends string = string\n >(\n template: T,\n options?: Omit<\n PromptTemplateInput<RunInput, string>,\n \"template\" | \"inputVariables\"\n >\n ): ChatPromptTemplate<ExtractedFStringParams<T, RunInput>>;\n\n static fromTemplate<\n RunInput extends InputValues = Symbol,\n T extends string = string\n >(\n template: T,\n options?: Omit<\n PromptTemplateInput<RunInput, string, \"mustache\">,\n \"template\" | \"inputVariables\"\n >\n ): ChatPromptTemplate<InputValues>;\n\n static fromTemplate<\n RunInput extends InputValues = Symbol,\n T extends string = string\n >(\n template: T,\n options?: Omit<\n PromptTemplateInput<RunInput, string, TemplateFormat>,\n \"template\" | \"inputVariables\"\n >\n ): ChatPromptTemplate<ExtractedFStringParams<T, RunInput> | InputValues> {\n const prompt = PromptTemplate.fromTemplate(template, options);\n const humanTemplate = new HumanMessagePromptTemplate({ prompt });\n return this.fromMessages<\n RunInput extends Symbol ? ParamsFromFString<T> : RunInput\n >([humanTemplate]);\n }\n\n /**\n * Create a chat model-specific prompt from individual chat messages\n * or message-like tuples.\n * @param promptMessages Messages to be passed to the chat model\n * @returns A new ChatPromptTemplate\n */\n static fromMessages<\n // eslint-disable-next-line @typescript-eslint/no-explicit-any\n RunInput extends InputValues = any,\n Extra extends ChatPromptTemplateInput<RunInput> = ChatPromptTemplateInput<RunInput>\n >(\n promptMessages: (\n | ChatPromptTemplate<InputValues, string>\n | BaseMessagePromptTemplateLike\n )[],\n extra?: Omit<\n Extra,\n \"inputVariables\" | \"promptMessages\" | \"partialVariables\"\n >\n ): ChatPromptTemplate<RunInput> {\n const flattenedMessages = promptMessages.reduce(\n (acc: Array<BaseMessagePromptTemplate | BaseMessage>, promptMessage) =>\n acc.concat(\n // eslint-disable-next-line no-instanceof/no-instanceof\n promptMessage instanceof ChatPromptTemplate\n ? promptMessage.promptMessages\n : [\n _coerceMessagePromptTemplateLike<\n RunInput,\n Omit<\n Extra,\n \"inputVariables\" | \"promptMessages\" | \"partialVariables\"\n >\n >(promptMessage, extra),\n ]\n ),\n []\n );\n const flattenedPartialVariables = promptMessages.reduce(\n (acc, promptMessage) =>\n // eslint-disable-next-line no-instanceof/no-instanceof\n promptMessage instanceof ChatPromptTemplate\n ? Object.assign(acc, promptMessage.partialVariables)\n : acc,\n Object.create(null) as PartialValues\n );\n const inputVariables = new Set<string>();\n for (const promptMessage of flattenedMessages) {\n // eslint-disable-next-line no-instanceof/no-instanceof\n if (promptMessage instanceof BaseMessage) continue;\n for (const inputVariable of promptMessage.inputVariables) {\n if (inputVariable in flattenedPartialVariables) {\n continue;\n }\n inputVariables.add(inputVariable);\n }\n }\n return new this<RunInput>({\n ...extra,\n inputVariables: [...inputVariables] as Extract<keyof RunInput, string>[],\n promptMessages: flattenedMessages,\n partialVariables: flattenedPartialVariables,\n templateFormat: extra?.templateFormat,\n });\n }\n\n /** @deprecated Renamed to .fromMessages */\n // eslint-disable-next-line @typescript-eslint/no-explicit-any\n static fromPromptMessages<RunInput extends InputValues = any>(\n promptMessages: (\n | ChatPromptTemplate<InputValues, string>\n | BaseMessagePromptTemplateLike\n )[]\n ): ChatPromptTemplate<RunInput> {\n return this.fromMessages(promptMessages);\n }\n}\n"],"mappings":"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"}
1
+ {"version":3,"file":"chat.js","names":["input: RunInput","options?: BaseCallbackConfig","input","fields:\n | Extract<keyof RunInput, string>\n | MessagesPlaceholderFields<Extract<keyof RunInput, string>>","values: TypedPromptInputValues<RunInput>","e: any","fields:\n | MessageStringPromptTemplateFields<\n InputValues<Extract<keyof RunInput, string>>\n >\n | BaseStringPromptTemplate<\n InputValues<Extract<keyof RunInput, string>>,\n string\n >","input: BasePromptTemplateInput<RunInput, PartialVariableName>","fields:\n | ChatMessagePromptTemplateFields<\n InputValues<Extract<keyof RunInput, string>>\n >\n | BaseStringPromptTemplate<InputValues<Extract<keyof RunInput, string>>>","role?: string","values: RunInput","template: T","role: string","options?: { templateFormat?: TemplateFormat }","param: unknown","fields: any","additionalOptions?: _StringImageMessagePromptTemplateOptions","inputVariables: Extract<keyof RunInput, string>[]","content: MessageContent","name: string","template:\n | string\n | Array<\n | string\n | _TextTemplateParam\n | _ImageTemplateParam\n | Record<string, unknown>\n >","prompt: Array<\n | PromptTemplate<InputValues>\n | ImagePromptTemplate<InputValues>\n | DictPromptTemplate\n >","imgTemplateObject: ImagePromptTemplate<InputValues>","inputVariables: string[]","parsedTemplate: ParsedTemplateNode[]","item","input: TypedPromptInputValues<RunInput>","inputs: Record<string, any>","additionalContentFields: ContentBlock | undefined","baseMessagePromptTemplateLike: BaseMessagePromptTemplateLike","messagePromptTemplateLike: BaseMessagePromptTemplateLike","extra?: Extra","templateData:\n | string\n | (\n | string\n | _TextTemplateParam\n | _ImageTemplateParam\n // eslint-disable-next-line @typescript-eslint/no-explicit-any\n | Record<string, any>\n )[]","x: BaseMessagePromptTemplate | BaseMessage","input: ChatPromptTemplateInput<RunInput, PartialVariableName>","message: BaseMessage","inputValues: InputValues<\n PartialVariableName | Extract<keyof RunInput, string>\n >","resultMessages: BaseMessage[]","inputValues: InputValues","values: PartialValues<NewPartialVariableName>","options?: Omit<\n PromptTemplateInput<RunInput, string, TemplateFormat>,\n \"template\" | \"inputVariables\"\n >","promptMessages: (\n | ChatPromptTemplate<InputValues, string>\n | BaseMessagePromptTemplateLike\n )[]","extra?: Omit<\n Extra,\n \"inputVariables\" | \"promptMessages\" | \"partialVariables\"\n >","acc: Array<BaseMessagePromptTemplate | BaseMessage>"],"sources":["../../src/prompts/chat.ts"],"sourcesContent":["// Default generic \"any\" values are for backwards compatibility.\n// Replace with \"string\" when we are comfortable with a breaking change.\n\nimport type { BaseCallbackConfig } from \"../callbacks/manager.js\";\nimport {\n AIMessage,\n HumanMessage,\n SystemMessage,\n BaseMessage,\n ChatMessage,\n type BaseMessageLike,\n coerceMessageLikeToMessage,\n isBaseMessage,\n MessageContent,\n ContentBlock,\n} from \"../messages/index.js\";\nimport {\n type ChatPromptValueInterface,\n ChatPromptValue,\n} from \"../prompt_values.js\";\nimport type { InputValues, PartialValues } from \"../utils/types/index.js\";\nimport { Runnable } from \"../runnables/base.js\";\nimport { BaseStringPromptTemplate } from \"./string.js\";\nimport {\n BasePromptTemplate,\n type BasePromptTemplateInput,\n type TypedPromptInputValues,\n} from \"./base.js\";\nimport {\n PromptTemplate,\n type ParamsFromFString,\n PromptTemplateInput,\n ExtractedFStringParams,\n} from \"./prompt.js\";\nimport { ImagePromptTemplate } from \"./image.js\";\nimport {\n ParsedTemplateNode,\n TemplateFormat,\n parseFString,\n parseMustache,\n} from \"./template.js\";\nimport { addLangChainErrorFields } from \"../errors/index.js\";\nimport { DictPromptTemplate } from \"./dict.js\";\n\n/**\n * Abstract class that serves as a base for creating message prompt\n * templates. It defines how to format messages for different roles in a\n * conversation.\n */\nexport abstract class BaseMessagePromptTemplate<\n // eslint-disable-next-line @typescript-eslint/no-explicit-any\n RunInput extends InputValues = any,\n RunOutput extends BaseMessage[] = BaseMessage[]\n> extends Runnable<RunInput, RunOutput> {\n lc_namespace = [\"langchain_core\", \"prompts\", \"chat\"];\n\n lc_serializable = true;\n\n abstract inputVariables: Array<Extract<keyof RunInput, string>>;\n\n /**\n * Method that takes an object of TypedPromptInputValues and returns a\n * promise that resolves to an array of BaseMessage instances.\n * @param values Object of TypedPromptInputValues\n * @returns Formatted array of BaseMessages\n */\n abstract formatMessages(\n values: TypedPromptInputValues<RunInput>\n ): Promise<RunOutput>;\n\n /**\n * Calls the formatMessages method with the provided input and options.\n * @param input Input for the formatMessages method\n * @param options Optional BaseCallbackConfig\n * @returns Formatted output messages\n */\n async invoke(\n input: RunInput,\n options?: BaseCallbackConfig\n ): Promise<RunOutput> {\n return this._callWithConfig(\n (input: RunInput) => this.formatMessages(input),\n input,\n { ...options, runType: \"prompt\" }\n );\n }\n}\n\n/**\n * Interface for the fields of a MessagePlaceholder.\n */\nexport interface MessagesPlaceholderFields<T extends string> {\n variableName: T;\n optional?: boolean;\n}\n\n/**\n * Class that represents a placeholder for messages in a chat prompt. It\n * extends the BaseMessagePromptTemplate.\n */\nexport class MessagesPlaceholder<\n // eslint-disable-next-line @typescript-eslint/no-explicit-any\n RunInput extends InputValues = any\n >\n extends BaseMessagePromptTemplate<RunInput>\n implements MessagesPlaceholderFields<Extract<keyof RunInput, string>>\n{\n static lc_name() {\n return \"MessagesPlaceholder\";\n }\n\n variableName: Extract<keyof RunInput, string>;\n\n optional: boolean;\n\n constructor(variableName: Extract<keyof RunInput, string>);\n\n constructor(\n fields: MessagesPlaceholderFields<Extract<keyof RunInput, string>>\n );\n\n constructor(\n fields:\n | Extract<keyof RunInput, string>\n | MessagesPlaceholderFields<Extract<keyof RunInput, string>>\n ) {\n if (typeof fields === \"string\") {\n // eslint-disable-next-line no-param-reassign\n fields = { variableName: fields };\n }\n super(fields);\n this.variableName = fields.variableName;\n this.optional = fields.optional ?? false;\n }\n\n get inputVariables() {\n return [this.variableName];\n }\n\n async formatMessages(\n values: TypedPromptInputValues<RunInput>\n ): Promise<BaseMessage[]> {\n const input = values[this.variableName];\n if (this.optional && !input) {\n return [];\n } else if (!input) {\n const error = new Error(\n `Field \"${this.variableName}\" in prompt uses a MessagesPlaceholder, which expects an array of BaseMessages as an input value. Received: undefined`\n );\n error.name = \"InputFormatError\";\n throw error;\n }\n\n let formattedMessages;\n try {\n if (Array.isArray(input)) {\n formattedMessages = input.map(coerceMessageLikeToMessage);\n } else {\n formattedMessages = [coerceMessageLikeToMessage(input)];\n }\n // eslint-disable-next-line @typescript-eslint/no-explicit-any\n } catch (e: any) {\n const readableInput =\n typeof input === \"string\" ? input : JSON.stringify(input, null, 2);\n const error = new Error(\n [\n `Field \"${this.variableName}\" in prompt uses a MessagesPlaceholder, which expects an array of BaseMessages or coerceable values as input.`,\n `Received value: ${readableInput}`,\n `Additional message: ${e.message}`,\n ].join(\"\\n\\n\")\n );\n error.name = \"InputFormatError\";\n // eslint-disable-next-line @typescript-eslint/no-explicit-any\n (error as any).lc_error_code = e.lc_error_code;\n throw error;\n }\n\n return formattedMessages;\n }\n}\n\n/**\n * Interface for the fields of a MessageStringPromptTemplate.\n */\nexport interface MessageStringPromptTemplateFields<\n // eslint-disable-next-line @typescript-eslint/no-explicit-any\n T extends InputValues = any\n> {\n prompt: BaseStringPromptTemplate<T, string>;\n}\n\n/**\n * Abstract class that serves as a base for creating message string prompt\n * templates. It extends the BaseMessagePromptTemplate.\n */\nexport abstract class BaseMessageStringPromptTemplate<\n // eslint-disable-next-line @typescript-eslint/no-explicit-any\n RunInput extends InputValues = any\n> extends BaseMessagePromptTemplate<RunInput> {\n prompt: BaseStringPromptTemplate<\n InputValues<Extract<keyof RunInput, string>>,\n string\n >;\n\n constructor(\n prompt: BaseStringPromptTemplate<\n InputValues<Extract<keyof RunInput, string>>\n >\n );\n\n constructor(\n fields: MessageStringPromptTemplateFields<\n InputValues<Extract<keyof RunInput, string>>\n >\n );\n\n constructor(\n fields:\n | MessageStringPromptTemplateFields<\n InputValues<Extract<keyof RunInput, string>>\n >\n | BaseStringPromptTemplate<\n InputValues<Extract<keyof RunInput, string>>,\n string\n >\n ) {\n if (!(\"prompt\" in fields)) {\n // eslint-disable-next-line no-param-reassign\n fields = { prompt: fields };\n }\n super(fields);\n this.prompt = fields.prompt;\n }\n\n get inputVariables() {\n return this.prompt.inputVariables;\n }\n\n abstract format(\n values: TypedPromptInputValues<RunInput>\n ): Promise<BaseMessage>;\n\n async formatMessages(\n values: TypedPromptInputValues<RunInput>\n ): Promise<BaseMessage[]> {\n return [await this.format(values)];\n }\n}\n\n/**\n * Abstract class that serves as a base for creating chat prompt\n * templates. It extends the BasePromptTemplate.\n */\nexport abstract class BaseChatPromptTemplate<\n // eslint-disable-next-line @typescript-eslint/no-explicit-any\n RunInput extends InputValues = any,\n // eslint-disable-next-line @typescript-eslint/no-explicit-any\n PartialVariableName extends string = any\n> extends BasePromptTemplate<\n RunInput,\n ChatPromptValueInterface,\n PartialVariableName\n> {\n constructor(input: BasePromptTemplateInput<RunInput, PartialVariableName>) {\n super(input);\n }\n\n abstract formatMessages(\n values: TypedPromptInputValues<RunInput>\n ): Promise<BaseMessage[]>;\n\n async format(values: TypedPromptInputValues<RunInput>): Promise<string> {\n return (await this.formatPromptValue(values)).toString();\n }\n\n async formatPromptValue(\n values: TypedPromptInputValues<RunInput>\n ): Promise<ChatPromptValueInterface> {\n const resultMessages = await this.formatMessages(values);\n return new ChatPromptValue(resultMessages);\n }\n}\n\n/**\n * Interface for the fields of a ChatMessagePromptTemplate.\n */\n// eslint-disable-next-line @typescript-eslint/no-explicit-any\nexport interface ChatMessagePromptTemplateFields<T extends InputValues = any>\n extends MessageStringPromptTemplateFields<T> {\n role: string;\n}\n\n/**\n * Class that represents a chat message prompt template. It extends the\n * BaseMessageStringPromptTemplate.\n */\nexport class ChatMessagePromptTemplate<\n // eslint-disable-next-line @typescript-eslint/no-explicit-any\n RunInput extends InputValues = any\n> extends BaseMessageStringPromptTemplate<RunInput> {\n static lc_name() {\n return \"ChatMessagePromptTemplate\";\n }\n\n role: string;\n\n constructor(\n prompt: BaseStringPromptTemplate<\n InputValues<Extract<keyof RunInput, string>>\n >,\n role: string\n );\n\n constructor(\n fields: ChatMessagePromptTemplateFields<\n InputValues<Extract<keyof RunInput, string>>\n >\n );\n\n constructor(\n fields:\n | ChatMessagePromptTemplateFields<\n InputValues<Extract<keyof RunInput, string>>\n >\n | BaseStringPromptTemplate<InputValues<Extract<keyof RunInput, string>>>,\n role?: string\n ) {\n if (!(\"prompt\" in fields)) {\n // eslint-disable-next-line no-param-reassign\n fields = { prompt: fields, role: role! };\n }\n super(fields);\n this.role = fields.role;\n }\n\n async format(values: RunInput): Promise<BaseMessage> {\n return new ChatMessage(await this.prompt.format(values), this.role);\n }\n\n static fromTemplate<\n RunInput extends InputValues = Symbol,\n T extends string = string\n >(template: T, role: string, options?: { templateFormat?: TemplateFormat }) {\n return new this(\n PromptTemplate.fromTemplate<RunInput, T>(template, {\n templateFormat: options?.templateFormat,\n }),\n role\n );\n }\n}\n\ninterface _TextTemplateParam {\n // eslint-disable-next-line @typescript-eslint/no-explicit-any\n text?: string | Record<string, any>;\n}\n\nfunction isTextTemplateParam(param: unknown): param is _TextTemplateParam {\n if (param === null || typeof param !== \"object\" || Array.isArray(param)) {\n return false;\n }\n return (\n Object.keys(param).length === 1 &&\n \"text\" in param &&\n typeof param.text === \"string\"\n );\n}\n\ninterface _ImageTemplateParam {\n // eslint-disable-next-line @typescript-eslint/no-explicit-any\n image_url?: string | Record<string, any>;\n}\n\nfunction isImageTemplateParam(param: unknown): param is _ImageTemplateParam {\n if (param === null || typeof param !== \"object\" || Array.isArray(param)) {\n return false;\n }\n return (\n \"image_url\" in param &&\n (typeof param.image_url === \"string\" ||\n (typeof param.image_url === \"object\" &&\n param.image_url !== null &&\n \"url\" in param.image_url &&\n typeof param.image_url.url === \"string\"))\n );\n}\n\ntype MessageClass =\n | typeof HumanMessage\n | typeof AIMessage\n | typeof SystemMessage;\n\ntype ChatMessageClass = typeof ChatMessage;\n\ninterface _StringImageMessagePromptTemplateOptions<\n Format extends TemplateFormat = TemplateFormat\n> extends Record<string, unknown> {\n templateFormat?: Format;\n}\n\nclass _StringImageMessagePromptTemplate<\n // eslint-disable-next-line @typescript-eslint/no-explicit-any\n RunInput extends InputValues = any,\n RunOutput extends BaseMessage[] = BaseMessage[]\n> extends BaseMessagePromptTemplate<RunInput, RunOutput> {\n lc_namespace = [\"langchain_core\", \"prompts\", \"chat\"];\n\n lc_serializable = true;\n\n inputVariables: Array<Extract<keyof RunInput, string>> = [];\n\n additionalOptions: _StringImageMessagePromptTemplateOptions = {};\n\n prompt:\n | BaseStringPromptTemplate<\n InputValues<Extract<keyof RunInput, string>>,\n string\n >\n | Array<\n | BaseStringPromptTemplate<\n InputValues<Extract<keyof RunInput, string>>,\n string\n >\n | ImagePromptTemplate<\n InputValues<Extract<keyof RunInput, string>>,\n string\n >\n | MessageStringPromptTemplateFields<\n InputValues<Extract<keyof RunInput, string>>\n >\n | DictPromptTemplate<InputValues<Extract<keyof RunInput, string>>>\n >;\n\n protected messageClass?: MessageClass;\n\n static _messageClass(): MessageClass {\n throw new Error(\n \"Can not invoke _messageClass from inside _StringImageMessagePromptTemplate\"\n );\n }\n\n // ChatMessage contains role field, others don't.\n // Because of this, we have a separate class property for ChatMessage.\n protected chatMessageClass?: ChatMessageClass;\n\n constructor(\n /** @TODO When we come up with a better way to type prompt templates, fix this */\n // eslint-disable-next-line @typescript-eslint/no-explicit-any\n fields: any,\n additionalOptions?: _StringImageMessagePromptTemplateOptions\n ) {\n if (!(\"prompt\" in fields)) {\n // eslint-disable-next-line no-param-reassign\n fields = { prompt: fields };\n }\n super(fields);\n this.prompt = fields.prompt;\n if (Array.isArray(this.prompt)) {\n let inputVariables: Extract<keyof RunInput, string>[] = [];\n this.prompt.forEach((prompt) => {\n if (\"inputVariables\" in prompt) {\n inputVariables = inputVariables.concat(prompt.inputVariables);\n }\n });\n this.inputVariables = inputVariables;\n } else {\n this.inputVariables = this.prompt.inputVariables;\n }\n this.additionalOptions = additionalOptions ?? this.additionalOptions;\n }\n\n createMessage(content: MessageContent) {\n // eslint-disable-next-line @typescript-eslint/no-explicit-any\n const constructor = this.constructor as any;\n if (constructor._messageClass()) {\n const MsgClass = constructor._messageClass();\n return new MsgClass({ content });\n } else if (constructor.chatMessageClass) {\n const MsgClass = constructor.chatMessageClass();\n // Assuming ChatMessage constructor also takes a content argument\n return new MsgClass({\n content,\n role: this.getRoleFromMessageClass(MsgClass.lc_name()),\n });\n } else {\n throw new Error(\"No message class defined\");\n }\n }\n\n getRoleFromMessageClass(name: string) {\n switch (name) {\n case \"HumanMessage\":\n return \"human\";\n case \"AIMessage\":\n return \"ai\";\n case \"SystemMessage\":\n return \"system\";\n case \"ChatMessage\":\n return \"chat\";\n default:\n throw new Error(\"Invalid message class name\");\n }\n }\n\n static fromTemplate(\n template:\n | string\n | Array<\n | string\n | _TextTemplateParam\n | _ImageTemplateParam\n | Record<string, unknown>\n >,\n additionalOptions?: _StringImageMessagePromptTemplateOptions\n ) {\n if (typeof template === \"string\") {\n return new this(PromptTemplate.fromTemplate(template, additionalOptions));\n }\n const prompt: Array<\n | PromptTemplate<InputValues>\n | ImagePromptTemplate<InputValues>\n | DictPromptTemplate\n > = [];\n for (const item of template) {\n // handle string cases\n if (typeof item === \"string\") {\n prompt.push(PromptTemplate.fromTemplate(item, additionalOptions));\n } else if (item === null) {\n // pass\n } else if (isTextTemplateParam(item)) {\n let text = \"\";\n if (typeof item.text === \"string\") {\n text = item.text ?? \"\";\n }\n\n const options = {\n ...additionalOptions,\n additionalContentFields: item as ContentBlock,\n };\n prompt.push(PromptTemplate.fromTemplate(text, options));\n } else if (isImageTemplateParam(item)) {\n let imgTemplate = item.image_url ?? \"\";\n let imgTemplateObject: ImagePromptTemplate<InputValues>;\n let inputVariables: string[] = [];\n if (typeof imgTemplate === \"string\") {\n let parsedTemplate: ParsedTemplateNode[];\n if (additionalOptions?.templateFormat === \"mustache\") {\n parsedTemplate = parseMustache(imgTemplate);\n } else {\n parsedTemplate = parseFString(imgTemplate);\n }\n\n const variables = parsedTemplate.flatMap((item) =>\n item.type === \"variable\" ? [item.name] : []\n );\n\n if ((variables?.length ?? 0) > 0) {\n if (variables.length > 1) {\n throw new Error(\n `Only one format variable allowed per image template.\\nGot: ${variables}\\nFrom: ${imgTemplate}`\n );\n }\n inputVariables = [variables[0]];\n } else {\n inputVariables = [];\n }\n\n imgTemplate = { url: imgTemplate };\n imgTemplateObject = new ImagePromptTemplate<InputValues>({\n template: imgTemplate,\n inputVariables,\n templateFormat: additionalOptions?.templateFormat,\n additionalContentFields: item as ContentBlock,\n });\n } else if (typeof imgTemplate === \"object\") {\n if (\"url\" in imgTemplate) {\n let parsedTemplate: ParsedTemplateNode[];\n if (additionalOptions?.templateFormat === \"mustache\") {\n parsedTemplate = parseMustache(imgTemplate.url);\n } else {\n parsedTemplate = parseFString(imgTemplate.url);\n }\n\n inputVariables = parsedTemplate.flatMap((item) =>\n item.type === \"variable\" ? [item.name] : []\n );\n } else {\n inputVariables = [];\n }\n imgTemplateObject = new ImagePromptTemplate<InputValues>({\n template: imgTemplate,\n inputVariables,\n templateFormat: additionalOptions?.templateFormat,\n additionalContentFields: item as ContentBlock,\n });\n } else {\n throw new Error(\"Invalid image template\");\n }\n prompt.push(imgTemplateObject);\n } else if (typeof item === \"object\") {\n prompt.push(\n new DictPromptTemplate({\n template: item,\n templateFormat: additionalOptions?.templateFormat,\n })\n );\n }\n }\n return new this({ prompt, additionalOptions });\n }\n\n async format(input: TypedPromptInputValues<RunInput>): Promise<BaseMessage> {\n // eslint-disable-next-line no-instanceof/no-instanceof\n if (this.prompt instanceof BaseStringPromptTemplate) {\n const text = await this.prompt.format(input);\n\n return this.createMessage(text);\n } else {\n const content: MessageContent = [];\n for (const prompt of this.prompt) {\n // eslint-disable-next-line @typescript-eslint/no-explicit-any\n let inputs: Record<string, any> = {};\n if (!(\"inputVariables\" in prompt)) {\n throw new Error(\n `Prompt ${prompt} does not have inputVariables defined.`\n );\n }\n for (const item of prompt.inputVariables) {\n if (!inputs) {\n inputs = { [item]: input[item] };\n }\n inputs = { ...inputs, [item]: input[item] };\n }\n // eslint-disable-next-line no-instanceof/no-instanceof\n if (prompt instanceof BaseStringPromptTemplate) {\n const formatted = await prompt.format(\n inputs as TypedPromptInputValues<RunInput>\n );\n let additionalContentFields: ContentBlock | undefined;\n if (\"additionalContentFields\" in prompt) {\n // eslint-disable-next-line @typescript-eslint/no-explicit-any\n additionalContentFields = prompt.additionalContentFields as any;\n }\n if (formatted !== \"\") {\n content.push({\n ...additionalContentFields,\n type: \"text\",\n text: formatted,\n });\n }\n /** @TODO replace this */\n // eslint-disable-next-line no-instanceof/no-instanceof\n } else if (prompt instanceof ImagePromptTemplate) {\n const formatted = await prompt.format(\n inputs as TypedPromptInputValues<RunInput>\n );\n let additionalContentFields: ContentBlock | undefined;\n if (\"additionalContentFields\" in prompt) {\n // eslint-disable-next-line @typescript-eslint/no-explicit-any\n additionalContentFields = prompt.additionalContentFields as any;\n }\n content.push({\n ...additionalContentFields,\n type: \"image_url\",\n image_url: formatted,\n });\n // eslint-disable-next-line no-instanceof/no-instanceof\n } else if (prompt instanceof DictPromptTemplate) {\n const formatted = await prompt.format(\n inputs as TypedPromptInputValues<RunInput>\n );\n let additionalContentFields: ContentBlock | undefined;\n if (\"additionalContentFields\" in prompt) {\n // eslint-disable-next-line @typescript-eslint/no-explicit-any\n additionalContentFields = prompt.additionalContentFields as any;\n }\n content.push({\n ...additionalContentFields,\n ...formatted,\n } as ContentBlock);\n }\n }\n return this.createMessage(content);\n }\n }\n\n async formatMessages(values: RunInput): Promise<RunOutput> {\n return [await this.format(values)] as BaseMessage[] as RunOutput;\n }\n}\n\n/**\n * Class that represents a human message prompt template. It extends the\n * BaseMessageStringPromptTemplate.\n * @example\n * ```typescript\n * const message = HumanMessagePromptTemplate.fromTemplate(\"{text}\");\n * const formatted = await message.format({ text: \"Hello world!\" });\n *\n * const chatPrompt = ChatPromptTemplate.fromMessages([message]);\n * const formattedChatPrompt = await chatPrompt.invoke({\n * text: \"Hello world!\",\n * });\n * ```\n */\nexport class HumanMessagePromptTemplate<\n // eslint-disable-next-line @typescript-eslint/no-explicit-any\n RunInput extends InputValues = any\n> extends _StringImageMessagePromptTemplate<RunInput> {\n static _messageClass(): typeof HumanMessage {\n return HumanMessage;\n }\n\n static lc_name() {\n return \"HumanMessagePromptTemplate\";\n }\n}\n\n/**\n * Class that represents an AI message prompt template. It extends the\n * BaseMessageStringPromptTemplate.\n */\nexport class AIMessagePromptTemplate<\n // eslint-disable-next-line @typescript-eslint/no-explicit-any\n RunInput extends InputValues = any\n> extends _StringImageMessagePromptTemplate<RunInput> {\n static _messageClass(): typeof AIMessage {\n return AIMessage;\n }\n\n static lc_name() {\n return \"AIMessagePromptTemplate\";\n }\n}\n\n/**\n * Class that represents a system message prompt template. It extends the\n * BaseMessageStringPromptTemplate.\n * @example\n * ```typescript\n * const message = SystemMessagePromptTemplate.fromTemplate(\"{text}\");\n * const formatted = await message.format({ text: \"Hello world!\" });\n *\n * const chatPrompt = ChatPromptTemplate.fromMessages([message]);\n * const formattedChatPrompt = await chatPrompt.invoke({\n * text: \"Hello world!\",\n * });\n * ```\n */\nexport class SystemMessagePromptTemplate<\n // eslint-disable-next-line @typescript-eslint/no-explicit-any\n RunInput extends InputValues = any\n> extends _StringImageMessagePromptTemplate<RunInput> {\n static _messageClass(): typeof SystemMessage {\n return SystemMessage;\n }\n\n static lc_name() {\n return \"SystemMessagePromptTemplate\";\n }\n}\n\n/**\n * Interface for the input of a ChatPromptTemplate.\n */\nexport interface ChatPromptTemplateInput<\n // eslint-disable-next-line @typescript-eslint/no-explicit-any\n RunInput extends InputValues = any,\n // eslint-disable-next-line @typescript-eslint/no-explicit-any\n PartialVariableName extends string = any\n> extends BasePromptTemplateInput<RunInput, PartialVariableName> {\n /**\n * The prompt messages\n */\n promptMessages: Array<BaseMessagePromptTemplate | BaseMessage>;\n\n /**\n * Whether to try validating the template on initialization\n *\n * @defaultValue `true`\n */\n validateTemplate?: boolean;\n\n /**\n * The formatting method to use on the prompt.\n * @default \"f-string\"\n */\n templateFormat?: TemplateFormat;\n}\n\nexport type BaseMessagePromptTemplateLike =\n | BaseMessagePromptTemplate\n | BaseMessageLike;\n\nfunction _isBaseMessagePromptTemplate(\n baseMessagePromptTemplateLike: BaseMessagePromptTemplateLike\n): baseMessagePromptTemplateLike is BaseMessagePromptTemplate {\n return (\n typeof (baseMessagePromptTemplateLike as BaseMessagePromptTemplate)\n .formatMessages === \"function\"\n );\n}\n\nfunction _coerceMessagePromptTemplateLike<\n // eslint-disable-next-line @typescript-eslint/no-explicit-any\n RunInput extends InputValues = any,\n Extra extends Omit<\n ChatPromptTemplateInput<RunInput>,\n \"inputVariables\" | \"promptMessages\" | \"partialVariables\"\n > = Omit<\n ChatPromptTemplateInput<RunInput>,\n \"inputVariables\" | \"promptMessages\" | \"partialVariables\"\n >\n>(\n messagePromptTemplateLike: BaseMessagePromptTemplateLike,\n extra?: Extra\n): BaseMessagePromptTemplate | BaseMessage {\n if (\n _isBaseMessagePromptTemplate(messagePromptTemplateLike) ||\n isBaseMessage(messagePromptTemplateLike)\n ) {\n return messagePromptTemplateLike;\n }\n if (\n Array.isArray(messagePromptTemplateLike) &&\n messagePromptTemplateLike[0] === \"placeholder\"\n ) {\n const messageContent = messagePromptTemplateLike[1];\n if (\n extra?.templateFormat === \"mustache\" &&\n typeof messageContent === \"string\" &&\n messageContent.slice(0, 2) === \"{{\" &&\n messageContent.slice(-2) === \"}}\"\n ) {\n const variableName = messageContent.slice(2, -2);\n return new MessagesPlaceholder({ variableName, optional: true });\n } else if (\n typeof messageContent === \"string\" &&\n messageContent[0] === \"{\" &&\n messageContent[messageContent.length - 1] === \"}\"\n ) {\n const variableName = messageContent.slice(1, -1);\n return new MessagesPlaceholder({ variableName, optional: true });\n }\n throw new Error(\n `Invalid placeholder template for format ${\n extra?.templateFormat ?? `\"f-string\"`\n }: \"${\n messagePromptTemplateLike[1]\n }\". Expected a variable name surrounded by ${\n extra?.templateFormat === \"mustache\" ? \"double\" : \"single\"\n } curly braces.`\n );\n }\n const message = coerceMessageLikeToMessage(messagePromptTemplateLike);\n let templateData:\n | string\n | (\n | string\n | _TextTemplateParam\n | _ImageTemplateParam\n // eslint-disable-next-line @typescript-eslint/no-explicit-any\n | Record<string, any>\n )[];\n\n if (typeof message.content === \"string\") {\n templateData = message.content;\n } else {\n // Assuming message.content is an array of complex objects, transform it.\n templateData = message.content.map((item) => {\n if (\"text\" in item) {\n return { ...item, text: item.text };\n } else if (\"image_url\" in item) {\n return { ...item, image_url: item.image_url };\n } else {\n return item;\n }\n });\n }\n\n if (message._getType() === \"human\") {\n return HumanMessagePromptTemplate.fromTemplate(templateData, extra);\n } else if (message._getType() === \"ai\") {\n return AIMessagePromptTemplate.fromTemplate(templateData, extra);\n } else if (message._getType() === \"system\") {\n return SystemMessagePromptTemplate.fromTemplate(templateData, extra);\n } else if (ChatMessage.isInstance(message)) {\n return ChatMessagePromptTemplate.fromTemplate(\n message.content as string,\n message.role,\n extra\n );\n } else {\n throw new Error(\n `Could not coerce message prompt template from input. Received message type: \"${message._getType()}\".`\n );\n }\n}\n\nfunction isMessagesPlaceholder(\n x: BaseMessagePromptTemplate | BaseMessage\n): x is MessagesPlaceholder {\n // eslint-disable-next-line @typescript-eslint/no-explicit-any\n return (x.constructor as any).lc_name() === \"MessagesPlaceholder\";\n}\n\n/**\n * Class that represents a chat prompt. It extends the\n * BaseChatPromptTemplate and uses an array of BaseMessagePromptTemplate\n * instances to format a series of messages for a conversation.\n * @example\n * ```typescript\n * const message = SystemMessagePromptTemplate.fromTemplate(\"{text}\");\n * const chatPrompt = ChatPromptTemplate.fromMessages([\n * [\"ai\", \"You are a helpful assistant.\"],\n * message,\n * ]);\n * const formattedChatPrompt = await chatPrompt.invoke({\n * text: \"Hello world!\",\n * });\n * ```\n */\nexport class ChatPromptTemplate<\n // eslint-disable-next-line @typescript-eslint/no-explicit-any\n RunInput extends InputValues = any,\n // eslint-disable-next-line @typescript-eslint/no-explicit-any\n PartialVariableName extends string = any\n >\n extends BaseChatPromptTemplate<RunInput, PartialVariableName>\n implements ChatPromptTemplateInput<RunInput, PartialVariableName>\n{\n static lc_name() {\n return \"ChatPromptTemplate\";\n }\n\n get lc_aliases(): Record<string, string> {\n return {\n promptMessages: \"messages\",\n };\n }\n\n promptMessages: Array<BaseMessagePromptTemplate | BaseMessage>;\n\n validateTemplate = true;\n\n templateFormat: TemplateFormat = \"f-string\";\n\n constructor(input: ChatPromptTemplateInput<RunInput, PartialVariableName>) {\n super(input);\n // If input is mustache and validateTemplate is not defined, set it to false\n if (\n input.templateFormat === \"mustache\" &&\n input.validateTemplate === undefined\n ) {\n this.validateTemplate = false;\n }\n Object.assign(this, input);\n\n if (this.validateTemplate) {\n const inputVariablesMessages = new Set<string>();\n for (const promptMessage of this.promptMessages) {\n // eslint-disable-next-line no-instanceof/no-instanceof\n if (promptMessage instanceof BaseMessage) continue;\n for (const inputVariable of promptMessage.inputVariables) {\n inputVariablesMessages.add(inputVariable);\n }\n }\n\n const totalInputVariables = this.inputVariables as string[];\n const inputVariablesInstance = new Set(\n this.partialVariables\n ? totalInputVariables.concat(Object.keys(this.partialVariables))\n : totalInputVariables\n );\n const difference = new Set(\n [...inputVariablesInstance].filter(\n (x) => !inputVariablesMessages.has(x)\n )\n );\n if (difference.size > 0) {\n throw new Error(\n `Input variables \\`${[\n ...difference,\n ]}\\` are not used in any of the prompt messages.`\n );\n }\n const otherDifference = new Set(\n [...inputVariablesMessages].filter(\n (x) => !inputVariablesInstance.has(x)\n )\n );\n if (otherDifference.size > 0) {\n throw new Error(\n `Input variables \\`${[\n ...otherDifference,\n ]}\\` are used in prompt messages but not in the prompt template.`\n );\n }\n }\n }\n\n _getPromptType(): \"chat\" {\n return \"chat\";\n }\n\n private async _parseImagePrompts(\n message: BaseMessage,\n inputValues: InputValues<\n PartialVariableName | Extract<keyof RunInput, string>\n >\n ): Promise<BaseMessage> {\n if (typeof message.content === \"string\") {\n return message;\n }\n const formattedMessageContent = await Promise.all(\n message.content.map(async (item) => {\n if (item.type !== \"image_url\") {\n return item;\n }\n\n let imageUrl = \"\";\n if (typeof item.image_url === \"string\") {\n imageUrl = item.image_url;\n } else if (\n typeof item.image_url === \"object\" &&\n item.image_url !== null &&\n \"url\" in item.image_url &&\n typeof item.image_url.url === \"string\"\n ) {\n imageUrl = item.image_url.url;\n }\n\n const promptTemplatePlaceholder = PromptTemplate.fromTemplate(\n imageUrl,\n {\n templateFormat: this.templateFormat,\n }\n );\n const formattedUrl = await promptTemplatePlaceholder.format(\n inputValues\n );\n\n if (\n typeof item.image_url === \"object\" &&\n item.image_url !== null &&\n \"url\" in item.image_url\n ) {\n // eslint-disable-next-line no-param-reassign\n item.image_url.url = formattedUrl;\n } else {\n item.image_url = formattedUrl;\n }\n return item;\n })\n );\n message.content = formattedMessageContent;\n return message;\n }\n\n async formatMessages(\n values: TypedPromptInputValues<RunInput>\n ): Promise<BaseMessage[]> {\n const allValues = await this.mergePartialAndUserVariables(values);\n let resultMessages: BaseMessage[] = [];\n\n for (const promptMessage of this.promptMessages) {\n // eslint-disable-next-line no-instanceof/no-instanceof\n if (promptMessage instanceof BaseMessage) {\n resultMessages.push(\n await this._parseImagePrompts(promptMessage, allValues)\n );\n } else {\n let inputValues: InputValues;\n\n if (this.templateFormat === \"mustache\") {\n inputValues = { ...allValues };\n } else {\n inputValues = promptMessage.inputVariables.reduce(\n (acc, inputVariable) => {\n if (\n !(inputVariable in allValues) &&\n !(\n isMessagesPlaceholder(promptMessage) && promptMessage.optional\n )\n ) {\n const error = addLangChainErrorFields(\n new Error(\n `Missing value for input variable \\`${inputVariable.toString()}\\``\n ),\n \"INVALID_PROMPT_INPUT\"\n );\n throw error;\n }\n acc[inputVariable] = allValues[inputVariable];\n return acc;\n },\n {} as InputValues\n );\n }\n const message = await promptMessage.formatMessages(inputValues);\n resultMessages = resultMessages.concat(message);\n }\n }\n return resultMessages;\n }\n\n async partial<NewPartialVariableName extends string>(\n values: PartialValues<NewPartialVariableName>\n ) {\n // This is implemented in a way it doesn't require making\n // BaseMessagePromptTemplate aware of .partial()\n const newInputVariables = this.inputVariables.filter(\n (iv) => !(iv in values)\n ) as Exclude<Extract<keyof RunInput, string>, NewPartialVariableName>[];\n const newPartialVariables = {\n ...(this.partialVariables ?? {}),\n ...values,\n } as PartialValues<PartialVariableName | NewPartialVariableName>;\n const promptDict = {\n ...this,\n inputVariables: newInputVariables,\n partialVariables: newPartialVariables,\n };\n return new ChatPromptTemplate<\n InputValues<\n Exclude<Extract<keyof RunInput, string>, NewPartialVariableName>\n >\n >(promptDict);\n }\n\n /**\n * Load prompt template from a template f-string\n */\n static fromTemplate<\n RunInput extends InputValues = Symbol,\n T extends string = string\n >(\n template: T,\n options?: Omit<\n PromptTemplateInput<RunInput, string, \"f-string\">,\n \"template\" | \"inputVariables\"\n >\n ): ChatPromptTemplate<ExtractedFStringParams<T, RunInput>>;\n\n static fromTemplate<\n RunInput extends InputValues = Symbol,\n T extends string = string\n >(\n template: T,\n options?: Omit<\n PromptTemplateInput<RunInput, string>,\n \"template\" | \"inputVariables\"\n >\n ): ChatPromptTemplate<ExtractedFStringParams<T, RunInput>>;\n\n static fromTemplate<\n RunInput extends InputValues = Symbol,\n T extends string = string\n >(\n template: T,\n options?: Omit<\n PromptTemplateInput<RunInput, string, \"mustache\">,\n \"template\" | \"inputVariables\"\n >\n ): ChatPromptTemplate<InputValues>;\n\n static fromTemplate<\n RunInput extends InputValues = Symbol,\n T extends string = string\n >(\n template: T,\n options?: Omit<\n PromptTemplateInput<RunInput, string, TemplateFormat>,\n \"template\" | \"inputVariables\"\n >\n ): ChatPromptTemplate<ExtractedFStringParams<T, RunInput> | InputValues> {\n const prompt = PromptTemplate.fromTemplate(template, options);\n const humanTemplate = new HumanMessagePromptTemplate({ prompt });\n return this.fromMessages<\n RunInput extends Symbol ? ParamsFromFString<T> : RunInput\n >([humanTemplate]);\n }\n\n /**\n * Create a chat model-specific prompt from individual chat messages\n * or message-like tuples.\n * @param promptMessages Messages to be passed to the chat model\n * @returns A new ChatPromptTemplate\n */\n static fromMessages<\n // eslint-disable-next-line @typescript-eslint/no-explicit-any\n RunInput extends InputValues = any,\n Extra extends ChatPromptTemplateInput<RunInput> = ChatPromptTemplateInput<RunInput>\n >(\n promptMessages: (\n | ChatPromptTemplate<InputValues, string>\n | BaseMessagePromptTemplateLike\n )[],\n extra?: Omit<\n Extra,\n \"inputVariables\" | \"promptMessages\" | \"partialVariables\"\n >\n ): ChatPromptTemplate<RunInput> {\n const flattenedMessages = promptMessages.reduce(\n (acc: Array<BaseMessagePromptTemplate | BaseMessage>, promptMessage) =>\n acc.concat(\n // eslint-disable-next-line no-instanceof/no-instanceof\n promptMessage instanceof ChatPromptTemplate\n ? promptMessage.promptMessages\n : [\n _coerceMessagePromptTemplateLike<\n RunInput,\n Omit<\n Extra,\n \"inputVariables\" | \"promptMessages\" | \"partialVariables\"\n >\n >(promptMessage, extra),\n ]\n ),\n []\n );\n const flattenedPartialVariables = promptMessages.reduce(\n (acc, promptMessage) =>\n // eslint-disable-next-line no-instanceof/no-instanceof\n promptMessage instanceof ChatPromptTemplate\n ? Object.assign(acc, promptMessage.partialVariables)\n : acc,\n Object.create(null) as PartialValues\n );\n const inputVariables = new Set<string>();\n for (const promptMessage of flattenedMessages) {\n // eslint-disable-next-line no-instanceof/no-instanceof\n if (promptMessage instanceof BaseMessage) continue;\n for (const inputVariable of promptMessage.inputVariables) {\n if (inputVariable in flattenedPartialVariables) {\n continue;\n }\n inputVariables.add(inputVariable);\n }\n }\n return new this<RunInput>({\n ...extra,\n inputVariables: [...inputVariables] as Extract<keyof RunInput, string>[],\n promptMessages: flattenedMessages,\n partialVariables: flattenedPartialVariables,\n templateFormat: extra?.templateFormat,\n });\n }\n}\n"],"mappings":"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"}
@@ -1,7 +1,7 @@
1
1
  import { InputValues } from "../utils/types/index.cjs";
2
2
  import { Runnable } from "../runnables/base.cjs";
3
- import { TemplateFormat } from "./template.cjs";
4
3
  import { TypedPromptInputValues } from "./base.cjs";
4
+ import { TemplateFormat } from "./template.cjs";
5
5
 
6
6
  //#region src/prompts/dict.d.ts
7
7
  declare class DictPromptTemplate<RunInput extends InputValues = InputValues, RunOutput extends Record<string, unknown> = Record<string, unknown>> extends Runnable<TypedPromptInputValues<RunInput>, RunOutput> {
@@ -1,7 +1,7 @@
1
1
  import { InputValues } from "../utils/types/index.js";
2
2
  import { Runnable } from "../runnables/base.js";
3
- import { TemplateFormat } from "./template.js";
4
3
  import { TypedPromptInputValues } from "./base.js";
4
+ import { TemplateFormat } from "./template.js";
5
5
 
6
6
  //#region src/prompts/dict.d.ts
7
7
  declare class DictPromptTemplate<RunInput extends InputValues = InputValues, RunOutput extends Record<string, unknown> = Record<string, unknown>> extends Runnable<TypedPromptInputValues<RunInput>, RunOutput> {
@@ -1,10 +1,10 @@
1
1
  import { BaseMessage } from "../messages/base.cjs";
2
2
  import { InputValues, PartialValues } from "../utils/types/index.cjs";
3
- import { TemplateFormat } from "./template.cjs";
4
- import { SerializedFewShotTemplate } from "./serde.cjs";
5
3
  import { BasePromptTemplateInput, Example, TypedPromptInputValues } from "./base.cjs";
6
4
  import { BaseExampleSelector } from "../example_selectors/base.cjs";
7
5
  import { BaseStringPromptTemplate } from "./string.cjs";
6
+ import { TemplateFormat } from "./template.cjs";
7
+ import { SerializedFewShotTemplate } from "./serde.cjs";
8
8
  import { PromptTemplate } from "./prompt.cjs";
9
9
  import { BaseChatPromptTemplate, BaseMessagePromptTemplate } from "./chat.cjs";
10
10
 
@@ -1,10 +1,10 @@
1
1
  import { BaseMessage } from "../messages/base.js";
2
2
  import { InputValues, PartialValues } from "../utils/types/index.js";
3
- import { TemplateFormat } from "./template.js";
4
- import { SerializedFewShotTemplate } from "./serde.js";
5
3
  import { BasePromptTemplateInput, Example, TypedPromptInputValues } from "./base.js";
6
4
  import { BaseExampleSelector } from "../example_selectors/base.js";
7
5
  import { BaseStringPromptTemplate } from "./string.js";
6
+ import { TemplateFormat } from "./template.js";
7
+ import { SerializedFewShotTemplate } from "./serde.js";
8
8
  import { PromptTemplate } from "./prompt.js";
9
9
  import { BaseChatPromptTemplate, BaseMessagePromptTemplate } from "./chat.js";
10
10
 
@@ -1,8 +1,8 @@
1
1
  import { ContentBlock } from "../messages/content/index.cjs";
2
2
  import { InputValues, PartialValues } from "../utils/types/index.cjs";
3
3
  import { ImageContent, ImagePromptValue } from "../prompt_values.cjs";
4
- import { TemplateFormat } from "./template.cjs";
5
4
  import { BasePromptTemplate, BasePromptTemplateInput, TypedPromptInputValues } from "./base.cjs";
5
+ import { TemplateFormat } from "./template.cjs";
6
6
 
7
7
  //#region src/prompts/image.d.ts
8
8
 
@@ -1,8 +1,8 @@
1
1
  import { ContentBlock } from "../messages/content/index.js";
2
2
  import { InputValues, PartialValues } from "../utils/types/index.js";
3
3
  import { ImageContent, ImagePromptValue } from "../prompt_values.js";
4
- import { TemplateFormat } from "./template.js";
5
4
  import { BasePromptTemplate, BasePromptTemplateInput, TypedPromptInputValues } from "./base.js";
5
+ import { TemplateFormat } from "./template.js";
6
6
 
7
7
  //#region src/prompts/image.d.ts
8
8
 
@@ -1,7 +1,7 @@
1
- import { DEFAULT_FORMATTER_MAPPING, DEFAULT_PARSER_MAPPING, ParsedFStringNode, ParsedTemplateNode, TemplateFormat, checkValidTemplate, interpolateFString, interpolateMustache, parseFString, parseMustache, parseTemplate, renderTemplate } from "./template.cjs";
2
- import { SerializedBasePromptTemplate, SerializedFewShotTemplate, SerializedPromptTemplate } from "./serde.cjs";
3
1
  import { BasePromptTemplate, BasePromptTemplateInput, Example, TypedPromptInputValues } from "./base.cjs";
4
2
  import { BaseStringPromptTemplate } from "./string.cjs";
3
+ import { DEFAULT_FORMATTER_MAPPING, DEFAULT_PARSER_MAPPING, ParsedFStringNode, ParsedTemplateNode, TemplateFormat, checkValidTemplate, interpolateFString, interpolateMustache, parseFString, parseMustache, parseTemplate, renderTemplate } from "./template.cjs";
4
+ import { SerializedBasePromptTemplate, SerializedFewShotTemplate, SerializedPromptTemplate } from "./serde.cjs";
5
5
  import { ExtractedFStringParams, ParamsFromFString, PromptTemplate, PromptTemplateInput } from "./prompt.cjs";
6
6
  import { ImagePromptTemplate, ImagePromptTemplateInput } from "./image.cjs";
7
7
  import { DictPromptTemplate } from "./dict.cjs";
@@ -1,7 +1,7 @@
1
- import { DEFAULT_FORMATTER_MAPPING, DEFAULT_PARSER_MAPPING, ParsedFStringNode, ParsedTemplateNode, TemplateFormat, checkValidTemplate, interpolateFString, interpolateMustache, parseFString, parseMustache, parseTemplate, renderTemplate } from "./template.js";
2
- import { SerializedBasePromptTemplate, SerializedFewShotTemplate, SerializedPromptTemplate } from "./serde.js";
3
1
  import { BasePromptTemplate, BasePromptTemplateInput, Example, TypedPromptInputValues } from "./base.js";
4
2
  import { BaseStringPromptTemplate } from "./string.js";
3
+ import { DEFAULT_FORMATTER_MAPPING, DEFAULT_PARSER_MAPPING, ParsedFStringNode, ParsedTemplateNode, TemplateFormat, checkValidTemplate, interpolateFString, interpolateMustache, parseFString, parseMustache, parseTemplate, renderTemplate } from "./template.js";
4
+ import { SerializedBasePromptTemplate, SerializedFewShotTemplate, SerializedPromptTemplate } from "./serde.js";
5
5
  import { ExtractedFStringParams, ParamsFromFString, PromptTemplate, PromptTemplateInput } from "./prompt.js";
6
6
  import { ImagePromptTemplate, ImagePromptTemplateInput } from "./image.js";
7
7
  import { DictPromptTemplate } from "./dict.js";
@@ -1,6 +1,6 @@
1
1
  import { InputValues, PartialValues } from "../utils/types/index.cjs";
2
- import { SerializedBasePromptTemplate } from "./serde.cjs";
3
2
  import { BasePromptTemplate, BasePromptTemplateInput } from "./base.cjs";
3
+ import { SerializedBasePromptTemplate } from "./serde.cjs";
4
4
 
5
5
  //#region src/prompts/pipeline.d.ts
6
6
 
@@ -1,6 +1,6 @@
1
1
  import { InputValues, PartialValues } from "../utils/types/index.js";
2
- import { SerializedBasePromptTemplate } from "./serde.js";
3
2
  import { BasePromptTemplate, BasePromptTemplateInput } from "./base.js";
3
+ import { SerializedBasePromptTemplate } from "./serde.js";
4
4
 
5
5
  //#region src/prompts/pipeline.d.ts
6
6
 
@@ -1,10 +1,10 @@
1
1
  import { ContentBlock } from "../messages/content/index.cjs";
2
2
  import { MessageContent } from "../messages/base.cjs";
3
3
  import { InputValues, PartialValues } from "../utils/types/index.cjs";
4
- import { TemplateFormat } from "./template.cjs";
5
- import { SerializedPromptTemplate } from "./serde.cjs";
6
4
  import { BasePromptTemplateInput, TypedPromptInputValues } from "./base.cjs";
7
5
  import { BaseStringPromptTemplate } from "./string.cjs";
6
+ import { TemplateFormat } from "./template.cjs";
7
+ import { SerializedPromptTemplate } from "./serde.cjs";
8
8
 
9
9
  //#region src/prompts/prompt.d.ts
10
10
 
@@ -1,10 +1,10 @@
1
1
  import { ContentBlock } from "../messages/content/index.js";
2
2
  import { MessageContent } from "../messages/base.js";
3
3
  import { InputValues, PartialValues } from "../utils/types/index.js";
4
- import { TemplateFormat } from "./template.js";
5
- import { SerializedPromptTemplate } from "./serde.js";
6
4
  import { BasePromptTemplateInput, TypedPromptInputValues } from "./base.js";
7
5
  import { BaseStringPromptTemplate } from "./string.js";
6
+ import { TemplateFormat } from "./template.js";
7
+ import { SerializedPromptTemplate } from "./serde.js";
8
8
 
9
9
  //#region src/prompts/prompt.d.ts
10
10
 
@@ -81,26 +81,11 @@ var BaseRetriever = class extends require_base.Runnable {
81
81
  * representing the most relevant documents to the query.
82
82
  */
83
83
  async invoke(input, options) {
84
- return this.getRelevantDocuments(input, require_config.ensureConfig(options));
85
- }
86
- /**
87
- * @deprecated Use .invoke() instead. Will be removed in 0.3.0.
88
- *
89
- * Main method used to retrieve relevant documents. It takes a query
90
- * string and an optional configuration object, and returns a promise that
91
- * resolves to an array of `Document` objects. This method handles the
92
- * retrieval process, including starting and ending callbacks, and error
93
- * handling.
94
- * @param query The query string to retrieve relevant documents for.
95
- * @param config Optional configuration object for the retrieval process.
96
- * @returns A promise that resolves to an array of `Document` objects.
97
- */
98
- async getRelevantDocuments(query, config) {
99
- const parsedConfig = require_config.ensureConfig(require_callbacks_manager.parseCallbackConfigArg(config));
84
+ const parsedConfig = require_config.ensureConfig(require_callbacks_manager.parseCallbackConfigArg(options));
100
85
  const callbackManager_ = await require_callbacks_manager.CallbackManager.configure(parsedConfig.callbacks, this.callbacks, parsedConfig.tags, this.tags, parsedConfig.metadata, this.metadata, { verbose: this.verbose });
101
- const runManager = await callbackManager_?.handleRetrieverStart(this.toJSON(), query, parsedConfig.runId, void 0, void 0, void 0, parsedConfig.runName);
86
+ const runManager = await callbackManager_?.handleRetrieverStart(this.toJSON(), input, parsedConfig.runId, void 0, void 0, void 0, parsedConfig.runName);
102
87
  try {
103
- const results = await this._getRelevantDocuments(query, runManager);
88
+ const results = await this._getRelevantDocuments(input, runManager);
104
89
  await runManager?.handleRetrieverEnd(results);
105
90
  return results;
106
91
  } catch (error) {
@@ -1 +1 @@
1
- {"version":3,"file":"index.cjs","names":["Runnable","fields?: BaseRetrieverInput","_query: string","_callbacks?: CallbackManagerForRetrieverRun","input: string","options?: RunnableConfig","ensureConfig","query: string","config?: Callbacks | BaseCallbackConfig","parseCallbackConfigArg","CallbackManager"],"sources":["../../src/retrievers/index.ts"],"sourcesContent":["import {\n BaseCallbackConfig,\n CallbackManager,\n CallbackManagerForRetrieverRun,\n Callbacks,\n parseCallbackConfigArg,\n} from \"../callbacks/manager.js\";\nimport type { DocumentInterface } from \"../documents/document.js\";\nimport { Runnable, type RunnableInterface } from \"../runnables/base.js\";\nimport { RunnableConfig, ensureConfig } from \"../runnables/config.js\";\n\n/**\n * Input configuration options for initializing a retriever that extends\n * the `BaseRetriever` class. This interface provides base properties\n * common to all retrievers, allowing customization of callback functions,\n * tagging, metadata, and logging verbosity.\n *\n * Fields:\n * - `callbacks` (optional): An array of callback functions that handle various\n * events during retrieval, such as logging, error handling, or progress updates.\n *\n * - `tags` (optional): An array of strings used to add contextual tags to\n * retrieval operations, allowing for easier categorization and tracking.\n *\n * - `metadata` (optional): A record of key-value pairs to store additional\n * contextual information for retrieval operations, which can be useful\n * for logging or auditing purposes.\n *\n * - `verbose` (optional): A boolean flag that, if set to `true`, enables\n * detailed logging and output during the retrieval process. Defaults to `false`.\n */\nexport interface BaseRetrieverInput {\n callbacks?: Callbacks;\n tags?: string[];\n metadata?: Record<string, unknown>;\n verbose?: boolean;\n}\n\n/**\n * Interface for a base retriever that defines core functionality for\n * retrieving relevant documents from a source based on a query.\n *\n * The `BaseRetrieverInterface` standardizes the `getRelevantDocuments` method,\n * enabling retrieval of documents that match the query criteria.\n *\n * @template Metadata - The type of metadata associated with each document,\n * defaulting to `Record<string, any>`.\n */\nexport interface BaseRetrieverInterface<\n // eslint-disable-next-line @typescript-eslint/no-explicit-any\n Metadata extends Record<string, any> = Record<string, any>\n> extends RunnableInterface<string, DocumentInterface<Metadata>[]> {\n /**\n * Retrieves documents relevant to a given query, allowing optional\n * configurations for customization.\n *\n * @param query - A string representing the query to search for relevant documents.\n * @param config - (optional) Configuration options for the retrieval process,\n * which may include callbacks and additional context settings.\n * @returns A promise that resolves to an array of `DocumentInterface` instances,\n * each containing metadata specified by the `Metadata` type parameter.\n */\n getRelevantDocuments(\n query: string,\n config?: Callbacks | BaseCallbackConfig\n ): Promise<DocumentInterface<Metadata>[]>;\n}\n\n/**\n * Abstract base class for a document retrieval system, designed to\n * process string queries and return the most relevant documents from a source.\n *\n * `BaseRetriever` provides common properties and methods for derived retrievers,\n * such as callbacks, tagging, and verbose logging. Custom retrieval systems\n * should extend this class and implement `_getRelevantDocuments` to define\n * the specific retrieval logic.\n *\n * @template Metadata - The type of metadata associated with each document,\n * defaulting to `Record<string, any>`.\n */\nexport abstract class BaseRetriever<\n // eslint-disable-next-line @typescript-eslint/no-explicit-any\n Metadata extends Record<string, any> = Record<string, any>\n >\n extends Runnable<string, DocumentInterface<Metadata>[]>\n implements BaseRetrieverInterface\n{\n /**\n * Optional callbacks to handle various events in the retrieval process.\n */\n callbacks?: Callbacks;\n\n /**\n * Tags to label or categorize the retrieval operation.\n */\n tags?: string[];\n\n /**\n * Metadata to provide additional context or information about the retrieval\n * operation.\n */\n metadata?: Record<string, unknown>;\n\n /**\n * If set to `true`, enables verbose logging for the retrieval process.\n */\n verbose?: boolean;\n\n /**\n * Constructs a new `BaseRetriever` instance with optional configuration fields.\n *\n * @param fields - Optional input configuration that can include `callbacks`,\n * `tags`, `metadata`, and `verbose` settings for custom retriever behavior.\n */\n constructor(fields?: BaseRetrieverInput) {\n super(fields);\n this.callbacks = fields?.callbacks;\n this.tags = fields?.tags ?? [];\n this.metadata = fields?.metadata ?? {};\n this.verbose = fields?.verbose ?? false;\n }\n\n /**\n * TODO: This should be an abstract method, but we'd like to avoid breaking\n * changes to people currently using subclassed custom retrievers.\n * Change it on next major release.\n */\n /**\n * Placeholder method for retrieving relevant documents based on a query.\n *\n * This method is intended to be implemented by subclasses and will be\n * converted to an abstract method in the next major release. Currently, it\n * throws an error if not implemented, ensuring that custom retrievers define\n * the specific retrieval logic.\n *\n * @param _query - The query string used to search for relevant documents.\n * @param _callbacks - (optional) Callback manager for managing callbacks\n * during retrieval.\n * @returns A promise resolving to an array of `DocumentInterface` instances relevant to the query.\n * @throws {Error} Throws an error indicating the method is not implemented.\n */\n _getRelevantDocuments(\n _query: string,\n _callbacks?: CallbackManagerForRetrieverRun\n ): Promise<DocumentInterface<Metadata>[]> {\n throw new Error(\"Not implemented!\");\n }\n\n /**\n * Executes a retrieval operation.\n *\n * @param input - The query string used to search for relevant documents.\n * @param options - (optional) Configuration options for the retrieval run,\n * which may include callbacks, tags, and metadata.\n * @returns A promise that resolves to an array of `DocumentInterface` instances\n * representing the most relevant documents to the query.\n */\n async invoke(\n input: string,\n options?: RunnableConfig\n ): Promise<DocumentInterface<Metadata>[]> {\n return this.getRelevantDocuments(input, ensureConfig(options));\n }\n\n /**\n * @deprecated Use .invoke() instead. Will be removed in 0.3.0.\n *\n * Main method used to retrieve relevant documents. It takes a query\n * string and an optional configuration object, and returns a promise that\n * resolves to an array of `Document` objects. This method handles the\n * retrieval process, including starting and ending callbacks, and error\n * handling.\n * @param query The query string to retrieve relevant documents for.\n * @param config Optional configuration object for the retrieval process.\n * @returns A promise that resolves to an array of `Document` objects.\n */\n async getRelevantDocuments(\n query: string,\n config?: Callbacks | BaseCallbackConfig\n ): Promise<DocumentInterface<Metadata>[]> {\n const parsedConfig = ensureConfig(parseCallbackConfigArg(config));\n const callbackManager_ = await CallbackManager.configure(\n parsedConfig.callbacks,\n this.callbacks,\n parsedConfig.tags,\n this.tags,\n parsedConfig.metadata,\n this.metadata,\n { verbose: this.verbose }\n );\n const runManager = await callbackManager_?.handleRetrieverStart(\n this.toJSON(),\n query,\n parsedConfig.runId,\n undefined,\n undefined,\n undefined,\n parsedConfig.runName\n );\n try {\n const results = await this._getRelevantDocuments(query, runManager);\n await runManager?.handleRetrieverEnd(results);\n return results;\n } catch (error) {\n await runManager?.handleRetrieverError(error);\n throw error;\n }\n }\n}\n"],"mappings":";;;;;;;;;;;;;;;;;;;;AAgFA,IAAsB,gBAAtB,cAIUA,sBAEV;;;;CAIE;;;;CAKA;;;;;CAMA;;;;CAKA;;;;;;;CAQA,YAAYC,QAA6B;EACvC,MAAM,OAAO;EACb,KAAK,YAAY,QAAQ;EACzB,KAAK,OAAO,QAAQ,QAAQ,CAAE;EAC9B,KAAK,WAAW,QAAQ,YAAY,CAAE;EACtC,KAAK,UAAU,QAAQ,WAAW;CACnC;;;;;;;;;;;;;;;;;;;;CAqBD,sBACEC,QACAC,YACwC;AACxC,QAAM,IAAI,MAAM;CACjB;;;;;;;;;;CAWD,MAAM,OACJC,OACAC,SACwC;AACxC,SAAO,KAAK,qBAAqB,OAAOC,4BAAa,QAAQ,CAAC;CAC/D;;;;;;;;;;;;;CAcD,MAAM,qBACJC,OACAC,QACwC;EACxC,MAAM,eAAeF,4BAAaG,iDAAuB,OAAO,CAAC;EACjE,MAAM,mBAAmB,MAAMC,0CAAgB,UAC7C,aAAa,WACb,KAAK,WACL,aAAa,MACb,KAAK,MACL,aAAa,UACb,KAAK,UACL,EAAE,SAAS,KAAK,QAAS,EAC1B;EACD,MAAM,aAAa,MAAM,kBAAkB,qBACzC,KAAK,QAAQ,EACb,OACA,aAAa,OACb,QACA,QACA,QACA,aAAa,QACd;AACD,MAAI;GACF,MAAM,UAAU,MAAM,KAAK,sBAAsB,OAAO,WAAW;GACnE,MAAM,YAAY,mBAAmB,QAAQ;AAC7C,UAAO;EACR,SAAQ,OAAO;GACd,MAAM,YAAY,qBAAqB,MAAM;AAC7C,SAAM;EACP;CACF;AACF"}
1
+ {"version":3,"file":"index.cjs","names":["Runnable","fields?: BaseRetrieverInput","_query: string","_callbacks?: CallbackManagerForRetrieverRun","input: string","options?: RunnableConfig","ensureConfig","parseCallbackConfigArg","CallbackManager"],"sources":["../../src/retrievers/index.ts"],"sourcesContent":["import {\n CallbackManager,\n CallbackManagerForRetrieverRun,\n Callbacks,\n parseCallbackConfigArg,\n} from \"../callbacks/manager.js\";\nimport type { DocumentInterface } from \"../documents/document.js\";\nimport { Runnable, type RunnableInterface } from \"../runnables/base.js\";\nimport { RunnableConfig, ensureConfig } from \"../runnables/config.js\";\n\n/**\n * Input configuration options for initializing a retriever that extends\n * the `BaseRetriever` class. This interface provides base properties\n * common to all retrievers, allowing customization of callback functions,\n * tagging, metadata, and logging verbosity.\n *\n * Fields:\n * - `callbacks` (optional): An array of callback functions that handle various\n * events during retrieval, such as logging, error handling, or progress updates.\n *\n * - `tags` (optional): An array of strings used to add contextual tags to\n * retrieval operations, allowing for easier categorization and tracking.\n *\n * - `metadata` (optional): A record of key-value pairs to store additional\n * contextual information for retrieval operations, which can be useful\n * for logging or auditing purposes.\n *\n * - `verbose` (optional): A boolean flag that, if set to `true`, enables\n * detailed logging and output during the retrieval process. Defaults to `false`.\n */\nexport interface BaseRetrieverInput {\n callbacks?: Callbacks;\n tags?: string[];\n metadata?: Record<string, unknown>;\n verbose?: boolean;\n}\n\n/**\n * Interface for a base retriever that defines core functionality for\n * retrieving relevant documents from a source based on a query.\n *\n * The `BaseRetrieverInterface` standardizes the `getRelevantDocuments` method,\n * enabling retrieval of documents that match the query criteria.\n *\n * @template Metadata - The type of metadata associated with each document,\n * defaulting to `Record<string, any>`.\n */\nexport interface BaseRetrieverInterface<\n // eslint-disable-next-line @typescript-eslint/no-explicit-any\n Metadata extends Record<string, any> = Record<string, any>\n> extends RunnableInterface<string, DocumentInterface<Metadata>[]> {}\n\n/**\n * Abstract base class for a document retrieval system, designed to\n * process string queries and return the most relevant documents from a source.\n *\n * `BaseRetriever` provides common properties and methods for derived retrievers,\n * such as callbacks, tagging, and verbose logging. Custom retrieval systems\n * should extend this class and implement `_getRelevantDocuments` to define\n * the specific retrieval logic.\n *\n * @template Metadata - The type of metadata associated with each document,\n * defaulting to `Record<string, any>`.\n */\nexport abstract class BaseRetriever<\n // eslint-disable-next-line @typescript-eslint/no-explicit-any\n Metadata extends Record<string, any> = Record<string, any>\n >\n extends Runnable<string, DocumentInterface<Metadata>[]>\n implements BaseRetrieverInterface\n{\n /**\n * Optional callbacks to handle various events in the retrieval process.\n */\n callbacks?: Callbacks;\n\n /**\n * Tags to label or categorize the retrieval operation.\n */\n tags?: string[];\n\n /**\n * Metadata to provide additional context or information about the retrieval\n * operation.\n */\n metadata?: Record<string, unknown>;\n\n /**\n * If set to `true`, enables verbose logging for the retrieval process.\n */\n verbose?: boolean;\n\n /**\n * Constructs a new `BaseRetriever` instance with optional configuration fields.\n *\n * @param fields - Optional input configuration that can include `callbacks`,\n * `tags`, `metadata`, and `verbose` settings for custom retriever behavior.\n */\n constructor(fields?: BaseRetrieverInput) {\n super(fields);\n this.callbacks = fields?.callbacks;\n this.tags = fields?.tags ?? [];\n this.metadata = fields?.metadata ?? {};\n this.verbose = fields?.verbose ?? false;\n }\n\n /**\n * TODO: This should be an abstract method, but we'd like to avoid breaking\n * changes to people currently using subclassed custom retrievers.\n * Change it on next major release.\n */\n /**\n * Placeholder method for retrieving relevant documents based on a query.\n *\n * This method is intended to be implemented by subclasses and will be\n * converted to an abstract method in the next major release. Currently, it\n * throws an error if not implemented, ensuring that custom retrievers define\n * the specific retrieval logic.\n *\n * @param _query - The query string used to search for relevant documents.\n * @param _callbacks - (optional) Callback manager for managing callbacks\n * during retrieval.\n * @returns A promise resolving to an array of `DocumentInterface` instances relevant to the query.\n * @throws {Error} Throws an error indicating the method is not implemented.\n */\n _getRelevantDocuments(\n _query: string,\n _callbacks?: CallbackManagerForRetrieverRun\n ): Promise<DocumentInterface<Metadata>[]> {\n throw new Error(\"Not implemented!\");\n }\n\n /**\n * Executes a retrieval operation.\n *\n * @param input - The query string used to search for relevant documents.\n * @param options - (optional) Configuration options for the retrieval run,\n * which may include callbacks, tags, and metadata.\n * @returns A promise that resolves to an array of `DocumentInterface` instances\n * representing the most relevant documents to the query.\n */\n async invoke(\n input: string,\n options?: RunnableConfig\n ): Promise<DocumentInterface<Metadata>[]> {\n const parsedConfig = ensureConfig(parseCallbackConfigArg(options));\n const callbackManager_ = await CallbackManager.configure(\n parsedConfig.callbacks,\n this.callbacks,\n parsedConfig.tags,\n this.tags,\n parsedConfig.metadata,\n this.metadata,\n { verbose: this.verbose }\n );\n const runManager = await callbackManager_?.handleRetrieverStart(\n this.toJSON(),\n input,\n parsedConfig.runId,\n undefined,\n undefined,\n undefined,\n parsedConfig.runName\n );\n try {\n const results = await this._getRelevantDocuments(input, runManager);\n await runManager?.handleRetrieverEnd(results);\n return results;\n } catch (error) {\n await runManager?.handleRetrieverError(error);\n throw error;\n }\n }\n}\n"],"mappings":";;;;;;;;;;;;;;;;;;;;AAgEA,IAAsB,gBAAtB,cAIUA,sBAEV;;;;CAIE;;;;CAKA;;;;;CAMA;;;;CAKA;;;;;;;CAQA,YAAYC,QAA6B;EACvC,MAAM,OAAO;EACb,KAAK,YAAY,QAAQ;EACzB,KAAK,OAAO,QAAQ,QAAQ,CAAE;EAC9B,KAAK,WAAW,QAAQ,YAAY,CAAE;EACtC,KAAK,UAAU,QAAQ,WAAW;CACnC;;;;;;;;;;;;;;;;;;;;CAqBD,sBACEC,QACAC,YACwC;AACxC,QAAM,IAAI,MAAM;CACjB;;;;;;;;;;CAWD,MAAM,OACJC,OACAC,SACwC;EACxC,MAAM,eAAeC,4BAAaC,iDAAuB,QAAQ,CAAC;EAClE,MAAM,mBAAmB,MAAMC,0CAAgB,UAC7C,aAAa,WACb,KAAK,WACL,aAAa,MACb,KAAK,MACL,aAAa,UACb,KAAK,UACL,EAAE,SAAS,KAAK,QAAS,EAC1B;EACD,MAAM,aAAa,MAAM,kBAAkB,qBACzC,KAAK,QAAQ,EACb,OACA,aAAa,OACb,QACA,QACA,QACA,aAAa,QACd;AACD,MAAI;GACF,MAAM,UAAU,MAAM,KAAK,sBAAsB,OAAO,WAAW;GACnE,MAAM,YAAY,mBAAmB,QAAQ;AAC7C,UAAO;EACR,SAAQ,OAAO;GACd,MAAM,YAAY,qBAAqB,MAAM;AAC7C,SAAM;EACP;CACF;AACF"}
@@ -1,5 +1,5 @@
1
1
  import { DocumentInterface } from "../documents/document.cjs";
2
- import { BaseCallbackConfig, CallbackManagerForRetrieverRun, Callbacks } from "../callbacks/manager.cjs";
2
+ import { CallbackManagerForRetrieverRun, Callbacks } from "../callbacks/manager.cjs";
3
3
  import { RunnableConfig, RunnableInterface } from "../runnables/types.cjs";
4
4
  import { Runnable } from "../runnables/base.cjs";
5
5
 
@@ -43,19 +43,7 @@ interface BaseRetrieverInput {
43
43
  */
44
44
  interface BaseRetrieverInterface<
45
45
  // eslint-disable-next-line @typescript-eslint/no-explicit-any
46
- Metadata extends Record<string, any> = Record<string, any>> extends RunnableInterface<string, DocumentInterface<Metadata>[]> {
47
- /**
48
- * Retrieves documents relevant to a given query, allowing optional
49
- * configurations for customization.
50
- *
51
- * @param query - A string representing the query to search for relevant documents.
52
- * @param config - (optional) Configuration options for the retrieval process,
53
- * which may include callbacks and additional context settings.
54
- * @returns A promise that resolves to an array of `DocumentInterface` instances,
55
- * each containing metadata specified by the `Metadata` type parameter.
56
- */
57
- getRelevantDocuments(query: string, config?: Callbacks | BaseCallbackConfig): Promise<DocumentInterface<Metadata>[]>;
58
- }
46
+ Metadata extends Record<string, any> = Record<string, any>> extends RunnableInterface<string, DocumentInterface<Metadata>[]> {}
59
47
  /**
60
48
  * Abstract base class for a document retrieval system, designed to
61
49
  * process string queries and return the most relevant documents from a source.
@@ -125,19 +113,6 @@ Metadata extends Record<string, any> = Record<string, any>> extends Runnable<str
125
113
  * representing the most relevant documents to the query.
126
114
  */
127
115
  invoke(input: string, options?: RunnableConfig): Promise<DocumentInterface<Metadata>[]>;
128
- /**
129
- * @deprecated Use .invoke() instead. Will be removed in 0.3.0.
130
- *
131
- * Main method used to retrieve relevant documents. It takes a query
132
- * string and an optional configuration object, and returns a promise that
133
- * resolves to an array of `Document` objects. This method handles the
134
- * retrieval process, including starting and ending callbacks, and error
135
- * handling.
136
- * @param query The query string to retrieve relevant documents for.
137
- * @param config Optional configuration object for the retrieval process.
138
- * @returns A promise that resolves to an array of `Document` objects.
139
- */
140
- getRelevantDocuments(query: string, config?: Callbacks | BaseCallbackConfig): Promise<DocumentInterface<Metadata>[]>;
141
116
  }
142
117
  //#endregion
143
118
  export { BaseRetriever, BaseRetrieverInput, BaseRetrieverInterface };
@@ -1 +1 @@
1
- {"version":3,"file":"index.d.cts","names":["BaseCallbackConfig","CallbackManagerForRetrieverRun","Callbacks","DocumentInterface","Runnable","RunnableInterface","RunnableConfig","BaseRetrieverInput","Record","BaseRetrieverInterface","Metadata","Promise","BaseRetriever"],"sources":["../../src/retrievers/index.d.ts"],"sourcesContent":["import { BaseCallbackConfig, CallbackManagerForRetrieverRun, Callbacks } from \"../callbacks/manager.js\";\nimport type { DocumentInterface } from \"../documents/document.js\";\nimport { Runnable, type RunnableInterface } from \"../runnables/base.js\";\nimport { RunnableConfig } from \"../runnables/config.js\";\n/**\n * Input configuration options for initializing a retriever that extends\n * the `BaseRetriever` class. This interface provides base properties\n * common to all retrievers, allowing customization of callback functions,\n * tagging, metadata, and logging verbosity.\n *\n * Fields:\n * - `callbacks` (optional): An array of callback functions that handle various\n * events during retrieval, such as logging, error handling, or progress updates.\n *\n * - `tags` (optional): An array of strings used to add contextual tags to\n * retrieval operations, allowing for easier categorization and tracking.\n *\n * - `metadata` (optional): A record of key-value pairs to store additional\n * contextual information for retrieval operations, which can be useful\n * for logging or auditing purposes.\n *\n * - `verbose` (optional): A boolean flag that, if set to `true`, enables\n * detailed logging and output during the retrieval process. Defaults to `false`.\n */\nexport interface BaseRetrieverInput {\n callbacks?: Callbacks;\n tags?: string[];\n metadata?: Record<string, unknown>;\n verbose?: boolean;\n}\n/**\n * Interface for a base retriever that defines core functionality for\n * retrieving relevant documents from a source based on a query.\n *\n * The `BaseRetrieverInterface` standardizes the `getRelevantDocuments` method,\n * enabling retrieval of documents that match the query criteria.\n *\n * @template Metadata - The type of metadata associated with each document,\n * defaulting to `Record<string, any>`.\n */\nexport interface BaseRetrieverInterface<\n// eslint-disable-next-line @typescript-eslint/no-explicit-any\nMetadata extends Record<string, any> = Record<string, any>> extends RunnableInterface<string, DocumentInterface<Metadata>[]> {\n /**\n * Retrieves documents relevant to a given query, allowing optional\n * configurations for customization.\n *\n * @param query - A string representing the query to search for relevant documents.\n * @param config - (optional) Configuration options for the retrieval process,\n * which may include callbacks and additional context settings.\n * @returns A promise that resolves to an array of `DocumentInterface` instances,\n * each containing metadata specified by the `Metadata` type parameter.\n */\n getRelevantDocuments(query: string, config?: Callbacks | BaseCallbackConfig): Promise<DocumentInterface<Metadata>[]>;\n}\n/**\n * Abstract base class for a document retrieval system, designed to\n * process string queries and return the most relevant documents from a source.\n *\n * `BaseRetriever` provides common properties and methods for derived retrievers,\n * such as callbacks, tagging, and verbose logging. Custom retrieval systems\n * should extend this class and implement `_getRelevantDocuments` to define\n * the specific retrieval logic.\n *\n * @template Metadata - The type of metadata associated with each document,\n * defaulting to `Record<string, any>`.\n */\nexport declare abstract class BaseRetriever<\n// eslint-disable-next-line @typescript-eslint/no-explicit-any\nMetadata extends Record<string, any> = Record<string, any>> extends Runnable<string, DocumentInterface<Metadata>[]> implements BaseRetrieverInterface {\n /**\n * Optional callbacks to handle various events in the retrieval process.\n */\n callbacks?: Callbacks;\n /**\n * Tags to label or categorize the retrieval operation.\n */\n tags?: string[];\n /**\n * Metadata to provide additional context or information about the retrieval\n * operation.\n */\n metadata?: Record<string, unknown>;\n /**\n * If set to `true`, enables verbose logging for the retrieval process.\n */\n verbose?: boolean;\n /**\n * Constructs a new `BaseRetriever` instance with optional configuration fields.\n *\n * @param fields - Optional input configuration that can include `callbacks`,\n * `tags`, `metadata`, and `verbose` settings for custom retriever behavior.\n */\n constructor(fields?: BaseRetrieverInput);\n /**\n * TODO: This should be an abstract method, but we'd like to avoid breaking\n * changes to people currently using subclassed custom retrievers.\n * Change it on next major release.\n */\n /**\n * Placeholder method for retrieving relevant documents based on a query.\n *\n * This method is intended to be implemented by subclasses and will be\n * converted to an abstract method in the next major release. Currently, it\n * throws an error if not implemented, ensuring that custom retrievers define\n * the specific retrieval logic.\n *\n * @param _query - The query string used to search for relevant documents.\n * @param _callbacks - (optional) Callback manager for managing callbacks\n * during retrieval.\n * @returns A promise resolving to an array of `DocumentInterface` instances relevant to the query.\n * @throws {Error} Throws an error indicating the method is not implemented.\n */\n _getRelevantDocuments(_query: string, _callbacks?: CallbackManagerForRetrieverRun): Promise<DocumentInterface<Metadata>[]>;\n /**\n * Executes a retrieval operation.\n *\n * @param input - The query string used to search for relevant documents.\n * @param options - (optional) Configuration options for the retrieval run,\n * which may include callbacks, tags, and metadata.\n * @returns A promise that resolves to an array of `DocumentInterface` instances\n * representing the most relevant documents to the query.\n */\n invoke(input: string, options?: RunnableConfig): Promise<DocumentInterface<Metadata>[]>;\n /**\n * @deprecated Use .invoke() instead. Will be removed in 0.3.0.\n *\n * Main method used to retrieve relevant documents. It takes a query\n * string and an optional configuration object, and returns a promise that\n * resolves to an array of `Document` objects. This method handles the\n * retrieval process, including starting and ending callbacks, and error\n * handling.\n * @param query The query string to retrieve relevant documents for.\n * @param config Optional configuration object for the retrieval process.\n * @returns A promise that resolves to an array of `Document` objects.\n */\n getRelevantDocuments(query: string, config?: Callbacks | BaseCallbackConfig): Promise<DocumentInterface<Metadata>[]>;\n}\n"],"mappings":";;;;;;;;;AAwBA;;;;AAGqB;AAarB;;;;;;;;;;;;AAEqF;AAyBvDY,UA3CbL,kBAAAA,CA2C0B;EAAA,SAAA,CAAA,EA1C3BL,SA0C2B;EAAA,IAE1BM,CAAAA,EAAAA,MAAAA,EAAAA;EAAM,QAAgBA,CAAAA,EA1CxBA,MA0CwBA,CAAAA,MAAAA,EAAAA,OAAAA,CAAAA;EAAM,OAA0DE,CAAAA,EAAAA,OAAAA;;;;;;;;;;;;AAsDlDC,UAnFpCF,sBAmFoCE;;iBAjFpCH,MA8F4CR,CAAAA,MAAAA,EAAAA,GAAAA,CAAAA,GA9FtBQ,MA8FsBR,CAAAA,MAAAA,EAAAA,GAAAA,CAAAA,CAAAA,SA9FOK,iBA8FPL,CAAAA,MAAAA,EA9FiCG,iBA8FjCH,CA9FmDU,QA8FnDV,CAAAA,EAAAA,CAAAA,CAAAA;EAAkB;;;;;AAnEsE;;;;;+CAhBpGE,YAAYF,qBAAqBW,QAAQR,kBAAkBO;;;;;;;;;;;;;;uBAc9EE;;iBAEbJ,sBAAsBA,6BAA6BJ,iBAAiBD,kBAAkBO,wBAAwBD;;;;cAI/GP;;;;;;;;;aASDM;;;;;;;;;;;uBAWUD;;;;;;;;;;;;;;;;;;;;qDAoB8BN,iCAAiCU,QAAQR,kBAAkBO;;;;;;;;;;kCAU9EJ,iBAAiBK,QAAQR,kBAAkBO;;;;;;;;;;;;;+CAa9BR,YAAYF,qBAAqBW,QAAQR,kBAAkBO"}
1
+ {"version":3,"file":"index.d.cts","names":["CallbackManagerForRetrieverRun","Callbacks","DocumentInterface","Runnable","RunnableInterface","RunnableConfig","BaseRetrieverInput","Record","BaseRetrieverInterface","Metadata","BaseRetriever","Promise"],"sources":["../../src/retrievers/index.d.ts"],"sourcesContent":["import { CallbackManagerForRetrieverRun, Callbacks } from \"../callbacks/manager.js\";\nimport type { DocumentInterface } from \"../documents/document.js\";\nimport { Runnable, type RunnableInterface } from \"../runnables/base.js\";\nimport { RunnableConfig } from \"../runnables/config.js\";\n/**\n * Input configuration options for initializing a retriever that extends\n * the `BaseRetriever` class. This interface provides base properties\n * common to all retrievers, allowing customization of callback functions,\n * tagging, metadata, and logging verbosity.\n *\n * Fields:\n * - `callbacks` (optional): An array of callback functions that handle various\n * events during retrieval, such as logging, error handling, or progress updates.\n *\n * - `tags` (optional): An array of strings used to add contextual tags to\n * retrieval operations, allowing for easier categorization and tracking.\n *\n * - `metadata` (optional): A record of key-value pairs to store additional\n * contextual information for retrieval operations, which can be useful\n * for logging or auditing purposes.\n *\n * - `verbose` (optional): A boolean flag that, if set to `true`, enables\n * detailed logging and output during the retrieval process. Defaults to `false`.\n */\nexport interface BaseRetrieverInput {\n callbacks?: Callbacks;\n tags?: string[];\n metadata?: Record<string, unknown>;\n verbose?: boolean;\n}\n/**\n * Interface for a base retriever that defines core functionality for\n * retrieving relevant documents from a source based on a query.\n *\n * The `BaseRetrieverInterface` standardizes the `getRelevantDocuments` method,\n * enabling retrieval of documents that match the query criteria.\n *\n * @template Metadata - The type of metadata associated with each document,\n * defaulting to `Record<string, any>`.\n */\nexport interface BaseRetrieverInterface<\n// eslint-disable-next-line @typescript-eslint/no-explicit-any\nMetadata extends Record<string, any> = Record<string, any>> extends RunnableInterface<string, DocumentInterface<Metadata>[]> {\n}\n/**\n * Abstract base class for a document retrieval system, designed to\n * process string queries and return the most relevant documents from a source.\n *\n * `BaseRetriever` provides common properties and methods for derived retrievers,\n * such as callbacks, tagging, and verbose logging. Custom retrieval systems\n * should extend this class and implement `_getRelevantDocuments` to define\n * the specific retrieval logic.\n *\n * @template Metadata - The type of metadata associated with each document,\n * defaulting to `Record<string, any>`.\n */\nexport declare abstract class BaseRetriever<\n// eslint-disable-next-line @typescript-eslint/no-explicit-any\nMetadata extends Record<string, any> = Record<string, any>> extends Runnable<string, DocumentInterface<Metadata>[]> implements BaseRetrieverInterface {\n /**\n * Optional callbacks to handle various events in the retrieval process.\n */\n callbacks?: Callbacks;\n /**\n * Tags to label or categorize the retrieval operation.\n */\n tags?: string[];\n /**\n * Metadata to provide additional context or information about the retrieval\n * operation.\n */\n metadata?: Record<string, unknown>;\n /**\n * If set to `true`, enables verbose logging for the retrieval process.\n */\n verbose?: boolean;\n /**\n * Constructs a new `BaseRetriever` instance with optional configuration fields.\n *\n * @param fields - Optional input configuration that can include `callbacks`,\n * `tags`, `metadata`, and `verbose` settings for custom retriever behavior.\n */\n constructor(fields?: BaseRetrieverInput);\n /**\n * TODO: This should be an abstract method, but we'd like to avoid breaking\n * changes to people currently using subclassed custom retrievers.\n * Change it on next major release.\n */\n /**\n * Placeholder method for retrieving relevant documents based on a query.\n *\n * This method is intended to be implemented by subclasses and will be\n * converted to an abstract method in the next major release. Currently, it\n * throws an error if not implemented, ensuring that custom retrievers define\n * the specific retrieval logic.\n *\n * @param _query - The query string used to search for relevant documents.\n * @param _callbacks - (optional) Callback manager for managing callbacks\n * during retrieval.\n * @returns A promise resolving to an array of `DocumentInterface` instances relevant to the query.\n * @throws {Error} Throws an error indicating the method is not implemented.\n */\n _getRelevantDocuments(_query: string, _callbacks?: CallbackManagerForRetrieverRun): Promise<DocumentInterface<Metadata>[]>;\n /**\n * Executes a retrieval operation.\n *\n * @param input - The query string used to search for relevant documents.\n * @param options - (optional) Configuration options for the retrieval run,\n * which may include callbacks, tags, and metadata.\n * @returns A promise that resolves to an array of `DocumentInterface` instances\n * representing the most relevant documents to the query.\n */\n invoke(input: string, options?: RunnableConfig): Promise<DocumentInterface<Metadata>[]>;\n}\n"],"mappings":";;;;;;;;;AAwBA;;;;AAGqB;AAarB;;;;;;;AAEqF;AAcrF;;;;;AAEqFE,UAlCpEI,kBAAAA,CAkCoEJ;EAAiB,SAItFD,CAAAA,EArCAA,SAqCAA;EAAS,IASVM,CAAAA,EAAAA,MAAAA,EAAAA;EAAM,QAWID,CAAAA,EAvDVC,MAuDUD,CAAAA,MAAAA,EAAAA,OAAAA,CAAAA;EAAkB,OAoBYN,CAAAA,EAAAA,OAAAA;;;;;;;;;;AA5C8F;;UAlBpIQ;;iBAEAD,sBAAsBA,6BAA6BH,0BAA0BF,kBAAkBO;;;;;;;;;;;;;uBAclFC;;iBAEbH,sBAAsBA,6BAA6BJ,iBAAiBD,kBAAkBO,wBAAwBD;;;;cAI/GP;;;;;;;;;aASDM;;;;;;;;;;;uBAWUD;;;;;;;;;;;;;;;;;;;;qDAoB8BN,iCAAiCW,QAAQT,kBAAkBO;;;;;;;;;;kCAU9EJ,iBAAiBM,QAAQT,kBAAkBO"}