From 3ed7078877fae4c0411f1d0c0b227bac90892763 Mon Sep 17 00:00:00 2001 From: Tat Dat Duong Date: Wed, 17 Jul 2024 11:41:40 -0700 Subject: [PATCH 1/5] fix(js): pass other traceable options in wrapSDK --- js/src/wrappers/openai.ts | 19 ++++++++++++++----- 1 file changed, 14 insertions(+), 5 deletions(-) diff --git a/js/src/wrappers/openai.ts b/js/src/wrappers/openai.ts index 0ea56f882..5652ce4e0 100644 --- a/js/src/wrappers/openai.ts +++ b/js/src/wrappers/openai.ts @@ -280,7 +280,7 @@ export const wrapOpenAI = ( const _wrapClient = ( sdk: T, runName: string, - options?: { client?: Client } + options?: Omit ): T => { return new Proxy(sdk, { get(target, propKey, receiver) { @@ -312,6 +312,10 @@ const _wrapClient = ( }); }; +type WrapSDKOptions = Partial< + Omit & { runName: string } +>; + /** * Wrap an arbitrary SDK, enabling automatic LangSmith tracing. * Method signatures are unchanged. @@ -325,9 +329,14 @@ const _wrapClient = ( */ export const wrapSDK = ( sdk: T, - options?: { client?: Client; runName?: string } + options?: WrapSDKOptions ): T => { - return _wrapClient(sdk, options?.runName ?? sdk.constructor?.name, { - client: options?.client, - }); + const traceableOptions = options ? { ...options } : undefined; + if (traceableOptions != null) delete traceableOptions.runName; + + return _wrapClient( + sdk, + options?.runName ?? sdk.constructor?.name, + traceableOptions + ); }; From 83b004cd26bbe3e14d3516f481af15cc2c06be0b Mon Sep 17 00:00:00 2001 From: Tat Dat Duong Date: Wed, 17 Jul 2024 15:13:58 -0700 Subject: [PATCH 2/5] Fix lint --- js/src/wrappers/openai.ts | 2 +- 1 file changed, 1 insertion(+), 1 deletion(-) diff --git a/js/src/wrappers/openai.ts b/js/src/wrappers/openai.ts index 5652ce4e0..7870e460e 100644 --- a/js/src/wrappers/openai.ts +++ b/js/src/wrappers/openai.ts @@ -1,6 +1,6 @@ import { OpenAI } from "openai"; import type { APIPromise } from "openai/core"; -import type { Client, RunTreeConfig } from "../index.js"; +import type { RunTreeConfig } from "../index.js"; import { isTraceableFunction, traceable } from "../traceable.js"; // Extra leniency around types in case multiple OpenAI SDK versions get installed From 9ba160d95ea8e3c7a4c52fcae84c62f361598a65 Mon Sep 17 00:00:00 2001 From: Tat Dat Duong Date: Thu, 18 Jul 2024 23:04:21 -0700 Subject: [PATCH 3/5] Upgrade devDeps --- js/package.json | 11 +++---- js/yarn.lock | 81 ++++++++++++++++++++++++++++--------------------- 2 files changed, 50 insertions(+), 42 deletions(-) diff --git a/js/package.json b/js/package.json index f6bb02d18..8d988da81 100644 --- a/js/package.json +++ b/js/package.json @@ -103,9 +103,9 @@ "@babel/preset-env": "^7.22.4", "@faker-js/faker": "^8.4.1", "@jest/globals": "^29.5.0", - "langchain": "^0.2.0", - "@langchain/core": "^0.2.0", - "@langchain/langgraph": "^0.0.19", + "langchain": "^0.2.10", + "@langchain/core": "^0.2.17", + "@langchain/langgraph": "^0.0.29", "@tsconfig/recommended": "^1.0.2", "@types/jest": "^29.5.1", "@typescript-eslint/eslint-plugin": "^5.59.8", @@ -141,9 +141,6 @@ "optional": true } }, - "resolutions": { - "@langchain/core": "0.2.0" - }, "lint-staged": { "**/*.{ts,tsx}": [ "prettier --write --ignore-unknown", @@ -261,4 +258,4 @@ }, "./package.json": "./package.json" } -} \ No newline at end of file +} diff --git a/js/yarn.lock b/js/yarn.lock index 8e4cee5e8..cf459cb03 100644 --- a/js/yarn.lock +++ b/js/yarn.lock @@ -1300,40 +1300,41 @@ "@jridgewell/resolve-uri" "3.1.0" "@jridgewell/sourcemap-codec" "1.4.14" -"@langchain/core@0.2.0", "@langchain/core@>0.1.0 <0.3.0", "@langchain/core@>0.1.56 <0.3.0", "@langchain/core@^0.1.61", "@langchain/core@^0.2.0", "@langchain/core@~0.2.0": - version "0.2.0" - resolved "https://registry.yarnpkg.com/@langchain/core/-/core-0.2.0.tgz#19c6374a5ad80daf8e14cb58582bc988109a1403" - integrity sha512-UbCJUp9eh2JXd9AW/vhPbTgtZoMgTqJgSan5Wf/EP27X8JM65lWdCOpJW+gHyBXvabbyrZz3/EGaptTUL5gutw== +"@langchain/core@>0.1.0 <0.3.0", "@langchain/core@>=0.2.11 <0.3.0", "@langchain/core@>=0.2.16 <0.3.0", "@langchain/core@^0.2.17": + version "0.2.17" + resolved "https://registry.yarnpkg.com/@langchain/core/-/core-0.2.17.tgz#dfd44a2ccf79cef88ba765741a1c277bc22e483f" + integrity sha512-WnFiZ7R/ZUVeHO2IgcSL7Tu+CjApa26Iy99THJP5fax/NF8UQCc/ZRcw2Sb/RUuRPVm6ALDass0fSQE1L9YNJg== dependencies: ansi-styles "^5.0.0" camelcase "6" decamelize "1.2.0" js-tiktoken "^1.0.12" - langsmith "~0.1.7" + langsmith "~0.1.30" ml-distance "^4.0.0" mustache "^4.2.0" p-queue "^6.6.2" p-retry "4" - uuid "^9.0.0" + uuid "^10.0.0" zod "^3.22.4" zod-to-json-schema "^3.22.3" -"@langchain/langgraph@^0.0.19": - version "0.0.19" - resolved "https://registry.yarnpkg.com/@langchain/langgraph/-/langgraph-0.0.19.tgz#c1cfeee7d0e2b91dd31cba7144f8a7283babc61d" - integrity sha512-V0t40qbwUyzEpL3Q0jHPVTVljdLc3YJCHIF9Q+sw9HRWwfBO1nWJHHbCxgVzeJ2NsX1X/dUyNkq8LbSEsTYpTQ== +"@langchain/langgraph@^0.0.29": + version "0.0.29" + resolved "https://registry.yarnpkg.com/@langchain/langgraph/-/langgraph-0.0.29.tgz#eda31d101e7a75981e0929661c41ab2461ff8640" + integrity sha512-BSFFJarkXqrMdH9yH6AIiBCw4ww0VsXXpBwqaw+9/7iulW0pBFRSkWXHjEYnmsdCRgyIxoP8vYQAQ8Jtu3qzZA== dependencies: - "@langchain/core" "^0.1.61" - uuid "^9.0.1" + "@langchain/core" ">=0.2.16 <0.3.0" + uuid "^10.0.0" + zod "^3.23.8" -"@langchain/openai@~0.0.28": - version "0.0.33" - resolved "https://registry.yarnpkg.com/@langchain/openai/-/openai-0.0.33.tgz#af88d815ff0095018c879d3a1a5a32b2795b5c69" - integrity sha512-hTBo9y9bHtFvMT5ySBW7TrmKhLSA91iNahigeqAFBVrLmBDz+6rzzLFc1mpq6JEAR3fZKdaUXqso3nB23jIpTw== +"@langchain/openai@>=0.1.0 <0.3.0": + version "0.2.4" + resolved "https://registry.yarnpkg.com/@langchain/openai/-/openai-0.2.4.tgz#02d210d2aacdaf654bceb686b3ec49517fb3b1ea" + integrity sha512-PQGmnnKbsC8odwjGbYf2aHAQEZ/uVXYtXqKnwk7BTVMZlFnt+Rt9eigp940xMKAadxHzqtKJpSd7Xf6G+LI6KA== dependencies: - "@langchain/core" ">0.1.56 <0.3.0" + "@langchain/core" ">=0.2.16 <0.3.0" js-tiktoken "^1.0.12" - openai "^4.41.1" + openai "^4.49.1" zod "^3.22.4" zod-to-json-schema "^3.22.3" @@ -3488,24 +3489,24 @@ kleur@^3.0.3: resolved "https://registry.npmjs.org/kleur/-/kleur-3.0.3.tgz" integrity sha512-eTIzlVOSUR+JxdDFepEYcBMtZ9Qqdef+rnzWdRZuMbOywu5tO2w2N7rqjoANZ5k9vywhL6Br1VRjUIgTQx4E8w== -langchain@^0.2.0: - version "0.2.0" - resolved "https://registry.yarnpkg.com/langchain/-/langchain-0.2.0.tgz#555d84538962720cd7223f6c3ca4bd060978ebf3" - integrity sha512-8c7Dg9OIPk4lFIQGyfOytXbUGLLSsxs9MV53cLODspkOGzaUpwy5FGBie30SrOxIEFJo+FDaJgpDAFO3Xi4NMw== +langchain@^0.2.10: + version "0.2.10" + resolved "https://registry.yarnpkg.com/langchain/-/langchain-0.2.10.tgz#35b74038e54650efbd9fe7d9d59765fe2790bb47" + integrity sha512-i0fC+RlX/6w6HKPWL3N5zrhrkijvpe2Xu4t/qbWzq4uFf8WBfPwmNFom3RtO2RatuPnHLm8mViU6nw8YBDiVwA== dependencies: - "@langchain/core" "~0.2.0" - "@langchain/openai" "~0.0.28" + "@langchain/core" ">=0.2.11 <0.3.0" + "@langchain/openai" ">=0.1.0 <0.3.0" "@langchain/textsplitters" "~0.0.0" binary-extensions "^2.2.0" js-tiktoken "^1.0.12" js-yaml "^4.1.0" jsonpointer "^5.0.1" langchainhub "~0.0.8" - langsmith "~0.1.7" + langsmith "~0.1.30" ml-distance "^4.0.0" openapi-types "^12.1.3" p-retry "4" - uuid "^9.0.0" + uuid "^10.0.0" yaml "^2.2.1" zod "^3.22.4" zod-to-json-schema "^3.22.3" @@ -3515,10 +3516,10 @@ langchainhub@~0.0.8: resolved "https://registry.yarnpkg.com/langchainhub/-/langchainhub-0.0.10.tgz#7579440a3255d67571b7046f3910593c5664f064" integrity sha512-mOVso7TGTMSlvTTUR1b4zUIMtu8zgie/pcwRm1SeooWwuHYMQovoNXjT6gEjvWEZ6cjt4gVH+1lu2tp1/phyIQ== -langsmith@~0.1.7: - version "0.1.25" - resolved "https://registry.yarnpkg.com/langsmith/-/langsmith-0.1.25.tgz#3d06b6fc62abb1a6fc16540d40ddb48bd795f128" - integrity sha512-Hft4Y1yoMgFgCUXVQklRZ7ndmLQ/6FmRZE9P3u5BRdMq5Fa0hpg8R7jd7bLLBXkAjqcFvWo0AGhpb8MMY5FAiA== +langsmith@~0.1.30: + version "0.1.38" + resolved "https://registry.yarnpkg.com/langsmith/-/langsmith-0.1.38.tgz#51c50db3110ffff15f522d0486dbeb069c82ca45" + integrity sha512-h8UHgvtGzIoo/52oN7gZlAPP+7FREFnZYFJ7HSPOYej9DE/yQMg6qjgIn9RwjhUgWWQlmvRN6fM3kqbCCDX5EQ== dependencies: "@types/uuid" "^9.0.1" commander "^10.0.1" @@ -3796,10 +3797,10 @@ onetime@^5.1.2: dependencies: mimic-fn "^2.1.0" -openai@^4.38.5, openai@^4.41.1: - version "4.47.1" - resolved "https://registry.yarnpkg.com/openai/-/openai-4.47.1.tgz#1d23c7a8eb3d7bcdc69709cd905f4c9af0181dba" - integrity sha512-WWSxhC/69ZhYWxH/OBsLEirIjUcfpQ5+ihkXKp06hmeYXgBBIUCa9IptMzYx6NdkiOCsSGYCnTIsxaic3AjRCQ== +openai@^4.38.5, openai@^4.49.1: + version "4.52.7" + resolved "https://registry.yarnpkg.com/openai/-/openai-4.52.7.tgz#e32b000142287a9e8eda8512ba28df33d11ec1f1" + integrity sha512-dgxA6UZHary6NXUHEDj5TWt8ogv0+ibH+b4pT5RrWMjiRZVylNwLcw/2ubDrX5n0oUmHX/ZgudMJeemxzOvz7A== dependencies: "@types/node" "^18.11.18" "@types/node-fetch" "^2.6.4" @@ -4477,7 +4478,12 @@ uri-js@^4.2.2: dependencies: punycode "^2.1.0" -uuid@^9.0.0, uuid@^9.0.1: +uuid@^10.0.0: + version "10.0.0" + resolved "https://registry.yarnpkg.com/uuid/-/uuid-10.0.0.tgz#5a95aa454e6e002725c79055fd42aaba30ca6294" + integrity sha512-8XkAphELsDnEGrDxUOHB3RGvXz6TeuYSGEZBOjtTtPm2lwhGBjLgOzLHB63IUWfBpNucQjND6d3AOudO+H3RWQ== + +uuid@^9.0.0: version "9.0.1" resolved "https://registry.yarnpkg.com/uuid/-/uuid-9.0.1.tgz#e188d4c8853cc722220392c424cd637f32293f30" integrity sha512-b+1eJOlsR9K8HJpow9Ok3fiWOWSIcIzXodvv0rQjVoOVNpWMpxf1wZNpt4y9h10odCNrqnYp1OBzRktckBe3sA== @@ -4640,3 +4646,8 @@ zod@^3.22.4: version "3.22.4" resolved "https://registry.yarnpkg.com/zod/-/zod-3.22.4.tgz#f31c3a9386f61b1f228af56faa9255e845cf3fff" integrity sha512-iC+8Io04lddc+mVqQ9AZ7OQ2MrUKGN+oIQyq1vemgt46jwCwLfhq7/pwnBnNXXXZb8VTVLKwp9EDkx+ryxIWmg== + +zod@^3.23.8: + version "3.23.8" + resolved "https://registry.yarnpkg.com/zod/-/zod-3.23.8.tgz#e37b957b5d52079769fb8097099b592f0ef4067d" + integrity sha512-XBx9AXhXktjUqnepgTiE5flcKIYWi/rme0Eaj+5Y0lftuGBq+jyRu/md4WnuxqgP1ubdpNCsYEYPxrzVHD8d6g== From e7214ecd193b05fa145d5476dbcb5052a92692c7 Mon Sep 17 00:00:00 2001 From: Tat Dat Duong Date: Thu, 18 Jul 2024 23:05:03 -0700 Subject: [PATCH 4/5] Deprecate runName --- js/src/wrappers/openai.ts | 21 ++++++++++++++------- 1 file changed, 14 insertions(+), 7 deletions(-) diff --git a/js/src/wrappers/openai.ts b/js/src/wrappers/openai.ts index 7870e460e..ba898f131 100644 --- a/js/src/wrappers/openai.ts +++ b/js/src/wrappers/openai.ts @@ -288,10 +288,9 @@ const _wrapClient = ( if (typeof originalValue === "function") { return traceable( originalValue.bind(target), - Object.assign( - { name: [runName, propKey.toString()].join("."), run_type: "llm" }, - options - ) + Object.assign({ run_type: "llm" }, options, { + name: [runName, propKey.toString()].join("."), + }) ); } else if ( originalValue != null && @@ -313,7 +312,12 @@ const _wrapClient = ( }; type WrapSDKOptions = Partial< - Omit & { runName: string } + RunTreeConfig & { + /** + * @deprecated Use `name` instead. + */ + runName: string; + } >; /** @@ -332,11 +336,14 @@ export const wrapSDK = ( options?: WrapSDKOptions ): T => { const traceableOptions = options ? { ...options } : undefined; - if (traceableOptions != null) delete traceableOptions.runName; + if (traceableOptions != null) { + delete traceableOptions.runName; + delete traceableOptions.name; + } return _wrapClient( sdk, - options?.runName ?? sdk.constructor?.name, + options?.name ?? options?.runName ?? sdk.constructor?.name, traceableOptions ); }; From a12638946923ca90d2e725b386bf07f1ed92f4ae Mon Sep 17 00:00:00 2001 From: Tat Dat Duong Date: Fri, 26 Jul 2024 12:18:42 -0700 Subject: [PATCH 5/5] Code review --- js/src/wrappers/openai.ts | 11 +++++------ 1 file changed, 5 insertions(+), 6 deletions(-) diff --git a/js/src/wrappers/openai.ts b/js/src/wrappers/openai.ts index ba898f131..23ff7d77e 100644 --- a/js/src/wrappers/openai.ts +++ b/js/src/wrappers/openai.ts @@ -286,12 +286,11 @@ const _wrapClient = ( get(target, propKey, receiver) { const originalValue = target[propKey as keyof T]; if (typeof originalValue === "function") { - return traceable( - originalValue.bind(target), - Object.assign({ run_type: "llm" }, options, { - name: [runName, propKey.toString()].join("."), - }) - ); + return traceable(originalValue.bind(target), { + run_type: "llm", + ...options, + name: [runName, propKey.toString()].join("."), + }); } else if ( originalValue != null && !Array.isArray(originalValue) &&