@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.
- package/dist_serve/bundle.js +1 -1
- package/dist_ts/00_commitinfo_data.d.ts +8 -0
- package/dist_ts/00_commitinfo_data.js +9 -0
- package/dist_ts/cache/classes.cache.cleaner.d.ts +47 -0
- package/dist_ts/cache/classes.cache.cleaner.js +130 -0
- package/dist_ts/cache/classes.cached.document.d.ts +76 -0
- package/dist_ts/cache/classes.cached.document.js +100 -0
- package/dist_ts/cache/classes.cachedb.d.ts +60 -0
- package/dist_ts/cache/classes.cachedb.js +126 -0
- package/dist_ts/cache/documents/classes.cached.email.d.ts +125 -0
- package/dist_ts/cache/documents/classes.cached.email.js +337 -0
- package/dist_ts/cache/documents/classes.cached.ip.reputation.d.ts +119 -0
- package/dist_ts/cache/documents/classes.cached.ip.reputation.js +323 -0
- package/dist_ts/cache/documents/index.d.ts +2 -0
- package/dist_ts/cache/documents/index.js +3 -0
- package/dist_ts/cache/index.d.ts +4 -0
- package/dist_ts/cache/index.js +7 -0
- package/dist_ts/classes.cert-provision-scheduler.d.ts +53 -0
- package/dist_ts/classes.cert-provision-scheduler.js +110 -0
- package/dist_ts/classes.storage-cert-manager.d.ts +18 -0
- package/dist_ts/classes.storage-cert-manager.js +43 -0
- package/dist_ts/config/classes.api-token-manager.d.ts +46 -0
- package/dist_ts/config/classes.api-token-manager.js +150 -0
- package/dist_ts/config/classes.route-config-manager.d.ts +35 -0
- package/dist_ts/config/classes.route-config-manager.js +231 -0
- package/dist_ts/config/index.d.ts +3 -0
- package/dist_ts/config/index.js +5 -0
- package/dist_ts/config/validator.d.ts +104 -0
- package/dist_ts/config/validator.js +152 -0
- package/dist_ts/errors/base.errors.d.ts +224 -0
- package/dist_ts/errors/base.errors.js +320 -0
- package/dist_ts/errors/error.codes.d.ts +115 -0
- package/dist_ts/errors/error.codes.js +136 -0
- package/dist_ts/logger.d.ts +21 -0
- package/dist_ts/logger.js +81 -0
- package/dist_ts/monitoring/classes.metricscache.d.ts +32 -0
- package/dist_ts/monitoring/classes.metricscache.js +63 -0
- package/dist_ts/monitoring/classes.metricsmanager.d.ts +178 -0
- package/dist_ts/monitoring/classes.metricsmanager.js +642 -0
- package/dist_ts/monitoring/index.d.ts +1 -0
- package/dist_ts/monitoring/index.js +2 -0
- package/dist_ts/opsserver/classes.opsserver.d.ts +37 -0
- package/dist_ts/opsserver/classes.opsserver.js +85 -0
- package/dist_ts/opsserver/handlers/admin.handler.d.ts +31 -0
- package/dist_ts/opsserver/handlers/admin.handler.js +180 -0
- package/dist_ts/opsserver/handlers/api-token.handler.d.ts +6 -0
- package/dist_ts/opsserver/handlers/api-token.handler.js +62 -0
- package/dist_ts/opsserver/handlers/certificate.handler.d.ts +32 -0
- package/dist_ts/opsserver/handlers/certificate.handler.js +421 -0
- package/dist_ts/opsserver/handlers/config.handler.d.ts +7 -0
- package/dist_ts/opsserver/handlers/config.handler.js +192 -0
- package/dist_ts/opsserver/handlers/email-ops.handler.d.ts +30 -0
- package/dist_ts/opsserver/handlers/email-ops.handler.js +227 -0
- package/dist_ts/opsserver/handlers/index.d.ts +11 -0
- package/dist_ts/opsserver/handlers/index.js +12 -0
- package/dist_ts/opsserver/handlers/logs.handler.d.ts +25 -0
- package/dist_ts/opsserver/handlers/logs.handler.js +256 -0
- package/dist_ts/opsserver/handlers/radius.handler.d.ts +6 -0
- package/dist_ts/opsserver/handlers/radius.handler.js +295 -0
- package/dist_ts/opsserver/handlers/remoteingress.handler.d.ts +6 -0
- package/dist_ts/opsserver/handlers/remoteingress.handler.js +156 -0
- package/dist_ts/opsserver/handlers/route-management.handler.d.ts +14 -0
- package/dist_ts/opsserver/handlers/route-management.handler.js +117 -0
- package/dist_ts/opsserver/handlers/security.handler.d.ts +9 -0
- package/dist_ts/opsserver/handlers/security.handler.js +231 -0
- package/dist_ts/opsserver/handlers/stats.handler.d.ts +11 -0
- package/dist_ts/opsserver/handlers/stats.handler.js +399 -0
- package/dist_ts/opsserver/helpers/guards.d.ts +27 -0
- package/dist_ts/opsserver/helpers/guards.js +43 -0
- package/dist_ts/opsserver/index.d.ts +1 -0
- package/dist_ts/opsserver/index.js +2 -0
- package/dist_ts/paths.d.ts +26 -0
- package/dist_ts/paths.js +45 -0
- package/dist_ts/plugins.d.ts +79 -0
- package/dist_ts/plugins.js +113 -0
- package/dist_ts/radius/classes.accounting.manager.d.ts +218 -0
- package/dist_ts/radius/classes.accounting.manager.js +417 -0
- package/dist_ts/radius/classes.radius.server.d.ts +171 -0
- package/dist_ts/radius/classes.radius.server.js +385 -0
- package/dist_ts/radius/classes.vlan.manager.d.ts +128 -0
- package/dist_ts/radius/classes.vlan.manager.js +279 -0
- package/dist_ts/radius/index.d.ts +13 -0
- package/dist_ts/radius/index.js +14 -0
- package/dist_ts/remoteingress/classes.remoteingress-manager.d.ts +82 -0
- package/dist_ts/remoteingress/classes.remoteingress-manager.js +227 -0
- package/dist_ts/remoteingress/classes.tunnel-manager.d.ts +59 -0
- package/dist_ts/remoteingress/classes.tunnel-manager.js +165 -0
- package/dist_ts/remoteingress/index.d.ts +2 -0
- package/dist_ts/remoteingress/index.js +3 -0
- package/dist_ts/security/classes.contentscanner.d.ts +164 -0
- package/dist_ts/security/classes.contentscanner.js +642 -0
- package/dist_ts/security/classes.ipreputationchecker.d.ts +160 -0
- package/dist_ts/security/classes.ipreputationchecker.js +537 -0
- package/dist_ts/security/classes.securitylogger.d.ts +144 -0
- package/dist_ts/security/classes.securitylogger.js +233 -0
- package/dist_ts/security/index.d.ts +3 -0
- package/dist_ts/security/index.js +4 -0
- package/dist_ts/storage/classes.storagemanager.d.ts +83 -0
- package/dist_ts/storage/classes.storagemanager.js +350 -0
- package/dist_ts/storage/index.d.ts +1 -0
- package/dist_ts/storage/index.js +3 -0
- package/dist_ts_web/00_commitinfo_data.js +1 -1
- package/package.json +2 -2
- package/ts/00_commitinfo_data.ts +1 -1
- 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
|
+
}
|