@kaitranntt/ccs 7.66.1-dev.4 → 7.66.1-dev.5

This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
Files changed (139) hide show
  1. package/dist/ccs.js +10 -0
  2. package/dist/ccs.js.map +1 -1
  3. package/dist/cliproxy/proxy-detector.d.ts.map +1 -1
  4. package/dist/cliproxy/proxy-detector.js +6 -2
  5. package/dist/cliproxy/proxy-detector.js.map +1 -1
  6. package/dist/cliproxy/startup-lock.d.ts.map +1 -1
  7. package/dist/cliproxy/startup-lock.js +5 -1
  8. package/dist/cliproxy/startup-lock.js.map +1 -1
  9. package/dist/cliproxy/tool-sanitization-proxy.d.ts +1 -0
  10. package/dist/cliproxy/tool-sanitization-proxy.d.ts.map +1 -1
  11. package/dist/cliproxy/tool-sanitization-proxy.js +6 -0
  12. package/dist/cliproxy/tool-sanitization-proxy.js.map +1 -1
  13. package/dist/commands/cleanup-command.d.ts +1 -1
  14. package/dist/commands/cleanup-command.d.ts.map +1 -1
  15. package/dist/commands/cleanup-command.js +57 -34
  16. package/dist/commands/cleanup-command.js.map +1 -1
  17. package/dist/commands/command-catalog.js +1 -1
  18. package/dist/commands/command-catalog.js.map +1 -1
  19. package/dist/commands/config-command.d.ts.map +1 -1
  20. package/dist/commands/config-command.js +23 -0
  21. package/dist/commands/config-command.js.map +1 -1
  22. package/dist/config/unified-config-loader.d.ts +2 -1
  23. package/dist/config/unified-config-loader.d.ts.map +1 -1
  24. package/dist/config/unified-config-loader.js +31 -1
  25. package/dist/config/unified-config-loader.js.map +1 -1
  26. package/dist/config/unified-config-types.d.ts +22 -0
  27. package/dist/config/unified-config-types.d.ts.map +1 -1
  28. package/dist/config/unified-config-types.js +10 -1
  29. package/dist/config/unified-config-types.js.map +1 -1
  30. package/dist/errors/error-handler.d.ts.map +1 -1
  31. package/dist/errors/error-handler.js +13 -0
  32. package/dist/errors/error-handler.js.map +1 -1
  33. package/dist/glmt/glmt-transformer.d.ts +1 -0
  34. package/dist/glmt/glmt-transformer.d.ts.map +1 -1
  35. package/dist/glmt/glmt-transformer.js +9 -0
  36. package/dist/glmt/glmt-transformer.js.map +1 -1
  37. package/dist/services/logging/index.d.ts +7 -0
  38. package/dist/services/logging/index.d.ts.map +1 -0
  39. package/dist/services/logging/index.js +22 -0
  40. package/dist/services/logging/index.js.map +1 -0
  41. package/dist/services/logging/log-buffer.d.ts +5 -0
  42. package/dist/services/logging/log-buffer.d.ts.map +1 -0
  43. package/dist/services/logging/log-buffer.js +20 -0
  44. package/dist/services/logging/log-buffer.js.map +1 -0
  45. package/dist/services/logging/log-config.d.ts +4 -0
  46. package/dist/services/logging/log-config.d.ts.map +1 -0
  47. package/dist/services/logging/log-config.js +68 -0
  48. package/dist/services/logging/log-config.js.map +1 -0
  49. package/dist/services/logging/log-paths.d.ts +8 -0
  50. package/dist/services/logging/log-paths.d.ts.map +1 -0
  51. package/dist/services/logging/log-paths.js +66 -0
  52. package/dist/services/logging/log-paths.js.map +1 -0
  53. package/dist/services/logging/log-reader.d.ts +5 -0
  54. package/dist/services/logging/log-reader.d.ts.map +1 -0
  55. package/dist/services/logging/log-reader.js +124 -0
  56. package/dist/services/logging/log-reader.js.map +1 -0
  57. package/dist/services/logging/log-redaction.d.ts +2 -0
  58. package/dist/services/logging/log-redaction.d.ts.map +1 -0
  59. package/dist/services/logging/log-redaction.js +53 -0
  60. package/dist/services/logging/log-redaction.js.map +1 -0
  61. package/dist/services/logging/log-storage.d.ts +4 -0
  62. package/dist/services/logging/log-storage.d.ts.map +1 -0
  63. package/dist/services/logging/log-storage.js +109 -0
  64. package/dist/services/logging/log-storage.js.map +1 -0
  65. package/dist/services/logging/log-types.d.ts +30 -0
  66. package/dist/services/logging/log-types.d.ts.map +1 -0
  67. package/dist/services/logging/log-types.js +19 -0
  68. package/dist/services/logging/log-types.js.map +1 -0
  69. package/dist/services/logging/logger.d.ts +9 -0
  70. package/dist/services/logging/logger.d.ts.map +1 -0
  71. package/dist/services/logging/logger.js +46 -0
  72. package/dist/services/logging/logger.js.map +1 -0
  73. package/dist/ui/assets/{accounts-DUWrYt3x.js → accounts-CoxemH1E.js} +1 -1
  74. package/dist/ui/assets/{alert-dialog-D_Yz_iZc.js → alert-dialog-CIVd-ody.js} +1 -1
  75. package/dist/ui/assets/{api-CBTgaJzF.js → api-BVfXHYxj.js} +2 -2
  76. package/dist/ui/assets/{auth-section-BoDZqbPJ.js → auth-section-DDd9GEBK.js} +1 -1
  77. package/dist/ui/assets/{backups-section-D4-FbvV4.js → backups-section-BWbdSnXt.js} +1 -1
  78. package/dist/ui/assets/{channels-BFBl4r-j.js → channels-BPxlzEif.js} +1 -1
  79. package/dist/ui/assets/{checkbox-DjeKLLRq.js → checkbox-BKFUU2sG.js} +1 -1
  80. package/dist/ui/assets/{claude-extension-C1FsOq-7.js → claude-extension-C-6KUHA0.js} +1 -1
  81. package/dist/ui/assets/{cliproxy-C2sZh-5V.js → cliproxy-C2_5ie4n.js} +2 -2
  82. package/dist/ui/assets/{cliproxy-ai-providers-DcCbeAbO.js → cliproxy-ai-providers-D1-ZGJt9.js} +5 -5
  83. package/dist/ui/assets/{cliproxy-control-panel-v4kA_2hy.js → cliproxy-control-panel-CTjW6xf_.js} +1 -1
  84. package/dist/ui/assets/{codex-Cj_wPgw5.js → codex-xU8SQWhS.js} +1 -1
  85. package/dist/ui/assets/{confirm-dialog-B273dyaD.js → confirm-dialog-B9mG4XrE.js} +1 -1
  86. package/dist/ui/assets/{copilot-DvgELRFw.js → copilot-B_cDTXu9.js} +2 -2
  87. package/dist/ui/assets/{cursor-8gcvd36W.js → cursor-B0aHykdX.js} +1 -1
  88. package/dist/ui/assets/{droid-DZDVCJBf.js → droid-Cou-phPn.js} +1 -1
  89. package/dist/ui/assets/{globalenv-section-CKv4BfT4.js → globalenv-section-B7fDhbOR.js} +1 -1
  90. package/dist/ui/assets/{health-DmZLL4IN.js → health-Cux4-fWS.js} +1 -1
  91. package/dist/ui/assets/icons-C4EMu2PL.js +1 -0
  92. package/dist/ui/assets/index-7qTHMz5v.css +1 -0
  93. package/dist/ui/assets/index-B-YlctHj.js +69 -0
  94. package/dist/ui/assets/index-CHWn7pks.js +1 -0
  95. package/dist/ui/assets/{index-DUM_z9jT.js → index-Cp8KcNTJ.js} +1 -1
  96. package/dist/ui/assets/{index-l8yS9gLo.js → index-CvqYFZA_.js} +1 -1
  97. package/dist/ui/assets/{index-DESEUD89.js → index-DOFoLunG.js} +1 -1
  98. package/dist/ui/assets/{index-B185OZF2.js → index-WuuQNt8F.js} +1 -1
  99. package/dist/ui/assets/logs-C2LvO27n.js +1 -0
  100. package/dist/ui/assets/{masked-input-C-vLCUuQ.js → masked-input-DyN9mmaP.js} +1 -1
  101. package/dist/ui/assets/{proxy-status-widget-190bjsgV.js → proxy-status-widget-EgraEYSp.js} +1 -1
  102. package/dist/ui/assets/{raw-json-settings-editor-panel-DcwxTJM2.js → raw-json-settings-editor-panel-T7HrEBqp.js} +1 -1
  103. package/dist/ui/assets/{searchable-select-CCNEAmMs.js → searchable-select-Bfwi19-3.js} +1 -1
  104. package/dist/ui/assets/{separator-DdqwGZjf.js → separator-Cia83j78.js} +1 -1
  105. package/dist/ui/assets/{shared-CiXoJI0N.js → shared-BRUYjDc4.js} +1 -1
  106. package/dist/ui/assets/{table-BbSidPe4.js → table-DVwKEwq6.js} +1 -1
  107. package/dist/ui/assets/{tanstack-DWm6aJ-G.js → tanstack-CrmUhA7Z.js} +2 -2
  108. package/dist/ui/assets/updates-CfwrNAck.js +1 -0
  109. package/dist/ui/index.html +4 -4
  110. package/dist/utils/websearch/trace.d.ts.map +1 -1
  111. package/dist/utils/websearch/trace.js +7 -0
  112. package/dist/utils/websearch/trace.js.map +1 -1
  113. package/dist/web-server/index.d.ts.map +1 -1
  114. package/dist/web-server/index.js +15 -0
  115. package/dist/web-server/index.js.map +1 -1
  116. package/dist/web-server/middleware/request-logging-middleware.d.ts +3 -0
  117. package/dist/web-server/middleware/request-logging-middleware.d.ts.map +1 -0
  118. package/dist/web-server/middleware/request-logging-middleware.js +30 -0
  119. package/dist/web-server/middleware/request-logging-middleware.js.map +1 -0
  120. package/dist/web-server/routes/index.d.ts.map +1 -1
  121. package/dist/web-server/routes/index.js +2 -0
  122. package/dist/web-server/routes/index.js.map +1 -1
  123. package/dist/web-server/routes/logs-routes.d.ts +3 -0
  124. package/dist/web-server/routes/logs-routes.d.ts.map +1 -0
  125. package/dist/web-server/routes/logs-routes.js +75 -0
  126. package/dist/web-server/routes/logs-routes.js.map +1 -0
  127. package/dist/web-server/services/logs-dashboard-service.d.ts +7 -0
  128. package/dist/web-server/services/logs-dashboard-service.d.ts.map +1 -0
  129. package/dist/web-server/services/logs-dashboard-service.js +33 -0
  130. package/dist/web-server/services/logs-dashboard-service.js.map +1 -0
  131. package/dist/web-server/websocket.d.ts.map +1 -1
  132. package/dist/web-server/websocket.js +23 -14
  133. package/dist/web-server/websocket.js.map +1 -1
  134. package/package.json +1 -1
  135. package/dist/ui/assets/icons-HPncf80J.js +0 -1
  136. package/dist/ui/assets/index-CObGkcxo.js +0 -1
  137. package/dist/ui/assets/index-D8NlA5zN.js +0 -69
  138. package/dist/ui/assets/index-DY4gWzEw.css +0 -1
  139. package/dist/ui/assets/updates-DqccLz_y.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,2 @@
