veryfront 0.1.186 → 0.1.187
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/esm/deno.js +1 -1
- package/esm/src/agent/runtime/chat-stream-handler.d.ts.map +1 -1
- package/esm/src/agent/runtime/chat-stream-handler.js +22 -2
- package/esm/src/agent/runtime/tool-helpers.d.ts.map +1 -1
- package/esm/src/agent/runtime/tool-helpers.js +9 -1
- package/esm/src/utils/version-constant.d.ts +1 -1
- package/esm/src/utils/version-constant.js +1 -1
- package/package.json +1 -1
- package/src/deno.js +1 -1
- package/src/src/agent/runtime/chat-stream-handler.ts +28 -2
- package/src/src/agent/runtime/tool-helpers.ts +13 -1
- package/src/src/utils/version-constant.ts +1 -1
package/esm/deno.js
CHANGED
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"chat-stream-handler.d.ts","sourceRoot":"","sources":["../../../../src/src/agent/runtime/chat-stream-handler.ts"],"names":[],"mappings":"AAAA;;;;;;;;GAQG;AAEH,OAAO,KAAK,EAAqB,mBAAmB,EAAE,MAAM,yBAAyB,CAAC;AAWtF,MAAM,WAAW,iBAAiB;IAChC,EAAE,EAAE,MAAM,CAAC;IACX,IAAI,EAAE,MAAM,CAAC;IACb,SAAS,EAAE,MAAM,CAAC;IAClB,gBAAgB,CAAC,EAAE,OAAO,CAAC;IAC3B,OAAO,CAAC,EAAE,OAAO,CAAC;CACnB;AAED,MAAM,WAAW,mBAAmB;IAClC,UAAU,EAAE,MAAM,CAAC;IACnB,QAAQ,EAAE,MAAM,CAAC;IACjB,MAAM,CAAC,EAAE,OAAO,CAAC;IACjB,KAAK,CAAC,EAAE,OAAO,CAAC;IAChB,gBAAgB,CAAC,EAAE,OAAO,CAAC;IAC3B,OAAO,CAAC,EAAE,OAAO,CAAC;IAClB,WAAW,CAAC,EAAE,OAAO,CAAC;CACvB;AAED,MAAM,WAAW,eAAe;IAC9B,eAAe,EAAE,MAAM,CAAC;IACxB,YAAY,EAAE,MAAM,GAAG,IAAI,CAAC;IAC5B,SAAS,EAAE,GAAG,CAAC,MAAM,EAAE,iBAAiB,CAAC,CAAC;IAC1C,WAAW,EAAE,mBAAmB,EAAE,CAAC;IACnC,KAAK,EAAE;QAAE,YAAY,EAAE,MAAM,CAAC;QAAC,gBAAgB,EAAE,MAAM,CAAC;QAAC,WAAW,EAAE,MAAM,CAAA;KAAE,CAAC;CAChF;AAED,MAAM,WAAW,mBAAmB;IAClC,OAAO,CAAC,EAAE,CAAC,KAAK,EAAE,MAAM,KAAK,IAAI,CAAC;IAClC,OAAO,CAAC,EAAE,CAAC,KAAK,EAAE;QAChB,YAAY,CAAC,EAAE,MAAM,CAAC;QACtB,gBAAgB,CAAC,EAAE,MAAM,CAAC;QAC1B,WAAW,CAAC,EAAE,MAAM,CAAC;KACtB,KAAK,IAAI,CAAC;CACZ;
|
|
1
|
+
{"version":3,"file":"chat-stream-handler.d.ts","sourceRoot":"","sources":["../../../../src/src/agent/runtime/chat-stream-handler.ts"],"names":[],"mappings":"AAAA;;;;;;;;GAQG;AAEH,OAAO,KAAK,EAAqB,mBAAmB,EAAE,MAAM,yBAAyB,CAAC;AAWtF,MAAM,WAAW,iBAAiB;IAChC,EAAE,EAAE,MAAM,CAAC;IACX,IAAI,EAAE,MAAM,CAAC;IACb,SAAS,EAAE,MAAM,CAAC;IAClB,gBAAgB,CAAC,EAAE,OAAO,CAAC;IAC3B,OAAO,CAAC,EAAE,OAAO,CAAC;CACnB;AAED,MAAM,WAAW,mBAAmB;IAClC,UAAU,EAAE,MAAM,CAAC;IACnB,QAAQ,EAAE,MAAM,CAAC;IACjB,MAAM,CAAC,EAAE,OAAO,CAAC;IACjB,KAAK,CAAC,EAAE,OAAO,CAAC;IAChB,gBAAgB,CAAC,EAAE,OAAO,CAAC;IAC3B,OAAO,CAAC,EAAE,OAAO,CAAC;IAClB,WAAW,CAAC,EAAE,OAAO,CAAC;CACvB;AAED,MAAM,WAAW,eAAe;IAC9B,eAAe,EAAE,MAAM,CAAC;IACxB,YAAY,EAAE,MAAM,GAAG,IAAI,CAAC;IAC5B,SAAS,EAAE,GAAG,CAAC,MAAM,EAAE,iBAAiB,CAAC,CAAC;IAC1C,WAAW,EAAE,mBAAmB,EAAE,CAAC;IACnC,KAAK,EAAE;QAAE,YAAY,EAAE,MAAM,CAAC;QAAC,gBAAgB,EAAE,MAAM,CAAC;QAAC,WAAW,EAAE,MAAM,CAAA;KAAE,CAAC;CAChF;AAED,MAAM,WAAW,mBAAmB;IAClC,OAAO,CAAC,EAAE,CAAC,KAAK,EAAE,MAAM,KAAK,IAAI,CAAC;IAClC,OAAO,CAAC,EAAE,CAAC,KAAK,EAAE;QAChB,YAAY,CAAC,EAAE,MAAM,CAAC;QACtB,gBAAgB,CAAC,EAAE,MAAM,CAAC;QAC1B,WAAW,CAAC,EAAE,MAAM,CAAC;KACtB,KAAK,IAAI,CAAC;CACZ;AAoHD,wBAAgB,iBAAiB,IAAI,eAAe,CAQnD;AAED;;;;;;;;;GASG;AACH,wBAAgB,aAAa,CAC3B,MAAM,EAAE,mBAAmB,EAC3B,KAAK,EAAE,eAAe,EACtB,UAAU,EAAE,+BAA+B,EAC3C,OAAO,EAAE,WAAW,EACpB,UAAU,EAAE,MAAM,GAAG,SAAS,EAC9B,SAAS,CAAC,EAAE,mBAAmB,EAC/B,WAAW,CAAC,EAAE,WAAW,GACxB,OAAO,CAAC,IAAI,CAAC,CAqPf"}
|
|
@@ -24,6 +24,24 @@ function normalizeToolInputString(input) {
|
|
|
24
24
|
}
|
|
25
25
|
return JSON.stringify(input ?? null) ?? "null";
|
|
26
26
|
}
|
|
27
|
+
function mergeToolInputDelta(currentArguments, nextDelta) {
|
|
28
|
+
if (currentArguments === "{}" && nextDelta.trimStart().startsWith("{")) {
|
|
29
|
+
return nextDelta;
|
|
30
|
+
}
|
|
31
|
+
return currentArguments + nextDelta;
|
|
32
|
+
}
|
|
33
|
+
function mergeToolCallInput(currentArguments, nextInput) {
|
|
34
|
+
if (currentArguments.length === 0) {
|
|
35
|
+
return nextInput;
|
|
36
|
+
}
|
|
37
|
+
if (nextInput.trim() === "{}" && currentArguments.trim().startsWith("{")) {
|
|
38
|
+
return currentArguments;
|
|
39
|
+
}
|
|
40
|
+
if (currentArguments.trim() === "{}" && nextInput.trim().startsWith("{")) {
|
|
41
|
+
return nextInput;
|
|
42
|
+
}
|
|
43
|
+
return nextInput;
|
|
44
|
+
}
|
|
27
45
|
function normalizeToolInputObject(input) {
|
|
28
46
|
if (isRecord(input)) {
|
|
29
47
|
return input;
|
|
@@ -166,7 +184,7 @@ export function processStream(result, state, controller, encoder, textPartId, ca
|
|
|
166
184
|
const tc = state.toolCalls.get(toolId);
|
|
167
185
|
if (!tc)
|
|
168
186
|
break;
|
|
169
|
-
tc.arguments
|
|
187
|
+
tc.arguments = mergeToolInputDelta(tc.arguments, typedPart.delta);
|
|
170
188
|
sendSSE(controller, encoder, {
|
|
171
189
|
type: "tool-input-delta",
|
|
172
190
|
toolCallId: toolId,
|
|
@@ -178,10 +196,12 @@ export function processStream(result, state, controller, encoder, textPartId, ca
|
|
|
178
196
|
// tool-call fires when the full tool call is available
|
|
179
197
|
const toolId = typedPart.toolCallId;
|
|
180
198
|
const inputStr = normalizeToolInputString(typedPart.input);
|
|
199
|
+
const previousArguments = state.toolCalls.get(toolId)?.arguments ?? "";
|
|
200
|
+
const resolvedArguments = mergeToolCallInput(previousArguments, inputStr);
|
|
181
201
|
state.toolCalls.set(toolId, {
|
|
182
202
|
id: toolId,
|
|
183
203
|
name: typedPart.toolName,
|
|
184
|
-
arguments:
|
|
204
|
+
arguments: resolvedArguments,
|
|
185
205
|
providerExecuted: typedPart.providerExecuted,
|
|
186
206
|
dynamic: typedPart.dynamic,
|
|
187
207
|
});
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"tool-helpers.d.ts","sourceRoot":"","sources":["../../../../src/src/agent/runtime/tool-helpers.ts"],"names":[],"mappings":"AAAA;;;;;;GAMG;AAEH,OAAO,KAAK,EAAE,gBAAgB,EAAE,IAAI,EAAE,cAAc,EAAE,oBAAoB,EAAE,MAAM,qBAAqB,CAAC;AAaxG;;GAEG;AACH,MAAM,WAAW,cAAc;IAC7B,IAAI,EAAE,MAAM,CAAC,MAAM,EAAE,OAAO,CAAC,CAAC;IAC9B,KAAK,CAAC,EAAE,MAAM,CAAC;CAChB;
|
|
1
|
+
{"version":3,"file":"tool-helpers.d.ts","sourceRoot":"","sources":["../../../../src/src/agent/runtime/tool-helpers.ts"],"names":[],"mappings":"AAAA;;;;;;GAMG;AAEH,OAAO,KAAK,EAAE,gBAAgB,EAAE,IAAI,EAAE,cAAc,EAAE,oBAAoB,EAAE,MAAM,qBAAqB,CAAC;AAaxG;;GAEG;AACH,MAAM,WAAW,cAAc;IAC7B,IAAI,EAAE,MAAM,CAAC,MAAM,EAAE,OAAO,CAAC,CAAC;IAC9B,KAAK,CAAC,EAAE,MAAM,CAAC;CAChB;AAYD;;;GAGG;AACH,wBAAgB,aAAa,CAC3B,OAAO,EAAE,MAAM,GAAG,MAAM,CAAC,MAAM,EAAE,OAAO,CAAC,GACxC,cAAc,CAyBhB;AAED;;GAEG;AACH,wBAAgB,aAAa,CAAC,IAAI,EAAE,MAAM,GAAG,OAAO,CAEnD;AAED;;;GAGG;AAEH,MAAM,MAAM,eAAe,GAAG,IAAI,CAAC,GAAG,EAAE,GAAG,CAAC,GAAG,OAAO,CAAC;AAqHvD,wBAAgB,qBAAqB,CACnC,WAAW,EAAE,IAAI,GAAG,MAAM,CAAC,MAAM,EAAE,eAAe,CAAC,GAAG,SAAS,EAC/D,QAAQ,EAAE,MAAM,GACf,IAAI,GAAG,IAAI,CAmBb;AAED,wBAAsB,qBAAqB,CACzC,QAAQ,EAAE,MAAM,EAChB,KAAK,EAAE,MAAM,CAAC,MAAM,EAAE,OAAO,CAAC,EAC9B,WAAW,EAAE,IAAI,GAAG,MAAM,CAAC,MAAM,EAAE,eAAe,CAAC,GAAG,SAAS,EAC/D,OAAO,CAAC,EAAE,oBAAoB,EAC9B,sBAAsB,CAAC,EAAE,MAAM,EAAE,EACjC,iBAAiB,CAAC,EAAE,gBAAgB,EAAE,GACrC,OAAO,CAAC,OAAO,CAAC,CAoClB;AAoBD;;;;;;;GAOG;AACH,wBAAsB,iBAAiB,CACrC,WAAW,EAAE,IAAI,GAAG,MAAM,CAAC,MAAM,EAAE,eAAe,CAAC,GAAG,SAAS,EAC/D,OAAO,CAAC,EAAE;IACR,iBAAiB,CAAC,EAAE,OAAO,CAAC;IAC5B,uBAAuB,CAAC,EAAE,OAAO,CAAC;IAClC,sBAAsB,CAAC,EAAE,MAAM,EAAE,CAAC;IAClC,iBAAiB,CAAC,EAAE,gBAAgB,EAAE,CAAC;IACvC,iBAAiB,CAAC,EAAE,oBAAoB,CAAC;CAC1C,GACA,OAAO,CAAC,cAAc,EAAE,CAAC,CA+E3B"}
|
|
@@ -12,6 +12,13 @@ import { serverLogger } from "../../utils/index.js";
|
|
|
12
12
|
import { createError, toError } from "../../errors/veryfront-error.js";
|
|
13
13
|
import { executeRemoteIntegrationTool, isRemoteIntegrationTool, } from "../../integrations/remote-tools.js";
|
|
14
14
|
const logger = serverLogger.component("agent");
|
|
15
|
+
function stripLeadingEmptyObjectPlaceholder(rawArgs) {
|
|
16
|
+
let normalized = rawArgs.trim();
|
|
17
|
+
while (normalized.startsWith("{}") && normalized.slice(2).trimStart().startsWith("{")) {
|
|
18
|
+
normalized = normalized.slice(2).trimStart();
|
|
19
|
+
}
|
|
20
|
+
return normalized;
|
|
21
|
+
}
|
|
15
22
|
/**
|
|
16
23
|
* Parse tool arguments from raw string or object.
|
|
17
24
|
* Returns parsed args and optional error message.
|
|
@@ -20,10 +27,11 @@ export function parseToolArgs(rawArgs) {
|
|
|
20
27
|
try {
|
|
21
28
|
// Handle empty string or whitespace-only string as empty object
|
|
22
29
|
if (typeof rawArgs === "string") {
|
|
23
|
-
const trimmed = rawArgs
|
|
30
|
+
const trimmed = stripLeadingEmptyObjectPlaceholder(rawArgs);
|
|
24
31
|
if (trimmed === "" || trimmed === "{}") {
|
|
25
32
|
return { args: {} };
|
|
26
33
|
}
|
|
34
|
+
rawArgs = trimmed;
|
|
27
35
|
}
|
|
28
36
|
const parsed = typeof rawArgs === "string" ? JSON.parse(rawArgs) : rawArgs;
|
|
29
37
|
if (!parsed || typeof parsed !== "object" || Array.isArray(parsed)) {
|
|
@@ -1,2 +1,2 @@
|
|
|
1
|
-
export declare const VERSION = "0.1.
|
|
1
|
+
export declare const VERSION = "0.1.187";
|
|
2
2
|
//# sourceMappingURL=version-constant.d.ts.map
|
package/package.json
CHANGED
package/src/deno.js
CHANGED
|
@@ -66,6 +66,30 @@ function normalizeToolInputString(input: unknown): string {
|
|
|
66
66
|
return JSON.stringify(input ?? null) ?? "null";
|
|
67
67
|
}
|
|
68
68
|
|
|
69
|
+
function mergeToolInputDelta(currentArguments: string, nextDelta: string): string {
|
|
70
|
+
if (currentArguments === "{}" && nextDelta.trimStart().startsWith("{")) {
|
|
71
|
+
return nextDelta;
|
|
72
|
+
}
|
|
73
|
+
|
|
74
|
+
return currentArguments + nextDelta;
|
|
75
|
+
}
|
|
76
|
+
|
|
77
|
+
function mergeToolCallInput(currentArguments: string, nextInput: string): string {
|
|
78
|
+
if (currentArguments.length === 0) {
|
|
79
|
+
return nextInput;
|
|
80
|
+
}
|
|
81
|
+
|
|
82
|
+
if (nextInput.trim() === "{}" && currentArguments.trim().startsWith("{")) {
|
|
83
|
+
return currentArguments;
|
|
84
|
+
}
|
|
85
|
+
|
|
86
|
+
if (currentArguments.trim() === "{}" && nextInput.trim().startsWith("{")) {
|
|
87
|
+
return nextInput;
|
|
88
|
+
}
|
|
89
|
+
|
|
90
|
+
return nextInput;
|
|
91
|
+
}
|
|
92
|
+
|
|
69
93
|
function normalizeToolInputObject(input: unknown): Record<string, unknown> {
|
|
70
94
|
if (isRecord(input)) {
|
|
71
95
|
return input;
|
|
@@ -250,7 +274,7 @@ export function processStream(
|
|
|
250
274
|
const tc = state.toolCalls.get(toolId);
|
|
251
275
|
if (!tc) break;
|
|
252
276
|
|
|
253
|
-
tc.arguments
|
|
277
|
+
tc.arguments = mergeToolInputDelta(tc.arguments, typedPart.delta);
|
|
254
278
|
sendSSE(controller, encoder, {
|
|
255
279
|
type: "tool-input-delta",
|
|
256
280
|
toolCallId: toolId,
|
|
@@ -263,10 +287,12 @@ export function processStream(
|
|
|
263
287
|
// tool-call fires when the full tool call is available
|
|
264
288
|
const toolId = typedPart.toolCallId;
|
|
265
289
|
const inputStr = normalizeToolInputString(typedPart.input);
|
|
290
|
+
const previousArguments = state.toolCalls.get(toolId)?.arguments ?? "";
|
|
291
|
+
const resolvedArguments = mergeToolCallInput(previousArguments, inputStr);
|
|
266
292
|
state.toolCalls.set(toolId, {
|
|
267
293
|
id: toolId,
|
|
268
294
|
name: typedPart.toolName,
|
|
269
|
-
arguments:
|
|
295
|
+
arguments: resolvedArguments,
|
|
270
296
|
providerExecuted: typedPart.providerExecuted,
|
|
271
297
|
dynamic: typedPart.dynamic,
|
|
272
298
|
});
|
|
@@ -27,6 +27,16 @@ export interface ParsedToolArgs {
|
|
|
27
27
|
error?: string;
|
|
28
28
|
}
|
|
29
29
|
|
|
30
|
+
function stripLeadingEmptyObjectPlaceholder(rawArgs: string): string {
|
|
31
|
+
let normalized = rawArgs.trim();
|
|
32
|
+
|
|
33
|
+
while (normalized.startsWith("{}") && normalized.slice(2).trimStart().startsWith("{")) {
|
|
34
|
+
normalized = normalized.slice(2).trimStart();
|
|
35
|
+
}
|
|
36
|
+
|
|
37
|
+
return normalized;
|
|
38
|
+
}
|
|
39
|
+
|
|
30
40
|
/**
|
|
31
41
|
* Parse tool arguments from raw string or object.
|
|
32
42
|
* Returns parsed args and optional error message.
|
|
@@ -37,10 +47,12 @@ export function parseToolArgs(
|
|
|
37
47
|
try {
|
|
38
48
|
// Handle empty string or whitespace-only string as empty object
|
|
39
49
|
if (typeof rawArgs === "string") {
|
|
40
|
-
const trimmed = rawArgs
|
|
50
|
+
const trimmed = stripLeadingEmptyObjectPlaceholder(rawArgs);
|
|
41
51
|
if (trimmed === "" || trimmed === "{}") {
|
|
42
52
|
return { args: {} };
|
|
43
53
|
}
|
|
54
|
+
|
|
55
|
+
rawArgs = trimmed;
|
|
44
56
|
}
|
|
45
57
|
|
|
46
58
|
const parsed = typeof rawArgs === "string" ? JSON.parse(rawArgs) : rawArgs;
|