@langchain/anthropic 0.1.1 → 0.1.3

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.
@@ -0,0 +1,82 @@
1
+ import { XMLBuilder } from "fast-xml-parser";
2
+ import { PromptTemplate } from "@langchain/core/prompts";
3
+ export const DEFAULT_TOOL_SYSTEM_PROMPT =
4
+ /* #__PURE__ */ PromptTemplate.fromTemplate(`In this environment you have access to a set of tools you can use to answer the user's question.
5
+
6
+ You may call them like this:
7
+ <function_calls>
8
+ <invoke>
9
+ <tool_name>$TOOL_NAME</tool_name>
10
+ <parameters>
11
+ <$PARAMETER_NAME>$PARAMETER_VALUE</$PARAMETER_NAME>
12
+ ...
13
+ </parameters>
14
+ </invoke>
15
+ </function_calls>
16
+
17
+ Here are the tools available:
18
+ {tools}`);
19
+ export function formatAsXMLRepresentation(tool) {
20
+ const builder = new XMLBuilder();
21
+ // eslint-disable-next-line @typescript-eslint/no-explicit-any
22
+ const toolParamProps = tool.function.parameters?.properties;
23
+ const parameterXml = Object.keys(toolParamProps)
24
+ .map((key) => {
25
+ const parameterData = toolParamProps[key];
26
+ let xml = `<parameter>
27
+ <name>${key}</name>
28
+ <type>${parameterData.type}</type>`;
29
+ if (parameterData.description) {
30
+ xml += `\n<description>${parameterData.description}</description>`;
31
+ }
32
+ if (parameterData.type === "array" && parameterData.items) {
33
+ xml += `\n<items>${builder.build(parameterData.items.properties)}</items>`;
34
+ }
35
+ if (parameterData.properties) {
36
+ xml += `\n<properties>\n${builder.build(parameterData.properties)}\n</properties>`;
37
+ }
38
+ return `${xml}\n</parameter>`;
39
+ })
40
+ .join("\n");
41
+ return `<tool_description>
42
+ <tool_name>${tool.function.name}</tool_name>
43
+ <description>${tool.function.description}</description>
44
+ <parameters>
45
+ ${parameterXml}
46
+ </parameters>
47
+ </tool_description>`;
48
+ }
49
+ export function fixArrayXMLParameters(schema,
50
+ // eslint-disable-next-line @typescript-eslint/no-explicit-any
51
+ xmlParameters
52
+ // eslint-disable-next-line @typescript-eslint/no-explicit-any
53
+ ) {
54
+ // eslint-disable-next-line @typescript-eslint/no-explicit-any
55
+ const fixedParameters = {};
56
+ for (const key of Object.keys(xmlParameters)) {
57
+ // eslint-disable-next-line @typescript-eslint/no-explicit-any
58
+ const schemaType = schema.properties[key].type;
59
+ // Crawl for lists indistinguishable from single items
60
+ if (schema.properties && schema.properties[key] && schemaType === "array") {
61
+ fixedParameters[key] = Array.isArray(xmlParameters[key])
62
+ ? xmlParameters[key]
63
+ : [xmlParameters[key]];
64
+ // Crawl for objects like {"item": "my string"} that should really just be "my string"
65
+ if (schemaType !== "object" &&
66
+ typeof xmlParameters[key] === "object" &&
67
+ !Array.isArray(xmlParameters[key]) &&
68
+ Object.keys(xmlParameters[key]).length === 1) {
69
+ // eslint-disable-next-line prefer-destructuring
70
+ fixedParameters[key] = Object.values(xmlParameters[key])[0];
71
+ }
72
+ }
73
+ else if (typeof xmlParameters[key] === "object" &&
74
+ xmlParameters[key] !== null) {
75
+ fixedParameters[key] = fixArrayXMLParameters(schema, xmlParameters[key]);
76
+ }
77
+ else {
78
+ fixedParameters[key] = xmlParameters[key];
79
+ }
80
+ }
81
+ return fixedParameters;
82
+ }
@@ -30,7 +30,7 @@ test("Test ChatAnthropic Generate", async () => {
30
30
  }
31
31
  console.log({ res });
32
32
  });
