@codemieai/code 0.0.16 → 0.0.17

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 (408) hide show
  1. package/README.md +62 -5
  2. package/bin/agent-executor.js +7 -28
  3. package/bin/codemie-claude.js +18 -0
  4. package/bin/codemie-codex.js +18 -0
  5. package/bin/codemie-deepagents.js +18 -0
  6. package/bin/codemie-gemini.js +18 -0
  7. package/dist/agents/codemie-code/agent.d.ts.map +1 -1
  8. package/dist/agents/codemie-code/agent.js +3 -32
  9. package/dist/agents/codemie-code/agent.js.map +1 -1
  10. package/dist/agents/codemie-code/tools/planning.d.ts +2 -2
  11. package/dist/agents/core/AgentCLI.d.ts.map +1 -1
  12. package/dist/agents/core/AgentCLI.js +25 -59
  13. package/dist/agents/core/AgentCLI.js.map +1 -1
  14. package/dist/agents/core/BaseAgentAdapter.d.ts +9 -1
  15. package/dist/agents/core/BaseAgentAdapter.d.ts.map +1 -1
  16. package/dist/agents/core/BaseAgentAdapter.js +103 -10
  17. package/dist/agents/core/BaseAgentAdapter.js.map +1 -1
  18. package/dist/agents/core/BaseMetricsAdapter.d.ts +64 -0
  19. package/dist/agents/core/BaseMetricsAdapter.d.ts.map +1 -0
  20. package/dist/agents/core/BaseMetricsAdapter.js +74 -0
  21. package/dist/agents/core/BaseMetricsAdapter.js.map +1 -0
  22. package/dist/agents/core/types.d.ts +1 -0
  23. package/dist/agents/core/types.d.ts.map +1 -1
  24. package/dist/agents/plugins/claude.metrics.d.ts +112 -0
  25. package/dist/agents/plugins/claude.metrics.d.ts.map +1 -0
  26. package/dist/agents/plugins/claude.metrics.js +700 -0
  27. package/dist/agents/plugins/claude.metrics.js.map +1 -0
  28. package/dist/agents/plugins/claude.plugin.d.ts +9 -0
  29. package/dist/agents/plugins/claude.plugin.d.ts.map +1 -1
  30. package/dist/agents/plugins/claude.plugin.js +52 -10
  31. package/dist/agents/plugins/claude.plugin.js.map +1 -1
  32. package/dist/agents/plugins/codemie-code.plugin.d.ts.map +1 -1
  33. package/dist/agents/plugins/codemie-code.plugin.js +45 -13
  34. package/dist/agents/plugins/codemie-code.plugin.js.map +1 -1
  35. package/dist/agents/plugins/codex.plugin.d.ts.map +1 -1
  36. package/dist/agents/plugins/codex.plugin.js +0 -2
  37. package/dist/agents/plugins/codex.plugin.js.map +1 -1
  38. package/dist/agents/plugins/gemini.plugin.d.ts.map +1 -1
  39. package/dist/agents/plugins/gemini.plugin.js +0 -7
  40. package/dist/agents/plugins/gemini.plugin.js.map +1 -1
  41. package/dist/agents/plugins/history-parser.d.ts +52 -0
  42. package/dist/agents/plugins/history-parser.d.ts.map +1 -0
  43. package/dist/agents/plugins/history-parser.js +155 -0
  44. package/dist/agents/plugins/history-parser.js.map +1 -0
  45. package/dist/cli/commands/analytics/aggregator.d.ts +58 -0
  46. package/dist/cli/commands/analytics/aggregator.d.ts.map +1 -0
  47. package/dist/cli/commands/analytics/aggregator.js +702 -0
  48. package/dist/cli/commands/analytics/aggregator.js.map +1 -0
  49. package/dist/cli/commands/analytics/data-loader.d.ts +84 -0
  50. package/dist/cli/commands/analytics/data-loader.d.ts.map +1 -0
  51. package/dist/cli/commands/analytics/data-loader.js +211 -0
  52. package/dist/cli/commands/analytics/data-loader.js.map +1 -0
  53. package/dist/cli/commands/analytics/exporter.d.ts +20 -0
  54. package/dist/cli/commands/analytics/exporter.d.ts.map +1 -0
  55. package/dist/cli/commands/analytics/exporter.js +103 -0
  56. package/dist/cli/commands/analytics/exporter.js.map +1 -0
  57. package/dist/cli/commands/analytics/formatter.d.ts +49 -0
  58. package/dist/cli/commands/analytics/formatter.d.ts.map +1 -0
  59. package/dist/cli/commands/analytics/formatter.js +309 -0
  60. package/dist/cli/commands/analytics/formatter.js.map +1 -0
  61. package/dist/cli/commands/analytics/index.d.ts +6 -0
  62. package/dist/cli/commands/analytics/index.d.ts.map +1 -0
  63. package/dist/cli/commands/analytics/index.js +157 -0
  64. package/dist/cli/commands/analytics/index.js.map +1 -0
  65. package/dist/cli/commands/analytics/model-normalizer.d.ts +21 -0
  66. package/dist/cli/commands/analytics/model-normalizer.d.ts.map +1 -0
  67. package/dist/cli/commands/analytics/model-normalizer.js +44 -0
  68. package/dist/cli/commands/analytics/model-normalizer.js.map +1 -0
  69. package/dist/cli/commands/analytics/types.d.ts +188 -0
  70. package/dist/cli/commands/analytics/types.d.ts.map +1 -0
  71. package/dist/cli/commands/analytics/types.js +6 -0
  72. package/dist/cli/commands/analytics/types.js.map +1 -0
  73. package/dist/cli/commands/doctor/checks/AwsCliCheck.d.ts +9 -0
  74. package/dist/cli/commands/doctor/checks/AwsCliCheck.d.ts.map +1 -0
  75. package/dist/cli/commands/doctor/checks/AwsCliCheck.js +28 -0
  76. package/dist/cli/commands/doctor/checks/AwsCliCheck.js.map +1 -0
  77. package/dist/cli/commands/doctor/checks/PythonCheck.d.ts.map +1 -1
  78. package/dist/cli/commands/doctor/checks/PythonCheck.js +10 -0
  79. package/dist/cli/commands/doctor/checks/PythonCheck.js.map +1 -1
  80. package/dist/cli/commands/doctor/checks/WorkflowsCheck.d.ts.map +1 -1
  81. package/dist/cli/commands/doctor/checks/WorkflowsCheck.js +2 -1
  82. package/dist/cli/commands/doctor/checks/WorkflowsCheck.js.map +1 -1
  83. package/dist/cli/commands/doctor/checks/index.d.ts +1 -0
  84. package/dist/cli/commands/doctor/checks/index.d.ts.map +1 -1
  85. package/dist/cli/commands/doctor/checks/index.js +1 -0
  86. package/dist/cli/commands/doctor/checks/index.js.map +1 -1
  87. package/dist/cli/commands/doctor/index.d.ts.map +1 -1
  88. package/dist/cli/commands/doctor/index.js +85 -3
  89. package/dist/cli/commands/doctor/index.js.map +1 -1
  90. package/dist/cli/commands/profile.d.ts.map +1 -1
  91. package/dist/cli/commands/profile.js +49 -89
  92. package/dist/cli/commands/profile.js.map +1 -1
  93. package/dist/cli/commands/setup.js +1 -21
  94. package/dist/cli/commands/setup.js.map +1 -1
  95. package/dist/cli/index.js +1 -1
  96. package/dist/cli/index.js.map +1 -1
  97. package/dist/env/types.d.ts +14 -2
  98. package/dist/env/types.d.ts.map +1 -1
  99. package/dist/env/types.js.map +1 -1
  100. package/dist/metrics/MetricsOrchestrator.d.ts +67 -0
  101. package/dist/metrics/MetricsOrchestrator.d.ts.map +1 -0
  102. package/dist/metrics/MetricsOrchestrator.js +287 -0
  103. package/dist/metrics/MetricsOrchestrator.js.map +1 -0
  104. package/dist/metrics/config.d.ts +38 -0
  105. package/dist/metrics/config.d.ts.map +1 -0
  106. package/dist/metrics/config.js +80 -0
  107. package/dist/metrics/config.js.map +1 -0
  108. package/dist/metrics/core/DeltaWriter.d.ts +49 -0
  109. package/dist/metrics/core/DeltaWriter.d.ts.map +1 -0
  110. package/dist/metrics/core/DeltaWriter.js +146 -0
  111. package/dist/metrics/core/DeltaWriter.js.map +1 -0
  112. package/dist/metrics/core/FileSnapshotter.d.ts +22 -0
  113. package/dist/metrics/core/FileSnapshotter.d.ts.map +1 -0
  114. package/dist/metrics/core/FileSnapshotter.js +74 -0
  115. package/dist/metrics/core/FileSnapshotter.js.map +1 -0
  116. package/dist/metrics/core/SessionCorrelator.d.ts +34 -0
  117. package/dist/metrics/core/SessionCorrelator.d.ts.map +1 -0
  118. package/dist/metrics/core/SessionCorrelator.js +115 -0
  119. package/dist/metrics/core/SessionCorrelator.js.map +1 -0
  120. package/dist/metrics/core/SyncStateManager.d.ts +69 -0
  121. package/dist/metrics/core/SyncStateManager.d.ts.map +1 -0
  122. package/dist/metrics/core/SyncStateManager.js +284 -0
  123. package/dist/metrics/core/SyncStateManager.js.map +1 -0
  124. package/dist/metrics/index.d.ts +9 -0
  125. package/dist/metrics/index.d.ts.map +1 -0
  126. package/dist/metrics/index.js +11 -0
  127. package/dist/metrics/index.js.map +1 -0
  128. package/dist/metrics/session/SessionStore.d.ts +43 -0
  129. package/dist/metrics/session/SessionStore.d.ts.map +1 -0
  130. package/dist/metrics/session/SessionStore.js +142 -0
  131. package/dist/metrics/session/SessionStore.js.map +1 -0
  132. package/dist/metrics/sync/MetricsApiClient.d.ts +32 -0
  133. package/dist/metrics/sync/MetricsApiClient.d.ts.map +1 -0
  134. package/dist/metrics/sync/MetricsApiClient.js +155 -0
  135. package/dist/metrics/sync/MetricsApiClient.js.map +1 -0
  136. package/dist/metrics/sync/aggregator.d.ts +13 -0
  137. package/dist/metrics/sync/aggregator.d.ts.map +1 -0
  138. package/dist/metrics/sync/aggregator.js +196 -0
  139. package/dist/metrics/sync/aggregator.js.map +1 -0
  140. package/dist/metrics/sync/index.d.ts +10 -0
  141. package/dist/metrics/sync/index.d.ts.map +1 -0
  142. package/dist/metrics/sync/index.js +10 -0
  143. package/dist/metrics/sync/index.js.map +1 -0
  144. package/dist/metrics/sync/jsonl-writer.d.ts +28 -0
  145. package/dist/metrics/sync/jsonl-writer.d.ts.map +1 -0
  146. package/dist/metrics/sync/jsonl-writer.js +72 -0
  147. package/dist/metrics/sync/jsonl-writer.js.map +1 -0
  148. package/dist/metrics/sync/types.d.ts +72 -0
  149. package/dist/metrics/sync/types.d.ts.map +1 -0
  150. package/dist/metrics/sync/types.js +7 -0
  151. package/dist/metrics/sync/types.js.map +1 -0
  152. package/dist/metrics/types.d.ts +308 -0
  153. package/dist/metrics/types.d.ts.map +1 -0
  154. package/dist/metrics/types.js +8 -0
  155. package/dist/metrics/types.js.map +1 -0
  156. package/dist/providers/index.d.ts +2 -0
  157. package/dist/providers/index.d.ts.map +1 -1
  158. package/dist/providers/index.js +2 -0
  159. package/dist/providers/index.js.map +1 -1
  160. package/dist/providers/integration/setup-ui.d.ts +1 -1
  161. package/dist/providers/integration/setup-ui.d.ts.map +1 -1
  162. package/dist/providers/integration/setup-ui.js +51 -6
  163. package/dist/providers/integration/setup-ui.js.map +1 -1
  164. package/dist/providers/plugins/bedrock/bedrock.health.d.ts +53 -0
  165. package/dist/providers/plugins/bedrock/bedrock.health.d.ts.map +1 -0
  166. package/dist/providers/plugins/bedrock/bedrock.health.js +115 -0
  167. package/dist/providers/plugins/bedrock/bedrock.health.js.map +1 -0
  168. package/dist/providers/plugins/bedrock/bedrock.models.d.ts +26 -0
  169. package/dist/providers/plugins/bedrock/bedrock.models.d.ts.map +1 -0
  170. package/dist/providers/plugins/bedrock/bedrock.models.js +89 -0
  171. package/dist/providers/plugins/bedrock/bedrock.models.js.map +1 -0
  172. package/dist/providers/plugins/bedrock/bedrock.setup-steps.d.ts +12 -0
  173. package/dist/providers/plugins/bedrock/bedrock.setup-steps.d.ts.map +1 -0
  174. package/dist/providers/plugins/bedrock/bedrock.setup-steps.js +308 -0
  175. package/dist/providers/plugins/bedrock/bedrock.setup-steps.js.map +1 -0
  176. package/dist/providers/plugins/bedrock/bedrock.template.d.ts +11 -0
  177. package/dist/providers/plugins/bedrock/bedrock.template.d.ts.map +1 -0
  178. package/dist/providers/plugins/bedrock/bedrock.template.js +85 -0
  179. package/dist/providers/plugins/bedrock/bedrock.template.js.map +1 -0
  180. package/dist/providers/plugins/bedrock/index.d.ts +11 -0
  181. package/dist/providers/plugins/bedrock/index.d.ts.map +1 -0
  182. package/dist/providers/plugins/bedrock/index.js +11 -0
  183. package/dist/providers/plugins/bedrock/index.js.map +1 -0
  184. package/dist/providers/plugins/ollama/ollama.template.d.ts.map +1 -1
  185. package/dist/providers/plugins/ollama/ollama.template.js +2 -0
  186. package/dist/providers/plugins/ollama/ollama.template.js.map +1 -1
  187. package/dist/providers/plugins/sso/sso.http-client.d.ts +2 -0
  188. package/dist/providers/plugins/sso/sso.http-client.d.ts.map +1 -1
  189. package/dist/providers/plugins/sso/sso.http-client.js +9 -3
  190. package/dist/providers/plugins/sso/sso.http-client.js.map +1 -1
  191. package/dist/proxy/http-client.d.ts.map +1 -1
  192. package/dist/proxy/http-client.js +49 -14
  193. package/dist/proxy/http-client.js.map +1 -1
  194. package/dist/proxy/plugins/endpoint-blocker.plugin.d.ts +19 -0
  195. package/dist/proxy/plugins/endpoint-blocker.plugin.d.ts.map +1 -0
  196. package/dist/proxy/plugins/endpoint-blocker.plugin.js +61 -0
  197. package/dist/proxy/plugins/endpoint-blocker.plugin.js.map +1 -0
  198. package/dist/proxy/plugins/header-injection.plugin.js +3 -0
  199. package/dist/proxy/plugins/header-injection.plugin.js.map +1 -1
  200. package/dist/proxy/plugins/index.d.ts +3 -1
  201. package/dist/proxy/plugins/index.d.ts.map +1 -1
  202. package/dist/proxy/plugins/index.js +5 -1
  203. package/dist/proxy/plugins/index.js.map +1 -1
  204. package/dist/proxy/plugins/logging.plugin.d.ts +3 -3
  205. package/dist/proxy/plugins/logging.plugin.js +84 -20
  206. package/dist/proxy/plugins/logging.plugin.js.map +1 -1
  207. package/dist/proxy/plugins/metrics-sync.plugin.d.ts +33 -0
  208. package/dist/proxy/plugins/metrics-sync.plugin.d.ts.map +1 -0
  209. package/dist/proxy/plugins/metrics-sync.plugin.js +310 -0
  210. package/dist/proxy/plugins/metrics-sync.plugin.js.map +1 -0
  211. package/dist/proxy/plugins/registry.d.ts.map +1 -1
  212. package/dist/proxy/plugins/registry.js +8 -1
  213. package/dist/proxy/plugins/registry.js.map +1 -1
  214. package/dist/proxy/plugins/types.d.ts +6 -2
  215. package/dist/proxy/plugins/types.d.ts.map +1 -1
  216. package/dist/proxy/types.d.ts +7 -0
  217. package/dist/proxy/types.d.ts.map +1 -1
  218. package/dist/utils/ascii-logo.d.ts +21 -0
  219. package/dist/utils/ascii-logo.d.ts.map +1 -0
  220. package/dist/utils/ascii-logo.js +75 -0
  221. package/dist/utils/ascii-logo.js.map +1 -0
  222. package/dist/utils/codemie-proxy.d.ts +0 -6
  223. package/dist/utils/codemie-proxy.d.ts.map +1 -1
  224. package/dist/utils/codemie-proxy.js +46 -56
  225. package/dist/utils/codemie-proxy.js.map +1 -1
  226. package/dist/utils/config-loader.d.ts.map +1 -1
  227. package/dist/utils/config-loader.js +22 -6
  228. package/dist/utils/config-loader.js.map +1 -1
  229. package/dist/utils/exec.d.ts +11 -0
  230. package/dist/utils/exec.d.ts.map +1 -1
  231. package/dist/utils/exec.js +17 -1
  232. package/dist/utils/exec.js.map +1 -1
  233. package/dist/utils/goodbye-messages.d.ts +13 -0
  234. package/dist/utils/goodbye-messages.d.ts.map +1 -0
  235. package/dist/utils/goodbye-messages.js +245 -0
  236. package/dist/utils/goodbye-messages.js.map +1 -0
  237. package/dist/utils/json-parser.d.ts +52 -0
  238. package/dist/utils/json-parser.d.ts.map +1 -0
  239. package/dist/utils/json-parser.js +126 -0
  240. package/dist/utils/json-parser.js.map +1 -0
  241. package/dist/utils/logger.d.ts +37 -1
  242. package/dist/utils/logger.d.ts.map +1 -1
  243. package/dist/utils/logger.js +92 -20
  244. package/dist/utils/logger.js.map +1 -1
  245. package/dist/utils/sanitize.d.ts.map +1 -1
  246. package/dist/utils/sanitize.js +0 -1
  247. package/dist/utils/sanitize.js.map +1 -1
  248. package/dist/utils/which.d.ts +20 -0
  249. package/dist/utils/which.d.ts.map +1 -0
  250. package/dist/utils/which.js +47 -0
  251. package/dist/utils/which.js.map +1 -0
  252. package/package.json +10 -5
  253. package/dist/analytics/aggregation/adapters/claude.adapter.d.ts +0 -37
  254. package/dist/analytics/aggregation/adapters/claude.adapter.d.ts.map +0 -1
  255. package/dist/analytics/aggregation/adapters/claude.adapter.js +0 -531
  256. package/dist/analytics/aggregation/adapters/claude.adapter.js.map +0 -1
  257. package/dist/analytics/aggregation/adapters/codex.adapter.d.ts +0 -25
  258. package/dist/analytics/aggregation/adapters/codex.adapter.d.ts.map +0 -1
  259. package/dist/analytics/aggregation/adapters/codex.adapter.js +0 -396
  260. package/dist/analytics/aggregation/adapters/codex.adapter.js.map +0 -1
  261. package/dist/analytics/aggregation/adapters/gemini.adapter.d.ts +0 -36
  262. package/dist/analytics/aggregation/adapters/gemini.adapter.d.ts.map +0 -1
  263. package/dist/analytics/aggregation/adapters/gemini.adapter.js +0 -365
  264. package/dist/analytics/aggregation/adapters/gemini.adapter.js.map +0 -1
  265. package/dist/analytics/aggregation/adapters/index.d.ts +0 -7
  266. package/dist/analytics/aggregation/adapters/index.d.ts.map +0 -1
  267. package/dist/analytics/aggregation/adapters/index.js +0 -7
  268. package/dist/analytics/aggregation/adapters/index.js.map +0 -1
  269. package/dist/analytics/aggregation/aggregator.d.ts +0 -49
  270. package/dist/analytics/aggregation/aggregator.d.ts.map +0 -1
  271. package/dist/analytics/aggregation/aggregator.js +0 -239
  272. package/dist/analytics/aggregation/aggregator.js.map +0 -1
  273. package/dist/analytics/aggregation/core/BaseAnalyticsAdapter.d.ts +0 -99
  274. package/dist/analytics/aggregation/core/BaseAnalyticsAdapter.d.ts.map +0 -1
  275. package/dist/analytics/aggregation/core/BaseAnalyticsAdapter.js +0 -110
  276. package/dist/analytics/aggregation/core/BaseAnalyticsAdapter.js.map +0 -1
  277. package/dist/analytics/aggregation/core/adapter.interface.d.ts +0 -76
  278. package/dist/analytics/aggregation/core/adapter.interface.d.ts.map +0 -1
  279. package/dist/analytics/aggregation/core/adapter.interface.js +0 -9
  280. package/dist/analytics/aggregation/core/adapter.interface.js.map +0 -1
  281. package/dist/analytics/aggregation/core/aggregation-utils.d.ts +0 -86
  282. package/dist/analytics/aggregation/core/aggregation-utils.d.ts.map +0 -1
  283. package/dist/analytics/aggregation/core/aggregation-utils.js +0 -126
  284. package/dist/analytics/aggregation/core/aggregation-utils.js.map +0 -1
  285. package/dist/analytics/aggregation/core/discovery.d.ts +0 -40
  286. package/dist/analytics/aggregation/core/discovery.d.ts.map +0 -1
  287. package/dist/analytics/aggregation/core/discovery.js +0 -132
  288. package/dist/analytics/aggregation/core/discovery.js.map +0 -1
  289. package/dist/analytics/aggregation/core/file-utils.d.ts +0 -24
  290. package/dist/analytics/aggregation/core/file-utils.d.ts.map +0 -1
  291. package/dist/analytics/aggregation/core/file-utils.js +0 -143
  292. package/dist/analytics/aggregation/core/file-utils.js.map +0 -1
  293. package/dist/analytics/aggregation/core/index.d.ts +0 -14
  294. package/dist/analytics/aggregation/core/index.d.ts.map +0 -1
  295. package/dist/analytics/aggregation/core/index.js +0 -14
  296. package/dist/analytics/aggregation/core/index.js.map +0 -1
  297. package/dist/analytics/aggregation/core/project-mapping.d.ts +0 -50
  298. package/dist/analytics/aggregation/core/project-mapping.d.ts.map +0 -1
  299. package/dist/analytics/aggregation/core/project-mapping.js +0 -102
  300. package/dist/analytics/aggregation/core/project-mapping.js.map +0 -1
  301. package/dist/analytics/aggregation/core/streaming.d.ts +0 -26
  302. package/dist/analytics/aggregation/core/streaming.d.ts.map +0 -1
  303. package/dist/analytics/aggregation/core/streaming.js +0 -58
  304. package/dist/analytics/aggregation/core/streaming.js.map +0 -1
  305. package/dist/analytics/aggregation/core/user-prompt-source.d.ts +0 -81
  306. package/dist/analytics/aggregation/core/user-prompt-source.d.ts.map +0 -1
  307. package/dist/analytics/aggregation/core/user-prompt-source.js +0 -69
  308. package/dist/analytics/aggregation/core/user-prompt-source.js.map +0 -1
  309. package/dist/analytics/aggregation/core/user-prompt-sources/json.d.ts +0 -49
  310. package/dist/analytics/aggregation/core/user-prompt-sources/json.d.ts.map +0 -1
  311. package/dist/analytics/aggregation/core/user-prompt-sources/json.js +0 -66
  312. package/dist/analytics/aggregation/core/user-prompt-sources/json.js.map +0 -1
  313. package/dist/analytics/aggregation/core/user-prompt-sources/jsonl.d.ts +0 -43
  314. package/dist/analytics/aggregation/core/user-prompt-sources/jsonl.d.ts.map +0 -1
  315. package/dist/analytics/aggregation/core/user-prompt-sources/jsonl.js +0 -56
  316. package/dist/analytics/aggregation/core/user-prompt-sources/jsonl.js.map +0 -1
  317. package/dist/analytics/aggregation/index.d.ts +0 -8
  318. package/dist/analytics/aggregation/index.d.ts.map +0 -1
  319. package/dist/analytics/aggregation/index.js +0 -8
  320. package/dist/analytics/aggregation/index.js.map +0 -1
  321. package/dist/analytics/aggregation/types.d.ts +0 -278
  322. package/dist/analytics/aggregation/types.d.ts.map +0 -1
  323. package/dist/analytics/aggregation/types.js +0 -8
  324. package/dist/analytics/aggregation/types.js.map +0 -1
  325. package/dist/analytics/collector.d.ts +0 -46
  326. package/dist/analytics/collector.d.ts.map +0 -1
  327. package/dist/analytics/collector.js +0 -83
  328. package/dist/analytics/collector.js.map +0 -1
  329. package/dist/analytics/config.d.ts +0 -15
  330. package/dist/analytics/config.d.ts.map +0 -1
  331. package/dist/analytics/config.js +0 -65
  332. package/dist/analytics/config.js.map +0 -1
  333. package/dist/analytics/index.d.ts +0 -99
  334. package/dist/analytics/index.d.ts.map +0 -1
  335. package/dist/analytics/index.js +0 -280
  336. package/dist/analytics/index.js.map +0 -1
  337. package/dist/analytics/plugins/api-metrics.plugin.d.ts +0 -26
  338. package/dist/analytics/plugins/api-metrics.plugin.d.ts.map +0 -1
  339. package/dist/analytics/plugins/api-metrics.plugin.js +0 -97
  340. package/dist/analytics/plugins/api-metrics.plugin.js.map +0 -1
  341. package/dist/analytics/plugins/index.d.ts +0 -15
  342. package/dist/analytics/plugins/index.d.ts.map +0 -1
  343. package/dist/analytics/plugins/index.js +0 -15
  344. package/dist/analytics/plugins/index.js.map +0 -1
  345. package/dist/analytics/plugins/model-metrics.plugin.d.ts +0 -39
  346. package/dist/analytics/plugins/model-metrics.plugin.d.ts.map +0 -1
  347. package/dist/analytics/plugins/model-metrics.plugin.js +0 -105
  348. package/dist/analytics/plugins/model-metrics.plugin.js.map +0 -1
  349. package/dist/analytics/plugins/provider-metrics.plugin.d.ts +0 -41
  350. package/dist/analytics/plugins/provider-metrics.plugin.d.ts.map +0 -1
  351. package/dist/analytics/plugins/provider-metrics.plugin.js +0 -123
  352. package/dist/analytics/plugins/provider-metrics.plugin.js.map +0 -1
  353. package/dist/analytics/plugins/types.d.ts +0 -61
  354. package/dist/analytics/plugins/types.d.ts.map +0 -1
  355. package/dist/analytics/plugins/types.js +0 -54
  356. package/dist/analytics/plugins/types.js.map +0 -1
  357. package/dist/analytics/privacy.d.ts +0 -10
  358. package/dist/analytics/privacy.d.ts.map +0 -1
  359. package/dist/analytics/privacy.js +0 -20
  360. package/dist/analytics/privacy.js.map +0 -1
  361. package/dist/analytics/remote-submission/cursor-manager.d.ts +0 -71
  362. package/dist/analytics/remote-submission/cursor-manager.d.ts.map +0 -1
  363. package/dist/analytics/remote-submission/cursor-manager.js +0 -204
  364. package/dist/analytics/remote-submission/cursor-manager.js.map +0 -1
  365. package/dist/analytics/remote-submission/index.d.ts +0 -12
  366. package/dist/analytics/remote-submission/index.d.ts.map +0 -1
  367. package/dist/analytics/remote-submission/index.js +0 -11
  368. package/dist/analytics/remote-submission/index.js.map +0 -1
  369. package/dist/analytics/remote-submission/lock-manager.d.ts +0 -71
  370. package/dist/analytics/remote-submission/lock-manager.d.ts.map +0 -1
  371. package/dist/analytics/remote-submission/lock-manager.js +0 -238
  372. package/dist/analytics/remote-submission/lock-manager.js.map +0 -1
  373. package/dist/analytics/remote-submission/metric-transformer.d.ts +0 -21
  374. package/dist/analytics/remote-submission/metric-transformer.d.ts.map +0 -1
  375. package/dist/analytics/remote-submission/metric-transformer.js +0 -82
  376. package/dist/analytics/remote-submission/metric-transformer.js.map +0 -1
  377. package/dist/analytics/remote-submission/submitter.d.ts +0 -79
  378. package/dist/analytics/remote-submission/submitter.d.ts.map +0 -1
  379. package/dist/analytics/remote-submission/submitter.js +0 -362
  380. package/dist/analytics/remote-submission/submitter.js.map +0 -1
  381. package/dist/analytics/remote-submission/types.d.ts +0 -123
  382. package/dist/analytics/remote-submission/types.d.ts.map +0 -1
  383. package/dist/analytics/remote-submission/types.js +0 -13
  384. package/dist/analytics/remote-submission/types.js.map +0 -1
  385. package/dist/analytics/session.d.ts +0 -56
  386. package/dist/analytics/session.d.ts.map +0 -1
  387. package/dist/analytics/session.js +0 -95
  388. package/dist/analytics/session.js.map +0 -1
  389. package/dist/analytics/types.d.ts +0 -104
  390. package/dist/analytics/types.d.ts.map +0 -1
  391. package/dist/analytics/types.js +0 -15
  392. package/dist/analytics/types.js.map +0 -1
  393. package/dist/analytics/writer.d.ts +0 -18
  394. package/dist/analytics/writer.d.ts.map +0 -1
  395. package/dist/analytics/writer.js +0 -44
  396. package/dist/analytics/writer.js.map +0 -1
  397. package/dist/cli/commands/analytics.d.ts +0 -3
  398. package/dist/cli/commands/analytics.d.ts.map +0 -1
  399. package/dist/cli/commands/analytics.js +0 -748
  400. package/dist/cli/commands/analytics.js.map +0 -1
  401. package/dist/utils/analytics-reader.d.ts +0 -117
  402. package/dist/utils/analytics-reader.d.ts.map +0 -1
  403. package/dist/utils/analytics-reader.js +0 -421
  404. package/dist/utils/analytics-reader.js.map +0 -1
  405. package/dist/utils/date-formatter.d.ts +0 -88
  406. package/dist/utils/date-formatter.d.ts.map +0 -1
  407. package/dist/utils/date-formatter.js +0 -133
  408. package/dist/utils/date-formatter.js.map +0 -1
