@kaitranntt/ccs 7.66.1 → 7.67.0-dev.10

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 (365) hide show
  1. package/README.md +3 -1
  2. package/dist/api/services/index.d.ts +1 -0
  3. package/dist/api/services/index.d.ts.map +1 -1
  4. package/dist/api/services/index.js +3 -1
  5. package/dist/api/services/index.js.map +1 -1
  6. package/dist/api/services/local-runtime-readiness.d.ts +14 -0
  7. package/dist/api/services/local-runtime-readiness.d.ts.map +1 -0
  8. package/dist/api/services/local-runtime-readiness.js +89 -0
  9. package/dist/api/services/local-runtime-readiness.js.map +1 -0
  10. package/dist/ccs.js +68 -35
  11. package/dist/ccs.js.map +1 -1
  12. package/dist/cliproxy/accounts/types.d.ts +1 -1
  13. package/dist/cliproxy/accounts/types.d.ts.map +1 -1
  14. package/dist/cliproxy/auth/auth-types.d.ts +29 -6
  15. package/dist/cliproxy/auth/auth-types.d.ts.map +1 -1
  16. package/dist/cliproxy/auth/auth-types.js +58 -10
  17. package/dist/cliproxy/auth/auth-types.js.map +1 -1
  18. package/dist/cliproxy/auth/oauth-handler.d.ts +6 -1
  19. package/dist/cliproxy/auth/oauth-handler.d.ts.map +1 -1
  20. package/dist/cliproxy/auth/oauth-handler.js +165 -45
  21. package/dist/cliproxy/auth/oauth-handler.js.map +1 -1
  22. package/dist/cliproxy/auth/oauth-process.d.ts +26 -1
  23. package/dist/cliproxy/auth/oauth-process.d.ts.map +1 -1
  24. package/dist/cliproxy/auth/oauth-process.js +314 -49
  25. package/dist/cliproxy/auth/oauth-process.js.map +1 -1
  26. package/dist/cliproxy/auth/token-manager.d.ts +9 -0
  27. package/dist/cliproxy/auth/token-manager.d.ts.map +1 -1
  28. package/dist/cliproxy/auth/token-manager.js +104 -58
  29. package/dist/cliproxy/auth/token-manager.js.map +1 -1
  30. package/dist/cliproxy/auth-utils.d.ts +2 -1
  31. package/dist/cliproxy/auth-utils.d.ts.map +1 -1
  32. package/dist/cliproxy/auth-utils.js +32 -7
  33. package/dist/cliproxy/auth-utils.js.map +1 -1
  34. package/dist/cliproxy/catalog-cache.d.ts +9 -1
  35. package/dist/cliproxy/catalog-cache.d.ts.map +1 -1
  36. package/dist/cliproxy/catalog-cache.js +115 -29
  37. package/dist/cliproxy/catalog-cache.js.map +1 -1
  38. package/dist/cliproxy/catalog-routing.d.ts +12 -0
  39. package/dist/cliproxy/catalog-routing.d.ts.map +1 -0
  40. package/dist/cliproxy/catalog-routing.js +19 -0
  41. package/dist/cliproxy/catalog-routing.js.map +1 -0
  42. package/dist/cliproxy/codex-plan-compatibility.d.ts +0 -1
  43. package/dist/cliproxy/codex-plan-compatibility.d.ts.map +1 -1
  44. package/dist/cliproxy/codex-plan-compatibility.js +3 -7
  45. package/dist/cliproxy/codex-plan-compatibility.js.map +1 -1
  46. package/dist/cliproxy/config/generator.d.ts +2 -1
  47. package/dist/cliproxy/config/generator.d.ts.map +1 -1
  48. package/dist/cliproxy/config/generator.js +11 -1
  49. package/dist/cliproxy/config/generator.js.map +1 -1
  50. package/dist/cliproxy/executor/index.d.ts +5 -0
  51. package/dist/cliproxy/executor/index.d.ts.map +1 -1
  52. package/dist/cliproxy/executor/index.js +119 -16
  53. package/dist/cliproxy/executor/index.js.map +1 -1
  54. package/dist/cliproxy/gemini-cli-quota-normalizer.js +1 -1
  55. package/dist/cliproxy/gemini-cli-quota-normalizer.js.map +1 -1
  56. package/dist/cliproxy/index.d.ts +1 -1
  57. package/dist/cliproxy/index.d.ts.map +1 -1
  58. package/dist/cliproxy/index.js.map +1 -1
  59. package/dist/cliproxy/managed-model-prefixes.d.ts +7 -0
  60. package/dist/cliproxy/managed-model-prefixes.d.ts.map +1 -0
  61. package/dist/cliproxy/managed-model-prefixes.js +116 -0
  62. package/dist/cliproxy/managed-model-prefixes.js.map +1 -0
  63. package/dist/cliproxy/management-api-client.d.ts +9 -0
  64. package/dist/cliproxy/management-api-client.d.ts.map +1 -1
  65. package/dist/cliproxy/management-api-client.js +14 -0
  66. package/dist/cliproxy/management-api-client.js.map +1 -1
  67. package/dist/cliproxy/model-catalog.d.ts.map +1 -1
  68. package/dist/cliproxy/model-catalog.js +19 -4
  69. package/dist/cliproxy/model-catalog.js.map +1 -1
  70. package/dist/cliproxy/provider-entitlement-evidence.d.ts +17 -0
  71. package/dist/cliproxy/provider-entitlement-evidence.d.ts.map +1 -0
  72. package/dist/cliproxy/provider-entitlement-evidence.js +55 -0
  73. package/dist/cliproxy/provider-entitlement-evidence.js.map +1 -0
  74. package/dist/cliproxy/provider-entitlement-types.d.ts +16 -0
  75. package/dist/cliproxy/provider-entitlement-types.d.ts.map +1 -0
  76. package/dist/cliproxy/provider-entitlement-types.js +3 -0
  77. package/dist/cliproxy/provider-entitlement-types.js.map +1 -0
  78. package/dist/cliproxy/proxy-detector.d.ts.map +1 -1
  79. package/dist/cliproxy/proxy-detector.js +6 -2
  80. package/dist/cliproxy/proxy-detector.js.map +1 -1
  81. package/dist/cliproxy/quota-fetcher-gemini-cli.d.ts.map +1 -1
  82. package/dist/cliproxy/quota-fetcher-gemini-cli.js +64 -19
  83. package/dist/cliproxy/quota-fetcher-gemini-cli.js.map +1 -1
  84. package/dist/cliproxy/quota-fetcher.d.ts +10 -0
  85. package/dist/cliproxy/quota-fetcher.d.ts.map +1 -1
  86. package/dist/cliproxy/quota-fetcher.js +116 -21
  87. package/dist/cliproxy/quota-fetcher.js.map +1 -1
  88. package/dist/cliproxy/quota-types.d.ts +3 -0
  89. package/dist/cliproxy/quota-types.d.ts.map +1 -1
  90. package/dist/cliproxy/routing-strategy-http.d.ts +6 -0
  91. package/dist/cliproxy/routing-strategy-http.d.ts.map +1 -0
  92. package/dist/cliproxy/routing-strategy-http.js +115 -0
  93. package/dist/cliproxy/routing-strategy-http.js.map +1 -0
  94. package/dist/cliproxy/routing-strategy.d.ts +18 -0
  95. package/dist/cliproxy/routing-strategy.d.ts.map +1 -0
  96. package/dist/cliproxy/routing-strategy.js +123 -0
  97. package/dist/cliproxy/routing-strategy.js.map +1 -0
  98. package/dist/cliproxy/services/variant-settings.d.ts.map +1 -1
  99. package/dist/cliproxy/services/variant-settings.js +43 -30
  100. package/dist/cliproxy/services/variant-settings.js.map +1 -1
  101. package/dist/cliproxy/startup-lock.d.ts.map +1 -1
  102. package/dist/cliproxy/startup-lock.js +5 -1
  103. package/dist/cliproxy/startup-lock.js.map +1 -1
  104. package/dist/cliproxy/tool-sanitization-proxy.d.ts +1 -0
  105. package/dist/cliproxy/tool-sanitization-proxy.d.ts.map +1 -1
  106. package/dist/cliproxy/tool-sanitization-proxy.js +6 -0
  107. package/dist/cliproxy/tool-sanitization-proxy.js.map +1 -1
  108. package/dist/cliproxy/types.d.ts +7 -0
  109. package/dist/cliproxy/types.d.ts.map +1 -1
  110. package/dist/cliproxy/types.js.map +1 -1
  111. package/dist/commands/api-command/create-command.d.ts +3 -0
  112. package/dist/commands/api-command/create-command.d.ts.map +1 -1
  113. package/dist/commands/api-command/create-command.js +20 -6
  114. package/dist/commands/api-command/create-command.js.map +1 -1
  115. package/dist/commands/api-command/help.d.ts.map +1 -1
  116. package/dist/commands/api-command/help.js +1 -0
  117. package/dist/commands/api-command/help.js.map +1 -1
  118. package/dist/commands/cleanup-command.d.ts +1 -1
  119. package/dist/commands/cleanup-command.d.ts.map +1 -1
  120. package/dist/commands/cleanup-command.js +57 -34
  121. package/dist/commands/cleanup-command.js.map +1 -1
  122. package/dist/commands/cliproxy/catalog-subcommand.d.ts.map +1 -1
  123. package/dist/commands/cliproxy/catalog-subcommand.js +72 -44
  124. package/dist/commands/cliproxy/catalog-subcommand.js.map +1 -1
  125. package/dist/commands/cliproxy/help-subcommand.d.ts.map +1 -1
  126. package/dist/commands/cliproxy/help-subcommand.js +6 -2
  127. package/dist/commands/cliproxy/help-subcommand.js.map +1 -1
  128. package/dist/commands/cliproxy/index.d.ts.map +1 -1
  129. package/dist/commands/cliproxy/index.js +14 -0
  130. package/dist/commands/cliproxy/index.js.map +1 -1
  131. package/dist/commands/cliproxy/quota-subcommand.d.ts +2 -0
  132. package/dist/commands/cliproxy/quota-subcommand.d.ts.map +1 -1
  133. package/dist/commands/cliproxy/quota-subcommand.js +8 -1
  134. package/dist/commands/cliproxy/quota-subcommand.js.map +1 -1
  135. package/dist/commands/cliproxy/routing-subcommand.d.ts +4 -0
  136. package/dist/commands/cliproxy/routing-subcommand.d.ts.map +1 -0
  137. package/dist/commands/cliproxy/routing-subcommand.js +68 -0
  138. package/dist/commands/cliproxy/routing-subcommand.js.map +1 -0
  139. package/dist/commands/cliproxy/variant-subcommand.d.ts.map +1 -1
  140. package/dist/commands/cliproxy/variant-subcommand.js +44 -3
  141. package/dist/commands/cliproxy/variant-subcommand.js.map +1 -1
  142. package/dist/commands/command-catalog.d.ts +2 -2
  143. package/dist/commands/command-catalog.d.ts.map +1 -1
  144. package/dist/commands/command-catalog.js +3 -1
  145. package/dist/commands/command-catalog.js.map +1 -1
  146. package/dist/commands/completion-backend.d.ts.map +1 -1
  147. package/dist/commands/completion-backend.js +15 -1
  148. package/dist/commands/completion-backend.js.map +1 -1
  149. package/dist/commands/config-command.d.ts.map +1 -1
  150. package/dist/commands/config-command.js +23 -0
  151. package/dist/commands/config-command.js.map +1 -1
  152. package/dist/commands/docker/up-subcommand.js +1 -1
  153. package/dist/commands/docker/up-subcommand.js.map +1 -1
  154. package/dist/commands/help-command.d.ts.map +1 -1
  155. package/dist/commands/help-command.js +62 -1
  156. package/dist/commands/help-command.js.map +1 -1
  157. package/dist/commands/update-command.d.ts +20 -5
  158. package/dist/commands/update-command.d.ts.map +1 -1
  159. package/dist/commands/update-command.js +169 -119
  160. package/dist/commands/update-command.js.map +1 -1
  161. package/dist/config/unified-config-loader.d.ts +2 -1
  162. package/dist/config/unified-config-loader.d.ts.map +1 -1
  163. package/dist/config/unified-config-loader.js +37 -1
  164. package/dist/config/unified-config-loader.js.map +1 -1
  165. package/dist/config/unified-config-types.d.ts +29 -1
  166. package/dist/config/unified-config-types.d.ts.map +1 -1
  167. package/dist/config/unified-config-types.js +13 -1
  168. package/dist/config/unified-config-types.js.map +1 -1
  169. package/dist/copilot/copilot-executor.d.ts.map +1 -1
  170. package/dist/copilot/copilot-executor.js +5 -8
  171. package/dist/copilot/copilot-executor.js.map +1 -1
  172. package/dist/delegation/headless-executor.d.ts.map +1 -1
  173. package/dist/delegation/headless-executor.js +19 -16
  174. package/dist/delegation/headless-executor.js.map +1 -1
  175. package/dist/errors/error-handler.d.ts.map +1 -1
  176. package/dist/errors/error-handler.js +13 -0
  177. package/dist/errors/error-handler.js.map +1 -1
  178. package/dist/glmt/glmt-transformer.d.ts +1 -0
  179. package/dist/glmt/glmt-transformer.d.ts.map +1 -1
  180. package/dist/glmt/glmt-transformer.js +9 -0
  181. package/dist/glmt/glmt-transformer.js.map +1 -1
  182. package/dist/management/checks/image-analysis-check.d.ts.map +1 -1
  183. package/dist/management/checks/image-analysis-check.js +19 -1
  184. package/dist/management/checks/image-analysis-check.js.map +1 -1
  185. package/dist/management/recovery-manager.d.ts +6 -0
  186. package/dist/management/recovery-manager.d.ts.map +1 -1
  187. package/dist/management/recovery-manager.js +72 -2
  188. package/dist/management/recovery-manager.js.map +1 -1
  189. package/dist/services/logging/index.d.ts +7 -0
  190. package/dist/services/logging/index.d.ts.map +1 -0
  191. package/dist/services/logging/index.js +22 -0
  192. package/dist/services/logging/index.js.map +1 -0
  193. package/dist/services/logging/log-buffer.d.ts +5 -0
  194. package/dist/services/logging/log-buffer.d.ts.map +1 -0
  195. package/dist/services/logging/log-buffer.js +20 -0
  196. package/dist/services/logging/log-buffer.js.map +1 -0
  197. package/dist/services/logging/log-config.d.ts +4 -0
  198. package/dist/services/logging/log-config.d.ts.map +1 -0
  199. package/dist/services/logging/log-config.js +68 -0
  200. package/dist/services/logging/log-config.js.map +1 -0
  201. package/dist/services/logging/log-paths.d.ts +8 -0
  202. package/dist/services/logging/log-paths.d.ts.map +1 -0
  203. package/dist/services/logging/log-paths.js +66 -0
  204. package/dist/services/logging/log-paths.js.map +1 -0
  205. package/dist/services/logging/log-reader.d.ts +5 -0
  206. package/dist/services/logging/log-reader.d.ts.map +1 -0
  207. package/dist/services/logging/log-reader.js +124 -0
  208. package/dist/services/logging/log-reader.js.map +1 -0
  209. package/dist/services/logging/log-redaction.d.ts +2 -0
  210. package/dist/services/logging/log-redaction.d.ts.map +1 -0
  211. package/dist/services/logging/log-redaction.js +53 -0
  212. package/dist/services/logging/log-redaction.js.map +1 -0
  213. package/dist/services/logging/log-storage.d.ts +4 -0
  214. package/dist/services/logging/log-storage.d.ts.map +1 -0
  215. package/dist/services/logging/log-storage.js +109 -0
  216. package/dist/services/logging/log-storage.js.map +1 -0
  217. package/dist/services/logging/log-types.d.ts +30 -0
  218. package/dist/services/logging/log-types.d.ts.map +1 -0
  219. package/dist/services/logging/log-types.js +19 -0
  220. package/dist/services/logging/log-types.js.map +1 -0
  221. package/dist/services/logging/logger.d.ts +9 -0
  222. package/dist/services/logging/logger.d.ts.map +1 -0
  223. package/dist/services/logging/logger.js +46 -0
  224. package/dist/services/logging/logger.js.map +1 -0
  225. package/dist/shared/agy-gemini-pro-compatibility.d.ts +15 -0
  226. package/dist/shared/agy-gemini-pro-compatibility.d.ts.map +1 -0
  227. package/dist/shared/agy-gemini-pro-compatibility.js +18 -0
  228. package/dist/shared/agy-gemini-pro-compatibility.js.map +1 -0
  229. package/dist/shared/cliproxy-model-routing.d.ts +45 -0
  230. package/dist/shared/cliproxy-model-routing.d.ts.map +1 -0
  231. package/dist/shared/cliproxy-model-routing.js +144 -0
  232. package/dist/shared/cliproxy-model-routing.js.map +1 -0
  233. package/dist/shared/provider-preset-catalog.d.ts +3 -1
  234. package/dist/shared/provider-preset-catalog.d.ts.map +1 -1
  235. package/dist/shared/provider-preset-catalog.js +16 -0
  236. package/dist/shared/provider-preset-catalog.js.map +1 -1
  237. package/dist/ui/assets/{accounts-BjfPKR8m.js → accounts-DjL3iVZW.js} +1 -1
  238. package/dist/ui/assets/{alert-dialog-Dh2NUFdm.js → alert-dialog-Tc_D1a_B.js} +1 -1
  239. package/dist/ui/assets/api-CUtkvXmX.js +4 -0
  240. package/dist/ui/assets/{auth-section-Dp10_YyD.js → auth-section-CuKWQHC7.js} +1 -1
  241. package/dist/ui/assets/{backups-section-C0jF8MP1.js → backups-section-BKW2pbb9.js} +1 -1
  242. package/dist/ui/assets/{channels-CkXuK5i7.js → channels-DvWJMdaq.js} +1 -1
  243. package/dist/ui/assets/{checkbox-tA5FH8Ol.js → checkbox-B0hZxMK5.js} +1 -1
  244. package/dist/ui/assets/{claude-extension-Bg2ZkzMz.js → claude-extension-Dfqu-rev.js} +1 -1
  245. package/dist/ui/assets/cliproxy-C9RxW-I8.js +3 -0
  246. package/dist/ui/assets/cliproxy-ai-providers-BXLuuxNf.js +15 -0
  247. package/dist/ui/assets/{cliproxy-control-panel-Da-sGGyI.js → cliproxy-control-panel-aQ7cCc2U.js} +1 -1
  248. package/dist/ui/assets/{codex-ooWKOPa2.js → codex-aq4RI6_n.js} +9 -9
  249. package/dist/ui/assets/{confirm-dialog-CKjwhn9j.js → confirm-dialog-CpDk6eu4.js} +1 -1
  250. package/dist/ui/assets/{copilot-GA7EPiK1.js → copilot-CQRpGXvY.js} +2 -2
  251. package/dist/ui/assets/{cursor-B6c8CyHG.js → cursor-BpXPf6qi.js} +1 -1
  252. package/dist/ui/assets/{droid-CPRHOIX2.js → droid-Cgx-yLjy.js} +2 -2
  253. package/dist/ui/assets/{globalenv-section-Czgnw_GV.js → globalenv-section-DsNqG1yB.js} +1 -1
  254. package/dist/ui/assets/{health-CXLOMk8n.js → health-BY-O-JcA.js} +1 -1
  255. package/dist/ui/assets/icons-KVCk4_U8.js +1 -0
  256. package/dist/ui/assets/index-BmSzf0T9.js +72 -0
  257. package/dist/ui/assets/index-CLGiPB3A.js +1 -0
  258. package/dist/ui/assets/{index-CvfzKRSH.js → index-Cet36v1V.js} +1 -1
  259. package/dist/ui/assets/{index-Boa5e-GY.js → index-DH6L6ybH.js} +1 -1
  260. package/dist/ui/assets/{index-BceMcbCR.js → index-DsCjnpco.js} +1 -1
  261. package/dist/ui/assets/{index-D2v_-6AW.js → index-TQFuDZdB.js} +1 -1
  262. package/dist/ui/assets/index-teLjoh2T.css +1 -0
  263. package/dist/ui/assets/logs-D5ro-pc7.js +1 -0
  264. package/dist/ui/assets/{masked-input-B1_asiUI.js → masked-input-h0XkMSwB.js} +1 -1
  265. package/dist/ui/assets/proxy-status-widget-yBdrFeb7.js +1 -0
  266. package/dist/ui/assets/{raw-json-settings-editor-panel-DMbTkxWw.js → raw-json-settings-editor-panel-Cb7ZInQV.js} +1 -1
  267. package/dist/ui/assets/searchable-select-D4xr5xKS.js +1 -0
  268. package/dist/ui/assets/{separator-CdaalG0K.js → separator-gw5BjIpP.js} +1 -1
  269. package/dist/ui/assets/{shared-BiFB-et0.js → shared-C-VeA1Z9.js} +1 -1
  270. package/dist/ui/assets/{table-BPwgFXLQ.js → table-Bd4isC18.js} +1 -1
  271. package/dist/ui/assets/{tanstack-DWm6aJ-G.js → tanstack-CrmUhA7Z.js} +2 -2
  272. package/dist/ui/assets/updates-DiK8I67C.js +1 -0
  273. package/dist/ui/index.html +4 -4
  274. package/dist/utils/hooks/image-analysis-runtime-status.d.ts.map +1 -1
  275. package/dist/utils/hooks/image-analysis-runtime-status.js +5 -1
  276. package/dist/utils/hooks/image-analysis-runtime-status.js.map +1 -1
  277. package/dist/utils/hooks/image-analyzer-hook-utils.d.ts +21 -0
  278. package/dist/utils/hooks/image-analyzer-hook-utils.d.ts.map +1 -0
  279. package/dist/utils/hooks/image-analyzer-hook-utils.js +81 -0
  280. package/dist/utils/hooks/image-analyzer-hook-utils.js.map +1 -0
  281. package/dist/utils/hooks/image-analyzer-profile-hook-injector.d.ts +1 -0
  282. package/dist/utils/hooks/image-analyzer-profile-hook-injector.d.ts.map +1 -1
  283. package/dist/utils/hooks/image-analyzer-profile-hook-injector.js +33 -12
  284. package/dist/utils/hooks/image-analyzer-profile-hook-injector.js.map +1 -1
  285. package/dist/utils/hooks/index.d.ts +1 -0
  286. package/dist/utils/hooks/index.d.ts.map +1 -1
  287. package/dist/utils/hooks/index.js +3 -1
  288. package/dist/utils/hooks/index.js.map +1 -1
  289. package/dist/utils/image-analysis/index.d.ts +1 -0
  290. package/dist/utils/image-analysis/index.d.ts.map +1 -1
  291. package/dist/utils/image-analysis/index.js +6 -1
  292. package/dist/utils/image-analysis/index.js.map +1 -1
  293. package/dist/utils/image-analysis/repair.d.ts +12 -0
  294. package/dist/utils/image-analysis/repair.d.ts.map +1 -0
  295. package/dist/utils/image-analysis/repair.js +105 -0
  296. package/dist/utils/image-analysis/repair.js.map +1 -0
  297. package/dist/utils/package-manager-detector.d.ts +30 -4
  298. package/dist/utils/package-manager-detector.d.ts.map +1 -1
  299. package/dist/utils/package-manager-detector.js +247 -60
  300. package/dist/utils/package-manager-detector.js.map +1 -1
  301. package/dist/utils/update-checker.d.ts +1 -1
  302. package/dist/utils/update-checker.d.ts.map +1 -1
  303. package/dist/utils/websearch/trace.d.ts.map +1 -1
  304. package/dist/utils/websearch/trace.js +7 -0
  305. package/dist/utils/websearch/trace.js.map +1 -1
  306. package/dist/web-server/index.d.ts.map +1 -1
  307. package/dist/web-server/index.js +24 -0
  308. package/dist/web-server/index.js.map +1 -1
  309. package/dist/web-server/middleware/request-logging-middleware.d.ts +3 -0
  310. package/dist/web-server/middleware/request-logging-middleware.d.ts.map +1 -0
  311. package/dist/web-server/middleware/request-logging-middleware.js +30 -0
  312. package/dist/web-server/middleware/request-logging-middleware.js.map +1 -0
  313. package/dist/web-server/routes/auth-routes.d.ts +10 -0
  314. package/dist/web-server/routes/auth-routes.d.ts.map +1 -1
  315. package/dist/web-server/routes/auth-routes.js +33 -6
  316. package/dist/web-server/routes/auth-routes.js.map +1 -1
  317. package/dist/web-server/routes/catalog-routes.d.ts.map +1 -1
  318. package/dist/web-server/routes/catalog-routes.js +9 -8
  319. package/dist/web-server/routes/catalog-routes.js.map +1 -1
  320. package/dist/web-server/routes/cliproxy-auth-routes.d.ts +8 -0
  321. package/dist/web-server/routes/cliproxy-auth-routes.d.ts.map +1 -1
  322. package/dist/web-server/routes/cliproxy-auth-routes.js +86 -76
  323. package/dist/web-server/routes/cliproxy-auth-routes.js.map +1 -1
  324. package/dist/web-server/routes/cliproxy-routing-routes.d.ts +3 -0
  325. package/dist/web-server/routes/cliproxy-routing-routes.d.ts.map +1 -0
  326. package/dist/web-server/routes/cliproxy-routing-routes.js +34 -0
  327. package/dist/web-server/routes/cliproxy-routing-routes.js.map +1 -0
  328. package/dist/web-server/routes/image-analysis-routes.d.ts.map +1 -1
  329. package/dist/web-server/routes/image-analysis-routes.js +1 -10
  330. package/dist/web-server/routes/image-analysis-routes.js.map +1 -1
  331. package/dist/web-server/routes/index.d.ts.map +1 -1
  332. package/dist/web-server/routes/index.js +22 -0
  333. package/dist/web-server/routes/index.js.map +1 -1
  334. package/dist/web-server/routes/logs-routes.d.ts +3 -0
  335. package/dist/web-server/routes/logs-routes.d.ts.map +1 -0
  336. package/dist/web-server/routes/logs-routes.js +75 -0
  337. package/dist/web-server/routes/logs-routes.js.map +1 -0
  338. package/dist/web-server/routes/profile-routes.d.ts.map +1 -1
  339. package/dist/web-server/routes/profile-routes.js +8 -0
  340. package/dist/web-server/routes/profile-routes.js.map +1 -1
  341. package/dist/web-server/routes/settings-routes.d.ts.map +1 -1
  342. package/dist/web-server/routes/settings-routes.js +2 -0
  343. package/dist/web-server/routes/settings-routes.js.map +1 -1
  344. package/dist/web-server/services/logs-dashboard-service.d.ts +7 -0
  345. package/dist/web-server/services/logs-dashboard-service.d.ts.map +1 -0
  346. package/dist/web-server/services/logs-dashboard-service.js +33 -0
  347. package/dist/web-server/services/logs-dashboard-service.js.map +1 -0
  348. package/dist/web-server/usage/routes.d.ts.map +1 -1
  349. package/dist/web-server/usage/routes.js +11 -0
  350. package/dist/web-server/usage/routes.js.map +1 -1
  351. package/dist/web-server/websocket.d.ts.map +1 -1
  352. package/dist/web-server/websocket.js +23 -14
  353. package/dist/web-server/websocket.js.map +1 -1
  354. package/lib/hooks/image-analyzer-transformer.cjs +5 -0
  355. package/package.json +1 -1
  356. package/dist/ui/assets/api-C-3mQCFf.js +0 -4
  357. package/dist/ui/assets/cliproxy-1qRVSbVC.js +0 -3
  358. package/dist/ui/assets/cliproxy-ai-providers-DBSXTTyw.js +0 -21
  359. package/dist/ui/assets/icons-B9oTjo-t.js +0 -1
  360. package/dist/ui/assets/index-BMHPMj0j.js +0 -69
  361. package/dist/ui/assets/index-CknHGRYp.css +0 -1
  362. package/dist/ui/assets/index-v-DY6Zby.js +0 -1
  363. package/dist/ui/assets/proxy-status-widget-Ci1JpStj.js +0 -1
  364. package/dist/ui/assets/searchable-select-HbP2PXl3.js +0 -1
  365. package/dist/ui/assets/updates-l8Co9uve.js +0 -1
