@kaitranntt/ccs 7.66.1 → 7.67.0-dev.2
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/ccs.js +68 -35
- package/dist/ccs.js.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/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/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/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/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 +14 -7
- package/dist/cliproxy/quota-fetcher-gemini-cli.js.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/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 +12 -38
- 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 +3 -0
- 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/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/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/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/ui/assets/{accounts-BjfPKR8m.js → accounts-ls0hXYZ9.js} +1 -1
- package/dist/ui/assets/{alert-dialog-Dh2NUFdm.js → alert-dialog-DJMw_zyc.js} +1 -1
- package/dist/ui/assets/{api-C-3mQCFf.js → api-Dz2nP1bN.js} +2 -2
- package/dist/ui/assets/{auth-section-Dp10_YyD.js → auth-section-BD8XqTiz.js} +1 -1
- package/dist/ui/assets/{backups-section-C0jF8MP1.js → backups-section-COOSGu9k.js} +1 -1
- package/dist/ui/assets/{channels-CkXuK5i7.js → channels-AGHzxMPw.js} +1 -1
- package/dist/ui/assets/{checkbox-tA5FH8Ol.js → checkbox-pojB3pE7.js} +1 -1
- package/dist/ui/assets/{claude-extension-Bg2ZkzMz.js → claude-extension-4b8gXOo_.js} +1 -1
- package/dist/ui/assets/cliproxy-BFEBo-pc.js +3 -0
- package/dist/ui/assets/{cliproxy-ai-providers-DBSXTTyw.js → cliproxy-ai-providers-BXE0HGLt.js} +6 -6
- package/dist/ui/assets/{cliproxy-control-panel-Da-sGGyI.js → cliproxy-control-panel-ZnCfRS9l.js} +1 -1
- package/dist/ui/assets/{codex-ooWKOPa2.js → codex-B9uBYmnm.js} +5 -5
- package/dist/ui/assets/{confirm-dialog-CKjwhn9j.js → confirm-dialog-DwPqRjyW.js} +1 -1
- package/dist/ui/assets/{copilot-GA7EPiK1.js → copilot-CSWApqyO.js} +2 -2
- package/dist/ui/assets/{cursor-B6c8CyHG.js → cursor-DYbVB4gp.js} +1 -1
- package/dist/ui/assets/{droid-CPRHOIX2.js → droid-BAovZe7o.js} +2 -2
- package/dist/ui/assets/{globalenv-section-Czgnw_GV.js → globalenv-section-CHHZbjD8.js} +1 -1
- package/dist/ui/assets/{health-CXLOMk8n.js → health-Jp7o0exN.js} +1 -1
- package/dist/ui/assets/icons-DfENUzBo.js +1 -0
- package/dist/ui/assets/{index-CvfzKRSH.js → index--j-jJwzV.js} +1 -1
- package/dist/ui/assets/{index-Boa5e-GY.js → index-C5iouJJ2.js} +1 -1
- package/dist/ui/assets/{index-D2v_-6AW.js → index-C5uQdep3.js} +1 -1
- package/dist/ui/assets/{index-BceMcbCR.js → index-CpkWv5tW.js} +1 -1
- package/dist/ui/assets/index-DFifef9c.css +1 -0
- package/dist/ui/assets/index-Du97tqVQ.js +69 -0
- package/dist/ui/assets/index-VluKB6dO.js +1 -0
- package/dist/ui/assets/logs-BDbHSujh.js +1 -0
- package/dist/ui/assets/{masked-input-B1_asiUI.js → masked-input-BcJDHDE6.js} +1 -1
- package/dist/ui/assets/proxy-status-widget-DQWsa532.js +1 -0
- package/dist/ui/assets/{raw-json-settings-editor-panel-DMbTkxWw.js → raw-json-settings-editor-panel-Cbn2O4rk.js} +1 -1
- package/dist/ui/assets/searchable-select-fldXYfY4.js +1 -0
- package/dist/ui/assets/{separator-CdaalG0K.js → separator-Dd3ktLxa.js} +1 -1
- package/dist/ui/assets/{shared-BiFB-et0.js → shared-CdAn8E3x.js} +1 -1
- package/dist/ui/assets/{table-BPwgFXLQ.js → table-CCf__Q_I.js} +1 -1
- package/dist/ui/assets/{tanstack-DWm6aJ-G.js → tanstack-CrmUhA7Z.js} +2 -2
- package/dist/ui/assets/updates-DfoGG8Jl.js +1 -0
- package/dist/ui/index.html +4 -4
- 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/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 +15 -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.js +7 -7
- 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 +63 -74
- 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/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/cliproxy-1qRVSbVC.js +0 -3
- 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
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"image-analysis-check.js","sourceRoot":"","sources":["../../../src/management/checks/image-analysis-check.ts"],"names":[],"mappings":";AAAA;;;;;GAKG;;;;;;;;;;;;;;;;;;;;;;;;;;AAEH,8EAA4E;AAC5E,4EAAkF;AAClF,uCAA+C;AAC/C,gEAAiE;AACjE,sEAAwE;
|
|
1
|
+
{"version":3,"file":"image-analysis-check.js","sourceRoot":"","sources":["../../../src/management/checks/image-analysis-check.ts"],"names":[],"mappings":"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"}
|
|
@@ -18,6 +18,12 @@ declare class RecoveryManager {
|
|
|
18
18
|
* Ensure ~/.ccs/ directory exists
|
|
19
19
|
*/
|
|
20
20
|
ensureCcsDirectory(): boolean;
|
|
21
|
+
/**
|
|
22
|
+
* Remove a dangling symlink so recovery can recreate the directory.
|
|
23
|
+
* Mirrors scripts/postinstall.js behavior for skipped lifecycle installs.
|
|
24
|
+
*/
|
|
25
|
+
private removeIfBrokenSymlink;
|
|
26
|
+
private inspectDirectoryPath;
|
|
21
27
|
/**
|
|
22
28
|
* Ensure ~/.ccs/config.yaml exists with defaults
|
|
23
29
|
* This is the primary config format (YAML unified config)
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"recovery-manager.d.ts","sourceRoot":"","sources":["../../src/management/recovery-manager.ts"],"names":[],"mappings":"AAAA;;;;GAIG;AAaH;;GAEG;AACH,cAAM,eAAe;IACnB,OAAO,CAAC,QAAQ,CAAC,OAAO,CAAS;IACjC,OAAO,CAAC,QAAQ,CAAC,MAAM,CAAS;IAChC,OAAO,CAAC,QAAQ,CAAC,SAAS,CAAS;IACnC,OAAO,CAAC,QAAQ,CAAC,SAAS,CAAS;IACnC,OAAO,CAAC,QAAQ,CAAC,cAAc,CAAS;IACxC,OAAO,CAAC,SAAS,CAAW;;IAW5B;;OAEG;IACH,kBAAkB,IAAI,OAAO;IAS7B;;;OAGG;IACH,gBAAgB,IAAI,OAAO;IA4C3B;;OAEG;IACH,oBAAoB,IAAI,OAAO;IAsB/B;;OAEG;IACH,uBAAuB,IAAI,OAAO;
|
|
1
|
+
{"version":3,"file":"recovery-manager.d.ts","sourceRoot":"","sources":["../../src/management/recovery-manager.ts"],"names":[],"mappings":"AAAA;;;;GAIG;AAaH;;GAEG;AACH,cAAM,eAAe;IACnB,OAAO,CAAC,QAAQ,CAAC,OAAO,CAAS;IACjC,OAAO,CAAC,QAAQ,CAAC,MAAM,CAAS;IAChC,OAAO,CAAC,QAAQ,CAAC,SAAS,CAAS;IACnC,OAAO,CAAC,QAAQ,CAAC,SAAS,CAAS;IACnC,OAAO,CAAC,QAAQ,CAAC,cAAc,CAAS;IACxC,OAAO,CAAC,SAAS,CAAW;;IAW5B;;OAEG;IACH,kBAAkB,IAAI,OAAO;IAS7B;;;OAGG;IACH,OAAO,CAAC,qBAAqB;IAyB7B,OAAO,CAAC,oBAAoB;IAiC5B;;;OAGG;IACH,gBAAgB,IAAI,OAAO;IA4C3B;;OAEG;IACH,oBAAoB,IAAI,OAAO;IAsB/B;;OAEG;IACH,uBAAuB,IAAI,OAAO;IAqClC;;OAEG;IACH,sBAAsB,IAAI,OAAO;IA+CjC;;;;;;OAMG;IACH,UAAU,IAAI,OAAO;IAiBrB;;OAEG;IACH,kBAAkB,IAAI,MAAM,EAAE;IAI9B;;OAEG;IACH,iBAAiB,IAAI,IAAI;CAgB1B;AAED,eAAe,eAAe,CAAC"}
|
|
@@ -57,6 +57,64 @@ class RecoveryManager {
|
|
|
57
57
|
}
|
|
58
58
|
return false;
|
|
59
59
|
}
|
|
60
|
+
/**
|
|
61
|
+
* Remove a dangling symlink so recovery can recreate the directory.
|
|
62
|
+
* Mirrors scripts/postinstall.js behavior for skipped lifecycle installs.
|
|
63
|
+
*/
|
|
64
|
+
removeIfBrokenSymlink(targetPath) {
|
|
65
|
+
try {
|
|
66
|
+
const stats = fs.lstatSync(targetPath);
|
|
67
|
+
if (!stats.isSymbolicLink()) {
|
|
68
|
+
return false;
|
|
69
|
+
}
|
|
70
|
+
try {
|
|
71
|
+
fs.statSync(targetPath);
|
|
72
|
+
return false;
|
|
73
|
+
}
|
|
74
|
+
catch (error) {
|
|
75
|
+
const code = error.code;
|
|
76
|
+
if (code !== 'ENOENT' && code !== 'ENOTDIR') {
|
|
77
|
+
return false;
|
|
78
|
+
}
|
|
79
|
+
fs.unlinkSync(targetPath);
|
|
80
|
+
this.recovered.push(`Removed broken symlink: ${targetPath}`);
|
|
81
|
+
return true;
|
|
82
|
+
}
|
|
83
|
+
}
|
|
84
|
+
catch {
|
|
85
|
+
return false;
|
|
86
|
+
}
|
|
87
|
+
}
|
|
88
|
+
inspectDirectoryPath(targetPath) {
|
|
89
|
+
try {
|
|
90
|
+
const stats = fs.lstatSync(targetPath);
|
|
91
|
+
if (stats.isSymbolicLink()) {
|
|
92
|
+
try {
|
|
93
|
+
return fs.statSync(targetPath).isDirectory()
|
|
94
|
+
? { state: 'ready' }
|
|
95
|
+
: { state: 'invalid', reason: 'symlink target is not a directory' };
|
|
96
|
+
}
|
|
97
|
+
catch (error) {
|
|
98
|
+
const code = error.code;
|
|
99
|
+
return code === 'ENOENT' || code === 'ENOTDIR'
|
|
100
|
+
? { state: 'missing' }
|
|
101
|
+
: {
|
|
102
|
+
state: 'invalid',
|
|
103
|
+
reason: `symlink target is not accessible (${code || 'unknown'})`,
|
|
104
|
+
};
|
|
105
|
+
}
|
|
106
|
+
}
|
|
107
|
+
return stats.isDirectory()
|
|
108
|
+
? { state: 'ready' }
|
|
109
|
+
: { state: 'invalid', reason: 'existing path is not a directory' };
|
|
110
|
+
}
|
|
111
|
+
catch (error) {
|
|
112
|
+
const code = error.code;
|
|
113
|
+
return code === 'ENOENT'
|
|
114
|
+
? { state: 'missing' }
|
|
115
|
+
: { state: 'invalid', reason: `could not inspect path (${code || 'unknown'})` };
|
|
116
|
+
}
|
|
117
|
+
}
|
|
60
118
|
/**
|
|
61
119
|
* Ensure ~/.ccs/config.yaml exists with defaults
|
|
62
120
|
* This is the primary config format (YAML unified config)
|
|
@@ -128,19 +186,31 @@ class RecoveryManager {
|
|
|
128
186
|
*/
|
|
129
187
|
ensureSharedDirectories() {
|
|
130
188
|
let created = false;
|
|
189
|
+
this.removeIfBrokenSymlink(this.sharedDir);
|
|
190
|
+
const sharedState = this.inspectDirectoryPath(this.sharedDir);
|
|
131
191
|
// Create shared directory
|
|
132
|
-
if (
|
|
192
|
+
if (sharedState.state === 'missing') {
|
|
133
193
|
fs.mkdirSync(this.sharedDir, { recursive: true, mode: 0o755 });
|
|
134
194
|
this.recovered.push(`Created ${this.sharedDir}`);
|
|
135
195
|
created = true;
|
|
136
196
|
}
|
|
197
|
+
else if (sharedState.state === 'invalid') {
|
|
198
|
+
this.recovered.push(`Skipped ${this.sharedDir}: ${sharedState.reason}`);
|
|
199
|
+
return created;
|
|
200
|
+
}
|
|
137
201
|
// Create subdirectories
|
|
138
202
|
const subdirs = ['commands', 'skills', 'agents', 'plugins'];
|
|
139
203
|
for (const subdir of subdirs) {
|
|
140
204
|
const subdirPath = path.join(this.sharedDir, subdir);
|
|
141
|
-
|
|
205
|
+
this.removeIfBrokenSymlink(subdirPath);
|
|
206
|
+
const subdirState = this.inspectDirectoryPath(subdirPath);
|
|
207
|
+
if (subdirState.state === 'missing') {
|
|
142
208
|
fs.mkdirSync(subdirPath, { recursive: true, mode: 0o755 });
|
|
143
209
|
created = true;
|
|
210
|
+
continue;
|
|
211
|
+
}
|
|
212
|
+
if (subdirState.state === 'invalid') {
|
|
213
|
+
this.recovered.push(`Skipped ${subdirPath}: ${subdirState.reason}`);
|
|
144
214
|
}
|
|
145
215
|
}
|
|
146
216
|
return created;
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"recovery-manager.js","sourceRoot":"","sources":["../../src/management/recovery-manager.ts"],"names":[],"mappings":"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
|
|
1
|
+
{"version":3,"file":"recovery-manager.js","sourceRoot":"","sources":["../../src/management/recovery-manager.ts"],"names":[],"mappings":"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"}
|
|
@@ -0,0 +1,7 @@
|
|
|
1
|
+
export { createLogger } from './logger';
|
|
2
|
+
export { getResolvedLoggingConfig, invalidateLoggingConfigCache } from './log-config';
|
|
3
|
+
export { readLogEntries, readLogSourceSummaries, normalizeLogQueryLevel } from './log-reader';
|
|
4
|
+
export { pruneExpiredLogArchives } from './log-storage';
|
|
5
|
+
export { ensureLoggingDirectories, getCurrentLogPath, getLegacyCliproxyLogsDir, getLogArchiveDir, getNativeLogsDir, isPathInsideDirectory, } from './log-paths';
|
|
6
|
+
export type { LogEntry, LogSourceSummary, LoggingLevel, ReadLogEntriesOptions } from './log-types';
|
|
7
|
+
//# sourceMappingURL=index.d.ts.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"index.d.ts","sourceRoot":"","sources":["../../../src/services/logging/index.ts"],"names":[],"mappings":"AAAA,OAAO,EAAE,YAAY,EAAE,MAAM,UAAU,CAAC;AACxC,OAAO,EAAE,wBAAwB,EAAE,4BAA4B,EAAE,MAAM,cAAc,CAAC;AACtF,OAAO,EAAE,cAAc,EAAE,sBAAsB,EAAE,sBAAsB,EAAE,MAAM,cAAc,CAAC;AAC9F,OAAO,EAAE,uBAAuB,EAAE,MAAM,eAAe,CAAC;AACxD,OAAO,EACL,wBAAwB,EACxB,iBAAiB,EACjB,wBAAwB,EACxB,gBAAgB,EAChB,gBAAgB,EAChB,qBAAqB,GACtB,MAAM,aAAa,CAAC;AACrB,YAAY,EAAE,QAAQ,EAAE,gBAAgB,EAAE,YAAY,EAAE,qBAAqB,EAAE,MAAM,aAAa,CAAC"}
|
|
@@ -0,0 +1,22 @@
|
|
|
1
|
+
"use strict";
|
|
2
|
+
Object.defineProperty(exports, "__esModule", { value: true });
|
|
3
|
+
exports.isPathInsideDirectory = exports.getNativeLogsDir = exports.getLogArchiveDir = exports.getLegacyCliproxyLogsDir = exports.getCurrentLogPath = exports.ensureLoggingDirectories = exports.pruneExpiredLogArchives = exports.normalizeLogQueryLevel = exports.readLogSourceSummaries = exports.readLogEntries = exports.invalidateLoggingConfigCache = exports.getResolvedLoggingConfig = exports.createLogger = void 0;
|
|
4
|
+
var logger_1 = require("./logger");
|
|
5
|
+
Object.defineProperty(exports, "createLogger", { enumerable: true, get: function () { return logger_1.createLogger; } });
|
|
6
|
+
var log_config_1 = require("./log-config");
|
|
7
|
+
Object.defineProperty(exports, "getResolvedLoggingConfig", { enumerable: true, get: function () { return log_config_1.getResolvedLoggingConfig; } });
|
|
8
|
+
Object.defineProperty(exports, "invalidateLoggingConfigCache", { enumerable: true, get: function () { return log_config_1.invalidateLoggingConfigCache; } });
|
|
9
|
+
var log_reader_1 = require("./log-reader");
|
|
10
|
+
Object.defineProperty(exports, "readLogEntries", { enumerable: true, get: function () { return log_reader_1.readLogEntries; } });
|
|
11
|
+
Object.defineProperty(exports, "readLogSourceSummaries", { enumerable: true, get: function () { return log_reader_1.readLogSourceSummaries; } });
|
|
12
|
+
Object.defineProperty(exports, "normalizeLogQueryLevel", { enumerable: true, get: function () { return log_reader_1.normalizeLogQueryLevel; } });
|
|
13
|
+
var log_storage_1 = require("./log-storage");
|
|
14
|
+
Object.defineProperty(exports, "pruneExpiredLogArchives", { enumerable: true, get: function () { return log_storage_1.pruneExpiredLogArchives; } });
|
|
15
|
+
var log_paths_1 = require("./log-paths");
|
|
16
|
+
Object.defineProperty(exports, "ensureLoggingDirectories", { enumerable: true, get: function () { return log_paths_1.ensureLoggingDirectories; } });
|
|
17
|
+
Object.defineProperty(exports, "getCurrentLogPath", { enumerable: true, get: function () { return log_paths_1.getCurrentLogPath; } });
|
|
18
|
+
Object.defineProperty(exports, "getLegacyCliproxyLogsDir", { enumerable: true, get: function () { return log_paths_1.getLegacyCliproxyLogsDir; } });
|
|
19
|
+
Object.defineProperty(exports, "getLogArchiveDir", { enumerable: true, get: function () { return log_paths_1.getLogArchiveDir; } });
|
|
20
|
+
Object.defineProperty(exports, "getNativeLogsDir", { enumerable: true, get: function () { return log_paths_1.getNativeLogsDir; } });
|
|
21
|
+
Object.defineProperty(exports, "isPathInsideDirectory", { enumerable: true, get: function () { return log_paths_1.isPathInsideDirectory; } });
|
|
22
|
+
//# sourceMappingURL=index.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"index.js","sourceRoot":"","sources":["../../../src/services/logging/index.ts"],"names":[],"mappings":";;;AAAA,mCAAwC;AAA/B,sGAAA,YAAY,OAAA;AACrB,2CAAsF;AAA7E,sHAAA,wBAAwB,OAAA;AAAE,0HAAA,4BAA4B,OAAA;AAC/D,2CAA8F;AAArF,4GAAA,cAAc,OAAA;AAAE,oHAAA,sBAAsB,OAAA;AAAE,oHAAA,sBAAsB,OAAA;AACvE,6CAAwD;AAA/C,sHAAA,uBAAuB,OAAA;AAChC,yCAOqB;AANnB,qHAAA,wBAAwB,OAAA;AACxB,8GAAA,iBAAiB,OAAA;AACjB,qHAAA,wBAAwB,OAAA;AACxB,6GAAA,gBAAgB,OAAA;AAChB,6GAAA,gBAAgB,OAAA;AAChB,kHAAA,qBAAqB,OAAA"}
|
|
@@ -0,0 +1,5 @@
|
|
|
1
|
+
import type { LogEntry } from './log-types';
|
|
2
|
+
export declare function pushRecentLogEntry(entry: LogEntry, maxEntries: number): void;
|
|
3
|
+
export declare function getRecentLogEntries(): LogEntry[];
|
|
4
|
+
export declare function clearRecentLogEntries(): void;
|
|
5
|
+
//# sourceMappingURL=log-buffer.d.ts.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"log-buffer.d.ts","sourceRoot":"","sources":["../../../src/services/logging/log-buffer.ts"],"names":[],"mappings":"AAAA,OAAO,KAAK,EAAE,QAAQ,EAAE,MAAM,aAAa,CAAC;AAI5C,wBAAgB,kBAAkB,CAAC,KAAK,EAAE,QAAQ,EAAE,UAAU,EAAE,MAAM,GAAG,IAAI,CAK5E;AAED,wBAAgB,mBAAmB,IAAI,QAAQ,EAAE,CAEhD;AAED,wBAAgB,qBAAqB,IAAI,IAAI,CAE5C"}
|
|
@@ -0,0 +1,20 @@
|
|
|
1
|
+
"use strict";
|
|
2
|
+
Object.defineProperty(exports, "__esModule", { value: true });
|
|
3
|
+
exports.clearRecentLogEntries = exports.getRecentLogEntries = exports.pushRecentLogEntry = void 0;
|
|
4
|
+
let recentEntries = [];
|
|
5
|
+
function pushRecentLogEntry(entry, maxEntries) {
|
|
6
|
+
recentEntries.push(entry);
|
|
7
|
+
if (recentEntries.length > maxEntries) {
|
|
8
|
+
recentEntries = recentEntries.slice(recentEntries.length - maxEntries);
|
|
9
|
+
}
|
|
10
|
+
}
|
|
11
|
+
exports.pushRecentLogEntry = pushRecentLogEntry;
|
|
12
|
+
function getRecentLogEntries() {
|
|
13
|
+
return [...recentEntries];
|
|
14
|
+
}
|
|
15
|
+
exports.getRecentLogEntries = getRecentLogEntries;
|
|
16
|
+
function clearRecentLogEntries() {
|
|
17
|
+
recentEntries = [];
|
|
18
|
+
}
|
|
19
|
+
exports.clearRecentLogEntries = clearRecentLogEntries;
|
|
20
|
+
//# sourceMappingURL=log-buffer.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"log-buffer.js","sourceRoot":"","sources":["../../../src/services/logging/log-buffer.ts"],"names":[],"mappings":";;;AAEA,IAAI,aAAa,GAAe,EAAE,CAAC;AAEnC,SAAgB,kBAAkB,CAAC,KAAe,EAAE,UAAkB;IACpE,aAAa,CAAC,IAAI,CAAC,KAAK,CAAC,CAAC;IAC1B,IAAI,aAAa,CAAC,MAAM,GAAG,UAAU,EAAE,CAAC;QACtC,aAAa,GAAG,aAAa,CAAC,KAAK,CAAC,aAAa,CAAC,MAAM,GAAG,UAAU,CAAC,CAAC;IACzE,CAAC;AACH,CAAC;AALD,gDAKC;AAED,SAAgB,mBAAmB;IACjC,OAAO,CAAC,GAAG,aAAa,CAAC,CAAC;AAC5B,CAAC;AAFD,kDAEC;AAED,SAAgB,qBAAqB;IACnC,aAAa,GAAG,EAAE,CAAC;AACrB,CAAC;AAFD,sDAEC"}
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"log-config.d.ts","sourceRoot":"","sources":["../../../src/services/logging/log-config.ts"],"names":[],"mappings":"AAMA,OAAO,KAAK,EAAE,aAAa,EAAE,MAAM,aAAa,CAAC;AAOjD,wBAAgB,4BAA4B,IAAI,IAAI,CAInD;AAED,wBAAgB,wBAAwB,IAAI,aAAa,CA2BxD"}
|
|
@@ -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
|