@@ -1,11 +1,11 @@
1
1
  /**
2
- * Logging Plugin - Request/Response Logging to Log Files
2
+ * Logging Plugin - Request/Response Logging
3
3
  * Priority: 50 (runs before analytics)
4
4
  *
5
- * Purpose: Logs detailed proxy request/response information to log files
5
+ * Purpose: Logs detailed proxy request/response information
6
6
  * Separates operational logging from analytics metrics
7
7
  *
8
- * Log Level: INFO (file-only, no console output)
8
+ * Log Level: DEBUG (file + console when CODEMIE_DEBUG=1)
9
9
  * Log Location: ~/.codemie/logs/debug-YYYY-MM-DD.log
10
10
  *
11
11
  * SOLID: Single responsibility = log proxy activity
@@ -23,12 +23,20 @@ export class LoggingPlugin {
23
23
  }
24
24
  class LoggingInterceptor {
25
25
  name = 'logging';
26
+ chunkCount = 0;
27
+ totalBytes = 0;
26
28
  async onRequest(context) {
27
29
  try {
28
- logger.info(`[proxy-request] ${context.method} ${context.url}`, {
30
+ // Reset counters for new request
31
+ this.chunkCount = 0;
32
+ this.totalBytes = 0;
33
+ logger.debug(`[proxy-request] ${context.method} ${context.url}`, {
29
34
  requestId: context.requestId,
30
35
  sessionId: context.sessionId,
31
36
  agent: context.agentName,
37
+ profile: context.profile,
38
+ provider: context.provider,
39
+ model: context.model,
32
40
  targetUrl: context.targetUrl,
33
41
  bodySize: context.requestBody?.length || 0,
34
42
  headers: this.sanitizeHeaders(context.headers)
@@ -39,14 +47,71 @@ class LoggingInterceptor {
39
47
  logger.error(`[${this.name}] Error logging request:`, error);
40
48
  }
41
49
  }
50
+ async onResponseHeaders(context, headers) {
51
+ try {
52
+ logger.debug(`[proxy-response-headers] ${context.url}`, {
53
+ requestId: context.requestId,
54
+ sessionId: context.sessionId,
55
+ agent: context.agentName,
56
+ profile: context.profile,
57
+ provider: context.provider,
58
+ model: context.model,
59
+ headers: {
60
+ 'content-type': headers['content-type'],
61
+ 'content-length': headers['content-length'],
62
+ 'transfer-encoding': headers['transfer-encoding']
63
+ }
64
+ });
65
+ }
66
+ catch (error) {
67
+ logger.error(`[${this.name}] Error logging response headers:`, error);
68
+ }
69
+ }
70
+ async onResponseChunk(context, chunk) {
71
+ try {
72
+ this.chunkCount++;
73
+ this.totalBytes += chunk.length;
74
+ // Log every 1000th chunk to avoid spam (or first/last chunks)
75
+ if (this.chunkCount === 1 || this.chunkCount % 1000 === 0) {
76
+ logger.debug(`[proxy-streaming] ${context.url}`, {
77
+ requestId: context.requestId,
78
+ sessionId: context.sessionId,
79
+ chunkNumber: this.chunkCount,
80
+ chunkSize: chunk.length,
81
+ totalBytes: this.totalBytes
82
+ });
83
+ }
84
+ }
85
+ catch (error) {
86
+ logger.error(`[${this.name}] Error logging chunk:`, error);
87
+ }
88
+ return chunk;
89
+ }
42
90
  async onResponseComplete(context, metadata) {
43
91
  try {
44
- logger.info(`[proxy-response] ${metadata.statusCode} ${context.url} (${metadata.durationMs}ms)`, {
92
+ logger.debug(`[proxy-response] ${metadata.statusCode} ${context.url} (${metadata.durationMs}ms)`, {
45
93
  requestId: context.requestId,
94
+ sessionId: context.sessionId,
95
+ agent: context.agentName,
96
+ profile: context.profile,
97
+ provider: context.provider,
98
+ model: context.model,
46
99
  statusCode: metadata.statusCode,
47
100
  statusMessage: metadata.statusMessage,
48
101
  bytesSent: metadata.bytesSent,
49
- durationMs: metadata.durationMs
102
+ durationMs: metadata.durationMs,
103
+ totalChunks: this.chunkCount,
104
+ totalBytesStreamed: this.totalBytes
105
+ });
106
+ // Log completion marker to track if we reach this point
107
+ logger.debug(`[proxy-complete] Request fully processed for ${context.url}`, {
108
+ requestId: context.requestId,
109
+ sessionId: context.sessionId,
110
+ agent: context.agentName,
111
+ profile: context.profile,
112
+ provider: context.provider,
113
+ model: context.model,
114
+ finalStatus: 'success'
50
115
  });
51
116
  }
52
117
  catch (error) {
@@ -56,10 +121,16 @@ class LoggingInterceptor {
56
121
  }
57
122
  async onError(context, error) {
58
123
  try {
59
- logger.info(`[proxy-error] ${error.name}: ${error.message}`, {
124
+ logger.debug(`[proxy-error] ${error.name}: ${error.message}`, {
60
125
  requestId: context.requestId,
126
+ sessionId: context.sessionId,
127
+ agent: context.agentName,
128
+ profile: context.profile,
129
+ provider: context.provider,
130
+ model: context.model,
61
131
  url: context.url,
62
132
  errorType: error.name,
133
+ errorMessage: error.message,
63
134
  errorStack: error.stack
64
135
  });
65
136
  }
@@ -69,24 +140,17 @@ class LoggingInterceptor {
69
140
  }
70
141
  }
71
142
  /**
72
- * Sanitize headers to remove sensitive data
143
+ * Filter headers to only include X-Codemie headers
73
144
  */
