zeitlich 0.2.20 → 0.2.21

This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
Files changed (46) hide show
  1. package/dist/adapters/sandbox/virtual/index.d.cts +3 -3
  2. package/dist/adapters/sandbox/virtual/index.d.ts +3 -3
  3. package/dist/adapters/thread/google-genai/index.cjs +70 -23
  4. package/dist/adapters/thread/google-genai/index.cjs.map +1 -1
  5. package/dist/adapters/thread/google-genai/index.d.cts +10 -10
  6. package/dist/adapters/thread/google-genai/index.d.ts +10 -10
  7. package/dist/adapters/thread/google-genai/index.js +70 -23
  8. package/dist/adapters/thread/google-genai/index.js.map +1 -1
  9. package/dist/adapters/thread/langchain/index.cjs +75 -70
  10. package/dist/adapters/thread/langchain/index.cjs.map +1 -1
  11. package/dist/adapters/thread/langchain/index.d.cts +10 -10
  12. package/dist/adapters/thread/langchain/index.d.ts +10 -10
  13. package/dist/adapters/thread/langchain/index.js +75 -70
  14. package/dist/adapters/thread/langchain/index.js.map +1 -1
  15. package/dist/index.cjs +54 -9
  16. package/dist/index.cjs.map +1 -1
  17. package/dist/index.d.cts +6 -6
  18. package/dist/index.d.ts +6 -6
  19. package/dist/index.js +54 -9
  20. package/dist/index.js.map +1 -1
  21. package/dist/{queries-KHj5Otv7.d.ts → queries-6Avfh74U.d.ts} +1 -1
  22. package/dist/{queries-nIdzTCDS.d.cts → queries-CHa2iv_I.d.cts} +1 -1
  23. package/dist/{types-By80IE1x.d.ts → types-BkAYmc96.d.ts} +4 -4
  24. package/dist/{types-DZ7BkA3-.d.cts → types-CES_30qx.d.cts} +4 -4
  25. package/dist/{types-Ct2igz9y.d.ts → types-YbL7JpEA.d.cts} +1 -1
  26. package/dist/{types-Ct2igz9y.d.cts → types-YbL7JpEA.d.ts} +1 -1
  27. package/dist/workflow.cjs +7 -8
  28. package/dist/workflow.cjs.map +1 -1
  29. package/dist/workflow.d.cts +6 -6
  30. package/dist/workflow.d.ts +6 -6
  31. package/dist/workflow.js +7 -8
  32. package/dist/workflow.js.map +1 -1
  33. package/package.json +1 -1
  34. package/src/adapters/thread/google-genai/activities.ts +11 -9
  35. package/src/adapters/thread/google-genai/model-invoker.ts +6 -11
  36. package/src/adapters/thread/google-genai/thread-manager.ts +44 -29
  37. package/src/adapters/thread/langchain/activities.ts +6 -4
  38. package/src/adapters/thread/langchain/thread-manager.ts +46 -22
  39. package/src/lib/session/session.ts +5 -4
  40. package/src/lib/session/types.ts +7 -2
  41. package/src/lib/tool-router/auto-append-sandbox.integration.test.ts +20 -21
  42. package/src/lib/tool-router/auto-append.ts +3 -2
  43. package/src/lib/tool-router/router-edge-cases.integration.test.ts +59 -23
  44. package/src/lib/tool-router/router.integration.test.ts +55 -23
  45. package/src/lib/tool-router/router.ts +4 -3
  46. package/src/lib/tool-router/types.ts +1 -1
package/dist/index.d.cts CHANGED
@@ -1,13 +1,13 @@
1
1
  import { BashArgs, FileEditArgs, GlobArgs, FileReadArgs, FileWriteArgs } from './workflow.cjs';
2
2
  export { AskUserQuestionArgs, GrepArgs, ReadSkillArgs, SubagentArgs, TaskCreateArgs, TaskGetArgs, TaskListArgs, TaskUpdateArgs, WorkflowConfig, WorkflowInput, WorkflowSessionInput, applyVirtualTreeMutations, askUserQuestionTool, bashTool, createAgentStateManager, createAskUserQuestionHandler, createBashToolDescription, createReadSkillHandler, createReadSkillTool, createSession, createTaskCreateHandler, createTaskGetHandler, createTaskListHandler, createTaskUpdateHandler, createToolRouter, defineSubagent, defineSubagentWorkflow, defineTool, defineWorkflow, editTool, formatVirtualFileTree, getShortId, globTool, grepTool, hasNoOtherToolCalls, parseSkillFile, proxyDefaultThreadOps, proxySandboxOps, readFileTool, taskCreateTool, taskGetTool, taskListTool, taskUpdateTool, writeFileTool } from './workflow.cjs';
