@superblocksteam/vite-plugin-file-sync 2.0.70 → 2.0.71-next.1
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/dist/ai-service/agent/prompts/build-base-system-prompt.js +1 -1
- package/dist/ai-service/agent/subagents/types.d.ts.map +1 -1
- package/dist/ai-service/agent/subagents/types.js +1 -0
- package/dist/ai-service/agent/subagents/types.js.map +1 -1
- package/dist/ai-service/agent/tool-message-utils.d.ts.map +1 -1
- package/dist/ai-service/agent/tool-message-utils.js +5 -0
- package/dist/ai-service/agent/tool-message-utils.js.map +1 -1
- package/dist/ai-service/agent/tools/apis/build-api-artifact.d.ts.map +1 -1
- package/dist/ai-service/agent/tools/apis/build-api-artifact.js +2 -1
- package/dist/ai-service/agent/tools/apis/build-api-artifact.js.map +1 -1
- package/dist/ai-service/agent/tools/apis/sample-json.d.ts +2 -0
- package/dist/ai-service/agent/tools/apis/sample-json.d.ts.map +1 -0
- package/dist/ai-service/agent/tools/apis/sample-json.js +16 -0
- package/dist/ai-service/agent/tools/apis/sample-json.js.map +1 -0
- package/dist/ai-service/agent/tools/apis/test-api.d.ts +4 -4
- package/dist/ai-service/agent/tools/apis/test-api.d.ts.map +1 -1
- package/dist/ai-service/agent/tools/apis/test-api.js +16 -5
- package/dist/ai-service/agent/tools/apis/test-api.js.map +1 -1
- package/dist/ai-service/agent/tools/build-capture-screenshot.d.ts +35 -0
- package/dist/ai-service/agent/tools/build-capture-screenshot.d.ts.map +1 -1
- package/dist/ai-service/agent/tools/build-capture-screenshot.js +90 -15
- package/dist/ai-service/agent/tools/build-capture-screenshot.js.map +1 -1
- package/dist/ai-service/agent/tools/build-validate-icons.d.ts +3 -18
- package/dist/ai-service/agent/tools/build-validate-icons.d.ts.map +1 -1
- package/dist/ai-service/agent/tools/build-validate-icons.js +12 -50
- package/dist/ai-service/agent/tools/build-validate-icons.js.map +1 -1
- package/dist/ai-service/agent/tools/debug-cache.js.map +1 -1
- package/dist/ai-service/agent/tools/integrations/execute-request.d.ts +1 -1
- package/dist/ai-service/agent/tools/shared-helpers.d.ts +0 -35
- package/dist/ai-service/agent/tools/shared-helpers.d.ts.map +1 -1
- package/dist/ai-service/agent/tools/shared-helpers.js +0 -89
- package/dist/ai-service/agent/tools/shared-helpers.js.map +1 -1
- package/dist/ai-service/agent/tools2/access-control.d.ts +1 -23
- package/dist/ai-service/agent/tools2/access-control.d.ts.map +1 -1
- package/dist/ai-service/agent/tools2/access-control.js +3 -68
- package/dist/ai-service/agent/tools2/access-control.js.map +1 -1
- package/dist/ai-service/agent/tools2/registry.d.ts.map +1 -1
- package/dist/ai-service/agent/tools2/registry.js +16 -5
- package/dist/ai-service/agent/tools2/registry.js.map +1 -1
- package/dist/ai-service/agent/tools2/tools/bash.d.ts.map +1 -1
- package/dist/ai-service/agent/tools2/tools/bash.js +2 -1
- package/dist/ai-service/agent/tools2/tools/bash.js.map +1 -1
- package/dist/ai-service/agent/tools2/tools/exit-plan-mode.d.ts.map +1 -1
- package/dist/ai-service/agent/tools2/tools/exit-plan-mode.js +10 -2
- package/dist/ai-service/agent/tools2/tools/exit-plan-mode.js.map +1 -1
- package/dist/ai-service/agent/tools2/tools/grep.d.ts.map +1 -1
- package/dist/ai-service/agent/tools2/tools/grep.js +2 -1
- package/dist/ai-service/agent/tools2/tools/grep.js.map +1 -1
- package/dist/ai-service/agent/tools2/tools/ls.d.ts.map +1 -1
- package/dist/ai-service/agent/tools2/tools/ls.js +3 -1
- package/dist/ai-service/agent/tools2/tools/ls.js.map +1 -1
- package/dist/ai-service/agent/tools2/types.d.ts +2 -1
- package/dist/ai-service/agent/tools2/types.d.ts.map +1 -1
- package/dist/ai-service/agent/tools2/types.js +31 -11
- package/dist/ai-service/agent/tools2/types.js.map +1 -1
- package/dist/ai-service/agent/utils.d.ts.map +1 -1
- package/dist/ai-service/agent/utils.js +5 -10
- package/dist/ai-service/agent/utils.js.map +1 -1
- package/dist/ai-service/clark-provider/clark-chat-settings.d.ts +2 -1
- package/dist/ai-service/clark-provider/clark-chat-settings.d.ts.map +1 -1
- package/dist/ai-service/clark-provider/clark-chat-settings.js +1 -0
- package/dist/ai-service/clark-provider/clark-chat-settings.js.map +1 -1
- package/dist/ai-service/index.d.ts.map +1 -1
- package/dist/ai-service/index.js +7 -4
- package/dist/ai-service/index.js.map +1 -1
- package/dist/ai-service/integrations/store.d.ts +1 -0
- package/dist/ai-service/integrations/store.d.ts.map +1 -1
- package/dist/ai-service/integrations/store.js +1 -0
- package/dist/ai-service/integrations/store.js.map +1 -1
- package/dist/ai-service/llm/client.d.ts +14 -117
- package/dist/ai-service/llm/client.d.ts.map +1 -1
- package/dist/ai-service/llm/client.js +57 -149
- package/dist/ai-service/llm/client.js.map +1 -1
- package/dist/ai-service/llm/error.d.ts +7 -2
- package/dist/ai-service/llm/error.d.ts.map +1 -1
- package/dist/ai-service/llm/error.js +17 -17
- package/dist/ai-service/llm/error.js.map +1 -1
- package/dist/ai-service/llm/impl/anthropic.d.ts.map +1 -1
- package/dist/ai-service/llm/impl/anthropic.js +2 -1
- package/dist/ai-service/llm/impl/anthropic.js.map +1 -1
- package/dist/ai-service/llm/impl/clark.d.ts.map +1 -1
- package/dist/ai-service/llm/impl/clark.js +2 -1
- package/dist/ai-service/llm/impl/clark.js.map +1 -1
- package/dist/ai-service/llm/interaction/index.d.ts +0 -64
- package/dist/ai-service/llm/interaction/index.d.ts.map +1 -1
- package/dist/ai-service/llm/interaction/index.js +0 -65
- package/dist/ai-service/llm/interaction/index.js.map +1 -1
- package/dist/ai-service/llm/provider.d.ts.map +1 -1
- package/dist/ai-service/llm/provider.js +2 -6
- package/dist/ai-service/llm/provider.js.map +1 -1
- package/dist/ai-service/llm/stream/config.d.ts +56 -0
- package/dist/ai-service/llm/stream/config.d.ts.map +1 -0
- package/dist/ai-service/llm/stream/config.js +41 -0
- package/dist/ai-service/llm/stream/config.js.map +1 -0
- package/dist/ai-service/llm/stream/errors.d.ts +16 -0
- package/dist/ai-service/llm/stream/errors.d.ts.map +1 -0
- package/dist/ai-service/llm/stream/errors.js +68 -0
- package/dist/ai-service/llm/stream/errors.js.map +1 -0
- package/dist/ai-service/llm/stream/event-bus.d.ts +68 -0
- package/dist/ai-service/llm/stream/event-bus.d.ts.map +1 -0
- package/dist/ai-service/llm/stream/event-bus.js +51 -0
- package/dist/ai-service/llm/stream/event-bus.js.map +1 -0
- package/dist/ai-service/llm/stream/index.d.ts +49 -0
- package/dist/ai-service/llm/stream/index.d.ts.map +1 -0
- package/dist/ai-service/llm/stream/index.js +46 -0
- package/dist/ai-service/llm/stream/index.js.map +1 -0
- package/dist/ai-service/llm/stream/managed-stream.d.ts +25 -0
- package/dist/ai-service/llm/stream/managed-stream.d.ts.map +1 -0
- package/dist/ai-service/llm/stream/managed-stream.js +68 -0
- package/dist/ai-service/llm/stream/managed-stream.js.map +1 -0
- package/dist/ai-service/llm/stream/observer.d.ts +34 -0
- package/dist/ai-service/llm/stream/observer.d.ts.map +1 -0
- package/dist/ai-service/llm/stream/observer.js +2 -0
- package/dist/ai-service/llm/stream/observer.js.map +1 -0
- package/dist/ai-service/llm/stream/observers/context.d.ts +40 -0
- package/dist/ai-service/llm/stream/observers/context.d.ts.map +1 -0
- package/dist/ai-service/llm/stream/observers/context.js +55 -0
- package/dist/ai-service/llm/stream/observers/context.js.map +1 -0
- package/dist/ai-service/llm/stream/observers/index.d.ts +8 -0
- package/dist/ai-service/llm/stream/observers/index.d.ts.map +1 -0
- package/dist/ai-service/llm/stream/observers/index.js +8 -0
- package/dist/ai-service/llm/stream/observers/index.js.map +1 -0
- package/dist/ai-service/llm/stream/observers/llmobs.d.ts +78 -0
- package/dist/ai-service/llm/stream/observers/llmobs.d.ts.map +1 -0
- package/dist/ai-service/llm/stream/observers/llmobs.js +504 -0
- package/dist/ai-service/llm/stream/observers/llmobs.js.map +1 -0
- package/dist/ai-service/llm/stream/observers/logging.d.ts +46 -0
- package/dist/ai-service/llm/stream/observers/logging.d.ts.map +1 -0
- package/dist/ai-service/llm/stream/observers/logging.js +296 -0
- package/dist/ai-service/llm/stream/observers/logging.js.map +1 -0
- package/dist/ai-service/llm/stream/observers/retry-notification.d.ts +17 -0
- package/dist/ai-service/llm/stream/observers/retry-notification.d.ts.map +1 -0
- package/dist/ai-service/llm/stream/observers/retry-notification.js +36 -0
- package/dist/ai-service/llm/stream/observers/retry-notification.js.map +1 -0
- package/dist/ai-service/llm/stream/orchestrator.d.ts +73 -0
- package/dist/ai-service/llm/stream/orchestrator.d.ts.map +1 -0
- package/dist/ai-service/llm/stream/orchestrator.js +285 -0
- package/dist/ai-service/llm/stream/orchestrator.js.map +1 -0
- package/dist/ai-service/llm/stream/retry-engine.d.ts +58 -0
- package/dist/ai-service/llm/stream/retry-engine.d.ts.map +1 -0
- package/dist/ai-service/llm/stream/retry-engine.js +151 -0
- package/dist/ai-service/llm/stream/retry-engine.js.map +1 -0
- package/dist/ai-service/llm/stream/session.d.ts +58 -0
- package/dist/ai-service/llm/stream/session.d.ts.map +1 -0
- package/dist/ai-service/llm/stream/session.js +116 -0
- package/dist/ai-service/llm/stream/session.js.map +1 -0
- package/dist/ai-service/llm/stream/tests/helpers/mock-provider.d.ts +129 -0
- package/dist/ai-service/llm/stream/tests/helpers/mock-provider.d.ts.map +1 -0
- package/dist/ai-service/llm/stream/tests/helpers/mock-provider.js +508 -0
- package/dist/ai-service/llm/stream/tests/helpers/mock-provider.js.map +1 -0
- package/dist/ai-service/llm/stream/types.d.ts +15 -0
- package/dist/ai-service/llm/stream/types.d.ts.map +1 -0
- package/dist/ai-service/llm/stream/types.js +2 -0
- package/dist/ai-service/llm/stream/types.js.map +1 -0
- package/dist/ai-service/llm/types.d.ts +1 -1
- package/dist/ai-service/llm/types.d.ts.map +1 -1
- package/dist/ai-service/llmobs/helpers.d.ts +0 -19
- package/dist/ai-service/llmobs/helpers.d.ts.map +1 -1
- package/dist/ai-service/llmobs/helpers.js +0 -23
- package/dist/ai-service/llmobs/helpers.js.map +1 -1
- package/dist/ai-service/llmobs/tracer.d.ts +1 -0
- package/dist/ai-service/llmobs/tracer.d.ts.map +1 -1
- package/dist/ai-service/llmobs/tracer.js +1 -0
- package/dist/ai-service/llmobs/tracer.js.map +1 -1
- package/dist/ai-service/llmobs/types.d.ts +2 -0
- package/dist/ai-service/llmobs/types.d.ts.map +1 -1
- package/dist/ai-service/llmobs/utils.d.ts.map +1 -1
- package/dist/ai-service/llmobs/utils.js +8 -0
- package/dist/ai-service/llmobs/utils.js.map +1 -1
- package/dist/ai-service/mcp/playwright-server.d.ts.map +1 -1
- package/dist/ai-service/mcp/playwright-server.js.map +1 -1
- package/dist/ai-service/state-machine/clark-fsm.d.ts +1 -3
- package/dist/ai-service/state-machine/clark-fsm.d.ts.map +1 -1
- package/dist/ai-service/state-machine/clark-fsm.js +6 -28
- package/dist/ai-service/state-machine/clark-fsm.js.map +1 -1
- package/dist/ai-service/state-machine/handlers/agent-planning.d.ts.map +1 -1
- package/dist/ai-service/state-machine/handlers/agent-planning.js +9 -11
- package/dist/ai-service/state-machine/handlers/agent-planning.js.map +1 -1
- package/dist/ai-service/state-machine/handlers/awaiting-user.d.ts.map +1 -1
- package/dist/ai-service/state-machine/handlers/awaiting-user.js +3 -2
- package/dist/ai-service/state-machine/handlers/awaiting-user.js.map +1 -1
- package/dist/ai-service/state-machine/handlers/llm-generating.d.ts.map +1 -1
- package/dist/ai-service/state-machine/handlers/llm-generating.js +18 -4
- package/dist/ai-service/state-machine/handlers/llm-generating.js.map +1 -1
- package/dist/ai-service/state-machine/traced-fsm.d.ts +5 -4
- package/dist/ai-service/state-machine/traced-fsm.d.ts.map +1 -1
- package/dist/ai-service/state-machine/traced-fsm.js +25 -25
- package/dist/ai-service/state-machine/traced-fsm.js.map +1 -1
- package/dist/ai-service/types.d.ts +3 -3
- package/dist/ai-service/types.d.ts.map +1 -1
- package/dist/ai-service/types.js +10 -10
- package/dist/ai-service/types.js.map +1 -1
- package/dist/socket-manager.d.ts.map +1 -1
- package/dist/socket-manager.js +10 -3
- package/dist/socket-manager.js.map +1 -1
- package/dist/source-tracker.d.ts.map +1 -1
- package/dist/source-tracker.js +8 -0
- package/dist/source-tracker.js.map +1 -1
- package/dist/sync-service/index.d.ts +7 -2
- package/dist/sync-service/index.d.ts.map +1 -1
- package/dist/sync-service/index.js +16 -9
- package/dist/sync-service/index.js.map +1 -1
- package/package.json +11 -11
- package/dist/ai-service/llm/interaction/compose.d.ts +0 -71
- package/dist/ai-service/llm/interaction/compose.d.ts.map +0 -1
- package/dist/ai-service/llm/interaction/compose.js +0 -88
- package/dist/ai-service/llm/interaction/compose.js.map +0 -1
- package/dist/ai-service/llm/interaction/middleware.d.ts +0 -52
- package/dist/ai-service/llm/interaction/middleware.d.ts.map +0 -1
- package/dist/ai-service/llm/interaction/middleware.js +0 -17
- package/dist/ai-service/llm/interaction/middleware.js.map +0 -1
- package/dist/ai-service/llm/interaction/middlewares/llmobs.d.ts +0 -45
- package/dist/ai-service/llm/interaction/middlewares/llmobs.d.ts.map +0 -1
- package/dist/ai-service/llm/interaction/middlewares/llmobs.js +0 -85
- package/dist/ai-service/llm/interaction/middlewares/llmobs.js.map +0 -1
- package/dist/ai-service/llm/interaction/middlewares/logging.d.ts +0 -88
- package/dist/ai-service/llm/interaction/middlewares/logging.d.ts.map +0 -1
- package/dist/ai-service/llm/interaction/middlewares/logging.js +0 -238
- package/dist/ai-service/llm/interaction/middlewares/logging.js.map +0 -1
- package/dist/ai-service/llm/interaction/middlewares/profiler.d.ts +0 -47
- package/dist/ai-service/llm/interaction/middlewares/profiler.d.ts.map +0 -1
- package/dist/ai-service/llm/interaction/middlewares/profiler.js +0 -183
- package/dist/ai-service/llm/interaction/middlewares/profiler.js.map +0 -1
- package/dist/ai-service/llm/interaction/middlewares/stream-retry.d.ts +0 -115
- package/dist/ai-service/llm/interaction/middlewares/stream-retry.d.ts.map +0 -1
- package/dist/ai-service/llm/interaction/middlewares/stream-retry.js +0 -231
- package/dist/ai-service/llm/interaction/middlewares/stream-retry.js.map +0 -1
- package/dist/ai-service/llm/interaction/middlewares/utils/abort.d.ts +0 -41
- package/dist/ai-service/llm/interaction/middlewares/utils/abort.d.ts.map +0 -1
- package/dist/ai-service/llm/interaction/middlewares/utils/abort.js +0 -74
- package/dist/ai-service/llm/interaction/middlewares/utils/abort.js.map +0 -1
- package/dist/ai-service/llm/interaction/middlewares/utils/fallback-chain.d.ts +0 -61
- package/dist/ai-service/llm/interaction/middlewares/utils/fallback-chain.d.ts.map +0 -1
- package/dist/ai-service/llm/interaction/middlewares/utils/fallback-chain.js +0 -116
- package/dist/ai-service/llm/interaction/middlewares/utils/fallback-chain.js.map +0 -1
- package/dist/ai-service/llm/interaction/middlewares/utils/retries.d.ts +0 -47
- package/dist/ai-service/llm/interaction/middlewares/utils/retries.d.ts.map +0 -1
- package/dist/ai-service/llm/interaction/middlewares/utils/retries.js +0 -141
- package/dist/ai-service/llm/interaction/middlewares/utils/retries.js.map +0 -1
- package/dist/ai-service/llm/interaction/middlewares/utils/stall-detector.d.ts +0 -30
- package/dist/ai-service/llm/interaction/middlewares/utils/stall-detector.d.ts.map +0 -1
- package/dist/ai-service/llm/interaction/middlewares/utils/stall-detector.js +0 -36
- package/dist/ai-service/llm/interaction/middlewares/utils/stall-detector.js.map +0 -1
- package/dist/ai-service/llm/interaction/middlewares/utils/streams.d.ts +0 -42
- package/dist/ai-service/llm/interaction/middlewares/utils/streams.d.ts.map +0 -1
- package/dist/ai-service/llm/interaction/middlewares/utils/streams.js +0 -208
- package/dist/ai-service/llm/interaction/middlewares/utils/streams.js.map +0 -1
- package/dist/ai-service/llmobs/middleware/stream-text.d.ts +0 -56
- package/dist/ai-service/llmobs/middleware/stream-text.d.ts.map +0 -1
- package/dist/ai-service/llmobs/middleware/stream-text.js +0 -597
- package/dist/ai-service/llmobs/middleware/stream-text.js.map +0 -1
|
@@ -0,0 +1,296 @@
|
|
|
1
|
+
import { safeJsonStringify } from "../../../util/safe-stringify.js";
|
|
2
|
+
const SECTION_WIDTH = 72;
|
|
3
|
+
const SECTION_CHAR = "-";
|
|
4
|
+
const MAX_IO_BYTES = 2 * 1024;
|
|
5
|
+
function formatSection(title) {
|
|
6
|
+
const prefix = `${SECTION_CHAR.repeat(6)} ${title} `;
|
|
7
|
+
const remaining = Math.max(0, SECTION_WIDTH - prefix.length);
|
|
8
|
+
return prefix + SECTION_CHAR.repeat(remaining);
|
|
9
|
+
}
|
|
10
|
+
function truncateString(s, maxBytes) {
|
|
11
|
+
if (s.length <= maxBytes) {
|
|
12
|
+
return { text: s, truncated: false, omittedBytes: 0 };
|
|
13
|
+
}
|
|
14
|
+
const omittedBytes = s.length - maxBytes;
|
|
15
|
+
return {
|
|
16
|
+
text: s.slice(0, maxBytes) + `\n... [truncated ${omittedBytes} bytes]`,
|
|
17
|
+
truncated: true,
|
|
18
|
+
omittedBytes,
|
|
19
|
+
};
|
|
20
|
+
}
|
|
21
|
+
function isEmptyJsonObject(value) {
|
|
22
|
+
if (value === null || value === undefined)
|
|
23
|
+
return true;
|
|
24
|
+
if (typeof value === "object" && Object.keys(value).length === 0)
|
|
25
|
+
return true;
|
|
26
|
+
return false;
|
|
27
|
+
}
|
|
28
|
+
function formatIoBlock(label, value) {
|
|
29
|
+
if (isEmptyJsonObject(value)) {
|
|
30
|
+
return "";
|
|
31
|
+
}
|
|
32
|
+
const jsonStr = safeJsonStringify(value, 2);
|
|
33
|
+
const { text } = truncateString(jsonStr, MAX_IO_BYTES);
|
|
34
|
+
const indented = text
|
|
35
|
+
.split("\n")
|
|
36
|
+
.map((line) => ` ${line}`)
|
|
37
|
+
.join("\n");
|
|
38
|
+
return ` ${label}:\n${indented}\n`;
|
|
39
|
+
}
|
|
40
|
+
/**
|
|
41
|
+
* Observer that captures detailed logs of LLM interactions.
|
|
42
|
+
*
|
|
43
|
+
* @example
|
|
44
|
+
* ```typescript
|
|
45
|
+
* const logRef = { content: "" };
|
|
46
|
+
* const observer = new LoggingObserver({ logRef });
|
|
47
|
+
* // Access logs during streaming: console.log(logRef.content)
|
|
48
|
+
* ```
|
|
49
|
+
*/
|
|
50
|
+
export class LoggingObserver {
|
|
51
|
+
logRef;
|
|
52
|
+
sessionStartTime;
|
|
53
|
+
currentTextBuffer = "";
|
|
54
|
+
currentReasoningBuffer = "";
|
|
55
|
+
reasoningLoggedViaChunks = false;
|
|
56
|
+
constructor(options = {}) {
|
|
57
|
+
this.logRef = options.logRef ?? { content: "" };
|
|
58
|
+
}
|
|
59
|
+
attach(events, config) {
|
|
60
|
+
if (!config.logging.enabled) {
|
|
61
|
+
return;
|
|
62
|
+
}
|
|
63
|
+
events.on("session:start", (session, request) => {
|
|
64
|
+
this.onSessionStart(session, config);
|
|
65
|
+
if (request) {
|
|
66
|
+
this.onRequestStart(request);
|
|
67
|
+
}
|
|
68
|
+
});
|
|
69
|
+
events.on("chunk", (chunk, _session) => {
|
|
70
|
+
this.onChunk(chunk);
|
|
71
|
+
});
|
|
72
|
+
events.on("step:complete", (step, _session) => {
|
|
73
|
+
this.onStepComplete(step);
|
|
74
|
+
});
|
|
75
|
+
events.on("retry", (error, attempt, delayMs, _session) => {
|
|
76
|
+
this.onRetry(error, attempt, delayMs);
|
|
77
|
+
});
|
|
78
|
+
events.on("fallback", (from, to, reason) => {
|
|
79
|
+
this.onFallback(from, to, reason);
|
|
80
|
+
});
|
|
81
|
+
events.on("stream:finish", (result, _session) => {
|
|
82
|
+
this.onStreamFinish(result);
|
|
83
|
+
});
|
|
84
|
+
events.on("session:complete", (session) => {
|
|
85
|
+
void this.onSessionComplete(session, config);
|
|
86
|
+
});
|
|
87
|
+
events.on("session:error", (error, session) => {
|
|
88
|
+
void this.onSessionError(error, session, config);
|
|
89
|
+
});
|
|
90
|
+
events.on("session:abort", (session) => {
|
|
91
|
+
void this.onSessionAbort(session, config);
|
|
92
|
+
});
|
|
93
|
+
}
|
|
94
|
+
onSessionStart(session, config) {
|
|
95
|
+
this.sessionStartTime = Date.now();
|
|
96
|
+
const conversationId = config.logging.conversationId ?? session.id;
|
|
97
|
+
const timestamp = new Date().toISOString();
|
|
98
|
+
this.logRef.content += formatSection("LLM CONVERSATION START") + "\n";
|
|
99
|
+
this.logRef.content += `Session ID: ${conversationId}\n`;
|
|
100
|
+
this.logRef.content += `Timestamp: ${timestamp}\n`;
|
|
101
|
+
this.logRef.content += `Provider: ${session.provider.name}\n`;
|
|
102
|
+
this.logRef.content += `Model: ${session.provider.model}\n`;
|
|
103
|
+
const metadata = config.logging.metadata;
|
|
104
|
+
if (metadata && Object.keys(metadata).length > 0) {
|
|
105
|
+
for (const [k, v] of Object.entries(metadata)) {
|
|
106
|
+
if (typeof v === "object") {
|
|
107
|
+
this.logRef.content += `${k}: ${safeJsonStringify(v)}\n`;
|
|
108
|
+
}
|
|
109
|
+
else {
|
|
110
|
+
this.logRef.content += `${k}: ${v}\n`;
|
|
111
|
+
}
|
|
112
|
+
}
|
|
113
|
+
}
|
|
114
|
+
this.logRef.content += "\n";
|
|
115
|
+
this.logRef.content += formatSection("TRANSCRIPT") + "\n";
|
|
116
|
+
this.currentTextBuffer = "";
|
|
117
|
+
this.currentReasoningBuffer = "";
|
|
118
|
+
this.reasoningLoggedViaChunks = false;
|
|
119
|
+
}
|
|
120
|
+
onRequestStart(payload) {
|
|
121
|
+
const lastUserMessage = [...payload.messages]
|
|
122
|
+
.reverse()
|
|
123
|
+
.find((m) => m.role === "user");
|
|
124
|
+
if (!lastUserMessage)
|
|
125
|
+
return;
|
|
126
|
+
let userText;
|
|
127
|
+
if (typeof lastUserMessage.content === "string") {
|
|
128
|
+
userText = lastUserMessage.content;
|
|
129
|
+
}
|
|
130
|
+
else if (Array.isArray(lastUserMessage.content)) {
|
|
131
|
+
userText = lastUserMessage.content
|
|
132
|
+
.filter((p) => p.type === "text")
|
|
133
|
+
.map((p) => p.text)
|
|
134
|
+
.join("\n");
|
|
135
|
+
}
|
|
136
|
+
else {
|
|
137
|
+
return;
|
|
138
|
+
}
|
|
139
|
+
if (userText) {
|
|
140
|
+
this.logRef.content += `USER:\n${userText}\n\n`;
|
|
141
|
+
}
|
|
142
|
+
}
|
|
143
|
+
onChunk(chunk) {
|
|
144
|
+
switch (chunk.type) {
|
|
145
|
+
case "text-delta":
|
|
146
|
+
this.currentTextBuffer += chunk.text;
|
|
147
|
+
break;
|
|
148
|
+
case "text-end":
|
|
149
|
+
this.flushTextBuffer();
|
|
150
|
+
break;
|
|
151
|
+
case "reasoning-delta":
|
|
152
|
+
this.currentReasoningBuffer += chunk.text;
|
|
153
|
+
break;
|
|
154
|
+
case "reasoning-end":
|
|
155
|
+
this.flushReasoningBuffer();
|
|
156
|
+
break;
|
|
157
|
+
case "tool-call":
|
|
158
|
+
this.flushTextBuffer();
|
|
159
|
+
this.flushReasoningBuffer();
|
|
160
|
+
this.formatToolCall(chunk);
|
|
161
|
+
break;
|
|
162
|
+
case "tool-result":
|
|
163
|
+
this.formatToolResult(chunk);
|
|
164
|
+
break;
|
|
165
|
+
case "error": {
|
|
166
|
+
this.flushTextBuffer();
|
|
167
|
+
this.flushReasoningBuffer();
|
|
168
|
+
const errorMsg = chunk.error instanceof Error
|
|
169
|
+
? chunk.error.message
|
|
170
|
+
: String(chunk.error);
|
|
171
|
+
this.logRef.content += `ERROR:\n${errorMsg}\n\n`;
|
|
172
|
+
break;
|
|
173
|
+
}
|
|
174
|
+
// Ignore other chunk types (text-start, reasoning-start, finish, etc.)
|
|
175
|
+
}
|
|
176
|
+
}
|
|
177
|
+
flushTextBuffer() {
|
|
178
|
+
if (this.currentTextBuffer.trim()) {
|
|
179
|
+
this.logRef.content += `ASSISTANT:\n${this.currentTextBuffer.trim()}\n\n`;
|
|
180
|
+
}
|
|
181
|
+
this.currentTextBuffer = "";
|
|
182
|
+
}
|
|
183
|
+
flushReasoningBuffer() {
|
|
184
|
+
if (this.currentReasoningBuffer.trim()) {
|
|
185
|
+
this.logRef.content += `REASONING:\n${this.currentReasoningBuffer.trim()}\n\n`;
|
|
186
|
+
this.reasoningLoggedViaChunks = true;
|
|
187
|
+
}
|
|
188
|
+
this.currentReasoningBuffer = "";
|
|
189
|
+
}
|
|
190
|
+
formatToolCall(chunk) {
|
|
191
|
+
this.logRef.content += `TOOL ${chunk.toolName}:\n`;
|
|
192
|
+
const args = chunk.input ?? chunk.args;
|
|
193
|
+
const inBlock = formatIoBlock("IN", args);
|
|
194
|
+
if (inBlock) {
|
|
195
|
+
this.logRef.content += inBlock;
|
|
196
|
+
}
|
|
197
|
+
}
|
|
198
|
+
formatToolResult(chunk) {
|
|
199
|
+
// SDK uses 'output' for tool-result chunks, but some tests may use 'result'
|
|
200
|
+
const result = chunk.output ?? chunk.result;
|
|
201
|
+
const outBlock = formatIoBlock("OUT", result);
|
|
202
|
+
if (outBlock) {
|
|
203
|
+
this.logRef.content += outBlock;
|
|
204
|
+
}
|
|
205
|
+
this.logRef.content += "\n";
|
|
206
|
+
}
|
|
207
|
+
onStepComplete(step) {
|
|
208
|
+
if (step.reasoningText && !this.reasoningLoggedViaChunks) {
|
|
209
|
+
this.logRef.content += `REASONING:\n${step.reasoningText}\n\n`;
|
|
210
|
+
}
|
|
211
|
+
this.reasoningLoggedViaChunks = false;
|
|
212
|
+
}
|
|
213
|
+
onRetry(error, attempt, delayMs) {
|
|
214
|
+
const errorMessage = error instanceof Error ? error.message : String(error);
|
|
215
|
+
this.logRef.content += `RETRY:\nattempt=${attempt} delay=${delayMs}ms error="${errorMessage}"\n\n`;
|
|
216
|
+
}
|
|
217
|
+
onFallback(from, to, reason) {
|
|
218
|
+
this.logRef.content += `FALLBACK:\n${from.name}/${from.model} -> ${to.name}/${to.model} reason=${reason}\n\n`;
|
|
219
|
+
}
|
|
220
|
+
onStreamFinish(result) {
|
|
221
|
+
this.flushTextBuffer();
|
|
222
|
+
this.flushReasoningBuffer();
|
|
223
|
+
this.logRef.content += "\n";
|
|
224
|
+
this.logRef.content += formatSection("USAGE") + "\n";
|
|
225
|
+
const usage = result.totalUsage;
|
|
226
|
+
if (usage) {
|
|
227
|
+
let usageLine = `Tokens: Input=${usage.inputTokens ?? 0} Output=${usage.outputTokens ?? 0} Total=${usage.totalTokens ?? 0}`;
|
|
228
|
+
if ((usage.cachedInputTokens ?? 0) > 0) {
|
|
229
|
+
usageLine += ` Cached=${usage.cachedInputTokens}`;
|
|
230
|
+
}
|
|
231
|
+
this.logRef.content += usageLine + "\n";
|
|
232
|
+
}
|
|
233
|
+
this.logRef.content += `Finish reason: ${result.finishReason}\n`;
|
|
234
|
+
this.logRef.content += `Total Steps: ${result.steps.length}\n`;
|
|
235
|
+
}
|
|
236
|
+
async onSessionComplete(session, config) {
|
|
237
|
+
const duration = this.computeDuration(session);
|
|
238
|
+
this.logRef.content += "\n";
|
|
239
|
+
this.logRef.content += formatSection("LLM CONVERSATION COMPLETE") + "\n";
|
|
240
|
+
this.logRef.content += `End Timestamp: ${new Date().toISOString()}\n`;
|
|
241
|
+
this.logRef.content += `Duration: ${duration}ms\n`;
|
|
242
|
+
this.logRef.content += `Chunks: ${session.metrics.chunkCount}\n`;
|
|
243
|
+
this.logRef.content += `Retries: ${session.metrics.retryCount}\n`;
|
|
244
|
+
await this.saveLog(session, config);
|
|
245
|
+
}
|
|
246
|
+
async onSessionError(error, session, config) {
|
|
247
|
+
const duration = this.computeDuration(session);
|
|
248
|
+
const errorMessage = error instanceof Error ? error.message : String(error);
|
|
249
|
+
this.logRef.content += "\n";
|
|
250
|
+
this.logRef.content += formatSection("LLM CONVERSATION ERROR") + "\n";
|
|
251
|
+
this.logRef.content += `Error Timestamp: ${new Date().toISOString()}\n`;
|
|
252
|
+
this.logRef.content += `Error: ${errorMessage}\n`;
|
|
253
|
+
this.logRef.content += `Duration: ${duration}ms\n`;
|
|
254
|
+
await this.saveLog(session, config);
|
|
255
|
+
}
|
|
256
|
+
async onSessionAbort(session, config) {
|
|
257
|
+
const duration = this.computeDuration(session);
|
|
258
|
+
this.logRef.content += "\n";
|
|
259
|
+
this.logRef.content += formatSection("LLM CONVERSATION ABORTED") + "\n";
|
|
260
|
+
this.logRef.content += `Abort Timestamp: ${new Date().toISOString()}\n`;
|
|
261
|
+
this.logRef.content += `Duration: ${duration}ms\n`;
|
|
262
|
+
await this.saveLog(session, config);
|
|
263
|
+
}
|
|
264
|
+
computeDuration(session) {
|
|
265
|
+
if (session.metrics.durationMs > 0) {
|
|
266
|
+
return session.metrics.durationMs;
|
|
267
|
+
}
|
|
268
|
+
if (this.sessionStartTime) {
|
|
269
|
+
return Date.now() - this.sessionStartTime;
|
|
270
|
+
}
|
|
271
|
+
return 0;
|
|
272
|
+
}
|
|
273
|
+
async saveLog(session, config) {
|
|
274
|
+
if (!config.logging.saveArtifact) {
|
|
275
|
+
return;
|
|
276
|
+
}
|
|
277
|
+
try {
|
|
278
|
+
const conversationId = config.logging.conversationId ?? session.id;
|
|
279
|
+
const artifact = {
|
|
280
|
+
type: "file",
|
|
281
|
+
filePath: `llm-conversation-${conversationId}.log`,
|
|
282
|
+
content: this.logRef.content,
|
|
283
|
+
};
|
|
284
|
+
const stepId = `llm-conversation-${conversationId}`;
|
|
285
|
+
const runTimestamp = new Date().toISOString();
|
|
286
|
+
await config.logging.saveArtifact(artifact, stepId, runTimestamp);
|
|
287
|
+
}
|
|
288
|
+
catch {
|
|
289
|
+
console.error("Failed to save LLM conversation log");
|
|
290
|
+
}
|
|
291
|
+
}
|
|
292
|
+
getLogContent() {
|
|
293
|
+
return this.logRef.content;
|
|
294
|
+
}
|
|
295
|
+
}
|
|
296
|
+
//# sourceMappingURL=logging.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"logging.js","sourceRoot":"","sources":["../../../../../src/ai-service/llm/stream/observers/logging.ts"],"names":[],"mappings":"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"}
|
|
@@ -0,0 +1,17 @@
|
|
|
1
|
+
import type { EditorClient } from "../../../types.js";
|
|
2
|
+
import type { StreamConfig } from "../config.js";
|
|
3
|
+
import type { StreamEventBus } from "../event-bus.js";
|
|
4
|
+
import type { StreamObserver } from "../observer.js";
|
|
5
|
+
export interface RetryNotificationOptions {
|
|
6
|
+
peer?: EditorClient;
|
|
7
|
+
notifyAfterMs?: number;
|
|
8
|
+
}
|
|
9
|
+
export declare class RetryNotificationObserver implements StreamObserver {
|
|
10
|
+
private readonly peer?;
|
|
11
|
+
private readonly notifyAfterMs;
|
|
12
|
+
private hasNotified;
|
|
13
|
+
constructor(options?: RetryNotificationOptions);
|
|
14
|
+
attach(events: StreamEventBus, _config: StreamConfig): void;
|
|
15
|
+
private handleRetry;
|
|
16
|
+
}
|
|
17
|
+
//# sourceMappingURL=retry-notification.d.ts.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"retry-notification.d.ts","sourceRoot":"","sources":["../../../../../src/ai-service/llm/stream/observers/retry-notification.ts"],"names":[],"mappings":"AAAA,OAAO,KAAK,EAAE,YAAY,EAAE,MAAM,mBAAmB,CAAC;AACtD,OAAO,KAAK,EAAE,YAAY,EAAE,MAAM,cAAc,CAAC;AACjD,OAAO,KAAK,EAAE,cAAc,EAAE,MAAM,iBAAiB,CAAC;AACtD,OAAO,KAAK,EAAE,cAAc,EAAE,MAAM,gBAAgB,CAAC;AAGrD,MAAM,WAAW,wBAAwB;IACvC,IAAI,CAAC,EAAE,YAAY,CAAC;IACpB,aAAa,CAAC,EAAE,MAAM,CAAC;CACxB;AAED,qBAAa,yBAA0B,YAAW,cAAc;IAC9D,OAAO,CAAC,QAAQ,CAAC,IAAI,CAAC,CAAe;IACrC,OAAO,CAAC,QAAQ,CAAC,aAAa,CAAS;IACvC,OAAO,CAAC,WAAW,CAAS;gBAEhB,OAAO,GAAE,wBAA6B;IAKlD,MAAM,CAAC,MAAM,EAAE,cAAc,EAAE,OAAO,EAAE,YAAY,GAAG,IAAI;IAU3D,OAAO,CAAC,WAAW;CAsBpB"}
|
|
@@ -0,0 +1,36 @@
|
|
|
1
|
+
export class RetryNotificationObserver {
|
|
2
|
+
peer;
|
|
3
|
+
notifyAfterMs;
|
|
4
|
+
hasNotified = false;
|
|
5
|
+
constructor(options = {}) {
|
|
6
|
+
this.peer = options.peer;
|
|
7
|
+
this.notifyAfterMs = options.notifyAfterMs ?? 5000;
|
|
8
|
+
}
|
|
9
|
+
attach(events, _config) {
|
|
10
|
+
events.on("retry", (_error, _attempt, delayMs, session) => {
|
|
11
|
+
this.handleRetry(delayMs, session);
|
|
12
|
+
});
|
|
13
|
+
events.on("session:start", () => {
|
|
14
|
+
this.hasNotified = false;
|
|
15
|
+
});
|
|
16
|
+
}
|
|
17
|
+
handleRetry(delayMs, session) {
|
|
18
|
+
if (!this.peer) {
|
|
19
|
+
return;
|
|
20
|
+
}
|
|
21
|
+
const totalRetryTimeMs = session.getElapsedMs();
|
|
22
|
+
if (totalRetryTimeMs < this.notifyAfterMs) {
|
|
23
|
+
return;
|
|
24
|
+
}
|
|
25
|
+
if (this.hasNotified) {
|
|
26
|
+
return;
|
|
27
|
+
}
|
|
28
|
+
this.hasNotified = true;
|
|
29
|
+
const delaySeconds = Math.round(delayMs / 1000);
|
|
30
|
+
void this.peer.call.aiPushMessage({
|
|
31
|
+
type: "text",
|
|
32
|
+
text: `Hmmm, I'm having trouble connecting to the model provider. Trying again in ${delaySeconds} seconds...`,
|
|
33
|
+
});
|
|
34
|
+
}
|
|
35
|
+
}
|
|
36
|
+
//# sourceMappingURL=retry-notification.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"retry-notification.js","sourceRoot":"","sources":["../../../../../src/ai-service/llm/stream/observers/retry-notification.ts"],"names":[],"mappings":"AAWA,MAAM,OAAO,yBAAyB;IACnB,IAAI,CAAgB;IACpB,aAAa,CAAS;IAC/B,WAAW,GAAG,KAAK,CAAC;IAE5B,YAAY,UAAoC,EAAE;QAChD,IAAI,CAAC,IAAI,GAAG,OAAO,CAAC,IAAI,CAAC;QACzB,IAAI,CAAC,aAAa,GAAG,OAAO,CAAC,aAAa,IAAI,IAAI,CAAC;IACrD,CAAC;IAED,MAAM,CAAC,MAAsB,EAAE,OAAqB;QAClD,MAAM,CAAC,EAAE,CAAC,OAAO,EAAE,CAAC,MAAM,EAAE,QAAQ,EAAE,OAAO,EAAE,OAAO,EAAE,EAAE;YACxD,IAAI,CAAC,WAAW,CAAC,OAAO,EAAE,OAAO,CAAC,CAAC;QACrC,CAAC,CAAC,CAAC;QAEH,MAAM,CAAC,EAAE,CAAC,eAAe,EAAE,GAAG,EAAE;YAC9B,IAAI,CAAC,WAAW,GAAG,KAAK,CAAC;QAC3B,CAAC,CAAC,CAAC;IACL,CAAC;IAEO,WAAW,CAAC,OAAe,EAAE,OAAsB;QACzD,IAAI,CAAC,IAAI,CAAC,IAAI,EAAE,CAAC;YACf,OAAO;QACT,CAAC;QAED,MAAM,gBAAgB,GAAG,OAAO,CAAC,YAAY,EAAE,CAAC;QAEhD,IAAI,gBAAgB,GAAG,IAAI,CAAC,aAAa,EAAE,CAAC;YAC1C,OAAO;QACT,CAAC;QAED,IAAI,IAAI,CAAC,WAAW,EAAE,CAAC;YACrB,OAAO;QACT,CAAC;QAED,IAAI,CAAC,WAAW,GAAG,IAAI,CAAC;QACxB,MAAM,YAAY,GAAG,IAAI,CAAC,KAAK,CAAC,OAAO,GAAG,IAAI,CAAC,CAAC;QAChD,KAAK,IAAI,CAAC,IAAI,CAAC,IAAI,CAAC,aAAa,CAAC;YAChC,IAAI,EAAE,MAAM;YACZ,IAAI,EAAE,8EAA8E,YAAY,aAAa;SAC9G,CAAC,CAAC;IACL,CAAC;CACF"}
|
|
@@ -0,0 +1,73 @@
|
|
|
1
|
+
import type { StreamConfig } from "./config.js";
|
|
2
|
+
import type { StreamObserver } from "./observer.js";
|
|
3
|
+
import type { Logger } from "../../../util/logger.js";
|
|
4
|
+
import type { Tool } from "../../agent/tools2/types.js";
|
|
5
|
+
import type { StreamTextProvider, StreamTextOptions, StreamTextResult } from "../interaction/provider.js";
|
|
6
|
+
export interface StreamOrchestratorOptions {
|
|
7
|
+
provider: StreamTextProvider;
|
|
8
|
+
config: StreamConfig;
|
|
9
|
+
observers?: StreamObserver[];
|
|
10
|
+
logger: Logger;
|
|
11
|
+
}
|
|
12
|
+
export type OrchestratorStreamTextOptions<TOOLS extends Record<string, Tool>> = StreamTextOptions<TOOLS> & {
|
|
13
|
+
abortSignal?: AbortSignal;
|
|
14
|
+
};
|
|
15
|
+
/**
|
|
16
|
+
* The main coordinator for stream operations.
|
|
17
|
+
*
|
|
18
|
+
* Brings together all components:
|
|
19
|
+
* - StreamSession for state management
|
|
20
|
+
* - RetryEngine for retry/fallback decisions
|
|
21
|
+
* - ManagedStream for lifecycle tracking
|
|
22
|
+
* - Observers for side effects
|
|
23
|
+
*
|
|
24
|
+
* @example
|
|
25
|
+
* ```typescript
|
|
26
|
+
* const orchestrator = new StreamOrchestrator({
|
|
27
|
+
* provider: createVercelProvider(),
|
|
28
|
+
* config: StreamConfig.create({ retry: { maxAttempts: 3 } }),
|
|
29
|
+
* observers: [new LoggingObserver()],
|
|
30
|
+
* logger: getLogger(),
|
|
31
|
+
* });
|
|
32
|
+
*
|
|
33
|
+
* const result = await orchestrator.execute({
|
|
34
|
+
* model,
|
|
35
|
+
* messages,
|
|
36
|
+
* tools,
|
|
37
|
+
* });
|
|
38
|
+
*
|
|
39
|
+
* for await (const chunk of result.fullStream) {
|
|
40
|
+
* console.log(chunk);
|
|
41
|
+
* }
|
|
42
|
+
* ```
|
|
43
|
+
*/
|
|
44
|
+
export declare class StreamOrchestrator {
|
|
45
|
+
private readonly provider;
|
|
46
|
+
private readonly config;
|
|
47
|
+
private readonly observers;
|
|
48
|
+
private readonly logger;
|
|
49
|
+
constructor(options: StreamOrchestratorOptions);
|
|
50
|
+
execute<TOOLS extends Record<string, Tool>>(options: OrchestratorStreamTextOptions<TOOLS>): Promise<StreamTextResult<TOOLS>>;
|
|
51
|
+
/**
|
|
52
|
+
* Wraps a fullStream with retry logic. When an error occurs (either thrown or
|
|
53
|
+
* as an error chunk), makes a retry decision and either creates a new stream
|
|
54
|
+
* or throws the final error. It catches errors from the managed stream (inner)
|
|
55
|
+
* and decides whether to retry or give up. Session finalization happens here,
|
|
56
|
+
* not in the managed stream. If you add finalization to managed-stream.ts,
|
|
57
|
+
* retries will silently fail (the new stream will close immediately because
|
|
58
|
+
* session.isPending() returns false).
|
|
59
|
+
*/
|
|
60
|
+
private wrapWithRetry;
|
|
61
|
+
/**
|
|
62
|
+
* Handle an error by making a retry decision. Returns either a new result to continue
|
|
63
|
+
* with, or the final error to throw.
|
|
64
|
+
*/
|
|
65
|
+
private handleRetryDecision;
|
|
66
|
+
private startStreamWithRetry;
|
|
67
|
+
private wrapFinalError;
|
|
68
|
+
private startStream;
|
|
69
|
+
private applyProvider;
|
|
70
|
+
private getFallbackReason;
|
|
71
|
+
private delay;
|
|
72
|
+
}
|
|
73
|
+
//# sourceMappingURL=orchestrator.d.ts.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"orchestrator.d.ts","sourceRoot":"","sources":["../../../../src/ai-service/llm/stream/orchestrator.ts"],"names":[],"mappings":"AAKA,OAAO,KAAK,EAAE,YAAY,EAAE,MAAM,aAAa,CAAC;AAChD,OAAO,KAAK,EAAE,cAAc,EAAE,MAAM,eAAe,CAAC;AAEpD,OAAO,KAAK,EAAE,MAAM,EAAE,MAAM,yBAAyB,CAAC;AACtD,OAAO,KAAK,EAAE,IAAI,EAAE,MAAM,6BAA6B,CAAC;AACxD,OAAO,KAAK,EACV,kBAAkB,EAClB,iBAAiB,EACjB,gBAAgB,EACjB,MAAM,4BAA4B,CAAC;AAGpC,MAAM,WAAW,yBAAyB;IACxC,QAAQ,EAAE,kBAAkB,CAAC;IAC7B,MAAM,EAAE,YAAY,CAAC;IACrB,SAAS,CAAC,EAAE,cAAc,EAAE,CAAC;IAC7B,MAAM,EAAE,MAAM,CAAC;CAChB;AAED,MAAM,MAAM,6BAA6B,CAAC,KAAK,SAAS,MAAM,CAAC,MAAM,EAAE,IAAI,CAAC,IAC1E,iBAAiB,CAAC,KAAK,CAAC,GAAG;IACzB,WAAW,CAAC,EAAE,WAAW,CAAC;CAC3B,CAAC;AAEJ;;;;;;;;;;;;;;;;;;;;;;;;;;;;GA4BG;AACH,qBAAa,kBAAkB;IAC7B,OAAO,CAAC,QAAQ,CAAC,QAAQ,CAAqB;IAC9C,OAAO,CAAC,QAAQ,CAAC,MAAM,CAAe;IACtC,OAAO,CAAC,QAAQ,CAAC,SAAS,CAAmB;IAC7C,OAAO,CAAC,QAAQ,CAAC,MAAM,CAAS;gBAEpB,OAAO,EAAE,yBAAyB;IAOxC,OAAO,CAAC,KAAK,SAAS,MAAM,CAAC,MAAM,EAAE,IAAI,CAAC,EAC9C,OAAO,EAAE,6BAA6B,CAAC,KAAK,CAAC,GAC5C,OAAO,CAAC,gBAAgB,CAAC,KAAK,CAAC,CAAC;IAgEnC;;;;;;;;OAQG;IACH,OAAO,CAAC,aAAa;IAmErB;;;OAGG;YACW,mBAAmB;YAiFnB,oBAAoB;IAyElC,OAAO,CAAC,cAAc;YA6BR,WAAW;IA0CzB,OAAO,CAAC,aAAa;IAsBrB,OAAO,CAAC,iBAAiB;IAQzB,OAAO,CAAC,KAAK;CAmBd"}
|