@serve.zone/dcrouter 11.0.22 → 11.0.23

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 (105) hide show
  1. package/dist_serve/bundle.js +1 -1
  2. package/dist_ts/00_commitinfo_data.d.ts +8 -0
  3. package/dist_ts/00_commitinfo_data.js +9 -0
  4. package/dist_ts/cache/classes.cache.cleaner.d.ts +47 -0
  5. package/dist_ts/cache/classes.cache.cleaner.js +130 -0
  6. package/dist_ts/cache/classes.cached.document.d.ts +76 -0
  7. package/dist_ts/cache/classes.cached.document.js +100 -0
  8. package/dist_ts/cache/classes.cachedb.d.ts +60 -0
  9. package/dist_ts/cache/classes.cachedb.js +126 -0
  10. package/dist_ts/cache/documents/classes.cached.email.d.ts +125 -0
  11. package/dist_ts/cache/documents/classes.cached.email.js +337 -0
  12. package/dist_ts/cache/documents/classes.cached.ip.reputation.d.ts +119 -0
  13. package/dist_ts/cache/documents/classes.cached.ip.reputation.js +323 -0
  14. package/dist_ts/cache/documents/index.d.ts +2 -0
  15. package/dist_ts/cache/documents/index.js +3 -0
  16. package/dist_ts/cache/index.d.ts +4 -0
  17. package/dist_ts/cache/index.js +7 -0
  18. package/dist_ts/classes.cert-provision-scheduler.d.ts +53 -0
  19. package/dist_ts/classes.cert-provision-scheduler.js +110 -0
  20. package/dist_ts/classes.storage-cert-manager.d.ts +18 -0
  21. package/dist_ts/classes.storage-cert-manager.js +43 -0
  22. package/dist_ts/config/classes.api-token-manager.d.ts +46 -0
  23. package/dist_ts/config/classes.api-token-manager.js +150 -0
  24. package/dist_ts/config/classes.route-config-manager.d.ts +35 -0
  25. package/dist_ts/config/classes.route-config-manager.js +231 -0
  26. package/dist_ts/config/index.d.ts +3 -0
  27. package/dist_ts/config/index.js +5 -0
  28. package/dist_ts/config/validator.d.ts +104 -0
  29. package/dist_ts/config/validator.js +152 -0
  30. package/dist_ts/errors/base.errors.d.ts +224 -0
  31. package/dist_ts/errors/base.errors.js +320 -0
  32. package/dist_ts/errors/error.codes.d.ts +115 -0
  33. package/dist_ts/errors/error.codes.js +136 -0
  34. package/dist_ts/logger.d.ts +21 -0
  35. package/dist_ts/logger.js +81 -0
  36. package/dist_ts/monitoring/classes.metricscache.d.ts +32 -0
  37. package/dist_ts/monitoring/classes.metricscache.js +63 -0
  38. package/dist_ts/monitoring/classes.metricsmanager.d.ts +178 -0
  39. package/dist_ts/monitoring/classes.metricsmanager.js +642 -0
  40. package/dist_ts/monitoring/index.d.ts +1 -0
  41. package/dist_ts/monitoring/index.js +2 -0
  42. package/dist_ts/opsserver/classes.opsserver.d.ts +37 -0
  43. package/dist_ts/opsserver/classes.opsserver.js +85 -0
  44. package/dist_ts/opsserver/handlers/admin.handler.d.ts +31 -0
  45. package/dist_ts/opsserver/handlers/admin.handler.js +180 -0
  46. package/dist_ts/opsserver/handlers/api-token.handler.d.ts +6 -0
  47. package/dist_ts/opsserver/handlers/api-token.handler.js +62 -0
  48. package/dist_ts/opsserver/handlers/certificate.handler.d.ts +32 -0
  49. package/dist_ts/opsserver/handlers/certificate.handler.js +421 -0
  50. package/dist_ts/opsserver/handlers/config.handler.d.ts +7 -0
  51. package/dist_ts/opsserver/handlers/config.handler.js +192 -0
  52. package/dist_ts/opsserver/handlers/email-ops.handler.d.ts +30 -0
  53. package/dist_ts/opsserver/handlers/email-ops.handler.js +227 -0
  54. package/dist_ts/opsserver/handlers/index.d.ts +11 -0
  55. package/dist_ts/opsserver/handlers/index.js +12 -0
  56. package/dist_ts/opsserver/handlers/logs.handler.d.ts +25 -0
  57. package/dist_ts/opsserver/handlers/logs.handler.js +256 -0
  58. package/dist_ts/opsserver/handlers/radius.handler.d.ts +6 -0
  59. package/dist_ts/opsserver/handlers/radius.handler.js +295 -0
  60. package/dist_ts/opsserver/handlers/remoteingress.handler.d.ts +6 -0
  61. package/dist_ts/opsserver/handlers/remoteingress.handler.js +156 -0
  62. package/dist_ts/opsserver/handlers/route-management.handler.d.ts +14 -0
  63. package/dist_ts/opsserver/handlers/route-management.handler.js +117 -0
  64. package/dist_ts/opsserver/handlers/security.handler.d.ts +9 -0
  65. package/dist_ts/opsserver/handlers/security.handler.js +231 -0
  66. package/dist_ts/opsserver/handlers/stats.handler.d.ts +11 -0
  67. package/dist_ts/opsserver/handlers/stats.handler.js +399 -0
  68. package/dist_ts/opsserver/helpers/guards.d.ts +27 -0
  69. package/dist_ts/opsserver/helpers/guards.js +43 -0
  70. package/dist_ts/opsserver/index.d.ts +1 -0
  71. package/dist_ts/opsserver/index.js +2 -0
  72. package/dist_ts/paths.d.ts +26 -0
  73. package/dist_ts/paths.js +45 -0
  74. package/dist_ts/plugins.d.ts +79 -0
  75. package/dist_ts/plugins.js +113 -0
  76. package/dist_ts/radius/classes.accounting.manager.d.ts +218 -0
  77. package/dist_ts/radius/classes.accounting.manager.js +417 -0
  78. package/dist_ts/radius/classes.radius.server.d.ts +171 -0
  79. package/dist_ts/radius/classes.radius.server.js +385 -0
  80. package/dist_ts/radius/classes.vlan.manager.d.ts +128 -0
  81. package/dist_ts/radius/classes.vlan.manager.js +279 -0
  82. package/dist_ts/radius/index.d.ts +13 -0
  83. package/dist_ts/radius/index.js +14 -0
  84. package/dist_ts/remoteingress/classes.remoteingress-manager.d.ts +82 -0
  85. package/dist_ts/remoteingress/classes.remoteingress-manager.js +227 -0
  86. package/dist_ts/remoteingress/classes.tunnel-manager.d.ts +59 -0
  87. package/dist_ts/remoteingress/classes.tunnel-manager.js +165 -0
  88. package/dist_ts/remoteingress/index.d.ts +2 -0
  89. package/dist_ts/remoteingress/index.js +3 -0
  90. package/dist_ts/security/classes.contentscanner.d.ts +164 -0
  91. package/dist_ts/security/classes.contentscanner.js +642 -0
  92. package/dist_ts/security/classes.ipreputationchecker.d.ts +160 -0
  93. package/dist_ts/security/classes.ipreputationchecker.js +537 -0
  94. package/dist_ts/security/classes.securitylogger.d.ts +144 -0
  95. package/dist_ts/security/classes.securitylogger.js +233 -0
  96. package/dist_ts/security/index.d.ts +3 -0
  97. package/dist_ts/security/index.js +4 -0
  98. package/dist_ts/storage/classes.storagemanager.d.ts +83 -0
  99. package/dist_ts/storage/classes.storagemanager.js +350 -0
  100. package/dist_ts/storage/index.d.ts +1 -0
  101. package/dist_ts/storage/index.js +3 -0
  102. package/dist_ts_web/00_commitinfo_data.js +1 -1
  103. package/package.json +2 -2
  104. package/ts/00_commitinfo_data.ts +1 -1
  105. package/ts_web/00_commitinfo_data.ts +1 -1
