@langgraph-js/pure-graph 2.4.0 → 2.4.2

This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
package/README.md CHANGED
@@ -1,19 +1,19 @@
1
- # Pure Graph
1
+ # Open LangGraph Server
2
2
 
3
- Pure Graph is a library that provides a standard LangGraph endpoint for integrating into various frameworks like NextJS and Hono.js. It supports multiple storage backends (SQLite, PostgreSQL, Redis) and message queues.
3
+ Open LangGraph Server is a library that provides a standard LangGraph endpoint for integrating into various frameworks like NextJS and Hono.js. It supports multiple storage backends (SQLite, PostgreSQL, Redis) and message queues.
4
4
 
5
5
  ## 📢 Version Compatibility
6
6
 
7
- - **Pure Graph 2.0+**: Supports LangGraph 1.0+
8
- - **Pure Graph 1.x**: Compatible with LangGraph 0.1+
7
+ - **Open LangGraph Server 2.0+**: Supports LangGraph 1.0+
8
+ - **Open LangGraph Server 1.x**: Compatible with LangGraph 0.1+
9
9
 
10
10
  ### Migration Guide
11
11
 
12
- For detailed migration instructions from Pure Graph 1.x to 2.0, see our [Migration Guide](https://pure-graph.netlify.app/docs/migration-2.0).
12
+ For detailed migration instructions from Open LangGraph Server 1.x to 2.0, see our [Migration Guide](https://open-langgraph-server.agent-aura.top/docs/migration-2.0).
13
13
 
14
- 📚 **[Complete Documentation](https://pure-graph.netlify.app/docs/index.md)** - Comprehensive guides, API reference, and examples
14
+ 📚 **[Complete Documentation](https://open-langgraph-server.agent-aura.top/docs/index.md)** - Comprehensive guides, API reference, and examples
15
15
 
16
- This document will guide you on how to use Pure Graph in your projects.
16
+ This document will guide you on how to use Open LangGraph Server in your projects.
17
17
 
18
18
  ## Features
19
19
 
@@ -24,7 +24,7 @@ This document will guide you on how to use Pure Graph in your projects.
24
24
 
25
25
  ## Installation
26
26
 
27
- First, you need to install the Pure Graph package. You can do this using npm or yarn.
27
+ First, you need to install the Open LangGraph Server package. You can do this using npm or yarn.
28
28
 
29
29
  ```sh
30
30
  npm install @langgraph-js/pure-graph
@@ -59,7 +59,7 @@ my-nextjs-app/
59
59
  └── tsconfig.json # TypeScript configuration
60
60
  ```
61
61
 
62
- To integrate Pure Graph into a Next.js project, follow these steps:
62
+ To integrate Open LangGraph Server into a Next.js project, follow these steps:
63
63
 
64
64
  1. **Create a Route Handler**
65
65
 
@@ -114,7 +114,7 @@ To integrate Pure Graph into a Next.js project, follow these steps:
114
114
 
115
115
  ### Hono.js Example
116
116
 
117
- To integrate Pure Graph into a Hono.js project, follow these steps:
117
+ To integrate Open LangGraph Server into a Hono.js project, follow these steps:
118
118
 
119
119
  1. **Create a Hono Application**
120
120
 
@@ -202,7 +202,7 @@ To integrate Pure Graph into a Hono.js project, follow these steps:
202
202
 
203
203
  ## Context Passing
204
204
 
205
- Pure Graph supports passing custom context data to your graphs, which can be accessed via `getConfig().configurable` in your graph logic. This allows you to inject user-specific data, session information, or any other custom data into your LangGraph workflows.
205
+ Open LangGraph Server supports passing custom context data to your graphs, which can be accessed via `getConfig().configurable` in your graph logic. This allows you to inject user-specific data, session information, or any other custom data into your LangGraph workflows.
206
206
 
207
207
  ### Graph Code Example
208
208
 
@@ -357,7 +357,7 @@ Here are the environment variables you need to configure:
357
357
 
358
358
  ## Persistence Configuration
359
359
 
360
- Pure Graph supports multiple storage backends for persisting graph state, checkpoints, and thread data. Choose the appropriate storage type based on your requirements for scalability, persistence, and performance.
360
+ Open LangGraph Server supports multiple storage backends for persisting graph state, checkpoints, and thread data. Choose the appropriate storage type based on your requirements for scalability, persistence, and performance.
361
361
 
362
362
  ### Memory Storage (Default)
363
363
 
@@ -434,7 +434,7 @@ unset DATABASE_INIT
434
434
 
435
435
  ### Redis Storage
436
436
 
437
- Pure Graph supports two Redis checkpoint modes:
437
+ Open LangGraph Server supports two Redis checkpoint modes:
438
438
 
439
439
  #### Full Redis Checkpoint
440
440
 
@@ -1,7 +1,7 @@
1
1
  import { Hono } from 'hono';
2
2
  import { zValidator } from '@hono/zod-validator';
3
3
  import { c as createEndpoint } from '../../createEndpoint-Bxzbc61h.js';
4
- import { A as AssistantsSearchSchema, a as AssistantGraphQuerySchema, T as ThreadIdParamSchema, R as RunStreamPayloadSchema, b as RunIdParamSchema, c as RunJoinStreamQuerySchema, d as RunListQuerySchema, e as RunCancelQuerySchema, f as ThreadStateUpdate, g as ThreadCreatePayloadSchema, h as ThreadSearchPayloadSchema } from '../../zod-DixWQt_u.js';
4
+ import { A as AssistantsSearchSchema, a as AssistantGraphQuerySchema, T as ThreadIdParamSchema, R as RunStreamPayloadSchema, b as RunIdParamSchema, c as RunJoinStreamQuerySchema, d as RunListQuerySchema, e as RunCancelQuerySchema, f as ThreadStateUpdate, g as ThreadCreatePayloadSchema, h as ThreadSearchPayloadSchema } from '../../zod-B6xyK6pu.js';
5
5
  import camelcaseKeys from 'camelcase-keys';
6
6
  import { streamSSE } from 'hono/streaming';
7
7
  import { s as serialiseAsDict, L as LangGraphGlobal } from '../../stream-CAZ9j0yn.js';
@@ -25,7 +25,7 @@ api$2.get("/assistants/:assistant_id/graph", zValidator("query", AssistantGraphQ
25
25
  return c.json(data);
26
26
  });
27
27
 
28
- function withHeartbeat(streamFn, heartbeatInterval = 3e3) {
28
+ function withHeartbeat(streamFn, heartbeatInterval = process.env.HEARTBEAT_INTERVAL ? parseInt(process.env.HEARTBEAT_INTERVAL) : 1500) {
29
29
  return async (stream) => {
30
30
  let heartbeatTimer = null;
31
31
  const startHeartbeat = () => {
@@ -1 +1 @@
1
- {"version":3,"file":"index.js","sources":["../../../src/adapter/hono/endpoint.ts","../../../src/adapter/hono/assistants.ts","../../../src/adapter/hono/runs.ts","../../../src/adapter/hono/threads.ts","../../../src/adapter/hono/index.ts"],"sourcesContent":["import { createEndpoint } from '../../createEndpoint.js';\n\nexport const client = createEndpoint();\n","import { zValidator } from '@hono/zod-validator';\nimport { Hono } from 'hono';\nimport { client } from './endpoint';\nimport { AssistantsSearchSchema, AssistantGraphQuerySchema } from '../zod';\nimport camelcaseKeys from 'camelcase-keys';\nconst api = new Hono();\n\napi.post('/assistants/search', zValidator('json', AssistantsSearchSchema), async (c) => {\n // Search Assistants\n const payload = c.req.valid('json');\n let total = 0;\n const data = await client.assistants.search(camelcaseKeys(payload));\n c.res.headers.set('X-Pagination-Total', total.toString());\n return c.json(data);\n});\n\napi.get('/assistants/:assistant_id/graph', zValidator('query', AssistantGraphQuerySchema), async (c) => {\n const xray = c.req.valid('query').xray;\n const data = await client.assistants.getGraph(c.req.param('assistant_id'), {\n xray: xray !== undefined ? xray === 'true' : undefined,\n });\n return c.json(data);\n});\n\nexport default api;\n","import { zValidator } from '@hono/zod-validator';\nimport { Hono } from 'hono';\nimport { SSEStreamingApi, streamSSE } from 'hono/streaming';\nimport { client } from './endpoint';\nimport {\n ThreadIdParamSchema,\n RunIdParamSchema,\n RunStreamPayloadSchema,\n RunListQuerySchema,\n RunCancelQuerySchema,\n RunJoinStreamQuerySchema,\n ThreadStateUpdate,\n} from '../zod';\nimport { serialiseAsDict } from '../../graph/stream';\nimport z from 'zod';\nimport type { LangGraphServerContext } from './index';\nimport camelcaseKeys from 'camelcase-keys';\n\n/**\n * 为 streamSSE 添加心跳功能的 wrapper 函数\n * @param streamFn 原始的 async stream 函数\n * @param heartbeatInterval 心跳间隔,默认 3 秒\n * @returns 包裹后的 async stream 函数\n */\nfunction withHeartbeat(\n streamFn: (stream: SSEStreamingApi) => Promise<void>,\n heartbeatInterval: number = 3000,\n): (stream: SSEStreamingApi) => Promise<void> {\n return async (stream: SSEStreamingApi) => {\n let heartbeatTimer: NodeJS.Timeout | null = null;\n\n // 启动心跳定时器的函数\n const startHeartbeat = () => {\n if (heartbeatTimer) {\n clearInterval(heartbeatTimer);\n }\n heartbeatTimer = setInterval(async () => {\n try {\n await stream.writeSSE({ event: 'ping', data: '{}' });\n } catch (error) {\n if (heartbeatTimer) {\n clearInterval(heartbeatTimer);\n heartbeatTimer = null;\n }\n }\n }, heartbeatInterval);\n };\n\n // 停止心跳定时器的函数\n const stopHeartbeat = () => {\n if (heartbeatTimer) {\n clearInterval(heartbeatTimer);\n heartbeatTimer = null;\n }\n };\n\n // 创建代理 stream 对象,在每次写入时重置心跳\n const proxiedStream = new Proxy(stream, {\n get(target, prop) {\n if (prop === 'writeSSE') {\n return async (...args: any[]) => {\n // 每次有数据写入时,先停止当前心跳,然后重新启动\n stopHeartbeat();\n const result = await (target as any)[prop](...args);\n startHeartbeat();\n return result;\n };\n }\n return (target as any)[prop];\n },\n });\n\n // 启动初始心跳\n startHeartbeat();\n\n try {\n await streamFn(proxiedStream);\n } finally {\n stopHeartbeat();\n }\n };\n}\n\nconst api = new Hono<{ Variables: LangGraphServerContext }>();\n\n// 最常用的对话接口\napi.post(\n '/threads/:thread_id/runs/stream',\n zValidator('param', ThreadIdParamSchema),\n zValidator('json', RunStreamPayloadSchema),\n async (c) => {\n // Stream Run\n const { thread_id } = c.req.valid('param');\n const payload = c.req.valid('json');\n\n // c.header('Content-Location', `/threads/${thread_id}/runs/${run.run_id}`);\n return streamSSE(\n c,\n withHeartbeat(async (stream) => {\n payload.config = payload.config || {};\n payload.config.configurable = payload.config.configurable || {};\n const langgraphContext = c.get('langgraph_context');\n if (langgraphContext) {\n Object.assign(payload.config.configurable, langgraphContext);\n }\n /** @ts-ignore zod v3 的问题,与 ts 类型不一致 */\n for await (const { event, data } of client.runs.stream(\n thread_id,\n payload.assistant_id,\n camelcaseKeys(payload) as any,\n )) {\n await stream.writeSSE({ data: serialiseAsDict(data) ?? '', event });\n }\n }),\n );\n },\n);\n\n// 加入现有流的 GET 接口\napi.get(\n '/threads/:thread_id/runs/:run_id/stream',\n zValidator('param', RunIdParamSchema),\n zValidator('query', RunJoinStreamQuerySchema),\n async (c) => {\n const { thread_id, run_id } = c.req.valid('param');\n const { cancel_on_disconnect, last_event_id, stream_mode } = c.req.valid('query');\n\n return streamSSE(\n c,\n withHeartbeat(async (stream) => {\n // 创建 AbortController 用于处理取消信号\n const controller = new AbortController();\n\n // 如果需要断开连接时取消,则监听连接断开事件\n if (cancel_on_disconnect) {\n const cleanup = () => {\n controller.abort('Client disconnected');\n };\n\n // 监听连接断开事件\n c.req.raw.signal?.addEventListener('abort', cleanup);\n stream.onAbort = cleanup;\n }\n\n try {\n // 使用 joinStream 方法加入现有流\n for await (const { event, data, id } of client.runs.joinStream(thread_id, run_id, {\n signal: controller.signal,\n cancelOnDisconnect: cancel_on_disconnect,\n lastEventId: last_event_id,\n streamMode: stream_mode ? [stream_mode] : undefined,\n })) {\n // 发送 SSE 事件\n await stream.writeSSE({\n data: serialiseAsDict(data) ?? '',\n event: event as unknown as string,\n id,\n });\n }\n } catch (error) {\n // 如果不是用户取消导致的错误,则发送错误事件\n if (!(error instanceof Error) || !error.message.includes('user cancel')) {\n console.error('Join stream error:', error);\n await stream.writeSSE({\n event: 'error',\n data: JSON.stringify({\n error: error instanceof Error ? error.message : 'Unknown error',\n }),\n });\n }\n }\n }),\n );\n },\n);\n\napi.get(\n '/threads/:thread_id/runs',\n zValidator('param', ThreadIdParamSchema),\n zValidator('query', RunListQuerySchema),\n async (c) => {\n const { thread_id } = c.req.valid('param');\n const { limit, offset, status } = c.req.valid('query');\n const runs = await client.runs.list(thread_id, { limit, offset, status });\n return c.json(runs);\n },\n);\n\napi.post(\n '/threads/:thread_id/runs/:run_id/cancel',\n zValidator('param', RunIdParamSchema),\n zValidator('query', RunCancelQuerySchema),\n async (c) => {\n // Cancel Run Http\n const { thread_id, run_id } = c.req.valid('param');\n const { wait, action } = c.req.valid('query');\n const cancel = client.runs.cancel(thread_id, run_id, wait, action);\n if (wait) {\n await cancel;\n }\n return c.body(null, wait ? 204 : 202);\n },\n);\n\napi.post(\n '/threads/:thread_id/state',\n zValidator('param', z.object({ thread_id: z.string().uuid() })),\n zValidator('json', ThreadStateUpdate),\n async (c) => {\n // Update Thread State\n const { thread_id } = c.req.valid('param');\n const payload = c.req.valid('json');\n // const config: RunnableConfig = { configurable: { thread_id } };\n\n // if (payload.checkpoint_id) {\n // config.configurable ??= {};\n // config.configurable.checkpoint_id = payload.checkpoint_id;\n // }\n // if (payload.checkpoint) {\n // config.configurable ??= {};\n // Object.assign(config.configurable, payload.checkpoint);\n // }\n\n const inserted = await client.threads.updateState(thread_id, payload);\n\n return c.json(inserted);\n },\n);\nexport default api;\n","import { zValidator } from '@hono/zod-validator';\nimport { Hono } from 'hono';\nimport { client } from './endpoint';\nimport { ThreadIdParamSchema, ThreadCreatePayloadSchema, ThreadSearchPayloadSchema } from '../zod';\nimport camelcaseKeys from 'camelcase-keys';\n\nconst api = new Hono();\n\n// Threads Routes\napi.post('/threads', zValidator('json', ThreadCreatePayloadSchema), async (c) => {\n const payload = c.req.valid('json');\n const thread = await client.threads.create(camelcaseKeys(payload));\n\n return c.json(thread);\n});\n\napi.post('/threads/search', zValidator('json', ThreadSearchPayloadSchema), async (c) => {\n // Search Threads\n const payload = c.req.valid('json');\n const result = await client.threads.search(camelcaseKeys(payload));\n c.res.headers.set('X-Pagination-Total', result.length.toString());\n return c.json(result);\n});\n\napi.get('/threads/:thread_id', zValidator('param', ThreadIdParamSchema), async (c) => {\n // Get Thread\n const { thread_id } = c.req.valid('param');\n return c.json(await client.threads.get(thread_id));\n});\n\napi.delete('/threads/:thread_id', zValidator('param', ThreadIdParamSchema), async (c) => {\n // Delete Thread\n const { thread_id } = c.req.valid('param');\n await client.threads.delete(thread_id);\n return new Response(null, { status: 204 });\n});\n\nexport default api;\n","import { Hono } from 'hono';\nimport Assistants from './assistants';\nimport Runs from './runs';\nimport Threads from './threads';\n// import { cors } from 'hono/cors';\nimport { LangGraphGlobal } from '../../global';\n\nexport interface LangGraphServerContext {\n langgraph_context: any;\n}\nconst app = new Hono<{ Variables: LangGraphServerContext }>();\napp.use('*', async (c, next) => {\n await LangGraphGlobal.initGlobal();\n return next();\n});\n// app.use(cors());\n\napp.route('/', Assistants);\napp.route('/', Runs);\napp.route('/', Threads);\n\nexport default app;\n"],"names":["api","Assistants","Runs","Threads"],"mappings":"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"}
1
+ {"version":3,"file":"index.js","sources":["../../../src/adapter/hono/endpoint.ts","../../../src/adapter/hono/assistants.ts","../../../src/adapter/hono/runs.ts","../../../src/adapter/hono/threads.ts","../../../src/adapter/hono/index.ts"],"sourcesContent":["import { createEndpoint } from '../../createEndpoint.js';\n\nexport const client = createEndpoint();\n","import { zValidator } from '@hono/zod-validator';\nimport { Hono } from 'hono';\nimport { client } from './endpoint';\nimport { AssistantsSearchSchema, AssistantGraphQuerySchema } from '../zod';\nimport camelcaseKeys from 'camelcase-keys';\nconst api = new Hono();\n\napi.post('/assistants/search', zValidator('json', AssistantsSearchSchema), async (c) => {\n // Search Assistants\n const payload = c.req.valid('json');\n let total = 0;\n const data = await client.assistants.search(camelcaseKeys(payload));\n c.res.headers.set('X-Pagination-Total', total.toString());\n return c.json(data);\n});\n\napi.get('/assistants/:assistant_id/graph', zValidator('query', AssistantGraphQuerySchema), async (c) => {\n const xray = c.req.valid('query').xray;\n const data = await client.assistants.getGraph(c.req.param('assistant_id'), {\n xray: xray !== undefined ? xray === 'true' : undefined,\n });\n return c.json(data);\n});\n\nexport default api;\n","import { zValidator } from '@hono/zod-validator';\nimport { Hono } from 'hono';\nimport { SSEStreamingApi, streamSSE } from 'hono/streaming';\nimport { client } from './endpoint';\nimport {\n ThreadIdParamSchema,\n RunIdParamSchema,\n RunStreamPayloadSchema,\n RunListQuerySchema,\n RunCancelQuerySchema,\n RunJoinStreamQuerySchema,\n ThreadStateUpdate,\n} from '../zod';\nimport { serialiseAsDict } from '../../graph/stream';\nimport z from 'zod';\nimport type { LangGraphServerContext } from './index';\nimport camelcaseKeys from 'camelcase-keys';\n\n/**\n * 为 streamSSE 添加心跳功能的 wrapper 函数\n * @param streamFn 原始的 async stream 函数\n * @param heartbeatInterval 心跳间隔,默认 3 秒\n * @returns 包裹后的 async stream 函数\n */\nfunction withHeartbeat(\n streamFn: (stream: SSEStreamingApi) => Promise<void>,\n heartbeatInterval: number = process.env.HEARTBEAT_INTERVAL ? parseInt(process.env.HEARTBEAT_INTERVAL) : 1500,\n): (stream: SSEStreamingApi) => Promise<void> {\n return async (stream: SSEStreamingApi) => {\n let heartbeatTimer: NodeJS.Timeout | null = null;\n\n // 启动心跳定时器的函数\n const startHeartbeat = () => {\n if (heartbeatTimer) {\n clearInterval(heartbeatTimer);\n }\n heartbeatTimer = setInterval(async () => {\n try {\n await stream.writeSSE({ event: 'ping', data: '{}' });\n } catch (error) {\n if (heartbeatTimer) {\n clearInterval(heartbeatTimer);\n heartbeatTimer = null;\n }\n }\n }, heartbeatInterval);\n };\n\n // 停止心跳定时器的函数\n const stopHeartbeat = () => {\n if (heartbeatTimer) {\n clearInterval(heartbeatTimer);\n heartbeatTimer = null;\n }\n };\n\n // 创建代理 stream 对象,在每次写入时重置心跳\n const proxiedStream = new Proxy(stream, {\n get(target, prop) {\n if (prop === 'writeSSE') {\n return async (...args: any[]) => {\n // 每次有数据写入时,先停止当前心跳,然后重新启动\n stopHeartbeat();\n const result = await (target as any)[prop](...args);\n startHeartbeat();\n return result;\n };\n }\n return (target as any)[prop];\n },\n });\n\n // 启动初始心跳\n startHeartbeat();\n\n try {\n await streamFn(proxiedStream);\n } finally {\n stopHeartbeat();\n }\n };\n}\n\nconst api = new Hono<{ Variables: LangGraphServerContext }>();\n\n// 最常用的对话接口\napi.post(\n '/threads/:thread_id/runs/stream',\n zValidator('param', ThreadIdParamSchema),\n zValidator('json', RunStreamPayloadSchema),\n async (c) => {\n // Stream Run\n const { thread_id } = c.req.valid('param');\n const payload = c.req.valid('json');\n\n // c.header('Content-Location', `/threads/${thread_id}/runs/${run.run_id}`);\n return streamSSE(\n c,\n withHeartbeat(async (stream) => {\n payload.config = payload.config || {};\n payload.config.configurable = payload.config.configurable || {};\n const langgraphContext = c.get('langgraph_context');\n if (langgraphContext) {\n Object.assign(payload.config.configurable, langgraphContext);\n }\n /** @ts-ignore zod v3 的问题,与 ts 类型不一致 */\n for await (const { event, data } of client.runs.stream(\n thread_id,\n payload.assistant_id,\n camelcaseKeys(payload) as any,\n )) {\n await stream.writeSSE({ data: serialiseAsDict(data) ?? '', event });\n }\n }),\n );\n },\n);\n\n// 加入现有流的 GET 接口\napi.get(\n '/threads/:thread_id/runs/:run_id/stream',\n zValidator('param', RunIdParamSchema),\n zValidator('query', RunJoinStreamQuerySchema),\n async (c) => {\n const { thread_id, run_id } = c.req.valid('param');\n const { cancel_on_disconnect, last_event_id, stream_mode } = c.req.valid('query');\n\n return streamSSE(\n c,\n withHeartbeat(async (stream) => {\n // 创建 AbortController 用于处理取消信号\n const controller = new AbortController();\n\n // 如果需要断开连接时取消,则监听连接断开事件\n if (cancel_on_disconnect) {\n const cleanup = () => {\n controller.abort('Client disconnected');\n };\n\n // 监听连接断开事件\n c.req.raw.signal?.addEventListener('abort', cleanup);\n stream.onAbort = cleanup;\n }\n\n try {\n // 使用 joinStream 方法加入现有流\n for await (const { event, data, id } of client.runs.joinStream(thread_id, run_id, {\n signal: controller.signal,\n cancelOnDisconnect: cancel_on_disconnect,\n lastEventId: last_event_id,\n streamMode: stream_mode ? [stream_mode] : undefined,\n })) {\n // 发送 SSE 事件\n await stream.writeSSE({\n data: serialiseAsDict(data) ?? '',\n event: event as unknown as string,\n id,\n });\n }\n } catch (error) {\n // 如果不是用户取消导致的错误,则发送错误事件\n if (!(error instanceof Error) || !error.message.includes('user cancel')) {\n console.error('Join stream error:', error);\n await stream.writeSSE({\n event: 'error',\n data: JSON.stringify({\n error: error instanceof Error ? error.message : 'Unknown error',\n }),\n });\n }\n }\n }),\n );\n },\n);\n\napi.get(\n '/threads/:thread_id/runs',\n zValidator('param', ThreadIdParamSchema),\n zValidator('query', RunListQuerySchema),\n async (c) => {\n const { thread_id } = c.req.valid('param');\n const { limit, offset, status } = c.req.valid('query');\n const runs = await client.runs.list(thread_id, { limit, offset, status });\n return c.json(runs);\n },\n);\n\napi.post(\n '/threads/:thread_id/runs/:run_id/cancel',\n zValidator('param', RunIdParamSchema),\n zValidator('query', RunCancelQuerySchema),\n async (c) => {\n // Cancel Run Http\n const { thread_id, run_id } = c.req.valid('param');\n const { wait, action } = c.req.valid('query');\n const cancel = client.runs.cancel(thread_id, run_id, wait, action);\n if (wait) {\n await cancel;\n }\n return c.body(null, wait ? 204 : 202);\n },\n);\n\napi.post(\n '/threads/:thread_id/state',\n zValidator('param', z.object({ thread_id: z.string().uuid() })),\n zValidator('json', ThreadStateUpdate),\n async (c) => {\n // Update Thread State\n const { thread_id } = c.req.valid('param');\n const payload = c.req.valid('json');\n // const config: RunnableConfig = { configurable: { thread_id } };\n\n // if (payload.checkpoint_id) {\n // config.configurable ??= {};\n // config.configurable.checkpoint_id = payload.checkpoint_id;\n // }\n // if (payload.checkpoint) {\n // config.configurable ??= {};\n // Object.assign(config.configurable, payload.checkpoint);\n // }\n\n const inserted = await client.threads.updateState(thread_id, payload);\n\n return c.json(inserted);\n },\n);\nexport default api;\n","import { zValidator } from '@hono/zod-validator';\nimport { Hono } from 'hono';\nimport { client } from './endpoint';\nimport { ThreadIdParamSchema, ThreadCreatePayloadSchema, ThreadSearchPayloadSchema } from '../zod';\nimport camelcaseKeys from 'camelcase-keys';\n\nconst api = new Hono();\n\n// Threads Routes\napi.post('/threads', zValidator('json', ThreadCreatePayloadSchema), async (c) => {\n const payload = c.req.valid('json');\n const thread = await client.threads.create(camelcaseKeys(payload));\n\n return c.json(thread);\n});\n\napi.post('/threads/search', zValidator('json', ThreadSearchPayloadSchema), async (c) => {\n // Search Threads\n const payload = c.req.valid('json');\n const result = await client.threads.search(camelcaseKeys(payload));\n c.res.headers.set('X-Pagination-Total', result.length.toString());\n return c.json(result);\n});\n\napi.get('/threads/:thread_id', zValidator('param', ThreadIdParamSchema), async (c) => {\n // Get Thread\n const { thread_id } = c.req.valid('param');\n return c.json(await client.threads.get(thread_id));\n});\n\napi.delete('/threads/:thread_id', zValidator('param', ThreadIdParamSchema), async (c) => {\n // Delete Thread\n const { thread_id } = c.req.valid('param');\n await client.threads.delete(thread_id);\n return new Response(null, { status: 204 });\n});\n\nexport default api;\n","import { Hono } from 'hono';\nimport Assistants from './assistants';\nimport Runs from './runs';\nimport Threads from './threads';\n// import { cors } from 'hono/cors';\nimport { LangGraphGlobal } from '../../global';\n\nexport interface LangGraphServerContext {\n langgraph_context: any;\n}\nconst app = new Hono<{ Variables: LangGraphServerContext }>();\napp.use('*', async (c, next) => {\n await LangGraphGlobal.initGlobal();\n return next();\n});\n// app.use(cors());\n\napp.route('/', Assistants);\napp.route('/', Runs);\napp.route('/', Threads);\n\nexport default app;\n"],"names":["api","Assistants","Runs","Threads"],"mappings":"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"}
@@ -5,7 +5,7 @@ async function ensureInitialized(attachGraphPromise) {
5
5
  globalThis.LG_INIT_PROMISE = (async () => {
6
6
  await LangGraphGlobal.initGlobal();
7
7
  await attachGraphPromise();
8
- const { GET, POST, DELETE } = await import('../../router-Dg9I9CpI.js');
8
+ const { GET, POST, DELETE } = await import('../../router-DOVN2of2.js');
9
9
  return {
10
10
  GET,
11
11
  POST,
@@ -2,596 +2,210 @@ import z from 'zod';
2
2
  export declare const AssistantConfigurable: z.ZodObject<{
3
3
  thread_id: z.ZodOptional<z.ZodString>;
4
4
  thread_ts: z.ZodOptional<z.ZodString>;
5
- }, "strip", z.ZodUnknown, z.objectOutputType<{
6
- thread_id: z.ZodOptional<z.ZodString>;
7
- thread_ts: z.ZodOptional<z.ZodString>;
8
- }, z.ZodUnknown, "strip">, z.objectInputType<{
9
- thread_id: z.ZodOptional<z.ZodString>;
10
- thread_ts: z.ZodOptional<z.ZodString>;
11
- }, z.ZodUnknown, "strip">>;
5
+ }, z.core.$catchall<z.ZodUnknown>>;
12
6
  export declare const AssistantConfig: z.ZodObject<{
13
- tags: z.ZodOptional<z.ZodArray<z.ZodString, "many">>;
14
- recursion_limit: z.ZodOptional<z.ZodNumber>;
15
- configurable: z.ZodOptional<z.ZodObject<{
16
- thread_id: z.ZodOptional<z.ZodString>;
17
- thread_ts: z.ZodOptional<z.ZodString>;
18
- }, "strip", z.ZodUnknown, z.objectOutputType<{
19
- thread_id: z.ZodOptional<z.ZodString>;
20
- thread_ts: z.ZodOptional<z.ZodString>;
21
- }, z.ZodUnknown, "strip">, z.objectInputType<{
22
- thread_id: z.ZodOptional<z.ZodString>;
23
- thread_ts: z.ZodOptional<z.ZodString>;
24
- }, z.ZodUnknown, "strip">>>;
25
- }, "strip", z.ZodUnknown, z.objectOutputType<{
26
- tags: z.ZodOptional<z.ZodArray<z.ZodString, "many">>;
27
- recursion_limit: z.ZodOptional<z.ZodNumber>;
28
- configurable: z.ZodOptional<z.ZodObject<{
29
- thread_id: z.ZodOptional<z.ZodString>;
30
- thread_ts: z.ZodOptional<z.ZodString>;
31
- }, "strip", z.ZodUnknown, z.objectOutputType<{
32
- thread_id: z.ZodOptional<z.ZodString>;
33
- thread_ts: z.ZodOptional<z.ZodString>;
34
- }, z.ZodUnknown, "strip">, z.objectInputType<{
35
- thread_id: z.ZodOptional<z.ZodString>;
36
- thread_ts: z.ZodOptional<z.ZodString>;
37
- }, z.ZodUnknown, "strip">>>;
38
- }, z.ZodUnknown, "strip">, z.objectInputType<{
39
- tags: z.ZodOptional<z.ZodArray<z.ZodString, "many">>;
7
+ tags: z.ZodOptional<z.ZodArray<z.ZodString>>;
40
8
  recursion_limit: z.ZodOptional<z.ZodNumber>;
41
9
  configurable: z.ZodOptional<z.ZodObject<{
42
10
  thread_id: z.ZodOptional<z.ZodString>;
43
11
  thread_ts: z.ZodOptional<z.ZodString>;
44
- }, "strip", z.ZodUnknown, z.objectOutputType<{
45
- thread_id: z.ZodOptional<z.ZodString>;
46
- thread_ts: z.ZodOptional<z.ZodString>;
47
- }, z.ZodUnknown, "strip">, z.objectInputType<{
48
- thread_id: z.ZodOptional<z.ZodString>;
49
- thread_ts: z.ZodOptional<z.ZodString>;
50
- }, z.ZodUnknown, "strip">>>;
51
- }, z.ZodUnknown, "strip">>;
12
+ }, z.core.$catchall<z.ZodUnknown>>>;
13
+ }, z.core.$catchall<z.ZodUnknown>>;
52
14
  export declare const Assistant: z.ZodObject<{
53
15
  assistant_id: z.ZodString;
54
16
  graph_id: z.ZodString;
55
17
  config: z.ZodObject<{
56
- tags: z.ZodOptional<z.ZodArray<z.ZodString, "many">>;
57
- recursion_limit: z.ZodOptional<z.ZodNumber>;
58
- configurable: z.ZodOptional<z.ZodObject<{
59
- thread_id: z.ZodOptional<z.ZodString>;
60
- thread_ts: z.ZodOptional<z.ZodString>;
61
- }, "strip", z.ZodUnknown, z.objectOutputType<{
62
- thread_id: z.ZodOptional<z.ZodString>;
63
- thread_ts: z.ZodOptional<z.ZodString>;
64
- }, z.ZodUnknown, "strip">, z.objectInputType<{
65
- thread_id: z.ZodOptional<z.ZodString>;
66
- thread_ts: z.ZodOptional<z.ZodString>;
67
- }, z.ZodUnknown, "strip">>>;
68
- }, "strip", z.ZodUnknown, z.objectOutputType<{
69
- tags: z.ZodOptional<z.ZodArray<z.ZodString, "many">>;
70
- recursion_limit: z.ZodOptional<z.ZodNumber>;
71
- configurable: z.ZodOptional<z.ZodObject<{
72
- thread_id: z.ZodOptional<z.ZodString>;
73
- thread_ts: z.ZodOptional<z.ZodString>;
74
- }, "strip", z.ZodUnknown, z.objectOutputType<{
75
- thread_id: z.ZodOptional<z.ZodString>;
76
- thread_ts: z.ZodOptional<z.ZodString>;
77
- }, z.ZodUnknown, "strip">, z.objectInputType<{
78
- thread_id: z.ZodOptional<z.ZodString>;
79
- thread_ts: z.ZodOptional<z.ZodString>;
80
- }, z.ZodUnknown, "strip">>>;
81
- }, z.ZodUnknown, "strip">, z.objectInputType<{
82
- tags: z.ZodOptional<z.ZodArray<z.ZodString, "many">>;
18
+ tags: z.ZodOptional<z.ZodArray<z.ZodString>>;
83
19
  recursion_limit: z.ZodOptional<z.ZodNumber>;
84
20
  configurable: z.ZodOptional<z.ZodObject<{
85
21
  thread_id: z.ZodOptional<z.ZodString>;
86
22
  thread_ts: z.ZodOptional<z.ZodString>;
87
- }, "strip", z.ZodUnknown, z.objectOutputType<{
88
- thread_id: z.ZodOptional<z.ZodString>;
89
- thread_ts: z.ZodOptional<z.ZodString>;
90
- }, z.ZodUnknown, "strip">, z.objectInputType<{
91
- thread_id: z.ZodOptional<z.ZodString>;
92
- thread_ts: z.ZodOptional<z.ZodString>;
93
- }, z.ZodUnknown, "strip">>>;
94
- }, z.ZodUnknown, "strip">>;
23
+ }, z.core.$catchall<z.ZodUnknown>>>;
24
+ }, z.core.$catchall<z.ZodUnknown>>;
95
25
  created_at: z.ZodString;
96
26
  updated_at: z.ZodString;
97
- metadata: z.ZodObject<{}, "strip", z.ZodAny, z.objectOutputType<{}, z.ZodAny, "strip">, z.objectInputType<{}, z.ZodAny, "strip">>;
98
- }, "strip", z.ZodTypeAny, {
99
- assistant_id: string;
100
- graph_id: string;
101
- created_at: string;
102
- updated_at: string;
103
- metadata: {} & {
104
- [k: string]: any;
105
- };
106
- config: {
107
- configurable?: z.objectOutputType<{
108
- thread_id: z.ZodOptional<z.ZodString>;
109
- thread_ts: z.ZodOptional<z.ZodString>;
110
- }, z.ZodUnknown, "strip"> | undefined;
111
- tags?: string[] | undefined;
112
- recursion_limit?: number | undefined;
113
- } & {
114
- [k: string]: unknown;
115
- };
116
- }, {
117
- assistant_id: string;
118
- graph_id: string;
119
- created_at: string;
120
- updated_at: string;
121
- metadata: {} & {
122
- [k: string]: any;
123
- };
124
- config: {
125
- configurable?: z.objectInputType<{
126
- thread_id: z.ZodOptional<z.ZodString>;
127
- thread_ts: z.ZodOptional<z.ZodString>;
128
- }, z.ZodUnknown, "strip"> | undefined;
129
- tags?: string[] | undefined;
130
- recursion_limit?: number | undefined;
131
- } & {
132
- [k: string]: unknown;
133
- };
134
- }>;
27
+ metadata: z.ZodObject<{}, z.core.$catchall<z.ZodAny>>;
28
+ }, z.core.$strip>;
135
29
  export declare const MetadataSchema: z.ZodObject<{
136
- source: z.ZodOptional<z.ZodUnion<[z.ZodLiteral<"input">, z.ZodLiteral<"loop">, z.ZodLiteral<"update">, z.ZodString]>>;
137
- step: z.ZodOptional<z.ZodNumber>;
138
- writes: z.ZodOptional<z.ZodNullable<z.ZodRecord<z.ZodString, z.ZodUnknown>>>;
139
- parents: z.ZodOptional<z.ZodRecord<z.ZodString, z.ZodString>>;
140
- }, "strip", z.ZodUnknown, z.objectOutputType<{
141
- source: z.ZodOptional<z.ZodUnion<[z.ZodLiteral<"input">, z.ZodLiteral<"loop">, z.ZodLiteral<"update">, z.ZodString]>>;
30
+ source: z.ZodOptional<z.ZodUnion<readonly [z.ZodLiteral<"input">, z.ZodLiteral<"loop">, z.ZodLiteral<"update">, z.ZodString]>>;
142
31
  step: z.ZodOptional<z.ZodNumber>;
143
- writes: z.ZodOptional<z.ZodNullable<z.ZodRecord<z.ZodString, z.ZodUnknown>>>;
144
- parents: z.ZodOptional<z.ZodRecord<z.ZodString, z.ZodString>>;
145
- }, z.ZodUnknown, "strip">, z.objectInputType<{
146
- source: z.ZodOptional<z.ZodUnion<[z.ZodLiteral<"input">, z.ZodLiteral<"loop">, z.ZodLiteral<"update">, z.ZodString]>>;
147
- step: z.ZodOptional<z.ZodNumber>;
148
- writes: z.ZodOptional<z.ZodNullable<z.ZodRecord<z.ZodString, z.ZodUnknown>>>;
149
- parents: z.ZodOptional<z.ZodRecord<z.ZodString, z.ZodString>>;
150
- }, z.ZodUnknown, "strip">>;
32
+ writes: z.ZodOptional<z.ZodNullable<z.ZodAny>>;
33
+ parents: z.ZodOptional<z.ZodAny>;
34
+ }, z.core.$catchall<z.ZodUnknown>>;
151
35
  export declare const SendSchema: z.ZodObject<{
152
36
  node: z.ZodString;
153
37
  input: z.ZodOptional<z.ZodUnknown>;
154
- }, "strip", z.ZodTypeAny, {
155
- node: string;
156
- input?: unknown;
157
- }, {
158
- node: string;
159
- input?: unknown;
160
- }>;
38
+ }, z.core.$strip>;
161
39
  export declare const CommandSchema: z.ZodObject<{
162
- update: z.ZodOptional<z.ZodNullable<z.ZodUnion<[z.ZodRecord<z.ZodString, z.ZodUnknown>, z.ZodArray<z.ZodTuple<[z.ZodString, z.ZodUnknown], null>, "many">]>>>;
40
+ update: z.ZodOptional<z.ZodNullable<z.ZodUnion<readonly [z.ZodAny, z.ZodArray<z.ZodTuple<[z.ZodString, z.ZodAny], null>>]>>>;
163
41
  resume: z.ZodOptional<z.ZodUnknown>;
164
- goto: z.ZodOptional<z.ZodUnion<[z.ZodObject<{
42
+ goto: z.ZodOptional<z.ZodUnion<readonly [z.ZodObject<{
165
43
  node: z.ZodString;
166
44
  input: z.ZodOptional<z.ZodUnknown>;
167
- }, "strip", z.ZodTypeAny, {
168
- node: string;
169
- input?: unknown;
170
- }, {
171
- node: string;
172
- input?: unknown;
173
- }>, z.ZodArray<z.ZodObject<{
45
+ }, z.core.$strip>, z.ZodArray<z.ZodObject<{
174
46
  node: z.ZodString;
175
47
  input: z.ZodOptional<z.ZodUnknown>;
176
- }, "strip", z.ZodTypeAny, {
177
- node: string;
178
- input?: unknown;
179
- }, {
180
- node: string;
181
- input?: unknown;
182
- }>, "many">, z.ZodString, z.ZodArray<z.ZodString, "many">]>>;
183
- }, "strip", z.ZodTypeAny, {
184
- resume?: unknown;
185
- update?: Record<string, unknown> | [string, unknown][] | null | undefined;
186
- goto?: string | string[] | {
187
- node: string;
188
- input?: unknown;
189
- } | {
190
- node: string;
191
- input?: unknown;
192
- }[] | undefined;
193
- }, {
194
- resume?: unknown;
195
- update?: Record<string, unknown> | [string, unknown][] | null | undefined;
196
- goto?: string | string[] | {
197
- node: string;
198
- input?: unknown;
199
- } | {
200
- node: string;
201
- input?: unknown;
202
- }[] | undefined;
203
- }>;
48
+ }, z.core.$strip>>, z.ZodString, z.ZodArray<z.ZodString>]>>;
49
+ }, z.core.$strip>;
204
50
  export declare const PaginationQuerySchema: z.ZodObject<{
205
51
  limit: z.ZodOptional<z.ZodNumber>;
206
52
  offset: z.ZodOptional<z.ZodNumber>;
207
- }, "strip", z.ZodTypeAny, {
208
- limit?: number | undefined;
209
- offset?: number | undefined;
210
- }, {
211
- limit?: number | undefined;
212
- offset?: number | undefined;
213
- }>;
53
+ }, z.core.$strip>;
214
54
  export declare const ThreadIdParamSchema: z.ZodObject<{
215
55
  thread_id: z.ZodString;
216
- }, "strip", z.ZodTypeAny, {
217
- thread_id: string;
218
- }, {
219
- thread_id: string;
220
- }>;
56
+ }, z.core.$strip>;
221
57
  export declare const RunIdParamSchema: z.ZodObject<{
222
58
  thread_id: z.ZodString;
223
59
  run_id: z.ZodString;
224
- }, "strip", z.ZodTypeAny, {
225
- thread_id: string;
226
- run_id: string;
227
- }, {
228
- thread_id: string;
229
- run_id: string;
230
- }>;
60
+ }, z.core.$strip>;
231
61
  export declare const AssistantsSearchSchema: z.ZodObject<{
232
62
  graph_id: z.ZodOptional<z.ZodString>;
233
63
  metadata: z.ZodOptional<z.ZodObject<{
234
- source: z.ZodOptional<z.ZodUnion<[z.ZodLiteral<"input">, z.ZodLiteral<"loop">, z.ZodLiteral<"update">, z.ZodString]>>;
235
- step: z.ZodOptional<z.ZodNumber>;
236
- writes: z.ZodOptional<z.ZodNullable<z.ZodRecord<z.ZodString, z.ZodUnknown>>>;
237
- parents: z.ZodOptional<z.ZodRecord<z.ZodString, z.ZodString>>;
238
- }, "strip", z.ZodUnknown, z.objectOutputType<{
239
- source: z.ZodOptional<z.ZodUnion<[z.ZodLiteral<"input">, z.ZodLiteral<"loop">, z.ZodLiteral<"update">, z.ZodString]>>;
64
+ source: z.ZodOptional<z.ZodUnion<readonly [z.ZodLiteral<"input">, z.ZodLiteral<"loop">, z.ZodLiteral<"update">, z.ZodString]>>;
240
65
  step: z.ZodOptional<z.ZodNumber>;
241
- writes: z.ZodOptional<z.ZodNullable<z.ZodRecord<z.ZodString, z.ZodUnknown>>>;
242
- parents: z.ZodOptional<z.ZodRecord<z.ZodString, z.ZodString>>;
243
- }, z.ZodUnknown, "strip">, z.objectInputType<{
244
- source: z.ZodOptional<z.ZodUnion<[z.ZodLiteral<"input">, z.ZodLiteral<"loop">, z.ZodLiteral<"update">, z.ZodString]>>;
245
- step: z.ZodOptional<z.ZodNumber>;
246
- writes: z.ZodOptional<z.ZodNullable<z.ZodRecord<z.ZodString, z.ZodUnknown>>>;
247
- parents: z.ZodOptional<z.ZodRecord<z.ZodString, z.ZodString>>;
248
- }, z.ZodUnknown, "strip">>>;
66
+ writes: z.ZodOptional<z.ZodNullable<z.ZodAny>>;
67
+ parents: z.ZodOptional<z.ZodAny>;
68
+ }, z.core.$catchall<z.ZodUnknown>>>;
249
69
  limit: z.ZodOptional<z.ZodNumber>;
