@superblocksteam/vite-plugin-file-sync 2.0.70-next.8 → 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,504 @@
1
+ import { APICallError } from "ai";
2
+ import { LLMProviderError } from "../../error.js";
3
+ export function classifyError(error) {
4
+ if (LLMProviderError.isInstance(error)) {
5
+ return {
6
+ category: error.type,
7
+ code: error.statusCode,
8
+ isRetryable: error.isRetryable,
9
+ message: error.message,
10
+ };
11
+ }
12
+ if (APICallError.isInstance(error)) {
13
+ return {
14
+ category: mapStatusCodeToCategory(error.statusCode),
15
+ code: error.statusCode,
16
+ isRetryable: error.isRetryable,
17
+ message: error.message,
18
+ };
19
+ }
20
+ if (error instanceof Error) {
21
+ if (error.name === "AbortError" || error.name === "AbortedError") {
22
+ return {
23
+ category: "aborted",
24
+ isRetryable: false,
25
+ message: error.message,
26
+ };
27
+ }
28
+ if (error.message.includes("ECONNREFUSED") ||
29
+ error.message.includes("ETIMEDOUT") ||
30
+ error.message.includes("ENOTFOUND") ||
31
+ error.message.includes("fetch failed")) {
32
+ return {
33
+ category: "network",
34
+ isRetryable: true,
35
+ message: error.message,
36
+ };
37
+ }
38
+ if (error.message.includes("timeout") ||
39
+ error.message.includes("Timeout")) {
40
+ return {
41
+ category: "timeout",
42
+ isRetryable: true,
43
+ message: error.message,
44
+ };
45
+ }
46
+ }
47
+ return {
48
+ category: "unknown",
49
+ isRetryable: true,
50
+ message: error instanceof Error ? error.message : String(error),
51
+ };
52
+ }
53
+ function mapStatusCodeToCategory(statusCode) {
54
+ if (!statusCode)
55
+ return "unknown";
56
+ if (statusCode === 401 || statusCode === 403)
57
+ return "auth_error";
58
+ if (statusCode === 429)
59
+ return "rate_limit";
60
+ if (statusCode === 408)
61
+ return "timeout";
62
+ if (statusCode >= 500 && statusCode < 600)
63
+ return "api_error";
64
+ if (statusCode >= 400 && statusCode < 500)
65
+ return "validation_error";
66
+ return "unknown";
67
+ }
68
+ /**
69
+ * Observer that manages LLM Observability tracing spans.
70
+ *
71
+ * Creates and manages:
72
+ * - A full workflow span (`ai.streamText`) for the entire session
73
+ * - Step spans (`ai.streamText.step`) for each LLM step
74
+ * - Segment spans (`ai.streamText.{type}`) for thinking/reasoning/text/tool-input
75
+ * - Annotations with usage metrics, model info, and input/output data
76
+ *
77
+ * @example
78
+ * ```typescript
79
+ * const observer = new LLMObsObserver({
80
+ * tracer: LLMObsTracer.instance,
81
+ * logger: getLogger(),
82
+ * });
83
+ * ```
84
+ */
85
+ export class LLMObsObserver {
86
+ tracer;
87
+ logger;
88
+ fullSpan;
89
+ stepSpan;
90
+ currentSegment;
91
+ stepNumber = 0;
92
+ constructor(options) {
93
+ this.tracer = options.tracer;
94
+ this.logger = options.logger;
95
+ }
96
+ attach(events, _config) {
97
+ events.on("session:start", (session) => {
98
+ this.onSessionStart(session);
99
+ });
100
+ events.on("chunk", (chunk, _session) => {
101
+ this.onChunk(chunk);
102
+ });
103
+ events.on("step:complete", (step, session) => {
104
+ this.onStepComplete(step, session);
105
+ });
106
+ events.on("stream:finish", (result, session) => {
107
+ this.onStreamFinish(result, session);
108
+ });
109
+ events.on("retry", (error, attempt, _delayMs, session) => {
110
+ this.onRetry(error, attempt, session);
111
+ });
112
+ events.on("fallback", (from, to, reason, session) => {
113
+ this.onFallback(from, to, reason, session);
114
+ });
115
+ events.on("session:complete", (session) => {
116
+ this.onSessionComplete(session);
117
+ });
118
+ events.on("session:error", (error, session) => {
119
+ this.onSessionError(error, session);
120
+ });
121
+ events.on("session:abort", (session) => {
122
+ this.onSessionAbort(session);
123
+ });
124
+ }
125
+ onSessionStart(session) {
126
+ this.fullSpan = this.tracer.startActiveSpan({
127
+ kind: "workflow",
128
+ name: "ai.streamText",
129
+ });
130
+ if (this.fullSpan) {
131
+ this.tracer.annotate(this.fullSpan, {
132
+ metadata: {
133
+ sessionId: session.id,
134
+ provider: session.provider.name,
135
+ model: session.provider.model,
136
+ },
137
+ });
138
+ }
139
+ this.stepNumber = 0;
140
+ this.startStepSpan();
141
+ this.startSegment("thinking");
142
+ this.logger.debug(`[llmobs] Started session span: ${session.id}`);
143
+ }
144
+ onChunk(chunk) {
145
+ if (chunk.type === "tool-input-start") {
146
+ this.startSegment("tool-input", {
147
+ toolCallId: chunk.id,
148
+ tool: chunk.toolName,
149
+ input: "",
150
+ });
151
+ return;
152
+ }
153
+ if (chunk.type === "tool-input-delta") {
154
+ this.appendToolInputDelta(chunk.delta);
155
+ return;
156
+ }
157
+ const segmentType = this.getSegmentTypeFromChunk(chunk.type);
158
+ if (segmentType) {
159
+ this.ensureSegment(segmentType);
160
+ if (this.isTextualSegment(segmentType) && "text" in chunk) {
161
+ this.appendTextToCurrentSegment(chunk.text);
162
+ }
163
+ }
164
+ }
165
+ onStepComplete(step, _session) {
166
+ this.finishSegment();
167
+ // Note: Tool spans are created by wrapToolsForObservability() during actual
168
+ // execution, not here. We only track step-level info.
169
+ this.finishStepSpan(step);
170
+ this.stepNumber++;
171
+ this.startStepSpan();
172
+ this.startSegment("thinking");
173
+ this.logger.debug(`[llmobs] Step ${this.stepNumber} complete: finishReason=${step.finishReason}`);
174
+ }
175
+ onStreamFinish(result, session) {
176
+ this.finishSegment();
177
+ this.finishStepSpan(result);
178
+ if (this.fullSpan) {
179
+ const metrics = this.compileMetrics(result.steps);
180
+ this.tracer.annotate(this.fullSpan, {
181
+ metrics,
182
+ metadata: {
183
+ totalSteps: result.steps.length,
184
+ finishReason: result.finishReason,
185
+ durationMs: session.getElapsedMs(),
186
+ },
187
+ });
188
+ }
189
+ this.logger.debug(`[llmobs] Stream finished: steps=${result.steps.length}`);
190
+ }
191
+ onRetry(error, attempt, session) {
192
+ if (this.fullSpan) {
193
+ const classified = classifyError(error);
194
+ const retryMetadata = {
195
+ error: classified.message,
196
+ errorCategory: classified.category,
197
+ errorCode: classified.code,
198
+ isRetryable: classified.isRetryable,
199
+ };
200
+ this.tracer.annotate(this.fullSpan, {
201
+ model: {
202
+ name: session.provider.model,
203
+ provider: session.provider.name,
204
+ },
205
+ tags: {
206
+ hasRetries: true,
207
+ },
208
+ metadata: {
209
+ [`retry_${attempt}`]: retryMetadata,
210
+ },
211
+ });
212
+ }
213
+ }
214
+ onFallback(from, to, reason, _session) {
215
+ if (this.fullSpan) {
216
+ const fallbackMetadata = {
217
+ fallbackReason: reason,
218
+ fromProvider: from.name,
219
+ fromModel: from.model,
220
+ toProvider: to.name,
221
+ toModel: to.model,
222
+ };
223
+ this.tracer.annotate(this.fullSpan, {
224
+ model: {
225
+ name: to.model,
226
+ provider: to.name,
227
+ },
228
+ tags: {
229
+ hasFallback: true,
230
+ },
231
+ metadata: fallbackMetadata,
232
+ });
233
+ }
234
+ }
235
+ onSessionComplete(session) {
236
+ this.finishFullSpan(session, "complete");
237
+ }
238
+ onSessionError(error, session) {
239
+ if (this.fullSpan) {
240
+ const classified = classifyError(error);
241
+ const errorMetadata = {
242
+ error: classified.message,
243
+ errorCategory: classified.category,
244
+ errorCode: classified.code,
245
+ isRetryable: classified.isRetryable,
246
+ };
247
+ this.tracer.annotate(this.fullSpan, {
248
+ tags: {
249
+ hasError: true,
250
+ errorCategory: classified.category,
251
+ },
252
+ metadata: errorMetadata,
253
+ });
254
+ }
255
+ this.finishFullSpan(session, "error");
256
+ }
257
+ onSessionAbort(session) {
258
+ if (this.fullSpan) {
259
+ this.tracer.annotate(this.fullSpan, {
260
+ tags: {
261
+ wasAborted: true,
262
+ },
263
+ });
264
+ }
265
+ this.finishFullSpan(session, "aborted");
266
+ }
267
+ startSegment(type, initialContent) {
268
+ if (this.currentSegment) {
269
+ this.finishSegment();
270
+ }
271
+ const span = this.tracer.startActiveSpan({
272
+ kind: "task",
273
+ name: `ai.streamText.${type}`,
274
+ });
275
+ this.currentSegment = { type, span, content: initialContent };
276
+ }
277
+ finishSegment() {
278
+ const segment = this.currentSegment;
279
+ if (!segment)
280
+ return;
281
+ // Parse tool-input JSON if possible
282
+ if (segment.type === "tool-input" && typeof segment.content === "object") {
283
+ const content = segment.content;
284
+ try {
285
+ content.input = JSON.parse(content.input);
286
+ }
287
+ catch {
288
+ // leave as string if not valid JSON
289
+ }
290
+ }
291
+ this.tracer.annotate(segment.span, {
292
+ outputData: segment.content,
293
+ });
294
+ segment.span.finish();
295
+ this.currentSegment = undefined;
296
+ }
297
+ ensureSegment(type) {
298
+ if (this.currentSegment?.type !== type) {
299
+ this.startSegment(type);
300
+ }
301
+ }
302
+ appendTextToCurrentSegment(text) {
303
+ if (!this.currentSegment)
304
+ return;
305
+ const existing = typeof this.currentSegment.content === "string"
306
+ ? this.currentSegment.content
307
+ : "";
308
+ this.currentSegment.content = `${existing}${text}`;
309
+ }
310
+ appendToolInputDelta(delta) {
311
+ if (!this.currentSegment || this.currentSegment.type !== "tool-input")
312
+ return;
313
+ const content = this.currentSegment.content;
314
+ content.input += delta;
315
+ }
316
+ isTextualSegment(type) {
317
+ return (type === "text" ||
318
+ type === "reasoning" ||
319
+ type === "thinking" ||
320
+ type === "raw" ||
321
+ type === "source");
322
+ }
323
+ getSegmentTypeFromChunk(chunkType) {
324
+ const suffix = "-delta";
325
+ if (!chunkType.endsWith(suffix))
326
+ return undefined;
327
+ const base = chunkType.slice(0, -suffix.length);
328
+ const admissible = [
329
+ "text",
330
+ "reasoning",
331
+ "thinking",
332
+ "raw",
333
+ "source",
334
+ "tool-call",
335
+ "tool-result",
336
+ "tool-input",
337
+ ];
338
+ return admissible.includes(base) ? base : undefined;
339
+ }
340
+ startStepSpan() {
341
+ this.stepSpan = this.tracer.startActiveSpan({
342
+ kind: "llm",
343
+ name: "ai.streamText.step",
344
+ });
345
+ if (this.stepSpan) {
346
+ this.tracer.annotate(this.stepSpan, {
347
+ tags: { stepNumber: this.stepNumber },
348
+ });
349
+ }
350
+ }
351
+ finishStepSpan(step) {
352
+ if (!this.stepSpan)
353
+ return;
354
+ const metrics = {};
355
+ if (step.usage) {
356
+ metrics.inputTokens =
357
+ (step.usage.inputTokens ?? 0) + (step.usage.cachedInputTokens ?? 0);
358
+ metrics.outputTokens = step.usage.outputTokens ?? 0;
359
+ metrics.totalTokens = step.usage.totalTokens ?? 0;
360
+ metrics.reasoningTokens = step.usage.reasoningTokens ?? 0;
361
+ metrics.cacheReadTokens = step.usage.cachedInputTokens ?? 0;
362
+ }
363
+ metrics.toolCallCount = step.toolCalls?.length ?? 0;
364
+ // Extract model info from response headers if available
365
+ const modelId = step.response?.headers?.["x-model-id"] ?? step.response?.modelId;
366
+ const provider = step.response?.headers?.["x-model-provider"];
367
+ this.tracer.annotate(this.stepSpan, {
368
+ metrics: metrics,
369
+ metadata: {
370
+ finishReason: step.finishReason,
371
+ toolCalls: step.toolCalls?.map((tc) => tc.toolName),
372
+ },
373
+ model: modelId && provider
374
+ ? {
375
+ name: modelId,
376
+ provider,
377
+ }
378
+ : undefined,
379
+ });
380
+ this.stepSpan.finish();
381
+ this.stepSpan = undefined;
382
+ }
383
+ finishFullSpan(session, outcome) {
384
+ this.finishSegment();
385
+ if (this.stepSpan) {
386
+ this.stepSpan.finish();
387
+ this.stepSpan = undefined;
388
+ }
389
+ if (this.tracer.rootSpan && session.metrics.timeToFirstTokenMs) {
390
+ this.tracer.annotate(this.tracer.rootSpan, {
391
+ metrics: {
392
+ timeToFirstToken: session.metrics.timeToFirstTokenMs / 1000,
393
+ },
394
+ });
395
+ }
396
+ if (this.fullSpan) {
397
+ this.tracer.annotate(this.fullSpan, {
398
+ metadata: {
399
+ outcome,
400
+ totalDurationMs: session.metrics.durationMs,
401
+ totalChunks: session.metrics.chunkCount,
402
+ totalRetries: session.metrics.retryCount,
403
+ totalRetryDelayMs: session.metrics.totalRetryDelayMs,
404
+ timeToFirstTokenMs: session.metrics.timeToFirstTokenMs,
405
+ },
406
+ });
407
+ this.fullSpan.finish();
408
+ this.fullSpan = undefined;
409
+ }
410
+ this.logger.debug(`[llmobs] Session ${session.id} finished: outcome=${outcome}`);
411
+ }
412
+ compileMetrics(steps) {
413
+ let inputTokens = 0;
414
+ let outputTokens = 0;
415
+ let totalTokens = 0;
416
+ let reasoningTokens = 0;
417
+ let cacheReadTokens = 0;
418
+ let toolCallCount = 0;
419
+ let staticToolCallCount = 0;
420
+ let dynamicToolCallCount = 0;
421
+ let filesGeneratedCount = 0;
422
+ for (const step of steps) {
423
+ const usage = step.usage;
424
+ inputTokens += (usage.inputTokens ?? 0) + (usage.cachedInputTokens ?? 0);
425
+ outputTokens += usage.outputTokens ?? 0;
426
+ totalTokens += usage.totalTokens ?? 0;
427
+ reasoningTokens += usage.reasoningTokens ?? 0;
428
+ cacheReadTokens += usage.cachedInputTokens ?? 0;
429
+ toolCallCount += step.toolCalls?.length ?? 0;
430
+ staticToolCallCount += step.staticToolCalls?.length ?? 0;
431
+ dynamicToolCallCount += step.dynamicToolCalls?.length ?? 0;
432
+ filesGeneratedCount += step.files?.length ?? 0;
433
+ }
434
+ return {
435
+ inputTokens,
436
+ outputTokens,
437
+ totalTokens,
438
+ reasoningTokens,
439
+ cacheReadTokens,
440
+ toolCallCount,
441
+ staticToolCallCount,
442
+ dynamicToolCallCount,
443
+ filesGeneratedCount,
444
+ stepCount: steps.length,
445
+ };
446
+ }
447
+ }
448
+ /**
449
+ * Wraps tools with LLMObs tracing for real-time tool execution observability.
450
+ *
451
+ * This utility intercepts each tool's `execute` function and wraps it with
452
+ * a traced span, capturing:
453
+ * - Tool name (`tool.{name}`)
454
+ * - Input arguments
455
+ * - Output result
456
+ * - Execution duration
457
+ * - Error status
458
+ */
459
+ export function wrapToolsForObservability(tools, tracer) {
460
+ return Object.fromEntries(Object.entries(tools).map(([name, tool]) => [
461
+ name,
462
+ {
463
+ ...tool,
464
+ async execute(input, options) {
465
+ return await tracer.trace({
466
+ kind: "tool",
467
+ name: `tool.${tool.name}`,
468
+ }, async (span) => {
469
+ try {
470
+ const result = await tool.execute(input, options);
471
+ tracer.annotate(span, {
472
+ inputData: typeof input === "object"
473
+ ? input
474
+ : undefined,
475
+ outputData: typeof result === "object"
476
+ ? result
477
+ : typeof result === "string"
478
+ ? result
479
+ : undefined,
480
+ metadata: {
481
+ toolCallId: options.toolCallId,
482
+ },
483
+ });
484
+ return result;
485
+ }
486
+ catch (error) {
487
+ tracer.annotate(span, {
488
+ inputData: typeof input === "object"
489
+ ? input
490
+ : undefined,
491
+ metadata: {
492
+ toolCallId: options.toolCallId,
493
+ isError: true,
494
+ error: error instanceof Error ? error.message : String(error),
495
+ },
496
+ });
497
+ throw error;
498
+ }
499
+ });
500
+ },
501
+ },
502
+ ]));
503
+ }
504
+ //# sourceMappingURL=llmobs.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"llmobs.js","sourceRoot":"","sources":["../../../../../src/ai-service/llm/stream/observers/llmobs.ts"],"names":[],"mappings":"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"}
@@ -0,0 +1,46 @@
1
+ import type { StreamConfig } from "../config.js";
2
+ import type { StreamEventBus } from "../event-bus.js";
3
+ import type { StreamObserver } from "../observer.js";
4
+ export interface LogRef {
5
+ content: string;
6
+ }
7
+ export interface LoggingObserverOptions {
8
+ logRef?: LogRef;
9
+ }
10
+ /**
11
+ * Observer that captures detailed logs of LLM interactions.
12
+ *
13
+ * @example
14
+ * ```typescript
15
+ * const logRef = { content: "" };
16
+ * const observer = new LoggingObserver({ logRef });
17
+ * // Access logs during streaming: console.log(logRef.content)
18
+ * ```
19
+ */
20
+ export declare class LoggingObserver implements StreamObserver {
21
+ private readonly logRef;
22
+ private sessionStartTime?;
23
+ private currentTextBuffer;
24
+ private currentReasoningBuffer;
25
+ private reasoningLoggedViaChunks;
26
+ constructor(options?: LoggingObserverOptions);
27
+ attach(events: StreamEventBus, config: StreamConfig): void;
28
+ private onSessionStart;
29
+ private onRequestStart;
30
+ private onChunk;
31
+ private flushTextBuffer;
32
+ private flushReasoningBuffer;
33
+ private formatToolCall;
34
+ private formatToolResult;
35
+ private onStepComplete;
36
+ private onRetry;
37
+ private onFallback;
38
+ private onStreamFinish;
39
+ private onSessionComplete;
40
+ private onSessionError;
41
+ private onSessionAbort;
42
+ private computeDuration;
43
+ private saveLog;
44
+ getLogContent(): string;
45
+ }
46
+ //# sourceMappingURL=logging.d.ts.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"logging.d.ts","sourceRoot":"","sources":["../../../../../src/ai-service/llm/stream/observers/logging.ts"],"names":[],"mappings":"AAQA,OAAO,KAAK,EAAE,YAAY,EAAE,MAAM,cAAc,CAAC;AACjD,OAAO,KAAK,EAAE,cAAc,EAAkB,MAAM,iBAAiB,CAAC;AACtE,OAAO,KAAK,EAAE,cAAc,EAAE,MAAM,gBAAgB,CAAC;AAGrD,MAAM,WAAW,MAAM;IACrB,OAAO,EAAE,MAAM,CAAC;CACjB;AAED,MAAM,WAAW,sBAAsB;IACrC,MAAM,CAAC,EAAE,MAAM,CAAC;CACjB;AAgDD;;;;;;;;;GASG;AACH,qBAAa,eAAgB,YAAW,cAAc;IACpD,OAAO,CAAC,QAAQ,CAAC,MAAM,CAAS;IAChC,OAAO,CAAC,gBAAgB,CAAC,CAAS;IAClC,OAAO,CAAC,iBAAiB,CAAM;IAC/B,OAAO,CAAC,sBAAsB,CAAM;IACpC,OAAO,CAAC,wBAAwB,CAAS;gBAE7B,OAAO,GAAE,sBAA2B;IAIhD,MAAM,CAAC,MAAM,EAAE,cAAc,EAAE,MAAM,EAAE,YAAY,GAAG,IAAI;IA6C1D,OAAO,CAAC,cAAc;IA8BtB,OAAO,CAAC,cAAc;IAwBtB,OAAO,CAAC,OAAO;IA2Cf,OAAO,CAAC,eAAe;IAOvB,OAAO,CAAC,oBAAoB;IAQ5B,OAAO,CAAC,cAAc;IAStB,OAAO,CAAC,gBAAgB;IAUxB,OAAO,CAAC,cAAc;IAOtB,OAAO,CAAC,OAAO;IAKf,OAAO,CAAC,UAAU;IAQlB,OAAO,CAAC,cAAc;YAoBR,iBAAiB;YAgBjB,cAAc;YAiBd,cAAc;IAc5B,OAAO,CAAC,eAAe;YAUT,OAAO;IAyBrB,aAAa,IAAI,MAAM;CAGxB"}