@@ -0,0 +1,68 @@
1
+ "use strict";
2
+ var __createBinding = (this && this.__createBinding) || (Object.create ? (function(o, m, k, k2) {
3
+ if (k2 === undefined) k2 = k;
4
+ var desc = Object.getOwnPropertyDescriptor(m, k);
5
+ if (!desc || ("get" in desc ? !m.__esModule : desc.writable || desc.configurable)) {
6
+ desc = { enumerable: true, get: function() { return m[k]; } };
7
+ }
8
+ Object.defineProperty(o, k2, desc);
9
+ }) : (function(o, m, k, k2) {
10
+ if (k2 === undefined) k2 = k;
11
+ o[k2] = m[k];
12
+ }));
13
+ var __setModuleDefault = (this && this.__setModuleDefault) || (Object.create ? (function(o, v) {
14
+ Object.defineProperty(o, "default", { enumerable: true, value: v });
15
+ }) : function(o, v) {
16
+ o["default"] = v;
17
+ });
18
+ var __importStar = (this && this.__importStar) || function (mod) {
19
+ if (mod && mod.__esModule) return mod;
20
+ var result = {};
21
+ if (mod != null) for (var k in mod) if (k !== "default" && Object.prototype.hasOwnProperty.call(mod, k)) __createBinding(result, mod, k);
22
+ __setModuleDefault(result, mod);
23
+ return result;
24
+ };
25
+ Object.defineProperty(exports, "__esModule", { value: true });
26
+ exports.getResolvedLoggingConfig = exports.invalidateLoggingConfigCache = void 0;
27
+ const fs = __importStar(require("fs"));
28
+ const unified_config_types_1 = require("../../config/unified-config-types");
29
+ const unified_config_loader_1 = require("../../config/unified-config-loader");
30
+ const CACHE_RECHECK_MS = 1000;
31
+ let cachedConfig = { ...unified_config_types_1.DEFAULT_LOGGING_CONFIG };
32
+ let cachedMtimeMs = null;
33
+ let lastCheckedAt = 0;
34
+ function invalidateLoggingConfigCache() {
35
+ cachedConfig = { ...unified_config_types_1.DEFAULT_LOGGING_CONFIG };
36
+ cachedMtimeMs = null;
37
+ lastCheckedAt = 0;
38
+ }
39
+ exports.invalidateLoggingConfigCache = invalidateLoggingConfigCache;
40
+ function getResolvedLoggingConfig() {
41
+ const now = Date.now();
42
+ if (now - lastCheckedAt < CACHE_RECHECK_MS) {
43
+ return cachedConfig;
44
+ }
45
+ try {
46
+ const configPath = (0, unified_config_loader_1.getConfigYamlPath)();
47
+ const nextMtimeMs = fs.existsSync(configPath) ? fs.statSync(configPath).mtimeMs : null;
48
+ if (nextMtimeMs === cachedMtimeMs) {
49
+ lastCheckedAt = now;
50
+ return cachedConfig;
51
+ }
52
+ cachedConfig = {
53
+ ...unified_config_types_1.DEFAULT_LOGGING_CONFIG,
54
+ ...(0, unified_config_loader_1.getLoggingConfig)(),
55
+ };
56
+ cachedMtimeMs = nextMtimeMs;
57
+ lastCheckedAt = now;
58
+ return cachedConfig;
59
+ }
60
+ catch {
61
+ cachedConfig = { ...unified_config_types_1.DEFAULT_LOGGING_CONFIG };
62
+ cachedMtimeMs = null;
63
+ lastCheckedAt = now;
64
+ return cachedConfig;
65
+ }
66
+ }
67
+ exports.getResolvedLoggingConfig = getResolvedLoggingConfig;
68
+ //# sourceMappingURL=log-config.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"log-config.js","sourceRoot":"","sources":["../../../src/services/logging/log-config.ts"],"names":[],"mappings":";;;;;;;;;;;;;;;;;;;;;;;;;;AAAA,uCAAyB;AACzB,4EAA2E;AAC3E,8EAG4C;AAG5C,MAAM,gBAAgB,GAAG,IAAI,CAAC;AAC9B,IAAI,YAAY,GAAkB,EAAE,GAAG,6CAAsB,EAAE,CAAC;AAChE,IAAI,aAAa,GAAkB,IAAI,CAAC;AACxC,IAAI,aAAa,GAAG,CAAC,CAAC;AAEtB,SAAgB,4BAA4B;IAC1C,YAAY,GAAG,EAAE,GAAG,6CAAsB,EAAE,CAAC;IAC7C,aAAa,GAAG,IAAI,CAAC;IACrB,aAAa,GAAG,CAAC,CAAC;AACpB,CAAC;AAJD,oEAIC;AAED,SAAgB,wBAAwB;IACtC,MAAM,GAAG,GAAG,IAAI,CAAC,GAAG,EAAE,CAAC;IACvB,IAAI,GAAG,GAAG,aAAa,GAAG,gBAAgB,EAAE,CAAC;QAC3C,OAAO,YAAY,CAAC;IACtB,CAAC;IAED,IAAI,CAAC;QACH,MAAM,UAAU,GAAG,IAAA,yCAAiB,GAAE,CAAC;QACvC,MAAM,WAAW,GAAG,EAAE,CAAC,UAAU,CAAC,UAAU,CAAC,CAAC,CAAC,CAAC,EAAE,CAAC,QAAQ,CAAC,UAAU,CAAC,CAAC,OAAO,CAAC,CAAC,CAAC,IAAI,CAAC;QACvF,IAAI,WAAW,KAAK,aAAa,EAAE,CAAC;YAClC,aAAa,GAAG,GAAG,CAAC;YACpB,OAAO,YAAY,CAAC;QACtB,CAAC;QAED,YAAY,GAAG;YACb,GAAG,6CAAsB;YACzB,GAAG,IAAA,wCAAuB,GAAE;SAC7B,CAAC;QACF,aAAa,GAAG,WAAW,CAAC;QAC5B,aAAa,GAAG,GAAG,CAAC;QACpB,OAAO,YAAY,CAAC;IACtB,CAAC;IAAC,MAAM,CAAC;QACP,YAAY,GAAG,EAAE,GAAG,6CAAsB,EAAE,CAAC;QAC7C,aAAa,GAAG,IAAI,CAAC;QACrB,aAAa,GAAG,GAAG,CAAC;QACpB,OAAO,YAAY,CAAC;IACtB,CAAC;AACH,CAAC;AA3BD,4DA2BC"}
@@ -0,0 +1,8 @@
1
+ export declare function getNativeLogsDir(): string;
2
+ export declare function getCurrentLogPath(): string;
3
+ export declare function getLogArchiveDir(): string;
4
+ export declare function getLegacyCliproxyLogsDir(): string;
5
+ export declare function ensureLoggingDirectories(): void;
6
+ export declare function isPathInsideDirectory(candidatePath: string, rootDir: string): boolean;
7
+ export declare function buildArchiveLogPath(timestamp?: Date): string;
8
+ //# sourceMappingURL=log-paths.d.ts.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"log-paths.d.ts","sourceRoot":"","sources":["../../../src/services/logging/log-paths.ts"],"names":[],"mappings":"AAQA,wBAAgB,gBAAgB,IAAI,MAAM,CAEzC;AAED,wBAAgB,iBAAiB,IAAI,MAAM,CAE1C;AAED,wBAAgB,gBAAgB,IAAI,MAAM,CAEzC;AAED,wBAAgB,wBAAwB,IAAI,MAAM,CAEjD;AAED,wBAAgB,wBAAwB,IAAI,IAAI,CAG/C;AAED,wBAAgB,qBAAqB,CAAC,aAAa,EAAE,MAAM,EAAE,OAAO,EAAE,MAAM,GAAG,OAAO,CAKrF;AAED,wBAAgB,mBAAmB,CAAC,SAAS,GAAE,IAAiB,GAAG,MAAM,CAGxE"}
@@ -0,0 +1,66 @@
1
+ "use strict";
2
+ var __createBinding = (this && this.__createBinding) || (Object.create ? (function(o, m, k, k2) {
3
+ if (k2 === undefined) k2 = k;
4
+ var desc = Object.getOwnPropertyDescriptor(m, k);
5
+ if (!desc || ("get" in desc ? !m.__esModule : desc.writable || desc.configurable)) {
6
+ desc = { enumerable: true, get: function() { return m[k]; } };
7
+ }
8
+ Object.defineProperty(o, k2, desc);
9
+ }) : (function(o, m, k, k2) {
10
+ if (k2 === undefined) k2 = k;
11
+ o[k2] = m[k];
12
+ }));
13
+ var __setModuleDefault = (this && this.__setModuleDefault) || (Object.create ? (function(o, v) {
14
+ Object.defineProperty(o, "default", { enumerable: true, value: v });
15
+ }) : function(o, v) {
16
+ o["default"] = v;
17
+ });
18
+ var __importStar = (this && this.__importStar) || function (mod) {
19
+ if (mod && mod.__esModule) return mod;
20
+ var result = {};
21
+ if (mod != null) for (var k in mod) if (k !== "default" && Object.prototype.hasOwnProperty.call(mod, k)) __createBinding(result, mod, k);
22
+ __setModuleDefault(result, mod);
23
+ return result;
24
+ };
25
+ Object.defineProperty(exports, "__esModule", { value: true });
26
+ exports.buildArchiveLogPath = exports.isPathInsideDirectory = exports.ensureLoggingDirectories = exports.getLegacyCliproxyLogsDir = exports.getLogArchiveDir = exports.getCurrentLogPath = exports.getNativeLogsDir = void 0;
27
+ const fs = __importStar(require("fs"));
28
+ const path = __importStar(require("path"));
29
+ const config_manager_1 = require("../../utils/config-manager");
30
+ const LOGS_DIR = 'logs';
31
+ const ARCHIVE_DIR = 'archive';
32
+ const CURRENT_LOG_FILE = 'current.jsonl';
33
+ function getNativeLogsDir() {
34
+ return path.join((0, config_manager_1.getCcsDir)(), LOGS_DIR);
35
+ }
36
+ exports.getNativeLogsDir = getNativeLogsDir;
37
+ function getCurrentLogPath() {
38
+ return path.join(getNativeLogsDir(), CURRENT_LOG_FILE);
39
+ }
40
+ exports.getCurrentLogPath = getCurrentLogPath;
41
+ function getLogArchiveDir() {
42
+ return path.join(getNativeLogsDir(), ARCHIVE_DIR);
43
+ }
44
+ exports.getLogArchiveDir = getLogArchiveDir;
45
+ function getLegacyCliproxyLogsDir() {
46
+ return path.join((0, config_manager_1.getCcsDir)(), 'cliproxy', 'logs');
47
+ }
48
+ exports.getLegacyCliproxyLogsDir = getLegacyCliproxyLogsDir;
49
+ function ensureLoggingDirectories() {
50
+ fs.mkdirSync(getNativeLogsDir(), { recursive: true, mode: 0o700 });
51
+ fs.mkdirSync(getLogArchiveDir(), { recursive: true, mode: 0o700 });
52
+ }
53
+ exports.ensureLoggingDirectories = ensureLoggingDirectories;
54
+ function isPathInsideDirectory(candidatePath, rootDir) {
55
+ const resolvedCandidate = path.resolve(candidatePath);
56
+ const resolvedRoot = path.resolve(rootDir);
57
+ const relative = path.relative(resolvedRoot, resolvedCandidate);
58
+ return relative === '' || (!relative.startsWith('..') && !path.isAbsolute(relative));
59
+ }
60
+ exports.isPathInsideDirectory = isPathInsideDirectory;
61
+ function buildArchiveLogPath(timestamp = new Date()) {
62
+ const compact = timestamp.toISOString().replace(/[:.]/g, '-');
63
+ return path.join(getLogArchiveDir(), `ccs-${compact}.jsonl.gz`);
64
+ }
65
+ exports.buildArchiveLogPath = buildArchiveLogPath;
66
+ //# sourceMappingURL=log-paths.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"log-paths.js","sourceRoot":"","sources":["../../../src/services/logging/log-paths.ts"],"names":[],"mappings":";;;;;;;;;;;;;;;;;;;;;;;;;;AAAA,uCAAyB;AACzB,2CAA6B;AAC7B,+DAAuD;AAEvD,MAAM,QAAQ,GAAG,MAAM,CAAC;AACxB,MAAM,WAAW,GAAG,SAAS,CAAC;AAC9B,MAAM,gBAAgB,GAAG,eAAe,CAAC;AAEzC,SAAgB,gBAAgB;IAC9B,OAAO,IAAI,CAAC,IAAI,CAAC,IAAA,0BAAS,GAAE,EAAE,QAAQ,CAAC,CAAC;AAC1C,CAAC;AAFD,4CAEC;AAED,SAAgB,iBAAiB;IAC/B,OAAO,IAAI,CAAC,IAAI,CAAC,gBAAgB,EAAE,EAAE,gBAAgB,CAAC,CAAC;AACzD,CAAC;AAFD,8CAEC;AAED,SAAgB,gBAAgB;IAC9B,OAAO,IAAI,CAAC,IAAI,CAAC,gBAAgB,EAAE,EAAE,WAAW,CAAC,CAAC;AACpD,CAAC;AAFD,4CAEC;AAED,SAAgB,wBAAwB;IACtC,OAAO,IAAI,CAAC,IAAI,CAAC,IAAA,0BAAS,GAAE,EAAE,UAAU,EAAE,MAAM,CAAC,CAAC;AACpD,CAAC;AAFD,4DAEC;AAED,SAAgB,wBAAwB;IACtC,EAAE,CAAC,SAAS,CAAC,gBAAgB,EAAE,EAAE,EAAE,SAAS,EAAE,IAAI,EAAE,IAAI,EAAE,KAAK,EAAE,CAAC,CAAC;IACnE,EAAE,CAAC,SAAS,CAAC,gBAAgB,EAAE,EAAE,EAAE,SAAS,EAAE,IAAI,EAAE,IAAI,EAAE,KAAK,EAAE,CAAC,CAAC;AACrE,CAAC;AAHD,4DAGC;AAED,SAAgB,qBAAqB,CAAC,aAAqB,EAAE,OAAe;IAC1E,MAAM,iBAAiB,GAAG,IAAI,CAAC,OAAO,CAAC,aAAa,CAAC,CAAC;IACtD,MAAM,YAAY,GAAG,IAAI,CAAC,OAAO,CAAC,OAAO,CAAC,CAAC;IAC3C,MAAM,QAAQ,GAAG,IAAI,CAAC,QAAQ,CAAC,YAAY,EAAE,iBAAiB,CAAC,CAAC;IAChE,OAAO,QAAQ,KAAK,EAAE,IAAI,CAAC,CAAC,QAAQ,CAAC,UAAU,CAAC,IAAI,CAAC,IAAI,CAAC,IAAI,CAAC,UAAU,CAAC,QAAQ,CAAC,CAAC,CAAC;AACvF,CAAC;AALD,sDAKC;AAED,SAAgB,mBAAmB,CAAC,YAAkB,IAAI,IAAI,EAAE;IAC9D,MAAM,OAAO,GAAG,SAAS,CAAC,WAAW,EAAE,CAAC,OAAO,CAAC,OAAO,EAAE,GAAG,CAAC,CAAC;IAC9D,OAAO,IAAI,CAAC,IAAI,CAAC,gBAAgB,EAAE,EAAE,OAAO,OAAO,WAAW,CAAC,CAAC;AAClE,CAAC;AAHD,kDAGC"}
@@ -0,0 +1,5 @@
1
+ import { type LogEntry, type LogSourceSummary, type ReadLogEntriesOptions } from './log-types';
2
+ export declare function readLogEntries(options?: ReadLogEntriesOptions): LogEntry[];
3
+ export declare function readLogSourceSummaries(): LogSourceSummary[];
4
+ export declare function normalizeLogQueryLevel(level: string | undefined): import("./log-types").LoggingLevel | undefined;
5
+ //# sourceMappingURL=log-reader.d.ts.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"log-reader.d.ts","sourceRoot":"","sources":["../../../src/services/logging/log-reader.ts"],"names":[],"mappings":"AAGA,OAAO,EAEL,KAAK,QAAQ,EACb,KAAK,gBAAgB,EACrB,KAAK,qBAAqB,EAC3B,MAAM,aAAa,CAAC;AAwFrB,wBAAgB,cAAc,CAAC,OAAO,GAAE,qBAA0B,GAAG,QAAQ,EAAE,CAO9E;AAED,wBAAgB,sBAAsB,IAAI,gBAAgB,EAAE,CAgB3D;AAED,wBAAgB,sBAAsB,CAAC,KAAK,EAAE,MAAM,GAAG,SAAS,kDAE/D"}
@@ -0,0 +1,124 @@
1
+ "use strict";
2
+ var __createBinding = (this && this.__createBinding) || (Object.create ? (function(o, m, k, k2) {
3
+ if (k2 === undefined) k2 = k;
4
+ var desc = Object.getOwnPropertyDescriptor(m, k);
5
+ if (!desc || ("get" in desc ? !m.__esModule : desc.writable || desc.configurable)) {
6
+ desc = { enumerable: true, get: function() { return m[k]; } };
7
+ }
8
+ Object.defineProperty(o, k2, desc);
9
+ }) : (function(o, m, k, k2) {
10
+ if (k2 === undefined) k2 = k;
11
+ o[k2] = m[k];
12
+ }));
13
+ var __setModuleDefault = (this && this.__setModuleDefault) || (Object.create ? (function(o, v) {
14
+ Object.defineProperty(o, "default", { enumerable: true, value: v });
15
+ }) : function(o, v) {
16
+ o["default"] = v;
17
+ });
18
+ var __importStar = (this && this.__importStar) || function (mod) {
19
+ if (mod && mod.__esModule) return mod;
20
+ var result = {};
21
+ if (mod != null) for (var k in mod) if (k !== "default" && Object.prototype.hasOwnProperty.call(mod, k)) __createBinding(result, mod, k);
22
+ __setModuleDefault(result, mod);
23
+ return result;
24
+ };
25
+ Object.defineProperty(exports, "__esModule", { value: true });
26
+ exports.normalizeLogQueryLevel = exports.readLogSourceSummaries = exports.readLogEntries = void 0;
27
+ const fs = __importStar(require("fs"));
28
+ const log_buffer_1 = require("./log-buffer");
29
+ const log_paths_1 = require("./log-paths");
30
+ const log_types_1 = require("./log-types");
31
+ let currentLogCache = null;
32
+ function parseLogLine(line) {
33
+ try {
34
+ return JSON.parse(line);
35
+ }
36
+ catch {
37
+ return null;
38
+ }
39
+ }
40
+ function readCurrentFileEntries() {
41
+ const currentLogPath = (0, log_paths_1.getCurrentLogPath)();
42
+ if (!fs.existsSync(currentLogPath)) {
43
+ currentLogCache = null;
44
+ return [];
45
+ }
46
+ const stats = fs.statSync(currentLogPath, { bigint: true });
47
+ if (currentLogCache &&
48
+ currentLogCache.path === currentLogPath &&
49
+ currentLogCache.mtimeNs === stats.mtimeNs &&
50
+ currentLogCache.size === stats.size) {
51
+ return [...currentLogCache.entries];
52
+ }
53
+ const entries = fs
54
+ .readFileSync(currentLogPath, 'utf8')
55
+ .split('\n')
56
+ .map((line) => line.trim())
57
+ .filter(Boolean)
58
+ .map(parseLogLine)
59
+ .filter((entry) => entry !== null);
60
+ currentLogCache = {
61
+ entries,
62
+ mtimeNs: stats.mtimeNs,
63
+ path: currentLogPath,
64
+ size: stats.size,
65
+ };
66
+ return [...entries];
67
+ }
68
+ function matchesLogQuery(entry, options) {
69
+ if (options.source && entry.source !== options.source) {
70
+ return false;
71
+ }
72
+ if (options.level && entry.level !== options.level) {
73
+ return false;
74
+ }
75
+ if (!options.search) {
76
+ return true;
77
+ }
78
+ const search = options.search.toLowerCase();
79
+ return (entry.message.toLowerCase().includes(search) ||
80
+ entry.event.toLowerCase().includes(search) ||
81
+ entry.source.toLowerCase().includes(search) ||
82
+ String(entry.processId).toLowerCase().includes(search) ||
83
+ entry.runId.toLowerCase().includes(search) ||
84
+ JSON.stringify(entry.context || {})
85
+ .toLowerCase()
86
+ .includes(search));
87
+ }
88
+ function dedupeEntries(entries) {
89
+ const seen = new Map();
90
+ for (const entry of entries) {
91
+ seen.set(entry.id, entry);
92
+ }
93
+ return [...seen.values()];
94
+ }
95
+ function readLogEntries(options = {}) {
96
+ const limit = options.limit ?? 200;
97
+ const entries = dedupeEntries([...readCurrentFileEntries(), ...(0, log_buffer_1.getRecentLogEntries)()])
98
+ .filter((entry) => matchesLogQuery(entry, options))
99
+ .sort((a, b) => Date.parse(b.timestamp) - Date.parse(a.timestamp));
100
+ return entries.slice(0, limit);
101
+ }
102
+ exports.readLogEntries = readLogEntries;
103
+ function readLogSourceSummaries() {
104
+ const summaryMap = new Map();
105
+ for (const entry of readLogEntries({ limit: 500 })) {
106
+ const current = summaryMap.get(entry.source) ?? {
107
+ source: entry.source,
108
+ label: entry.source,
109
+ kind: 'native',
110
+ count: 0,
111
+ lastTimestamp: null,
112
+ };
113
+ current.count += 1;
114
+ current.lastTimestamp = current.lastTimestamp ?? entry.timestamp;
115
+ summaryMap.set(entry.source, current);
116
+ }
117
+ return [...summaryMap.values()].sort((a, b) => a.label.localeCompare(b.label));
118
+ }
119
+ exports.readLogSourceSummaries = readLogSourceSummaries;
120
+ function normalizeLogQueryLevel(level) {
121
+ return (0, log_types_1.isLoggingLevel)(level) ? level : undefined;
122
+ }
123
+ exports.normalizeLogQueryLevel = normalizeLogQueryLevel;
124
+ //# sourceMappingURL=log-reader.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"log-reader.js","sourceRoot":"","sources":["../../../src/services/logging/log-reader.ts"],"names":[],"mappings":";;;;;;;;;;;;;;;;;;;;;;;;;;AAAA,uCAAyB;AACzB,6CAAmD;AACnD,2CAAgD;AAChD,2CAKqB;AASrB,IAAI,eAAe,GAAoB,IAAI,CAAC;AAE5C,SAAS,YAAY,CAAC,IAAY;IAChC,IAAI,CAAC;QACH,OAAO,IAAI,CAAC,KAAK,CAAC,IAAI,CAAa,CAAC;IACtC,CAAC;IAAC,MAAM,CAAC;QACP,OAAO,IAAI,CAAC;IACd,CAAC;AACH,CAAC;AAED,SAAS,sBAAsB;IAC7B,MAAM,cAAc,GAAG,IAAA,6BAAiB,GAAE,CAAC;IAC3C,IAAI,CAAC,EAAE,CAAC,UAAU,CAAC,cAAc,CAAC,EAAE,CAAC;QACnC,eAAe,GAAG,IAAI,CAAC;QACvB,OAAO,EAAE,CAAC;IACZ,CAAC;IAED,MAAM,KAAK,GAAG,EAAE,CAAC,QAAQ,CAAC,cAAc,EAAE,EAAE,MAAM,EAAE,IAAI,EAAE,CAAC,CAAC;IAC5D,IACE,eAAe;QACf,eAAe,CAAC,IAAI,KAAK,cAAc;QACvC,eAAe,CAAC,OAAO,KAAK,KAAK,CAAC,OAAO;QACzC,eAAe,CAAC,IAAI,KAAK,KAAK,CAAC,IAAI,EACnC,CAAC;QACD,OAAO,CAAC,GAAG,eAAe,CAAC,OAAO,CAAC,CAAC;IACtC,CAAC;IAED,MAAM,OAAO,GAAG,EAAE;SACf,YAAY,CAAC,cAAc,EAAE,MAAM,CAAC;SACpC,KAAK,CAAC,IAAI,CAAC;SACX,GAAG,CAAC,CAAC,IAAI,EAAE,EAAE,CAAC,IAAI,CAAC,IAAI,EAAE,CAAC;SAC1B,MAAM,CAAC,OAAO,CAAC;SACf,GAAG,CAAC,YAAY,CAAC;SACjB,MAAM,CAAC,CAAC,KAAK,EAAqB,EAAE,CAAC,KAAK,KAAK,IAAI,CAAC,CAAC;IAExD,eAAe,GAAG;QAChB,OAAO;QACP,OAAO,EAAE,KAAK,CAAC,OAAO;QACtB,IAAI,EAAE,cAAc;QACpB,IAAI,EAAE,KAAK,CAAC,IAAI;KACjB,CAAC;IAEF,OAAO,CAAC,GAAG,OAAO,CAAC,CAAC;AACtB,CAAC;AAED,SAAS,eAAe,CAAC,KAAe,EAAE,OAA8B;IACtE,IAAI,OAAO,CAAC,MAAM,IAAI,KAAK,CAAC,MAAM,KAAK,OAAO,CAAC,MAAM,EAAE,CAAC;QACtD,OAAO,KAAK,CAAC;IACf,CAAC;IAED,IAAI,OAAO,CAAC,KAAK,IAAI,KAAK,CAAC,KAAK,KAAK,OAAO,CAAC,KAAK,EAAE,CAAC;QACnD,OAAO,KAAK,CAAC;IACf,CAAC;IAED,IAAI,CAAC,OAAO,CAAC,MAAM,EAAE,CAAC;QACpB,OAAO,IAAI,CAAC;IACd,CAAC;IAED,MAAM,MAAM,GAAG,OAAO,CAAC,MAAM,CAAC,WAAW,EAAE,CAAC;IAC5C,OAAO,CACL,KAAK,CAAC,OAAO,CAAC,WAAW,EAAE,CAAC,QAAQ,CAAC,MAAM,CAAC;QAC5C,KAAK,CAAC,KAAK,CAAC,WAAW,EAAE,CAAC,QAAQ,CAAC,MAAM,CAAC;QAC1C,KAAK,CAAC,MAAM,CAAC,WAAW,EAAE,CAAC,QAAQ,CAAC,MAAM,CAAC;QAC3C,MAAM,CAAC,KAAK,CAAC,SAAS,CAAC,CAAC,WAAW,EAAE,CAAC,QAAQ,CAAC,MAAM,CAAC;QACtD,KAAK,CAAC,KAAK,CAAC,WAAW,EAAE,CAAC,QAAQ,CAAC,MAAM,CAAC;QAC1C,IAAI,CAAC,SAAS,CAAC,KAAK,CAAC,OAAO,IAAI,EAAE,CAAC;aAChC,WAAW,EAAE;aACb,QAAQ,CAAC,MAAM,CAAC,CACpB,CAAC;AACJ,CAAC;AAED,SAAS,aAAa,CAAC,OAAmB;IACxC,MAAM,IAAI,GAAG,IAAI,GAAG,EAAoB,CAAC;IACzC,KAAK,MAAM,KAAK,IAAI,OAAO,EAAE,CAAC;QAC5B,IAAI,CAAC,GAAG,CAAC,KAAK,CAAC,EAAE,EAAE,KAAK,CAAC,CAAC;IAC5B,CAAC;IACD,OAAO,CAAC,GAAG,IAAI,CAAC,MAAM,EAAE,CAAC,CAAC;AAC5B,CAAC;AAED,SAAgB,cAAc,CAAC,UAAiC,EAAE;IAChE,MAAM,KAAK,GAAG,OAAO,CAAC,KAAK,IAAI,GAAG,CAAC;IACnC,MAAM,OAAO,GAAG,aAAa,CAAC,CAAC,GAAG,sBAAsB,EAAE,EAAE,GAAG,IAAA,gCAAmB,GAAE,CAAC,CAAC;SACnF,MAAM,CAAC,CAAC,KAAK,EAAE,EAAE,CAAC,eAAe,CAAC,KAAK,EAAE,OAAO,CAAC,CAAC;SAClD,IAAI,CAAC,CAAC,CAAC,EAAE,CAAC,EAAE,EAAE,CAAC,IAAI,CAAC,KAAK,CAAC,CAAC,CAAC,SAAS,CAAC,GAAG,IAAI,CAAC,KAAK,CAAC,CAAC,CAAC,SAAS,CAAC,CAAC,CAAC;IAErE,OAAO,OAAO,CAAC,KAAK,CAAC,CAAC,EAAE,KAAK,CAAC,CAAC;AACjC,CAAC;AAPD,wCAOC;AAED,SAAgB,sBAAsB;IACpC,MAAM,UAAU,GAAG,IAAI,GAAG,EAA4B,CAAC;IACvD,KAAK,MAAM,KAAK,IAAI,cAAc,CAAC,EAAE,KAAK,EAAE,GAAG,EAAE,CAAC,EAAE,CAAC;QACnD,MAAM,OAAO,GAAG,UAAU,CAAC,GAAG,CAAC,KAAK,CAAC,MAAM,CAAC,IAAI;YAC9C,MAAM,EAAE,KAAK,CAAC,MAAM;YACpB,KAAK,EAAE,KAAK,CAAC,MAAM;YACnB,IAAI,EAAE,QAAiB;YACvB,KAAK,EAAE,CAAC;YACR,aAAa,EAAE,IAAI;SACpB,CAAC;QACF,OAAO,CAAC,KAAK,IAAI,CAAC,CAAC;QACnB,OAAO,CAAC,aAAa,GAAG,OAAO,CAAC,aAAa,IAAI,KAAK,CAAC,SAAS,CAAC;QACjE,UAAU,CAAC,GAAG,CAAC,KAAK,CAAC,MAAM,EAAE,OAAO,CAAC,CAAC;IACxC,CAAC;IAED,OAAO,CAAC,GAAG,UAAU,CAAC,MAAM,EAAE,CAAC,CAAC,IAAI,CAAC,CAAC,CAAC,EAAE,CAAC,EAAE,EAAE,CAAC,CAAC,CAAC,KAAK,CAAC,aAAa,CAAC,CAAC,CAAC,KAAK,CAAC,CAAC,CAAC;AACjF,CAAC;AAhBD,wDAgBC;AAED,SAAgB,sBAAsB,CAAC,KAAyB;IAC9D,OAAO,IAAA,0BAAc,EAAC,KAAK,CAAC,CAAC,CAAC,CAAC,KAAK,CAAC,CAAC,CAAC,SAAS,CAAC;AACnD,CAAC;AAFD,wDAEC"}
@@ -0,0 +1,2 @@
1
+ export declare function redactContext(context: Record<string, unknown> | undefined): Record<string, unknown>;
2
+ //# sourceMappingURL=log-redaction.d.ts.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"log-redaction.d.ts","sourceRoot":"","sources":["../../../src/services/logging/log-redaction.ts"],"names":[],"mappings":"AAqDA,wBAAgB,aAAa,CAC3B,OAAO,EAAE,MAAM,CAAC,MAAM,EAAE,OAAO,CAAC,GAAG,SAAS,GAC3C,MAAM,CAAC,MAAM,EAAE,OAAO,CAAC,CAMzB"}
@@ -0,0 +1,53 @@
1
+ "use strict";
2
+ Object.defineProperty(exports, "__esModule", { value: true });
3
+ exports.redactContext = void 0;
4
+ const SENSITIVE_KEY_PATTERN = /^(authorization|cookie|set-cookie|password|password_hash|secret|token|api[_-]?key|management[_-]?key)$/i;
5
+ const MAX_STRING_LENGTH = 2000;
6
+ const MAX_DEPTH = 5;
7
+ function truncateString(value) {
8
+ if (value.length <= MAX_STRING_LENGTH) {
9
+ return value;
10
+ }
11
+ return `${value.slice(0, MAX_STRING_LENGTH)}...[truncated]`;
12
+ }
13
+ function sanitizeValue(value, depth) {
14
+ if (value === null || value === undefined) {
15
+ return value;
16
+ }
17
+ if (depth >= MAX_DEPTH) {
18
+ return '[max-depth]';
19
+ }
20
+ if (typeof value === 'string') {
21
+ return truncateString(value);
22
+ }
23
+ if (typeof value === 'number' || typeof value === 'boolean') {
24
+ return value;
25
+ }
26
+ if (value instanceof Error) {
27
+ return {
28
+ name: value.name,
29
+ message: truncateString(value.message),
30
+ };
31
+ }
32
+ if (Array.isArray(value)) {
33
+ return value.map((item) => sanitizeValue(item, depth + 1));
34
+ }
35
+ if (typeof value === 'object') {
36
+ const sanitized = {};
37
+ for (const [key, nestedValue] of Object.entries(value)) {
38
+ sanitized[key] = SENSITIVE_KEY_PATTERN.test(key)
39
+ ? '[redacted]'
40
+ : sanitizeValue(nestedValue, depth + 1);
41
+ }
42
+ return sanitized;
43
+ }
44
+ return String(value);
45
+ }
46
+ function redactContext(context) {
47
+ if (!context) {
48
+ return {};
49
+ }
50
+ return sanitizeValue(context, 0);
51
+ }
52
+ exports.redactContext = redactContext;
53
+ //# sourceMappingURL=log-redaction.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"log-redaction.js","sourceRoot":"","sources":["../../../src/services/logging/log-redaction.ts"],"names":[],"mappings":";;;AAAA,MAAM,qBAAqB,GACzB,yGAAyG,CAAC;AAC5G,MAAM,iBAAiB,GAAG,IAAI,CAAC;AAC/B,MAAM,SAAS,GAAG,CAAC,CAAC;AAEpB,SAAS,cAAc,CAAC,KAAa;IACnC,IAAI,KAAK,CAAC,MAAM,IAAI,iBAAiB,EAAE,CAAC;QACtC,OAAO,KAAK,CAAC;IACf,CAAC;IACD,OAAO,GAAG,KAAK,CAAC,KAAK,CAAC,CAAC,EAAE,iBAAiB,CAAC,gBAAgB,CAAC;AAC9D,CAAC;AAED,SAAS,aAAa,CAAC,KAAc,EAAE,KAAa;IAClD,IAAI,KAAK,KAAK,IAAI,IAAI,KAAK,KAAK,SAAS,EAAE,CAAC;QAC1C,OAAO,KAAK,CAAC;IACf,CAAC;IAED,IAAI,KAAK,IAAI,SAAS,EAAE,CAAC;QACvB,OAAO,aAAa,CAAC;IACvB,CAAC;IAED,IAAI,OAAO,KAAK,KAAK,QAAQ,EAAE,CAAC;QAC9B,OAAO,cAAc,CAAC,KAAK,CAAC,CAAC;IAC/B,CAAC;IAED,IAAI,OAAO,KAAK,KAAK,QAAQ,IAAI,OAAO,KAAK,KAAK,SAAS,EAAE,CAAC;QAC5D,OAAO,KAAK,CAAC;IACf,CAAC;IAED,IAAI,KAAK,YAAY,KAAK,EAAE,CAAC;QAC3B,OAAO;YACL,IAAI,EAAE,KAAK,CAAC,IAAI;YAChB,OAAO,EAAE,cAAc,CAAC,KAAK,CAAC,OAAO,CAAC;SACvC,CAAC;IACJ,CAAC;IAED,IAAI,KAAK,CAAC,OAAO,CAAC,KAAK,CAAC,EAAE,CAAC;QACzB,OAAO,KAAK,CAAC,GAAG,CAAC,CAAC,IAAI,EAAE,EAAE,CAAC,aAAa,CAAC,IAAI,EAAE,KAAK,GAAG,CAAC,CAAC,CAAC,CAAC;IAC7D,CAAC;IAED,IAAI,OAAO,KAAK,KAAK,QAAQ,EAAE,CAAC;QAC9B,MAAM,SAAS,GAA4B,EAAE,CAAC;QAC9C,KAAK,MAAM,CAAC,GAAG,EAAE,WAAW,CAAC,IAAI,MAAM,CAAC,OAAO,CAAC,KAAgC,CAAC,EAAE,CAAC;YAClF,SAAS,CAAC,GAAG,CAAC,GAAG,qBAAqB,CAAC,IAAI,CAAC,GAAG,CAAC;gBAC9C,CAAC,CAAC,YAAY;gBACd,CAAC,CAAC,aAAa,CAAC,WAAW,EAAE,KAAK,GAAG,CAAC,CAAC,CAAC;QAC5C,CAAC;QACD,OAAO,SAAS,CAAC;IACnB,CAAC;IAED,OAAO,MAAM,CAAC,KAAK,CAAC,CAAC;AACvB,CAAC;AAED,SAAgB,aAAa,CAC3B,OAA4C;IAE5C,IAAI,CAAC,OAAO,EAAE,CAAC;QACb,OAAO,EAAE,CAAC;IACZ,CAAC;IAED,OAAO,aAAa,CAAC,OAAO,EAAE,CAAC,CAA4B,CAAC;AAC9D,CAAC;AARD,sCAQC"}
@@ -0,0 +1,4 @@
1
+ import { type LogEntry } from './log-types';
2
+ export declare function pruneExpiredLogArchives(): void;
3
+ export declare function appendStructuredLogEntry(entry: LogEntry): void;
4
+ //# sourceMappingURL=log-storage.d.ts.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"log-storage.d.ts","sourceRoot":"","sources":["../../../src/services/logging/log-storage.ts"],"names":[],"mappings":"AAWA,OAAO,EAAuB,KAAK,QAAQ,EAAE,MAAM,aAAa,CAAC;AAqCjE,wBAAgB,uBAAuB,IAAI,IAAI,CAsB9C;AAED,wBAAgB,wBAAwB,CAAC,KAAK,EAAE,QAAQ,GAAG,IAAI,CAqB9D"}
@@ -0,0 +1,109 @@
1
+ "use strict";
2
+ var __createBinding = (this && this.__createBinding) || (Object.create ? (function(o, m, k, k2) {
3
+ if (k2 === undefined) k2 = k;
4
+ var desc = Object.getOwnPropertyDescriptor(m, k);
5
+ if (!desc || ("get" in desc ? !m.__esModule : desc.writable || desc.configurable)) {
6
+ desc = { enumerable: true, get: function() { return m[k]; } };
7
+ }
8
+ Object.defineProperty(o, k2, desc);
9
+ }) : (function(o, m, k, k2) {
10
+ if (k2 === undefined) k2 = k;
11
+ o[k2] = m[k];
12
+ }));
13
+ var __setModuleDefault = (this && this.__setModuleDefault) || (Object.create ? (function(o, v) {
14
+ Object.defineProperty(o, "default", { enumerable: true, value: v });
15
+ }) : function(o, v) {
16
+ o["default"] = v;
17
+ });
18
+ var __importStar = (this && this.__importStar) || function (mod) {
19
+ if (mod && mod.__esModule) return mod;
20
+ var result = {};
21
+ if (mod != null) for (var k in mod) if (k !== "default" && Object.prototype.hasOwnProperty.call(mod, k)) __createBinding(result, mod, k);
22
+ __setModuleDefault(result, mod);
23
+ return result;
24
+ };
25
+ Object.defineProperty(exports, "__esModule", { value: true });
26
+ exports.appendStructuredLogEntry = exports.pruneExpiredLogArchives = void 0;
27
+ const fs = __importStar(require("fs"));
28
+ const path = __importStar(require("path"));
29
+ const zlib = __importStar(require("zlib"));
30
+ const log_config_1 = require("./log-config");
31
+ const log_paths_1 = require("./log-paths");
32
+ const log_buffer_1 = require("./log-buffer");
33
+ const log_types_1 = require("./log-types");
34
+ const ONE_DAY_MS = 24 * 60 * 60 * 1000;
35
+ const PRUNE_INTERVAL_MS = 60 * 1000;
36
+ let lastPruneAt = 0;
37
+ function getRotateBytes(rotateMb) {
38
+ return Math.max(1, rotateMb) * 1024 * 1024;
39
+ }
40
+ function rotateCurrentLogIfNeeded() {
41
+ const config = (0, log_config_1.getResolvedLoggingConfig)();
42
+ const currentLogPath = (0, log_paths_1.getCurrentLogPath)();
43
+ if (!fs.existsSync(currentLogPath)) {
44
+ return;
45
+ }
46
+ const stats = fs.statSync(currentLogPath);
47
+ const ageMs = Date.now() - stats.mtimeMs;
48
+ const exceedsSize = stats.size >= getRotateBytes(config.rotate_mb);
49
+ const exceedsAge = ageMs >= ONE_DAY_MS;
50
+ if (!exceedsSize && !exceedsAge) {
51
+ return;
52
+ }
53
+ const currentContent = fs.readFileSync(currentLogPath, 'utf8');
54
+ if (!currentContent.trim()) {
55
+ fs.truncateSync(currentLogPath, 0);
56
+ return;
57
+ }
58
+ const archivePath = (0, log_paths_1.buildArchiveLogPath)(new Date(stats.mtimeMs || Date.now()));
59
+ fs.writeFileSync(archivePath, zlib.gzipSync(currentContent), { mode: 0o600 });
60
+ fs.truncateSync(currentLogPath, 0);
61
+ }
62
+ function pruneExpiredLogArchives() {
63
+ const config = (0, log_config_1.getResolvedLoggingConfig)();
64
+ const archiveDir = (0, log_paths_1.getLogArchiveDir)();
65
+ if (!fs.existsSync(archiveDir)) {
66
+ return;
67
+ }
68
+ const cutoffMs = Date.now() - config.retain_days * ONE_DAY_MS;
69
+ for (const entry of fs.readdirSync(archiveDir)) {
70
+ const archivePath = path.join(archiveDir, entry);
71
+ try {
72
+ const stats = fs.lstatSync(archivePath);
73
+ if (!stats.isFile() || stats.isSymbolicLink()) {
74
+ continue;
75
+ }
76
+ if (stats.mtimeMs < cutoffMs) {
77
+ fs.unlinkSync(archivePath);
78
+ }
79
+ }
80
+ catch {
81
+ continue;
82
+ }
83
+ }
84
+ }
85
+ exports.pruneExpiredLogArchives = pruneExpiredLogArchives;
86
+ function appendStructuredLogEntry(entry) {
87
+ const config = (0, log_config_1.getResolvedLoggingConfig)();
88
+ if (!config.enabled || !(0, log_types_1.shouldWriteLogLevel)(entry.level, config.level)) {
89
+ return;
90
+ }
91
+ try {
92
+ (0, log_paths_1.ensureLoggingDirectories)();
93
+ rotateCurrentLogIfNeeded();
94
+ fs.appendFileSync((0, log_paths_1.getCurrentLogPath)(), `${JSON.stringify(entry)}\n`, {
95
+ encoding: 'utf8',
96
+ mode: 0o600,
97
+ });
98
+ (0, log_buffer_1.pushRecentLogEntry)(entry, config.live_buffer_size);
99
+ if (Date.now() - lastPruneAt >= PRUNE_INTERVAL_MS) {
100
+ pruneExpiredLogArchives();
101
+ lastPruneAt = Date.now();
102
+ }
103
+ }
104
+ catch {
105
+ // Logging must never break runtime behavior.
106
+ }
107
+ }
108
+ exports.appendStructuredLogEntry = appendStructuredLogEntry;
109
+ //# sourceMappingURL=log-storage.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"log-storage.js","sourceRoot":"","sources":["../../../src/services/logging/log-storage.ts"],"names":[],"mappings":"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"}
@@ -0,0 +1,30 @@
1
+ import type { LoggingConfig, LoggingLevel } from '../../config/unified-config-types';
2
+ export type { LoggingConfig, LoggingLevel };
3
+ export interface LogEntry {
4
+ id: string;
5
+ timestamp: string;
6
+ level: LoggingLevel;
7
+ source: string;
8
+ event: string;
9
+ message: string;
10
+ processId: number;
11
+ runId: string;
12
+ context?: Record<string, unknown>;
13
+ }
14
+ export interface LogSourceSummary {
15
+ source: string;
16
+ label: string;
17
+ kind: 'native' | 'legacy';
18
+ count: number;
19
+ lastTimestamp: string | null;
20
+ }
21
+ export interface ReadLogEntriesOptions {
22
+ source?: string;
23
+ level?: LoggingLevel;
24
+ search?: string;
25
+ limit?: number;
26
+ }
27
+ export declare const LOG_LEVELS: readonly LoggingLevel[];
28
+ export declare function shouldWriteLogLevel(level: LoggingLevel, configuredLevel: LoggingLevel): boolean;
29
+ export declare function isLoggingLevel(value: string | undefined): value is LoggingLevel;
30
+ //# sourceMappingURL=log-types.d.ts.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"log-types.d.ts","sourceRoot":"","sources":["../../../src/services/logging/log-types.ts"],"names":[],"mappings":"AAAA,OAAO,KAAK,EAAE,aAAa,EAAE,YAAY,EAAE,MAAM,mCAAmC,CAAC;AAErF,YAAY,EAAE,aAAa,EAAE,YAAY,EAAE,CAAC;AAE5C,MAAM,WAAW,QAAQ;IACvB,EAAE,EAAE,MAAM,CAAC;IACX,SAAS,EAAE,MAAM,CAAC;IAClB,KAAK,EAAE,YAAY,CAAC;IACpB,MAAM,EAAE,MAAM,CAAC;IACf,KAAK,EAAE,MAAM,CAAC;IACd,OAAO,EAAE,MAAM,CAAC;IAChB,SAAS,EAAE,MAAM,CAAC;IAClB,KAAK,EAAE,MAAM,CAAC;IACd,OAAO,CAAC,EAAE,MAAM,CAAC,MAAM,EAAE,OAAO,CAAC,CAAC;CACnC;AAED,MAAM,WAAW,gBAAgB;IAC/B,MAAM,EAAE,MAAM,CAAC;IACf,KAAK,EAAE,MAAM,CAAC;IACd,IAAI,EAAE,QAAQ,GAAG,QAAQ,CAAC;IAC1B,KAAK,EAAE,MAAM,CAAC;IACd,aAAa,EAAE,MAAM,GAAG,IAAI,CAAC;CAC9B;AAED,MAAM,WAAW,qBAAqB;IACpC,MAAM,CAAC,EAAE,MAAM,CAAC;IAChB,KAAK,CAAC,EAAE,YAAY,CAAC;IACrB,MAAM,CAAC,EAAE,MAAM,CAAC;IAChB,KAAK,CAAC,EAAE,MAAM,CAAC;CAChB;AAED,eAAO,MAAM,UAAU,EAAE,SAAS,YAAY,EAAuC,CAAC;AAStF,wBAAgB,mBAAmB,CAAC,KAAK,EAAE,YAAY,EAAE,eAAe,EAAE,YAAY,GAAG,OAAO,CAE/F;AAED,wBAAgB,cAAc,CAAC,KAAK,EAAE,MAAM,GAAG,SAAS,GAAG,KAAK,IAAI,YAAY,CAE/E"}
@@ -0,0 +1,19 @@
1
+ "use strict";
2
+ Object.defineProperty(exports, "__esModule", { value: true });
3
+ exports.isLoggingLevel = exports.shouldWriteLogLevel = exports.LOG_LEVELS = void 0;
4
+ exports.LOG_LEVELS = ['error', 'warn', 'info', 'debug'];
5
+ const LOG_LEVEL_PRIORITY = {
6
+ error: 0,
7
+ warn: 1,
8
+ info: 2,
9
+ debug: 3,
10
+ };
11
+ function shouldWriteLogLevel(level, configuredLevel) {
12
+ return LOG_LEVEL_PRIORITY[level] <= LOG_LEVEL_PRIORITY[configuredLevel];
13
+ }
14
+ exports.shouldWriteLogLevel = shouldWriteLogLevel;
15
+ function isLoggingLevel(value) {
16
+ return typeof value === 'string' && exports.LOG_LEVELS.includes(value);
17
+ }
18
+ exports.isLoggingLevel = isLoggingLevel;
19
+ //# sourceMappingURL=log-types.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"log-types.js","sourceRoot":"","sources":["../../../src/services/logging/log-types.ts"],"names":[],"mappings":";;;AA+Ba,QAAA,UAAU,GAA4B,CAAC,OAAO,EAAE,MAAM,EAAE,MAAM,EAAE,OAAO,CAAC,CAAC;AAEtF,MAAM,kBAAkB,GAAiC;IACvD,KAAK,EAAE,CAAC;IACR,IAAI,EAAE,CAAC;IACP,IAAI,EAAE,CAAC;IACP,KAAK,EAAE,CAAC;CACT,CAAC;AAEF,SAAgB,mBAAmB,CAAC,KAAmB,EAAE,eAA6B;IACpF,OAAO,kBAAkB,CAAC,KAAK,CAAC,IAAI,kBAAkB,CAAC,eAAe,CAAC,CAAC;AAC1E,CAAC;AAFD,kDAEC;AAED,SAAgB,cAAc,CAAC,KAAyB;IACtD,OAAO,OAAO,KAAK,KAAK,QAAQ,IAAI,kBAAU,CAAC,QAAQ,CAAC,KAAqB,CAAC,CAAC;AACjF,CAAC;AAFD,wCAEC"}
@@ -0,0 +1,9 @@
1
+ export interface Logger {
2
+ child(context: Record<string, unknown>): Logger;
3
+ debug(event: string, message: string, context?: Record<string, unknown>): void;
4
+ info(event: string, message: string, context?: Record<string, unknown>): void;
5
+ warn(event: string, message: string, context?: Record<string, unknown>): void;
6
+ error(event: string, message: string, context?: Record<string, unknown>): void;
7
+ }
8
+ export declare function createLogger(source: string, baseContext?: Record<string, unknown>): Logger;
9
+ //# sourceMappingURL=logger.d.ts.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"logger.d.ts","sourceRoot":"","sources":["../../../src/services/logging/logger.ts"],"names":[],"mappings":"AA6BA,MAAM,WAAW,MAAM;IACrB,KAAK,CAAC,OAAO,EAAE,MAAM,CAAC,MAAM,EAAE,OAAO,CAAC,GAAG,MAAM,CAAC;IAChD,KAAK,CAAC,KAAK,EAAE,MAAM,EAAE,OAAO,EAAE,MAAM,EAAE,OAAO,CAAC,EAAE,MAAM,CAAC,MAAM,EAAE,OAAO,CAAC,GAAG,IAAI,CAAC;IAC/E,IAAI,CAAC,KAAK,EAAE,MAAM,EAAE,OAAO,EAAE,MAAM,EAAE,OAAO,CAAC,EAAE,MAAM,CAAC,MAAM,EAAE,OAAO,CAAC,GAAG,IAAI,CAAC;IAC9E,IAAI,CAAC,KAAK,EAAE,MAAM,EAAE,OAAO,EAAE,MAAM,EAAE,OAAO,CAAC,EAAE,MAAM,CAAC,MAAM,EAAE,OAAO,CAAC,GAAG,IAAI,CAAC;IAC9E,KAAK,CAAC,KAAK,EAAE,MAAM,EAAE,OAAO,EAAE,MAAM,EAAE,OAAO,CAAC,EAAE,MAAM,CAAC,MAAM,EAAE,OAAO,CAAC,GAAG,IAAI,CAAC;CAChF;AAED,wBAAgB,YAAY,CAAC,MAAM,EAAE,MAAM,EAAE,WAAW,GAAE,MAAM,CAAC,MAAM,EAAE,OAAO,CAAM,GAAG,MAAM,CA6B9F"}
@@ -0,0 +1,46 @@
1
+ "use strict";
2
+ Object.defineProperty(exports, "__esModule", { value: true });
3
+ exports.createLogger = void 0;
4
+ const crypto_1 = require("crypto");
5
+ const log_config_1 = require("./log-config");
6
+ const log_redaction_1 = require("./log-redaction");
7
+ const log_storage_1 = require("./log-storage");
8
+ const processRunId = `${Date.now()}-${process.pid}-${Math.random().toString(36).slice(2, 10)}`;
9
+ function createEntry(source, level, event, message, context) {
10
+ const config = (0, log_config_1.getResolvedLoggingConfig)();
11
+ return {
12
+ id: (0, crypto_1.randomUUID)(),
13
+ timestamp: new Date().toISOString(),
14
+ level,
15
+ source,
16
+ event,
17
+ message,
18
+ processId: process.pid,
19
+ runId: processRunId,
20
+ context: config.redact ? (0, log_redaction_1.redactContext)(context) : context,
21
+ };
22
+ }
23
+ function createLogger(source, baseContext = {}) {
24
+ const write = (level, event, message, context) => {
25
+ (0, log_storage_1.appendStructuredLogEntry)(createEntry(source, level, event, message, { ...baseContext, ...(context || {}) }));
26
+ };
27
+ return {
28
+ child(context) {
29
+ return createLogger(source, { ...baseContext, ...context });
30
+ },
31
+ debug(event, message, context) {
32
+ write('debug', event, message, context);
33
+ },
34
+ info(event, message, context) {
35
+ write('info', event, message, context);
36
+ },
37
+ warn(event, message, context) {
38
+ write('warn', event, message, context);
39
+ },
40
+ error(event, message, context) {
41
+ write('error', event, message, context);
42
+ },
43
+ };
44
+ }
45
+ exports.createLogger = createLogger;
46
+ //# sourceMappingURL=logger.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"logger.js","sourceRoot":"","sources":["../../../src/services/logging/logger.ts"],"names":[],"mappings":";;;AAAA,mCAAoC;AACpC,6CAAwD;AACxD,mDAAgD;AAChD,+CAAyD;AAGzD,MAAM,YAAY,GAAG,GAAG,IAAI,CAAC,GAAG,EAAE,IAAI,OAAO,CAAC,GAAG,IAAI,IAAI,CAAC,MAAM,EAAE,CAAC,QAAQ,CAAC,EAAE,CAAC,CAAC,KAAK,CAAC,CAAC,EAAE,EAAE,CAAC,EAAE,CAAC;AAE/F,SAAS,WAAW,CAClB,MAAc,EACd,KAAmB,EACnB,KAAa,EACb,OAAe,EACf,OAAgC;IAEhC,MAAM,MAAM,GAAG,IAAA,qCAAwB,GAAE,CAAC;IAC1C,OAAO;QACL,EAAE,EAAE,IAAA,mBAAU,GAAE;QAChB,SAAS,EAAE,IAAI,IAAI,EAAE,CAAC,WAAW,EAAE;QACnC,KAAK;QACL,MAAM;QACN,KAAK;QACL,OAAO;QACP,SAAS,EAAE,OAAO,CAAC,GAAG;QACtB,KAAK,EAAE,YAAY;QACnB,OAAO,EAAE,MAAM,CAAC,MAAM,CAAC,CAAC,CAAC,IAAA,6BAAa,EAAC,OAAO,CAAC,CAAC,CAAC,CAAC,OAAO;KAC1D,CAAC;AACJ,CAAC;AAUD,SAAgB,YAAY,CAAC,MAAc,EAAE,cAAuC,EAAE;IACpF,MAAM,KAAK,GAAG,CACZ,KAAmB,EACnB,KAAa,EACb,OAAe,EACf,OAAiC,EACjC,EAAE;QACF,IAAA,sCAAwB,EACtB,WAAW,CAAC,MAAM,EAAE,KAAK,EAAE,KAAK,EAAE,OAAO,EAAE,EAAE,GAAG,WAAW,EAAE,GAAG,CAAC,OAAO,IAAI,EAAE,CAAC,EAAE,CAAC,CACnF,CAAC;IACJ,CAAC,CAAC;IAEF,OAAO;QACL,KAAK,CAAC,OAAgC;YACpC,OAAO,YAAY,CAAC,MAAM,EAAE,EAAE,GAAG,WAAW,EAAE,GAAG,OAAO,EAAE,CAAC,CAAC;QAC9D,CAAC;QACD,KAAK,CAAC,KAAK,EAAE,OAAO,EAAE,OAAO;YAC3B,KAAK,CAAC,OAAO,EAAE,KAAK,EAAE,OAAO,EAAE,OAAO,CAAC,CAAC;QAC1C,CAAC;QACD,IAAI,CAAC,KAAK,EAAE,OAAO,EAAE,OAAO;YAC1B,KAAK,CAAC,MAAM,EAAE,KAAK,EAAE,OAAO,EAAE,OAAO,CAAC,CAAC;QACzC,CAAC;QACD,IAAI,CAAC,KAAK,EAAE,OAAO,EAAE,OAAO;YAC1B,KAAK,CAAC,MAAM,EAAE,KAAK,EAAE,OAAO,EAAE,OAAO,CAAC,CAAC;QACzC,CAAC;QACD,KAAK,CAAC,KAAK,EAAE,OAAO,EAAE,OAAO;YAC3B,KAAK,CAAC,OAAO,EAAE,KAAK,EAAE,OAAO,EAAE,OAAO,CAAC,CAAC;QAC1C,CAAC;KACF,CAAC;AACJ,CAAC;AA7BD,oCA6BC"}
@@ -0,0 +1,15 @@
1
+ export declare const AGY_GEMINI_PRO_HIGH_ID = "gemini-3.1-pro-high";
2
+ export declare const AGY_GEMINI_PRO_LOW_ID = "gemini-3.1-pro-low";
3
+ export declare const AGY_GEMINI_PRO_COMPATIBILITY_IDS: Readonly<{
4
+ 'gemini-3-pro-high': string;
5
+ 'gemini-3.1-pro-high': string;
6
+ 'gemini-3-pro-low': string;
7
+ 'gemini-3.1-pro-low': string;
8
+ 'gemini-3-pro-preview': string;
9
+ 'gemini-3-pro-preview-customtools': string;
10
+ 'gemini-3.1-pro-preview': string;
11
+ 'gemini-3.1-pro-preview-customtools': string;
12
+ 'gemini-3-1-pro-preview': string;
13
+ 'gemini-3-1-pro-preview-customtools': string;
14
+ }>;
15
+ //# sourceMappingURL=agy-gemini-pro-compatibility.d.ts.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"agy-gemini-pro-compatibility.d.ts","sourceRoot":"","sources":["../../src/shared/agy-gemini-pro-compatibility.ts"],"names":[],"mappings":"AAAA,eAAO,MAAM,sBAAsB,wBAAwB,CAAC;AAC5D,eAAO,MAAM,qBAAqB,uBAAuB,CAAC;AAE1D,eAAO,MAAM,gCAAgC;;;;;;;;;;;EAWV,CAAC"}