3
- import { S as SkillProvider, b as SkillMetadata, c as Skill } from './types-DZ7BkA3-.cjs';
4
- export { A as AgentResponse, d as AgentState, e as AgentStateManager, H as Hooks, J as JsonPrimitive, f as JsonSerializable, g as JsonValue, M as ModelInvoker, a as ModelInvokerConfig, P as PostHumanMessageAppendHook, h as PostHumanMessageAppendHookContext, i as PreHumanMessageAppendHook, j as PreHumanMessageAppendHookContext, R as RunAgentActivity, k as SessionConfig, l as SessionEndHook, m as SessionEndHookContext, n as SessionStartHook, o as SessionStartHookContext, p as SubagentConfig, q as SubagentDefinition, r as SubagentHandlerResponse, s as SubagentHooks, t as SubagentSessionInput, u as SubagentWorkflow, v as SubagentWorkflowInput, T as ThreadOps, Z as ZeitlichSession } from './types-DZ7BkA3-.cjs';
5
- import { R as RouterContext, j as ToolResultConfig, A as ActivityToolHandler, c as ToolHandlerResponse, B as BaseAgentState, g as RunAgentConfig } from './types-Ct2igz9y.cjs';
6
- export { l as AgentConfig, m as AgentFile, h as AgentStatus, n as AppendToolResultFn, C as ContentPart, I as InferToolResults, M as MessageContent, o as ParsedToolCall, p as ParsedToolCallUnion, q as PostToolUseFailureHook, r as PostToolUseFailureHookContext, d as PostToolUseFailureHookResult, s as PostToolUseHook, t as PostToolUseHookContext, u as PreToolUseHook, v as PreToolUseHookContext, P as PreToolUseHookResult, w as ProcessToolCallsContext, e as RawToolCall, x as SerializableToolDefinition, S as SessionExitReason, y as TaskStatus, f as TokenUsage, z as ToolArgs, D as ToolCallResult, k as ToolCallResultUnion, i as ToolDefinition, E as ToolHandler, F as ToolHooks, a as ToolMap, T as ToolMessageContent, G as ToolNames, H as ToolResult, J as ToolRouter, b as ToolRouterHooks, K as ToolWithHandler, W as WorkflowTask, L as isTerminalStatus } from './types-Ct2igz9y.cjs';
3
+ import { S as SkillProvider, b as SkillMetadata, c as Skill } from './types-CES_30qx.cjs';
4
+ export { A as AgentResponse, d as AgentState, e as AgentStateManager, H as Hooks, J as JsonPrimitive, f as JsonSerializable, g as JsonValue, M as ModelInvoker, a as ModelInvokerConfig, P as PostHumanMessageAppendHook, h as PostHumanMessageAppendHookContext, i as PreHumanMessageAppendHook, j as PreHumanMessageAppendHookContext, R as RunAgentActivity, k as SessionConfig, l as SessionEndHook, m as SessionEndHookContext, n as SessionStartHook, o as SessionStartHookContext, p as SubagentConfig, q as SubagentDefinition, r as SubagentHandlerResponse, s as SubagentHooks, t as SubagentSessionInput, u as SubagentWorkflow, v as SubagentWorkflowInput, T as ThreadOps, Z as ZeitlichSession } from './types-CES_30qx.cjs';
5
+ import { R as RouterContext, j as ToolResultConfig, A as ActivityToolHandler, c as ToolHandlerResponse, B as BaseAgentState, g as RunAgentConfig } from './types-YbL7JpEA.cjs';
6
+ export { l as AgentConfig, m as AgentFile, h as AgentStatus, n as AppendToolResultFn, C as ContentPart, I as InferToolResults, M as MessageContent, o as ParsedToolCall, p as ParsedToolCallUnion, q as PostToolUseFailureHook, r as PostToolUseFailureHookContext, d as PostToolUseFailureHookResult, s as PostToolUseHook, t as PostToolUseHookContext, u as PreToolUseHook, v as PreToolUseHookContext, P as PreToolUseHookResult, w as ProcessToolCallsContext, e as RawToolCall, x as SerializableToolDefinition, S as SessionExitReason, y as TaskStatus, f as TokenUsage, z as ToolArgs, D as ToolCallResult, k as ToolCallResultUnion, i as ToolDefinition, E as ToolHandler, F as ToolHooks, a as ToolMap, T as ToolMessageContent, G as ToolNames, H as ToolResult, J as ToolRouter, b as ToolRouterHooks, K as ToolWithHandler, W as WorkflowTask, L as isTerminalStatus } from './types-YbL7JpEA.cjs';
7
7
  import { S as Sandbox, a as SandboxFileSystem, d as SandboxCreateOptions, b as SandboxProvider, f as SandboxSnapshot, g as SandboxOps, E as ExecResult } from './types-BMRzfELQ.cjs';