74
145
  sanitizeHeaders(headers) {
75
- const sanitized = {};
146
+ const filtered = {};
76
147
  for (const [key, value] of Object.entries(headers)) {
77
- const lowerKey = key.toLowerCase();
78
- // Mask sensitive headers
79
- if (lowerKey.includes('authorization') ||
80
- lowerKey.includes('api-key') ||
81
- lowerKey.includes('token') ||
82
- lowerKey.includes('cookie')) {
83
- sanitized[key] = '[REDACTED]';
84
- }
85
- else {
86
- sanitized[key] = value;
148
+ // Only include X-Codemie headers
149
+ if (key.toLowerCase().startsWith('x-codemie')) {
150
+ filtered[key] = value;
87
151
  }
88
152
  }
89
- return sanitized;
153
+ return filtered;
90
154
  }
91
155
  }
92
156
  //# sourceMappingURL=logging.plugin.js.map
@@ -1 +1 @@
1
- {"version":3,"file":"logging.plugin.js","sourceRoot":"","sources":["../../../src/proxy/plugins/logging.plugin.ts"],"names":[],"mappings":"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"}
1
+ {"version":3,"file":"logging.plugin.js","sourceRoot":"","sources":["../../../src/proxy/plugins/logging.plugin.ts"],"names":[],"mappings":"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"}
@@ -0,0 +1,33 @@
1
+ /**
2
+ * Metrics Sync Plugin
3
+ * Priority: 100 (runs after logging plugin)
4
+ *
5
+ * Purpose: Syncs metrics to CodeMie API in background
6
+ * - Runs only in SSO mode (ai-run-sso provider)
7
+ * - Background timer (every 5 minutes)
8
+ * - Aggregates pending deltas into single metric
9
+ * - Marks deltas as synced in JSONL
10
+ * - Final sync on proxy shutdown
11
+ *
12
+ * SOLID: Single responsibility = sync metrics
13
+ * KISS: Simple timer-based sync
14
+ */
15
+ import { ProxyPlugin, PluginContext, ProxyInterceptor } from './types.js';
16
+ export declare class MetricsSyncPlugin implements ProxyPlugin {
17
+ id: string;
18
+ name: string;
19
+ version: string;
20
+ priority: number;
21
+ createInterceptor(context: PluginContext): Promise<ProxyInterceptor>;
22
+ /**
23
+ * Check if metrics sync is enabled
24
+ * Priority: ENV > Profile config > Default (true)
25
+ */
26
+ private isSyncEnabled;
27
+ /**
28
+ * Check if dry-run mode is enabled
29
+ * Priority: ENV > Profile config > Default (false)
30
+ */
31
+ private isDryRunEnabled;
32
+ }
33
+ //# sourceMappingURL=metrics-sync.plugin.d.ts.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"metrics-sync.plugin.d.ts","sourceRoot":"","sources":["../../../src/proxy/plugins/metrics-sync.plugin.ts"],"names":[],"mappings":"AAAA;;;;;;;;;;;;;GAaG;AAEH,OAAO,EAAE,WAAW,EAAE,aAAa,EAAE,gBAAgB,EAAE,MAAM,YAAY,CAAC;AAQ1E,qBAAa,iBAAkB,YAAW,WAAW;IACnD,EAAE,SAAiC;IACnC,IAAI,SAAkB;IACtB,OAAO,SAAW;IAClB,QAAQ,SAAO;IAET,iBAAiB,CAAC,OAAO,EAAE,aAAa,GAAG,OAAO,CAAC,gBAAgB,CAAC;IAkC1E;;;OAGG;IACH,OAAO,CAAC,aAAa;IAgBrB;;;OAGG;IACH,OAAO,CAAC,eAAe;CAexB"}
@@ -0,0 +1,310 @@
1
+ /**
2
+ * Metrics Sync Plugin
3
+ * Priority: 100 (runs after logging plugin)
4
+ *
5
+ * Purpose: Syncs metrics to CodeMie API in background
6
+ * - Runs only in SSO mode (ai-run-sso provider)
7
+ * - Background timer (every 5 minutes)
8
+ * - Aggregates pending deltas into single metric
9
+ * - Marks deltas as synced in JSONL
10
+ * - Final sync on proxy shutdown
11
+ *
12
+ * SOLID: Single responsibility = sync metrics
13
+ * KISS: Simple timer-based sync
14
+ */
15
+ import { logger } from '../../utils/logger.js';
16
+ import { MetricsApiClient } from '../../metrics/sync/MetricsApiClient.js';
17
+ import { readJSONL, writeJSONLAtomic } from '../../metrics/sync/jsonl-writer.js';
18
+ import { aggregateDeltas } from '../../metrics/sync/aggregator.js';
19
+ import { SessionStore } from '../../metrics/session/SessionStore.js';
20
+ import { getSessionMetricsPath } from '../../metrics/config.js';
21
+ export class MetricsSyncPlugin {
22
+ id = '@codemie/proxy-metrics-sync';
23
+ name = 'Metrics Sync';
24
+ version = '1.0.0';
25
+ priority = 100; // Run after logging (priority 50)
26
+ async createInterceptor(context) {
27
+ // Only create interceptor if we have necessary context
28
+ if (!context.config.sessionId) {
29
+ logger.debug('[MetricsSyncPlugin] Skipping: Session ID not available');
30
+ throw new Error('Session ID not available (metrics sync disabled)');
31
+ }
32
+ if (!context.credentials) {
33
+ logger.debug('[MetricsSyncPlugin] Skipping: SSO credentials not available');
34
+ throw new Error('SSO credentials not available (metrics sync disabled)');
35
+ }
36
+ // Check if metrics sync is enabled (from config or env var)
37
+ const syncEnabled = this.isSyncEnabled(context);
38
+ if (!syncEnabled) {
39
+ logger.debug('[MetricsSyncPlugin] Skipping: Metrics sync disabled by configuration');
40
+ throw new Error('Metrics sync disabled by configuration');
41
+ }
42
+ logger.info('[MetricsSyncPlugin] Initializing metrics sync');
43
+ // Check if dry-run mode is enabled
44
+ const dryRun = this.isDryRunEnabled(context);
45
+ return new MetricsSyncInterceptor(context.config.sessionId, context.config.targetApiUrl, context.credentials.cookies, context.config.clientType, context.config.version, dryRun);
46
+ }
47
+ /**
48
+ * Check if metrics sync is enabled
49
+ * Priority: ENV > Profile config > Default (true)
50
+ */
51
+ isSyncEnabled(context) {
52
+ // Check environment variable first
53
+ const envEnabled = process.env.CODEMIE_METRICS_SYNC_ENABLED;
54
+ if (envEnabled !== undefined) {
55
+ return envEnabled === 'true' || envEnabled === '1';
56
+ }
57
+ // Check profile config (if available)
58
+ if (context.profileConfig?.metrics?.sync?.enabled !== undefined) {
59
+ return context.profileConfig.metrics.sync.enabled;
60
+ }
61
+ // Default to enabled for SSO mode
62
+ return true;
63
+ }
64
+ /**
65
+ * Check if dry-run mode is enabled
66
+ * Priority: ENV > Profile config > Default (false)
67
+ */
68
+ isDryRunEnabled(context) {
69
+ // Check environment variable first
70
+ const envDryRun = process.env.CODEMIE_METRICS_DRY_RUN;
71
+ if (envDryRun !== undefined) {
72
+ return envDryRun === 'true' || envDryRun === '1';
73
+ }
74
+ // Check profile config (if available)
75
+ if (context.profileConfig?.metrics?.sync?.dryRun !== undefined) {
76
+ return context.profileConfig.metrics.sync.dryRun;
77
+ }
78
+ // Default to disabled
79
+ return false;
80
+ }
81
+ }
82
+ class MetricsSyncInterceptor {
83
+ sessionId;
84
+ name = 'metrics-sync';
85
+ syncTimer;
86
+ sessionStore = new SessionStore();
87
+ apiClient;
88
+ syncInterval;
89
+ isSyncing = false;
90
+ version;
91
+ dryRun;
92
+ constructor(sessionId, baseUrl, cookies, clientType, version, dryRun = false) {
93
+ this.sessionId = sessionId;
94
+ // Get version from proxy config (passed from AgentCLI)
95
+ this.version = version || '0.0.0';
96
+ // Set dry-run mode (passed from plugin)
97
+ this.dryRun = dryRun;
98
+ if (this.dryRun) {
99
+ logger.info('[metrics-sync] Dry-run mode enabled - metrics will be logged but not sent');
100
+ }
101
+ // Build cookie header
102
+ const cookieHeader = Object.entries(cookies)
103
+ .map(([key, value]) => `${key}=${value}`)
104
+ .join('; ');
105
+ this.apiClient = new MetricsApiClient({
106
+ baseUrl,
107
+ cookies: cookieHeader,
108
+ timeout: 30000,
109
+ retryAttempts: 3,
110
+ version: this.version,
111
+ clientType: clientType || 'codemie-cli'
112
+ });
113
+ // Get sync interval from env or default to 5 minutes
114
+ this.syncInterval = Number.parseInt(process.env.CODEMIE_METRICS_SYNC_INTERVAL || '300000', 10);
115
+ }
116
+ /**
117
+ * Called when proxy starts - initialize background timer
118
+ */
119
+ async onProxyStart() {
120
+ logger.info(`[${this.name}] Starting metrics sync (interval: ${this.syncInterval}ms)`);
121
+ // Start background timer
122
+ this.syncTimer = setInterval(() => {
123
+ this.syncMetrics().catch(error => {
124
+ logger.error(`[${this.name}] Sync failed:`, error);
125
+ });
126
+ }, this.syncInterval);
127
+ logger.debug(`[${this.name}] Background timer started`);
128
+ }
129
+ /**
130
+ * Called when proxy stops - cleanup and final sync
131
+ */
132
+ async onProxyStop() {
133
+ logger.info(`[${this.name}] Stopping metrics sync`);
134
+ // Stop timer
135
+ if (this.syncTimer) {
136
+ clearInterval(this.syncTimer);
137
+ this.syncTimer = undefined;
138
+ }
139
+ // Final sync (ensure all pending metrics are sent)
140
+ try {
141
+ await this.syncMetrics();
142
+ logger.info(`[${this.name}] Final sync completed`);
143
+ }
144
+ catch (error) {
145
+ logger.error(`[${this.name}] Final sync failed:`, error);
146
+ }
147
+ }
148
+ /**
149
+ * Sync metrics to API
150
+ */
151
+ async syncMetrics() {
152
+ // Skip if already syncing (prevent concurrent syncs)
153
+ if (this.isSyncing) {
154
+ logger.debug(`[${this.name}] Sync already in progress, skipping`);
155
+ return;
156
+ }
157
+ this.isSyncing = true;
158
+ try {
159
+ const metricsFile = getSessionMetricsPath(this.sessionId);
160
+ // 1. Read all deltas from JSONL
161
+ const allDeltas = await readJSONL(metricsFile);
162
+ // 2. Filter for pending deltas only
163
+ const pendingDeltas = allDeltas.filter(d => d.syncStatus === 'pending');
164
+ if (pendingDeltas.length === 0) {
165
+ logger.debug(`[${this.name}] No pending deltas to sync`);
166
+ return;
167
+ }
168
+ logger.info(`[${this.name}] Syncing ${pendingDeltas.length} pending deltas`);
169
+ // Debug: Log collected deltas
170
+ logger.debug(`[${this.name}] Collected pending deltas:`, {
171
+ count: pendingDeltas.length,
172
+ deltas: pendingDeltas.map(d => {
173
+ // Calculate tool stats from tools and toolStatus
174
+ const totalTools = Object.values(d.tools || {}).reduce((sum, count) => sum + count, 0);
175
+ let successCount = 0;
176
+ let failureCount = 0;
177
+ if (d.toolStatus) {
178
+ for (const status of Object.values(d.toolStatus)) {
179
+ successCount += status.success || 0;
180
+ failureCount += status.failure || 0;
181
+ }
182
+ }
183
+ // Calculate file operation totals
184
+ const fileOps = d.fileOperations || [];
185
+ const linesAdded = fileOps.reduce((sum, op) => sum + (op.linesAdded || 0), 0);
186
+ const linesRemoved = fileOps.reduce((sum, op) => sum + (op.linesRemoved || 0), 0);
187
+ const writeOps = fileOps.filter(op => op.type === 'write').length;
188
+ const editOps = fileOps.filter(op => op.type === 'edit').length;
189
+ const deleteOps = fileOps.filter(op => op.type === 'delete').length;
190
+ return {
191
+ recordId: d.recordId,
192
+ timestamp: typeof d.timestamp === 'number'
193
+ ? new Date(d.timestamp).toISOString()
194
+ : d.timestamp,
195
+ tokens: d.tokens,
196
+ tools: {
197
+ total: totalTools,
198
+ success: successCount,
199
+ failure: failureCount,
200
+ breakdown: d.tools
201
+ },
202
+ fileOperations: {
203
+ created: writeOps,
204
+ modified: editOps,
205
+ deleted: deleteOps,
206
+ linesAdded,
207
+ linesRemoved
208
+ }
209
+ };
210
+ })
211
+ });
212
+ // 3. Load session metadata
213
+ const session = await this.sessionStore.loadSession(this.sessionId);
214
+ if (!session) {
215
+ logger.error(`[${this.name}] Session not found: ${this.sessionId}`);
216
+ return;
217
+ }
218
+ // 4. Aggregate pending deltas into single metric
219
+ const metric = aggregateDeltas(pendingDeltas, session, this.version);
220
+ // Debug: Log aggregated metric
221
+ logger.debug(`[${this.name}] Aggregated metric:`, {
222
+ name: metric.name,
223
+ attributes: {
224
+ // Identity
225
+ agent: metric.attributes.agent,
226
+ agent_version: metric.attributes.agent_version,
227
+ llm_model: metric.attributes.llm_model,
228
+ project: metric.attributes.project,
229
+ session_id: metric.attributes.session_id,
230
+ // Interaction totals
231
+ total_user_prompts: metric.attributes.total_user_prompts,
232
+ // Token totals
233
+ total_input_tokens: metric.attributes.total_input_tokens,
234
+ total_output_tokens: metric.attributes.total_output_tokens,
235
+ total_cache_read_input_tokens: metric.attributes.total_cache_read_input_tokens,
236
+ total_cache_creation_tokens: metric.attributes.total_cache_creation_tokens,
237
+ // Tool totals
238
+ total_tool_calls: metric.attributes.total_tool_calls,
239
+ successful_tool_calls: metric.attributes.successful_tool_calls,
240
+ failed_tool_calls: metric.attributes.failed_tool_calls,
241
+ // File operation totals
242
+ files_created: metric.attributes.files_created,
243
+ files_modified: metric.attributes.files_modified,
244
+ files_deleted: metric.attributes.files_deleted,
245
+ total_lines_added: metric.attributes.total_lines_added,
246
+ total_lines_removed: metric.attributes.total_lines_removed,
247
+ // Session info
248
+ session_duration_ms: metric.attributes.session_duration_ms,
249
+ count: metric.attributes.count
250
+ }
251
+ });
252
+ // 5. Send to API (single aggregated metric) or log in dry-run mode
253
+ if (this.dryRun) {
254
+ // Dry-run mode: Log what would be sent without actually sending
255
+ logger.info(`[${this.name}] [DRY-RUN] Would send metric to API:`, {
256
+ endpoint: `${this.apiClient['config'].baseUrl}/v1/metrics`,
257
+ method: 'POST',
258
+ headers: {
259
+ 'Content-Type': 'application/json',
260
+ 'User-Agent': `CodeMie-CLI/${this.version}`,
261
+ 'X-CodeMie-Client': this.apiClient['config'].clientType,
262
+ 'Cookie': '[REDACTED]'
263
+ },
264
+ payload: {
265
+ name: metric.name,
266
+ attributes: metric.attributes
267
+ }
268
+ });
269
+ logger.info(`[${this.name}] [DRY-RUN] Skipping actual API call - ${pendingDeltas.length} deltas would be synced`);
270
+ }
271
+ else {
272
+ // Normal mode: Actually send to API
273
+ const response = await this.apiClient.sendMetric(metric);
274
+ if (!response.success) {
275
+ logger.error(`[${this.name}] Sync failed: ${response.message}`);
276
+ return;
277
+ }
278
+ }
279
+ // 6. Mark deltas as synced in JSONL (atomic rewrite)
280
+ const syncedAt = Date.now();
281
+ const pendingRecordIds = new Set(pendingDeltas.map(d => d.recordId));
282
+ const updatedDeltas = allDeltas.map(d => pendingRecordIds.has(d.recordId)
283
+ ? {
284
+ ...d,
285
+ syncStatus: 'synced',
286
+ syncAttempts: d.syncAttempts + 1,
287
+ syncedAt
288
+ }
289
+ : d);
290
+ await writeJSONLAtomic(metricsFile, updatedDeltas);
291
+ logger.info(`[${this.name}] Successfully synced ${pendingDeltas.length} deltas`);
292
+ // Debug: Log which deltas were marked as synced
293
+ logger.debug(`[${this.name}] Marked deltas as synced:`, {
294
+ syncedAt: new Date(syncedAt).toISOString(),
295
+ recordIds: Array.from(pendingRecordIds),
296
+ totalDeltasInFile: updatedDeltas.length,
297
+ syncedCount: updatedDeltas.filter(d => d.syncStatus === 'synced').length,
298
+ pendingCount: updatedDeltas.filter(d => d.syncStatus === 'pending').length
299
+ });
300
+ }
301
+ catch (error) {
302
+ logger.error(`[${this.name}] Sync failed:`, error);
303
+ throw error;
304
+ }
305
+ finally {
306
+ this.isSyncing = false;
307
+ }
308
+ }
309
+ }
310
+ //# sourceMappingURL=metrics-sync.plugin.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"metrics-sync.plugin.js","sourceRoot":"","sources":["../../../src/proxy/plugins/metrics-sync.plugin.ts"],"names":[],"mappings":"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"}
@@ -1 +1 @@
1
- {"version":3,"file":"registry.d.ts","sourceRoot":"","sources":["../../../src/proxy/plugins/registry.ts"],"names":[],"mappings":"AAAA;;;;;GAKG;AAEH,OAAO,EAAE,WAAW,EAAE,YAAY,EAAE,aAAa,EAAE,gBAAgB,EAAE,MAAM,YAAY,CAAC;AAGxF;;GAEG;AACH,qBAAa,cAAc;IACzB,OAAO,CAAC,OAAO,CAAkC;IACjD,OAAO,CAAC,OAAO,CAAmC;IAClD,OAAO,CAAC,YAAY,CAAuC;IAE3D;;OAEG;IACH,QAAQ,CAAC,MAAM,EAAE,WAAW,EAAE,MAAM,CAAC,EAAE,OAAO,CAAC,YAAY,CAAC,GAAG,IAAI;IAanE;;OAEG;IACG,UAAU,CAAC,OAAO,EAAE,aAAa,GAAG,OAAO,CAAC,gBAAgB,EAAE,CAAC;IAoBrE;;OAEG;IACH,OAAO,CAAC,uBAAuB;IAiB/B;;OAEG;IACG,UAAU,CAAC,QAAQ,EAAE,MAAM,EAAE,OAAO,EAAE,OAAO,GAAG,OAAO,CAAC,IAAI,CAAC;IAkBnE;;OAEG;IACH,MAAM,IAAI,WAAW,EAAE;IAIvB;;OAEG;IACH,SAAS,CAAC,QAAQ,EAAE,MAAM,GAAG,YAAY,GAAG,SAAS;IAIrD;;OAEG;IACH,YAAY,CAAC,QAAQ,EAAE,MAAM,EAAE,OAAO,EAAE,OAAO,CAAC,YAAY,CAAC,GAAG,IAAI;IAOpE;;OAEG;IACH,KAAK,IAAI,IAAI;CAKd;AAKD,wBAAgB,iBAAiB,IAAI,cAAc,CAKlD;AAED,wBAAgB,mBAAmB,IAAI,IAAI,CAE1C"}
1
+ {"version":3,"file":"registry.d.ts","sourceRoot":"","sources":["../../../src/proxy/plugins/registry.ts"],"names":[],"mappings":"AAAA;;;;;GAKG;AAEH,OAAO,EAAE,WAAW,EAAE,YAAY,EAAE,aAAa,EAAE,gBAAgB,EAAE,MAAM,YAAY,CAAC;AAGxF;;GAEG;AACH,qBAAa,cAAc;IACzB,OAAO,CAAC,OAAO,CAAkC;IACjD,OAAO,CAAC,OAAO,CAAmC;IAClD,OAAO,CAAC,YAAY,CAAuC;IAE3D;;OAEG;IACH,QAAQ,CAAC,MAAM,EAAE,WAAW,EAAE,MAAM,CAAC,EAAE,OAAO,CAAC,YAAY,CAAC,GAAG,IAAI;IAanE;;OAEG;IACG,UAAU,CAAC,OAAO,EAAE,aAAa,GAAG,OAAO,CAAC,gBAAgB,EAAE,CAAC;IA0BrE;;OAEG;IACH,OAAO,CAAC,uBAAuB;IAiB/B;;OAEG;IACG,UAAU,CAAC,QAAQ,EAAE,MAAM,EAAE,OAAO,EAAE,OAAO,GAAG,OAAO,CAAC,IAAI,CAAC;IAkBnE;;OAEG;IACH,MAAM,IAAI,WAAW,EAAE;IAIvB;;OAEG;IACH,SAAS,CAAC,QAAQ,EAAE,MAAM,GAAG,YAAY,GAAG,SAAS;IAIrD;;OAEG;IACH,YAAY,CAAC,QAAQ,EAAE,MAAM,EAAE,OAAO,EAAE,OAAO,CAAC,YAAY,CAAC,GAAG,IAAI;IAOpE;;OAEG;IACH,KAAK,IAAI,IAAI;CAKd;AAKD,wBAAgB,iBAAiB,IAAI,cAAc,CAKlD;AAED,wBAAgB,mBAAmB,IAAI,IAAI,CAE1C"}
@@ -39,7 +39,14 @@ export class PluginRegistry {
39
39
  logger.debug(`[PluginRegistry] Initialized plugin: ${plugin.id} (priority: ${plugin.priority})`);
40
40
  }