1
+ export declare function redactContext(context: Record<string, unknown> | undefined): Record<string, unknown>;
2
+ //# sourceMappingURL=log-redaction.d.ts.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"log-redaction.d.ts","sourceRoot":"","sources":["../../../src/services/logging/log-redaction.ts"],"names":[],"mappings":"AAqDA,wBAAgB,aAAa,CAC3B,OAAO,EAAE,MAAM,CAAC,MAAM,EAAE,OAAO,CAAC,GAAG,SAAS,GAC3C,MAAM,CAAC,MAAM,EAAE,OAAO,CAAC,CAMzB"}
@@ -0,0 +1,53 @@
1
+ "use strict";
2
+ Object.defineProperty(exports, "__esModule", { value: true });
3
+ exports.redactContext = void 0;
4
+ const SENSITIVE_KEY_PATTERN = /^(authorization|cookie|set-cookie|password|password_hash|secret|token|api[_-]?key|management[_-]?key)$/i;
5
+ const MAX_STRING_LENGTH = 2000;
6
+ const MAX_DEPTH = 5;
7
+ function truncateString(value) {
8
+ if (value.length <= MAX_STRING_LENGTH) {
9
+ return value;
10
+ }
11
+ return `${value.slice(0, MAX_STRING_LENGTH)}...[truncated]`;
12
+ }
13
+ function sanitizeValue(value, depth) {
14
+ if (value === null || value === undefined) {
15
+ return value;
16
+ }
17
+ if (depth >= MAX_DEPTH) {
18
+ return '[max-depth]';
19
+ }
20
+ if (typeof value === 'string') {
21
+ return truncateString(value);
22
+ }
23
+ if (typeof value === 'number' || typeof value === 'boolean') {
24
+ return value;
25
+ }
26
+ if (value instanceof Error) {
27
+ return {
28
+ name: value.name,
29
+ message: truncateString(value.message),
30
+ };
31
+ }
32
+ if (Array.isArray(value)) {
33
+ return value.map((item) => sanitizeValue(item, depth + 1));
34
+ }
35
+ if (typeof value === 'object') {
36
+ const sanitized = {};
37
+ for (const [key, nestedValue] of Object.entries(value)) {
38
+ sanitized[key] = SENSITIVE_KEY_PATTERN.test(key)
39
+ ? '[redacted]'
40
+ : sanitizeValue(nestedValue, depth + 1);
41
+ }
42
+ return sanitized;
43
+ }
44
+ return String(value);
45
+ }
46
+ function redactContext(context) {
47
+ if (!context) {
48
+ return {};
49
+ }
50
+ return sanitizeValue(context, 0);
51
+ }
52
+ exports.redactContext = redactContext;
53
+ //# sourceMappingURL=log-redaction.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"log-redaction.js","sourceRoot":"","sources":["../../../src/services/logging/log-redaction.ts"],"names":[],"mappings":";;;AAAA,MAAM,qBAAqB,GACzB,yGAAyG,CAAC;AAC5G,MAAM,iBAAiB,GAAG,IAAI,CAAC;AAC/B,MAAM,SAAS,GAAG,CAAC,CAAC;AAEpB,SAAS,cAAc,CAAC,KAAa;IACnC,IAAI,KAAK,CAAC,MAAM,IAAI,iBAAiB,EAAE,CAAC;QACtC,OAAO,KAAK,CAAC;IACf,CAAC;IACD,OAAO,GAAG,KAAK,CAAC,KAAK,CAAC,CAAC,EAAE,iBAAiB,CAAC,gBAAgB,CAAC;AAC9D,CAAC;AAED,SAAS,aAAa,CAAC,KAAc,EAAE,KAAa;IAClD,IAAI,KAAK,KAAK,IAAI,IAAI,KAAK,KAAK,SAAS,EAAE,CAAC;QAC1C,OAAO,KAAK,CAAC;IACf,CAAC;IAED,IAAI,KAAK,IAAI,SAAS,EAAE,CAAC;QACvB,OAAO,aAAa,CAAC;IACvB,CAAC;IAED,IAAI,OAAO,KAAK,KAAK,QAAQ,EAAE,CAAC;QAC9B,OAAO,cAAc,CAAC,KAAK,CAAC,CAAC;IAC/B,CAAC;IAED,IAAI,OAAO,KAAK,KAAK,QAAQ,IAAI,OAAO,KAAK,KAAK,SAAS,EAAE,CAAC;QAC5D,OAAO,KAAK,CAAC;IACf,CAAC;IAED,IAAI,KAAK,YAAY,KAAK,EAAE,CAAC;QAC3B,OAAO;YACL,IAAI,EAAE,KAAK,CAAC,IAAI;YAChB,OAAO,EAAE,cAAc,CAAC,KAAK,CAAC,OAAO,CAAC;SACvC,CAAC;IACJ,CAAC;IAED,IAAI,KAAK,CAAC,OAAO,CAAC,KAAK,CAAC,EAAE,CAAC;QACzB,OAAO,KAAK,CAAC,GAAG,CAAC,CAAC,IAAI,EAAE,EAAE,CAAC,aAAa,CAAC,IAAI,EAAE,KAAK,GAAG,CAAC,CAAC,CAAC,CAAC;IAC7D,CAAC;IAED,IAAI,OAAO,KAAK,KAAK,QAAQ,EAAE,CAAC;QAC9B,MAAM,SAAS,GAA4B,EAAE,CAAC;QAC9C,KAAK,MAAM,CAAC,GAAG,EAAE,WAAW,CAAC,IAAI,MAAM,CAAC,OAAO,CAAC,KAAgC,CAAC,EAAE,CAAC;YAClF,SAAS,CAAC,GAAG,CAAC,GAAG,qBAAqB,CAAC,IAAI,CAAC,GAAG,CAAC;gBAC9C,CAAC,CAAC,YAAY;gBACd,CAAC,CAAC,aAAa,CAAC,WAAW,EAAE,KAAK,GAAG,CAAC,CAAC,CAAC;QAC5C,CAAC;QACD,OAAO,SAAS,CAAC;IACnB,CAAC;IAED,OAAO,MAAM,CAAC,KAAK,CAAC,CAAC;AACvB,CAAC;AAED,SAAgB,aAAa,CAC3B,OAA4C;IAE5C,IAAI,CAAC,OAAO,EAAE,CAAC;QACb,OAAO,EAAE,CAAC;IACZ,CAAC;IAED,OAAO,aAAa,CAAC,OAAO,EAAE,CAAC,CAA4B,CAAC;AAC9D,CAAC;AARD,sCAQC"}
@@ -0,0 +1,4 @@
1
+ import { type LogEntry } from './log-types';
2
+ export declare function pruneExpiredLogArchives(): void;
3
+ export declare function appendStructuredLogEntry(entry: LogEntry): void;
4
+ //# sourceMappingURL=log-storage.d.ts.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"log-storage.d.ts","sourceRoot":"","sources":["../../../src/services/logging/log-storage.ts"],"names":[],"mappings":"AAWA,OAAO,EAAuB,KAAK,QAAQ,EAAE,MAAM,aAAa,CAAC;AAqCjE,wBAAgB,uBAAuB,IAAI,IAAI,CAsB9C;AAED,wBAAgB,wBAAwB,CAAC,KAAK,EAAE,QAAQ,GAAG,IAAI,CAqB9D"}
@@ -0,0 +1,109 @@
1
+ "use strict";
2
+ var __createBinding = (this && this.__createBinding) || (Object.create ? (function(o, m, k, k2) {
3
+ if (k2 === undefined) k2 = k;
4
+ var desc = Object.getOwnPropertyDescriptor(m, k);
5
+ if (!desc || ("get" in desc ? !m.__esModule : desc.writable || desc.configurable)) {
6
+ desc = { enumerable: true, get: function() { return m[k]; } };
7
+ }
8
+ Object.defineProperty(o, k2, desc);
9
+ }) : (function(o, m, k, k2) {
10
+ if (k2 === undefined) k2 = k;
11
+ o[k2] = m[k];
12
+ }));
13
+ var __setModuleDefault = (this && this.__setModuleDefault) || (Object.create ? (function(o, v) {
14
+ Object.defineProperty(o, "default", { enumerable: true, value: v });
15
+ }) : function(o, v) {
16
+ o["default"] = v;
17
+ });
18
+ var __importStar = (this && this.__importStar) || function (mod) {
19
+ if (mod && mod.__esModule) return mod;
20
+ var result = {};
21
+ if (mod != null) for (var k in mod) if (k !== "default" && Object.prototype.hasOwnProperty.call(mod, k)) __createBinding(result, mod, k);
22
+ __setModuleDefault(result, mod);
23
+ return result;
24
+ };
25
+ Object.defineProperty(exports, "__esModule", { value: true });
26
+ exports.appendStructuredLogEntry = exports.pruneExpiredLogArchives = void 0;
27
+ const fs = __importStar(require("fs"));
28
+ const path = __importStar(require("path"));
29
+ const zlib = __importStar(require("zlib"));
30
+ const log_config_1 = require("./log-config");
31
+ const log_paths_1 = require("./log-paths");
32
+ const log_buffer_1 = require("./log-buffer");
33
+ const log_types_1 = require("./log-types");
34
+ const ONE_DAY_MS = 24 * 60 * 60 * 1000;
35
+ const PRUNE_INTERVAL_MS = 60 * 1000;
36
+ let lastPruneAt = 0;
37
+ function getRotateBytes(rotateMb) {
38
+ return Math.max(1, rotateMb) * 1024 * 1024;
39
+ }
40
+ function rotateCurrentLogIfNeeded() {
41
+ const config = (0, log_config_1.getResolvedLoggingConfig)();
42
+ const currentLogPath = (0, log_paths_1.getCurrentLogPath)();
43
+ if (!fs.existsSync(currentLogPath)) {
44
+ return;
45
+ }
46
+ const stats = fs.statSync(currentLogPath);
47
+ const ageMs = Date.now() - stats.mtimeMs;
48
+ const exceedsSize = stats.size >= getRotateBytes(config.rotate_mb);
49
+ const exceedsAge = ageMs >= ONE_DAY_MS;
50
+ if (!exceedsSize && !exceedsAge) {
51
+ return;
52
+ }
53
+ const currentContent = fs.readFileSync(currentLogPath, 'utf8');
54
+ if (!currentContent.trim()) {
55
+ fs.truncateSync(currentLogPath, 0);
56
+ return;
57
+ }
58
+ const archivePath = (0, log_paths_1.buildArchiveLogPath)(new Date(stats.mtimeMs || Date.now()));
59
+ fs.writeFileSync(archivePath, zlib.gzipSync(currentContent), { mode: 0o600 });
60
+ fs.truncateSync(currentLogPath, 0);
61
+ }
62
+ function pruneExpiredLogArchives() {
63
+ const config = (0, log_config_1.getResolvedLoggingConfig)();
64
+ const archiveDir = (0, log_paths_1.getLogArchiveDir)();
65
+ if (!fs.existsSync(archiveDir)) {
66
+ return;
67
+ }
68
+ const cutoffMs = Date.now() - config.retain_days * ONE_DAY_MS;
69
+ for (const entry of fs.readdirSync(archiveDir)) {
70
+ const archivePath = path.join(archiveDir, entry);
71
+ try {
72
+ const stats = fs.lstatSync(archivePath);
73
+ if (!stats.isFile() || stats.isSymbolicLink()) {
74
+ continue;
75
+ }
76
+ if (stats.mtimeMs < cutoffMs) {
77
+ fs.unlinkSync(archivePath);
78
+ }
79
+ }
80
+ catch {
81
+ continue;
82
+ }
83
+ }
84
+ }
85
+ exports.pruneExpiredLogArchives = pruneExpiredLogArchives;
86
+ function appendStructuredLogEntry(entry) {
87
+ const config = (0, log_config_1.getResolvedLoggingConfig)();
88
+ if (!config.enabled || !(0, log_types_1.shouldWriteLogLevel)(entry.level, config.level)) {
89
+ return;
90
+ }
91
+ try {
92
+ (0, log_paths_1.ensureLoggingDirectories)();
93
+ rotateCurrentLogIfNeeded();
94
+ fs.appendFileSync((0, log_paths_1.getCurrentLogPath)(), `${JSON.stringify(entry)}\n`, {
95
+ encoding: 'utf8',
96
+ mode: 0o600,
97
+ });
98
+ (0, log_buffer_1.pushRecentLogEntry)(entry, config.live_buffer_size);
99
+ if (Date.now() - lastPruneAt >= PRUNE_INTERVAL_MS) {
100
+ pruneExpiredLogArchives();
101
+ lastPruneAt = Date.now();
102
+ }
103
+ }
104
+ catch {
105
+ // Logging must never break runtime behavior.
106
+ }
107
+ }
108
+ exports.appendStructuredLogEntry = appendStructuredLogEntry;
109
+ //# sourceMappingURL=log-storage.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"log-storage.js","sourceRoot":"","sources":["../../../src/services/logging/log-storage.ts"],"names":[],"mappings":"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"}
@@ -0,0 +1,30 @@
1
+ import type { LoggingConfig, LoggingLevel } from '../../config/unified-config-types';
2
+ export type { LoggingConfig, LoggingLevel };
3
+ export interface LogEntry {
4
+ id: string;
5
+ timestamp: string;
6
+ level: LoggingLevel;
7
+ source: string;
8
+ event: string;
9
+ message: string;
10
+ processId: number;
11
+ runId: string;
12
+ context?: Record<string, unknown>;
13
+ }
14
+ export interface LogSourceSummary {
15
+ source: string;
16
+ label: string;
17
+ kind: 'native' | 'legacy';
18
+ count: number;
19
+ lastTimestamp: string | null;
20
+ }
21
+ export interface ReadLogEntriesOptions {
22
+ source?: string;
23
+ level?: LoggingLevel;
24
+ search?: string;
25
+ limit?: number;
26
+ }
27
+ export declare const LOG_LEVELS: readonly LoggingLevel[];
28
+ export declare function shouldWriteLogLevel(level: LoggingLevel, configuredLevel: LoggingLevel): boolean;
29
+ export declare function isLoggingLevel(value: string | undefined): value is LoggingLevel;
30
+ //# sourceMappingURL=log-types.d.ts.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"log-types.d.ts","sourceRoot":"","sources":["../../../src/services/logging/log-types.ts"],"names":[],"mappings":"AAAA,OAAO,KAAK,EAAE,aAAa,EAAE,YAAY,EAAE,MAAM,mCAAmC,CAAC;AAErF,YAAY,EAAE,aAAa,EAAE,YAAY,EAAE,CAAC;AAE5C,MAAM,WAAW,QAAQ;IACvB,EAAE,EAAE,MAAM,CAAC;IACX,SAAS,EAAE,MAAM,CAAC;IAClB,KAAK,EAAE,YAAY,CAAC;IACpB,MAAM,EAAE,MAAM,CAAC;IACf,KAAK,EAAE,MAAM,CAAC;IACd,OAAO,EAAE,MAAM,CAAC;IAChB,SAAS,EAAE,MAAM,CAAC;IAClB,KAAK,EAAE,MAAM,CAAC;IACd,OAAO,CAAC,EAAE,MAAM,CAAC,MAAM,EAAE,OAAO,CAAC,CAAC;CACnC;AAED,MAAM,WAAW,gBAAgB;IAC/B,MAAM,EAAE,MAAM,CAAC;IACf,KAAK,EAAE,MAAM,CAAC;IACd,IAAI,EAAE,QAAQ,GAAG,QAAQ,CAAC;IAC1B,KAAK,EAAE,MAAM,CAAC;IACd,aAAa,EAAE,MAAM,GAAG,IAAI,CAAC;CAC9B;AAED,MAAM,WAAW,qBAAqB;IACpC,MAAM,CAAC,EAAE,MAAM,CAAC;IAChB,KAAK,CAAC,EAAE,YAAY,CAAC;IACrB,MAAM,CAAC,EAAE,MAAM,CAAC;IAChB,KAAK,CAAC,EAAE,MAAM,CAAC;CAChB;AAED,eAAO,MAAM,UAAU,EAAE,SAAS,YAAY,EAAuC,CAAC;AAStF,wBAAgB,mBAAmB,CAAC,KAAK,EAAE,YAAY,EAAE,eAAe,EAAE,YAAY,GAAG,OAAO,CAE/F;AAED,wBAAgB,cAAc,CAAC,KAAK,EAAE,MAAM,GAAG,SAAS,GAAG,KAAK,IAAI,YAAY,CAE/E"}
@@ -0,0 +1,19 @@
1
+ "use strict";
2
+ Object.defineProperty(exports, "__esModule", { value: true });
3
+ exports.isLoggingLevel = exports.shouldWriteLogLevel = exports.LOG_LEVELS = void 0;
4
+ exports.LOG_LEVELS = ['error', 'warn', 'info', 'debug'];
5
+ const LOG_LEVEL_PRIORITY = {
6
+ error: 0,
7
+ warn: 1,
8
+ info: 2,
9
+ debug: 3,
10
+ };
11
+ function shouldWriteLogLevel(level, configuredLevel) {
12
+ return LOG_LEVEL_PRIORITY[level] <= LOG_LEVEL_PRIORITY[configuredLevel];
13
+ }
14
+ exports.shouldWriteLogLevel = shouldWriteLogLevel;
15
+ function isLoggingLevel(value) {
16
+ return typeof value === 'string' && exports.LOG_LEVELS.includes(value);
17
+ }
18
+ exports.isLoggingLevel = isLoggingLevel;
19
+ //# sourceMappingURL=log-types.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"log-types.js","sourceRoot":"","sources":["../../../src/services/logging/log-types.ts"],"names":[],"mappings":";;;AA+Ba,QAAA,UAAU,GAA4B,CAAC,OAAO,EAAE,MAAM,EAAE,MAAM,EAAE,OAAO,CAAC,CAAC;AAEtF,MAAM,kBAAkB,GAAiC;IACvD,KAAK,EAAE,CAAC;IACR,IAAI,EAAE,CAAC;IACP,IAAI,EAAE,CAAC;IACP,KAAK,EAAE,CAAC;CACT,CAAC;AAEF,SAAgB,mBAAmB,CAAC,KAAmB,EAAE,eAA6B;IACpF,OAAO,kBAAkB,CAAC,KAAK,CAAC,IAAI,kBAAkB,CAAC,eAAe,CAAC,CAAC;AAC1E,CAAC;AAFD,kDAEC;AAED,SAAgB,cAAc,CAAC,KAAyB;IACtD,OAAO,OAAO,KAAK,KAAK,QAAQ,IAAI,kBAAU,CAAC,QAAQ,CAAC,KAAqB,CAAC,CAAC;AACjF,CAAC;AAFD,wCAEC"}
@@ -0,0 +1,9 @@
1
+ export interface Logger {
2
+ child(context: Record<string, unknown>): Logger;
3
+ debug(event: string, message: string, context?: Record<string, unknown>): void;
4
+ info(event: string, message: string, context?: Record<string, unknown>): void;
5
+ warn(event: string, message: string, context?: Record<string, unknown>): void;
6
+ error(event: string, message: string, context?: Record<string, unknown>): void;
7
+ }
8
+ export declare function createLogger(source: string, baseContext?: Record<string, unknown>): Logger;
9
+ //# sourceMappingURL=logger.d.ts.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"logger.d.ts","sourceRoot":"","sources":["../../../src/services/logging/logger.ts"],"names":[],"mappings":"AA6BA,MAAM,WAAW,MAAM;IACrB,KAAK,CAAC,OAAO,EAAE,MAAM,CAAC,MAAM,EAAE,OAAO,CAAC,GAAG,MAAM,CAAC;IAChD,KAAK,CAAC,KAAK,EAAE,MAAM,EAAE,OAAO,EAAE,MAAM,EAAE,OAAO,CAAC,EAAE,MAAM,CAAC,MAAM,EAAE,OAAO,CAAC,GAAG,IAAI,CAAC;IAC/E,IAAI,CAAC,KAAK,EAAE,MAAM,EAAE,OAAO,EAAE,MAAM,EAAE,OAAO,CAAC,EAAE,MAAM,CAAC,MAAM,EAAE,OAAO,CAAC,GAAG,IAAI,CAAC;IAC9E,IAAI,CAAC,KAAK,EAAE,MAAM,EAAE,OAAO,EAAE,MAAM,EAAE,OAAO,CAAC,EAAE,MAAM,CAAC,MAAM,EAAE,OAAO,CAAC,GAAG,IAAI,CAAC;IAC9E,KAAK,CAAC,KAAK,EAAE,MAAM,EAAE,OAAO,EAAE,MAAM,EAAE,OAAO,CAAC,EAAE,MAAM,CAAC,MAAM,EAAE,OAAO,CAAC,GAAG,IAAI,CAAC;CAChF;AAED,wBAAgB,YAAY,CAAC,MAAM,EAAE,MAAM,EAAE,WAAW,GAAE,MAAM,CAAC,MAAM,EAAE,OAAO,CAAM,GAAG,MAAM,CA6B9F"}
@@ -0,0 +1,46 @@
1
+ "use strict";
2
+ Object.defineProperty(exports, "__esModule", { value: true });
3
+ exports.createLogger = void 0;
4
+ const crypto_1 = require("crypto");
5
+ const log_config_1 = require("./log-config");
6
+ const log_redaction_1 = require("./log-redaction");
7
+ const log_storage_1 = require("./log-storage");
8
+ const processRunId = `${Date.now()}-${process.pid}-${Math.random().toString(36).slice(2, 10)}`;
9
+ function createEntry(source, level, event, message, context) {
10
+ const config = (0, log_config_1.getResolvedLoggingConfig)();
11
+ return {
12
+ id: (0, crypto_1.randomUUID)(),
13
+ timestamp: new Date().toISOString(),
14
+ level,
15
+ source,
16
+ event,
17
+ message,
18
+ processId: process.pid,
19
+ runId: processRunId,
20
+ context: config.redact ? (0, log_redaction_1.redactContext)(context) : context,
21
+ };
22
+ }
23
+ function createLogger(source, baseContext = {}) {
24
+ const write = (level, event, message, context) => {
25
+ (0, log_storage_1.appendStructuredLogEntry)(createEntry(source, level, event, message, { ...baseContext, ...(context || {}) }));
26
+ };
27
+ return {
28
+ child(context) {
29
+ return createLogger(source, { ...baseContext, ...context });
30
+ },
31
+ debug(event, message, context) {
32
+ write('debug', event, message, context);
33
+ },
34
+ info(event, message, context) {
35
+ write('info', event, message, context);
36
+ },
37
+ warn(event, message, context) {
38
+ write('warn', event, message, context);
39
+ },
40
+ error(event, message, context) {
41
+ write('error', event, message, context);
42
+ },
43
+ };
44
+ }
45
+ exports.createLogger = createLogger;
46
+ //# sourceMappingURL=logger.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"logger.js","sourceRoot":"","sources":["../../../src/services/logging/logger.ts"],"names":[],"mappings":";;;AAAA,mCAAoC;AACpC,6CAAwD;AACxD,mDAAgD;AAChD,+CAAyD;AAGzD,MAAM,YAAY,GAAG,GAAG,IAAI,CAAC,GAAG,EAAE,IAAI,OAAO,CAAC,GAAG,IAAI,IAAI,CAAC,MAAM,EAAE,CAAC,QAAQ,CAAC,EAAE,CAAC,CAAC,KAAK,CAAC,CAAC,EAAE,EAAE,CAAC,EAAE,CAAC;AAE/F,SAAS,WAAW,CAClB,MAAc,EACd,KAAmB,EACnB,KAAa,EACb,OAAe,EACf,OAAgC;IAEhC,MAAM,MAAM,GAAG,IAAA,qCAAwB,GAAE,CAAC;IAC1C,OAAO;QACL,EAAE,EAAE,IAAA,mBAAU,GAAE;QAChB,SAAS,EAAE,IAAI,IAAI,EAAE,CAAC,WAAW,EAAE;QACnC,KAAK;QACL,MAAM;QACN,KAAK;QACL,OAAO;QACP,SAAS,EAAE,OAAO,CAAC,GAAG;QACtB,KAAK,EAAE,YAAY;QACnB,OAAO,EAAE,MAAM,CAAC,MAAM,CAAC,CAAC,CAAC,IAAA,6BAAa,EAAC,OAAO,CAAC,CAAC,CAAC,CAAC,OAAO;KAC1D,CAAC;AACJ,CAAC;AAUD,SAAgB,YAAY,CAAC,MAAc,EAAE,cAAuC,EAAE;IACpF,MAAM,KAAK,GAAG,CACZ,KAAmB,EACnB,KAAa,EACb,OAAe,EACf,OAAiC,EACjC,EAAE;QACF,IAAA,sCAAwB,EACtB,WAAW,CAAC,MAAM,EAAE,KAAK,EAAE,KAAK,EAAE,OAAO,EAAE,EAAE,GAAG,WAAW,EAAE,GAAG,CAAC,OAAO,IAAI,EAAE,CAAC,EAAE,CAAC,CACnF,CAAC;IACJ,CAAC,CAAC;IAEF,OAAO;QACL,KAAK,CAAC,OAAgC;YACpC,OAAO,YAAY,CAAC,MAAM,EAAE,EAAE,GAAG,WAAW,EAAE,GAAG,OAAO,EAAE,CAAC,CAAC;QAC9D,CAAC;QACD,KAAK,CAAC,KAAK,EAAE,OAAO,EAAE,OAAO;YAC3B,KAAK,CAAC,OAAO,EAAE,KAAK,EAAE,OAAO,EAAE,OAAO,CAAC,CAAC;QAC1C,CAAC;QACD,IAAI,CAAC,KAAK,EAAE,OAAO,EAAE,OAAO;YAC1B,KAAK,CAAC,MAAM,EAAE,KAAK,EAAE,OAAO,EAAE,OAAO,CAAC,CAAC;QACzC,CAAC;QACD,IAAI,CAAC,KAAK,EAAE,OAAO,EAAE,OAAO;YAC1B,KAAK,CAAC,MAAM,EAAE,KAAK,EAAE,OAAO,EAAE,OAAO,CAAC,CAAC;QACzC,CAAC;QACD,KAAK,CAAC,KAAK,EAAE,OAAO,EAAE,OAAO;YAC3B,KAAK,CAAC,OAAO,EAAE,KAAK,EAAE,OAAO,EAAE,OAAO,CAAC,CAAC;QAC1C,CAAC;KACF,CAAC;AACJ,CAAC;AA7BD,oCA6BC"}