250
70
  offset: z.ZodOptional<z.ZodNumber>;
251
- }, "strip", z.ZodTypeAny, {
252
- graph_id?: string | undefined;
253
- metadata?: z.objectOutputType<{
254
- source: z.ZodOptional<z.ZodUnion<[z.ZodLiteral<"input">, z.ZodLiteral<"loop">, z.ZodLiteral<"update">, z.ZodString]>>;
255
- step: z.ZodOptional<z.ZodNumber>;
256
- writes: z.ZodOptional<z.ZodNullable<z.ZodRecord<z.ZodString, z.ZodUnknown>>>;
257
- parents: z.ZodOptional<z.ZodRecord<z.ZodString, z.ZodString>>;
258
- }, z.ZodUnknown, "strip"> | undefined;
259
- limit?: number | undefined;
260
- offset?: number | undefined;
261
- }, {
262
- graph_id?: string | undefined;
263
- metadata?: z.objectInputType<{
264
- source: z.ZodOptional<z.ZodUnion<[z.ZodLiteral<"input">, z.ZodLiteral<"loop">, z.ZodLiteral<"update">, z.ZodString]>>;
265
- step: z.ZodOptional<z.ZodNumber>;
266
- writes: z.ZodOptional<z.ZodNullable<z.ZodRecord<z.ZodString, z.ZodUnknown>>>;
267
- parents: z.ZodOptional<z.ZodRecord<z.ZodString, z.ZodString>>;
268
- }, z.ZodUnknown, "strip"> | undefined;
269
- limit?: number | undefined;
270
- offset?: number | undefined;
271
- }>;
71
+ }, z.core.$strip>;
272
72
  export declare const AssistantGraphQuerySchema: z.ZodObject<{
273
73
  xray: z.ZodOptional<z.ZodString>;
274
- }, "strip", z.ZodTypeAny, {
275
- xray?: string | undefined;
276
- }, {
277
- xray?: string | undefined;
278
- }>;
74
+ }, z.core.$strip>;
279
75
  export declare const RunStreamPayloadSchema: z.ZodObject<{
280
- assistant_id: z.ZodUnion<[z.ZodString, z.ZodString]>;
76
+ assistant_id: z.ZodUnion<readonly [z.ZodString, z.ZodString]>;
281
77
  checkpoint_id: z.ZodOptional<z.ZodString>;
282
78
  input: z.ZodOptional<z.ZodAny>;
283
79
  command: z.ZodOptional<z.ZodObject<{
284
- update: z.ZodOptional<z.ZodNullable<z.ZodUnion<[z.ZodRecord<z.ZodString, z.ZodUnknown>, z.ZodArray<z.ZodTuple<[z.ZodString, z.ZodUnknown], null>, "many">]>>>;
80
+ update: z.ZodOptional<z.ZodNullable<z.ZodUnion<readonly [z.ZodAny, z.ZodArray<z.ZodTuple<[z.ZodString, z.ZodAny], null>>]>>>;
285
81
  resume: z.ZodOptional<z.ZodUnknown>;
286
- goto: z.ZodOptional<z.ZodUnion<[z.ZodObject<{
82
+ goto: z.ZodOptional<z.ZodUnion<readonly [z.ZodObject<{
287
83
  node: z.ZodString;
288
84
  input: z.ZodOptional<z.ZodUnknown>;
289
- }, "strip", z.ZodTypeAny, {
290
- node: string;
291
- input?: unknown;
292
- }, {
293
- node: string;
294
- input?: unknown;
295
- }>, z.ZodArray<z.ZodObject<{
85
+ }, z.core.$strip>, z.ZodArray<z.ZodObject<{
296
86
  node: z.ZodString;
297
87
  input: z.ZodOptional<z.ZodUnknown>;
298
- }, "strip", z.ZodTypeAny, {
299
- node: string;
300
- input?: unknown;
301
- }, {
302
- node: string;
303
- input?: unknown;
304
- }>, "many">, z.ZodString, z.ZodArray<z.ZodString, "many">]>>;
305
- }, "strip", z.ZodTypeAny, {
306
- resume?: unknown;
307
- update?: Record<string, unknown> | [string, unknown][] | null | undefined;
308
- goto?: string | string[] | {
309
- node: string;
310
- input?: unknown;
311
- } | {
312
- node: string;
313
- input?: unknown;
314
- }[] | undefined;
315
- }, {
316
- resume?: unknown;
317
- update?: Record<string, unknown> | [string, unknown][] | null | undefined;
318
- goto?: string | string[] | {
319
- node: string;
320
- input?: unknown;
321
- } | {
322
- node: string;
323
- input?: unknown;
324
- }[] | undefined;
325
- }>>;
88
+ }, z.core.$strip>>, z.ZodString, z.ZodArray<z.ZodString>]>>;
89
+ }, z.core.$strip>>;
326
90
  metadata: z.ZodOptional<z.ZodObject<{
327
- source: z.ZodOptional<z.ZodUnion<[z.ZodLiteral<"input">, z.ZodLiteral<"loop">, z.ZodLiteral<"update">, z.ZodString]>>;
328
- step: z.ZodOptional<z.ZodNumber>;
329
- writes: z.ZodOptional<z.ZodNullable<z.ZodRecord<z.ZodString, z.ZodUnknown>>>;
330
- parents: z.ZodOptional<z.ZodRecord<z.ZodString, z.ZodString>>;
331
- }, "strip", z.ZodUnknown, z.objectOutputType<{
332
- source: z.ZodOptional<z.ZodUnion<[z.ZodLiteral<"input">, z.ZodLiteral<"loop">, z.ZodLiteral<"update">, z.ZodString]>>;
91
+ source: z.ZodOptional<z.ZodUnion<readonly [z.ZodLiteral<"input">, z.ZodLiteral<"loop">, z.ZodLiteral<"update">, z.ZodString]>>;
333
92
  step: z.ZodOptional<z.ZodNumber>;
334
- writes: z.ZodOptional<z.ZodNullable<z.ZodRecord<z.ZodString, z.ZodUnknown>>>;
335
- parents: z.ZodOptional<z.ZodRecord<z.ZodString, z.ZodString>>;
336
- }, z.ZodUnknown, "strip">, z.objectInputType<{
337
- source: z.ZodOptional<z.ZodUnion<[z.ZodLiteral<"input">, z.ZodLiteral<"loop">, z.ZodLiteral<"update">, z.ZodString]>>;
338
- step: z.ZodOptional<z.ZodNumber>;
339
- writes: z.ZodOptional<z.ZodNullable<z.ZodRecord<z.ZodString, z.ZodUnknown>>>;
340
- parents: z.ZodOptional<z.ZodRecord<z.ZodString, z.ZodString>>;
341
- }, z.ZodUnknown, "strip">>>;
93
+ writes: z.ZodOptional<z.ZodNullable<z.ZodAny>>;
94
+ parents: z.ZodOptional<z.ZodAny>;
95
+ }, z.core.$catchall<z.ZodUnknown>>>;
342
96
  config: z.ZodOptional<z.ZodObject<{
343
- tags: z.ZodOptional<z.ZodArray<z.ZodString, "many">>;
344
- recursion_limit: z.ZodOptional<z.ZodNumber>;
345
- configurable: z.ZodOptional<z.ZodObject<{
346
- thread_id: z.ZodOptional<z.ZodString>;
347
- thread_ts: z.ZodOptional<z.ZodString>;
348
- }, "strip", z.ZodUnknown, z.objectOutputType<{
349
- thread_id: z.ZodOptional<z.ZodString>;
350
- thread_ts: z.ZodOptional<z.ZodString>;
351
- }, z.ZodUnknown, "strip">, z.objectInputType<{
352
- thread_id: z.ZodOptional<z.ZodString>;
353
- thread_ts: z.ZodOptional<z.ZodString>;
354
- }, z.ZodUnknown, "strip">>>;
355
- }, "strip", z.ZodUnknown, z.objectOutputType<{
356
- tags: z.ZodOptional<z.ZodArray<z.ZodString, "many">>;
357
- recursion_limit: z.ZodOptional<z.ZodNumber>;
358
- configurable: z.ZodOptional<z.ZodObject<{
359
- thread_id: z.ZodOptional<z.ZodString>;
360
- thread_ts: z.ZodOptional<z.ZodString>;
361
- }, "strip", z.ZodUnknown, z.objectOutputType<{
362
- thread_id: z.ZodOptional<z.ZodString>;
363
- thread_ts: z.ZodOptional<z.ZodString>;
364
- }, z.ZodUnknown, "strip">, z.objectInputType<{
365
- thread_id: z.ZodOptional<z.ZodString>;
366
- thread_ts: z.ZodOptional<z.ZodString>;
367
- }, z.ZodUnknown, "strip">>>;
368
- }, z.ZodUnknown, "strip">, z.objectInputType<{
369
- tags: z.ZodOptional<z.ZodArray<z.ZodString, "many">>;
97
+ tags: z.ZodOptional<z.ZodArray<z.ZodString>>;
370
98
  recursion_limit: z.ZodOptional<z.ZodNumber>;
371
99
  configurable: z.ZodOptional<z.ZodObject<{
372
100
  thread_id: z.ZodOptional<z.ZodString>;
373
101
  thread_ts: z.ZodOptional<z.ZodString>;
374
- }, "strip", z.ZodUnknown, z.objectOutputType<{
375
- thread_id: z.ZodOptional<z.ZodString>;
376
- thread_ts: z.ZodOptional<z.ZodString>;
377
- }, z.ZodUnknown, "strip">, z.objectInputType<{
378
- thread_id: z.ZodOptional<z.ZodString>;
379
- thread_ts: z.ZodOptional<z.ZodString>;
380
- }, z.ZodUnknown, "strip">>>;
381
- }, z.ZodUnknown, "strip">>>;
102
+ }, z.core.$catchall<z.ZodUnknown>>>;
103
+ }, z.core.$catchall<z.ZodUnknown>>>;
382
104
  webhook: z.ZodOptional<z.ZodString>;