8
8
  export { h as ExecOptions, c as SandboxCapabilities, e as SandboxCreateResult, D as SandboxDirentEntry, F as SandboxFileStat, i as SandboxNotFoundError, j as SandboxNotSupportedError } from './types-BMRzfELQ.cjs';
9
9
  import { WorkflowClient } from '@temporalio/client';
10
- export { c as FileEntry, F as FileEntryMetadata, a as FileResolver, T as TreeMutation, f as VirtualFileTree, h as VirtualSandboxState, i as filesWithMimeType, j as hasDirectory, k as hasFileWithMimeType } from './queries-nIdzTCDS.cjs';
10
+ export { c as FileEntry, F as FileEntryMetadata, a as FileResolver, T as TreeMutation, f as VirtualFileTree, h as VirtualSandboxState, i as filesWithMimeType, j as hasDirectory, k as hasFileWithMimeType } from './queries-CHa2iv_I.cjs';
11
11
  import { T as ThreadManagerConfig, B as BaseThreadManager } from './types-35POpVfa.cjs';
12
12
  import '@temporalio/workflow';
13
13
  import 'zod';
@@ -42,7 +42,7 @@ import 'ioredis';
42
42
  * );
43
43
  * ```
44
44
  */
45
- declare function withAutoAppend<TArgs, TResult, TContext extends RouterContext = RouterContext>(threadHandler: (config: ToolResultConfig) => Promise<void>, handler: ActivityToolHandler<TArgs, TResult, TContext>): ActivityToolHandler<TArgs, TResult, TContext>;
45
+ declare function withAutoAppend<TArgs, TResult, TContext extends RouterContext = RouterContext>(threadHandler: (id: string, config: ToolResultConfig) => Promise<void>, handler: ActivityToolHandler<TArgs, TResult, TContext>): ActivityToolHandler<TArgs, TResult, TContext>;
46
46
 
47
47
  /**
48
48
  * Extended router context with a resolved {@link Sandbox} instance.
package/dist/index.d.ts CHANGED
@@ -1,13 +1,13 @@
1
1
  import { BashArgs, FileEditArgs, GlobArgs, FileReadArgs, FileWriteArgs } from './workflow.js';
2
2
  export { AskUserQuestionArgs, GrepArgs, ReadSkillArgs, SubagentArgs, TaskCreateArgs, TaskGetArgs, TaskListArgs, TaskUpdateArgs, WorkflowConfig, WorkflowInput, WorkflowSessionInput, applyVirtualTreeMutations, askUserQuestionTool, bashTool, createAgentStateManager, createAskUserQuestionHandler, createBashToolDescription, createReadSkillHandler, createReadSkillTool, createSession, createTaskCreateHandler, createTaskGetHandler, createTaskListHandler, createTaskUpdateHandler, createToolRouter, defineSubagent, defineSubagentWorkflow, defineTool, defineWorkflow, editTool, formatVirtualFileTree, getShortId, globTool, grepTool, hasNoOtherToolCalls, parseSkillFile, proxyDefaultThreadOps, proxySandboxOps, readFileTool, taskCreateTool, taskGetTool, taskListTool, taskUpdateTool, writeFileTool } from './workflow.js';
3
- import { S as SkillProvider, b as SkillMetadata, c as Skill } from './types-By80IE1x.js';
4
- export { A as AgentResponse, d as AgentState, e as AgentStateManager, H as Hooks, J as JsonPrimitive, f as JsonSerializable, g as JsonValue, M as ModelInvoker, a as ModelInvokerConfig, P as PostHumanMessageAppendHook, h as PostHumanMessageAppendHookContext, i as PreHumanMessageAppendHook, j as PreHumanMessageAppendHookContext, R as RunAgentActivity, k as SessionConfig, l as SessionEndHook, m as SessionEndHookContext, n as SessionStartHook, o as SessionStartHookContext, p as SubagentConfig, q as SubagentDefinition, r as SubagentHandlerResponse, s as SubagentHooks, t as SubagentSessionInput, u as SubagentWorkflow, v as SubagentWorkflowInput, T as ThreadOps, Z as ZeitlichSession } from './types-By80IE1x.js';
5
- import { R as RouterContext, j as ToolResultConfig, A as ActivityToolHandler, c as ToolHandlerResponse, B as BaseAgentState, g as RunAgentConfig } from './types-Ct2igz9y.js';
6
- export { l as AgentConfig, m as AgentFile, h as AgentStatus, n as AppendToolResultFn, C as ContentPart, I as InferToolResults, M as MessageContent, o as ParsedToolCall, p as ParsedToolCallUnion, q as PostToolUseFailureHook, r as PostToolUseFailureHookContext, d as PostToolUseFailureHookResult, s as PostToolUseHook, t as PostToolUseHookContext, u as PreToolUseHook, v as PreToolUseHookContext, P as PreToolUseHookResult, w as ProcessToolCallsContext, e as RawToolCall, x as SerializableToolDefinition, S as SessionExitReason, y as TaskStatus, f as TokenUsage, z as ToolArgs, D as ToolCallResult, k as ToolCallResultUnion, i as ToolDefinition, E as ToolHandler, F as ToolHooks, a as ToolMap, T as ToolMessageContent, G as ToolNames, H as ToolResult, J as ToolRouter, b as ToolRouterHooks, K as ToolWithHandler, W as WorkflowTask, L as isTerminalStatus } from './types-Ct2igz9y.js';
3
+ import { S as SkillProvider, b as SkillMetadata, c as Skill } from './types-BkAYmc96.js';
4
+ export { A as AgentResponse, d as AgentState, e as AgentStateManager, H as Hooks, J as JsonPrimitive, f as JsonSerializable, g as JsonValue, M as ModelInvoker, a as ModelInvokerConfig, P as PostHumanMessageAppendHook, h as PostHumanMessageAppendHookContext, i as PreHumanMessageAppendHook, j as PreHumanMessageAppendHookContext, R as RunAgentActivity, k as SessionConfig, l as SessionEndHook, m as SessionEndHookContext, n as SessionStartHook, o as SessionStartHookContext, p as SubagentConfig, q as SubagentDefinition, r as SubagentHandlerResponse, s as SubagentHooks, t as SubagentSessionInput, u as SubagentWorkflow, v as SubagentWorkflowInput, T as ThreadOps, Z as ZeitlichSession } from './types-BkAYmc96.js';
5
+ import { R as RouterContext, j as ToolResultConfig, A as ActivityToolHandler, c as ToolHandlerResponse, B as BaseAgentState, g as RunAgentConfig } from './types-YbL7JpEA.js';
6
+ export { l as AgentConfig, m as AgentFile, h as AgentStatus, n as AppendToolResultFn, C as ContentPart, I as InferToolResults, M as MessageContent, o as ParsedToolCall, p as ParsedToolCallUnion, q as PostToolUseFailureHook, r as PostToolUseFailureHookContext, d as PostToolUseFailureHookResult, s as PostToolUseHook, t as PostToolUseHookContext, u as PreToolUseHook, v as PreToolUseHookContext, P as PreToolUseHookResult, w as ProcessToolCallsContext, e as RawToolCall, x as SerializableToolDefinition, S as SessionExitReason, y as TaskStatus, f as TokenUsage, z as ToolArgs, D as ToolCallResult, k as ToolCallResultUnion, i as ToolDefinition, E as ToolHandler, F as ToolHooks, a as ToolMap, T as ToolMessageContent, G as ToolNames, H as ToolResult, J as ToolRouter, b as ToolRouterHooks, K as ToolWithHandler, W as WorkflowTask, L as isTerminalStatus } from './types-YbL7JpEA.js';
7
7
  import { S as Sandbox, a as SandboxFileSystem, d as SandboxCreateOptions, b as SandboxProvider, f as SandboxSnapshot, g as SandboxOps, E as ExecResult } from './types-BMRzfELQ.js';
8
8
  export { h as ExecOptions, c as SandboxCapabilities, e as SandboxCreateResult, D as SandboxDirentEntry, F as SandboxFileStat, i as SandboxNotFoundError, j as SandboxNotSupportedError } from './types-BMRzfELQ.js';
9
9
  import { WorkflowClient } from '@temporalio/client';
10
- export { c as FileEntry, F as FileEntryMetadata, a as FileResolver, T as TreeMutation, f as VirtualFileTree, h as VirtualSandboxState, i as filesWithMimeType, j as hasDirectory, k as hasFileWithMimeType } from './queries-KHj5Otv7.js';
10
+ export { c as FileEntry, F as FileEntryMetadata, a as FileResolver, T as TreeMutation, f as VirtualFileTree, h as VirtualSandboxState, i as filesWithMimeType, j as hasDirectory, k as hasFileWithMimeType } from './queries-6Avfh74U.js';
11
11
  import { T as ThreadManagerConfig, B as BaseThreadManager } from './types-35POpVfa.js';
12
12
  import '@temporalio/workflow';
13
13
  import 'zod';
@@ -42,7 +42,7 @@ import 'ioredis';
42
42
  * );
43
43
  * ```
