codex-multi-auth 0.1.0

This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
Files changed (327) hide show
  1. package/LICENSE +1 -0
  2. package/README.md +162 -0
  3. package/assets/opencode-logo-ornate-dark.svg +18 -0
  4. package/assets/readme-hero.svg +31 -0
  5. package/config/README.md +87 -0
  6. package/config/minimal-opencode.json +13 -0
  7. package/config/opencode-legacy.json +571 -0
  8. package/config/opencode-modern.json +239 -0
  9. package/dist/index.d.ts +45 -0
  10. package/dist/index.d.ts.map +1 -0
  11. package/dist/index.js +3160 -0
  12. package/dist/index.js.map +1 -0
  13. package/dist/lib/accounts/rate-limits.d.ts +22 -0
  14. package/dist/lib/accounts/rate-limits.d.ts.map +1 -0
  15. package/dist/lib/accounts/rate-limits.js +63 -0
  16. package/dist/lib/accounts/rate-limits.js.map +1 -0
  17. package/dist/lib/accounts.d.ts +95 -0
  18. package/dist/lib/accounts.d.ts.map +1 -0
  19. package/dist/lib/accounts.js +668 -0
  20. package/dist/lib/accounts.js.map +1 -0
  21. package/dist/lib/audit.d.ts +45 -0
  22. package/dist/lib/audit.d.ts.map +1 -0
  23. package/dist/lib/audit.js +131 -0
  24. package/dist/lib/audit.js.map +1 -0
  25. package/dist/lib/auth/auth.d.ts +56 -0
  26. package/dist/lib/auth/auth.d.ts.map +1 -0
  27. package/dist/lib/auth/auth.js +214 -0
  28. package/dist/lib/auth/auth.js.map +1 -0
  29. package/dist/lib/auth/browser.d.ts +34 -0
  30. package/dist/lib/auth/browser.d.ts.map +1 -0
  31. package/dist/lib/auth/browser.js +185 -0
  32. package/dist/lib/auth/browser.js.map +1 -0
  33. package/dist/lib/auth/server.d.ts +24 -0
  34. package/dist/lib/auth/server.d.ts.map +1 -0
  35. package/dist/lib/auth/server.js +116 -0
  36. package/dist/lib/auth/server.js.map +1 -0
  37. package/dist/lib/auth/token-utils.d.ts +59 -0
  38. package/dist/lib/auth/token-utils.d.ts.map +1 -0
  39. package/dist/lib/auth/token-utils.js +331 -0
  40. package/dist/lib/auth/token-utils.js.map +1 -0
  41. package/dist/lib/auth-rate-limit.d.ts +20 -0
  42. package/dist/lib/auth-rate-limit.d.ts.map +1 -0
  43. package/dist/lib/auth-rate-limit.js +91 -0
  44. package/dist/lib/auth-rate-limit.js.map +1 -0
  45. package/dist/lib/auto-update-checker.d.ts +10 -0
  46. package/dist/lib/auto-update-checker.d.ts.map +1 -0
  47. package/dist/lib/auto-update-checker.js +216 -0
  48. package/dist/lib/auto-update-checker.js.map +1 -0
  49. package/dist/lib/capability-policy.d.ts +18 -0
  50. package/dist/lib/capability-policy.d.ts.map +1 -0
  51. package/dist/lib/capability-policy.js +150 -0
  52. package/dist/lib/capability-policy.js.map +1 -0
  53. package/dist/lib/circuit-breaker.d.ts +34 -0
  54. package/dist/lib/circuit-breaker.d.ts.map +1 -0
  55. package/dist/lib/circuit-breaker.js +124 -0
  56. package/dist/lib/circuit-breaker.js.map +1 -0
  57. package/dist/lib/cli.d.ts +64 -0
  58. package/dist/lib/cli.d.ts.map +1 -0
  59. package/dist/lib/cli.js +274 -0
  60. package/dist/lib/cli.js.map +1 -0
  61. package/dist/lib/codex-cli/observability.d.ts +22 -0
  62. package/dist/lib/codex-cli/observability.d.ts.map +1 -0
  63. package/dist/lib/codex-cli/observability.js +36 -0
  64. package/dist/lib/codex-cli/observability.js.map +1 -0
  65. package/dist/lib/codex-cli/state.d.ts +86 -0
  66. package/dist/lib/codex-cli/state.d.ts.map +1 -0
  67. package/dist/lib/codex-cli/state.js +470 -0
  68. package/dist/lib/codex-cli/state.js.map +1 -0
  69. package/dist/lib/codex-cli/sync.d.ts +27 -0
  70. package/dist/lib/codex-cli/sync.d.ts.map +1 -0
  71. package/dist/lib/codex-cli/sync.js +325 -0
  72. package/dist/lib/codex-cli/sync.js.map +1 -0
  73. package/dist/lib/codex-cli/writer.d.ts +12 -0
  74. package/dist/lib/codex-cli/writer.d.ts.map +1 -0
  75. package/dist/lib/codex-cli/writer.js +388 -0
  76. package/dist/lib/codex-cli/writer.js.map +1 -0
  77. package/dist/lib/codex-manager.d.ts +2 -0
  78. package/dist/lib/codex-manager.d.ts.map +1 -0
  79. package/dist/lib/codex-manager.js +4841 -0
  80. package/dist/lib/codex-manager.js.map +1 -0
  81. package/dist/lib/config.d.ts +269 -0
  82. package/dist/lib/config.d.ts.map +1 -0
  83. package/dist/lib/config.js +789 -0
  84. package/dist/lib/config.js.map +1 -0
  85. package/dist/lib/constants.d.ts +78 -0
  86. package/dist/lib/constants.d.ts.map +1 -0
  87. package/dist/lib/constants.js +78 -0
  88. package/dist/lib/constants.js.map +1 -0
  89. package/dist/lib/context-overflow.d.ts +27 -0
  90. package/dist/lib/context-overflow.d.ts.map +1 -0
  91. package/dist/lib/context-overflow.js +124 -0
  92. package/dist/lib/context-overflow.js.map +1 -0
  93. package/dist/lib/dashboard-settings.d.ts +90 -0
  94. package/dist/lib/dashboard-settings.d.ts.map +1 -0
  95. package/dist/lib/dashboard-settings.js +327 -0
  96. package/dist/lib/dashboard-settings.js.map +1 -0
  97. package/dist/lib/entitlement-cache.d.ts +41 -0
  98. package/dist/lib/entitlement-cache.d.ts.map +1 -0
  99. package/dist/lib/entitlement-cache.js +137 -0
  100. package/dist/lib/entitlement-cache.js.map +1 -0
  101. package/dist/lib/errors.d.ts +113 -0
  102. package/dist/lib/errors.d.ts.map +1 -0
  103. package/dist/lib/errors.js +103 -0
  104. package/dist/lib/errors.js.map +1 -0
  105. package/dist/lib/forecast.d.ts +42 -0
  106. package/dist/lib/forecast.d.ts.map +1 -0
  107. package/dist/lib/forecast.js +256 -0
  108. package/dist/lib/forecast.js.map +1 -0
  109. package/dist/lib/health.d.ts +33 -0
  110. package/dist/lib/health.d.ts.map +1 -0
  111. package/dist/lib/health.js +70 -0
  112. package/dist/lib/health.js.map +1 -0
  113. package/dist/lib/index.d.ts +32 -0
  114. package/dist/lib/index.d.ts.map +1 -0
  115. package/dist/lib/index.js +32 -0
  116. package/dist/lib/index.js.map +1 -0
  117. package/dist/lib/live-account-sync.d.ts +39 -0
  118. package/dist/lib/live-account-sync.d.ts.map +1 -0
  119. package/dist/lib/live-account-sync.js +196 -0
  120. package/dist/lib/live-account-sync.js.map +1 -0
  121. package/dist/lib/logger.d.ts +40 -0
  122. package/dist/lib/logger.d.ts.map +1 -0
  123. package/dist/lib/logger.js +364 -0
  124. package/dist/lib/logger.js.map +1 -0
  125. package/dist/lib/oauth-success.html +338 -0
  126. package/dist/lib/parallel-probe.d.ts +28 -0
  127. package/dist/lib/parallel-probe.d.ts.map +1 -0
  128. package/dist/lib/parallel-probe.js +97 -0
  129. package/dist/lib/parallel-probe.js.map +1 -0
  130. package/dist/lib/preemptive-quota-scheduler.d.ts +53 -0
  131. package/dist/lib/preemptive-quota-scheduler.d.ts.map +1 -0
  132. package/dist/lib/preemptive-quota-scheduler.js +220 -0
  133. package/dist/lib/preemptive-quota-scheduler.js.map +1 -0
  134. package/dist/lib/proactive-refresh.d.ts +66 -0
  135. package/dist/lib/proactive-refresh.d.ts.map +1 -0
  136. package/dist/lib/proactive-refresh.js +143 -0
  137. package/dist/lib/proactive-refresh.js.map +1 -0
  138. package/dist/lib/prompts/codex-opencode-bridge.d.ts +19 -0
  139. package/dist/lib/prompts/codex-opencode-bridge.d.ts.map +1 -0
  140. package/dist/lib/prompts/codex-opencode-bridge.js +169 -0
  141. package/dist/lib/prompts/codex-opencode-bridge.js.map +1 -0
  142. package/dist/lib/prompts/codex.d.ts +41 -0
  143. package/dist/lib/prompts/codex.d.ts.map +1 -0
  144. package/dist/lib/prompts/codex.js +383 -0
  145. package/dist/lib/prompts/codex.js.map +1 -0
  146. package/dist/lib/prompts/opencode-codex.d.ts +25 -0
  147. package/dist/lib/prompts/opencode-codex.d.ts.map +1 -0
  148. package/dist/lib/prompts/opencode-codex.js +270 -0
  149. package/dist/lib/prompts/opencode-codex.js.map +1 -0
  150. package/dist/lib/quota-cache.d.ts +68 -0
  151. package/dist/lib/quota-cache.d.ts.map +1 -0
  152. package/dist/lib/quota-cache.js +224 -0
  153. package/dist/lib/quota-cache.js.map +1 -0
  154. package/dist/lib/quota-probe.d.ts +49 -0
  155. package/dist/lib/quota-probe.d.ts.map +1 -0
  156. package/dist/lib/quota-probe.js +368 -0
  157. package/dist/lib/quota-probe.js.map +1 -0
  158. package/dist/lib/recovery/constants.d.ts +12 -0
  159. package/dist/lib/recovery/constants.d.ts.map +1 -0
  160. package/dist/lib/recovery/constants.js +31 -0
  161. package/dist/lib/recovery/constants.js.map +1 -0
  162. package/dist/lib/recovery/index.d.ts +12 -0
  163. package/dist/lib/recovery/index.d.ts.map +1 -0
  164. package/dist/lib/recovery/index.js +12 -0
  165. package/dist/lib/recovery/index.js.map +1 -0
  166. package/dist/lib/recovery/storage.d.ts +24 -0
  167. package/dist/lib/recovery/storage.d.ts.map +1 -0
  168. package/dist/lib/recovery/storage.js +362 -0
  169. package/dist/lib/recovery/storage.js.map +1 -0
  170. package/dist/lib/recovery/types.d.ts +116 -0
  171. package/dist/lib/recovery/types.d.ts.map +1 -0
  172. package/dist/lib/recovery/types.js +7 -0
  173. package/dist/lib/recovery/types.js.map +1 -0
  174. package/dist/lib/recovery.d.ts +31 -0
  175. package/dist/lib/recovery.d.ts.map +1 -0
  176. package/dist/lib/recovery.js +313 -0
  177. package/dist/lib/recovery.js.map +1 -0
  178. package/dist/lib/refresh-guardian.d.ts +31 -0
  179. package/dist/lib/refresh-guardian.d.ts.map +1 -0
  180. package/dist/lib/refresh-guardian.js +151 -0
  181. package/dist/lib/refresh-guardian.js.map +1 -0
  182. package/dist/lib/refresh-lease.d.ts +37 -0
  183. package/dist/lib/refresh-lease.d.ts.map +1 -0
  184. package/dist/lib/refresh-lease.js +335 -0
  185. package/dist/lib/refresh-lease.js.map +1 -0
  186. package/dist/lib/refresh-queue.d.ts +117 -0
  187. package/dist/lib/refresh-queue.d.ts.map +1 -0
  188. package/dist/lib/refresh-queue.js +297 -0
  189. package/dist/lib/refresh-queue.js.map +1 -0
  190. package/dist/lib/request/failure-policy.d.ts +42 -0
  191. package/dist/lib/request/failure-policy.d.ts.map +1 -0
  192. package/dist/lib/request/failure-policy.js +133 -0
  193. package/dist/lib/request/failure-policy.js.map +1 -0
  194. package/dist/lib/request/fetch-helpers.d.ts +152 -0
  195. package/dist/lib/request/fetch-helpers.d.ts.map +1 -0
  196. package/dist/lib/request/fetch-helpers.js +704 -0
  197. package/dist/lib/request/fetch-helpers.js.map +1 -0
  198. package/dist/lib/request/helpers/input-utils.d.ts +7 -0
  199. package/dist/lib/request/helpers/input-utils.d.ts.map +1 -0
  200. package/dist/lib/request/helpers/input-utils.js +214 -0
  201. package/dist/lib/request/helpers/input-utils.js.map +1 -0
  202. package/dist/lib/request/helpers/model-map.d.ts +28 -0
  203. package/dist/lib/request/helpers/model-map.d.ts.map +1 -0
  204. package/dist/lib/request/helpers/model-map.js +133 -0
  205. package/dist/lib/request/helpers/model-map.js.map +1 -0
  206. package/dist/lib/request/helpers/tool-utils.d.ts +29 -0
  207. package/dist/lib/request/helpers/tool-utils.d.ts.map +1 -0
  208. package/dist/lib/request/helpers/tool-utils.js +117 -0
  209. package/dist/lib/request/helpers/tool-utils.js.map +1 -0
  210. package/dist/lib/request/rate-limit-backoff.d.ts +17 -0
  211. package/dist/lib/request/rate-limit-backoff.d.ts.map +1 -0
  212. package/dist/lib/request/rate-limit-backoff.js +83 -0
  213. package/dist/lib/request/rate-limit-backoff.js.map +1 -0
  214. package/dist/lib/request/request-transformer.d.ts +107 -0
  215. package/dist/lib/request/request-transformer.d.ts.map +1 -0
  216. package/dist/lib/request/request-transformer.js +814 -0
  217. package/dist/lib/request/request-transformer.js.map +1 -0
  218. package/dist/lib/request/response-handler.d.ts +23 -0
  219. package/dist/lib/request/response-handler.d.ts.map +1 -0
  220. package/dist/lib/request/response-handler.js +155 -0
  221. package/dist/lib/request/response-handler.js.map +1 -0
  222. package/dist/lib/request/stream-failover.d.ts +21 -0
  223. package/dist/lib/request/stream-failover.d.ts.map +1 -0
  224. package/dist/lib/request/stream-failover.js +204 -0
  225. package/dist/lib/request/stream-failover.js.map +1 -0
  226. package/dist/lib/rotation.d.ts +146 -0
  227. package/dist/lib/rotation.d.ts.map +1 -0
  228. package/dist/lib/rotation.js +321 -0
  229. package/dist/lib/rotation.js.map +1 -0
  230. package/dist/lib/runtime-paths.d.ts +58 -0
  231. package/dist/lib/runtime-paths.d.ts.map +1 -0
  232. package/dist/lib/runtime-paths.js +164 -0
  233. package/dist/lib/runtime-paths.js.map +1 -0
  234. package/dist/lib/schemas.d.ts +435 -0
  235. package/dist/lib/schemas.d.ts.map +1 -0
  236. package/dist/lib/schemas.js +268 -0
  237. package/dist/lib/schemas.js.map +1 -0
  238. package/dist/lib/session-affinity.d.ts +23 -0
  239. package/dist/lib/session-affinity.d.ts.map +1 -0
  240. package/dist/lib/session-affinity.js +127 -0
  241. package/dist/lib/session-affinity.js.map +1 -0
  242. package/dist/lib/shutdown.d.ts +7 -0
  243. package/dist/lib/shutdown.d.ts.map +1 -0
  244. package/dist/lib/shutdown.js +43 -0
  245. package/dist/lib/shutdown.js.map +1 -0
  246. package/dist/lib/storage/migrations.d.ts +59 -0
  247. package/dist/lib/storage/migrations.d.ts.map +1 -0
  248. package/dist/lib/storage/migrations.js +41 -0
  249. package/dist/lib/storage/migrations.js.map +1 -0
  250. package/dist/lib/storage/paths.d.ts +51 -0
  251. package/dist/lib/storage/paths.d.ts.map +1 -0
  252. package/dist/lib/storage/paths.js +152 -0
  253. package/dist/lib/storage/paths.js.map +1 -0
  254. package/dist/lib/storage.d.ts +106 -0
  255. package/dist/lib/storage.d.ts.map +1 -0
  256. package/dist/lib/storage.js +896 -0
  257. package/dist/lib/storage.js.map +1 -0
  258. package/dist/lib/table-formatter.d.ts +32 -0
  259. package/dist/lib/table-formatter.d.ts.map +1 -0
  260. package/dist/lib/table-formatter.js +44 -0
  261. package/dist/lib/table-formatter.js.map +1 -0
  262. package/dist/lib/tools/hashline-tools.d.ts +51 -0
  263. package/dist/lib/tools/hashline-tools.d.ts.map +1 -0
  264. package/dist/lib/tools/hashline-tools.js +456 -0
  265. package/dist/lib/tools/hashline-tools.js.map +1 -0
  266. package/dist/lib/types.d.ts +130 -0
  267. package/dist/lib/types.d.ts.map +1 -0
  268. package/dist/lib/types.js +2 -0
  269. package/dist/lib/types.js.map +1 -0
  270. package/dist/lib/ui/ansi.d.ts +40 -0
  271. package/dist/lib/ui/ansi.d.ts.map +1 -0
  272. package/dist/lib/ui/ansi.js +68 -0
  273. package/dist/lib/ui/ansi.js.map +1 -0
  274. package/dist/lib/ui/auth-menu.d.ts +76 -0
  275. package/dist/lib/ui/auth-menu.d.ts.map +1 -0
  276. package/dist/lib/ui/auth-menu.js +590 -0
  277. package/dist/lib/ui/auth-menu.js.map +1 -0
  278. package/dist/lib/ui/confirm.d.ts +11 -0
  279. package/dist/lib/ui/confirm.d.ts.map +1 -0
  280. package/dist/lib/ui/confirm.js +29 -0
  281. package/dist/lib/ui/confirm.js.map +1 -0
  282. package/dist/lib/ui/copy.d.ts +123 -0
  283. package/dist/lib/ui/copy.d.ts.map +1 -0
  284. package/dist/lib/ui/copy.js +127 -0
  285. package/dist/lib/ui/copy.js.map +1 -0
  286. package/dist/lib/ui/format.d.ts +62 -0
  287. package/dist/lib/ui/format.d.ts.map +1 -0
  288. package/dist/lib/ui/format.js +205 -0
  289. package/dist/lib/ui/format.js.map +1 -0
  290. package/dist/lib/ui/runtime.d.ts +43 -0
  291. package/dist/lib/ui/runtime.d.ts.map +1 -0
  292. package/dist/lib/ui/runtime.js +69 -0
  293. package/dist/lib/ui/runtime.js.map +1 -0
  294. package/dist/lib/ui/select.d.ts +60 -0
  295. package/dist/lib/ui/select.d.ts.map +1 -0
  296. package/dist/lib/ui/select.js +467 -0
  297. package/dist/lib/ui/select.js.map +1 -0
  298. package/dist/lib/ui/theme.d.ts +56 -0
  299. package/dist/lib/ui/theme.d.ts.map +1 -0
  300. package/dist/lib/ui/theme.js +186 -0
  301. package/dist/lib/ui/theme.js.map +1 -0
  302. package/dist/lib/unified-settings.d.ts +71 -0
  303. package/dist/lib/unified-settings.d.ts.map +1 -0
  304. package/dist/lib/unified-settings.js +299 -0
  305. package/dist/lib/unified-settings.js.map +1 -0
  306. package/dist/lib/utils.d.ts +29 -0
  307. package/dist/lib/utils.d.ts.map +1 -0
  308. package/dist/lib/utils.js +54 -0
  309. package/dist/lib/utils.js.map +1 -0
  310. package/package.json +115 -0
  311. package/scripts/audit-dev-allowlist.js +128 -0
  312. package/scripts/bench-format/hashline-v2.mjs +642 -0
  313. package/scripts/bench-format/models.mjs +105 -0
  314. package/scripts/bench-format/opencode.mjs +205 -0
  315. package/scripts/bench-format/render.mjs +496 -0
  316. package/scripts/bench-format/stats.mjs +54 -0
  317. package/scripts/bench-format/tasks.mjs +151 -0
  318. package/scripts/benchmark-edit-formats.mjs +1161 -0
  319. package/scripts/benchmark-render-dashboard.mjs +49 -0
  320. package/scripts/codex-multi-auth.js +6 -0
  321. package/scripts/codex-routing.js +34 -0
  322. package/scripts/codex.js +122 -0
  323. package/scripts/copy-oauth-success.js +37 -0
  324. package/scripts/install-opencode-codex-auth.js +193 -0
  325. package/scripts/test-all-models.sh +7 -0
  326. package/scripts/test-model-matrix.js +424 -0
  327. package/scripts/validate-model-map.sh +7 -0