383
- interrupt_before: z.ZodOptional<z.ZodUnion<[z.ZodLiteral<"*">, z.ZodArray<z.ZodString, "many">]>>;
384
- interrupt_after: z.ZodOptional<z.ZodUnion<[z.ZodLiteral<"*">, z.ZodArray<z.ZodString, "many">]>>;
385
- on_disconnect: z.ZodDefault<z.ZodOptional<z.ZodEnum<["cancel", "continue"]>>>;
386
- multitask_strategy: z.ZodOptional<z.ZodEnum<["reject", "rollback", "interrupt", "enqueue"]>>;
387
- stream_mode: z.ZodOptional<z.ZodArray<z.ZodEnum<["values", "messages", "messages-tuple", "updates", "events", "debug", "custom"]>, "many">>;
105
+ interrupt_before: z.ZodOptional<z.ZodUnion<readonly [z.ZodLiteral<"*">, z.ZodArray<z.ZodString>]>>;
106
+ interrupt_after: z.ZodOptional<z.ZodUnion<readonly [z.ZodLiteral<"*">, z.ZodArray<z.ZodString>]>>;
107
+ on_disconnect: z.ZodDefault<z.ZodOptional<z.ZodEnum<{
108
+ cancel: "cancel";
109
+ continue: "continue";
110
+ }>>>;
111
+ multitask_strategy: z.ZodOptional<z.ZodEnum<{
112
+ reject: "reject";
113
+ interrupt: "interrupt";
114
+ rollback: "rollback";
115
+ enqueue: "enqueue";
116
+ }>>;
117
+ stream_mode: z.ZodOptional<z.ZodArray<z.ZodEnum<{
118
+ values: "values";
119
+ messages: "messages";
120
+ updates: "updates";
121
+ events: "events";
122
+ debug: "debug";
123
+ custom: "custom";
124
+ "messages-tuple": "messages-tuple";
125
+ }>>>;
388
126
  stream_subgraphs: z.ZodOptional<z.ZodBoolean>;