44
44
  */
45
- declare function withAutoAppend<TArgs, TResult, TContext extends RouterContext = RouterContext>(threadHandler: (config: ToolResultConfig) => Promise<void>, handler: ActivityToolHandler<TArgs, TResult, TContext>): ActivityToolHandler<TArgs, TResult, TContext>;
45
+ declare function withAutoAppend<TArgs, TResult, TContext extends RouterContext = RouterContext>(threadHandler: (id: string, config: ToolResultConfig) => Promise<void>, handler: ActivityToolHandler<TArgs, TResult, TContext>): ActivityToolHandler<TArgs, TResult, TContext>;
46
46
 
47
47
  /**
48
48
  * Extended router context with a resolved {@link Sandbox} instance.
package/dist/index.js CHANGED
@@ -1,5 +1,6 @@
1
1
  import { uuid4, setHandler, defineUpdate, ApplicationFailure, condition, proxyActivities, defineQuery, workflowInfo, executeChild } from '@temporalio/workflow';
2
2
  import z14, { z } from 'zod';
3
+ import { randomUUID, randomFillSync } from 'crypto';
3
4
  import { ApplicationFailure as ApplicationFailure$1 } from '@temporalio/common';
4
5
  import { join } from 'path';
5
6
  import { Context } from '@temporalio/activity';
@@ -108,7 +109,7 @@ function createToolRouter(options) {
108
109
  const tool = toolMap.get(toolCall.name);
109
110
  const preResult = await runPreHooks(toolCall, tool, turn);
110
111
  if (preResult.skip) {
111
- await appendToolResult({
112
+ await appendToolResult(uuid4(), {
112
113
  threadId: options.threadId,
113
114
  toolCallId: toolCall.id,
114
115
  toolName: toolCall.name,
@@ -164,7 +165,7 @@ function createToolRouter(options) {
164
165
  {
165
166
  summary: `Append ${toolCall.name} result`
166
167
  },
167
- [config]
168
+ [uuid4(), config]
168
169
  );
169
170
  }
170
171
  const toolResult = {
@@ -261,6 +262,7 @@ function createToolRouter(options) {
261
262
  summary: `Append ${toolCall.name} result`
262
263
  },
263
264
  [
265
+ uuid4(),
264
266
  {
265
267
  threadId: options.threadId,
266
268
  toolCallId: toolCall.id,
@@ -496,8 +498,6 @@ function buildSkillRegistration(skills) {
496
498
  handler: createReadSkillHandler(skills)
497
499
  };
498
500
  }
499
-
500
- // src/lib/session/session.ts
501
501
  var createSession = async ({
502
502
  threadId: providedThreadId,
503
503
  agentName,
@@ -567,7 +567,7 @@ var createSession = async ({
567
567
  threadId
568
568
  });
569
569
  }
570
- await appendHumanMessage(threadId, message);
570
+ await appendHumanMessage(threadId, uuid4(), message);
571
571
  if (hooks.onPostHumanMessageAppend) {
572
572
  await hooks.onPostHumanMessageAppend({
573
573
  message,
@@ -604,12 +604,12 @@ var createSession = async ({
604
604
  nonRetryable: true
605
605
  });
606
606
  }
607
- await appendSystemMessage(threadId, systemPrompt);
607
+ await appendSystemMessage(threadId, uuid4(), systemPrompt);
608
608
  } else {
609
609
  await initializeThread(threadId);
610
610
  }
611
611
  }
612
- await appendHumanMessage(threadId, await buildContextMessage());
612
+ await appendHumanMessage(threadId, uuid4(), await buildContextMessage());
613
613
  let exitReason = "completed";
614
614
  try {
615
615
  while (stateManager.isRunning() && !stateManager.isTerminal() && stateManager.getTurns() < maxTurns) {
@@ -639,7 +639,7 @@ var createSession = async ({
639
639
  try {
640
640
  parsedToolCalls.push(toolRouter.parseToolCall(tc));
641
641
  } catch (error) {
642
- await appendToolResult({
642
+ await appendToolResult(uuid4(), {
643
643
  threadId,
644
644
  toolCallId: tc.id ?? "",
645
645
  toolName: tc.name,
@@ -899,11 +899,56 @@ function createAgentStateManager({
899
899
  };
900
900
  }
901
901
 
902
+ // node_modules/uuid/dist/esm/stringify.js
903
+ var byteToHex = [];
904
+ for (let i = 0; i < 256; ++i) {
905
+ byteToHex.push((i + 256).toString(16).slice(1));
906
+ }
907
+ function unsafeStringify(arr, offset = 0) {
908
+ return (byteToHex[arr[offset + 0]] + byteToHex[arr[offset + 1]] + byteToHex[arr[offset + 2]] + byteToHex[arr[offset + 3]] + "-" + byteToHex[arr[offset + 4]] + byteToHex[arr[offset + 5]] + "-" + byteToHex[arr[offset + 6]] + byteToHex[arr[offset + 7]] + "-" + byteToHex[arr[offset + 8]] + byteToHex[arr[offset + 9]] + "-" + byteToHex[arr[offset + 10]] + byteToHex[arr[offset + 11]] + byteToHex[arr[offset + 12]] + byteToHex[arr[offset + 13]] + byteToHex[arr[offset + 14]] + byteToHex[arr[offset + 15]]).toLowerCase();
909
+ }
910
+ var rnds8Pool = new Uint8Array(256);
911
+ var poolPtr = rnds8Pool.length;
912
+ function rng() {
913
+ if (poolPtr > rnds8Pool.length - 16) {
914
+ randomFillSync(rnds8Pool);
915
+ poolPtr = 0;
916
+ }
917
+ return rnds8Pool.slice(poolPtr, poolPtr += 16);
918
+ }
919
+ var native_default = { randomUUID };
920
+
921
+ // node_modules/uuid/dist/esm/v4.js
922
+ function v4(options, buf, offset) {
923
+ if (native_default.randomUUID && !buf && !options) {
924
+ return native_default.randomUUID();
925
+ }
926
+ options = options || {};
927
+ const rnds = options.random ?? options.rng?.() ?? rng();
928
+ if (rnds.length < 16) {
929
+ throw new Error("Random bytes length must be >= 16");
930
+ }
931
+ rnds[6] = rnds[6] & 15 | 64;
932
+ rnds[8] = rnds[8] & 63 | 128;
933
+ if (buf) {
934
+ offset = offset || 0;
935
+ if (offset < 0 || offset + 16 > buf.length) {
936
+ throw new RangeError(`UUID byte range ${offset}:${offset + 15} is out of buffer bounds`);
937
+ }
938
+ for (let i = 0; i < 16; ++i) {
939
+ buf[offset + i] = rnds[i];
940
+ }
941
+ return buf;
942
+ }
943
+ return unsafeStringify(rnds);
944
+ }
945
+ var v4_default = v4;
946
+
902
947
  // src/lib/tool-router/auto-append.ts
903
948
  function withAutoAppend(threadHandler, handler) {
904
949
  return async (args, context) => {
905
950
  const response = await handler(args, context);
906
- await threadHandler({
951
+ await threadHandler(v4_default(), {
907
952
  threadId: context.threadId,
908
953
  toolCallId: context.toolCallId,
909
954
  toolName: context.toolName,