33
- test("Test ChatAnthropic Generate w/ ClientOptions", async () => {
33
+ test.skip("Test ChatAnthropic Generate w/ ClientOptions", async () => {
34
34
  const chat = new ChatAnthropic({
35
35
  modelName: "claude-3-sonnet-20240229",
36
36
  maxRetries: 0,
@@ -127,7 +127,7 @@ test("Test ChatAnthropic in streaming mode with a signal", async () => {
127
127
  }).rejects.toThrow();
128
128
  console.log({ nrNewTokens, streamedCompletion });
129
129
  }, 5000);
130
- test("Test ChatAnthropic prompt value", async () => {
130
+ test.skip("Test ChatAnthropic prompt value", async () => {
131
131
  const chat = new ChatAnthropic({
132
132
  modelName: "claude-3-sonnet-20240229",
133
133
  maxRetries: 0,
@@ -142,7 +142,7 @@ test("Test ChatAnthropic prompt value", async () => {
142
142
  }
143
143
  console.log({ res });
144
144
  });
145
- test("ChatAnthropic, docs, prompt templates", async () => {
145
+ test.skip("ChatAnthropic, docs, prompt templates", async () => {
146
146
  const chat = new ChatAnthropic({
147
147
  modelName: "claude-3-sonnet-20240229",
148
148
  maxRetries: 0,
@@ -162,7 +162,7 @@ test("ChatAnthropic, docs, prompt templates", async () => {
162
162
  ]);
163
163
  console.log(responseA.generations);
164
164
  });
165
- test("ChatAnthropic, longer chain of messages", async () => {
165
+ test.skip("ChatAnthropic, longer chain of messages", async () => {
166
166
  const chat = new ChatAnthropic({
167
167
  modelName: "claude-3-sonnet-20240229",
168
168
  maxRetries: 0,
@@ -180,7 +180,7 @@ test("ChatAnthropic, longer chain of messages", async () => {
180
180
  ]);
181
181
  console.log(responseA.generations);
182
182
  });
183
- test("ChatAnthropic, Anthropic apiUrl set manually via constructor", async () => {
183
+ test.skip("ChatAnthropic, Anthropic apiUrl set manually via constructor", async () => {
184
184
  // Pass the default URL through (should use this, and work as normal)
185
185
  const anthropicApiUrl = "https://api.anthropic.com";
186
186
  const chat = new ChatAnthropic({
@@ -249,6 +249,26 @@ test("Test ChatAnthropic headers passed through", async () => {
249
249
  },
250
250
  });
251
251
  const message = new HumanMessage("Hello!");
252
- const res = await chat.call([message]);
252
+ const res = await chat.invoke([message]);
253
253
  console.log({ res });
254
254
  });
255
+ test("Test ChatAnthropic multimodal", async () => {
256
+ const chat = new ChatAnthropic({
257
+ modelName: "claude-3-sonnet-20240229",
258
+ maxRetries: 0,
259
+ });
260
+ const res = await chat.invoke([
261
+ new HumanMessage({
262
+ content: [
263
+ {
264
+ type: "image_url",
265
+ image_url: {
266
+ url: "",
267
+ },
268
+ },
269
+ { type: "text", text: "What is this a logo for?" },
270
+ ],
271
+ }),
272
+ ]);
273
+ console.log(res);
274
+ });
@@ -0,0 +1 @@
1
+ module.exports = require('./dist/experimental/index.cjs');
@@ -0,0 +1 @@
1
+ export * from './dist/experimental/index.js'
@@ -0,0 +1 @@
1
+ export * from './dist/experimental/index.js'
@@ -0,0 +1 @@
1
+ export * from './dist/experimental/index.js'
package/package.json CHANGED
@@ -1,6 +1,6 @@
1
1
  {
2
2
  "name": "@langchain/anthropic",
3
- "version": "0.1.1",
3
+ "version": "0.1.3",
4
4
  "description": "Anthropic integrations for LangChain.js",
5
5
  "type": "module",
6
6
  "engines": {
@@ -39,10 +39,14 @@
39
39
  "license": "MIT",
40
40
  "dependencies": {
41
41
  "@anthropic-ai/sdk": "^0.15.0",
42
- "@langchain/core": "~0.1"
42
+ "@langchain/core": "~0.1",
43
+ "fast-xml-parser": "^4.3.5",
44
+ "zod": "^3.22.4",
45
+ "zod-to-json-schema": "^3.22.4"
43
46
  },
44
47
  "devDependencies": {
45
48
  "@jest/globals": "^29.5.0",
49
+ "@langchain/community": "workspace:^",
46
50
  "@langchain/scripts": "~0.0",
47
51
  "@swc/core": "^1.3.90",
48
52
  "@swc/jest": "^0.2.29",
@@ -88,6 +92,15 @@
88
92
  "import": "./index.js",
89
93
  "require": "./index.cjs"
90
94
  },
95
+ "./experimental": {
96
+ "types": {
97
+ "import": "./experimental.d.ts",
98
+ "require": "./experimental.d.cts",
99
+ "default": "./experimental.d.ts"
100
+ },
101
+ "import": "./experimental.js",
102
+ "require": "./experimental.cjs"
103
+ },
91
104
  "./package.json": "./package.json"
92
105
  },
93
106
  "files": [
@@ -95,6 +108,10 @@
95
108
  "index.cjs",
96
109
  "index.js",
97
110
  "index.d.ts",
98
- "index.d.cts"
111
+ "index.d.cts",
112
+ "experimental.cjs",
113
+ "experimental.js",
114
+ "experimental.d.ts",
115
+ "experimental.d.cts"
99
116
  ]
100
117
  }