41
41
  catch (error) {
42
- logger.error(`[PluginRegistry] Failed to initialize plugin ${plugin.id}:`, error);
42
+ // Log as info/debug for graceful skips, error for unexpected failures
43
+ const errorMessage = error instanceof Error ? error.message : String(error);
44
+ if (errorMessage.includes('disabled') || errorMessage.includes('not available')) {
45
+ logger.info(`[PluginRegistry] Skipped plugin ${plugin.id}: ${errorMessage}`);
46
+ }
47
+ else {
48
+ logger.error(`[PluginRegistry] Failed to initialize plugin ${plugin.id}:`, error);
49
+ }
43
50
  // Continue with other plugins (fail gracefully)
44
51
  }
45
52
  }
@@ -1 +1 @@
1
- {"version":3,"file":"registry.js","sourceRoot":"","sources":["../../../src/proxy/plugins/registry.ts"],"names":[],"mappings":"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"}
1
+ {"version":3,"file":"registry.js","sourceRoot":"","sources":["../../../src/proxy/plugins/registry.ts"],"names":[],"mappings":"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"}
@@ -7,8 +7,8 @@
7
7
  import { IncomingHttpHeaders } from 'http';
8
8
  import { ProxyConfig, ProxyContext } from '../types.js';
9
9
  import { logger } from '../../utils/logger.js';