389
127
  stream_resumable: z.ZodOptional<z.ZodBoolean>;
390
128
  after_seconds: z.ZodOptional<z.ZodNumber>;
391
- if_not_exists: z.ZodOptional<z.ZodEnum<["create", "reject"]>>;
392
- on_completion: z.ZodOptional<z.ZodEnum<["complete", "continue"]>>;
393
- feedback_keys: z.ZodOptional<z.ZodArray<z.ZodString, "many">>;
129
+ if_not_exists: z.ZodOptional<z.ZodEnum<{
130
+ reject: "reject";
131
+ create: "create";
132
+ }>>;
133
+ on_completion: z.ZodOptional<z.ZodEnum<{
134
+ continue: "continue";
135
+ complete: "complete";
136
+ }>>;
137
+ feedback_keys: z.ZodOptional<z.ZodArray<z.ZodString>>;
394
138
  langsmith_tracer: z.ZodOptional<z.ZodUnknown>;
395
- }, "strip", z.ZodTypeAny, {
396
- assistant_id: string;
397
- on_disconnect: "cancel" | "continue";
398
- checkpoint_id?: string | undefined;
399
- metadata?: z.objectOutputType<{
400
- source: z.ZodOptional<z.ZodUnion<[z.ZodLiteral<"input">, z.ZodLiteral<"loop">, z.ZodLiteral<"update">, z.ZodString]>>;
401
- step: z.ZodOptional<z.ZodNumber>;
402
- writes: z.ZodOptional<z.ZodNullable<z.ZodRecord<z.ZodString, z.ZodUnknown>>>;
403
- parents: z.ZodOptional<z.ZodRecord<z.ZodString, z.ZodString>>;
404
- }, z.ZodUnknown, "strip"> | undefined;
405
- input?: any;
406
- multitask_strategy?: "reject" | "interrupt" | "rollback" | "enqueue" | undefined;
407
- config?: z.objectOutputType<{
408
- tags: z.ZodOptional<z.ZodArray<z.ZodString, "many">>;
409
- recursion_limit: z.ZodOptional<z.ZodNumber>;
410
- configurable: z.ZodOptional<z.ZodObject<{
411
- thread_id: z.ZodOptional<z.ZodString>;
412
- thread_ts: z.ZodOptional<z.ZodString>;
413
- }, "strip", z.ZodUnknown, z.objectOutputType<{
414
- thread_id: z.ZodOptional<z.ZodString>;
415
- thread_ts: z.ZodOptional<z.ZodString>;
416
- }, z.ZodUnknown, "strip">, z.objectInputType<{
417
- thread_id: z.ZodOptional<z.ZodString>;
418
- thread_ts: z.ZodOptional<z.ZodString>;
419
- }, z.ZodUnknown, "strip">>>;
420
- }, z.ZodUnknown, "strip"> | undefined;
421
- command?: {
422
- resume?: unknown;
423
- update?: Record<string, unknown> | [string, unknown][] | null | undefined;
424
- goto?: string | string[] | {
425
- node: string;
426
- input?: unknown;
427
- } | {
428
- node: string;
429
- input?: unknown;
430
- }[] | undefined;
431
- } | undefined;
432
- webhook?: string | undefined;
433
- interrupt_before?: string[] | "*" | undefined;
434
- interrupt_after?: string[] | "*" | undefined;
435
- stream_mode?: ("values" | "messages" | "updates" | "events" | "debug" | "custom" | "messages-tuple")[] | undefined;
436
- stream_subgraphs?: boolean | undefined;
437
- stream_resumable?: boolean | undefined;
438
- after_seconds?: number | undefined;
439
- if_not_exists?: "reject" | "create" | undefined;
440
- on_completion?: "continue" | "complete" | undefined;
441
- feedback_keys?: string[] | undefined;
442
- langsmith_tracer?: unknown;
443
- }, {
444
- assistant_id: string;
445
- checkpoint_id?: string | undefined;
446
- metadata?: z.objectInputType<{
447
- source: z.ZodOptional<z.ZodUnion<[z.ZodLiteral<"input">, z.ZodLiteral<"loop">, z.ZodLiteral<"update">, z.ZodString]>>;
448
- step: z.ZodOptional<z.ZodNumber>;
449
- writes: z.ZodOptional<z.ZodNullable<z.ZodRecord<z.ZodString, z.ZodUnknown>>>;
450
- parents: z.ZodOptional<z.ZodRecord<z.ZodString, z.ZodString>>;
451
- }, z.ZodUnknown, "strip"> | undefined;
452
- input?: any;
453
- multitask_strategy?: "reject" | "interrupt" | "rollback" | "enqueue" | undefined;
454
- config?: z.objectInputType<{
455
- tags: z.ZodOptional<z.ZodArray<z.ZodString, "many">>;
456
- recursion_limit: z.ZodOptional<z.ZodNumber>;
457
- configurable: z.ZodOptional<z.ZodObject<{
458
- thread_id: z.ZodOptional<z.ZodString>;
459
- thread_ts: z.ZodOptional<z.ZodString>;
460
- }, "strip", z.ZodUnknown, z.objectOutputType<{
461
- thread_id: z.ZodOptional<z.ZodString>;
462
- thread_ts: z.ZodOptional<z.ZodString>;
463
- }, z.ZodUnknown, "strip">, z.objectInputType<{
464
- thread_id: z.ZodOptional<z.ZodString>;
465
- thread_ts: z.ZodOptional<z.ZodString>;
466
- }, z.ZodUnknown, "strip">>>;
467
- }, z.ZodUnknown, "strip"> | undefined;
468
- command?: {
469
- resume?: unknown;
470
- update?: Record<string, unknown> | [string, unknown][] | null | undefined;
471
- goto?: string | string[] | {
472
- node: string;
473
- input?: unknown;
474
- } | {
475
- node: string;
476
- input?: unknown;
477
- }[] | undefined;
478
- } | undefined;
479
- webhook?: string | undefined;
480
- interrupt_before?: string[] | "*" | undefined;
481
- interrupt_after?: string[] | "*" | undefined;
482
- on_disconnect?: "cancel" | "continue" | undefined;
483
- stream_mode?: ("values" | "messages" | "updates" | "events" | "debug" | "custom" | "messages-tuple")[] | undefined;
484
- stream_subgraphs?: boolean | undefined;
485
- stream_resumable?: boolean | undefined;
486
- after_seconds?: number | undefined;
487
- if_not_exists?: "reject" | "create" | undefined;
488
- on_completion?: "continue" | "complete" | undefined;
489
- feedback_keys?: string[] | undefined;
490
- langsmith_tracer?: unknown;
491
- }>;
139
+ }, z.core.$strip>;
492
140
  export declare const RunListQuerySchema: z.ZodObject<{
493
- limit: z.ZodOptional<z.ZodNumber>;
494
- offset: z.ZodOptional<z.ZodNumber>;
495
- status: z.ZodOptional<z.ZodEnum<["pending", "running", "error", "success", "timeout", "interrupted"]>>;
496
- }, "strip", z.ZodTypeAny, {
497
- status?: "pending" | "running" | "error" | "success" | "timeout" | "interrupted" | undefined;
498
- limit?: number | undefined;
499
- offset?: number | undefined;
500
- }, {
501
- status?: "pending" | "running" | "error" | "success" | "timeout" | "interrupted" | undefined;
502
- limit?: number | undefined;
503
- offset?: number | undefined;
504
- }>;
141
+ limit: z.ZodOptional<z.ZodCoercedNumber<unknown>>;
142
+ offset: z.ZodOptional<z.ZodCoercedNumber<unknown>>;
143
+ status: z.ZodOptional<z.ZodEnum<{
144
+ pending: "pending";
145
+ running: "running";
146
+ error: "error";
147
+ success: "success";
148
+ timeout: "timeout";
149
+ interrupted: "interrupted";
150
+ }>>;
151
+ }, z.core.$strip>;
505
152
  export declare const RunCancelQuerySchema: z.ZodObject<{
506
- wait: z.ZodDefault<z.ZodOptional<z.ZodBoolean>>;
507
- action: z.ZodDefault<z.ZodOptional<z.ZodEnum<["interrupt", "rollback"]>>>;
508
- }, "strip", z.ZodTypeAny, {
509
- wait: boolean;
510
- action: "interrupt" | "rollback";
511
- }, {
512
- wait?: boolean | undefined;
513
- action?: "interrupt" | "rollback" | undefined;
514
- }>;
153
+ wait: z.ZodDefault<z.ZodOptional<z.ZodCoercedBoolean<unknown>>>;
154
+ action: z.ZodDefault<z.ZodOptional<z.ZodEnum<{
155
+ interrupt: "interrupt";
156
+ rollback: "rollback";
157
+ }>>>;
158
+ }, z.core.$strip>;
515
159
  export declare const RunJoinStreamQuerySchema: z.ZodObject<{
516
- cancel_on_disconnect: z.ZodDefault<z.ZodOptional<z.ZodBoolean>>;
160
+ cancel_on_disconnect: z.ZodDefault<z.ZodOptional<z.ZodCoercedBoolean<unknown>>>;
517
161
  last_event_id: z.ZodOptional<z.ZodString>;
518
- stream_mode: z.ZodOptional<z.ZodEnum<["values", "messages", "messages-tuple", "updates", "events", "debug", "custom"]>>;
519
- }, "strip", z.ZodTypeAny, {
520
- cancel_on_disconnect: boolean;
521
- stream_mode?: "values" | "messages" | "updates" | "events" | "debug" | "custom" | "messages-tuple" | undefined;
522
- last_event_id?: string | undefined;
523
- }, {
524
- stream_mode?: "values" | "messages" | "updates" | "events" | "debug" | "custom" | "messages-tuple" | undefined;
525
- cancel_on_disconnect?: boolean | undefined;
526
- last_event_id?: string | undefined;
527
- }>;
162
+ stream_mode: z.ZodOptional<z.ZodEnum<{
163
+ values: "values";
164
+ messages: "messages";
165
+ updates: "updates";
166
+ events: "events";
167
+ debug: "debug";
168
+ custom: "custom";
169
+ "messages-tuple": "messages-tuple";
170
+ }>>;
171
+ }, z.core.$strip>;
528
172
  export declare const ThreadCreatePayloadSchema: z.ZodObject<{
529
173
  thread_id: z.ZodOptional<z.ZodString>;
530
174
  metadata: z.ZodOptional<z.ZodObject<{
531
- source: z.ZodOptional<z.ZodUnion<[z.ZodLiteral<"input">, z.ZodLiteral<"loop">, z.ZodLiteral<"update">, z.ZodString]>>;
532
- step: z.ZodOptional<z.ZodNumber>;
533
- writes: z.ZodOptional<z.ZodNullable<z.ZodRecord<z.ZodString, z.ZodUnknown>>>;
534
- parents: z.ZodOptional<z.ZodRecord<z.ZodString, z.ZodString>>;
535
- }, "strip", z.ZodUnknown, z.objectOutputType<{
536
- source: z.ZodOptional<z.ZodUnion<[z.ZodLiteral<"input">, z.ZodLiteral<"loop">, z.ZodLiteral<"update">, z.ZodString]>>;
537
- step: z.ZodOptional<z.ZodNumber>;
538
- writes: z.ZodOptional<z.ZodNullable<z.ZodRecord<z.ZodString, z.ZodUnknown>>>;
539
- parents: z.ZodOptional<z.ZodRecord<z.ZodString, z.ZodString>>;
540
- }, z.ZodUnknown, "strip">, z.objectInputType<{
541
- source: z.ZodOptional<z.ZodUnion<[z.ZodLiteral<"input">, z.ZodLiteral<"loop">, z.ZodLiteral<"update">, z.ZodString]>>;
542
- step: z.ZodOptional<z.ZodNumber>;
543
- writes: z.ZodOptional<z.ZodNullable<z.ZodRecord<z.ZodString, z.ZodUnknown>>>;
544
- parents: z.ZodOptional<z.ZodRecord<z.ZodString, z.ZodString>>;
545
- }, z.ZodUnknown, "strip">>>;
546
- if_exists: z.ZodOptional<z.ZodUnion<[z.ZodLiteral<"raise">, z.ZodLiteral<"do_nothing">]>>;
547
- }, "strip", z.ZodTypeAny, {
548
- thread_id?: string | undefined;
549
- metadata?: z.objectOutputType<{
550
- source: z.ZodOptional<z.ZodUnion<[z.ZodLiteral<"input">, z.ZodLiteral<"loop">, z.ZodLiteral<"update">, z.ZodString]>>;
175
+ source: z.ZodOptional<z.ZodUnion<readonly [z.ZodLiteral<"input">, z.ZodLiteral<"loop">, z.ZodLiteral<"update">, z.ZodString]>>;
551
176
  step: z.ZodOptional<z.ZodNumber>;
552
- writes: z.ZodOptional<z.ZodNullable<z.ZodRecord<z.ZodString, z.ZodUnknown>>>;
553
- parents: z.ZodOptional<z.ZodRecord<z.ZodString, z.ZodString>>;
554
- }, z.ZodUnknown, "strip"> | undefined;
555
- if_exists?: "raise" | "do_nothing" | undefined;
556
- }, {
557
- thread_id?: string | undefined;
558
- metadata?: z.objectInputType<{
559
- source: z.ZodOptional<z.ZodUnion<[z.ZodLiteral<"input">, z.ZodLiteral<"loop">, z.ZodLiteral<"update">, z.ZodString]>>;
560
- step: z.ZodOptional<z.ZodNumber>;
561
- writes: z.ZodOptional<z.ZodNullable<z.ZodRecord<z.ZodString, z.ZodUnknown>>>;
562
- parents: z.ZodOptional<z.ZodRecord<z.ZodString, z.ZodString>>;
563
- }, z.ZodUnknown, "strip"> | undefined;
564
- if_exists?: "raise" | "do_nothing" | undefined;
565
- }>;
177
+ writes: z.ZodOptional<z.ZodNullable<z.ZodAny>>;
178
+ parents: z.ZodOptional<z.ZodAny>;
179
+ }, z.core.$catchall<z.ZodUnknown>>>;
180
+ if_exists: z.ZodOptional<z.ZodUnion<readonly [z.ZodLiteral<"raise">, z.ZodLiteral<"do_nothing">]>>;
181
+ }, z.core.$strip>;
566
182
  export declare const ThreadSearchPayloadSchema: z.ZodObject<{
567
- metadata: z.ZodOptional<z.ZodRecord<z.ZodString, z.ZodUnknown>>;
568
- status: z.ZodOptional<z.ZodEnum<["idle", "busy", "interrupted", "error"]>>;
569
- values: z.ZodOptional<z.ZodRecord<z.ZodString, z.ZodUnknown>>;
183
+ metadata: z.ZodOptional<z.ZodObject<{
184
+ source: z.ZodOptional<z.ZodUnion<readonly [z.ZodLiteral<"input">, z.ZodLiteral<"loop">, z.ZodLiteral<"update">, z.ZodString]>>;
185
+ step: z.ZodOptional<z.ZodNumber>;
186
+ writes: z.ZodOptional<z.ZodNullable<z.ZodAny>>;
187
+ parents: z.ZodOptional<z.ZodAny>;
188
+ }, z.core.$catchall<z.ZodUnknown>>>;
189
+ status: z.ZodOptional<z.ZodEnum<{
190
+ error: "error";
191
+ interrupted: "interrupted";
192
+ idle: "idle";
193
+ busy: "busy";
194
+ }>>;
195
+ values: z.ZodOptional<z.ZodAny>;
570
196
  limit: z.ZodOptional<z.ZodNumber>;
571
197
  offset: z.ZodOptional<z.ZodNumber>;
572
- sort_by: z.ZodOptional<z.ZodEnum<["thread_id", "status", "created_at", "updated_at"]>>;
573
- sort_order: z.ZodOptional<z.ZodEnum<["asc", "desc"]>>;
574
- }, "strip", z.ZodTypeAny, {
575
- values?: Record<string, unknown> | undefined;
576
- status?: "error" | "interrupted" | "idle" | "busy" | undefined;
577
- metadata?: Record<string, unknown> | undefined;
578
- limit?: number | undefined;
579
- offset?: number | undefined;
580
- sort_by?: "created_at" | "updated_at" | "thread_id" | "status" | undefined;
581
- sort_order?: "asc" | "desc" | undefined;
582
- }, {
583
- values?: Record<string, unknown> | undefined;
584
- status?: "error" | "interrupted" | "idle" | "busy" | undefined;
585
- metadata?: Record<string, unknown> | undefined;
586
- limit?: number | undefined;
587
- offset?: number | undefined;
588
- sort_by?: "created_at" | "updated_at" | "thread_id" | "status" | undefined;
589
- sort_order?: "asc" | "desc" | undefined;
590
- }>;
198
+ sort_by: z.ZodOptional<z.ZodEnum<{
199
+ created_at: "created_at";
200
+ updated_at: "updated_at";
201
+ thread_id: "thread_id";
202
+ status: "status";
203
+ }>>;
204
+ sort_order: z.ZodOptional<z.ZodEnum<{
205
+ asc: "asc";
206
+ desc: "desc";
207
+ }>>;
208
+ }, z.core.$strip>;
591
209
  export declare const ThreadStateUpdate: z.ZodObject<{
592
- values: z.ZodOptional<z.ZodNullable<z.ZodUnion<[z.ZodRecord<z.ZodString, z.ZodUnknown>, z.ZodArray<z.ZodRecord<z.ZodString, z.ZodUnknown>, "many">]>>>;
593
- }, "strip", z.ZodTypeAny, {
594
- values?: Record<string, unknown> | Record<string, unknown>[] | null | undefined;
595
- }, {
596
- values?: Record<string, unknown> | Record<string, unknown>[] | null | undefined;
597
- }>;
210
+ values: z.ZodOptional<z.ZodNullable<z.ZodUnion<readonly [z.ZodRecord<z.ZodString, z.ZodUnknown>, z.ZodArray<z.ZodRecord<z.ZodString, z.ZodUnknown>>]>>>;
211
+ }, z.core.$strip>;
@@ -1,6 +1,6 @@
1
1
  import { NextResponse } from 'next/server';
