@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.
- package/README.md +3 -1
- package/dist/api/services/index.d.ts +1 -0
- package/dist/api/services/index.d.ts.map +1 -1
- package/dist/api/services/index.js +3 -1
- package/dist/api/services/index.js.map +1 -1
- package/dist/api/services/local-runtime-readiness.d.ts +14 -0
- package/dist/api/services/local-runtime-readiness.d.ts.map +1 -0
- package/dist/api/services/local-runtime-readiness.js +89 -0
- package/dist/api/services/local-runtime-readiness.js.map +1 -0
- package/dist/ccs.js +68 -35
- package/dist/ccs.js.map +1 -1
- package/dist/cliproxy/accounts/types.d.ts +1 -1
- package/dist/cliproxy/accounts/types.d.ts.map +1 -1
- package/dist/cliproxy/auth/auth-types.d.ts +29 -6
- package/dist/cliproxy/auth/auth-types.d.ts.map +1 -1
- package/dist/cliproxy/auth/auth-types.js +58 -10
- package/dist/cliproxy/auth/auth-types.js.map +1 -1
- package/dist/cliproxy/auth/oauth-handler.d.ts +6 -1
- package/dist/cliproxy/auth/oauth-handler.d.ts.map +1 -1
- package/dist/cliproxy/auth/oauth-handler.js +165 -45
- package/dist/cliproxy/auth/oauth-handler.js.map +1 -1
- package/dist/cliproxy/auth/oauth-process.d.ts +26 -1
- package/dist/cliproxy/auth/oauth-process.d.ts.map +1 -1
- package/dist/cliproxy/auth/oauth-process.js +314 -49
- package/dist/cliproxy/auth/oauth-process.js.map +1 -1
- package/dist/cliproxy/auth/token-manager.d.ts +9 -0
- package/dist/cliproxy/auth/token-manager.d.ts.map +1 -1
- package/dist/cliproxy/auth/token-manager.js +104 -58
- package/dist/cliproxy/auth/token-manager.js.map +1 -1
- package/dist/cliproxy/auth-utils.d.ts +2 -1
- package/dist/cliproxy/auth-utils.d.ts.map +1 -1
- package/dist/cliproxy/auth-utils.js +32 -7
- package/dist/cliproxy/auth-utils.js.map +1 -1
- package/dist/cliproxy/catalog-cache.d.ts +9 -1
- package/dist/cliproxy/catalog-cache.d.ts.map +1 -1
- package/dist/cliproxy/catalog-cache.js +115 -29
- package/dist/cliproxy/catalog-cache.js.map +1 -1
- package/dist/cliproxy/catalog-routing.d.ts +12 -0
- package/dist/cliproxy/catalog-routing.d.ts.map +1 -0
- package/dist/cliproxy/catalog-routing.js +19 -0
- package/dist/cliproxy/catalog-routing.js.map +1 -0
- package/dist/cliproxy/codex-plan-compatibility.d.ts +0 -1
- package/dist/cliproxy/codex-plan-compatibility.d.ts.map +1 -1
- package/dist/cliproxy/codex-plan-compatibility.js +3 -7
- package/dist/cliproxy/codex-plan-compatibility.js.map +1 -1
- package/dist/cliproxy/config/generator.d.ts +2 -1
- package/dist/cliproxy/config/generator.d.ts.map +1 -1
- package/dist/cliproxy/config/generator.js +11 -1
- package/dist/cliproxy/config/generator.js.map +1 -1
- package/dist/cliproxy/executor/index.d.ts +5 -0
- package/dist/cliproxy/executor/index.d.ts.map +1 -1
- package/dist/cliproxy/executor/index.js +119 -16
- package/dist/cliproxy/executor/index.js.map +1 -1
- package/dist/cliproxy/gemini-cli-quota-normalizer.js +1 -1
- package/dist/cliproxy/gemini-cli-quota-normalizer.js.map +1 -1
- package/dist/cliproxy/index.d.ts +1 -1
- package/dist/cliproxy/index.d.ts.map +1 -1
- package/dist/cliproxy/index.js.map +1 -1
- package/dist/cliproxy/managed-model-prefixes.d.ts +7 -0
- package/dist/cliproxy/managed-model-prefixes.d.ts.map +1 -0
- package/dist/cliproxy/managed-model-prefixes.js +116 -0
- package/dist/cliproxy/managed-model-prefixes.js.map +1 -0
- package/dist/cliproxy/management-api-client.d.ts +9 -0
- package/dist/cliproxy/management-api-client.d.ts.map +1 -1
- package/dist/cliproxy/management-api-client.js +14 -0
- package/dist/cliproxy/management-api-client.js.map +1 -1
- package/dist/cliproxy/model-catalog.d.ts.map +1 -1
- package/dist/cliproxy/model-catalog.js +19 -4
- package/dist/cliproxy/model-catalog.js.map +1 -1
- package/dist/cliproxy/provider-entitlement-evidence.d.ts +17 -0
- package/dist/cliproxy/provider-entitlement-evidence.d.ts.map +1 -0
- package/dist/cliproxy/provider-entitlement-evidence.js +55 -0
- package/dist/cliproxy/provider-entitlement-evidence.js.map +1 -0
- package/dist/cliproxy/provider-entitlement-types.d.ts +16 -0
- package/dist/cliproxy/provider-entitlement-types.d.ts.map +1 -0
- package/dist/cliproxy/provider-entitlement-types.js +3 -0
- package/dist/cliproxy/provider-entitlement-types.js.map +1 -0
- package/dist/cliproxy/proxy-detector.d.ts.map +1 -1
- package/dist/cliproxy/proxy-detector.js +6 -2
- package/dist/cliproxy/proxy-detector.js.map +1 -1
- package/dist/cliproxy/quota-fetcher-gemini-cli.d.ts.map +1 -1
- package/dist/cliproxy/quota-fetcher-gemini-cli.js +64 -19
- package/dist/cliproxy/quota-fetcher-gemini-cli.js.map +1 -1
- package/dist/cliproxy/quota-fetcher.d.ts +10 -0
- package/dist/cliproxy/quota-fetcher.d.ts.map +1 -1
- package/dist/cliproxy/quota-fetcher.js +116 -21
- package/dist/cliproxy/quota-fetcher.js.map +1 -1
- package/dist/cliproxy/quota-types.d.ts +3 -0
- package/dist/cliproxy/quota-types.d.ts.map +1 -1
- package/dist/cliproxy/routing-strategy-http.d.ts +6 -0
- package/dist/cliproxy/routing-strategy-http.d.ts.map +1 -0
- package/dist/cliproxy/routing-strategy-http.js +115 -0
- package/dist/cliproxy/routing-strategy-http.js.map +1 -0
- package/dist/cliproxy/routing-strategy.d.ts +18 -0
- package/dist/cliproxy/routing-strategy.d.ts.map +1 -0
- package/dist/cliproxy/routing-strategy.js +123 -0
- package/dist/cliproxy/routing-strategy.js.map +1 -0
- package/dist/cliproxy/services/variant-settings.d.ts.map +1 -1
- package/dist/cliproxy/services/variant-settings.js +43 -30
- package/dist/cliproxy/services/variant-settings.js.map +1 -1
- package/dist/cliproxy/startup-lock.d.ts.map +1 -1
- package/dist/cliproxy/startup-lock.js +5 -1
- package/dist/cliproxy/startup-lock.js.map +1 -1
- package/dist/cliproxy/tool-sanitization-proxy.d.ts +1 -0
- package/dist/cliproxy/tool-sanitization-proxy.d.ts.map +1 -1
- package/dist/cliproxy/tool-sanitization-proxy.js +6 -0
- package/dist/cliproxy/tool-sanitization-proxy.js.map +1 -1
- package/dist/cliproxy/types.d.ts +7 -0
- package/dist/cliproxy/types.d.ts.map +1 -1
- package/dist/cliproxy/types.js.map +1 -1
- package/dist/commands/api-command/create-command.d.ts +3 -0
- package/dist/commands/api-command/create-command.d.ts.map +1 -1
- package/dist/commands/api-command/create-command.js +20 -6
- package/dist/commands/api-command/create-command.js.map +1 -1
- package/dist/commands/api-command/help.d.ts.map +1 -1
- package/dist/commands/api-command/help.js +1 -0
- package/dist/commands/api-command/help.js.map +1 -1
- package/dist/commands/cleanup-command.d.ts +1 -1
- package/dist/commands/cleanup-command.d.ts.map +1 -1
- package/dist/commands/cleanup-command.js +57 -34
- package/dist/commands/cleanup-command.js.map +1 -1
- package/dist/commands/cliproxy/catalog-subcommand.d.ts.map +1 -1
- package/dist/commands/cliproxy/catalog-subcommand.js +72 -44
- package/dist/commands/cliproxy/catalog-subcommand.js.map +1 -1
- package/dist/commands/cliproxy/help-subcommand.d.ts.map +1 -1
- package/dist/commands/cliproxy/help-subcommand.js +6 -2
- package/dist/commands/cliproxy/help-subcommand.js.map +1 -1
- package/dist/commands/cliproxy/index.d.ts.map +1 -1
- package/dist/commands/cliproxy/index.js +14 -0
- package/dist/commands/cliproxy/index.js.map +1 -1
- package/dist/commands/cliproxy/quota-subcommand.d.ts +2 -0
- package/dist/commands/cliproxy/quota-subcommand.d.ts.map +1 -1
- package/dist/commands/cliproxy/quota-subcommand.js +8 -1
- package/dist/commands/cliproxy/quota-subcommand.js.map +1 -1
- package/dist/commands/cliproxy/routing-subcommand.d.ts +4 -0
- package/dist/commands/cliproxy/routing-subcommand.d.ts.map +1 -0
- package/dist/commands/cliproxy/routing-subcommand.js +68 -0
- package/dist/commands/cliproxy/routing-subcommand.js.map +1 -0
- package/dist/commands/cliproxy/variant-subcommand.d.ts.map +1 -1
- package/dist/commands/cliproxy/variant-subcommand.js +44 -3
- package/dist/commands/cliproxy/variant-subcommand.js.map +1 -1
- package/dist/commands/command-catalog.d.ts +2 -2
- package/dist/commands/command-catalog.d.ts.map +1 -1
- package/dist/commands/command-catalog.js +3 -1
- package/dist/commands/command-catalog.js.map +1 -1
- package/dist/commands/completion-backend.d.ts.map +1 -1
- package/dist/commands/completion-backend.js +15 -1
- package/dist/commands/completion-backend.js.map +1 -1
- package/dist/commands/config-command.d.ts.map +1 -1
- package/dist/commands/config-command.js +23 -0
- package/dist/commands/config-command.js.map +1 -1
- package/dist/commands/docker/up-subcommand.js +1 -1
- package/dist/commands/docker/up-subcommand.js.map +1 -1
- package/dist/commands/help-command.d.ts.map +1 -1
- package/dist/commands/help-command.js +62 -1
- package/dist/commands/help-command.js.map +1 -1
- package/dist/commands/update-command.d.ts +20 -5
- package/dist/commands/update-command.d.ts.map +1 -1
- package/dist/commands/update-command.js +169 -119
- package/dist/commands/update-command.js.map +1 -1
- package/dist/config/unified-config-loader.d.ts +2 -1
- package/dist/config/unified-config-loader.d.ts.map +1 -1
- package/dist/config/unified-config-loader.js +37 -1
- package/dist/config/unified-config-loader.js.map +1 -1
- package/dist/config/unified-config-types.d.ts +29 -1
- package/dist/config/unified-config-types.d.ts.map +1 -1
- package/dist/config/unified-config-types.js +13 -1
- package/dist/config/unified-config-types.js.map +1 -1
- package/dist/copilot/copilot-executor.d.ts.map +1 -1
- package/dist/copilot/copilot-executor.js +5 -8
- package/dist/copilot/copilot-executor.js.map +1 -1
- package/dist/delegation/headless-executor.d.ts.map +1 -1
- package/dist/delegation/headless-executor.js +19 -16
- package/dist/delegation/headless-executor.js.map +1 -1
- package/dist/errors/error-handler.d.ts.map +1 -1
- package/dist/errors/error-handler.js +13 -0
- package/dist/errors/error-handler.js.map +1 -1
- package/dist/glmt/glmt-transformer.d.ts +1 -0
- package/dist/glmt/glmt-transformer.d.ts.map +1 -1
- package/dist/glmt/glmt-transformer.js +9 -0
- package/dist/glmt/glmt-transformer.js.map +1 -1
- package/dist/management/checks/image-analysis-check.d.ts.map +1 -1
- package/dist/management/checks/image-analysis-check.js +19 -1
- package/dist/management/checks/image-analysis-check.js.map +1 -1
- package/dist/management/recovery-manager.d.ts +6 -0
- package/dist/management/recovery-manager.d.ts.map +1 -1
- package/dist/management/recovery-manager.js +72 -2
- package/dist/management/recovery-manager.js.map +1 -1
- package/dist/services/logging/index.d.ts +7 -0
- package/dist/services/logging/index.d.ts.map +1 -0
- package/dist/services/logging/index.js +22 -0
- package/dist/services/logging/index.js.map +1 -0
- package/dist/services/logging/log-buffer.d.ts +5 -0
- package/dist/services/logging/log-buffer.d.ts.map +1 -0
- package/dist/services/logging/log-buffer.js +20 -0
- package/dist/services/logging/log-buffer.js.map +1 -0
- package/dist/services/logging/log-config.d.ts +4 -0
- package/dist/services/logging/log-config.d.ts.map +1 -0
- package/dist/services/logging/log-config.js +68 -0
- package/dist/services/logging/log-config.js.map +1 -0
- package/dist/services/logging/log-paths.d.ts +8 -0
- package/dist/services/logging/log-paths.d.ts.map +1 -0
- package/dist/services/logging/log-paths.js +66 -0
- package/dist/services/logging/log-paths.js.map +1 -0
- package/dist/services/logging/log-reader.d.ts +5 -0
- package/dist/services/logging/log-reader.d.ts.map +1 -0
- package/dist/services/logging/log-reader.js +124 -0
- package/dist/services/logging/log-reader.js.map +1 -0
- package/dist/services/logging/log-redaction.d.ts +2 -0
- package/dist/services/logging/log-redaction.d.ts.map +1 -0
- package/dist/services/logging/log-redaction.js +53 -0
- package/dist/services/logging/log-redaction.js.map +1 -0
- package/dist/services/logging/log-storage.d.ts +4 -0
- package/dist/services/logging/log-storage.d.ts.map +1 -0
- package/dist/services/logging/log-storage.js +109 -0
- package/dist/services/logging/log-storage.js.map +1 -0
- package/dist/services/logging/log-types.d.ts +30 -0
- package/dist/services/logging/log-types.d.ts.map +1 -0
- package/dist/services/logging/log-types.js +19 -0
- package/dist/services/logging/log-types.js.map +1 -0
- package/dist/services/logging/logger.d.ts +9 -0
- package/dist/services/logging/logger.d.ts.map +1 -0
- package/dist/services/logging/logger.js +46 -0
- package/dist/services/logging/logger.js.map +1 -0
- package/dist/shared/agy-gemini-pro-compatibility.d.ts +15 -0
- package/dist/shared/agy-gemini-pro-compatibility.d.ts.map +1 -0
- package/dist/shared/agy-gemini-pro-compatibility.js +18 -0
- package/dist/shared/agy-gemini-pro-compatibility.js.map +1 -0
- package/dist/shared/cliproxy-model-routing.d.ts +45 -0
- package/dist/shared/cliproxy-model-routing.d.ts.map +1 -0
- package/dist/shared/cliproxy-model-routing.js +144 -0
- package/dist/shared/cliproxy-model-routing.js.map +1 -0
- package/dist/shared/provider-preset-catalog.d.ts +3 -1
- package/dist/shared/provider-preset-catalog.d.ts.map +1 -1
- package/dist/shared/provider-preset-catalog.js +16 -0
- package/dist/shared/provider-preset-catalog.js.map +1 -1
- package/dist/ui/assets/{accounts-BjfPKR8m.js → accounts-DjL3iVZW.js} +1 -1
- package/dist/ui/assets/{alert-dialog-Dh2NUFdm.js → alert-dialog-Tc_D1a_B.js} +1 -1
- package/dist/ui/assets/api-CUtkvXmX.js +4 -0
- package/dist/ui/assets/{auth-section-Dp10_YyD.js → auth-section-CuKWQHC7.js} +1 -1
- package/dist/ui/assets/{backups-section-C0jF8MP1.js → backups-section-BKW2pbb9.js} +1 -1
- package/dist/ui/assets/{channels-CkXuK5i7.js → channels-DvWJMdaq.js} +1 -1
- package/dist/ui/assets/{checkbox-tA5FH8Ol.js → checkbox-B0hZxMK5.js} +1 -1
- package/dist/ui/assets/{claude-extension-Bg2ZkzMz.js → claude-extension-Dfqu-rev.js} +1 -1
- package/dist/ui/assets/cliproxy-C9RxW-I8.js +3 -0
- package/dist/ui/assets/cliproxy-ai-providers-BXLuuxNf.js +15 -0
- package/dist/ui/assets/{cliproxy-control-panel-Da-sGGyI.js → cliproxy-control-panel-aQ7cCc2U.js} +1 -1
- package/dist/ui/assets/{codex-ooWKOPa2.js → codex-aq4RI6_n.js} +9 -9
- package/dist/ui/assets/{confirm-dialog-CKjwhn9j.js → confirm-dialog-CpDk6eu4.js} +1 -1
- package/dist/ui/assets/{copilot-GA7EPiK1.js → copilot-CQRpGXvY.js} +2 -2
- package/dist/ui/assets/{cursor-B6c8CyHG.js → cursor-BpXPf6qi.js} +1 -1
- package/dist/ui/assets/{droid-CPRHOIX2.js → droid-Cgx-yLjy.js} +2 -2
- package/dist/ui/assets/{globalenv-section-Czgnw_GV.js → globalenv-section-DsNqG1yB.js} +1 -1
- package/dist/ui/assets/{health-CXLOMk8n.js → health-BY-O-JcA.js} +1 -1
- package/dist/ui/assets/icons-KVCk4_U8.js +1 -0
- package/dist/ui/assets/index-BmSzf0T9.js +72 -0
- package/dist/ui/assets/index-CLGiPB3A.js +1 -0
- package/dist/ui/assets/{index-CvfzKRSH.js → index-Cet36v1V.js} +1 -1
- package/dist/ui/assets/{index-Boa5e-GY.js → index-DH6L6ybH.js} +1 -1
- package/dist/ui/assets/{index-BceMcbCR.js → index-DsCjnpco.js} +1 -1
- package/dist/ui/assets/{index-D2v_-6AW.js → index-TQFuDZdB.js} +1 -1
- package/dist/ui/assets/index-teLjoh2T.css +1 -0
- package/dist/ui/assets/logs-D5ro-pc7.js +1 -0
- package/dist/ui/assets/{masked-input-B1_asiUI.js → masked-input-h0XkMSwB.js} +1 -1
- package/dist/ui/assets/proxy-status-widget-yBdrFeb7.js +1 -0
- package/dist/ui/assets/{raw-json-settings-editor-panel-DMbTkxWw.js → raw-json-settings-editor-panel-Cb7ZInQV.js} +1 -1
- package/dist/ui/assets/searchable-select-D4xr5xKS.js +1 -0
- package/dist/ui/assets/{separator-CdaalG0K.js → separator-gw5BjIpP.js} +1 -1
- package/dist/ui/assets/{shared-BiFB-et0.js → shared-C-VeA1Z9.js} +1 -1
- package/dist/ui/assets/{table-BPwgFXLQ.js → table-Bd4isC18.js} +1 -1
- package/dist/ui/assets/{tanstack-DWm6aJ-G.js → tanstack-CrmUhA7Z.js} +2 -2
- package/dist/ui/assets/updates-DiK8I67C.js +1 -0
- package/dist/ui/index.html +4 -4
- package/dist/utils/hooks/image-analysis-runtime-status.d.ts.map +1 -1
- package/dist/utils/hooks/image-analysis-runtime-status.js +5 -1
- package/dist/utils/hooks/image-analysis-runtime-status.js.map +1 -1
- package/dist/utils/hooks/image-analyzer-hook-utils.d.ts +21 -0
- package/dist/utils/hooks/image-analyzer-hook-utils.d.ts.map +1 -0
- package/dist/utils/hooks/image-analyzer-hook-utils.js +81 -0
- package/dist/utils/hooks/image-analyzer-hook-utils.js.map +1 -0
- package/dist/utils/hooks/image-analyzer-profile-hook-injector.d.ts +1 -0
- package/dist/utils/hooks/image-analyzer-profile-hook-injector.d.ts.map +1 -1
- package/dist/utils/hooks/image-analyzer-profile-hook-injector.js +33 -12
- package/dist/utils/hooks/image-analyzer-profile-hook-injector.js.map +1 -1
- package/dist/utils/hooks/index.d.ts +1 -0
- package/dist/utils/hooks/index.d.ts.map +1 -1
- package/dist/utils/hooks/index.js +3 -1
- package/dist/utils/hooks/index.js.map +1 -1
- package/dist/utils/image-analysis/index.d.ts +1 -0
- package/dist/utils/image-analysis/index.d.ts.map +1 -1
- package/dist/utils/image-analysis/index.js +6 -1
- package/dist/utils/image-analysis/index.js.map +1 -1
- package/dist/utils/image-analysis/repair.d.ts +12 -0
- package/dist/utils/image-analysis/repair.d.ts.map +1 -0
- package/dist/utils/image-analysis/repair.js +105 -0
- package/dist/utils/image-analysis/repair.js.map +1 -0
- package/dist/utils/package-manager-detector.d.ts +30 -4
- package/dist/utils/package-manager-detector.d.ts.map +1 -1
- package/dist/utils/package-manager-detector.js +247 -60
- package/dist/utils/package-manager-detector.js.map +1 -1
- package/dist/utils/update-checker.d.ts +1 -1
- package/dist/utils/update-checker.d.ts.map +1 -1
- package/dist/utils/websearch/trace.d.ts.map +1 -1
- package/dist/utils/websearch/trace.js +7 -0
- package/dist/utils/websearch/trace.js.map +1 -1
- package/dist/web-server/index.d.ts.map +1 -1
- package/dist/web-server/index.js +24 -0
- package/dist/web-server/index.js.map +1 -1
- package/dist/web-server/middleware/request-logging-middleware.d.ts +3 -0
- package/dist/web-server/middleware/request-logging-middleware.d.ts.map +1 -0
- package/dist/web-server/middleware/request-logging-middleware.js +30 -0
- package/dist/web-server/middleware/request-logging-middleware.js.map +1 -0
- package/dist/web-server/routes/auth-routes.d.ts +10 -0
- package/dist/web-server/routes/auth-routes.d.ts.map +1 -1
- package/dist/web-server/routes/auth-routes.js +33 -6
- package/dist/web-server/routes/auth-routes.js.map +1 -1
- package/dist/web-server/routes/catalog-routes.d.ts.map +1 -1
- package/dist/web-server/routes/catalog-routes.js +9 -8
- package/dist/web-server/routes/catalog-routes.js.map +1 -1
- package/dist/web-server/routes/cliproxy-auth-routes.d.ts +8 -0
- package/dist/web-server/routes/cliproxy-auth-routes.d.ts.map +1 -1
- package/dist/web-server/routes/cliproxy-auth-routes.js +86 -76
- package/dist/web-server/routes/cliproxy-auth-routes.js.map +1 -1
- package/dist/web-server/routes/cliproxy-routing-routes.d.ts +3 -0
- package/dist/web-server/routes/cliproxy-routing-routes.d.ts.map +1 -0
- package/dist/web-server/routes/cliproxy-routing-routes.js +34 -0
- package/dist/web-server/routes/cliproxy-routing-routes.js.map +1 -0
- package/dist/web-server/routes/image-analysis-routes.d.ts.map +1 -1
- package/dist/web-server/routes/image-analysis-routes.js +1 -10
- package/dist/web-server/routes/image-analysis-routes.js.map +1 -1
- package/dist/web-server/routes/index.d.ts.map +1 -1
- package/dist/web-server/routes/index.js +22 -0
- package/dist/web-server/routes/index.js.map +1 -1
- package/dist/web-server/routes/logs-routes.d.ts +3 -0
- package/dist/web-server/routes/logs-routes.d.ts.map +1 -0
- package/dist/web-server/routes/logs-routes.js +75 -0
- package/dist/web-server/routes/logs-routes.js.map +1 -0
- package/dist/web-server/routes/profile-routes.d.ts.map +1 -1
- package/dist/web-server/routes/profile-routes.js +8 -0
- package/dist/web-server/routes/profile-routes.js.map +1 -1
- package/dist/web-server/routes/settings-routes.d.ts.map +1 -1
- package/dist/web-server/routes/settings-routes.js +2 -0
- package/dist/web-server/routes/settings-routes.js.map +1 -1
- package/dist/web-server/services/logs-dashboard-service.d.ts +7 -0
- package/dist/web-server/services/logs-dashboard-service.d.ts.map +1 -0
- package/dist/web-server/services/logs-dashboard-service.js +33 -0
- package/dist/web-server/services/logs-dashboard-service.js.map +1 -0
- package/dist/web-server/usage/routes.d.ts.map +1 -1
- package/dist/web-server/usage/routes.js +11 -0
- package/dist/web-server/usage/routes.js.map +1 -1
- package/dist/web-server/websocket.d.ts.map +1 -1
- package/dist/web-server/websocket.js +23 -14
- package/dist/web-server/websocket.js.map +1 -1
- package/lib/hooks/image-analyzer-transformer.cjs +5 -0
- package/package.json +1 -1
- package/dist/ui/assets/api-C-3mQCFf.js +0 -4
- package/dist/ui/assets/cliproxy-1qRVSbVC.js +0 -3
- package/dist/ui/assets/cliproxy-ai-providers-DBSXTTyw.js +0 -21
- package/dist/ui/assets/icons-B9oTjo-t.js +0 -1
- package/dist/ui/assets/index-BMHPMj0j.js +0 -69
- package/dist/ui/assets/index-CknHGRYp.css +0 -1
- package/dist/ui/assets/index-v-DY6Zby.js +0 -1
- package/dist/ui/assets/proxy-status-widget-Ci1JpStj.js +0 -1
- package/dist/ui/assets/searchable-select-HbP2PXl3.js +0 -1
- 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":"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"}
|
|
@@ -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 @@
|
|
|
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"}
|