@@ -0,0 +1,81 @@
1
+ import * as plugins from './plugins.js';
2
+ import { randomUUID } from 'node:crypto';
3
+ import { SmartlogDestinationBuffer } from '@push.rocks/smartlog/destination-buffer';
4
+ // Map NODE_ENV to valid TEnvironment
5
+ const nodeEnv = process.env.NODE_ENV || 'production';
6
+ const envMap = {
7
+ 'development': 'local',
8
+ 'test': 'test',
9
+ 'staging': 'staging',
10
+ 'production': 'production'
11
+ };
12
+ // In-memory log buffer for the OpsServer UI
13
+ export const logBuffer = new SmartlogDestinationBuffer({ maxEntries: 2000 });
14
+ // Default Smartlog instance (exported so OpsServer can add push destinations)
15
+ export const baseLogger = new plugins.smartlog.Smartlog({
16
+ logContext: {
17
+ environment: envMap[nodeEnv] || 'production',
18
+ runtime: 'node',
19
+ zone: 'serve.zone',
20
+ }
21
+ });
22
+ // Wire the buffer destination so all logs are captured
23
+ baseLogger.addLogDestination(logBuffer);
24
+ // Extended logger compatible with the original enhanced logger API
25
+ class StandardLogger {
26
+ defaultContext = {};
27
+ correlationId = null;
28
+ constructor() { }
29
+ // Log methods
30
+ log(level, message, context = {}) {
31
+ const combinedContext = {
32
+ ...this.defaultContext,
33
+ ...context
34
+ };
35
+ if (this.correlationId) {
36
+ combinedContext.correlation_id = this.correlationId;
37
+ }
38
+ baseLogger.log(level, message, combinedContext);
39
+ }
40
+ error(message, context = {}) {
41
+ this.log('error', message, context);
42
+ }
43
+ warn(message, context = {}) {
44
+ this.log('warn', message, context);
45
+ }
46
+ info(message, context = {}) {
47
+ this.log('info', message, context);
48
+ }
49
+ success(message, context = {}) {
50
+ this.log('success', message, context);
51
+ }
52
+ debug(message, context = {}) {
53
+ this.log('debug', message, context);
54
+ }
55
+ // Context management
56
+ setContext(context, overwrite = false) {
57
+ if (overwrite) {
58
+ this.defaultContext = context;
59
+ }
60
+ else {
61
+ this.defaultContext = {
62
+ ...this.defaultContext,
63
+ ...context
64
+ };
65
+ }
66
+ }
67
+ // Correlation ID management
68
+ setCorrelationId(id = null) {
69
+ this.correlationId = id || randomUUID();
70
+ return this.correlationId;
71
+ }
72
+ getCorrelationId() {
73
+ return this.correlationId;
74
+ }
75
+ clearCorrelationId() {
76
+ this.correlationId = null;
77
+ }
78
+ }
79
+ // Export a singleton instance (build verification)
80
+ export const logger = new StandardLogger();
81
+ //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoibG9nZ2VyLmpzIiwic291cmNlUm9vdCI6IiIsInNvdXJjZXMiOlsiLi4vLi4vdHMvbG9nZ2VyLnRzIl0sIm5hbWVzIjpbXSwibWFwcGluZ3MiOiJBQUFBLE9BQU8sS0FBSyxPQUFPLE1BQU0sY0FBYyxDQUFDO0FBQ3hDLE9BQU8sRUFBRSxVQUFVLEVBQUUsTUFBTSxhQUFhLENBQUM7QUFDekMsT0FBTyxFQUFFLHlCQUF5QixFQUFFLE1BQU0seUNBQXlDLENBQUM7QUFFcEYscUNBQXFDO0FBQ3JDLE1BQU0sT0FBTyxHQUFHLE9BQU8sQ0FBQyxHQUFHLENBQUMsUUFBUSxJQUFJLFlBQVksQ0FBQztBQUNyRCxNQUFNLE1BQU0sR0FBZ0U7SUFDMUUsYUFBYSxFQUFFLE9BQU87SUFDdEIsTUFBTSxFQUFFLE1BQU07SUFDZCxTQUFTLEVBQUUsU0FBUztJQUNwQixZQUFZLEVBQUUsWUFBWTtDQUMzQixDQUFDO0FBRUYsNENBQTRDO0FBQzVDLE1BQU0sQ0FBQyxNQUFNLFNBQVMsR0FBRyxJQUFJLHlCQUF5QixDQUFDLEVBQUUsVUFBVSxFQUFFLElBQUksRUFBRSxDQUFDLENBQUM7QUFFN0UsOEVBQThFO0FBQzlFLE1BQU0sQ0FBQyxNQUFNLFVBQVUsR0FBRyxJQUFJLE9BQU8sQ0FBQyxRQUFRLENBQUMsUUFBUSxDQUFDO0lBQ3RELFVBQVUsRUFBRTtRQUNWLFdBQVcsRUFBRSxNQUFNLENBQUMsT0FBTyxDQUFDLElBQUksWUFBWTtRQUM1QyxPQUFPLEVBQUUsTUFBTTtRQUNmLElBQUksRUFBRSxZQUFZO0tBQ25CO0NBQ0YsQ0FBQyxDQUFDO0FBRUgsdURBQXVEO0FBQ3ZELFVBQVUsQ0FBQyxpQkFBaUIsQ0FBQyxTQUFTLENBQUMsQ0FBQztBQUV4QyxtRUFBbUU7QUFDbkUsTUFBTSxjQUFjO0lBQ1YsY0FBYyxHQUF3QixFQUFFLENBQUM7SUFDekMsYUFBYSxHQUFrQixJQUFJLENBQUM7SUFFNUMsZ0JBQWUsQ0FBQztJQUVoQixjQUFjO0lBQ1AsR0FBRyxDQUFDLEtBQXNELEVBQUUsT0FBZSxFQUFFLFVBQStCLEVBQUU7UUFDbkgsTUFBTSxlQUFlLEdBQUc7WUFDdEIsR0FBRyxJQUFJLENBQUMsY0FBYztZQUN0QixHQUFHLE9BQU87U0FDWCxDQUFDO1FBRUYsSUFBSSxJQUFJLENBQUMsYUFBYSxFQUFFLENBQUM7WUFDdkIsZUFBZSxDQUFDLGNBQWMsR0FBRyxJQUFJLENBQUMsYUFBYSxDQUFDO1FBQ3RELENBQUM7UUFFRCxVQUFVLENBQUMsR0FBRyxDQUFDLEtBQUssRUFBRSxPQUFPLEVBQUUsZUFBZSxDQUFDLENBQUM7SUFDbEQsQ0FBQztJQUVNLEtBQUssQ0FBQyxPQUFlLEVBQUUsVUFBK0IsRUFBRTtRQUM3RCxJQUFJLENBQUMsR0FBRyxDQUFDLE9BQU8sRUFBRSxPQUFPLEVBQUUsT0FBTyxDQUFDLENBQUM7SUFDdEMsQ0FBQztJQUVNLElBQUksQ0FBQyxPQUFlLEVBQUUsVUFBK0IsRUFBRTtRQUM1RCxJQUFJLENBQUMsR0FBRyxDQUFDLE1BQU0sRUFBRSxPQUFPLEVBQUUsT0FBTyxDQUFDLENBQUM7SUFDckMsQ0FBQztJQUVNLElBQUksQ0FBQyxPQUFlLEVBQUUsVUFBK0IsRUFBRTtRQUM1RCxJQUFJLENBQUMsR0FBRyxDQUFDLE1BQU0sRUFBRSxPQUFPLEVBQUUsT0FBTyxDQUFDLENBQUM7SUFDckMsQ0FBQztJQUVNLE9BQU8sQ0FBQyxPQUFlLEVBQUUsVUFBK0IsRUFBRTtRQUMvRCxJQUFJLENBQUMsR0FBRyxDQUFDLFNBQVMsRUFBRSxPQUFPLEVBQUUsT0FBTyxDQUFDLENBQUM7SUFDeEMsQ0FBQztJQUVNLEtBQUssQ0FBQyxPQUFlLEVBQUUsVUFBK0IsRUFBRTtRQUM3RCxJQUFJLENBQUMsR0FBRyxDQUFDLE9BQU8sRUFBRSxPQUFPLEVBQUUsT0FBTyxDQUFDLENBQUM7SUFDdEMsQ0FBQztJQUVELHFCQUFxQjtJQUNkLFVBQVUsQ0FBQyxPQUE0QixFQUFFLFlBQXFCLEtBQUs7UUFDeEUsSUFBSSxTQUFTLEVBQUUsQ0FBQztZQUNkLElBQUksQ0FBQyxjQUFjLEdBQUcsT0FBTyxDQUFDO1FBQ2hDLENBQUM7YUFBTSxDQUFDO1lBQ04sSUFBSSxDQUFDLGNBQWMsR0FBRztnQkFDcEIsR0FBRyxJQUFJLENBQUMsY0FBYztnQkFDdEIsR0FBRyxPQUFPO2FBQ1gsQ0FBQztRQUNKLENBQUM7SUFDSCxDQUFDO0lBRUQsNEJBQTRCO0lBQ3JCLGdCQUFnQixDQUFDLEtBQW9CLElBQUk7UUFDOUMsSUFBSSxDQUFDLGFBQWEsR0FBRyxFQUFFLElBQUksVUFBVSxFQUFFLENBQUM7UUFDeEMsT0FBTyxJQUFJLENBQUMsYUFBYSxDQUFDO0lBQzVCLENBQUM7SUFFTSxnQkFBZ0I7UUFDckIsT0FBTyxJQUFJLENBQUMsYUFBYSxDQUFDO0lBQzVCLENBQUM7SUFFTSxrQkFBa0I7UUFDdkIsSUFBSSxDQUFDLGFBQWEsR0FBRyxJQUFJLENBQUM7SUFDNUIsQ0FBQztDQUNGO0FBRUQsbURBQW1EO0FBQ25ELE1BQU0sQ0FBQyxNQUFNLE1BQU0sR0FBRyxJQUFJLGNBQWMsRUFBRSxDQUFDIn0=
@@ -0,0 +1,32 @@
1
+ export interface ICacheEntry<T> {
2
+ data: T;
3
+ timestamp: number;
4
+ }
5
+ export declare class MetricsCache {
6
+ private cache;
7
+ private readonly defaultTTL;
8
+ constructor(defaultTTL?: number);
9
+ /**
10
+ * Get cached data or compute and cache it
11
+ */
12
+ get<T>(key: string, computeFn: () => T | Promise<T>, ttl?: number): T | Promise<T>;
13
+ /**
14
+ * Invalidate a specific cache entry
15
+ */
16
+ invalidate(key: string): void;
17
+ /**
18
+ * Clear all cache entries
19
+ */
20
+ clear(): void;
21
+ /**
22
+ * Get cache statistics
23
+ */
24
+ getStats(): {
25
+ size: number;
26
+ keys: string[];
27
+ };
28
+ /**
29
+ * Clean up expired entries
30
+ */
31
+ cleanup(): void;
32
+ }
@@ -0,0 +1,63 @@
1
+ export class MetricsCache {
2
+ cache = new Map();
3
+ defaultTTL;
4
+ constructor(defaultTTL = 500) {
5
+ this.defaultTTL = defaultTTL;
6
+ }
7
+ /**
8
+ * Get cached data or compute and cache it
9
+ */
10
+ get(key, computeFn, ttl) {
11
+ const cached = this.cache.get(key);
12
+ const now = Date.now();
13
+ const actualTTL = ttl ?? this.defaultTTL;
14
+ if (cached && (now - cached.timestamp) < actualTTL) {
15
+ return cached.data;
16
+ }
17
+ const result = computeFn();
18
+ // Handle both sync and async compute functions
19
+ if (result instanceof Promise) {
20
+ return result.then(data => {
21
+ this.cache.set(key, { data, timestamp: now });
22
+ return data;
23
+ });
24
+ }
25
+ else {
26
+ this.cache.set(key, { data: result, timestamp: now });
27
+ return result;
28
+ }
29
+ }
30
+ /**
31
+ * Invalidate a specific cache entry
32
+ */
33
+ invalidate(key) {
34
+ this.cache.delete(key);
35
+ }
36
+ /**
37
+ * Clear all cache entries
38
+ */
39
+ clear() {
40
+ this.cache.clear();
41
+ }
42
+ /**
43
+ * Get cache statistics
44
+ */
45
+ getStats() {
46
+ return {
47
+ size: this.cache.size,
48
+ keys: Array.from(this.cache.keys())
49
+ };
50
+ }
51
+ /**
52
+ * Clean up expired entries
53
+ */
54
+ cleanup() {
55
+ const now = Date.now();
56
+ for (const [key, entry] of this.cache.entries()) {
57
+ if (now - entry.timestamp > this.defaultTTL) {
58
+ this.cache.delete(key);
59
+ }
60
+ }
61
+ }
62
+ }
63
+ //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiY2xhc3Nlcy5tZXRyaWNzY2FjaGUuanMiLCJzb3VyY2VSb290IjoiIiwic291cmNlcyI6WyIuLi8uLi8uLi90cy9tb25pdG9yaW5nL2NsYXNzZXMubWV0cmljc2NhY2hlLnRzIl0sIm5hbWVzIjpbXSwibWFwcGluZ3MiOiJBQUtBLE1BQU0sT0FBTyxZQUFZO0lBQ2YsS0FBSyxHQUFHLElBQUksR0FBRyxFQUE0QixDQUFDO0lBQ25DLFVBQVUsQ0FBUztJQUVwQyxZQUFZLGFBQXFCLEdBQUc7UUFDbEMsSUFBSSxDQUFDLFVBQVUsR0FBRyxVQUFVLENBQUM7SUFDL0IsQ0FBQztJQUVEOztPQUVHO0lBQ0ksR0FBRyxDQUFJLEdBQVcsRUFBRSxTQUErQixFQUFFLEdBQVk7UUFDdEUsTUFBTSxNQUFNLEdBQUcsSUFBSSxDQUFDLEtBQUssQ0FBQyxHQUFHLENBQUMsR0FBRyxDQUFDLENBQUM7UUFDbkMsTUFBTSxHQUFHLEdBQUcsSUFBSSxDQUFDLEdBQUcsRUFBRSxDQUFDO1FBQ3ZCLE1BQU0sU0FBUyxHQUFHLEdBQUcsSUFBSSxJQUFJLENBQUMsVUFBVSxDQUFDO1FBRXpDLElBQUksTUFBTSxJQUFJLENBQUMsR0FBRyxHQUFHLE1BQU0sQ0FBQyxTQUFTLENBQUMsR0FBRyxTQUFTLEVBQUUsQ0FBQztZQUNuRCxPQUFPLE1BQU0sQ0FBQyxJQUFJLENBQUM7UUFDckIsQ0FBQztRQUVELE1BQU0sTUFBTSxHQUFHLFNBQVMsRUFBRSxDQUFDO1FBRTNCLCtDQUErQztRQUMvQyxJQUFJLE1BQU0sWUFBWSxPQUFPLEVBQUUsQ0FBQztZQUM5QixPQUFPLE1BQU0sQ0FBQyxJQUFJLENBQUMsSUFBSSxDQUFDLEVBQUU7Z0JBQ3hCLElBQUksQ0FBQyxLQUFLLENBQUMsR0FBRyxDQUFDLEdBQUcsRUFBRSxFQUFFLElBQUksRUFBRSxTQUFTLEVBQUUsR0FBRyxFQUFFLENBQUMsQ0FBQztnQkFDOUMsT0FBTyxJQUFJLENBQUM7WUFDZCxDQUFDLENBQUMsQ0FBQztRQUNMLENBQUM7YUFBTSxDQUFDO1lBQ04sSUFBSSxDQUFDLEtBQUssQ0FBQyxHQUFHLENBQUMsR0FBRyxFQUFFLEVBQUUsSUFBSSxFQUFFLE1BQU0sRUFBRSxTQUFTLEVBQUUsR0FBRyxFQUFFLENBQUMsQ0FBQztZQUN0RCxPQUFPLE1BQU0sQ0FBQztRQUNoQixDQUFDO0lBQ0gsQ0FBQztJQUVEOztPQUVHO0lBQ0ksVUFBVSxDQUFDLEdBQVc7UUFDM0IsSUFBSSxDQUFDLEtBQUssQ0FBQyxNQUFNLENBQUMsR0FBRyxDQUFDLENBQUM7SUFDekIsQ0FBQztJQUVEOztPQUVHO0lBQ0ksS0FBSztRQUNWLElBQUksQ0FBQyxLQUFLLENBQUMsS0FBSyxFQUFFLENBQUM7SUFDckIsQ0FBQztJQUVEOztPQUVHO0lBQ0ksUUFBUTtRQUNiLE9BQU87WUFDTCxJQUFJLEVBQUUsSUFBSSxDQUFDLEtBQUssQ0FBQyxJQUFJO1lBQ3JCLElBQUksRUFBRSxLQUFLLENBQUMsSUFBSSxDQUFDLElBQUksQ0FBQyxLQUFLLENBQUMsSUFBSSxFQUFFLENBQUM7U0FDcEMsQ0FBQztJQUNKLENBQUM7SUFFRDs7T0FFRztJQUNJLE9BQU87UUFDWixNQUFNLEdBQUcsR0FBRyxJQUFJLENBQUMsR0FBRyxFQUFFLENBQUM7UUFDdkIsS0FBSyxNQUFNLENBQUMsR0FBRyxFQUFFLEtBQUssQ0FBQyxJQUFJLElBQUksQ0FBQyxLQUFLLENBQUMsT0FBTyxFQUFFLEVBQUUsQ0FBQztZQUNoRCxJQUFJLEdBQUcsR0FBRyxLQUFLLENBQUMsU0FBUyxHQUFHLElBQUksQ0FBQyxVQUFVLEVBQUUsQ0FBQztnQkFDNUMsSUFBSSxDQUFDLEtBQUssQ0FBQyxNQUFNLENBQUMsR0FBRyxDQUFDLENBQUM7WUFDekIsQ0FBQztRQUNILENBQUM7SUFDSCxDQUFDO0NBQ0YifQ==
@@ -0,0 +1,178 @@
1
+ import { DcRouter } from '../classes.dcrouter.js';
2
+ export declare class MetricsManager {
3
+ private metricsLogger;
4
+ private smartMetrics;
5
+ private dcRouter;
6
+ private resetInterval?;
7
+ private metricsCache;
8
+ private readonly MAX_TOP_DOMAINS;
9
+ private emailMetrics;
10
+ private dnsMetrics;
11
+ private emailMinuteBuckets;
12
+ private dnsMinuteBuckets;
13
+ private securityMetrics;
14
+ constructor(dcRouter: DcRouter);
15
+ start(): Promise<void>;
16
+ stop(): Promise<void>;
17
+ getServerStats(): Promise<{
18
+ uptime: number;
19
+ startTime: number;
20
+ memoryUsage: {
21
+ heapUsed: number;
22
+ heapTotal: number;
23
+ external: number;
24
+ rss: number;
25
+ maxMemoryMB: number;
26
+ actualUsageBytes: number;
27
+ actualUsagePercentage: number;
28
+ };
29
+ cpuUsage: {
30
+ user: number;
31
+ system: number;
32
+ };
33
+ activeConnections: any;
34
+ totalConnections: number;
35
+ requestsPerSecond: number;
36
+ throughput: {
37
+ bytesIn: number;
38
+ bytesOut: number;
39
+ bytesInPerSecond: number;
40
+ bytesOutPerSecond: number;
41
+ };
42
+ }>;
43
+ getEmailStats(): Promise<{
44
+ sentToday: number;
45
+ receivedToday: number;
46
+ failedToday: number;
47
+ bounceRate: number;
48
+ deliveryRate: number;
49
+ queueSize: number;
50
+ averageDeliveryTime: number;
51
+ topRecipients: {
52
+ email: string;
53
+ count: number;
54
+ }[];
55
+ recentActivity: {
56
+ timestamp: number;
57
+ type: string;
58
+ details: string;
59
+ }[];
60
+ }>;
61
+ getDnsStats(): Promise<{
62
+ queriesPerSecond: number;
63
+ totalQueries: number;
64
+ cacheHits: number;
65
+ cacheMisses: number;
66
+ cacheHitRate: number;
67
+ topDomains: {
68
+ domain: string;
69
+ count: number;
70
+ }[];
71
+ queryTypes: Record<string, number>;
72
+ averageResponseTime: number;
73
+ activeDomains: number;
74
+ recentQueries: {
75
+ timestamp: number;
76
+ domain: string;
77
+ type: string;
78
+ answered: boolean;
79
+ responseTimeMs: number;
80
+ }[];
81
+ }>;
82
+ /**
83
+ * Sync security metrics from the SecurityLogger singleton (last 24h).
84
+ * Called before returning security stats so counters reflect real events.
85
+ */
86
+ private syncFromSecurityLogger;
87
+ getSecurityStats(): Promise<{
88
+ blockedIPs: number;
89
+ authFailures: number;
90
+ spamDetected: number;
91
+ malwareDetected: number;
92
+ phishingDetected: number;
93
+ totalThreatsBlocked: number;
94
+ recentIncidents: {
95
+ timestamp: number;
96
+ type: string;
97
+ severity: string;
98
+ details: string;
99
+ }[];
100
+ }>;
101
+ getConnectionInfo(): Promise<any[]>;
102
+ trackEmailSent(recipient?: string, deliveryTimeMs?: number): void;
103
+ trackEmailReceived(sender?: string): void;
104
+ trackEmailFailed(recipient?: string, reason?: string): void;
105
+ trackEmailBounced(recipient?: string): void;
106
+ updateQueueSize(size: number): void;
107
+ trackDnsQuery(queryType: string, domain: string, cacheHit: boolean, responseTimeMs?: number, answered?: boolean): void;
108
+ trackBlockedIP(ip?: string, reason?: string): void;
109
+ trackAuthFailure(username?: string, ip?: string): void;
110
+ trackSpamDetected(sender?: string): void;
111
+ trackMalwareDetected(source?: string): void;
112
+ trackPhishingDetected(source?: string): void;
113
+ getNetworkStats(): Promise<{
114
+ connectionsByIP: Map<string, number>;
115
+ throughputRate: {
116
+ bytesInPerSecond: number;
117
+ bytesOutPerSecond: number;
118
+ };
119
+ topIPs: Array<{
120
+ ip: string;
121
+ count: number;
122
+ }>;
123
+ totalDataTransferred: {
124
+ bytesIn: number;
125
+ bytesOut: number;
126
+ };
127
+ throughputHistory: Array<{
128
+ timestamp: number;
129
+ in: number;
130
+ out: number;
131
+ }>;
132
+ throughputByIP: Map<string, {
133
+ in: number;
134
+ out: number;
135
+ }>;
136
+ requestsPerSecond: number;
137
+ requestsTotal: number;
138
+ }>;
139
+ private static minuteKey;
140
+ private incrementEmailBucket;
141
+ private incrementDnsBucket;
142
+ /**
143
+ * Increment the per-second query counter in the ring buffer.
144
+ * Zeros any stale slots between the last write and the current second.
145
+ */
146
+ private incrementQueryRing;
147
+ /**
148
+ * Sum query counts from the ring buffer for the last N seconds.
149
+ */
150
+ private getQueryRingSum;
151
+ private pruneOldBuckets;
152
+ /**
153
+ * Get email time-series data for the last N hours, aggregated per minute.
154
+ */
155
+ getEmailTimeSeries(hours?: number): {
156
+ sent: Array<{
157
+ timestamp: number;
158
+ value: number;
159
+ }>;
160
+ received: Array<{
161
+ timestamp: number;
162
+ value: number;
163
+ }>;
164
+ failed: Array<{
165
+ timestamp: number;
166
+ value: number;
167
+ }>;
168
+ };
169
+ /**
170
+ * Get DNS time-series data for the last N hours, aggregated per minute.
171
+ */
172
+ getDnsTimeSeries(hours?: number): {
173
+ queries: Array<{
174
+ timestamp: number;
175
+ value: number;
176
+ }>;
177
+ };
178
+ }