@serve.zone/dcrouter 11.0.38 → 11.0.39

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 (78) hide show
  1. package/dist_serve/bundle.js +1 -1
  2. package/dist_ts_web/00_commitinfo_data.js +1 -1
  3. package/package.json +2 -2
  4. package/ts/00_commitinfo_data.ts +1 -1
  5. package/ts_web/00_commitinfo_data.ts +1 -1
  6. package/dist_ts/cache/classes.cache.cleaner.d.ts +0 -47
  7. package/dist_ts/cache/classes.cache.cleaner.js +0 -130
  8. package/dist_ts/cache/documents/classes.cached.email.d.ts +0 -125
  9. package/dist_ts/cache/documents/classes.cached.email.js +0 -337
  10. package/dist_ts/cache/documents/classes.cached.ip.reputation.d.ts +0 -119
  11. package/dist_ts/cache/documents/classes.cached.ip.reputation.js +0 -323
  12. package/dist_ts/cache/documents/index.d.ts +0 -2
  13. package/dist_ts/cache/documents/index.js +0 -3
  14. package/dist_ts/cache/index.d.ts +0 -4
  15. package/dist_ts/cache/index.js +0 -7
  16. package/dist_ts/classes.cert-provision-scheduler.d.ts +0 -53
  17. package/dist_ts/classes.cert-provision-scheduler.js +0 -110
  18. package/dist_ts/classes.storage-cert-manager.d.ts +0 -18
  19. package/dist_ts/classes.storage-cert-manager.js +0 -43
  20. package/dist_ts/errors/base.errors.js +0 -320
  21. package/dist_ts/errors/error.codes.d.ts +0 -115
  22. package/dist_ts/errors/error.codes.js +0 -136
  23. package/dist_ts/monitoring/classes.metricscache.d.ts +0 -32
  24. package/dist_ts/monitoring/classes.metricscache.js +0 -63
  25. package/dist_ts/monitoring/classes.metricsmanager.d.ts +0 -178
  26. package/dist_ts/monitoring/classes.metricsmanager.js +0 -642
  27. package/dist_ts/monitoring/index.d.ts +0 -1
  28. package/dist_ts/monitoring/index.js +0 -2
  29. package/dist_ts/opsserver/classes.opsserver.d.ts +0 -37
  30. package/dist_ts/opsserver/classes.opsserver.js +0 -85
  31. package/dist_ts/opsserver/handlers/admin.handler.d.ts +0 -31
  32. package/dist_ts/opsserver/handlers/admin.handler.js +0 -180
  33. package/dist_ts/opsserver/handlers/api-token.handler.d.ts +0 -6
  34. package/dist_ts/opsserver/handlers/api-token.handler.js +0 -62
  35. package/dist_ts/opsserver/handlers/certificate.handler.d.ts +0 -32
  36. package/dist_ts/opsserver/handlers/certificate.handler.js +0 -421
  37. package/dist_ts/opsserver/handlers/config.handler.d.ts +0 -7
  38. package/dist_ts/opsserver/handlers/config.handler.js +0 -192
  39. package/dist_ts/opsserver/handlers/email-ops.handler.d.ts +0 -30
  40. package/dist_ts/opsserver/handlers/email-ops.handler.js +0 -227
  41. package/dist_ts/opsserver/handlers/index.d.ts +0 -11
  42. package/dist_ts/opsserver/handlers/index.js +0 -12
  43. package/dist_ts/opsserver/handlers/logs.handler.d.ts +0 -25
  44. package/dist_ts/opsserver/handlers/logs.handler.js +0 -256
  45. package/dist_ts/opsserver/handlers/radius.handler.d.ts +0 -6
  46. package/dist_ts/opsserver/handlers/radius.handler.js +0 -295
  47. package/dist_ts/opsserver/handlers/remoteingress.handler.d.ts +0 -6
  48. package/dist_ts/opsserver/handlers/remoteingress.handler.js +0 -156
  49. package/dist_ts/opsserver/handlers/route-management.handler.d.ts +0 -14
  50. package/dist_ts/opsserver/handlers/route-management.handler.js +0 -117
  51. package/dist_ts/opsserver/handlers/security.handler.d.ts +0 -9
  52. package/dist_ts/opsserver/handlers/security.handler.js +0 -231
  53. package/dist_ts/opsserver/handlers/stats.handler.d.ts +0 -11
  54. package/dist_ts/opsserver/handlers/stats.handler.js +0 -399
  55. package/dist_ts/opsserver/helpers/guards.d.ts +0 -27
  56. package/dist_ts/opsserver/helpers/guards.js +0 -43
  57. package/dist_ts/opsserver/index.d.ts +0 -1
  58. package/dist_ts/opsserver/index.js +0 -2
  59. package/dist_ts/radius/classes.accounting.manager.d.ts +0 -218
  60. package/dist_ts/radius/classes.accounting.manager.js +0 -417
  61. package/dist_ts/radius/classes.radius.server.d.ts +0 -171
  62. package/dist_ts/radius/classes.radius.server.js +0 -385
  63. package/dist_ts/radius/classes.vlan.manager.d.ts +0 -128
  64. package/dist_ts/radius/classes.vlan.manager.js +0 -279
  65. package/dist_ts/radius/index.d.ts +0 -13
  66. package/dist_ts/radius/index.js +0 -14
  67. package/dist_ts/remoteingress/classes.remoteingress-manager.d.ts +0 -82
  68. package/dist_ts/remoteingress/classes.remoteingress-manager.js +0 -227
  69. package/dist_ts/remoteingress/classes.tunnel-manager.d.ts +0 -59
  70. package/dist_ts/remoteingress/classes.tunnel-manager.js +0 -165
  71. package/dist_ts/remoteingress/index.d.ts +0 -2
  72. package/dist_ts/remoteingress/index.js +0 -3
  73. package/dist_ts/security/classes.securitylogger.d.ts +0 -144
  74. package/dist_ts/security/classes.securitylogger.js +0 -233
  75. package/dist_ts/storage/classes.storagemanager.d.ts +0 -83
  76. package/dist_ts/storage/classes.storagemanager.js +0 -350
  77. package/dist_ts/storage/index.d.ts +0 -1
  78. package/dist_ts/storage/index.js +0 -3
@@ -1,63 +0,0 @@
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==
@@ -1,178 +0,0 @@
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
- }