@@ -0,0 +1 @@
1
+ {"version":3,"file":"live-account-sync.d.ts","sourceRoot":"","sources":["../../lib/live-account-sync.ts"],"names":[],"mappings":"AAMA,MAAM,WAAW,sBAAsB;IACtC,UAAU,CAAC,EAAE,MAAM,CAAC;IACpB,cAAc,CAAC,EAAE,MAAM,CAAC;CACxB;AAED,MAAM,WAAW,uBAAuB;IACvC,IAAI,EAAE,MAAM,GAAG,IAAI,CAAC;IACpB,OAAO,EAAE,OAAO,CAAC;IACjB,gBAAgB,EAAE,MAAM,GAAG,IAAI,CAAC;IAChC,UAAU,EAAE,MAAM,GAAG,IAAI,CAAC;IAC1B,WAAW,EAAE,MAAM,CAAC;IACpB,UAAU,EAAE,MAAM,CAAC;CACnB;AA0CD;;;GAGG;AACH,qBAAa,eAAe;IAC3B,OAAO,CAAC,QAAQ,CAAC,MAAM,CAAsB;IAC7C,OAAO,CAAC,QAAQ,CAAC,UAAU,CAAS;IACpC,OAAO,CAAC,QAAQ,CAAC,cAAc,CAAS;IACxC,OAAO,CAAC,OAAO,CAA0B;IACzC,OAAO,CAAC,SAAS,CAA+C;IAChE,OAAO,CAAC,aAAa,CAA8C;IACnE,OAAO,CAAC,WAAW,CAAuB;IAC1C,OAAO,CAAC,OAAO,CAAS;IACxB,OAAO,CAAC,gBAAgB,CAAuB;IAC/C,OAAO,CAAC,UAAU,CAAuB;IACzC,OAAO,CAAC,WAAW,CAAK;IACxB,OAAO,CAAC,UAAU,CAAK;IACvB,OAAO,CAAC,cAAc,CAA8B;gBAExC,MAAM,EAAE,MAAM,OAAO,CAAC,IAAI,CAAC,EAAE,OAAO,GAAE,sBAA2B;IAMvE,UAAU,CAAC,IAAI,EAAE,MAAM,GAAG,OAAO,CAAC,IAAI,CAAC;IAwC7C,IAAI,IAAI,IAAI;IAgBZ,WAAW,IAAI,uBAAuB;IAWtC,OAAO,CAAC,cAAc;YAUR,QAAQ;YAiBR,SAAS;CAkCvB"}
@@ -0,0 +1,196 @@
1
+ import { promises as fs, watch as fsWatch } from "node:fs";
2
+ import { basename, dirname } from "node:path";
3
+ import { createLogger } from "./logger.js";
4
+ const log = createLogger("live-account-sync");
5
+ /**
6
+ * Convert an fs.watch filename value to a UTF-8 string or null.
7
+ *
8
+ * @param filename - The value supplied by fs.watch listeners; may be a `string`, `Buffer`, or `null`. Buffers are decoded as UTF-8.
9
+ * @returns `filename` as a UTF-8 string, or `null` when the input is `null`.
10
+ */
11
+ function normalizeFsWatchFilename(filename) {
12
+ if (filename === null)
13
+ return null;
14
+ if (typeof filename === "string")
15
+ return filename;
16
+ return filename.toString("utf-8");
17
+ }
18
+ /**
19
+ * Read the file modification time (mtime) for a given filesystem path in milliseconds.
20
+ *
21
+ * This is a point-in-time snapshot — the value may change immediately due to concurrent writes and callers
22
+ * should not assume stability across subsequent operations. On some platforms (notably Windows) timestamp
23
+ * resolution can be coarse; callers should account for that when comparing mtime values.
24
+ *
25
+ * Treat `path` as sensitive when logging: redact any tokens or secrets before emitting it.
26
+ *
27
+ * @param path - Filesystem path to inspect
28
+ * @returns The file's mtime in milliseconds, or `null` if the path does not exist or the mtime is not finite
29
+ */
30
+ async function readMtimeMs(path) {
31
+ try {
32
+ const stats = await fs.stat(path);
33
+ return Number.isFinite(stats.mtimeMs) ? stats.mtimeMs : null;
34
+ }
35
+ catch (error) {
36
+ const code = error.code;
37
+ if (code === "ENOENT" || code === "EBUSY" || code === "EACCES")
38
+ return null;
39
+ throw error;
40
+ }
41
+ }
42
+ function summarizeWatchPath(path) {
43
+ if (!path)
44
+ return "<unknown>";
45
+ return basename(path);
46
+ }
47
+ /**
48
+ * Watches account storage and triggers a reload callback when file content
49
+ * changes. Uses fs.watch + polling fallback for Windows reliability.
50
+ */
51
+ export class LiveAccountSync {
52
+ reload;
53
+ debounceMs;
54
+ pollIntervalMs;
55
+ watcher = null;
56
+ pollTimer = null;
57
+ debounceTimer = null;
58
+ currentPath = null;
59
+ running = false;
60
+ lastKnownMtimeMs = null;
61
+ lastSyncAt = null;
62
+ reloadCount = 0;
63
+ errorCount = 0;
64
+ reloadInFlight = null;
65
+ constructor(reload, options = {}) {
66
+ this.reload = reload;
67
+ this.debounceMs = Math.max(50, Math.floor(options.debounceMs ?? 250));
68
+ this.pollIntervalMs = Math.max(500, Math.floor(options.pollIntervalMs ?? 2_000));
69
+ }
70
+ async syncToPath(path) {
71
+ if (!path)
72
+ return;
73
+ if (this.currentPath === path && this.running)
74
+ return;
75
+ this.stop();
76
+ this.currentPath = path;
77
+ this.lastKnownMtimeMs = await readMtimeMs(path);
78
+ const targetDir = dirname(path);
79
+ const targetName = basename(path);
80
+ try {
81
+ this.watcher = fsWatch(targetDir, { persistent: false }, (_eventType, filename) => {
82
+ const name = normalizeFsWatchFilename(filename);
83
+ if (!name) {
84
+ this.scheduleReload("watch");
85
+ return;
86
+ }
87
+ if (name === targetName || name.startsWith(`${targetName}.`)) {
88
+ this.scheduleReload("watch");
89
+ }
90
+ });
91
+ }
92
+ catch (error) {
93
+ this.errorCount += 1;
94
+ log.warn("Failed to start fs.watch for account storage", {
95
+ path: summarizeWatchPath(path),
96
+ error: error instanceof Error ? error.message : String(error),
97
+ });
98
+ }
99
+ this.pollTimer = setInterval(() => {
100
+ void this.pollOnce();
101
+ }, this.pollIntervalMs);
102
+ if (typeof this.pollTimer === "object" && "unref" in this.pollTimer && typeof this.pollTimer.unref === "function") {
103
+ this.pollTimer.unref();
104
+ }
105
+ this.running = true;
106
+ }
107
+ stop() {
108
+ this.running = false;
109
+ if (this.watcher) {
110
+ this.watcher.close();
111
+ this.watcher = null;
112
+ }
113
+ if (this.pollTimer) {
114
+ clearInterval(this.pollTimer);
115
+ this.pollTimer = null;
116
+ }
117
+ if (this.debounceTimer) {
118
+ clearTimeout(this.debounceTimer);
119
+ this.debounceTimer = null;
120
+ }
121
+ }
122
+ getSnapshot() {
123
+ return {
124
+ path: this.currentPath,
125
+ running: this.running,
126
+ lastKnownMtimeMs: this.lastKnownMtimeMs,
127
+ lastSyncAt: this.lastSyncAt,
128
+ reloadCount: this.reloadCount,
129
+ errorCount: this.errorCount,
130
+ };
131
+ }
132
+ scheduleReload(reason) {
133
+ if (!this.running)
134
+ return;
135
+ if (this.debounceTimer) {
136
+ clearTimeout(this.debounceTimer);
137
+ }
138
+ this.debounceTimer = setTimeout(() => {
139
+ void this.runReload(reason);
140
+ }, this.debounceMs);
141
+ }
142
+ async pollOnce() {
143
+ if (!this.running || !this.currentPath)
144
+ return;
145
+ try {
146
+ const currentMtime = await readMtimeMs(this.currentPath);
147
+ if (currentMtime !== this.lastKnownMtimeMs) {
148
+ this.lastKnownMtimeMs = currentMtime;
149
+ this.scheduleReload("poll");
150
+ }
151
+ }
152
+ catch (error) {
153
+ this.errorCount += 1;
154
+ log.debug("Live account sync poll failed", {
155
+ path: summarizeWatchPath(this.currentPath),
156
+ error: error instanceof Error ? error.message : String(error),
157
+ });
158
+ }
159
+ }
160
+ async runReload(reason) {
161
+ if (!this.running || !this.currentPath)
162
+ return;
163
+ const targetPath = this.currentPath;
164
+ if (this.reloadInFlight) {
165
+ await this.reloadInFlight;
166
+ return;
167
+ }
168
+ this.reloadInFlight = (async () => {
169
+ try {
170
+ await this.reload();
171
+ this.lastSyncAt = Date.now();
172
+ this.reloadCount += 1;
173
+ this.lastKnownMtimeMs = await readMtimeMs(targetPath);
174
+ log.debug("Reloaded account manager from live storage update", {
175
+ reason,
176
+ path: summarizeWatchPath(targetPath),
177
+ });
178
+ }
179
+ catch (error) {
180
+ this.errorCount += 1;
181
+ log.warn("Live account sync reload failed", {
182
+ reason,
183
+ path: summarizeWatchPath(targetPath),
184
+ error: error instanceof Error ? error.message : String(error),
185
+ });
186
+ }
187
+ })();
188
+ try {
189
+ await this.reloadInFlight;
190
+ }
191
+ finally {
192
+ this.reloadInFlight = null;
193
+ }
194
+ }
195
+ }
196
+ //# sourceMappingURL=live-account-sync.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"live-account-sync.js","sourceRoot":"","sources":["../../lib/live-account-sync.ts"],"names":[],"mappings":"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"}
@@ -0,0 +1,40 @@
1
+ export type LogLevel = "debug" | "info" | "warn" | "error";
2
+ export interface LogClient {
3
+ app?: {
4
+ log?: (options: {
5
+ body: {
6
+ service: string;
7
+ level: LogLevel;
8
+ message: string;
9
+ extra?: Record<string, unknown>;
10
+ };
11
+ }) => unknown;
12
+ };
13
+ }
14
+ declare function maskEmail(email: string): string;
15
+ export declare const LOGGING_ENABLED: boolean;
16
+ export declare const REQUEST_BODY_LOGGING_ENABLED: boolean;
17
+ export declare const DEBUG_ENABLED: boolean;
18
+ export declare const LOG_LEVEL: LogLevel;
19
+ export declare function setCorrelationId(id?: string): string;
20
+ export declare function getCorrelationId(): string | null;
21
+ export declare function clearCorrelationId(): void;
22
+ export declare function initLogger(newClient: LogClient): void;
23
+ declare function formatDuration(ms: number): string;
24
+ export declare function logRequest(stage: string, data: Record<string, unknown>): void;
25
+ export declare function logDebug(message: string, data?: unknown): void;
26
+ export declare function logInfo(message: string, data?: unknown): void;
27
+ export declare function logWarn(message: string, data?: unknown): void;
28
+ export declare function logError(message: string, data?: unknown): void;
29
+ export interface ScopedLogger {
30
+ debug(message: string, data?: unknown): void;
31
+ info(message: string, data?: unknown): void;
32
+ warn(message: string, data?: unknown): void;
33
+ error(message: string, data?: unknown): void;
34
+ time(label: string): () => number;
35
+ timeEnd(label: string, startTime: number): void;
36
+ }
37
+ export declare function createLogger(scope: string): ScopedLogger;
38
+ export declare function getRequestId(): number;
39
+ export { formatDuration, maskEmail };
40
+ //# sourceMappingURL=logger.d.ts.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"logger.d.ts","sourceRoot":"","sources":["../../lib/logger.ts"],"names":[],"mappings":"AAMA,MAAM,MAAM,QAAQ,GAAG,OAAO,GAAG,MAAM,GAAG,MAAM,GAAG,OAAO,CAAC;AAE3D,MAAM,WAAW,SAAS;IACzB,GAAG,CAAC,EAAE;QACL,GAAG,CAAC,EAAE,CAAC,OAAO,EAAE;YACf,IAAI,EAAE;gBACL,OAAO,EAAE,MAAM,CAAC;gBAChB,KAAK,EAAE,QAAQ,CAAC;gBAChB,OAAO,EAAE,MAAM,CAAC;gBAChB,KAAK,CAAC,EAAE,MAAM,CAAC,MAAM,EAAE,OAAO,CAAC,CAAC;aAChC,CAAC;SACF,KAAK,OAAO,CAAC;KACd,CAAC;CACF;AA4CD,iBAAS,SAAS,CAAC,KAAK,EAAE,MAAM,GAAG,MAAM,CASxC;AA8CD,eAAO,MAAM,eAAe,SAAoD,CAAC;AACjF,eAAO,MAAM,4BAA4B,SAA8C,CAAC;AACxF,eAAO,MAAM,aAAa,SAA4D,CAAC;AACvF,eAAO,MAAM,SAAS,UAAoD,CAAC;AAU3E,wBAAgB,gBAAgB,CAAC,EAAE,CAAC,EAAE,MAAM,GAAG,MAAM,CAGpD;AAED,wBAAgB,gBAAgB,IAAI,MAAM,GAAG,IAAI,CAEhD;AAED,wBAAgB,kBAAkB,IAAI,IAAI,CAEzC;AAED,wBAAgB,UAAU,CAAC,SAAS,EAAE,SAAS,GAAG,IAAI,CAErD;AAsGD,iBAAS,cAAc,CAAC,EAAE,EAAE,MAAM,GAAG,MAAM,CAM1C;AA+BD,wBAAgB,UAAU,CAAC,KAAK,EAAE,MAAM,EAAE,IAAI,EAAE,MAAM,CAAC,MAAM,EAAE,OAAO,CAAC,GAAG,IAAI,CAqC7E;AAED,wBAAgB,QAAQ,CAAC,OAAO,EAAE,MAAM,EAAE,IAAI,CAAC,EAAE,OAAO,GAAG,IAAI,CAM9D;AAED,wBAAgB,OAAO,CAAC,OAAO,EAAE,MAAM,EAAE,IAAI,CAAC,EAAE,OAAO,GAAG,IAAI,CAM7D;AAED,wBAAgB,OAAO,CAAC,OAAO,EAAE,MAAM,EAAE,IAAI,CAAC,EAAE,OAAO,GAAG,IAAI,CAK7D;AAED,wBAAgB,QAAQ,CAAC,OAAO,EAAE,MAAM,EAAE,IAAI,CAAC,EAAE,OAAO,GAAG,IAAI,CAI9D;AAED,MAAM,WAAW,YAAY;IAC5B,KAAK,CAAC,OAAO,EAAE,MAAM,EAAE,IAAI,CAAC,EAAE,OAAO,GAAG,IAAI,CAAC;IAC7C,IAAI,CAAC,OAAO,EAAE,MAAM,EAAE,IAAI,CAAC,EAAE,OAAO,GAAG,IAAI,CAAC;IAC5C,IAAI,CAAC,OAAO,EAAE,MAAM,EAAE,IAAI,CAAC,EAAE,OAAO,GAAG,IAAI,CAAC;IAC5C,KAAK,CAAC,OAAO,EAAE,MAAM,EAAE,IAAI,CAAC,EAAE,OAAO,GAAG,IAAI,CAAC;IAC7C,IAAI,CAAC,KAAK,EAAE,MAAM,GAAG,MAAM,MAAM,CAAC;IAClC,OAAO,CAAC,KAAK,EAAE,MAAM,EAAE,SAAS,EAAE,MAAM,GAAG,IAAI,CAAC;CAChD;AAKD,wBAAgB,YAAY,CAAC,KAAK,EAAE,MAAM,GAAG,YAAY,CA0DxD;AAED,wBAAgB,YAAY,IAAI,MAAM,CAErC;AAED,OAAO,EAAE,cAAc,EAAE,SAAS,EAAE,CAAC"}
@@ -0,0 +1,364 @@
1
+ import { writeFileSync, mkdirSync, existsSync } from "node:fs";
2
+ import { join } from "node:path";
3
+ import { randomUUID } from "node:crypto";
4
+ import { PLUGIN_NAME } from "./constants.js";
5
+ import { getCodexLogDir } from "./runtime-paths.js";
6
+ const LOG_LEVEL_PRIORITY = {
7
+ debug: 0,
8
+ info: 1,
9
+ warn: 2,
10
+ error: 3,
11
+ };
12
+ const TOKEN_PATTERNS = [
13
+ /eyJ[A-Za-z0-9_-]+\.eyJ[A-Za-z0-9_-]+\.[A-Za-z0-9_-]+/g,
14
+ /[a-f0-9]{40,}/gi,
15
+ /sk-[A-Za-z0-9]{20,}/g,
16
+ /Bearer\s+\S+/gi,
17
+ ];
18
+ const EMAIL_PATTERN = /[a-zA-Z0-9._%+-]+@[a-zA-Z0-9.-]+\.[a-zA-Z]{2,}/g;
19
+ const SENSITIVE_KEYS = new Set([
20
+ "access",
21
+ "accesstoken",
22
+ "access_token",
23
+ "refresh",
24
+ "refreshtoken",
25
+ "refresh_token",
26
+ "token",
27
+ "authorization",
28
+ "apikey",
29
+ "api_key",
30
+ "secret",
31
+ "password",
32
+ "credential",
33
+ "id_token",
34
+ "idtoken",
35
+ "email",
36
+ "accountid",
37
+ "account_id",
38
+ ]);
39
+ function maskToken(token) {
40
+ if (token.length <= 12)
41
+ return "***MASKED***";
42
+ return `${token.slice(0, 6)}...${token.slice(-4)}`;
43
+ }
44
+ function maskEmail(email) {
45
+ const atIndex = email.indexOf("@");
46
+ if (atIndex < 0)
47
+ return "***@***";
48
+ const local = email.slice(0, atIndex);
49
+ const domain = email.slice(atIndex + 1);
50
+ const parts = domain.split(".");
51
+ const tld = parts.pop() || "";
52
+ const prefix = local.slice(0, Math.min(2, local.length));
53
+ return `${prefix}***@***.${tld}`;
54
+ }
55
+ function maskString(value) {
56
+ let result = value;
57
+ // Mask emails first (before token patterns might match parts of them)
58
+ result = result.replace(EMAIL_PATTERN, (match) => maskEmail(match));
59
+ for (const pattern of TOKEN_PATTERNS) {
60
+ result = result.replace(pattern, (match) => maskToken(match));
61
+ }
62
+ return result;
63
+ }
64
+ function sanitizeValue(value, depth = 0) {
65
+ if (depth > 10)
66
+ return "[max depth]";
67
+ if (typeof value === "string") {
68
+ return maskString(value);
69
+ }
70
+ if (Array.isArray(value)) {
71
+ return value.map((item) => sanitizeValue(item, depth + 1));
72
+ }
73
+ if (value !== null && typeof value === "object") {
74
+ const sanitized = {};
75
+ for (const [key, val] of Object.entries(value)) {
76
+ const normalizedKey = key.toLowerCase().replace(/[-_]/g, "");
77
+ if (SENSITIVE_KEYS.has(normalizedKey)) {
78
+ sanitized[key] = typeof val === "string" ? maskToken(val) : "***MASKED***";
79
+ }
80
+ else {
81
+ sanitized[key] = sanitizeValue(val, depth + 1);
82
+ }
83
+ }
84
+ return sanitized;
85
+ }
86
+ return value;
87
+ }
88
+ function parseLogLevel(value) {
89
+ if (!value)
90
+ return "info";
91
+ const normalized = value.toLowerCase().trim();
92
+ if (normalized in LOG_LEVEL_PRIORITY)
93
+ return normalized;
94
+ return "info";
95
+ }
96
+ export const LOGGING_ENABLED = process.env.ENABLE_PLUGIN_REQUEST_LOGGING === "1";
97
+ export const REQUEST_BODY_LOGGING_ENABLED = process.env.CODEX_PLUGIN_LOG_BODIES === "1";
98
+ export const DEBUG_ENABLED = process.env.DEBUG_CODEX_PLUGIN === "1" || LOGGING_ENABLED;
99
+ export const LOG_LEVEL = parseLogLevel(process.env.CODEX_PLUGIN_LOG_LEVEL);
100
+ const CONSOLE_LOG_ENABLED = process.env.CODEX_CONSOLE_LOG === "1";
101
+ const LOG_DIR = join(getCodexLogDir(), "codex-plugin");
102
+ const LOG_DIR_RETRYABLE_ERRORS = new Set(["EBUSY", "EPERM"]);
103
+ const LOG_DIR_MAX_ATTEMPTS = 3;
104
+ const LOG_DIR_RETRY_BASE_DELAY_MS = 10;
105
+ let client = null;
106
+ let currentCorrelationId = null;
107
+ export function setCorrelationId(id) {
108
+ currentCorrelationId = id ?? randomUUID();
109
+ return currentCorrelationId;
110
+ }
111
+ export function getCorrelationId() {
112
+ return currentCorrelationId;
113
+ }
114
+ export function clearCorrelationId() {
115
+ currentCorrelationId = null;
116
+ }
117
+ export function initLogger(newClient) {
118
+ client = newClient;
119
+ }
120
+ function logToApp(level, message, data, service = PLUGIN_NAME) {
121
+ const appLog = client?.app?.log;
122
+ if (!appLog)
123
+ return;
124
+ const sanitizedMessage = maskString(message).replace(/[\r\n]+/g, " ");
125
+ const sanitizedData = data === undefined ? undefined : sanitizeValue(data);
126
+ const correlationId = currentCorrelationId;
127
+ const extraData = {};
128
+ if (correlationId) {
129
+ extraData.correlationId = correlationId;
130
+ }
131
+ if (sanitizedData !== undefined) {
132
+ extraData.data = typeof sanitizedData === "object" ? sanitizedData : { value: sanitizedData };
133
+ }
134
+ const extra = Object.keys(extraData).length > 0 ? extraData : undefined;
135
+ try {
136
+ const result = appLog({
137
+ body: {
138
+ service,
139
+ level,
140
+ message: sanitizedMessage,
141
+ extra,
142
+ },
143
+ });
144
+ if (result && typeof result.catch === "function") {
145
+ result.catch(() => { });
146
+ }
147
+ }
148
+ catch {
149
+ // Ignore app log failures
150
+ }
151
+ }
152
+ function logToConsole(level, message, data) {
153
+ if (!CONSOLE_LOG_ENABLED)
154
+ return;
155
+ const sanitizedMessage = maskString(message);
156
+ const sanitizedData = data === undefined ? undefined : sanitizeValue(data);
157
+ if (sanitizedData !== undefined) {
158
+ if (level === "warn")
159
+ console.warn(sanitizedMessage, sanitizedData);
160
+ else if (level === "error")
161
+ console.error(sanitizedMessage, sanitizedData);
162
+ else
163
+ console.log(sanitizedMessage, sanitizedData);
164
+ return;
165
+ }
166
+ if (level === "warn")
167
+ console.warn(sanitizedMessage);
168
+ else if (level === "error")
169
+ console.error(sanitizedMessage);
170
+ else
171
+ console.log(sanitizedMessage);
172
+ }
173
+ if (LOGGING_ENABLED) {
174
+ logToConsole("info", REQUEST_BODY_LOGGING_ENABLED
175
+ ? `[${PLUGIN_NAME}] Request logging ENABLED (raw payload capture ON) - logs will be saved to: ${LOG_DIR}`
176
+ : `[${PLUGIN_NAME}] Request logging ENABLED (metadata only; set CODEX_PLUGIN_LOG_BODIES=1 for raw payloads) - logs will be saved to: ${LOG_DIR}`);
177
+ }
178
+ if (DEBUG_ENABLED && !LOGGING_ENABLED) {
179
+ logToConsole("info", `[${PLUGIN_NAME}] Debug logging ENABLED (level: ${LOG_LEVEL})`);
180
+ }
181
+ let requestCounter = 0;
182
+ function sanitizeRequestLogData(data) {
183
+ if (REQUEST_BODY_LOGGING_ENABLED) {
184
+ return data;
185
+ }
186
+ let omittedPayloads = false;
187
+ const sanitized = {};
188
+ for (const [key, value] of Object.entries(data)) {
189
+ const normalizedKey = key.toLowerCase().replace(/[-_]/g, "");
190
+ if (normalizedKey === "body" || normalizedKey === "fullcontent") {
191
+ omittedPayloads = true;
192
+ continue;
193
+ }
194
+ sanitized[key] = value;
195
+ }
196
+ if (omittedPayloads) {
197
+ sanitized.payloadsOmitted = true;
198
+ }
199
+ return sanitized;
200
+ }
201
+ function shouldLog(level) {
202
+ if (level === "error")
203
+ return true;
204
+ if (!DEBUG_ENABLED && !LOGGING_ENABLED)
205
+ return false;
206
+ return LOG_LEVEL_PRIORITY[level] >= LOG_LEVEL_PRIORITY[LOG_LEVEL];
207
+ }
208
+ function formatDuration(ms) {
209
+ if (ms < 1000)
210
+ return `${Math.round(ms)}ms`;
211
+ if (ms < 60000)
212
+ return `${(ms / 1000).toFixed(2)}s`;
213
+ const minutes = Math.floor(ms / 60000);
214
+ const seconds = ((ms % 60000) / 1000).toFixed(1);
215
+ return `${minutes}m ${seconds}s`;
216
+ }
217
+ function ensureLogDir(path) {
218
+ for (let attempt = 0; attempt < LOG_DIR_MAX_ATTEMPTS; attempt += 1) {
219
+ try {
220
+ if (!existsSync(path)) {
221
+ mkdirSync(path, { recursive: true, mode: 0o700 });
222
+ }
223
+ return true;
224
+ }
225
+ catch (error) {
226
+ const code = error.code ?? "";
227
+ const canRetry = LOG_DIR_RETRYABLE_ERRORS.has(code);
228
+ if (canRetry && attempt + 1 < LOG_DIR_MAX_ATTEMPTS) {
229
+ Atomics.wait(new Int32Array(new SharedArrayBuffer(4)), 0, 0, LOG_DIR_RETRY_BASE_DELAY_MS * 2 ** attempt);
230
+ continue;
231
+ }
232
+ logToConsole("warn", `[${PLUGIN_NAME}] Failed to ensure log directory`, {
233
+ path,
234
+ error: error instanceof Error ? error.message : String(error),
235
+ });
236
+ return false;
237
+ }
238
+ }
239
+ return false;
240
+ }
241
+ export function logRequest(stage, data) {
242
+ if (!LOGGING_ENABLED)
243
+ return;
244
+ if (!ensureLogDir(LOG_DIR)) {
245
+ return;
246
+ }
247
+ const timestamp = new Date().toISOString();
248
+ const requestId = ++requestCounter;
249
+ const correlationId = currentCorrelationId;
250
+ const filename = join(LOG_DIR, `request-${requestId}-${stage}.json`);
251
+ const requestData = sanitizeRequestLogData(data);
252
+ const sanitizedData = sanitizeValue(requestData);
253
+ try {
254
+ writeFileSync(filename, JSON.stringify({
255
+ timestamp,
256
+ requestId,
257
+ ...(correlationId ? { correlationId } : {}),
258
+ stage,
259
+ ...sanitizedData,
260
+ }, null, 2), { encoding: "utf8", mode: 0o600 });
261
+ logToApp("info", `Logged ${stage} to ${filename}`);
262
+ logToConsole("info", `[${PLUGIN_NAME}] Logged ${stage} to ${filename}`);
263
+ }
264
+ catch (e) {
265
+ const error = e;
266
+ logToApp("error", `Failed to write log: ${error.message}`);
267
+ logToConsole("error", `[${PLUGIN_NAME}] Failed to write log: ${error.message}`);
268
+ }
269
+ }
270
+ export function logDebug(message, data) {
271
+ if (!shouldLog("debug"))
272
+ return;
273
+ logToApp("debug", message, data);
274
+ const text = `[${PLUGIN_NAME}] ${message}`;
275
+ logToConsole("debug", text, data);
276
+ }
277
+ export function logInfo(message, data) {
278
+ if (!shouldLog("info"))
279
+ return;
280
+ logToApp("info", message, data);
281
+ const text = `[${PLUGIN_NAME}] ${message}`;
282
+ logToConsole("info", text, data);
283
+ }
284
+ export function logWarn(message, data) {
285
+ if (!shouldLog("warn"))
286
+ return;
287
+ logToApp("warn", message, data);
288
+ const text = `[${PLUGIN_NAME}] ${message}`;
289
+ logToConsole("warn", text, data);
290
+ }
291
+ export function logError(message, data) {
292
+ logToApp("error", message, data);
293
+ const text = `[${PLUGIN_NAME}] ${message}`;
294
+ logToConsole("error", text, data);
295
+ }
296
+ const MAX_TIMERS = 100;
297
+ const timers = new Map();
298
+ export function createLogger(scope) {
299
+ const prefix = `[${PLUGIN_NAME}:${scope}]`;
300
+ const service = `${PLUGIN_NAME}.${scope}`;
301
+ return {
302
+ debug(message, data) {
303
+ if (!shouldLog("debug"))
304
+ return;
305
+ const text = `${prefix} ${message}`;
306
+ logToApp("debug", text, data, service);
307
+ logToConsole("debug", text, data);
308
+ },
309
+ info(message, data) {
310
+ if (!shouldLog("info"))
311
+ return;
312
+ const text = `${prefix} ${message}`;
313
+ logToApp("info", text, data, service);
314
+ logToConsole("info", text, data);
315
+ },
316
+ warn(message, data) {
317
+ if (!shouldLog("warn"))
318
+ return;
319
+ const text = `${prefix} ${message}`;
320
+ logToApp("warn", text, data, service);
321
+ logToConsole("warn", text, data);
322
+ },
323
+ error(message, data) {
324
+ const text = `${prefix} ${message}`;
325
+ logToApp("error", text, data, service);
326
+ logToConsole("error", text, data);
327
+ },
328
+ time(label) {
329
+ const key = `${scope}:${label}`;
330
+ const startTime = performance.now();
331
+ if (timers.size >= MAX_TIMERS) {
332
+ const firstKey = timers.keys().next().value;
333
+ // istanbul ignore next -- defensive: firstKey always exists when size >= MAX_TIMERS
334
+ if (firstKey)
335
+ timers.delete(firstKey);
336
+ }
337
+ timers.set(key, startTime);
338
+ return () => {
339
+ const endTime = performance.now();
340
+ const duration = endTime - startTime;
341
+ timers.delete(key);
342
+ if (shouldLog("debug")) {
343
+ const text = `${prefix} ${label}: ${formatDuration(duration)}`;
344
+ logToApp("debug", text, undefined, service);
345
+ logToConsole("debug", text);
346
+ }
347
+ return duration;
348
+ };
349
+ },
350
+ timeEnd(label, startTime) {
351
+ const duration = performance.now() - startTime;
352
+ if (shouldLog("debug")) {
353
+ const text = `${prefix} ${label}: ${formatDuration(duration)}`;
354
+ logToApp("debug", text, undefined, service);
355
+ logToConsole("debug", text);
356
+ }
357
+ },
358
+ };
359
+ }
360
+ export function getRequestId() {
361
+ return requestCounter;
362
+ }
363
+ export { formatDuration, maskEmail };
364
+ //# sourceMappingURL=logger.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"logger.js","sourceRoot":"","sources":["../../lib/logger.ts"],"names":[],"mappings":"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"}