2
2
  import { c as createEndpoint } from './createEndpoint-Bxzbc61h.js';
3
- import { a as AssistantGraphQuerySchema, d as RunListQuerySchema, c as RunJoinStreamQuerySchema, A as AssistantsSearchSchema, g as ThreadCreatePayloadSchema, h as ThreadSearchPayloadSchema, f as ThreadStateUpdate, R as RunStreamPayloadSchema, e as RunCancelQuerySchema } from './zod-DixWQt_u.js';
3
+ import { a as AssistantGraphQuerySchema, d as RunListQuerySchema, c as RunJoinStreamQuerySchema, A as AssistantsSearchSchema, g as ThreadCreatePayloadSchema, h as ThreadSearchPayloadSchema, f as ThreadStateUpdate, R as RunStreamPayloadSchema, e as RunCancelQuerySchema } from './zod-B6xyK6pu.js';
4
4
  import { s as serialiseAsDict } from './stream-CAZ9j0yn.js';
5
5
  import camelcaseKeys from 'camelcase-keys';
6
6
 
@@ -215,4 +215,4 @@ async function DELETE(req) {
215
215
  }
216
216
 
217
217
  export { DELETE, GET, POST };
218
- //# sourceMappingURL=router-Dg9I9CpI.js.map
218
+ //# sourceMappingURL=router-DOVN2of2.js.map
@@ -1 +1 @@
1
- {"version":3,"file":"router-Dg9I9CpI.js","sources":["../src/adapter/nextjs/endpoint.ts","../src/adapter/nextjs/router.ts"],"sourcesContent":["import { createEndpoint } from '../../createEndpoint.js';\nexport const client = createEndpoint();\n","/** @ts-ignore */\nimport { NextRequest, NextResponse } from 'next/server';\nimport { client } from './endpoint';\nimport {\n AssistantsSearchSchema,\n AssistantGraphQuerySchema,\n RunStreamPayloadSchema,\n RunListQuerySchema,\n RunCancelQuerySchema,\n RunJoinStreamQuerySchema,\n ThreadCreatePayloadSchema,\n ThreadSearchPayloadSchema,\n ThreadStateUpdate,\n} from '../zod';\nimport { serialiseAsDict } from '../../graph/stream';\nimport camelcaseKeys from 'camelcase-keys';\n\n// Next.js App Router 的 SSE 响应实现\nasync function sseResponse(generator: AsyncGenerator<{ event: string; data: unknown }>): Promise<Response> {\n const encoder = new TextEncoder();\n const stream = new ReadableStream({\n async start(controller) {\n try {\n for await (const { event, data } of generator) {\n const line = `event: ${event}\\n` + `data: ${serialiseAsDict(data, 0)}\\n\\n`;\n controller.enqueue(encoder.encode(line));\n }\n } catch (err) {\n // ignore\n } finally {\n controller.close();\n }\n },\n });\n return new Response(stream, {\n headers: {\n 'Content-Type': 'text/event-stream; charset=utf-8',\n 'Cache-Control': 'no-cache, no-transform',\n Connection: 'keep-alive',\n },\n });\n}\n\n// 统一路由处理器\nexport async function GET(req: NextRequest) {\n const url = new URL(req.url);\n const pathname = url.pathname;\n\n // Assistants routes\n if (pathname.match(/\\/assistants\\/[^/]+\\/graph$/)) {\n const match = pathname.match(/\\/assistants\\/([^/]+)\\/graph$/);\n if (match) {\n const assistant_id = match[1];\n const xrayParam = url.searchParams.get('xray') ?? undefined;\n const queryParams = { xray: xrayParam };\n const { xray } = AssistantGraphQuerySchema.parse(queryParams);\n const data = await client.assistants.getGraph(assistant_id, {\n xray: xray !== undefined ? xray === 'true' : undefined,\n });\n return NextResponse.json(data);\n }\n }\n\n // Threads routes\n if (pathname.match(/\\/threads\\/[0-9a-fA-F-]{36}$/)) {\n const match = pathname.match(/\\/threads\\/([0-9a-fA-F-]{36})$/);\n if (match) {\n const thread_id = match[1];\n const data = await client.threads.get(thread_id);\n return NextResponse.json(data);\n }\n }\n\n // Runs routes\n if (pathname.match(/\\/threads\\/[0-9a-fA-F-]{36}\\/runs$/)) {\n const match = pathname.match(/\\/threads\\/([0-9a-fA-F-]{36})\\/runs$/);\n if (match) {\n const thread_id = match[1];\n const limit = url.searchParams.get('limit') ?? undefined;\n const offset = url.searchParams.get('offset') ?? undefined;\n const status = url.searchParams.get('status') ?? undefined;\n const queryParams = { limit, offset, status };\n const {\n limit: parsedLimit,\n offset: parsedOffset,\n status: parsedStatus,\n } = RunListQuerySchema.parse(queryParams);\n const runs = await client.runs.list(thread_id, {\n limit: parsedLimit,\n offset: parsedOffset,\n status: parsedStatus,\n });\n return Response.json(runs);\n }\n }\n\n // Runs join stream route\n if (pathname.match(/\\/threads\\/[0-9a-fA-F-]{36}\\/runs\\/[0-9a-fA-F-]{36}\\/stream$/)) {\n const match = pathname.match(/\\/threads\\/([0-9a-fA-F-]{36})\\/runs\\/([0-9a-fA-F-]{36})\\/stream$/);\n if (match) {\n const thread_id = match[1];\n const run_id = match[2];\n\n // 解析查询参数\n const cancel_on_disconnect = url.searchParams.get('cancel_on_disconnect') ?? undefined;\n const last_event_id = url.searchParams.get('last_event_id') ?? undefined;\n const stream_mode = url.searchParams.get('stream_mode') ?? undefined;\n\n const queryParams = {\n cancel_on_disconnect: cancel_on_disconnect ? cancel_on_disconnect === 'true' : false,\n last_event_id,\n stream_mode,\n };\n const {\n cancel_on_disconnect: parsedCancelOnDisconnect,\n last_event_id: parsedLastEventId,\n stream_mode: parsedStreamMode,\n } = RunJoinStreamQuerySchema.parse(queryParams);\n\n // 创建 AbortController 用于处理取消信号\n const controller = new AbortController();\n\n // 如果需要断开连接时取消,则监听请求信号\n if (parsedCancelOnDisconnect && req.signal) {\n req.signal.addEventListener('abort', () => {\n controller.abort('Client disconnected');\n });\n }\n\n // 创建带 ID 的生成器\n async function* joinStreamGenerator() {\n try {\n for await (const { event, data, id } of client.runs.joinStream(thread_id, run_id, {\n signal: controller.signal,\n cancelOnDisconnect: parsedCancelOnDisconnect,\n lastEventId: parsedLastEventId,\n streamMode: parsedStreamMode ? [parsedStreamMode] : undefined,\n })) {\n yield { event: event as unknown as string, data, id };\n }\n } catch (error) {\n // 记录错误但不抛出,避免中断流\n console.error('Join stream error:', error);\n }\n }\n\n return sseResponse(joinStreamGenerator());\n }\n }\n\n return new NextResponse('Not Found', { status: 404 });\n}\n\nexport async function POST(req: NextRequest) {\n const url = new URL(req.url);\n const pathname = url.pathname;\n\n // Assistants routes\n if (pathname.endsWith('/assistants/search')) {\n const body = await req.json();\n const payload = AssistantsSearchSchema.parse(body);\n const data = await client.assistants.search({\n graphId: payload.graph_id,\n metadata: payload.metadata,\n limit: payload.limit,\n offset: payload.offset,\n });\n return NextResponse.json(data, {\n headers: { 'X-Pagination-Total': String(data.length) },\n });\n }\n\n // Threads routes\n if (pathname.endsWith('/threads')) {\n const body = await req.json();\n const payload = ThreadCreatePayloadSchema.parse(body);\n const thread = await client.threads.create(camelcaseKeys(payload));\n return NextResponse.json(thread);\n }\n\n if (pathname.endsWith('/threads/search')) {\n const body = await req.json();\n const payload = ThreadSearchPayloadSchema.parse(body);\n const result = await client.threads.search(camelcaseKeys(payload));\n return NextResponse.json(result, {\n headers: { 'X-Pagination-Total': String(result.length) },\n });\n }\n\n // Threads state update\n if (pathname.match(/\\/threads\\/[0-9a-fA-F-]{36}\\/state$/)) {\n const match = pathname.match(/\\/threads\\/([0-9a-fA-F-]{36})\\/state$/);\n if (match) {\n const thread_id = match[1];\n const body = await req.json();\n const payload = ThreadStateUpdate.parse(body);\n const result = await client.threads.updateState(thread_id, camelcaseKeys(payload));\n return NextResponse.json(result);\n }\n }\n\n // Runs routes - stream\n if (pathname.match(/\\/threads\\/[0-9a-fA-F-]{36}\\/runs\\/stream$/)) {\n const match = pathname.match(/\\/threads\\/([0-9a-fA-F-]{36})\\/runs\\/stream$/);\n if (match) {\n const thread_id = match[1];\n const body = await req.json();\n const payload = RunStreamPayloadSchema.parse(body);\n\n // Extract custom context from request headers\n const langgraphContextHeader = req.headers.get('x-langgraph-context');\n if (langgraphContextHeader) {\n const langgraphContext = JSON.parse(decodeURIComponent(langgraphContextHeader));\n payload.config = payload.config || {};\n payload.config.configurable = payload.config.configurable || {};\n Object.assign(payload.config.configurable, langgraphContext);\n }\n const generator = client.runs.stream(\n thread_id,\n payload.assistant_id as string,\n camelcaseKeys(payload) as any,\n );\n return sseResponse(generator as any);\n }\n }\n\n // Runs routes - cancel\n if (pathname.match(/\\/threads\\/[0-9a-fA-F-]{36}\\/runs\\/[0-9a-fA-F-]{36}\\/cancel$/)) {\n const match = pathname.match(/\\/threads\\/([0-9a-fA-F-]{36})\\/runs\\/([0-9a-fA-F-]{36})\\/cancel$/);\n if (match) {\n const thread_id = match[1];\n const run_id = match[2];\n const waitParam = url.searchParams.get('wait') ?? undefined;\n const actionParam = url.searchParams.get('action') ?? undefined;\n const queryParams = {\n wait: waitParam ? waitParam === 'true' : false,\n action: actionParam ?? 'interrupt',\n };\n const { wait, action } = RunCancelQuerySchema.parse(queryParams);\n const promise = client.runs.cancel(thread_id, run_id, wait, action);\n if (wait) await promise;\n return new Response(null, { status: wait ? 204 : 202 });\n }\n }\n\n return new NextResponse('Not Found', { status: 404 });\n}\n\nexport async function DELETE(req: NextRequest) {\n const url = new URL(req.url);\n const pathname = url.pathname;\n\n // Threads routes\n if (pathname.match(/\\/threads\\/[0-9a-fA-F-]{36}$/)) {\n const match = pathname.match(/\\/threads\\/([0-9a-fA-F-]{36})$/);\n if (match) {\n const thread_id = match[1];\n await client.threads.delete(thread_id);\n return new NextResponse(null, { status: 204 });\n }\n }\n\n return new NextResponse('Not Found', { status: 404 });\n}\n"],"names":[],"mappings":";;;;;;AACO,MAAM,SAAS,cAAA,EAAe;;ACiBrC,eAAe,YAAY,SAAA,EAAgF;AACvG,EAAA,MAAM,OAAA,GAAU,IAAI,WAAA,EAAY;AAChC,EAAA,MAAM,MAAA,GAAS,IAAI,cAAA,CAAe;AAAA,IAC9B,MAAM,MAAM,UAAA,EAAY;AACpB,MAAA,IAAI;AACA,QAAA,WAAA,MAAiB,EAAE,KAAA,EAAO,IAAA,EAAK,IAAK,SAAA,EAAW;AAC3C,UAAA,MAAM,IAAA,GAAO,UAAU,KAAK;AAAA,MAAA,EAAgB,eAAA,CAAgB,IAAA,EAAM,CAAC,CAAC;;AAAA,CAAA;AACpE,UAAA,UAAA,CAAW,OAAA,CAAQ,OAAA,CAAQ,MAAA,CAAO,IAAI,CAAC,CAAA;AAAA,QAC3C;AAAA,MACJ,SAAS,GAAA,EAAK;AAAA,MAEd,CAAA,SAAE;AACE,QAAA,UAAA,CAAW,KAAA,EAAM;AAAA,MACrB;AAAA,IACJ;AAAA,GACH,CAAA;AACD,EAAA,OAAO,IAAI,SAAS,MAAA,EAAQ;AAAA,IACxB,OAAA,EAAS;AAAA,MACL,cAAA,EAAgB,kCAAA;AAAA,MAChB,eAAA,EAAiB,wBAAA;AAAA,MACjB,UAAA,EAAY;AAAA;AAChB,GACH,CAAA;AACL;AAGA,eAAsB,IAAI,GAAA,EAAkB;AACxC,EAAA,MAAM,GAAA,GAAM,IAAI,GAAA,CAAI,GAAA,CAAI,GAAG,CAAA;AAC3B,EAAA,MAAM,WAAW,GAAA,CAAI,QAAA;AAGrB,EAAA,IAAI,QAAA,CAAS,KAAA,CAAM,6BAA6B,CAAA,EAAG;AAC/C,IAAA,MAAM,KAAA,GAAQ,QAAA,CAAS,KAAA,CAAM,+BAA+B,CAAA;AAC5D,IAAA,IAAI,KAAA,EAAO;AACP,MAAA,MAAM,YAAA,GAAe,MAAM,CAAC,CAAA;AAC5B,MAAA,MAAM,SAAA,GAAY,GAAA,CAAI,YAAA,CAAa,GAAA,CAAI,MAAM,CAAA,IAAK,MAAA;AAClD,MAAA,MAAM,WAAA,GAAc,EAAE,IAAA,EAAM,SAAA,EAAU;AACtC,MAAA,MAAM,EAAE,IAAA,EAAK,GAAI,yBAAA,CAA0B,MAAM,WAAW,CAAA;AAC5D,MAAA,MAAM,IAAA,GAAO,MAAM,MAAA,CAAO,UAAA,CAAW,SAAS,YAAA,EAAc;AAAA,QACxD,IAAA,EAAM,IAAA,KAAS,MAAA,GAAY,IAAA,KAAS,MAAA,GAAS;AAAA,OAChD,CAAA;AACD,MAAA,OAAO,YAAA,CAAa,KAAK,IAAI,CAAA;AAAA,IACjC;AAAA,EACJ;AAGA,EAAA,IAAI,QAAA,CAAS,KAAA,CAAM,8BAA8B,CAAA,EAAG;AAChD,IAAA,MAAM,KAAA,GAAQ,QAAA,CAAS,KAAA,CAAM,gCAAgC,CAAA;AAC7D,IAAA,IAAI,KAAA,EAAO;AACP,MAAA,MAAM,SAAA,GAAY,MAAM,CAAC,CAAA;AACzB,MAAA,MAAM,IAAA,GAAO,MAAM,MAAA,CAAO,OAAA,CAAQ,IAAI,SAAS,CAAA;AAC/C,MAAA,OAAO,YAAA,CAAa,KAAK,IAAI,CAAA;AAAA,IACjC;AAAA,EACJ;AAGA,EAAA,IAAI,QAAA,CAAS,KAAA,CAAM,oCAAoC,CAAA,EAAG;AACtD,IAAA,MAAM,KAAA,GAAQ,QAAA,CAAS,KAAA,CAAM,sCAAsC,CAAA;AACnE,IAAA,IAAI,KAAA,EAAO;AACP,MAAA,MAAM,SAAA,GAAY,MAAM,CAAC,CAAA;AACzB,MAAA,MAAM,KAAA,GAAQ,GAAA,CAAI,YAAA,CAAa,GAAA,CAAI,OAAO,CAAA,IAAK,MAAA;AAC/C,MAAA,MAAM,MAAA,GAAS,GAAA,CAAI,YAAA,CAAa,GAAA,CAAI,QAAQ,CAAA,IAAK,MAAA;AACjD,MAAA,MAAM,MAAA,GAAS,GAAA,CAAI,YAAA,CAAa,GAAA,CAAI,QAAQ,CAAA,IAAK,MAAA;AACjD,MAAA,MAAM,WAAA,GAAc,EAAE,KAAA,EAAO,MAAA,EAAQ,MAAA,EAAO;AAC5C,MAAA,MAAM;AAAA,QACF,KAAA,EAAO,WAAA;AAAA,QACP,MAAA,EAAQ,YAAA;AAAA,QACR,MAAA,EAAQ;AAAA,OACZ,GAAI,kBAAA,CAAmB,KAAA,CAAM,WAAW,CAAA;AACxC,MAAA,MAAM,IAAA,GAAO,MAAM,MAAA,CAAO,IAAA,CAAK,KAAK,SAAA,EAAW;AAAA,QAC3C,KAAA,EAAO,WAAA;AAAA,QACP,MAAA,EAAQ,YAAA;AAAA,QACR,MAAA,EAAQ;AAAA,OACX,CAAA;AACD,MAAA,OAAO,QAAA,CAAS,KAAK,IAAI,CAAA;AAAA,IAC7B;AAAA,EACJ;AAGA,EAAA,IAAI,QAAA,CAAS,KAAA,CAAM,8DAA8D,CAAA,EAAG;AAChF,IAAA,MAAM,KAAA,GAAQ,QAAA,CAAS,KAAA,CAAM,kEAAkE,CAAA;AAC/F,IAAA,IAAI,KAAA,EAAO;AACP,MAAA,MAAM,SAAA,GAAY,MAAM,CAAC,CAAA;AACzB,MAAA,MAAM,MAAA,GAAS,MAAM,CAAC,CAAA;AAGtB,MAAA,MAAM,oBAAA,GAAuB,GAAA,CAAI,YAAA,CAAa,GAAA,CAAI,sBAAsB,CAAA,IAAK,MAAA;AAC7E,MAAA,MAAM,aAAA,GAAgB,GAAA,CAAI,YAAA,CAAa,GAAA,CAAI,eAAe,CAAA,IAAK,MAAA;AAC/D,MAAA,MAAM,WAAA,GAAc,GAAA,CAAI,YAAA,CAAa,GAAA,CAAI,aAAa,CAAA,IAAK,MAAA;AAE3D,MAAA,MAAM,WAAA,GAAc;AAAA,QAChB,oBAAA,EAAsB,oBAAA,GAAuB,oBAAA,KAAyB,MAAA,GAAS,KAAA;AAAA,QAC/E,aAAA;AAAA,QACA;AAAA,OACJ;AACA,MAAA,MAAM;AAAA,QACF,oBAAA,EAAsB,wBAAA;AAAA,QACtB,aAAA,EAAe,iBAAA;AAAA,QACf,WAAA,EAAa;AAAA,OACjB,GAAI,wBAAA,CAAyB,KAAA,CAAM,WAAW,CAAA;AAG9C,MAAA,MAAM,UAAA,GAAa,IAAI,eAAA,EAAgB;AAGvC,MAAA,IAAI,wBAAA,IAA4B,IAAI,MAAA,EAAQ;AACxC,QAAA,GAAA,CAAI,MAAA,CAAO,gBAAA,CAAiB,OAAA,EAAS,MAAM;AACvC,UAAA,UAAA,CAAW,MAAM,qBAAqB,CAAA;AAAA,QAC1C,CAAC,CAAA;AAAA,MACL;AAGA,MAAA,gBAAgB,mBAAA,GAAsB;AAClC,QAAA,IAAI;AACA,UAAA,WAAA,MAAiB,EAAE,OAAO,IAAA,EAAM,EAAA,MAAQ,MAAA,CAAO,IAAA,CAAK,UAAA,CAAW,SAAA,EAAW,MAAA,EAAQ;AAAA,YAC9E,QAAQ,UAAA,CAAW,MAAA;AAAA,YACnB,kBAAA,EAAoB,wBAAA;AAAA,YACpB,WAAA,EAAa,iBAAA;AAAA,YACb,UAAA,EAAY,gBAAA,GAAmB,CAAC,gBAAgB,CAAA,GAAI,KAAA;AAAA,WACvD,CAAA,EAAG;AACA,YAAA,MAAM,EAAE,KAAA,EAAmC,IAAA,EAAM,EAAA,EAAG;AAAA,UACxD;AAAA,QACJ,SAAS,KAAA,EAAO;AAEZ,UAAA,OAAA,CAAQ,KAAA,CAAM,sBAAsB,KAAK,CAAA;AAAA,QAC7C;AAAA,MACJ;AAEA,MAAA,OAAO,WAAA,CAAY,qBAAqB,CAAA;AAAA,IAC5C;AAAA,EACJ;AAEA,EAAA,OAAO,IAAI,YAAA,CAAa,WAAA,EAAa,EAAE,MAAA,EAAQ,KAAK,CAAA;AACxD;AAEA,eAAsB,KAAK,GAAA,EAAkB;AACzC,EAAA,MAAM,GAAA,GAAM,IAAI,GAAA,CAAI,GAAA,CAAI,GAAG,CAAA;AAC3B,EAAA,MAAM,WAAW,GAAA,CAAI,QAAA;AAGrB,EAAA,IAAI,QAAA,CAAS,QAAA,CAAS,oBAAoB,CAAA,EAAG;AACzC,IAAA,MAAM,IAAA,GAAO,MAAM,GAAA,CAAI,IAAA,EAAK;AAC5B,IAAA,MAAM,OAAA,GAAU,sBAAA,CAAuB,KAAA,CAAM,IAAI,CAAA;AACjD,IAAA,MAAM,IAAA,GAAO,MAAM,MAAA,CAAO,UAAA,CAAW,MAAA,CAAO;AAAA,MACxC,SAAS,OAAA,CAAQ,QAAA;AAAA,MACjB,UAAU,OAAA,CAAQ,QAAA;AAAA,MAClB,OAAO,OAAA,CAAQ,KAAA;AAAA,MACf,QAAQ,OAAA,CAAQ;AAAA,KACnB,CAAA;AACD,IAAA,OAAO,YAAA,CAAa,KAAK,IAAA,EAAM;AAAA,MAC3B,SAAS,EAAE,oBAAA,EAAsB,MAAA,CAAO,IAAA,CAAK,MAAM,CAAA;AAAE,KACxD,CAAA;AAAA,EACL;AAGA,EAAA,IAAI,QAAA,CAAS,QAAA,CAAS,UAAU,CAAA,EAAG;AAC/B,IAAA,MAAM,IAAA,GAAO,MAAM,GAAA,CAAI,IAAA,EAAK;AAC5B,IAAA,MAAM,OAAA,GAAU,yBAAA,CAA0B,KAAA,CAAM,IAAI,CAAA;AACpD,IAAA,MAAM,SAAS,MAAM,MAAA,CAAO,QAAQ,MAAA,CAAO,aAAA,CAAc,OAAO,CAAC,CAAA;AACjE,IAAA,OAAO,YAAA,CAAa,KAAK,MAAM,CAAA;AAAA,EACnC;AAEA,EAAA,IAAI,QAAA,CAAS,QAAA,CAAS,iBAAiB,CAAA,EAAG;AACtC,IAAA,MAAM,IAAA,GAAO,MAAM,GAAA,CAAI,IAAA,EAAK;AAC5B,IAAA,MAAM,OAAA,GAAU,yBAAA,CAA0B,KAAA,CAAM,IAAI,CAAA;AACpD,IAAA,MAAM,SAAS,MAAM,MAAA,CAAO,QAAQ,MAAA,CAAO,aAAA,CAAc,OAAO,CAAC,CAAA;AACjE,IAAA,OAAO,YAAA,CAAa,KAAK,MAAA,EAAQ;AAAA,MAC7B,SAAS,EAAE,oBAAA,EAAsB,MAAA,CAAO,MAAA,CAAO,MAAM,CAAA;AAAE,KAC1D,CAAA;AAAA,EACL;AAGA,EAAA,IAAI,QAAA,CAAS,KAAA,CAAM,qCAAqC,CAAA,EAAG;AACvD,IAAA,MAAM,KAAA,GAAQ,QAAA,CAAS,KAAA,CAAM,uCAAuC,CAAA;AACpE,IAAA,IAAI,KAAA,EAAO;AACP,MAAA,MAAM,SAAA,GAAY,MAAM,CAAC,CAAA;AACzB,MAAA,MAAM,IAAA,GAAO,MAAM,GAAA,CAAI,IAAA,EAAK;AAC5B,MAAA,MAAM,OAAA,GAAU,iBAAA,CAAkB,KAAA,CAAM,IAAI,CAAA;AAC5C,MAAA,MAAM,MAAA,GAAS,MAAM,MAAA,CAAO,OAAA,CAAQ,YAAY,SAAA,EAAW,aAAA,CAAc,OAAO,CAAC,CAAA;AACjF,MAAA,OAAO,YAAA,CAAa,KAAK,MAAM,CAAA;AAAA,IACnC;AAAA,EACJ;AAGA,EAAA,IAAI,QAAA,CAAS,KAAA,CAAM,4CAA4C,CAAA,EAAG;AAC9D,IAAA,MAAM,KAAA,GAAQ,QAAA,CAAS,KAAA,CAAM,8CAA8C,CAAA;AAC3E,IAAA,IAAI,KAAA,EAAO;AACP,MAAA,MAAM,SAAA,GAAY,MAAM,CAAC,CAAA;AACzB,MAAA,MAAM,IAAA,GAAO,MAAM,GAAA,CAAI,IAAA,EAAK;AAC5B,MAAA,MAAM,OAAA,GAAU,sBAAA,CAAuB,KAAA,CAAM,IAAI,CAAA;AAGjD,MAAA,MAAM,sBAAA,GAAyB,GAAA,CAAI,OAAA,CAAQ,GAAA,CAAI,qBAAqB,CAAA;AACpE,MAAA,IAAI,sBAAA,EAAwB;AACxB,QAAA,MAAM,gBAAA,GAAmB,IAAA,CAAK,KAAA,CAAM,kBAAA,CAAmB,sBAAsB,CAAC,CAAA;AAC9E,QAAA,OAAA,CAAQ,MAAA,GAAS,OAAA,CAAQ,MAAA,IAAU,EAAC;AACpC,QAAA,OAAA,CAAQ,MAAA,CAAO,YAAA,GAAe,OAAA,CAAQ,MAAA,CAAO,gBAAgB,EAAC;AAC9D,QAAA,MAAA,CAAO,MAAA,CAAO,OAAA,CAAQ,MAAA,CAAO,YAAA,EAAc,gBAAgB,CAAA;AAAA,MAC/D;AACA,MAAA,MAAM,SAAA,GAAY,OAAO,IAAA,CAAK,MAAA;AAAA,QAC1B,SAAA;AAAA,QACA,OAAA,CAAQ,YAAA;AAAA,QACR,cAAc,OAAO;AAAA,OACzB;AACA,MAAA,OAAO,YAAY,SAAgB,CAAA;AAAA,IACvC;AAAA,EACJ;AAGA,EAAA,IAAI,QAAA,CAAS,KAAA,CAAM,8DAA8D,CAAA,EAAG;AAChF,IAAA,MAAM,KAAA,GAAQ,QAAA,CAAS,KAAA,CAAM,kEAAkE,CAAA;AAC/F,IAAA,IAAI,KAAA,EAAO;AACP,MAAA,MAAM,SAAA,GAAY,MAAM,CAAC,CAAA;AACzB,MAAA,MAAM,MAAA,GAAS,MAAM,CAAC,CAAA;AACtB,MAAA,MAAM,SAAA,GAAY,GAAA,CAAI,YAAA,CAAa,GAAA,CAAI,MAAM,CAAA,IAAK,MAAA;AAClD,MAAA,MAAM,WAAA,GAAc,GAAA,CAAI,YAAA,CAAa,GAAA,CAAI,QAAQ,CAAA,IAAK,MAAA;AACtD,MAAA,MAAM,WAAA,GAAc;AAAA,QAChB,IAAA,EAAM,SAAA,GAAY,SAAA,KAAc,MAAA,GAAS,KAAA;AAAA,QACzC,QAAQ,WAAA,IAAe;AAAA,OAC3B;AACA,MAAA,MAAM,EAAE,IAAA,EAAM,MAAA,EAAO,GAAI,oBAAA,CAAqB,MAAM,WAAW,CAAA;AAC/D,MAAA,MAAM,UAAU,MAAA,CAAO,IAAA,CAAK,OAAO,SAAA,EAAW,MAAA,EAAQ,MAAM,MAAM,CAAA;AAClE,MAAA,IAAI,MAAM,MAAM,OAAA;AAChB,MAAA,OAAO,IAAI,SAAS,IAAA,EAAM,EAAE,QAAQ,IAAA,GAAO,GAAA,GAAM,KAAK,CAAA;AAAA,IAC1D;AAAA,EACJ;AAEA,EAAA,OAAO,IAAI,YAAA,CAAa,WAAA,EAAa,EAAE,MAAA,EAAQ,KAAK,CAAA;AACxD;AAEA,eAAsB,OAAO,GAAA,EAAkB;AAC3C,EAAA,MAAM,GAAA,GAAM,IAAI,GAAA,CAAI,GAAA,CAAI,GAAG,CAAA;AAC3B,EAAA,MAAM,WAAW,GAAA,CAAI,QAAA;AAGrB,EAAA,IAAI,QAAA,CAAS,KAAA,CAAM,8BAA8B,CAAA,EAAG;AAChD,IAAA,MAAM,KAAA,GAAQ,QAAA,CAAS,KAAA,CAAM,gCAAgC,CAAA;AAC7D,IAAA,IAAI,KAAA,EAAO;AACP,MAAA,MAAM,SAAA,GAAY,MAAM,CAAC,CAAA;AACzB,MAAA,MAAM,MAAA,CAAO,OAAA,CAAQ,MAAA,CAAO,SAAS,CAAA;AACrC,MAAA,OAAO,IAAI,YAAA,CAAa,IAAA,EAAM,EAAE,MAAA,EAAQ,KAAK,CAAA;AAAA,IACjD;AAAA,EACJ;AAEA,EAAA,OAAO,IAAI,YAAA,CAAa,WAAA,EAAa,EAAE,MAAA,EAAQ,KAAK,CAAA;AACxD;;;;"}
1
+ {"version":3,"file":"router-DOVN2of2.js","sources":["../src/adapter/nextjs/endpoint.ts","../src/adapter/nextjs/router.ts"],"sourcesContent":["import { createEndpoint } from '../../createEndpoint.js';\nexport const client = createEndpoint();\n","/** @ts-ignore */\nimport { NextRequest, NextResponse } from 'next/server';\nimport { client } from './endpoint';\nimport {\n AssistantsSearchSchema,\n AssistantGraphQuerySchema,\n RunStreamPayloadSchema,\n RunListQuerySchema,\n RunCancelQuerySchema,\n RunJoinStreamQuerySchema,\n ThreadCreatePayloadSchema,\n ThreadSearchPayloadSchema,\n ThreadStateUpdate,\n} from '../zod';\nimport { serialiseAsDict } from '../../graph/stream';\nimport camelcaseKeys from 'camelcase-keys';\n\n// Next.js App Router 的 SSE 响应实现\nasync function sseResponse(generator: AsyncGenerator<{ event: string; data: unknown }>): Promise<Response> {\n const encoder = new TextEncoder();\n const stream = new ReadableStream({\n async start(controller) {\n try {\n for await (const { event, data } of generator) {\n const line = `event: ${event}\\n` + `data: ${serialiseAsDict(data, 0)}\\n\\n`;\n controller.enqueue(encoder.encode(line));\n }\n } catch (err) {\n // ignore\n } finally {\n controller.close();\n }\n },\n });\n return new Response(stream, {\n headers: {\n 'Content-Type': 'text/event-stream; charset=utf-8',\n 'Cache-Control': 'no-cache, no-transform',\n Connection: 'keep-alive',\n },\n });\n}\n\n// 统一路由处理器\nexport async function GET(req: NextRequest) {\n const url = new URL(req.url);\n const pathname = url.pathname;\n\n // Assistants routes\n if (pathname.match(/\\/assistants\\/[^/]+\\/graph$/)) {\n const match = pathname.match(/\\/assistants\\/([^/]+)\\/graph$/);\n if (match) {\n const assistant_id = match[1];\n const xrayParam = url.searchParams.get('xray') ?? undefined;\n const queryParams = { xray: xrayParam };\n const { xray } = AssistantGraphQuerySchema.parse(queryParams);\n const data = await client.assistants.getGraph(assistant_id, {\n xray: xray !== undefined ? xray === 'true' : undefined,\n });\n return NextResponse.json(data);\n }\n }\n\n // Threads routes\n if (pathname.match(/\\/threads\\/[0-9a-fA-F-]{36}$/)) {\n const match = pathname.match(/\\/threads\\/([0-9a-fA-F-]{36})$/);\n if (match) {\n const thread_id = match[1];\n const data = await client.threads.get(thread_id);\n return NextResponse.json(data);\n }\n }\n\n // Runs routes\n if (pathname.match(/\\/threads\\/[0-9a-fA-F-]{36}\\/runs$/)) {\n const match = pathname.match(/\\/threads\\/([0-9a-fA-F-]{36})\\/runs$/);\n if (match) {\n const thread_id = match[1];\n const limit = url.searchParams.get('limit') ?? undefined;\n const offset = url.searchParams.get('offset') ?? undefined;\n const status = url.searchParams.get('status') ?? undefined;\n const queryParams = { limit, offset, status };\n const {\n limit: parsedLimit,\n offset: parsedOffset,\n status: parsedStatus,\n } = RunListQuerySchema.parse(queryParams);\n const runs = await client.runs.list(thread_id, {\n limit: parsedLimit,\n offset: parsedOffset,\n status: parsedStatus,\n });\n return Response.json(runs);\n }\n }\n\n // Runs join stream route\n if (pathname.match(/\\/threads\\/[0-9a-fA-F-]{36}\\/runs\\/[0-9a-fA-F-]{36}\\/stream$/)) {\n const match = pathname.match(/\\/threads\\/([0-9a-fA-F-]{36})\\/runs\\/([0-9a-fA-F-]{36})\\/stream$/);\n if (match) {\n const thread_id = match[1];\n const run_id = match[2];\n\n // 解析查询参数\n const cancel_on_disconnect = url.searchParams.get('cancel_on_disconnect') ?? undefined;\n const last_event_id = url.searchParams.get('last_event_id') ?? undefined;\n const stream_mode = url.searchParams.get('stream_mode') ?? undefined;\n\n const queryParams = {\n cancel_on_disconnect: cancel_on_disconnect ? cancel_on_disconnect === 'true' : false,\n last_event_id,\n stream_mode,\n };\n const {\n cancel_on_disconnect: parsedCancelOnDisconnect,\n last_event_id: parsedLastEventId,\n stream_mode: parsedStreamMode,\n } = RunJoinStreamQuerySchema.parse(queryParams);\n\n // 创建 AbortController 用于处理取消信号\n const controller = new AbortController();\n\n // 如果需要断开连接时取消,则监听请求信号\n if (parsedCancelOnDisconnect && req.signal) {\n req.signal.addEventListener('abort', () => {\n controller.abort('Client disconnected');\n });\n }\n\n // 创建带 ID 的生成器\n async function* joinStreamGenerator() {\n try {\n for await (const { event, data, id } of client.runs.joinStream(thread_id, run_id, {\n signal: controller.signal,\n cancelOnDisconnect: parsedCancelOnDisconnect,\n lastEventId: parsedLastEventId,\n streamMode: parsedStreamMode ? [parsedStreamMode] : undefined,\n })) {\n yield { event: event as unknown as string, data, id };\n }\n } catch (error) {\n // 记录错误但不抛出,避免中断流\n console.error('Join stream error:', error);\n }\n }\n\n return sseResponse(joinStreamGenerator());\n }\n }\n\n return new NextResponse('Not Found', { status: 404 });\n}\n\nexport async function POST(req: NextRequest) {\n const url = new URL(req.url);\n const pathname = url.pathname;\n\n // Assistants routes\n if (pathname.endsWith('/assistants/search')) {\n const body = await req.json();\n const payload = AssistantsSearchSchema.parse(body);\n const data = await client.assistants.search({\n graphId: payload.graph_id,\n metadata: payload.metadata,\n limit: payload.limit,\n offset: payload.offset,\n });\n return NextResponse.json(data, {\n headers: { 'X-Pagination-Total': String(data.length) },\n });\n }\n\n // Threads routes\n if (pathname.endsWith('/threads')) {\n const body = await req.json();\n const payload = ThreadCreatePayloadSchema.parse(body);\n const thread = await client.threads.create(camelcaseKeys(payload));\n return NextResponse.json(thread);\n }\n\n if (pathname.endsWith('/threads/search')) {\n const body = await req.json();\n const payload = ThreadSearchPayloadSchema.parse(body);\n const result = await client.threads.search(camelcaseKeys(payload));\n return NextResponse.json(result, {\n headers: { 'X-Pagination-Total': String(result.length) },\n });\n }\n\n // Threads state update\n if (pathname.match(/\\/threads\\/[0-9a-fA-F-]{36}\\/state$/)) {\n const match = pathname.match(/\\/threads\\/([0-9a-fA-F-]{36})\\/state$/);\n if (match) {\n const thread_id = match[1];\n const body = await req.json();\n const payload = ThreadStateUpdate.parse(body);\n const result = await client.threads.updateState(thread_id, camelcaseKeys(payload));\n return NextResponse.json(result);\n }\n }\n\n // Runs routes - stream\n if (pathname.match(/\\/threads\\/[0-9a-fA-F-]{36}\\/runs\\/stream$/)) {\n const match = pathname.match(/\\/threads\\/([0-9a-fA-F-]{36})\\/runs\\/stream$/);\n if (match) {\n const thread_id = match[1];\n const body = await req.json();\n const payload = RunStreamPayloadSchema.parse(body);\n\n // Extract custom context from request headers\n const langgraphContextHeader = req.headers.get('x-langgraph-context');\n if (langgraphContextHeader) {\n const langgraphContext = JSON.parse(decodeURIComponent(langgraphContextHeader));\n payload.config = payload.config || {};\n payload.config.configurable = payload.config.configurable || {};\n Object.assign(payload.config.configurable, langgraphContext);\n }\n const generator = client.runs.stream(\n thread_id,\n payload.assistant_id as string,\n camelcaseKeys(payload) as any,\n );\n return sseResponse(generator as any);\n }\n }\n\n // Runs routes - cancel\n if (pathname.match(/\\/threads\\/[0-9a-fA-F-]{36}\\/runs\\/[0-9a-fA-F-]{36}\\/cancel$/)) {\n const match = pathname.match(/\\/threads\\/([0-9a-fA-F-]{36})\\/runs\\/([0-9a-fA-F-]{36})\\/cancel$/);\n if (match) {\n const thread_id = match[1];\n const run_id = match[2];\n const waitParam = url.searchParams.get('wait') ?? undefined;\n const actionParam = url.searchParams.get('action') ?? undefined;\n const queryParams = {\n wait: waitParam ? waitParam === 'true' : false,\n action: actionParam ?? 'interrupt',\n };\n const { wait, action } = RunCancelQuerySchema.parse(queryParams);\n const promise = client.runs.cancel(thread_id, run_id, wait, action);\n if (wait) await promise;\n return new Response(null, { status: wait ? 204 : 202 });\n }\n }\n\n return new NextResponse('Not Found', { status: 404 });\n}\n\nexport async function DELETE(req: NextRequest) {\n const url = new URL(req.url);\n const pathname = url.pathname;\n\n // Threads routes\n if (pathname.match(/\\/threads\\/[0-9a-fA-F-]{36}$/)) {\n const match = pathname.match(/\\/threads\\/([0-9a-fA-F-]{36})$/);\n if (match) {\n const thread_id = match[1];\n await client.threads.delete(thread_id);\n return new NextResponse(null, { status: 204 });\n }\n }\n\n return new NextResponse('Not Found', { status: 404 });\n}\n"],"names":[],"mappings":"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"}
@@ -20,15 +20,15 @@ z.object({
20
20
  const MetadataSchema = z.object({
21
21
  source: z.union([z.literal("input"), z.literal("loop"), z.literal("update"), z.string()]).optional(),
22
22
  step: z.number().optional(),
23
- writes: z.record(z.unknown()).nullable().optional(),
24
- parents: z.record(z.string()).optional()
23
+ writes: z.any().nullable().optional(),
24
+ parents: z.any().optional()
25
25
  }).catchall(z.unknown());
26
26
  const SendSchema = z.object({
27
27
  node: z.string(),
28
28
  input: z.unknown().optional()
29
29
  });
30
30
  const CommandSchema = z.object({
31
- update: z.union([z.record(z.unknown()), z.array(z.tuple([z.string(), z.unknown()]))]).nullable().optional(),
31
+ update: z.union([z.any(), z.array(z.tuple([z.string(), z.any()]))]).nullable().optional(),
32
32
  resume: z.unknown().optional(),
33
33
  goto: z.union([SendSchema, z.array(SendSchema), z.string(), z.array(z.string())]).optional()
34
34
  });
@@ -93,9 +93,9 @@ const ThreadCreatePayloadSchema = z.object({
93
93
  if_exists: z.union([z.literal("raise"), z.literal("do_nothing")]).optional()
94
94
  }).describe("Payload for creating a thread.");
95
95
  const ThreadSearchPayloadSchema = z.object({
96
- metadata: z.record(z.unknown()).describe("Metadata to search for.").optional(),
96
+ metadata: MetadataSchema.describe("Metadata to search for.").optional(),
97
97
  status: z.enum(["idle", "busy", "interrupted", "error"]).describe("Filter by thread status.").optional(),
98
- values: z.record(z.unknown()).describe("Filter by thread values.").optional(),
98
+ values: z.any().describe("Filter by thread values.").optional(),
99
99
  limit: z.number().int().gte(1).lte(1e3).describe("Maximum number to return.").optional(),
100
100
  offset: z.number().int().gte(0).describe("Offset to start from.").optional(),
101
101
  sort_by: z.enum(["thread_id", "status", "created_at", "updated_at"]).describe("Sort by field.").optional(),
@@ -109,4 +109,4 @@ const ThreadStateUpdate = z.object({
109
109
  }).describe("Payload for adding state to a thread.");
110
110
 
111
111
  export { AssistantsSearchSchema as A, RunStreamPayloadSchema as R, ThreadIdParamSchema as T, AssistantGraphQuerySchema as a, RunIdParamSchema as b, RunJoinStreamQuerySchema as c, RunListQuerySchema as d, RunCancelQuerySchema as e, ThreadStateUpdate as f, ThreadCreatePayloadSchema as g, ThreadSearchPayloadSchema as h };
112
- //# sourceMappingURL=zod-DixWQt_u.js.map
112
+ //# sourceMappingURL=zod-B6xyK6pu.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"zod-B6xyK6pu.js","sources":["../src/adapter/zod.ts"],"sourcesContent":["import z from 'zod';\n\nexport const AssistantConfigurable = z\n .object({\n thread_id: z.string().optional(),\n thread_ts: z.string().optional(),\n })\n .catchall(z.unknown());\n\nexport const AssistantConfig = z\n .object({\n tags: z.array(z.string()).optional(),\n recursion_limit: z.number().int().optional(),\n configurable: AssistantConfigurable.optional(),\n })\n .catchall(z.unknown())\n .describe('The configuration of an assistant.');\n\nexport const Assistant = z.object({\n assistant_id: z.string().uuid(),\n graph_id: z.string(),\n config: AssistantConfig,\n created_at: z.string(),\n updated_at: z.string(),\n metadata: z.object({}).catchall(z.any()),\n});\n\nexport const MetadataSchema = z\n .object({\n source: z.union([z.literal('input'), z.literal('loop'), z.literal('update'), z.string()]).optional(),\n step: z.number().optional(),\n writes: z.any().nullable().optional(),\n parents: z.any().optional(),\n })\n .catchall(z.unknown());\n\nexport const SendSchema = z.object({\n node: z.string(),\n input: z.unknown().optional(),\n});\n\nexport const CommandSchema = z.object({\n update: z\n .union([z.any(), z.array(z.tuple([z.string(), z.any()]))])\n .nullable()\n .optional(),\n resume: z.unknown().optional(),\n goto: z.union([SendSchema, z.array(SendSchema), z.string(), z.array(z.string())]).optional(),\n});\n\n// 公共的查询参数验证 schema\nexport const PaginationQuerySchema = z.object({\n limit: z.number().int().optional(),\n offset: z.number().int().optional(),\n});\n\nexport const ThreadIdParamSchema = z.object({\n thread_id: z.string().uuid(),\n});\n\nexport const RunIdParamSchema = z.object({\n thread_id: z.string().uuid(),\n run_id: z.string().uuid(),\n});\n\n// Assistants 相关的 schema\nexport const AssistantsSearchSchema = z.object({\n graph_id: z.string().optional(),\n metadata: MetadataSchema.optional(),\n limit: z.number().int().optional(),\n offset: z.number().int().optional(),\n});\n\nexport const AssistantGraphQuerySchema = z.object({\n xray: z.string().optional(),\n});\n\n// Runs 相关的 schema\nexport const RunStreamPayloadSchema = z\n .object({\n assistant_id: z.union([z.string().uuid(), z.string()]),\n checkpoint_id: z.string().optional(),\n input: z.any().optional(),\n command: CommandSchema.optional(),\n metadata: MetadataSchema.optional(),\n config: AssistantConfig.optional(),\n webhook: z.string().optional(),\n interrupt_before: z.union([z.literal('*'), z.array(z.string())]).optional(),\n interrupt_after: z.union([z.literal('*'), z.array(z.string())]).optional(),\n on_disconnect: z.enum(['cancel', 'continue']).optional().default('continue'),\n multitask_strategy: z.enum(['reject', 'rollback', 'interrupt', 'enqueue']).optional(),\n stream_mode: z\n .array(z.enum(['values', 'messages', 'messages-tuple', 'updates', 'events', 'debug', 'custom']))\n .optional(),\n stream_subgraphs: z.boolean().optional(),\n stream_resumable: z.boolean().optional(),\n after_seconds: z.number().optional(),\n if_not_exists: z.enum(['create', 'reject']).optional(),\n on_completion: z.enum(['complete', 'continue']).optional(),\n feedback_keys: z.array(z.string()).optional(),\n langsmith_tracer: z.unknown().optional(),\n })\n .describe('Payload for creating a stateful run.');\n\nexport const RunListQuerySchema = z.object({\n limit: z.coerce.number().int().optional(),\n offset: z.coerce.number().int().optional(),\n status: z.enum(['pending', 'running', 'error', 'success', 'timeout', 'interrupted']).optional(),\n});\n\nexport const RunCancelQuerySchema = z.object({\n wait: z.coerce.boolean().optional().default(false),\n action: z.enum(['interrupt', 'rollback']).optional().default('interrupt'),\n});\n\nexport const RunJoinStreamQuerySchema = z.object({\n cancel_on_disconnect: z.coerce.boolean().optional().default(false),\n last_event_id: z.string().optional(),\n stream_mode: z.enum(['values', 'messages', 'messages-tuple', 'updates', 'events', 'debug', 'custom']).optional(),\n});\n\n// Threads 相关的 schema\nexport const ThreadCreatePayloadSchema = z\n .object({\n thread_id: z.string().uuid().describe('The ID of the thread. If not provided, an ID is generated.').optional(),\n metadata: MetadataSchema.optional(),\n if_exists: z.union([z.literal('raise'), z.literal('do_nothing')]).optional(),\n })\n .describe('Payload for creating a thread.');\n\nexport const ThreadSearchPayloadSchema = z\n .object({\n metadata: MetadataSchema.describe('Metadata to search for.').optional(),\n status: z.enum(['idle', 'busy', 'interrupted', 'error']).describe('Filter by thread status.').optional(),\n values: z.any().describe('Filter by thread values.').optional(),\n limit: z.number().int().gte(1).lte(1000).describe('Maximum number to return.').optional(),\n offset: z.number().int().gte(0).describe('Offset to start from.').optional(),\n sort_by: z.enum(['thread_id', 'status', 'created_at', 'updated_at']).describe('Sort by field.').optional(),\n sort_order: z.enum(['asc', 'desc']).describe('Sort order.').optional(),\n })\n .describe('Payload for listing threads.');\n\nexport const ThreadStateUpdate = z\n .object({\n values: z.union([z.record(z.string(), z.unknown()), z.array(z.record(z.string(), z.unknown()))]).nullish(),\n // as_node: z.string().optional(),\n // checkpoint_id: z.string().optional(),\n // checkpoint: CheckpointSchema.nullish(),\n })\n .describe('Payload for adding state to a thread.');\n"],"names":[],"mappings":"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"}
package/package.json CHANGED
@@ -1,6 +1,6 @@
1
1
  {
2
2
  "name": "@langgraph-js/pure-graph",
3
- "version": "2.4.0",
3
+ "version": "2.4.2",
4
4
  "description": "A library that provides a standard LangGraph endpoint for integrating into various frameworks like Next.js and Hono.js, with support for multiple storage backends (SQLite, PostgreSQL, Redis) and message queues.",
5
5
  "main": "dist/index.js",
6
6
  "types": "dist/index.d.ts",
@@ -26,11 +26,11 @@
26
26
  ],
27
27
  "repository": {
28
28
  "type": "git",
29
- "url": "https://github.com/KonghaYao/pure-graph.git"
29
+ "url": "https://github.com/KonghaYao/open-langgraph-server.git"
30
30
  },
31
- "homepage": "https://github.com/KonghaYao/pure-graph",
31
+ "homepage": "https://github.com/KonghaYao/open-langgraph-server",
32
32
  "bugs": {
33
- "url": "https://github.com/KonghaYao/pure-graph/issues"
33
+ "url": "https://github.com/KonghaYao/open-langgraph-server/issues"
34
34
  },
35
35
  "engines": {
36
36
  "node": ">=18.0.0"
@@ -47,7 +47,7 @@
47
47
  "eventemitter3": "^5.0.1",
48
48
  "kysely": "^0.28.8",
49
49
  "langchain": "^1.0.1",
50
- "zod": "^3"
50
+ "zod": "^4"
51
51
  },
52
52
  "optionalDependencies": {
53
53
  "@hono/zod-validator": "^0.7.3",
@@ -61,7 +61,7 @@
61
61
  "devDependencies": {
62
62
  "@langchain/langgraph-sdk": "^1.0.0",
63
63
  "@langchain/openai": "^1.0.0",
64
- "@langgraph-js/sdk": "^3.0.1",
64
+ "@langgraph-js/sdk": "^3.3.1",
65
65
  "@types/node": "^22.13.5",
66
66
  "@types/pg": "^8.15.5",
67
67
  "rollup-plugin-node-externals": "^8.1.1",
@@ -70,9 +70,9 @@
70
70
  },
71
71
  "scripts": {
72
72
  "dev": "bun run --port 8123 test/hono.ts",
73
- "dev:docs": "npx xyd-js",
73
+ "dev:docs": "bunx --bun xyd-js",
74
74
  "build": " vite build && tsc",
75
- "build:docs": "npx xyd-js build",
75
+ "docs:build": "pnpx xyd-js build",
76
76
  "prepublish": "pnpm build"
77
77
  }
78
78
  }
@@ -1 +0,0 @@
1
- {"version":3,"file":"zod-DixWQt_u.js","sources":["../src/adapter/zod.ts"],"sourcesContent":["import z from 'zod';\n\nexport const AssistantConfigurable = z\n .object({\n thread_id: z.string().optional(),\n thread_ts: z.string().optional(),\n })\n .catchall(z.unknown());\n\nexport const AssistantConfig = z\n .object({\n tags: z.array(z.string()).optional(),\n recursion_limit: z.number().int().optional(),\n configurable: AssistantConfigurable.optional(),\n })\n .catchall(z.unknown())\n .describe('The configuration of an assistant.');\n\nexport const Assistant = z.object({\n assistant_id: z.string().uuid(),\n graph_id: z.string(),\n config: AssistantConfig,\n created_at: z.string(),\n updated_at: z.string(),\n metadata: z.object({}).catchall(z.any()),\n});\n\nexport const MetadataSchema = z\n .object({\n source: z.union([z.literal('input'), z.literal('loop'), z.literal('update'), z.string()]).optional(),\n step: z.number().optional(),\n writes: z.record(z.unknown()).nullable().optional(),\n parents: z.record(z.string()).optional(),\n })\n .catchall(z.unknown());\n\nexport const SendSchema = z.object({\n node: z.string(),\n input: z.unknown().optional(),\n});\n\nexport const CommandSchema = z.object({\n update: z\n .union([z.record(z.unknown()), z.array(z.tuple([z.string(), z.unknown()]))])\n .nullable()\n .optional(),\n resume: z.unknown().optional(),\n goto: z.union([SendSchema, z.array(SendSchema), z.string(), z.array(z.string())]).optional(),\n});\n\n// 公共的查询参数验证 schema\nexport const PaginationQuerySchema = z.object({\n limit: z.number().int().optional(),\n offset: z.number().int().optional(),\n});\n\nexport const ThreadIdParamSchema = z.object({\n thread_id: z.string().uuid(),\n});\n\nexport const RunIdParamSchema = z.object({\n thread_id: z.string().uuid(),\n run_id: z.string().uuid(),\n});\n\n// Assistants 相关的 schema\nexport const AssistantsSearchSchema = z.object({\n graph_id: z.string().optional(),\n metadata: MetadataSchema.optional(),\n limit: z.number().int().optional(),\n offset: z.number().int().optional(),\n});\n\nexport const AssistantGraphQuerySchema = z.object({\n xray: z.string().optional(),\n});\n\n// Runs 相关的 schema\nexport const RunStreamPayloadSchema = z\n .object({\n assistant_id: z.union([z.string().uuid(), z.string()]),\n checkpoint_id: z.string().optional(),\n input: z.any().optional(),\n command: CommandSchema.optional(),\n metadata: MetadataSchema.optional(),\n config: AssistantConfig.optional(),\n webhook: z.string().optional(),\n interrupt_before: z.union([z.literal('*'), z.array(z.string())]).optional(),\n interrupt_after: z.union([z.literal('*'), z.array(z.string())]).optional(),\n on_disconnect: z.enum(['cancel', 'continue']).optional().default('continue'),\n multitask_strategy: z.enum(['reject', 'rollback', 'interrupt', 'enqueue']).optional(),\n stream_mode: z\n .array(z.enum(['values', 'messages', 'messages-tuple', 'updates', 'events', 'debug', 'custom']))\n .optional(),\n stream_subgraphs: z.boolean().optional(),\n stream_resumable: z.boolean().optional(),\n after_seconds: z.number().optional(),\n if_not_exists: z.enum(['create', 'reject']).optional(),\n on_completion: z.enum(['complete', 'continue']).optional(),\n feedback_keys: z.array(z.string()).optional(),\n langsmith_tracer: z.unknown().optional(),\n })\n .describe('Payload for creating a stateful run.');\n\nexport const RunListQuerySchema = z.object({\n limit: z.coerce.number().int().optional(),\n offset: z.coerce.number().int().optional(),\n status: z.enum(['pending', 'running', 'error', 'success', 'timeout', 'interrupted']).optional(),\n});\n\nexport const RunCancelQuerySchema = z.object({\n wait: z.coerce.boolean().optional().default(false),\n action: z.enum(['interrupt', 'rollback']).optional().default('interrupt'),\n});\n\nexport const RunJoinStreamQuerySchema = z.object({\n cancel_on_disconnect: z.coerce.boolean().optional().default(false),\n last_event_id: z.string().optional(),\n stream_mode: z.enum(['values', 'messages', 'messages-tuple', 'updates', 'events', 'debug', 'custom']).optional(),\n});\n\n// Threads 相关的 schema\nexport const ThreadCreatePayloadSchema = z\n .object({\n thread_id: z.string().uuid().describe('The ID of the thread. If not provided, an ID is generated.').optional(),\n metadata: MetadataSchema.optional(),\n if_exists: z.union([z.literal('raise'), z.literal('do_nothing')]).optional(),\n })\n .describe('Payload for creating a thread.');\n\nexport const ThreadSearchPayloadSchema = z\n .object({\n metadata: z.record(z.unknown()).describe('Metadata to search for.').optional(),\n status: z.enum(['idle', 'busy', 'interrupted', 'error']).describe('Filter by thread status.').optional(),\n values: z.record(z.unknown()).describe('Filter by thread values.').optional(),\n limit: z.number().int().gte(1).lte(1000).describe('Maximum number to return.').optional(),\n offset: z.number().int().gte(0).describe('Offset to start from.').optional(),\n sort_by: z.enum(['thread_id', 'status', 'created_at', 'updated_at']).describe('Sort by field.').optional(),\n sort_order: z.enum(['asc', 'desc']).describe('Sort order.').optional(),\n })\n .describe('Payload for listing threads.');\n\nexport const ThreadStateUpdate = z\n .object({\n values: z.union([z.record(z.string(), z.unknown()), z.array(z.record(z.string(), z.unknown()))]).nullish(),\n // as_node: z.string().optional(),\n // checkpoint_id: z.string().optional(),\n // checkpoint: CheckpointSchema.nullish(),\n })\n .describe('Payload for adding state to a thread.');\n"],"names":[],"mappings":"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"}