@superblocksteam/vite-plugin-file-sync 2.0.70 → 2.0.71-next.0

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 (251) hide show
  1. package/dist/ai-service/agent/prompts/build-base-system-prompt.js +1 -1
  2. package/dist/ai-service/agent/subagents/types.d.ts.map +1 -1
  3. package/dist/ai-service/agent/subagents/types.js +1 -0
  4. package/dist/ai-service/agent/subagents/types.js.map +1 -1
  5. package/dist/ai-service/agent/tool-message-utils.d.ts.map +1 -1
  6. package/dist/ai-service/agent/tool-message-utils.js +5 -0
  7. package/dist/ai-service/agent/tool-message-utils.js.map +1 -1
  8. package/dist/ai-service/agent/tools/apis/build-api-artifact.d.ts.map +1 -1
  9. package/dist/ai-service/agent/tools/apis/build-api-artifact.js +2 -1
  10. package/dist/ai-service/agent/tools/apis/build-api-artifact.js.map +1 -1
  11. package/dist/ai-service/agent/tools/apis/sample-json.d.ts +2 -0
  12. package/dist/ai-service/agent/tools/apis/sample-json.d.ts.map +1 -0
  13. package/dist/ai-service/agent/tools/apis/sample-json.js +16 -0
  14. package/dist/ai-service/agent/tools/apis/sample-json.js.map +1 -0
  15. package/dist/ai-service/agent/tools/apis/test-api.d.ts +4 -4
  16. package/dist/ai-service/agent/tools/apis/test-api.d.ts.map +1 -1
  17. package/dist/ai-service/agent/tools/apis/test-api.js +16 -5
  18. package/dist/ai-service/agent/tools/apis/test-api.js.map +1 -1
  19. package/dist/ai-service/agent/tools/build-capture-screenshot.d.ts +35 -0
  20. package/dist/ai-service/agent/tools/build-capture-screenshot.d.ts.map +1 -1
  21. package/dist/ai-service/agent/tools/build-capture-screenshot.js +90 -15
  22. package/dist/ai-service/agent/tools/build-capture-screenshot.js.map +1 -1
  23. package/dist/ai-service/agent/tools/build-validate-icons.d.ts +3 -18
  24. package/dist/ai-service/agent/tools/build-validate-icons.d.ts.map +1 -1
  25. package/dist/ai-service/agent/tools/build-validate-icons.js +12 -50
  26. package/dist/ai-service/agent/tools/build-validate-icons.js.map +1 -1
  27. package/dist/ai-service/agent/tools/debug-cache.js.map +1 -1
  28. package/dist/ai-service/agent/tools/integrations/execute-request.d.ts +1 -1
  29. package/dist/ai-service/agent/tools/shared-helpers.d.ts +0 -35
  30. package/dist/ai-service/agent/tools/shared-helpers.d.ts.map +1 -1
  31. package/dist/ai-service/agent/tools/shared-helpers.js +0 -89
  32. package/dist/ai-service/agent/tools/shared-helpers.js.map +1 -1
  33. package/dist/ai-service/agent/tools2/access-control.d.ts +1 -23
  34. package/dist/ai-service/agent/tools2/access-control.d.ts.map +1 -1
  35. package/dist/ai-service/agent/tools2/access-control.js +3 -68
  36. package/dist/ai-service/agent/tools2/access-control.js.map +1 -1
  37. package/dist/ai-service/agent/tools2/registry.d.ts.map +1 -1
  38. package/dist/ai-service/agent/tools2/registry.js +16 -5
  39. package/dist/ai-service/agent/tools2/registry.js.map +1 -1
  40. package/dist/ai-service/agent/tools2/tools/bash.d.ts.map +1 -1
  41. package/dist/ai-service/agent/tools2/tools/bash.js +2 -1
  42. package/dist/ai-service/agent/tools2/tools/bash.js.map +1 -1
  43. package/dist/ai-service/agent/tools2/tools/exit-plan-mode.d.ts.map +1 -1
  44. package/dist/ai-service/agent/tools2/tools/exit-plan-mode.js +10 -2
  45. package/dist/ai-service/agent/tools2/tools/exit-plan-mode.js.map +1 -1
  46. package/dist/ai-service/agent/tools2/tools/grep.d.ts.map +1 -1
  47. package/dist/ai-service/agent/tools2/tools/grep.js +2 -1
  48. package/dist/ai-service/agent/tools2/tools/grep.js.map +1 -1
  49. package/dist/ai-service/agent/tools2/tools/ls.d.ts.map +1 -1
  50. package/dist/ai-service/agent/tools2/tools/ls.js +3 -1
  51. package/dist/ai-service/agent/tools2/tools/ls.js.map +1 -1
  52. package/dist/ai-service/agent/tools2/types.d.ts +2 -1
  53. package/dist/ai-service/agent/tools2/types.d.ts.map +1 -1
  54. package/dist/ai-service/agent/tools2/types.js +31 -11
  55. package/dist/ai-service/agent/tools2/types.js.map +1 -1
  56. package/dist/ai-service/agent/utils.d.ts.map +1 -1
  57. package/dist/ai-service/agent/utils.js +5 -10
  58. package/dist/ai-service/agent/utils.js.map +1 -1
  59. package/dist/ai-service/clark-provider/clark-chat-settings.d.ts +2 -1
  60. package/dist/ai-service/clark-provider/clark-chat-settings.d.ts.map +1 -1
  61. package/dist/ai-service/clark-provider/clark-chat-settings.js +1 -0
  62. package/dist/ai-service/clark-provider/clark-chat-settings.js.map +1 -1
  63. package/dist/ai-service/index.d.ts.map +1 -1
  64. package/dist/ai-service/index.js +7 -4
  65. package/dist/ai-service/index.js.map +1 -1
  66. package/dist/ai-service/integrations/store.d.ts +1 -0
  67. package/dist/ai-service/integrations/store.d.ts.map +1 -1
  68. package/dist/ai-service/integrations/store.js +1 -0
  69. package/dist/ai-service/integrations/store.js.map +1 -1
  70. package/dist/ai-service/llm/client.d.ts +14 -117
  71. package/dist/ai-service/llm/client.d.ts.map +1 -1
  72. package/dist/ai-service/llm/client.js +57 -149
  73. package/dist/ai-service/llm/client.js.map +1 -1
  74. package/dist/ai-service/llm/error.d.ts +7 -2
  75. package/dist/ai-service/llm/error.d.ts.map +1 -1
  76. package/dist/ai-service/llm/error.js +17 -17
  77. package/dist/ai-service/llm/error.js.map +1 -1
  78. package/dist/ai-service/llm/impl/anthropic.d.ts.map +1 -1
  79. package/dist/ai-service/llm/impl/anthropic.js +2 -1
  80. package/dist/ai-service/llm/impl/anthropic.js.map +1 -1
  81. package/dist/ai-service/llm/impl/clark.d.ts.map +1 -1
  82. package/dist/ai-service/llm/impl/clark.js +2 -1
  83. package/dist/ai-service/llm/impl/clark.js.map +1 -1
  84. package/dist/ai-service/llm/interaction/index.d.ts +0 -64
  85. package/dist/ai-service/llm/interaction/index.d.ts.map +1 -1
  86. package/dist/ai-service/llm/interaction/index.js +0 -65
  87. package/dist/ai-service/llm/interaction/index.js.map +1 -1
  88. package/dist/ai-service/llm/provider.d.ts.map +1 -1
  89. package/dist/ai-service/llm/provider.js +2 -6
  90. package/dist/ai-service/llm/provider.js.map +1 -1
  91. package/dist/ai-service/llm/stream/config.d.ts +56 -0
  92. package/dist/ai-service/llm/stream/config.d.ts.map +1 -0
  93. package/dist/ai-service/llm/stream/config.js +41 -0
  94. package/dist/ai-service/llm/stream/config.js.map +1 -0
  95. package/dist/ai-service/llm/stream/errors.d.ts +16 -0
  96. package/dist/ai-service/llm/stream/errors.d.ts.map +1 -0
  97. package/dist/ai-service/llm/stream/errors.js +68 -0
  98. package/dist/ai-service/llm/stream/errors.js.map +1 -0
  99. package/dist/ai-service/llm/stream/event-bus.d.ts +68 -0
  100. package/dist/ai-service/llm/stream/event-bus.d.ts.map +1 -0
  101. package/dist/ai-service/llm/stream/event-bus.js +51 -0
  102. package/dist/ai-service/llm/stream/event-bus.js.map +1 -0
  103. package/dist/ai-service/llm/stream/index.d.ts +49 -0
  104. package/dist/ai-service/llm/stream/index.d.ts.map +1 -0
  105. package/dist/ai-service/llm/stream/index.js +46 -0
  106. package/dist/ai-service/llm/stream/index.js.map +1 -0
  107. package/dist/ai-service/llm/stream/managed-stream.d.ts +25 -0
  108. package/dist/ai-service/llm/stream/managed-stream.d.ts.map +1 -0
  109. package/dist/ai-service/llm/stream/managed-stream.js +68 -0
  110. package/dist/ai-service/llm/stream/managed-stream.js.map +1 -0
  111. package/dist/ai-service/llm/stream/observer.d.ts +34 -0
  112. package/dist/ai-service/llm/stream/observer.d.ts.map +1 -0
  113. package/dist/ai-service/llm/stream/observer.js +2 -0
  114. package/dist/ai-service/llm/stream/observer.js.map +1 -0
  115. package/dist/ai-service/llm/stream/observers/context.d.ts +40 -0
  116. package/dist/ai-service/llm/stream/observers/context.d.ts.map +1 -0
  117. package/dist/ai-service/llm/stream/observers/context.js +55 -0
  118. package/dist/ai-service/llm/stream/observers/context.js.map +1 -0
  119. package/dist/ai-service/llm/stream/observers/index.d.ts +8 -0
  120. package/dist/ai-service/llm/stream/observers/index.d.ts.map +1 -0
  121. package/dist/ai-service/llm/stream/observers/index.js +8 -0
  122. package/dist/ai-service/llm/stream/observers/index.js.map +1 -0
  123. package/dist/ai-service/llm/stream/observers/llmobs.d.ts +78 -0
  124. package/dist/ai-service/llm/stream/observers/llmobs.d.ts.map +1 -0
  125. package/dist/ai-service/llm/stream/observers/llmobs.js +504 -0
  126. package/dist/ai-service/llm/stream/observers/llmobs.js.map +1 -0
  127. package/dist/ai-service/llm/stream/observers/logging.d.ts +46 -0
  128. package/dist/ai-service/llm/stream/observers/logging.d.ts.map +1 -0
  129. package/dist/ai-service/llm/stream/observers/logging.js +296 -0
  130. package/dist/ai-service/llm/stream/observers/logging.js.map +1 -0
  131. package/dist/ai-service/llm/stream/observers/retry-notification.d.ts +17 -0
  132. package/dist/ai-service/llm/stream/observers/retry-notification.d.ts.map +1 -0
  133. package/dist/ai-service/llm/stream/observers/retry-notification.js +36 -0
  134. package/dist/ai-service/llm/stream/observers/retry-notification.js.map +1 -0
  135. package/dist/ai-service/llm/stream/orchestrator.d.ts +73 -0
  136. package/dist/ai-service/llm/stream/orchestrator.d.ts.map +1 -0
  137. package/dist/ai-service/llm/stream/orchestrator.js +285 -0
  138. package/dist/ai-service/llm/stream/orchestrator.js.map +1 -0
  139. package/dist/ai-service/llm/stream/retry-engine.d.ts +58 -0
  140. package/dist/ai-service/llm/stream/retry-engine.d.ts.map +1 -0
  141. package/dist/ai-service/llm/stream/retry-engine.js +151 -0
  142. package/dist/ai-service/llm/stream/retry-engine.js.map +1 -0
  143. package/dist/ai-service/llm/stream/session.d.ts +58 -0
  144. package/dist/ai-service/llm/stream/session.d.ts.map +1 -0
  145. package/dist/ai-service/llm/stream/session.js +116 -0
  146. package/dist/ai-service/llm/stream/session.js.map +1 -0
  147. package/dist/ai-service/llm/stream/tests/helpers/mock-provider.d.ts +129 -0
  148. package/dist/ai-service/llm/stream/tests/helpers/mock-provider.d.ts.map +1 -0
  149. package/dist/ai-service/llm/stream/tests/helpers/mock-provider.js +508 -0
  150. package/dist/ai-service/llm/stream/tests/helpers/mock-provider.js.map +1 -0
  151. package/dist/ai-service/llm/stream/types.d.ts +15 -0
  152. package/dist/ai-service/llm/stream/types.d.ts.map +1 -0
  153. package/dist/ai-service/llm/stream/types.js +2 -0
  154. package/dist/ai-service/llm/stream/types.js.map +1 -0
  155. package/dist/ai-service/llm/types.d.ts +1 -1
  156. package/dist/ai-service/llm/types.d.ts.map +1 -1
  157. package/dist/ai-service/llmobs/helpers.d.ts +0 -19
  158. package/dist/ai-service/llmobs/helpers.d.ts.map +1 -1
  159. package/dist/ai-service/llmobs/helpers.js +0 -23
  160. package/dist/ai-service/llmobs/helpers.js.map +1 -1
  161. package/dist/ai-service/llmobs/tracer.d.ts +1 -0
  162. package/dist/ai-service/llmobs/tracer.d.ts.map +1 -1
  163. package/dist/ai-service/llmobs/tracer.js +1 -0
  164. package/dist/ai-service/llmobs/tracer.js.map +1 -1
  165. package/dist/ai-service/llmobs/types.d.ts +2 -0
  166. package/dist/ai-service/llmobs/types.d.ts.map +1 -1
  167. package/dist/ai-service/llmobs/utils.d.ts.map +1 -1
  168. package/dist/ai-service/llmobs/utils.js +8 -0
  169. package/dist/ai-service/llmobs/utils.js.map +1 -1
  170. package/dist/ai-service/mcp/playwright-server.d.ts.map +1 -1
  171. package/dist/ai-service/mcp/playwright-server.js.map +1 -1
  172. package/dist/ai-service/state-machine/clark-fsm.d.ts +1 -3
  173. package/dist/ai-service/state-machine/clark-fsm.d.ts.map +1 -1
  174. package/dist/ai-service/state-machine/clark-fsm.js +6 -28
  175. package/dist/ai-service/state-machine/clark-fsm.js.map +1 -1
  176. package/dist/ai-service/state-machine/handlers/agent-planning.d.ts.map +1 -1
  177. package/dist/ai-service/state-machine/handlers/agent-planning.js +9 -11
  178. package/dist/ai-service/state-machine/handlers/agent-planning.js.map +1 -1
  179. package/dist/ai-service/state-machine/handlers/awaiting-user.d.ts.map +1 -1
  180. package/dist/ai-service/state-machine/handlers/awaiting-user.js +3 -2
  181. package/dist/ai-service/state-machine/handlers/awaiting-user.js.map +1 -1
  182. package/dist/ai-service/state-machine/handlers/llm-generating.d.ts.map +1 -1
  183. package/dist/ai-service/state-machine/handlers/llm-generating.js +18 -4
  184. package/dist/ai-service/state-machine/handlers/llm-generating.js.map +1 -1
  185. package/dist/ai-service/state-machine/traced-fsm.d.ts +5 -4
  186. package/dist/ai-service/state-machine/traced-fsm.d.ts.map +1 -1
  187. package/dist/ai-service/state-machine/traced-fsm.js +25 -25
  188. package/dist/ai-service/state-machine/traced-fsm.js.map +1 -1
  189. package/dist/ai-service/types.d.ts +3 -3
  190. package/dist/ai-service/types.d.ts.map +1 -1
  191. package/dist/ai-service/types.js +10 -10
  192. package/dist/ai-service/types.js.map +1 -1
  193. package/dist/socket-manager.d.ts.map +1 -1
  194. package/dist/socket-manager.js +10 -3
  195. package/dist/socket-manager.js.map +1 -1
  196. package/dist/source-tracker.d.ts.map +1 -1
  197. package/dist/source-tracker.js +8 -0
  198. package/dist/source-tracker.js.map +1 -1
  199. package/dist/sync-service/index.d.ts +7 -2
  200. package/dist/sync-service/index.d.ts.map +1 -1
  201. package/dist/sync-service/index.js +16 -9
  202. package/dist/sync-service/index.js.map +1 -1
  203. package/package.json +11 -11
  204. package/dist/ai-service/llm/interaction/compose.d.ts +0 -71
  205. package/dist/ai-service/llm/interaction/compose.d.ts.map +0 -1
  206. package/dist/ai-service/llm/interaction/compose.js +0 -88
  207. package/dist/ai-service/llm/interaction/compose.js.map +0 -1
  208. package/dist/ai-service/llm/interaction/middleware.d.ts +0 -52
  209. package/dist/ai-service/llm/interaction/middleware.d.ts.map +0 -1
  210. package/dist/ai-service/llm/interaction/middleware.js +0 -17
  211. package/dist/ai-service/llm/interaction/middleware.js.map +0 -1
  212. package/dist/ai-service/llm/interaction/middlewares/llmobs.d.ts +0 -45
  213. package/dist/ai-service/llm/interaction/middlewares/llmobs.d.ts.map +0 -1
  214. package/dist/ai-service/llm/interaction/middlewares/llmobs.js +0 -85
  215. package/dist/ai-service/llm/interaction/middlewares/llmobs.js.map +0 -1
  216. package/dist/ai-service/llm/interaction/middlewares/logging.d.ts +0 -88
  217. package/dist/ai-service/llm/interaction/middlewares/logging.d.ts.map +0 -1
  218. package/dist/ai-service/llm/interaction/middlewares/logging.js +0 -238
  219. package/dist/ai-service/llm/interaction/middlewares/logging.js.map +0 -1
  220. package/dist/ai-service/llm/interaction/middlewares/profiler.d.ts +0 -47
  221. package/dist/ai-service/llm/interaction/middlewares/profiler.d.ts.map +0 -1
  222. package/dist/ai-service/llm/interaction/middlewares/profiler.js +0 -183
  223. package/dist/ai-service/llm/interaction/middlewares/profiler.js.map +0 -1
  224. package/dist/ai-service/llm/interaction/middlewares/stream-retry.d.ts +0 -115
  225. package/dist/ai-service/llm/interaction/middlewares/stream-retry.d.ts.map +0 -1
  226. package/dist/ai-service/llm/interaction/middlewares/stream-retry.js +0 -231
  227. package/dist/ai-service/llm/interaction/middlewares/stream-retry.js.map +0 -1
  228. package/dist/ai-service/llm/interaction/middlewares/utils/abort.d.ts +0 -41
  229. package/dist/ai-service/llm/interaction/middlewares/utils/abort.d.ts.map +0 -1
  230. package/dist/ai-service/llm/interaction/middlewares/utils/abort.js +0 -74
  231. package/dist/ai-service/llm/interaction/middlewares/utils/abort.js.map +0 -1
  232. package/dist/ai-service/llm/interaction/middlewares/utils/fallback-chain.d.ts +0 -61
  233. package/dist/ai-service/llm/interaction/middlewares/utils/fallback-chain.d.ts.map +0 -1
  234. package/dist/ai-service/llm/interaction/middlewares/utils/fallback-chain.js +0 -116
  235. package/dist/ai-service/llm/interaction/middlewares/utils/fallback-chain.js.map +0 -1
  236. package/dist/ai-service/llm/interaction/middlewares/utils/retries.d.ts +0 -47
  237. package/dist/ai-service/llm/interaction/middlewares/utils/retries.d.ts.map +0 -1
  238. package/dist/ai-service/llm/interaction/middlewares/utils/retries.js +0 -141
  239. package/dist/ai-service/llm/interaction/middlewares/utils/retries.js.map +0 -1
  240. package/dist/ai-service/llm/interaction/middlewares/utils/stall-detector.d.ts +0 -30
  241. package/dist/ai-service/llm/interaction/middlewares/utils/stall-detector.d.ts.map +0 -1
  242. package/dist/ai-service/llm/interaction/middlewares/utils/stall-detector.js +0 -36
  243. package/dist/ai-service/llm/interaction/middlewares/utils/stall-detector.js.map +0 -1
  244. package/dist/ai-service/llm/interaction/middlewares/utils/streams.d.ts +0 -42
  245. package/dist/ai-service/llm/interaction/middlewares/utils/streams.d.ts.map +0 -1
  246. package/dist/ai-service/llm/interaction/middlewares/utils/streams.js +0 -208
  247. package/dist/ai-service/llm/interaction/middlewares/utils/streams.js.map +0 -1
  248. package/dist/ai-service/llmobs/middleware/stream-text.d.ts +0 -56
  249. package/dist/ai-service/llmobs/middleware/stream-text.d.ts.map +0 -1
  250. package/dist/ai-service/llmobs/middleware/stream-text.js +0 -597
  251. 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":"AAAA,OAAO,EAAE,iBAAiB,EAAE,MAAM,iCAAiC,CAAC;AAqBpE,MAAM,aAAa,GAAG,EAAE,CAAC;AACzB,MAAM,YAAY,GAAG,GAAG,CAAC;AACzB,MAAM,YAAY,GAAG,CAAC,GAAG,IAAI,CAAC;AAE9B,SAAS,aAAa,CAAC,KAAa;IAClC,MAAM,MAAM,GAAG,GAAG,YAAY,CAAC,MAAM,CAAC,CAAC,CAAC,IAAI,KAAK,GAAG,CAAC;IACrD,MAAM,SAAS,GAAG,IAAI,CAAC,GAAG,CAAC,CAAC,EAAE,aAAa,GAAG,MAAM,CAAC,MAAM,CAAC,CAAC;IAC7D,OAAO,MAAM,GAAG,YAAY,CAAC,MAAM,CAAC,SAAS,CAAC,CAAC;AACjD,CAAC;AAED,SAAS,cAAc,CACrB,CAAS,EACT,QAAgB;IAEhB,IAAI,CAAC,CAAC,MAAM,IAAI,QAAQ,EAAE,CAAC;QACzB,OAAO,EAAE,IAAI,EAAE,CAAC,EAAE,SAAS,EAAE,KAAK,EAAE,YAAY,EAAE,CAAC,EAAE,CAAC;IACxD,CAAC;IACD,MAAM,YAAY,GAAG,CAAC,CAAC,MAAM,GAAG,QAAQ,CAAC;IACzC,OAAO;QACL,IAAI,EAAE,CAAC,CAAC,KAAK,CAAC,CAAC,EAAE,QAAQ,CAAC,GAAG,oBAAoB,YAAY,SAAS;QACtE,SAAS,EAAE,IAAI;QACf,YAAY;KACb,CAAC;AACJ,CAAC;AAED,SAAS,iBAAiB,CAAC,KAAc;IACvC,IAAI,KAAK,KAAK,IAAI,IAAI,KAAK,KAAK,SAAS;QAAE,OAAO,IAAI,CAAC;IACvD,IAAI,OAAO,KAAK,KAAK,QAAQ,IAAI,MAAM,CAAC,IAAI,CAAC,KAAK,CAAC,CAAC,MAAM,KAAK,CAAC;QAAE,OAAO,IAAI,CAAC;IAC9E,OAAO,KAAK,CAAC;AACf,CAAC;AAED,SAAS,aAAa,CAAC,KAAmB,EAAE,KAAc;IACxD,IAAI,iBAAiB,CAAC,KAAK,CAAC,EAAE,CAAC;QAC7B,OAAO,EAAE,CAAC;IACZ,CAAC;IAED,MAAM,OAAO,GAAG,iBAAiB,CAAC,KAAK,EAAE,CAAC,CAAC,CAAC;IAC5C,MAAM,EAAE,IAAI,EAAE,GAAG,cAAc,CAAC,OAAO,EAAE,YAAY,CAAC,CAAC;IACvD,MAAM,QAAQ,GAAG,IAAI;SAClB,KAAK,CAAC,IAAI,CAAC;SACX,GAAG,CAAC,CAAC,IAAI,EAAE,EAAE,CAAC,OAAO,IAAI,EAAE,CAAC;SAC5B,IAAI,CAAC,IAAI,CAAC,CAAC;IAEd,OAAO,KAAK,KAAK,MAAM,QAAQ,IAAI,CAAC;AACtC,CAAC;AAED;;;;;;;;;GASG;AACH,MAAM,OAAO,eAAe;IACT,MAAM,CAAS;IACxB,gBAAgB,CAAU;IAC1B,iBAAiB,GAAG,EAAE,CAAC;IACvB,sBAAsB,GAAG,EAAE,CAAC;IAC5B,wBAAwB,GAAG,KAAK,CAAC;IAEzC,YAAY,UAAkC,EAAE;QAC9C,IAAI,CAAC,MAAM,GAAG,OAAO,CAAC,MAAM,IAAI,EAAE,OAAO,EAAE,EAAE,EAAE,CAAC;IAClD,CAAC;IAED,MAAM,CAAC,MAAsB,EAAE,MAAoB;QACjD,IAAI,CAAC,MAAM,CAAC,OAAO,CAAC,OAAO,EAAE,CAAC;YAC5B,OAAO;QACT,CAAC;QAED,MAAM,CAAC,EAAE,CAAC,eAAe,EAAE,CAAC,OAAO,EAAE,OAAO,EAAE,EAAE;YAC9C,IAAI,CAAC,cAAc,CAAC,OAAO,EAAE,MAAM,CAAC,CAAC;YACrC,IAAI,OAAO,EAAE,CAAC;gBACZ,IAAI,CAAC,cAAc,CAAC,OAAO,CAAC,CAAC;YAC/B,CAAC;QACH,CAAC,CAAC,CAAC;QAEH,MAAM,CAAC,EAAE,CAAC,OAAO,EAAE,CAAC,KAAK,EAAE,QAAQ,EAAE,EAAE;YACrC,IAAI,CAAC,OAAO,CAAC,KAAK,CAAC,CAAC;QACtB,CAAC,CAAC,CAAC;QAEH,MAAM,CAAC,EAAE,CAAC,eAAe,EAAE,CAAC,IAAI,EAAE,QAAQ,EAAE,EAAE;YAC5C,IAAI,CAAC,cAAc,CAAC,IAAI,CAAC,CAAC;QAC5B,CAAC,CAAC,CAAC;QAEH,MAAM,CAAC,EAAE,CAAC,OAAO,EAAE,CAAC,KAAK,EAAE,OAAO,EAAE,OAAO,EAAE,QAAQ,EAAE,EAAE;YACvD,IAAI,CAAC,OAAO,CAAC,KAAK,EAAE,OAAO,EAAE,OAAO,CAAC,CAAC;QACxC,CAAC,CAAC,CAAC;QAEH,MAAM,CAAC,EAAE,CAAC,UAAU,EAAE,CAAC,IAAI,EAAE,EAAE,EAAE,MAAM,EAAE,EAAE;YACzC,IAAI,CAAC,UAAU,CAAC,IAAI,EAAE,EAAE,EAAE,MAAM,CAAC,CAAC;QACpC,CAAC,CAAC,CAAC;QAEH,MAAM,CAAC,EAAE,CAAC,eAAe,EAAE,CAAC,MAAM,EAAE,QAAQ,EAAE,EAAE;YAC9C,IAAI,CAAC,cAAc,CAAC,MAAM,CAAC,CAAC;QAC9B,CAAC,CAAC,CAAC;QAEH,MAAM,CAAC,EAAE,CAAC,kBAAkB,EAAE,CAAC,OAAO,EAAE,EAAE;YACxC,KAAK,IAAI,CAAC,iBAAiB,CAAC,OAAO,EAAE,MAAM,CAAC,CAAC;QAC/C,CAAC,CAAC,CAAC;QAEH,MAAM,CAAC,EAAE,CAAC,eAAe,EAAE,CAAC,KAAK,EAAE,OAAO,EAAE,EAAE;YAC5C,KAAK,IAAI,CAAC,cAAc,CAAC,KAAK,EAAE,OAAO,EAAE,MAAM,CAAC,CAAC;QACnD,CAAC,CAAC,CAAC;QAEH,MAAM,CAAC,EAAE,CAAC,eAAe,EAAE,CAAC,OAAO,EAAE,EAAE;YACrC,KAAK,IAAI,CAAC,cAAc,CAAC,OAAO,EAAE,MAAM,CAAC,CAAC;QAC5C,CAAC,CAAC,CAAC;IACL,CAAC;IAEO,cAAc,CAAC,OAAsB,EAAE,MAAoB;QACjE,IAAI,CAAC,gBAAgB,GAAG,IAAI,CAAC,GAAG,EAAE,CAAC;QACnC,MAAM,cAAc,GAAG,MAAM,CAAC,OAAO,CAAC,cAAc,IAAI,OAAO,CAAC,EAAE,CAAC;QACnE,MAAM,SAAS,GAAG,IAAI,IAAI,EAAE,CAAC,WAAW,EAAE,CAAC;QAE3C,IAAI,CAAC,MAAM,CAAC,OAAO,IAAI,aAAa,CAAC,wBAAwB,CAAC,GAAG,IAAI,CAAC;QACtE,IAAI,CAAC,MAAM,CAAC,OAAO,IAAI,eAAe,cAAc,IAAI,CAAC;QACzD,IAAI,CAAC,MAAM,CAAC,OAAO,IAAI,cAAc,SAAS,IAAI,CAAC;QACnD,IAAI,CAAC,MAAM,CAAC,OAAO,IAAI,aAAa,OAAO,CAAC,QAAQ,CAAC,IAAI,IAAI,CAAC;QAC9D,IAAI,CAAC,MAAM,CAAC,OAAO,IAAI,UAAU,OAAO,CAAC,QAAQ,CAAC,KAAK,IAAI,CAAC;QAE5D,MAAM,QAAQ,GAAG,MAAM,CAAC,OAAO,CAAC,QAAQ,CAAC;QACzC,IAAI,QAAQ,IAAI,MAAM,CAAC,IAAI,CAAC,QAAQ,CAAC,CAAC,MAAM,GAAG,CAAC,EAAE,CAAC;YACjD,KAAK,MAAM,CAAC,CAAC,EAAE,CAAC,CAAC,IAAI,MAAM,CAAC,OAAO,CAAC,QAAQ,CAAC,EAAE,CAAC;gBAC9C,IAAI,OAAO,CAAC,KAAK,QAAQ,EAAE,CAAC;oBAC1B,IAAI,CAAC,MAAM,CAAC,OAAO,IAAI,GAAG,CAAC,KAAK,iBAAiB,CAAC,CAAC,CAAC,IAAI,CAAC;gBAC3D,CAAC;qBAAM,CAAC;oBACN,IAAI,CAAC,MAAM,CAAC,OAAO,IAAI,GAAG,CAAC,KAAK,CAAC,IAAI,CAAC;gBACxC,CAAC;YACH,CAAC;QACH,CAAC;QAED,IAAI,CAAC,MAAM,CAAC,OAAO,IAAI,IAAI,CAAC;QAC5B,IAAI,CAAC,MAAM,CAAC,OAAO,IAAI,aAAa,CAAC,YAAY,CAAC,GAAG,IAAI,CAAC;QAE1D,IAAI,CAAC,iBAAiB,GAAG,EAAE,CAAC;QAC5B,IAAI,CAAC,sBAAsB,GAAG,EAAE,CAAC;QACjC,IAAI,CAAC,wBAAwB,GAAG,KAAK,CAAC;IACxC,CAAC;IAEO,cAAc,CAAC,OAAuB;QAC5C,MAAM,eAAe,GAAG,CAAC,GAAG,OAAO,CAAC,QAAQ,CAAC;aAC1C,OAAO,EAAE;aACT,IAAI,CAAC,CAAC,CAAC,EAAE,EAAE,CAAC,CAAC,CAAC,IAAI,KAAK,MAAM,CAAC,CAAC;QAElC,IAAI,CAAC,eAAe;YAAE,OAAO;QAE7B,IAAI,QAAgB,CAAC;QACrB,IAAI,OAAO,eAAe,CAAC,OAAO,KAAK,QAAQ,EAAE,CAAC;YAChD,QAAQ,GAAG,eAAe,CAAC,OAAO,CAAC;QACrC,CAAC;aAAM,IAAI,KAAK,CAAC,OAAO,CAAC,eAAe,CAAC,OAAO,CAAC,EAAE,CAAC;YAClD,QAAQ,GAAG,eAAe,CAAC,OAAO;iBAC/B,MAAM,CAAC,CAAC,CAAM,EAAE,EAAE,CAAC,CAAC,CAAC,IAAI,KAAK,MAAM,CAAC;iBACrC,GAAG,CAAC,CAAC,CAAM,EAAE,EAAE,CAAC,CAAC,CAAC,IAAI,CAAC;iBACvB,IAAI,CAAC,IAAI,CAAC,CAAC;QAChB,CAAC;aAAM,CAAC;YACN,OAAO;QACT,CAAC;QAED,IAAI,QAAQ,EAAE,CAAC;YACb,IAAI,CAAC,MAAM,CAAC,OAAO,IAAI,UAAU,QAAQ,MAAM,CAAC;QAClD,CAAC;IACH,CAAC;IAEO,OAAO,CAAC,KAAkB;QAChC,QAAQ,KAAK,CAAC,IAAI,EAAE,CAAC;YACnB,KAAK,YAAY;gBACf,IAAI,CAAC,iBAAiB,IAAI,KAAK,CAAC,IAAI,CAAC;gBACrC,MAAM;YAER,KAAK,UAAU;gBACb,IAAI,CAAC,eAAe,EAAE,CAAC;gBACvB,MAAM;YAER,KAAK,iBAAiB;gBACpB,IAAI,CAAC,sBAAsB,IAAI,KAAK,CAAC,IAAI,CAAC;gBAC1C,MAAM;YAER,KAAK,eAAe;gBAClB,IAAI,CAAC,oBAAoB,EAAE,CAAC;gBAC5B,MAAM;YAER,KAAK,WAAW;gBACd,IAAI,CAAC,eAAe,EAAE,CAAC;gBACvB,IAAI,CAAC,oBAAoB,EAAE,CAAC;gBAC5B,IAAI,CAAC,cAAc,CAAC,KAAK,CAAC,CAAC;gBAC3B,MAAM;YAER,KAAK,aAAa;gBAChB,IAAI,CAAC,gBAAgB,CAAC,KAAK,CAAC,CAAC;gBAC7B,MAAM;YAER,KAAK,OAAO,CAAC,CAAC,CAAC;gBACb,IAAI,CAAC,eAAe,EAAE,CAAC;gBACvB,IAAI,CAAC,oBAAoB,EAAE,CAAC;gBAC5B,MAAM,QAAQ,GACZ,KAAK,CAAC,KAAK,YAAY,KAAK;oBAC1B,CAAC,CAAC,KAAK,CAAC,KAAK,CAAC,OAAO;oBACrB,CAAC,CAAC,MAAM,CAAC,KAAK,CAAC,KAAK,CAAC,CAAC;gBAC1B,IAAI,CAAC,MAAM,CAAC,OAAO,IAAI,WAAW,QAAQ,MAAM,CAAC;gBACjD,MAAM;YACR,CAAC;YAED,uEAAuE;QACzE,CAAC;IACH,CAAC;IAEO,eAAe;QACrB,IAAI,IAAI,CAAC,iBAAiB,CAAC,IAAI,EAAE,EAAE,CAAC;YAClC,IAAI,CAAC,MAAM,CAAC,OAAO,IAAI,eAAe,IAAI,CAAC,iBAAiB,CAAC,IAAI,EAAE,MAAM,CAAC;QAC5E,CAAC;QACD,IAAI,CAAC,iBAAiB,GAAG,EAAE,CAAC;IAC9B,CAAC;IAEO,oBAAoB;QAC1B,IAAI,IAAI,CAAC,sBAAsB,CAAC,IAAI,EAAE,EAAE,CAAC;YACvC,IAAI,CAAC,MAAM,CAAC,OAAO,IAAI,eAAe,IAAI,CAAC,sBAAsB,CAAC,IAAI,EAAE,MAAM,CAAC;YAC/E,IAAI,CAAC,wBAAwB,GAAG,IAAI,CAAC;QACvC,CAAC;QACD,IAAI,CAAC,sBAAsB,GAAG,EAAE,CAAC;IACnC,CAAC;IAEO,cAAc,CAAC,KAAU;QAC/B,IAAI,CAAC,MAAM,CAAC,OAAO,IAAI,QAAQ,KAAK,CAAC,QAAQ,KAAK,CAAC;QACnD,MAAM,IAAI,GAAG,KAAK,CAAC,KAAK,IAAI,KAAK,CAAC,IAAI,CAAC;QACvC,MAAM,OAAO,GAAG,aAAa,CAAC,IAAI,EAAE,IAAI,CAAC,CAAC;QAC1C,IAAI,OAAO,EAAE,CAAC;YACZ,IAAI,CAAC,MAAM,CAAC,OAAO,IAAI,OAAO,CAAC;QACjC,CAAC;IACH,CAAC;IAEO,gBAAgB,CAAC,KAAU;QACjC,4EAA4E;QAC5E,MAAM,MAAM,GAAG,KAAK,CAAC,MAAM,IAAI,KAAK,CAAC,MAAM,CAAC;QAC5C,MAAM,QAAQ,GAAG,aAAa,CAAC,KAAK,EAAE,MAAM,CAAC,CAAC;QAC9C,IAAI,QAAQ,EAAE,CAAC;YACb,IAAI,CAAC,MAAM,CAAC,OAAO,IAAI,QAAQ,CAAC;QAClC,CAAC;QACD,IAAI,CAAC,MAAM,CAAC,OAAO,IAAI,IAAI,CAAC;IAC9B,CAAC;IAEO,cAAc,CAAC,IAAsC;QAC3D,IAAI,IAAI,CAAC,aAAa,IAAI,CAAC,IAAI,CAAC,wBAAwB,EAAE,CAAC;YACzD,IAAI,CAAC,MAAM,CAAC,OAAO,IAAI,eAAe,IAAI,CAAC,aAAa,MAAM,CAAC;QACjE,CAAC;QACD,IAAI,CAAC,wBAAwB,GAAG,KAAK,CAAC;IACxC,CAAC;IAEO,OAAO,CAAC,KAAc,EAAE,OAAe,EAAE,OAAe;QAC9D,MAAM,YAAY,GAAG,KAAK,YAAY,KAAK,CAAC,CAAC,CAAC,KAAK,CAAC,OAAO,CAAC,CAAC,CAAC,MAAM,CAAC,KAAK,CAAC,CAAC;QAC5E,IAAI,CAAC,MAAM,CAAC,OAAO,IAAI,mBAAmB,OAAO,UAAU,OAAO,aAAa,YAAY,OAAO,CAAC;IACrG,CAAC;IAEO,UAAU,CAChB,IAAqC,EACrC,EAAmC,EACnC,MAAc;QAEd,IAAI,CAAC,MAAM,CAAC,OAAO,IAAI,cAAc,IAAI,CAAC,IAAI,IAAI,IAAI,CAAC,KAAK,OAAO,EAAE,CAAC,IAAI,IAAI,EAAE,CAAC,KAAK,WAAW,MAAM,MAAM,CAAC;IAChH,CAAC;IAEO,cAAc,CAAC,MAAyC;QAC9D,IAAI,CAAC,eAAe,EAAE,CAAC;QACvB,IAAI,CAAC,oBAAoB,EAAE,CAAC;QAE5B,IAAI,CAAC,MAAM,CAAC,OAAO,IAAI,IAAI,CAAC;QAC5B,IAAI,CAAC,MAAM,CAAC,OAAO,IAAI,aAAa,CAAC,OAAO,CAAC,GAAG,IAAI,CAAC;QAErD,MAAM,KAAK,GAAG,MAAM,CAAC,UAAU,CAAC;QAChC,IAAI,KAAK,EAAE,CAAC;YACV,IAAI,SAAS,GAAG,iBAAiB,KAAK,CAAC,WAAW,IAAI,CAAC,WAAW,KAAK,CAAC,YAAY,IAAI,CAAC,UAAU,KAAK,CAAC,WAAW,IAAI,CAAC,EAAE,CAAC;YAC5H,IAAI,CAAC,KAAK,CAAC,iBAAiB,IAAI,CAAC,CAAC,GAAG,CAAC,EAAE,CAAC;gBACvC,SAAS,IAAI,WAAW,KAAK,CAAC,iBAAiB,EAAE,CAAC;YACpD,CAAC;YACD,IAAI,CAAC,MAAM,CAAC,OAAO,IAAI,SAAS,GAAG,IAAI,CAAC;QAC1C,CAAC;QAED,IAAI,CAAC,MAAM,CAAC,OAAO,IAAI,kBAAkB,MAAM,CAAC,YAAY,IAAI,CAAC;QACjE,IAAI,CAAC,MAAM,CAAC,OAAO,IAAI,gBAAgB,MAAM,CAAC,KAAK,CAAC,MAAM,IAAI,CAAC;IACjE,CAAC;IAEO,KAAK,CAAC,iBAAiB,CAC7B,OAAsB,EACtB,MAAoB;QAEpB,MAAM,QAAQ,GAAG,IAAI,CAAC,eAAe,CAAC,OAAO,CAAC,CAAC;QAE/C,IAAI,CAAC,MAAM,CAAC,OAAO,IAAI,IAAI,CAAC;QAC5B,IAAI,CAAC,MAAM,CAAC,OAAO,IAAI,aAAa,CAAC,2BAA2B,CAAC,GAAG,IAAI,CAAC;QACzE,IAAI,CAAC,MAAM,CAAC,OAAO,IAAI,kBAAkB,IAAI,IAAI,EAAE,CAAC,WAAW,EAAE,IAAI,CAAC;QACtE,IAAI,CAAC,MAAM,CAAC,OAAO,IAAI,aAAa,QAAQ,MAAM,CAAC;QACnD,IAAI,CAAC,MAAM,CAAC,OAAO,IAAI,WAAW,OAAO,CAAC,OAAO,CAAC,UAAU,IAAI,CAAC;QACjE,IAAI,CAAC,MAAM,CAAC,OAAO,IAAI,YAAY,OAAO,CAAC,OAAO,CAAC,UAAU,IAAI,CAAC;QAElE,MAAM,IAAI,CAAC,OAAO,CAAC,OAAO,EAAE,MAAM,CAAC,CAAC;IACtC,CAAC;IAEO,KAAK,CAAC,cAAc,CAC1B,KAAc,EACd,OAAsB,EACtB,MAAoB;QAEpB,MAAM,QAAQ,GAAG,IAAI,CAAC,eAAe,CAAC,OAAO,CAAC,CAAC;QAC/C,MAAM,YAAY,GAAG,KAAK,YAAY,KAAK,CAAC,CAAC,CAAC,KAAK,CAAC,OAAO,CAAC,CAAC,CAAC,MAAM,CAAC,KAAK,CAAC,CAAC;QAE5E,IAAI,CAAC,MAAM,CAAC,OAAO,IAAI,IAAI,CAAC;QAC5B,IAAI,CAAC,MAAM,CAAC,OAAO,IAAI,aAAa,CAAC,wBAAwB,CAAC,GAAG,IAAI,CAAC;QACtE,IAAI,CAAC,MAAM,CAAC,OAAO,IAAI,oBAAoB,IAAI,IAAI,EAAE,CAAC,WAAW,EAAE,IAAI,CAAC;QACxE,IAAI,CAAC,MAAM,CAAC,OAAO,IAAI,UAAU,YAAY,IAAI,CAAC;QAClD,IAAI,CAAC,MAAM,CAAC,OAAO,IAAI,aAAa,QAAQ,MAAM,CAAC;QAEnD,MAAM,IAAI,CAAC,OAAO,CAAC,OAAO,EAAE,MAAM,CAAC,CAAC;IACtC,CAAC;IAEO,KAAK,CAAC,cAAc,CAC1B,OAAsB,EACtB,MAAoB;QAEpB,MAAM,QAAQ,GAAG,IAAI,CAAC,eAAe,CAAC,OAAO,CAAC,CAAC;QAE/C,IAAI,CAAC,MAAM,CAAC,OAAO,IAAI,IAAI,CAAC;QAC5B,IAAI,CAAC,MAAM,CAAC,OAAO,IAAI,aAAa,CAAC,0BAA0B,CAAC,GAAG,IAAI,CAAC;QACxE,IAAI,CAAC,MAAM,CAAC,OAAO,IAAI,oBAAoB,IAAI,IAAI,EAAE,CAAC,WAAW,EAAE,IAAI,CAAC;QACxE,IAAI,CAAC,MAAM,CAAC,OAAO,IAAI,aAAa,QAAQ,MAAM,CAAC;QAEnD,MAAM,IAAI,CAAC,OAAO,CAAC,OAAO,EAAE,MAAM,CAAC,CAAC;IACtC,CAAC;IAEO,eAAe,CAAC,OAAsB;QAC5C,IAAI,OAAO,CAAC,OAAO,CAAC,UAAU,GAAG,CAAC,EAAE,CAAC;YACnC,OAAO,OAAO,CAAC,OAAO,CAAC,UAAU,CAAC;QACpC,CAAC;QACD,IAAI,IAAI,CAAC,gBAAgB,EAAE,CAAC;YAC1B,OAAO,IAAI,CAAC,GAAG,EAAE,GAAG,IAAI,CAAC,gBAAgB,CAAC;QAC5C,CAAC;QACD,OAAO,CAAC,CAAC;IACX,CAAC;IAEO,KAAK,CAAC,OAAO,CACnB,OAAsB,EACtB,MAAoB;QAEpB,IAAI,CAAC,MAAM,CAAC,OAAO,CAAC,YAAY,EAAE,CAAC;YACjC,OAAO;QACT,CAAC;QAED,IAAI,CAAC;YACH,MAAM,cAAc,GAAG,MAAM,CAAC,OAAO,CAAC,cAAc,IAAI,OAAO,CAAC,EAAE,CAAC;YACnE,MAAM,QAAQ,GAAiB;gBAC7B,IAAI,EAAE,MAAM;gBACZ,QAAQ,EAAE,oBAAoB,cAAc,MAAM;gBAClD,OAAO,EAAE,IAAI,CAAC,MAAM,CAAC,OAAO;aAC7B,CAAC;YAEF,MAAM,MAAM,GAAG,oBAAoB,cAAc,EAAE,CAAC;YACpD,MAAM,YAAY,GAAG,IAAI,IAAI,EAAE,CAAC,WAAW,EAAE,CAAC;YAE9C,MAAM,MAAM,CAAC,OAAO,CAAC,YAAY,CAAC,QAAQ,EAAE,MAAM,EAAE,YAAY,CAAC,CAAC;QACpE,CAAC;QAAC,MAAM,CAAC;YACP,OAAO,CAAC,KAAK,CAAC,qCAAqC,CAAC,CAAC;QACvD,CAAC;IACH,CAAC;IAED,aAAa;QACX,OAAO,IAAI,CAAC,MAAM,CAAC,OAAO,CAAC;IAC7B,CAAC;CACF"}
@@ -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"}