10
- import { Analytics } from '../../analytics/index.js';
11
10
  import { SSOCredentials } from '../../providers/core/types.js';
11
+ import type { CodeMieConfigOptions } from '../../env/types.js';
12
12
  /**
13
13
  * Plugin metadata and lifecycle
14
14
  */
@@ -38,7 +38,7 @@ export interface PluginContext {
38
38
  config: ProxyConfig;
39
39
  logger: typeof logger;
40
40
  credentials?: SSOCredentials;
41
- analytics?: Analytics;
41
+ profileConfig?: CodeMieConfigOptions;
42
42
  [key: string]: unknown;
43
43
  }
44
44
  /**
@@ -55,6 +55,10 @@ export interface PluginConfig {
55
55
  */
56
56
  export interface ProxyInterceptor {
57
57
  name: string;
58
+ /** Called when proxy starts (for initialization) */
59
+ onProxyStart?(): Promise<void>;
60
+ /** Called when proxy stops (for cleanup) */
61
+ onProxyStop?(): Promise<void>;
58
62
  /** Called before forwarding request */
59
63
  onRequest?(context: ProxyContext): Promise<void>;
60
64
  /** Called after response headers received (BEFORE body streaming) */
@@ -1 +1 @@
1
- {"version":3,"file":"types.d.ts","sourceRoot":"","sources":["../../../src/proxy/plugins/types.ts"],"names":[],"mappings":"AAAA;;;;;GAKG;AAEH,OAAO,EAAE,mBAAmB,EAAE,MAAM,MAAM,CAAC;AAC3C,OAAO,EAAE,WAAW,EAAE,YAAY,EAAE,MAAM,aAAa,CAAC;AACxD,OAAO,EAAE,MAAM,EAAE,MAAM,uBAAuB,CAAC;AAC/C,OAAO,EAAE,SAAS,EAAE,MAAM,0BAA0B,CAAC;AACrD,OAAO,EAAE,cAAc,EAAE,MAAM,+BAA+B,CAAC;AAE/D;;GAEG;AACH,MAAM,WAAW,WAAW;IAC1B,kEAAkE;IAClE,EAAE,EAAE,MAAM,CAAC;IAEX,mBAAmB;IACnB,IAAI,EAAE,MAAM,CAAC;IAEb,qBAAqB;IACrB,OAAO,EAAE,MAAM,CAAC;IAEhB,mDAAmD;IACnD,QAAQ,EAAE,MAAM,CAAC;IAEjB,6CAA6C;IAC7C,YAAY,CAAC,EAAE,MAAM,EAAE,CAAC;IAExB,kCAAkC;IAClC,iBAAiB,CAAC,OAAO,EAAE,aAAa,GAAG,gBAAgB,GAAG,OAAO,CAAC,gBAAgB,CAAC,CAAC;IAExF,sBAAsB;IACtB,SAAS,CAAC,IAAI,OAAO,CAAC,IAAI,CAAC,CAAC;IAC5B,WAAW,CAAC,IAAI,OAAO,CAAC,IAAI,CAAC,CAAC;IAC9B,QAAQ,CAAC,IAAI,OAAO,CAAC,IAAI,CAAC,CAAC;IAC3B,SAAS,CAAC,IAAI,OAAO,CAAC,IAAI,CAAC,CAAC;CAC7B;AAED;;GAEG;AACH,MAAM,WAAW,aAAa;IAC5B,MAAM,EAAE,WAAW,CAAC;IACpB,MAAM,EAAE,OAAO,MAAM,CAAC;IACtB,WAAW,CAAC,EAAE,cAAc,CAAC;IAC7B,SAAS,CAAC,EAAE,SAAS,CAAC;IACtB,CAAC,GAAG,EAAE,MAAM,GAAG,OAAO,CAAC;CACxB;AAED;;GAEG;AACH,MAAM,WAAW,YAAY;IAC3B,EAAE,EAAE,MAAM,CAAC;IACX,OAAO,EAAE,OAAO,CAAC;IACjB,QAAQ,CAAC,EAAE,MAAM,CAAC;IAClB,OAAO,CAAC,EAAE,MAAM,CAAC,MAAM,EAAE,OAAO,CAAC,CAAC;CACnC;AAED;;GAEG;AACH,MAAM,WAAW,gBAAgB;IAC/B,IAAI,EAAE,MAAM,CAAC;IAEb,uCAAuC;IACvC,SAAS,CAAC,CAAC,OAAO,EAAE,YAAY,GAAG,OAAO,CAAC,IAAI,CAAC,CAAC;IAEjD,qEAAqE;IACrE,iBAAiB,CAAC,CAAC,OAAO,EAAE,YAAY,EAAE,OAAO,EAAE,mBAAmB,GAAG,OAAO,CAAC,IAAI,CAAC,CAAC;IAEvF,mEAAmE;IACnE,eAAe,CAAC,CAAC,OAAO,EAAE,YAAY,EAAE,KAAK,EAAE,MAAM,GAAG,OAAO,CAAC,MAAM,GAAG,IAAI,CAAC,CAAC;IAE/E,2CAA2C;IAC3C,kBAAkB,CAAC,CAAC,OAAO,EAAE,YAAY,EAAE,QAAQ,EAAE,gBAAgB,GAAG,OAAO,CAAC,IAAI,CAAC,CAAC;IAEtF,0BAA0B;IAC1B,OAAO,CAAC,CAAC,OAAO,EAAE,YAAY,EAAE,KAAK,EAAE,KAAK,GAAG,OAAO,CAAC,IAAI,CAAC,CAAC;CAC9D;AAED;;GAEG;AACH,MAAM,WAAW,gBAAgB;IAC/B,UAAU,EAAE,MAAM,CAAC;IACnB,aAAa,EAAE,MAAM,CAAC;IACtB,OAAO,EAAE,mBAAmB,CAAC;IAC7B,SAAS,EAAE,MAAM,CAAC;IAClB,UAAU,EAAE,MAAM,CAAC;CACpB"}
1
+ {"version":3,"file":"types.d.ts","sourceRoot":"","sources":["../../../src/proxy/plugins/types.ts"],"names":[],"mappings":"AAAA;;;;;GAKG;AAEH,OAAO,EAAE,mBAAmB,EAAE,MAAM,MAAM,CAAC;AAC3C,OAAO,EAAE,WAAW,EAAE,YAAY,EAAE,MAAM,aAAa,CAAC;AACxD,OAAO,EAAE,MAAM,EAAE,MAAM,uBAAuB,CAAC;AAC/C,OAAO,EAAE,cAAc,EAAE,MAAM,+BAA+B,CAAC;AAC/D,OAAO,KAAK,EAAE,oBAAoB,EAAE,MAAM,oBAAoB,CAAC;AAE/D;;GAEG;AACH,MAAM,WAAW,WAAW;IAC1B,kEAAkE;IAClE,EAAE,EAAE,MAAM,CAAC;IAEX,mBAAmB;IACnB,IAAI,EAAE,MAAM,CAAC;IAEb,qBAAqB;IACrB,OAAO,EAAE,MAAM,CAAC;IAEhB,mDAAmD;IACnD,QAAQ,EAAE,MAAM,CAAC;IAEjB,6CAA6C;IAC7C,YAAY,CAAC,EAAE,MAAM,EAAE,CAAC;IAExB,kCAAkC;IAClC,iBAAiB,CAAC,OAAO,EAAE,aAAa,GAAG,gBAAgB,GAAG,OAAO,CAAC,gBAAgB,CAAC,CAAC;IAExF,sBAAsB;IACtB,SAAS,CAAC,IAAI,OAAO,CAAC,IAAI,CAAC,CAAC;IAC5B,WAAW,CAAC,IAAI,OAAO,CAAC,IAAI,CAAC,CAAC;IAC9B,QAAQ,CAAC,IAAI,OAAO,CAAC,IAAI,CAAC,CAAC;IAC3B,SAAS,CAAC,IAAI,OAAO,CAAC,IAAI,CAAC,CAAC;CAC7B;AAED;;GAEG;AACH,MAAM,WAAW,aAAa;IAC5B,MAAM,EAAE,WAAW,CAAC;IACpB,MAAM,EAAE,OAAO,MAAM,CAAC;IACtB,WAAW,CAAC,EAAE,cAAc,CAAC;IAC7B,aAAa,CAAC,EAAE,oBAAoB,CAAC;IACrC,CAAC,GAAG,EAAE,MAAM,GAAG,OAAO,CAAC;CACxB;AAED;;GAEG;AACH,MAAM,WAAW,YAAY;IAC3B,EAAE,EAAE,MAAM,CAAC;IACX,OAAO,EAAE,OAAO,CAAC;IACjB,QAAQ,CAAC,EAAE,MAAM,CAAC;IAClB,OAAO,CAAC,EAAE,MAAM,CAAC,MAAM,EAAE,OAAO,CAAC,CAAC;CACnC;AAED;;GAEG;AACH,MAAM,WAAW,gBAAgB;IAC/B,IAAI,EAAE,MAAM,CAAC;IAEb,oDAAoD;IACpD,YAAY,CAAC,IAAI,OAAO,CAAC,IAAI,CAAC,CAAC;IAE/B,4CAA4C;IAC5C,WAAW,CAAC,IAAI,OAAO,CAAC,IAAI,CAAC,CAAC;IAE9B,uCAAuC;IACvC,SAAS,CAAC,CAAC,OAAO,EAAE,YAAY,GAAG,OAAO,CAAC,IAAI,CAAC,CAAC;IAEjD,qEAAqE;IACrE,iBAAiB,CAAC,CAAC,OAAO,EAAE,YAAY,EAAE,OAAO,EAAE,mBAAmB,GAAG,OAAO,CAAC,IAAI,CAAC,CAAC;IAEvF,mEAAmE;IACnE,eAAe,CAAC,CAAC,OAAO,EAAE,YAAY,EAAE,KAAK,EAAE,MAAM,GAAG,OAAO,CAAC,MAAM,GAAG,IAAI,CAAC,CAAC;IAE/E,2CAA2C;IAC3C,kBAAkB,CAAC,CAAC,OAAO,EAAE,YAAY,EAAE,QAAQ,EAAE,gBAAgB,GAAG,OAAO,CAAC,IAAI,CAAC,CAAC;IAEtF,0BAA0B;IAC1B,OAAO,CAAC,CAAC,OAAO,EAAE,YAAY,EAAE,KAAK,EAAE,KAAK,GAAG,OAAO,CAAC,IAAI,CAAC,CAAC;CAC9D;AAED;;GAEG;AACH,MAAM,WAAW,gBAAgB;IAC/B,UAAU,EAAE,MAAM,CAAC;IACnB,aAAa,EAAE,MAAM,CAAC;IACtB,OAAO,EAAE,mBAAmB,CAAC;IAC7B,SAAS,EAAE,MAAM,CAAC;IAClB,UAAU,EAAE,MAAM,CAAC;CACpB"}