@serve.zone/dcrouter 11.0.28 → 11.0.29

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 (46) hide show
  1. package/dist_serve/bundle.js +1 -1
  2. package/dist_ts/monitoring/classes.metricsmanager.d.ts +178 -0
  3. package/dist_ts/monitoring/classes.metricsmanager.js +642 -0
  4. package/dist_ts/monitoring/index.d.ts +1 -0
  5. package/dist_ts/monitoring/index.js +2 -0
  6. package/dist_ts/opsserver/classes.opsserver.d.ts +37 -0
  7. package/dist_ts/opsserver/classes.opsserver.js +85 -0
  8. package/dist_ts/opsserver/handlers/api-token.handler.d.ts +6 -0
  9. package/dist_ts/opsserver/handlers/api-token.handler.js +62 -0
  10. package/dist_ts/opsserver/handlers/certificate.handler.d.ts +32 -0
  11. package/dist_ts/opsserver/handlers/certificate.handler.js +421 -0
  12. package/dist_ts/opsserver/handlers/email-ops.handler.d.ts +30 -0
  13. package/dist_ts/opsserver/handlers/email-ops.handler.js +227 -0
  14. package/dist_ts/opsserver/handlers/index.d.ts +11 -0
  15. package/dist_ts/opsserver/handlers/index.js +12 -0
  16. package/dist_ts/opsserver/handlers/radius.handler.d.ts +6 -0
  17. package/dist_ts/opsserver/handlers/radius.handler.js +295 -0
  18. package/dist_ts/opsserver/handlers/remoteingress.handler.d.ts +6 -0
  19. package/dist_ts/opsserver/handlers/remoteingress.handler.js +156 -0
  20. package/dist_ts/opsserver/handlers/route-management.handler.d.ts +14 -0
  21. package/dist_ts/opsserver/handlers/route-management.handler.js +117 -0
  22. package/dist_ts/opsserver/handlers/security.handler.d.ts +9 -0
  23. package/dist_ts/opsserver/handlers/security.handler.js +231 -0
  24. package/dist_ts/opsserver/handlers/stats.handler.d.ts +11 -0
  25. package/dist_ts/opsserver/handlers/stats.handler.js +399 -0
  26. package/dist_ts/opsserver/helpers/guards.d.ts +27 -0
  27. package/dist_ts/opsserver/helpers/guards.js +43 -0
  28. package/dist_ts/opsserver/index.d.ts +1 -0
  29. package/dist_ts/opsserver/index.js +2 -0
  30. package/dist_ts/radius/classes.accounting.manager.d.ts +218 -0
  31. package/dist_ts/radius/classes.accounting.manager.js +417 -0
  32. package/dist_ts/radius/classes.radius.server.d.ts +171 -0
  33. package/dist_ts/radius/classes.radius.server.js +385 -0
  34. package/dist_ts/radius/classes.vlan.manager.d.ts +128 -0
  35. package/dist_ts/radius/classes.vlan.manager.js +279 -0
  36. package/dist_ts/radius/index.d.ts +13 -0
  37. package/dist_ts/radius/index.js +14 -0
  38. package/dist_ts/remoteingress/classes.remoteingress-manager.d.ts +82 -0
  39. package/dist_ts/remoteingress/classes.remoteingress-manager.js +227 -0
  40. package/dist_ts/remoteingress/classes.tunnel-manager.d.ts +59 -0
  41. package/dist_ts/remoteingress/classes.tunnel-manager.js +165 -0
  42. package/dist_ts/security/classes.securitylogger.d.ts +144 -0
  43. package/dist_ts_web/00_commitinfo_data.js +1 -1
  44. package/package.json +2 -2
  45. package/ts/00_commitinfo_data.ts +1 -1
  46. package/ts_web/00_commitinfo_data.ts +1 -1
@@ -39328,4 +39328,4 @@ ibantools/jsnext/ibantools.js:
39328
39328
  * @preferred
39329
39329
  *)
39330
39330
  */
39331
- //# sourceMappingURL=bundle-1772721434313.js.map
39331
+ //# sourceMappingURL=bundle-1772721753301.js.map
@@ -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
+ }