@serve.zone/dcrouter 8.1.0 → 9.1.0

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 (34) hide show
  1. package/dist_serve/bundle.js +1417 -992
  2. package/dist_ts/00_commitinfo_data.js +1 -1
  3. package/dist_ts/monitoring/classes.metricsmanager.d.ts +169 -0
  4. package/dist_ts/monitoring/classes.metricsmanager.js +591 -0
  5. package/dist_ts/monitoring/index.d.ts +1 -0
  6. package/dist_ts/monitoring/index.js +2 -0
  7. package/dist_ts/opsserver/handlers/certificate.handler.d.ts +34 -0
  8. package/dist_ts/opsserver/handlers/certificate.handler.js +419 -0
  9. package/dist_ts/opsserver/handlers/email-ops.handler.d.ts +32 -0
  10. package/dist_ts/opsserver/handlers/email-ops.handler.js +226 -0
  11. package/dist_ts/opsserver/handlers/radius.handler.d.ts +8 -0
  12. package/dist_ts/opsserver/handlers/radius.handler.js +296 -0
  13. package/dist_ts/opsserver/handlers/remoteingress.handler.d.ts +8 -0
  14. package/dist_ts/opsserver/handlers/remoteingress.handler.js +154 -0
  15. package/dist_ts/opsserver/handlers/security.handler.d.ts +11 -0
  16. package/dist_ts/opsserver/handlers/security.handler.js +232 -0
  17. package/dist_ts/opsserver/handlers/stats.handler.d.ts +13 -0
  18. package/dist_ts/opsserver/handlers/stats.handler.js +400 -0
  19. package/dist_ts/security/classes.securitylogger.d.ts +140 -0
  20. package/dist_ts_interfaces/requests/config.d.ts +77 -1
  21. package/dist_ts_web/00_commitinfo_data.js +1 -1
  22. package/dist_ts_web/appstate.d.ts +1 -1
  23. package/dist_ts_web/elements/ops-dashboard.js +15 -5
  24. package/dist_ts_web/elements/ops-view-apitokens.js +8 -4
  25. package/dist_ts_web/elements/ops-view-config.d.ts +10 -8
  26. package/dist_ts_web/elements/ops-view-config.js +215 -297
  27. package/package.json +2 -2
  28. package/ts/00_commitinfo_data.ts +1 -1
  29. package/ts/opsserver/handlers/config.handler.ts +154 -72
  30. package/ts_web/00_commitinfo_data.ts +1 -1
  31. package/ts_web/appstate.ts +1 -1
  32. package/ts_web/elements/ops-dashboard.ts +14 -4
  33. package/ts_web/elements/ops-view-apitokens.ts +7 -3
  34. package/ts_web/elements/ops-view-config.ts +237 -299
@@ -0,0 +1,591 @@
1
+ import * as plugins from '../plugins.js';
2
+ import { DcRouter } from '../classes.dcrouter.js';
3
+ import { MetricsCache } from './classes.metricscache.js';
4
+ import { SecurityLogger, SecurityEventType } from '../security/classes.securitylogger.js';
5
+ import { logger } from '../logger.js';
6
+ export class MetricsManager {
7
+ metricsLogger;
8
+ smartMetrics;
9
+ dcRouter;
10
+ resetInterval;
11
+ metricsCache;
12
+ // Constants
13
+ MAX_TOP_DOMAINS = 1000; // Limit topDomains Map size
14
+ // Track email-specific metrics
15
+ emailMetrics = {
16
+ sentToday: 0,
17
+ receivedToday: 0,
18
+ failedToday: 0,
19
+ bouncedToday: 0,
20
+ queueSize: 0,
21
+ lastResetDate: new Date().toDateString(),
22
+ deliveryTimes: [], // Track delivery times in ms
23
+ recipients: new Map(), // Track email count by recipient
24
+ recentActivity: [],
25
+ };
26
+ // Track DNS-specific metrics
27
+ dnsMetrics = {
28
+ totalQueries: 0,
29
+ cacheHits: 0,
30
+ cacheMisses: 0,
31
+ queryTypes: {},
32
+ topDomains: new Map(),
33
+ lastResetDate: new Date().toDateString(),
34
+ queryTimestamps: [], // Track query timestamps for rate calculation
35
+ responseTimes: [], // Track response times in ms
36
+ recentQueries: [],
37
+ };
38
+ // Per-minute time-series buckets for charts
39
+ emailMinuteBuckets = new Map();
40
+ dnsMinuteBuckets = new Map();
41
+ // Track security-specific metrics
42
+ securityMetrics = {
43
+ blockedIPs: 0,
44
+ authFailures: 0,
45
+ spamDetected: 0,
46
+ malwareDetected: 0,
47
+ phishingDetected: 0,
48
+ lastResetDate: new Date().toDateString(),
49
+ incidents: [],
50
+ };
51
+ constructor(dcRouter) {
52
+ this.dcRouter = dcRouter;
53
+ // Create a Smartlog instance for SmartMetrics (requires its own instance)
54
+ this.metricsLogger = new plugins.smartlog.Smartlog({
55
+ logContext: {
56
+ environment: 'production',
57
+ runtime: 'node',
58
+ zone: 'dcrouter-metrics',
59
+ }
60
+ });
61
+ this.smartMetrics = new plugins.smartmetrics.SmartMetrics(this.metricsLogger, 'dcrouter');
62
+ // Initialize metrics cache with 500ms TTL
63
+ this.metricsCache = new MetricsCache(500);
64
+ }
65
+ async start() {
66
+ // Start SmartMetrics collection
67
+ this.smartMetrics.start();
68
+ // Reset daily counters at midnight
69
+ this.resetInterval = setInterval(() => {
70
+ const currentDate = new Date().toDateString();
71
+ if (currentDate !== this.emailMetrics.lastResetDate) {
72
+ this.emailMetrics.sentToday = 0;
73
+ this.emailMetrics.receivedToday = 0;
74
+ this.emailMetrics.failedToday = 0;
75
+ this.emailMetrics.bouncedToday = 0;
76
+ this.emailMetrics.deliveryTimes = [];
77
+ this.emailMetrics.recipients.clear();
78
+ this.emailMetrics.recentActivity = [];
79
+ this.emailMetrics.lastResetDate = currentDate;
80
+ }
81
+ if (currentDate !== this.dnsMetrics.lastResetDate) {
82
+ this.dnsMetrics.totalQueries = 0;
83
+ this.dnsMetrics.cacheHits = 0;
84
+ this.dnsMetrics.cacheMisses = 0;
85
+ this.dnsMetrics.queryTypes = {};
86
+ this.dnsMetrics.topDomains.clear();
87
+ this.dnsMetrics.queryTimestamps = [];
88
+ this.dnsMetrics.responseTimes = [];
89
+ this.dnsMetrics.recentQueries = [];
90
+ this.dnsMetrics.lastResetDate = currentDate;
91
+ }
92
+ if (currentDate !== this.securityMetrics.lastResetDate) {
93
+ this.securityMetrics.blockedIPs = 0;
94
+ this.securityMetrics.authFailures = 0;
95
+ this.securityMetrics.spamDetected = 0;
96
+ this.securityMetrics.malwareDetected = 0;
97
+ this.securityMetrics.phishingDetected = 0;
98
+ this.securityMetrics.incidents = [];
99
+ this.securityMetrics.lastResetDate = currentDate;
100
+ }
101
+ // Prune old time-series buckets every minute (don't wait for lazy query)
102
+ this.pruneOldBuckets();
103
+ }, 60000); // Check every minute
104
+ logger.log('info', 'MetricsManager started');
105
+ }
106
+ async stop() {
107
+ // Clear the reset interval
108
+ if (this.resetInterval) {
109
+ clearInterval(this.resetInterval);
110
+ this.resetInterval = undefined;
111
+ }
112
+ this.smartMetrics.stop();
113
+ // Clear caches and time-series buckets on shutdown
114
+ this.metricsCache.clear();
115
+ this.emailMinuteBuckets.clear();
116
+ this.dnsMinuteBuckets.clear();
117
+ logger.log('info', 'MetricsManager stopped');
118
+ }
119
+ // Get server metrics from SmartMetrics and SmartProxy
120
+ async getServerStats() {
121
+ return this.metricsCache.get('serverStats', async () => {
122
+ const smartMetricsData = await this.smartMetrics.getMetrics();
123
+ const proxyMetrics = this.dcRouter.smartProxy ? this.dcRouter.smartProxy.getMetrics() : null;
124
+ const proxyStats = this.dcRouter.smartProxy ? await this.dcRouter.smartProxy.getStatistics() : null;
125
+ return {
126
+ uptime: process.uptime(),
127
+ startTime: Date.now() - (process.uptime() * 1000),
128
+ memoryUsage: {
129
+ heapUsed: process.memoryUsage().heapUsed,
130
+ heapTotal: process.memoryUsage().heapTotal,
131
+ external: process.memoryUsage().external,
132
+ rss: process.memoryUsage().rss,
133
+ // Add SmartMetrics memory data
134
+ maxMemoryMB: this.smartMetrics.maxMemoryMB,
135
+ actualUsageBytes: smartMetricsData.memoryUsageBytes,
136
+ actualUsagePercentage: smartMetricsData.memoryPercentage,
137
+ },
138
+ cpuUsage: {
139
+ user: smartMetricsData.cpuPercentage,
140
+ system: 0,
141
+ },
142
+ activeConnections: proxyStats ? proxyStats.activeConnections : 0,
143
+ totalConnections: proxyMetrics ? proxyMetrics.totals.connections() : 0,
144
+ requestsPerSecond: proxyMetrics ? proxyMetrics.requests.perSecond() : 0,
145
+ throughput: proxyMetrics ? {
146
+ bytesIn: proxyMetrics.totals.bytesIn(),
147
+ bytesOut: proxyMetrics.totals.bytesOut(),
148
+ bytesInPerSecond: proxyMetrics.throughput.instant().in,
149
+ bytesOutPerSecond: proxyMetrics.throughput.instant().out,
150
+ } : { bytesIn: 0, bytesOut: 0, bytesInPerSecond: 0, bytesOutPerSecond: 0 },
151
+ };
152
+ });
153
+ }
154
+ // Get email metrics
155
+ async getEmailStats() {
156
+ return this.metricsCache.get('emailStats', () => {
157
+ // Calculate average delivery time
158
+ const avgDeliveryTime = this.emailMetrics.deliveryTimes.length > 0
159
+ ? this.emailMetrics.deliveryTimes.reduce((a, b) => a + b, 0) / this.emailMetrics.deliveryTimes.length
160
+ : 0;
161
+ // Get top recipients
162
+ const topRecipients = Array.from(this.emailMetrics.recipients.entries())
163
+ .sort((a, b) => b[1] - a[1])
164
+ .slice(0, 10)
165
+ .map(([email, count]) => ({ email, count }));
166
+ // Get recent activity (last 50 entries)
167
+ const recentActivity = this.emailMetrics.recentActivity.slice(-50);
168
+ return {
169
+ sentToday: this.emailMetrics.sentToday,
170
+ receivedToday: this.emailMetrics.receivedToday,
171
+ failedToday: this.emailMetrics.failedToday,
172
+ bounceRate: this.emailMetrics.bouncedToday > 0
173
+ ? (this.emailMetrics.bouncedToday / this.emailMetrics.sentToday) * 100
174
+ : 0,
175
+ deliveryRate: this.emailMetrics.sentToday > 0
176
+ ? ((this.emailMetrics.sentToday - this.emailMetrics.failedToday) / this.emailMetrics.sentToday) * 100
177
+ : 100,
178
+ queueSize: this.emailMetrics.queueSize,
179
+ averageDeliveryTime: Math.round(avgDeliveryTime),
180
+ topRecipients,
181
+ recentActivity,
182
+ };
183
+ });
184
+ }
185
+ // Get DNS metrics
186
+ async getDnsStats() {
187
+ return this.metricsCache.get('dnsStats', () => {
188
+ const cacheHitRate = this.dnsMetrics.totalQueries > 0
189
+ ? (this.dnsMetrics.cacheHits / this.dnsMetrics.totalQueries) * 100
190
+ : 0;
191
+ const topDomains = Array.from(this.dnsMetrics.topDomains.entries())
192
+ .sort((a, b) => b[1] - a[1])
193
+ .slice(0, 10)
194
+ .map(([domain, count]) => ({ domain, count }));
195
+ // Calculate queries per second from recent timestamps
196
+ const now = Date.now();
197
+ const oneMinuteAgo = now - 60000;
198
+ const recentQueries = this.dnsMetrics.queryTimestamps.filter(ts => ts >= oneMinuteAgo);
199
+ const queriesPerSecond = recentQueries.length / 60;
200
+ // Calculate average response time
201
+ const avgResponseTime = this.dnsMetrics.responseTimes.length > 0
202
+ ? this.dnsMetrics.responseTimes.reduce((a, b) => a + b, 0) / this.dnsMetrics.responseTimes.length
203
+ : 0;
204
+ return {
205
+ queriesPerSecond: Math.round(queriesPerSecond * 10) / 10,
206
+ totalQueries: this.dnsMetrics.totalQueries,
207
+ cacheHits: this.dnsMetrics.cacheHits,
208
+ cacheMisses: this.dnsMetrics.cacheMisses,
209
+ cacheHitRate: cacheHitRate,
210
+ topDomains: topDomains,
211
+ queryTypes: this.dnsMetrics.queryTypes,
212
+ averageResponseTime: Math.round(avgResponseTime),
213
+ activeDomains: this.dnsMetrics.topDomains.size,
214
+ recentQueries: this.dnsMetrics.recentQueries.slice(),
215
+ };
216
+ });
217
+ }
218
+ /**
219
+ * Sync security metrics from the SecurityLogger singleton (last 24h).
220
+ * Called before returning security stats so counters reflect real events.
221
+ */
222
+ syncFromSecurityLogger() {
223
+ try {
224
+ const securityLogger = SecurityLogger.getInstance();
225
+ const summary = securityLogger.getEventsSummary(86400000); // last 24h
226
+ this.securityMetrics.spamDetected = summary.byType[SecurityEventType.SPAM] || 0;
227
+ this.securityMetrics.malwareDetected = summary.byType[SecurityEventType.MALWARE] || 0;
228
+ this.securityMetrics.phishingDetected = summary.byType[SecurityEventType.DMARC] || 0; // phishing via DMARC
229
+ this.securityMetrics.authFailures =
230
+ summary.byType[SecurityEventType.AUTHENTICATION] || 0;
231
+ this.securityMetrics.blockedIPs =
232
+ (summary.byType[SecurityEventType.IP_REPUTATION] || 0) +
233
+ (summary.byType[SecurityEventType.REJECTED_CONNECTION] || 0);
234
+ }
235
+ catch {
236
+ // SecurityLogger may not be initialized yet — ignore
237
+ }
238
+ }
239
+ // Get security metrics
240
+ async getSecurityStats() {
241
+ return this.metricsCache.get('securityStats', () => {
242
+ // Sync counters from the real SecurityLogger events
243
+ this.syncFromSecurityLogger();
244
+ // Get recent incidents (last 20)
245
+ const recentIncidents = this.securityMetrics.incidents.slice(-20);
246
+ return {
247
+ blockedIPs: this.securityMetrics.blockedIPs,
248
+ authFailures: this.securityMetrics.authFailures,
249
+ spamDetected: this.securityMetrics.spamDetected,
250
+ malwareDetected: this.securityMetrics.malwareDetected,
251
+ phishingDetected: this.securityMetrics.phishingDetected,
252
+ totalThreatsBlocked: this.securityMetrics.spamDetected +
253
+ this.securityMetrics.malwareDetected +
254
+ this.securityMetrics.phishingDetected,
255
+ recentIncidents,
256
+ };
257
+ });
258
+ }
259
+ // Get connection info from SmartProxy
260
+ async getConnectionInfo() {
261
+ return this.metricsCache.get('connectionInfo', () => {
262
+ const proxyMetrics = this.dcRouter.smartProxy ? this.dcRouter.smartProxy.getMetrics() : null;
263
+ if (!proxyMetrics) {
264
+ return [];
265
+ }
266
+ const connectionsByRoute = proxyMetrics.connections.byRoute();
267
+ const connectionInfo = [];
268
+ for (const [routeName, count] of connectionsByRoute) {
269
+ connectionInfo.push({
270
+ type: 'https',
271
+ count,
272
+ source: routeName,
273
+ lastActivity: new Date(),
274
+ });
275
+ }
276
+ return connectionInfo;
277
+ });
278
+ }
279
+ // Email event tracking methods
280
+ trackEmailSent(recipient, deliveryTimeMs) {
281
+ this.emailMetrics.sentToday++;
282
+ this.incrementEmailBucket('sent');
283
+ if (recipient) {
284
+ const count = this.emailMetrics.recipients.get(recipient) || 0;
285
+ this.emailMetrics.recipients.set(recipient, count + 1);
286
+ // Cap recipients map to prevent unbounded growth within a day
287
+ if (this.emailMetrics.recipients.size > this.MAX_TOP_DOMAINS) {
288
+ const sorted = Array.from(this.emailMetrics.recipients.entries())
289
+ .sort((a, b) => b[1] - a[1])
290
+ .slice(0, Math.floor(this.MAX_TOP_DOMAINS * 0.8));
291
+ this.emailMetrics.recipients = new Map(sorted);
292
+ }
293
+ }
294
+ if (deliveryTimeMs) {
295
+ this.emailMetrics.deliveryTimes.push(deliveryTimeMs);
296
+ // Keep only last 1000 delivery times
297
+ if (this.emailMetrics.deliveryTimes.length > 1000) {
298
+ this.emailMetrics.deliveryTimes.shift();
299
+ }
300
+ }
301
+ this.emailMetrics.recentActivity.push({
302
+ timestamp: Date.now(),
303
+ type: 'sent',
304
+ details: recipient || 'unknown',
305
+ });
306
+ // Keep only last 1000 activities
307
+ if (this.emailMetrics.recentActivity.length > 1000) {
308
+ this.emailMetrics.recentActivity.shift();
309
+ }
310
+ }
311
+ trackEmailReceived(sender) {
312
+ this.emailMetrics.receivedToday++;
313
+ this.incrementEmailBucket('received');
314
+ this.emailMetrics.recentActivity.push({
315
+ timestamp: Date.now(),
316
+ type: 'received',
317
+ details: sender || 'unknown',
318
+ });
319
+ // Keep only last 1000 activities
320
+ if (this.emailMetrics.recentActivity.length > 1000) {
321
+ this.emailMetrics.recentActivity.shift();
322
+ }
323
+ }
324
+ trackEmailFailed(recipient, reason) {
325
+ this.emailMetrics.failedToday++;
326
+ this.incrementEmailBucket('failed');
327
+ this.emailMetrics.recentActivity.push({
328
+ timestamp: Date.now(),
329
+ type: 'failed',
330
+ details: `${recipient || 'unknown'}: ${reason || 'unknown error'}`,
331
+ });
332
+ // Keep only last 1000 activities
333
+ if (this.emailMetrics.recentActivity.length > 1000) {
334
+ this.emailMetrics.recentActivity.shift();
335
+ }
336
+ }
337
+ trackEmailBounced(recipient) {
338
+ this.emailMetrics.bouncedToday++;
339
+ this.emailMetrics.recentActivity.push({
340
+ timestamp: Date.now(),
341
+ type: 'bounced',
342
+ details: recipient || 'unknown',
343
+ });
344
+ // Keep only last 1000 activities
345
+ if (this.emailMetrics.recentActivity.length > 1000) {
346
+ this.emailMetrics.recentActivity.shift();
347
+ }
348
+ }
349
+ updateQueueSize(size) {
350
+ this.emailMetrics.queueSize = size;
351
+ }
352
+ // DNS event tracking methods
353
+ trackDnsQuery(queryType, domain, cacheHit, responseTimeMs, answered) {
354
+ this.dnsMetrics.totalQueries++;
355
+ this.incrementDnsBucket();
356
+ // Store recent query entry
357
+ this.dnsMetrics.recentQueries.push({
358
+ timestamp: Date.now(),
359
+ domain,
360
+ type: queryType,
361
+ answered: answered ?? true,
362
+ responseTimeMs: responseTimeMs ?? 0,
363
+ });
364
+ if (this.dnsMetrics.recentQueries.length > 100) {
365
+ this.dnsMetrics.recentQueries.shift();
366
+ }
367
+ if (cacheHit) {
368
+ this.dnsMetrics.cacheHits++;
369
+ }
370
+ else {
371
+ this.dnsMetrics.cacheMisses++;
372
+ }
373
+ // Track query timestamp
374
+ this.dnsMetrics.queryTimestamps.push(Date.now());
375
+ // Keep only timestamps from last 5 minutes
376
+ const fiveMinutesAgo = Date.now() - 300000;
377
+ this.dnsMetrics.queryTimestamps = this.dnsMetrics.queryTimestamps.filter(ts => ts >= fiveMinutesAgo);
378
+ // Track response time if provided
379
+ if (responseTimeMs) {
380
+ this.dnsMetrics.responseTimes.push(responseTimeMs);
381
+ // Keep only last 1000 response times
382
+ if (this.dnsMetrics.responseTimes.length > 1000) {
383
+ this.dnsMetrics.responseTimes.shift();
384
+ }
385
+ }
386
+ // Track query types
387
+ this.dnsMetrics.queryTypes[queryType] = (this.dnsMetrics.queryTypes[queryType] || 0) + 1;
388
+ // Track top domains with size limit
389
+ const currentCount = this.dnsMetrics.topDomains.get(domain) || 0;
390
+ this.dnsMetrics.topDomains.set(domain, currentCount + 1);
391
+ // If we've exceeded the limit, remove the least accessed domains
392
+ if (this.dnsMetrics.topDomains.size > this.MAX_TOP_DOMAINS) {
393
+ // Convert to array, sort by count, and keep only top domains
394
+ const sortedDomains = Array.from(this.dnsMetrics.topDomains.entries())
395
+ .sort((a, b) => b[1] - a[1])
396
+ .slice(0, Math.floor(this.MAX_TOP_DOMAINS * 0.8)); // Keep 80% to avoid frequent cleanup
397
+ // Clear and repopulate with top domains
398
+ this.dnsMetrics.topDomains.clear();
399
+ sortedDomains.forEach(([domain, count]) => {
400
+ this.dnsMetrics.topDomains.set(domain, count);
401
+ });
402
+ }
403
+ }
404
+ // Security event tracking methods
405
+ trackBlockedIP(ip, reason) {
406
+ this.securityMetrics.blockedIPs++;
407
+ this.securityMetrics.incidents.push({
408
+ timestamp: Date.now(),
409
+ type: 'ip_blocked',
410
+ severity: 'medium',
411
+ details: `IP ${ip || 'unknown'} blocked: ${reason || 'security policy'}`,
412
+ });
413
+ // Keep only last 1000 incidents
414
+ if (this.securityMetrics.incidents.length > 1000) {
415
+ this.securityMetrics.incidents.shift();
416
+ }
417
+ }
418
+ trackAuthFailure(username, ip) {
419
+ this.securityMetrics.authFailures++;
420
+ this.securityMetrics.incidents.push({
421
+ timestamp: Date.now(),
422
+ type: 'auth_failure',
423
+ severity: 'low',
424
+ details: `Authentication failed for ${username || 'unknown'} from ${ip || 'unknown'}`,
425
+ });
426
+ // Keep only last 1000 incidents
427
+ if (this.securityMetrics.incidents.length > 1000) {
428
+ this.securityMetrics.incidents.shift();
429
+ }
430
+ }
431
+ trackSpamDetected(sender) {
432
+ this.securityMetrics.spamDetected++;
433
+ this.securityMetrics.incidents.push({
434
+ timestamp: Date.now(),
435
+ type: 'spam_detected',
436
+ severity: 'low',
437
+ details: `Spam detected from ${sender || 'unknown'}`,
438
+ });
439
+ // Keep only last 1000 incidents
440
+ if (this.securityMetrics.incidents.length > 1000) {
441
+ this.securityMetrics.incidents.shift();
442
+ }
443
+ }
444
+ trackMalwareDetected(source) {
445
+ this.securityMetrics.malwareDetected++;
446
+ this.securityMetrics.incidents.push({
447
+ timestamp: Date.now(),
448
+ type: 'malware_detected',
449
+ severity: 'high',
450
+ details: `Malware detected from ${source || 'unknown'}`,
451
+ });
452
+ // Keep only last 1000 incidents
453
+ if (this.securityMetrics.incidents.length > 1000) {
454
+ this.securityMetrics.incidents.shift();
455
+ }
456
+ }
457
+ trackPhishingDetected(source) {
458
+ this.securityMetrics.phishingDetected++;
459
+ this.securityMetrics.incidents.push({
460
+ timestamp: Date.now(),
461
+ type: 'phishing_detected',
462
+ severity: 'high',
463
+ details: `Phishing attempt from ${source || 'unknown'}`,
464
+ });
465
+ // Keep only last 1000 incidents
466
+ if (this.securityMetrics.incidents.length > 1000) {
467
+ this.securityMetrics.incidents.shift();
468
+ }
469
+ }
470
+ // Get network metrics from SmartProxy
471
+ async getNetworkStats() {
472
+ // Use shorter cache TTL for network stats to ensure real-time updates
473
+ return this.metricsCache.get('networkStats', () => {
474
+ const proxyMetrics = this.dcRouter.smartProxy ? this.dcRouter.smartProxy.getMetrics() : null;
475
+ if (!proxyMetrics) {
476
+ return {
477
+ connectionsByIP: new Map(),
478
+ throughputRate: { bytesInPerSecond: 0, bytesOutPerSecond: 0 },
479
+ topIPs: [],
480
+ totalDataTransferred: { bytesIn: 0, bytesOut: 0 },
481
+ throughputHistory: [],
482
+ throughputByIP: new Map(),
483
+ requestsPerSecond: 0,
484
+ requestsTotal: 0,
485
+ };
486
+ }
487
+ // Get metrics using the new API
488
+ const connectionsByIP = proxyMetrics.connections.byIP();
489
+ const instantThroughput = proxyMetrics.throughput.instant();
490
+ // Get throughput rate
491
+ const throughputRate = {
492
+ bytesInPerSecond: instantThroughput.in,
493
+ bytesOutPerSecond: instantThroughput.out
494
+ };
495
+ // Get top IPs
496
+ const topIPs = proxyMetrics.connections.topIPs(10);
497
+ // Get total data transferred
498
+ const totalDataTransferred = {
499
+ bytesIn: proxyMetrics.totals.bytesIn(),
500
+ bytesOut: proxyMetrics.totals.bytesOut()
501
+ };
502
+ // Get throughput history from Rust engine (up to 300 seconds)
503
+ const throughputHistory = proxyMetrics.throughput.history(300);
504
+ // Get per-IP throughput
505
+ const throughputByIP = proxyMetrics.throughput.byIP();
506
+ // Get HTTP request rates
507
+ const requestsPerSecond = proxyMetrics.requests.perSecond();
508
+ const requestsTotal = proxyMetrics.requests.total();
509
+ return {
510
+ connectionsByIP,
511
+ throughputRate,
512
+ topIPs,
513
+ totalDataTransferred,
514
+ throughputHistory,
515
+ throughputByIP,
516
+ requestsPerSecond,
517
+ requestsTotal,
518
+ };
519
+ }, 200); // Use 200ms cache for more frequent updates
520
+ }
521
+ // --- Time-series helpers ---
522
+ static minuteKey(ts = Date.now()) {
523
+ return Math.floor(ts / 60000) * 60000;
524
+ }
525
+ incrementEmailBucket(field) {
526
+ const key = MetricsManager.minuteKey();
527
+ let bucket = this.emailMinuteBuckets.get(key);
528
+ if (!bucket) {
529
+ bucket = { sent: 0, received: 0, failed: 0 };
530
+ this.emailMinuteBuckets.set(key, bucket);
531
+ }
532
+ bucket[field]++;
533
+ }
534
+ incrementDnsBucket() {
535
+ const key = MetricsManager.minuteKey();
536
+ let bucket = this.dnsMinuteBuckets.get(key);
537
+ if (!bucket) {
538
+ bucket = { queries: 0 };
539
+ this.dnsMinuteBuckets.set(key, bucket);
540
+ }
541
+ bucket.queries++;
542
+ }
543
+ pruneOldBuckets() {
544
+ const cutoff = Date.now() - 86400000; // 24h
545
+ for (const key of this.emailMinuteBuckets.keys()) {
546
+ if (key < cutoff)
547
+ this.emailMinuteBuckets.delete(key);
548
+ }
549
+ for (const key of this.dnsMinuteBuckets.keys()) {
550
+ if (key < cutoff)
551
+ this.dnsMinuteBuckets.delete(key);
552
+ }
553
+ }
554
+ /**
555
+ * Get email time-series data for the last N hours, aggregated per minute.
556
+ */
557
+ getEmailTimeSeries(hours = 24) {
558
+ this.pruneOldBuckets();
559
+ const cutoff = Date.now() - hours * 3600000;
560
+ const sent = [];
561
+ const received = [];
562
+ const failed = [];
563
+ const sortedKeys = Array.from(this.emailMinuteBuckets.keys())
564
+ .filter((k) => k >= cutoff)
565
+ .sort((a, b) => a - b);
566
+ for (const key of sortedKeys) {
567
+ const bucket = this.emailMinuteBuckets.get(key);
568
+ sent.push({ timestamp: key, value: bucket.sent });
569
+ received.push({ timestamp: key, value: bucket.received });
570
+ failed.push({ timestamp: key, value: bucket.failed });
571
+ }
572
+ return { sent, received, failed };
573
+ }
574
+ /**
575
+ * Get DNS time-series data for the last N hours, aggregated per minute.
576
+ */
577
+ getDnsTimeSeries(hours = 24) {
578
+ this.pruneOldBuckets();
579
+ const cutoff = Date.now() - hours * 3600000;
580
+ const queries = [];
581
+ const sortedKeys = Array.from(this.dnsMinuteBuckets.keys())
582
+ .filter((k) => k >= cutoff)
583
+ .sort((a, b) => a - b);
584
+ for (const key of sortedKeys) {
585
+ const bucket = this.dnsMinuteBuckets.get(key);
586
+ queries.push({ timestamp: key, value: bucket.queries });
587
+ }
588
+ return { queries };
589
+ }
590
+ }
591
+ //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"classes.metricsmanager.js","sourceRoot":"","sources":["../../../ts/monitoring/classes.metricsmanager.ts"],"names":[],"mappings":"AAAA,OAAO,KAAK,OAAO,MAAM,eAAe,CAAC;AACzC,OAAO,EAAE,QAAQ,EAAE,MAAM,wBAAwB,CAAC;AAClD,OAAO,EAAE,YAAY,EAAE,MAAM,2BAA2B,CAAC;AACzD,OAAO,EAAE,cAAc,EAAE,iBAAiB,EAAE,MAAM,uCAAuC,CAAC;AAC1F,OAAO,EAAE,MAAM,EAAE,MAAM,cAAc,CAAC;AAEtC,MAAM,OAAO,cAAc;IACjB,aAAa,CAA4B;IACzC,YAAY,CAAoC;IAChD,QAAQ,CAAW;IACnB,aAAa,CAAkB;IAC/B,YAAY,CAAe;IAEnC,YAAY;IACK,eAAe,GAAG,IAAI,CAAC,CAAC,4BAA4B;IAErE,+BAA+B;IACvB,YAAY,GAAG;QACrB,SAAS,EAAE,CAAC;QACZ,aAAa,EAAE,CAAC;QAChB,WAAW,EAAE,CAAC;QACd,YAAY,EAAE,CAAC;QACf,SAAS,EAAE,CAAC;QACZ,aAAa,EAAE,IAAI,IAAI,EAAE,CAAC,YAAY,EAAE;QACxC,aAAa,EAAE,EAAc,EAAE,6BAA6B;QAC5D,UAAU,EAAE,IAAI,GAAG,EAAkB,EAAE,iCAAiC;QACxE,cAAc,EAAE,EAAiE;KAClF,CAAC;IAEF,6BAA6B;IACrB,UAAU,GAAG;QACnB,YAAY,EAAE,CAAC;QACf,SAAS,EAAE,CAAC;QACZ,WAAW,EAAE,CAAC;QACd,UAAU,EAAE,EAA4B;QACxC,UAAU,EAAE,IAAI,GAAG,EAAkB;QACrC,aAAa,EAAE,IAAI,IAAI,EAAE,CAAC,YAAY,EAAE;QACxC,eAAe,EAAE,EAAc,EAAE,8CAA8C;QAC/E,aAAa,EAAE,EAAc,EAAE,6BAA6B;QAC5D,aAAa,EAAE,EAA2G;KAC3H,CAAC;IAEF,4CAA4C;IACpC,kBAAkB,GAAG,IAAI,GAAG,EAA8D,CAAC;IAC3F,gBAAgB,GAAG,IAAI,GAAG,EAA+B,CAAC;IAElE,kCAAkC;IAC1B,eAAe,GAAG;QACxB,UAAU,EAAE,CAAC;QACb,YAAY,EAAE,CAAC;QACf,YAAY,EAAE,CAAC;QACf,eAAe,EAAE,CAAC;QAClB,gBAAgB,EAAE,CAAC;QACnB,aAAa,EAAE,IAAI,IAAI,EAAE,CAAC,YAAY,EAAE;QACxC,SAAS,EAAE,EAAmF;KAC/F,CAAC;IAEF,YAAY,QAAkB;QAC5B,IAAI,CAAC,QAAQ,GAAG,QAAQ,CAAC;QACzB,0EAA0E;QAC1E,IAAI,CAAC,aAAa,GAAG,IAAI,OAAO,CAAC,QAAQ,CAAC,QAAQ,CAAC;YACjD,UAAU,EAAE;gBACV,WAAW,EAAE,YAAY;gBACzB,OAAO,EAAE,MAAM;gBACf,IAAI,EAAE,kBAAkB;aACzB;SACF,CAAC,CAAC;QACH,IAAI,CAAC,YAAY,GAAG,IAAI,OAAO,CAAC,YAAY,CAAC,YAAY,CAAC,IAAI,CAAC,aAAa,EAAE,UAAU,CAAC,CAAC;QAC1F,0CAA0C;QAC1C,IAAI,CAAC,YAAY,GAAG,IAAI,YAAY,CAAC,GAAG,CAAC,CAAC;IAC5C,CAAC;IAEM,KAAK,CAAC,KAAK;QAChB,gCAAgC;QAChC,IAAI,CAAC,YAAY,CAAC,KAAK,EAAE,CAAC;QAE1B,mCAAmC;QACnC,IAAI,CAAC,aAAa,GAAG,WAAW,CAAC,GAAG,EAAE;YACpC,MAAM,WAAW,GAAG,IAAI,IAAI,EAAE,CAAC,YAAY,EAAE,CAAC;YAE9C,IAAI,WAAW,KAAK,IAAI,CAAC,YAAY,CAAC,aAAa,EAAE,CAAC;gBACpD,IAAI,CAAC,YAAY,CAAC,SAAS,GAAG,CAAC,CAAC;gBAChC,IAAI,CAAC,YAAY,CAAC,aAAa,GAAG,CAAC,CAAC;gBACpC,IAAI,CAAC,YAAY,CAAC,WAAW,GAAG,CAAC,CAAC;gBAClC,IAAI,CAAC,YAAY,CAAC,YAAY,GAAG,CAAC,CAAC;gBACnC,IAAI,CAAC,YAAY,CAAC,aAAa,GAAG,EAAE,CAAC;gBACrC,IAAI,CAAC,YAAY,CAAC,UAAU,CAAC,KAAK,EAAE,CAAC;gBACrC,IAAI,CAAC,YAAY,CAAC,cAAc,GAAG,EAAE,CAAC;gBACtC,IAAI,CAAC,YAAY,CAAC,aAAa,GAAG,WAAW,CAAC;YAChD,CAAC;YAED,IAAI,WAAW,KAAK,IAAI,CAAC,UAAU,CAAC,aAAa,EAAE,CAAC;gBAClD,IAAI,CAAC,UAAU,CAAC,YAAY,GAAG,CAAC,CAAC;gBACjC,IAAI,CAAC,UAAU,CAAC,SAAS,GAAG,CAAC,CAAC;gBAC9B,IAAI,CAAC,UAAU,CAAC,WAAW,GAAG,CAAC,CAAC;gBAChC,IAAI,CAAC,UAAU,CAAC,UAAU,GAAG,EAAE,CAAC;gBAChC,IAAI,CAAC,UAAU,CAAC,UAAU,CAAC,KAAK,EAAE,CAAC;gBACnC,IAAI,CAAC,UAAU,CAAC,eAAe,GAAG,EAAE,CAAC;gBACrC,IAAI,CAAC,UAAU,CAAC,aAAa,GAAG,EAAE,CAAC;gBACnC,IAAI,CAAC,UAAU,CAAC,aAAa,GAAG,EAAE,CAAC;gBACnC,IAAI,CAAC,UAAU,CAAC,aAAa,GAAG,WAAW,CAAC;YAC9C,CAAC;YAED,IAAI,WAAW,KAAK,IAAI,CAAC,eAAe,CAAC,aAAa,EAAE,CAAC;gBACvD,IAAI,CAAC,eAAe,CAAC,UAAU,GAAG,CAAC,CAAC;gBACpC,IAAI,CAAC,eAAe,CAAC,YAAY,GAAG,CAAC,CAAC;gBACtC,IAAI,CAAC,eAAe,CAAC,YAAY,GAAG,CAAC,CAAC;gBACtC,IAAI,CAAC,eAAe,CAAC,eAAe,GAAG,CAAC,CAAC;gBACzC,IAAI,CAAC,eAAe,CAAC,gBAAgB,GAAG,CAAC,CAAC;gBAC1C,IAAI,CAAC,eAAe,CAAC,SAAS,GAAG,EAAE,CAAC;gBACpC,IAAI,CAAC,eAAe,CAAC,aAAa,GAAG,WAAW,CAAC;YACnD,CAAC;YAED,yEAAyE;YACzE,IAAI,CAAC,eAAe,EAAE,CAAC;QACzB,CAAC,EAAE,KAAK,CAAC,CAAC,CAAC,qBAAqB;QAEhC,MAAM,CAAC,GAAG,CAAC,MAAM,EAAE,wBAAwB,CAAC,CAAC;IAC/C,CAAC;IAEM,KAAK,CAAC,IAAI;QACf,2BAA2B;QAC3B,IAAI,IAAI,CAAC,aAAa,EAAE,CAAC;YACvB,aAAa,CAAC,IAAI,CAAC,aAAa,CAAC,CAAC;YAClC,IAAI,CAAC,aAAa,GAAG,SAAS,CAAC;QACjC,CAAC;QAED,IAAI,CAAC,YAAY,CAAC,IAAI,EAAE,CAAC;QAEzB,mDAAmD;QACnD,IAAI,CAAC,YAAY,CAAC,KAAK,EAAE,CAAC;QAC1B,IAAI,CAAC,kBAAkB,CAAC,KAAK,EAAE,CAAC;QAChC,IAAI,CAAC,gBAAgB,CAAC,KAAK,EAAE,CAAC;QAE9B,MAAM,CAAC,GAAG,CAAC,MAAM,EAAE,wBAAwB,CAAC,CAAC;IAC/C,CAAC;IAED,sDAAsD;IAC/C,KAAK,CAAC,cAAc;QACzB,OAAO,IAAI,CAAC,YAAY,CAAC,GAAG,CAAC,aAAa,EAAE,KAAK,IAAI,EAAE;YACrD,MAAM,gBAAgB,GAAG,MAAM,IAAI,CAAC,YAAY,CAAC,UAAU,EAAE,CAAC;YAC9D,MAAM,YAAY,GAAG,IAAI,CAAC,QAAQ,CAAC,UAAU,CAAC,CAAC,CAAC,IAAI,CAAC,QAAQ,CAAC,UAAU,CAAC,UAAU,EAAE,CAAC,CAAC,CAAC,IAAI,CAAC;YAC7F,MAAM,UAAU,GAAG,IAAI,CAAC,QAAQ,CAAC,UAAU,CAAC,CAAC,CAAC,MAAM,IAAI,CAAC,QAAQ,CAAC,UAAU,CAAC,aAAa,EAAE,CAAC,CAAC,CAAC,IAAI,CAAC;YAEpG,OAAO;gBACL,MAAM,EAAE,OAAO,CAAC,MAAM,EAAE;gBACxB,SAAS,EAAE,IAAI,CAAC,GAAG,EAAE,GAAG,CAAC,OAAO,CAAC,MAAM,EAAE,GAAG,IAAI,CAAC;gBACjD,WAAW,EAAE;oBACX,QAAQ,EAAE,OAAO,CAAC,WAAW,EAAE,CAAC,QAAQ;oBACxC,SAAS,EAAE,OAAO,CAAC,WAAW,EAAE,CAAC,SAAS;oBAC1C,QAAQ,EAAE,OAAO,CAAC,WAAW,EAAE,CAAC,QAAQ;oBACxC,GAAG,EAAE,OAAO,CAAC,WAAW,EAAE,CAAC,GAAG;oBAC9B,+BAA+B;oBAC/B,WAAW,EAAE,IAAI,CAAC,YAAY,CAAC,WAAW;oBAC1C,gBAAgB,EAAE,gBAAgB,CAAC,gBAAgB;oBACnD,qBAAqB,EAAE,gBAAgB,CAAC,gBAAgB;iBACzD;gBACD,QAAQ,EAAE;oBACR,IAAI,EAAE,gBAAgB,CAAC,aAAa;oBACpC,MAAM,EAAE,CAAC;iBACV;gBACD,iBAAiB,EAAE,UAAU,CAAC,CAAC,CAAC,UAAU,CAAC,iBAAiB,CAAC,CAAC,CAAC,CAAC;gBAChE,gBAAgB,EAAE,YAAY,CAAC,CAAC,CAAC,YAAY,CAAC,MAAM,CAAC,WAAW,EAAE,CAAC,CAAC,CAAC,CAAC;gBACtE,iBAAiB,EAAE,YAAY,CAAC,CAAC,CAAC,YAAY,CAAC,QAAQ,CAAC,SAAS,EAAE,CAAC,CAAC,CAAC,CAAC;gBACvE,UAAU,EAAE,YAAY,CAAC,CAAC,CAAC;oBACzB,OAAO,EAAE,YAAY,CAAC,MAAM,CAAC,OAAO,EAAE;oBACtC,QAAQ,EAAE,YAAY,CAAC,MAAM,CAAC,QAAQ,EAAE;oBACxC,gBAAgB,EAAE,YAAY,CAAC,UAAU,CAAC,OAAO,EAAE,CAAC,EAAE;oBACtD,iBAAiB,EAAE,YAAY,CAAC,UAAU,CAAC,OAAO,EAAE,CAAC,GAAG;iBACzD,CAAC,CAAC,CAAC,EAAE,OAAO,EAAE,CAAC,EAAE,QAAQ,EAAE,CAAC,EAAE,gBAAgB,EAAE,CAAC,EAAE,iBAAiB,EAAE,CAAC,EAAE;aAC3E,CAAC;QACJ,CAAC,CAAC,CAAC;IACL,CAAC;IAED,oBAAoB;IACb,KAAK,CAAC,aAAa;QACxB,OAAO,IAAI,CAAC,YAAY,CAAC,GAAG,CAAC,YAAY,EAAE,GAAG,EAAE;YAC9C,kCAAkC;YAClC,MAAM,eAAe,GAAG,IAAI,CAAC,YAAY,CAAC,aAAa,CAAC,MAAM,GAAG,CAAC;gBAChE,CAAC,CAAC,IAAI,CAAC,YAAY,CAAC,aAAa,CAAC,MAAM,CAAC,CAAC,CAAC,EAAE,CAAC,EAAE,EAAE,CAAC,CAAC,GAAG,CAAC,EAAE,CAAC,CAAC,GAAG,IAAI,CAAC,YAAY,CAAC,aAAa,CAAC,MAAM;gBACrG,CAAC,CAAC,CAAC,CAAC;YAEN,qBAAqB;YACrB,MAAM,aAAa,GAAG,KAAK,CAAC,IAAI,CAAC,IAAI,CAAC,YAAY,CAAC,UAAU,CAAC,OAAO,EAAE,CAAC;iBACrE,IAAI,CAAC,CAAC,CAAC,EAAE,CAAC,EAAE,EAAE,CAAC,CAAC,CAAC,CAAC,CAAC,GAAG,CAAC,CAAC,CAAC,CAAC,CAAC;iBAC3B,KAAK,CAAC,CAAC,EAAE,EAAE,CAAC;iBACZ,GAAG,CAAC,CAAC,CAAC,KAAK,EAAE,KAAK,CAAC,EAAE,EAAE,CAAC,CAAC,EAAE,KAAK,EAAE,KAAK,EAAE,CAAC,CAAC,CAAC;YAE/C,wCAAwC;YACxC,MAAM,cAAc,GAAG,IAAI,CAAC,YAAY,CAAC,cAAc,CAAC,KAAK,CAAC,CAAC,EAAE,CAAC,CAAC;YAEnE,OAAO;gBACL,SAAS,EAAE,IAAI,CAAC,YAAY,CAAC,SAAS;gBACtC,aAAa,EAAE,IAAI,CAAC,YAAY,CAAC,aAAa;gBAC9C,WAAW,EAAE,IAAI,CAAC,YAAY,CAAC,WAAW;gBAC1C,UAAU,EAAE,IAAI,CAAC,YAAY,CAAC,YAAY,GAAG,CAAC;oBAC5C,CAAC,CAAC,CAAC,IAAI,CAAC,YAAY,CAAC,YAAY,GAAG,IAAI,CAAC,YAAY,CAAC,SAAS,CAAC,GAAG,GAAG;oBACtE,CAAC,CAAC,CAAC;gBACL,YAAY,EAAE,IAAI,CAAC,YAAY,CAAC,SAAS,GAAG,CAAC;oBAC3C,CAAC,CAAC,CAAC,CAAC,IAAI,CAAC,YAAY,CAAC,SAAS,GAAG,IAAI,CAAC,YAAY,CAAC,WAAW,CAAC,GAAG,IAAI,CAAC,YAAY,CAAC,SAAS,CAAC,GAAG,GAAG;oBACrG,CAAC,CAAC,GAAG;gBACP,SAAS,EAAE,IAAI,CAAC,YAAY,CAAC,SAAS;gBACtC,mBAAmB,EAAE,IAAI,CAAC,KAAK,CAAC,eAAe,CAAC;gBAChD,aAAa;gBACb,cAAc;aACf,CAAC;QACJ,CAAC,CAAC,CAAC;IACL,CAAC;IAED,kBAAkB;IACX,KAAK,CAAC,WAAW;QACtB,OAAO,IAAI,CAAC,YAAY,CAAC,GAAG,CAAC,UAAU,EAAE,GAAG,EAAE;YAC5C,MAAM,YAAY,GAAG,IAAI,CAAC,UAAU,CAAC,YAAY,GAAG,CAAC;gBACnD,CAAC,CAAC,CAAC,IAAI,CAAC,UAAU,CAAC,SAAS,GAAG,IAAI,CAAC,UAAU,CAAC,YAAY,CAAC,GAAG,GAAG;gBAClE,CAAC,CAAC,CAAC,CAAC;YAEN,MAAM,UAAU,GAAG,KAAK,CAAC,IAAI,CAAC,IAAI,CAAC,UAAU,CAAC,UAAU,CAAC,OAAO,EAAE,CAAC;iBAChE,IAAI,CAAC,CAAC,CAAC,EAAE,CAAC,EAAE,EAAE,CAAC,CAAC,CAAC,CAAC,CAAC,GAAG,CAAC,CAAC,CAAC,CAAC,CAAC;iBAC3B,KAAK,CAAC,CAAC,EAAE,EAAE,CAAC;iBACZ,GAAG,CAAC,CAAC,CAAC,MAAM,EAAE,KAAK,CAAC,EAAE,EAAE,CAAC,CAAC,EAAE,MAAM,EAAE,KAAK,EAAE,CAAC,CAAC,CAAC;YAEjD,sDAAsD;YACtD,MAAM,GAAG,GAAG,IAAI,CAAC,GAAG,EAAE,CAAC;YACvB,MAAM,YAAY,GAAG,GAAG,GAAG,KAAK,CAAC;YACjC,MAAM,aAAa,GAAG,IAAI,CAAC,UAAU,CAAC,eAAe,CAAC,MAAM,CAAC,EAAE,CAAC,EAAE,CAAC,EAAE,IAAI,YAAY,CAAC,CAAC;YACvF,MAAM,gBAAgB,GAAG,aAAa,CAAC,MAAM,GAAG,EAAE,CAAC;YAEnD,kCAAkC;YAClC,MAAM,eAAe,GAAG,IAAI,CAAC,UAAU,CAAC,aAAa,CAAC,MAAM,GAAG,CAAC;gBAC9D,CAAC,CAAC,IAAI,CAAC,UAAU,CAAC,aAAa,CAAC,MAAM,CAAC,CAAC,CAAC,EAAE,CAAC,EAAE,EAAE,CAAC,CAAC,GAAG,CAAC,EAAE,CAAC,CAAC,GAAG,IAAI,CAAC,UAAU,CAAC,aAAa,CAAC,MAAM;gBACjG,CAAC,CAAC,CAAC,CAAC;YAEN,OAAO;gBACL,gBAAgB,EAAE,IAAI,CAAC,KAAK,CAAC,gBAAgB,GAAG,EAAE,CAAC,GAAG,EAAE;gBACxD,YAAY,EAAE,IAAI,CAAC,UAAU,CAAC,YAAY;gBAC1C,SAAS,EAAE,IAAI,CAAC,UAAU,CAAC,SAAS;gBACpC,WAAW,EAAE,IAAI,CAAC,UAAU,CAAC,WAAW;gBACxC,YAAY,EAAE,YAAY;gBAC1B,UAAU,EAAE,UAAU;gBACtB,UAAU,EAAE,IAAI,CAAC,UAAU,CAAC,UAAU;gBACtC,mBAAmB,EAAE,IAAI,CAAC,KAAK,CAAC,eAAe,CAAC;gBAChD,aAAa,EAAE,IAAI,CAAC,UAAU,CAAC,UAAU,CAAC,IAAI;gBAC9C,aAAa,EAAE,IAAI,CAAC,UAAU,CAAC,aAAa,CAAC,KAAK,EAAE;aACrD,CAAC;QACJ,CAAC,CAAC,CAAC;IACL,CAAC;IAED;;;OAGG;IACK,sBAAsB;QAC5B,IAAI,CAAC;YACH,MAAM,cAAc,GAAG,cAAc,CAAC,WAAW,EAAE,CAAC;YACpD,MAAM,OAAO,GAAG,cAAc,CAAC,gBAAgB,CAAC,QAAQ,CAAC,CAAC,CAAC,WAAW;YAEtE,IAAI,CAAC,eAAe,CAAC,YAAY,GAAG,OAAO,CAAC,MAAM,CAAC,iBAAiB,CAAC,IAAI,CAAC,IAAI,CAAC,CAAC;YAChF,IAAI,CAAC,eAAe,CAAC,eAAe,GAAG,OAAO,CAAC,MAAM,CAAC,iBAAiB,CAAC,OAAO,CAAC,IAAI,CAAC,CAAC;YACtF,IAAI,CAAC,eAAe,CAAC,gBAAgB,GAAG,OAAO,CAAC,MAAM,CAAC,iBAAiB,CAAC,KAAK,CAAC,IAAI,CAAC,CAAC,CAAC,qBAAqB;YAC3G,IAAI,CAAC,eAAe,CAAC,YAAY;gBAC/B,OAAO,CAAC,MAAM,CAAC,iBAAiB,CAAC,cAAc,CAAC,IAAI,CAAC,CAAC;YACxD,IAAI,CAAC,eAAe,CAAC,UAAU;gBAC7B,CAAC,OAAO,CAAC,MAAM,CAAC,iBAAiB,CAAC,aAAa,CAAC,IAAI,CAAC,CAAC;oBACtD,CAAC,OAAO,CAAC,MAAM,CAAC,iBAAiB,CAAC,mBAAmB,CAAC,IAAI,CAAC,CAAC,CAAC;QACjE,CAAC;QAAC,MAAM,CAAC;YACP,qDAAqD;QACvD,CAAC;IACH,CAAC;IAED,uBAAuB;IAChB,KAAK,CAAC,gBAAgB;QAC3B,OAAO,IAAI,CAAC,YAAY,CAAC,GAAG,CAAC,eAAe,EAAE,GAAG,EAAE;YACjD,oDAAoD;YACpD,IAAI,CAAC,sBAAsB,EAAE,CAAC;YAE9B,iCAAiC;YACjC,MAAM,eAAe,GAAG,IAAI,CAAC,eAAe,CAAC,SAAS,CAAC,KAAK,CAAC,CAAC,EAAE,CAAC,CAAC;YAElE,OAAO;gBACL,UAAU,EAAE,IAAI,CAAC,eAAe,CAAC,UAAU;gBAC3C,YAAY,EAAE,IAAI,CAAC,eAAe,CAAC,YAAY;gBAC/C,YAAY,EAAE,IAAI,CAAC,eAAe,CAAC,YAAY;gBAC/C,eAAe,EAAE,IAAI,CAAC,eAAe,CAAC,eAAe;gBACrD,gBAAgB,EAAE,IAAI,CAAC,eAAe,CAAC,gBAAgB;gBACvD,mBAAmB,EAAE,IAAI,CAAC,eAAe,CAAC,YAAY;oBACpD,IAAI,CAAC,eAAe,CAAC,eAAe;oBACpC,IAAI,CAAC,eAAe,CAAC,gBAAgB;gBACvC,eAAe;aAChB,CAAC;QACJ,CAAC,CAAC,CAAC;IACL,CAAC;IAED,sCAAsC;IAC/B,KAAK,CAAC,iBAAiB;QAC5B,OAAO,IAAI,CAAC,YAAY,CAAC,GAAG,CAAC,gBAAgB,EAAE,GAAG,EAAE;YAClD,MAAM,YAAY,GAAG,IAAI,CAAC,QAAQ,CAAC,UAAU,CAAC,CAAC,CAAC,IAAI,CAAC,QAAQ,CAAC,UAAU,CAAC,UAAU,EAAE,CAAC,CAAC,CAAC,IAAI,CAAC;YAE7F,IAAI,CAAC,YAAY,EAAE,CAAC;gBAClB,OAAO,EAAE,CAAC;YACZ,CAAC;YAED,MAAM,kBAAkB,GAAG,YAAY,CAAC,WAAW,CAAC,OAAO,EAAE,CAAC;YAC9D,MAAM,cAAc,GAAG,EAAE,CAAC;YAE1B,KAAK,MAAM,CAAC,SAAS,EAAE,KAAK,CAAC,IAAI,kBAAkB,EAAE,CAAC;gBACpD,cAAc,CAAC,IAAI,CAAC;oBAClB,IAAI,EAAE,OAAO;oBACb,KAAK;oBACL,MAAM,EAAE,SAAS;oBACjB,YAAY,EAAE,IAAI,IAAI,EAAE;iBACzB,CAAC,CAAC;YACL,CAAC;YAED,OAAO,cAAc,CAAC;QACxB,CAAC,CAAC,CAAC;IACL,CAAC;IAED,+BAA+B;IACxB,cAAc,CAAC,SAAkB,EAAE,cAAuB;QAC/D,IAAI,CAAC,YAAY,CAAC,SAAS,EAAE,CAAC;QAC9B,IAAI,CAAC,oBAAoB,CAAC,MAAM,CAAC,CAAC;QAElC,IAAI,SAAS,EAAE,CAAC;YACd,MAAM,KAAK,GAAG,IAAI,CAAC,YAAY,CAAC,UAAU,CAAC,GAAG,CAAC,SAAS,CAAC,IAAI,CAAC,CAAC;YAC/D,IAAI,CAAC,YAAY,CAAC,UAAU,CAAC,GAAG,CAAC,SAAS,EAAE,KAAK,GAAG,CAAC,CAAC,CAAC;YAEvD,8DAA8D;YAC9D,IAAI,IAAI,CAAC,YAAY,CAAC,UAAU,CAAC,IAAI,GAAG,IAAI,CAAC,eAAe,EAAE,CAAC;gBAC7D,MAAM,MAAM,GAAG,KAAK,CAAC,IAAI,CAAC,IAAI,CAAC,YAAY,CAAC,UAAU,CAAC,OAAO,EAAE,CAAC;qBAC9D,IAAI,CAAC,CAAC,CAAC,EAAE,CAAC,EAAE,EAAE,CAAC,CAAC,CAAC,CAAC,CAAC,GAAG,CAAC,CAAC,CAAC,CAAC,CAAC;qBAC3B,KAAK,CAAC,CAAC,EAAE,IAAI,CAAC,KAAK,CAAC,IAAI,CAAC,eAAe,GAAG,GAAG,CAAC,CAAC,CAAC;gBACpD,IAAI,CAAC,YAAY,CAAC,UAAU,GAAG,IAAI,GAAG,CAAC,MAAM,CAAC,CAAC;YACjD,CAAC;QACH,CAAC;QAED,IAAI,cAAc,EAAE,CAAC;YACnB,IAAI,CAAC,YAAY,CAAC,aAAa,CAAC,IAAI,CAAC,cAAc,CAAC,CAAC;YACrD,qCAAqC;YACrC,IAAI,IAAI,CAAC,YAAY,CAAC,aAAa,CAAC,MAAM,GAAG,IAAI,EAAE,CAAC;gBAClD,IAAI,CAAC,YAAY,CAAC,aAAa,CAAC,KAAK,EAAE,CAAC;YAC1C,CAAC;QACH,CAAC;QAED,IAAI,CAAC,YAAY,CAAC,cAAc,CAAC,IAAI,CAAC;YACpC,SAAS,EAAE,IAAI,CAAC,GAAG,EAAE;YACrB,IAAI,EAAE,MAAM;YACZ,OAAO,EAAE,SAAS,IAAI,SAAS;SAChC,CAAC,CAAC;QAEH,iCAAiC;QACjC,IAAI,IAAI,CAAC,YAAY,CAAC,cAAc,CAAC,MAAM,GAAG,IAAI,EAAE,CAAC;YACnD,IAAI,CAAC,YAAY,CAAC,cAAc,CAAC,KAAK,EAAE,CAAC;QAC3C,CAAC;IACH,CAAC;IAEM,kBAAkB,CAAC,MAAe;QACvC,IAAI,CAAC,YAAY,CAAC,aAAa,EAAE,CAAC;QAClC,IAAI,CAAC,oBAAoB,CAAC,UAAU,CAAC,CAAC;QAEtC,IAAI,CAAC,YAAY,CAAC,cAAc,CAAC,IAAI,CAAC;YACpC,SAAS,EAAE,IAAI,CAAC,GAAG,EAAE;YACrB,IAAI,EAAE,UAAU;YAChB,OAAO,EAAE,MAAM,IAAI,SAAS;SAC7B,CAAC,CAAC;QAEH,iCAAiC;QACjC,IAAI,IAAI,CAAC,YAAY,CAAC,cAAc,CAAC,MAAM,GAAG,IAAI,EAAE,CAAC;YACnD,IAAI,CAAC,YAAY,CAAC,cAAc,CAAC,KAAK,EAAE,CAAC;QAC3C,CAAC;IACH,CAAC;IAEM,gBAAgB,CAAC,SAAkB,EAAE,MAAe;QACzD,IAAI,CAAC,YAAY,CAAC,WAAW,EAAE,CAAC;QAChC,IAAI,CAAC,oBAAoB,CAAC,QAAQ,CAAC,CAAC;QAEpC,IAAI,CAAC,YAAY,CAAC,cAAc,CAAC,IAAI,CAAC;YACpC,SAAS,EAAE,IAAI,CAAC,GAAG,EAAE;YACrB,IAAI,EAAE,QAAQ;YACd,OAAO,EAAE,GAAG,SAAS,IAAI,SAAS,KAAK,MAAM,IAAI,eAAe,EAAE;SACnE,CAAC,CAAC;QAEH,iCAAiC;QACjC,IAAI,IAAI,CAAC,YAAY,CAAC,cAAc,CAAC,MAAM,GAAG,IAAI,EAAE,CAAC;YACnD,IAAI,CAAC,YAAY,CAAC,cAAc,CAAC,KAAK,EAAE,CAAC;QAC3C,CAAC;IACH,CAAC;IAEM,iBAAiB,CAAC,SAAkB;QACzC,IAAI,CAAC,YAAY,CAAC,YAAY,EAAE,CAAC;QAEjC,IAAI,CAAC,YAAY,CAAC,cAAc,CAAC,IAAI,CAAC;YACpC,SAAS,EAAE,IAAI,CAAC,GAAG,EAAE;YACrB,IAAI,EAAE,SAAS;YACf,OAAO,EAAE,SAAS,IAAI,SAAS;SAChC,CAAC,CAAC;QAEH,iCAAiC;QACjC,IAAI,IAAI,CAAC,YAAY,CAAC,cAAc,CAAC,MAAM,GAAG,IAAI,EAAE,CAAC;YACnD,IAAI,CAAC,YAAY,CAAC,cAAc,CAAC,KAAK,EAAE,CAAC;QAC3C,CAAC;IACH,CAAC;IAEM,eAAe,CAAC,IAAY;QACjC,IAAI,CAAC,YAAY,CAAC,SAAS,GAAG,IAAI,CAAC;IACrC,CAAC;IAED,6BAA6B;IACtB,aAAa,CAAC,SAAiB,EAAE,MAAc,EAAE,QAAiB,EAAE,cAAuB,EAAE,QAAkB;QACpH,IAAI,CAAC,UAAU,CAAC,YAAY,EAAE,CAAC;QAC/B,IAAI,CAAC,kBAAkB,EAAE,CAAC;QAE1B,2BAA2B;QAC3B,IAAI,CAAC,UAAU,CAAC,aAAa,CAAC,IAAI,CAAC;YACjC,SAAS,EAAE,IAAI,CAAC,GAAG,EAAE;YACrB,MAAM;YACN,IAAI,EAAE,SAAS;YACf,QAAQ,EAAE,QAAQ,IAAI,IAAI;YAC1B,cAAc,EAAE,cAAc,IAAI,CAAC;SACpC,CAAC,CAAC;QACH,IAAI,IAAI,CAAC,UAAU,CAAC,aAAa,CAAC,MAAM,GAAG,GAAG,EAAE,CAAC;YAC/C,IAAI,CAAC,UAAU,CAAC,aAAa,CAAC,KAAK,EAAE,CAAC;QACxC,CAAC;QAED,IAAI,QAAQ,EAAE,CAAC;YACb,IAAI,CAAC,UAAU,CAAC,SAAS,EAAE,CAAC;QAC9B,CAAC;aAAM,CAAC;YACN,IAAI,CAAC,UAAU,CAAC,WAAW,EAAE,CAAC;QAChC,CAAC;QAED,wBAAwB;QACxB,IAAI,CAAC,UAAU,CAAC,eAAe,CAAC,IAAI,CAAC,IAAI,CAAC,GAAG,EAAE,CAAC,CAAC;QAEjD,2CAA2C;QAC3C,MAAM,cAAc,GAAG,IAAI,CAAC,GAAG,EAAE,GAAG,MAAM,CAAC;QAC3C,IAAI,CAAC,UAAU,CAAC,eAAe,GAAG,IAAI,CAAC,UAAU,CAAC,eAAe,CAAC,MAAM,CAAC,EAAE,CAAC,EAAE,CAAC,EAAE,IAAI,cAAc,CAAC,CAAC;QAErG,kCAAkC;QAClC,IAAI,cAAc,EAAE,CAAC;YACnB,IAAI,CAAC,UAAU,CAAC,aAAa,CAAC,IAAI,CAAC,cAAc,CAAC,CAAC;YACnD,qCAAqC;YACrC,IAAI,IAAI,CAAC,UAAU,CAAC,aAAa,CAAC,MAAM,GAAG,IAAI,EAAE,CAAC;gBAChD,IAAI,CAAC,UAAU,CAAC,aAAa,CAAC,KAAK,EAAE,CAAC;YACxC,CAAC;QACH,CAAC;QAED,oBAAoB;QACpB,IAAI,CAAC,UAAU,CAAC,UAAU,CAAC,SAAS,CAAC,GAAG,CAAC,IAAI,CAAC,UAAU,CAAC,UAAU,CAAC,SAAS,CAAC,IAAI,CAAC,CAAC,GAAG,CAAC,CAAC;QAEzF,oCAAoC;QACpC,MAAM,YAAY,GAAG,IAAI,CAAC,UAAU,CAAC,UAAU,CAAC,GAAG,CAAC,MAAM,CAAC,IAAI,CAAC,CAAC;QACjE,IAAI,CAAC,UAAU,CAAC,UAAU,CAAC,GAAG,CAAC,MAAM,EAAE,YAAY,GAAG,CAAC,CAAC,CAAC;QAEzD,iEAAiE;QACjE,IAAI,IAAI,CAAC,UAAU,CAAC,UAAU,CAAC,IAAI,GAAG,IAAI,CAAC,eAAe,EAAE,CAAC;YAC3D,6DAA6D;YAC7D,MAAM,aAAa,GAAG,KAAK,CAAC,IAAI,CAAC,IAAI,CAAC,UAAU,CAAC,UAAU,CAAC,OAAO,EAAE,CAAC;iBACnE,IAAI,CAAC,CAAC,CAAC,EAAE,CAAC,EAAE,EAAE,CAAC,CAAC,CAAC,CAAC,CAAC,GAAG,CAAC,CAAC,CAAC,CAAC,CAAC;iBAC3B,KAAK,CAAC,CAAC,EAAE,IAAI,CAAC,KAAK,CAAC,IAAI,CAAC,eAAe,GAAG,GAAG,CAAC,CAAC,CAAC,CAAC,qCAAqC;YAE1F,wCAAwC;YACxC,IAAI,CAAC,UAAU,CAAC,UAAU,CAAC,KAAK,EAAE,CAAC;YACnC,aAAa,CAAC,OAAO,CAAC,CAAC,CAAC,MAAM,EAAE,KAAK,CAAC,EAAE,EAAE;gBACxC,IAAI,CAAC,UAAU,CAAC,UAAU,CAAC,GAAG,CAAC,MAAM,EAAE,KAAK,CAAC,CAAC;YAChD,CAAC,CAAC,CAAC;QACL,CAAC;IACH,CAAC;IAED,kCAAkC;IAC3B,cAAc,CAAC,EAAW,EAAE,MAAe;QAChD,IAAI,CAAC,eAAe,CAAC,UAAU,EAAE,CAAC;QAElC,IAAI,CAAC,eAAe,CAAC,SAAS,CAAC,IAAI,CAAC;YAClC,SAAS,EAAE,IAAI,CAAC,GAAG,EAAE;YACrB,IAAI,EAAE,YAAY;YAClB,QAAQ,EAAE,QAAQ;YAClB,OAAO,EAAE,MAAM,EAAE,IAAI,SAAS,aAAa,MAAM,IAAI,iBAAiB,EAAE;SACzE,CAAC,CAAC;QAEH,gCAAgC;QAChC,IAAI,IAAI,CAAC,eAAe,CAAC,SAAS,CAAC,MAAM,GAAG,IAAI,EAAE,CAAC;YACjD,IAAI,CAAC,eAAe,CAAC,SAAS,CAAC,KAAK,EAAE,CAAC;QACzC,CAAC;IACH,CAAC;IAEM,gBAAgB,CAAC,QAAiB,EAAE,EAAW;QACpD,IAAI,CAAC,eAAe,CAAC,YAAY,EAAE,CAAC;QAEpC,IAAI,CAAC,eAAe,CAAC,SAAS,CAAC,IAAI,CAAC;YAClC,SAAS,EAAE,IAAI,CAAC,GAAG,EAAE;YACrB,IAAI,EAAE,cAAc;YACpB,QAAQ,EAAE,KAAK;YACf,OAAO,EAAE,6BAA6B,QAAQ,IAAI,SAAS,SAAS,EAAE,IAAI,SAAS,EAAE;SACtF,CAAC,CAAC;QAEH,gCAAgC;QAChC,IAAI,IAAI,CAAC,eAAe,CAAC,SAAS,CAAC,MAAM,GAAG,IAAI,EAAE,CAAC;YACjD,IAAI,CAAC,eAAe,CAAC,SAAS,CAAC,KAAK,EAAE,CAAC;QACzC,CAAC;IACH,CAAC;IAEM,iBAAiB,CAAC,MAAe;QACtC,IAAI,CAAC,eAAe,CAAC,YAAY,EAAE,CAAC;QAEpC,IAAI,CAAC,eAAe,CAAC,SAAS,CAAC,IAAI,CAAC;YAClC,SAAS,EAAE,IAAI,CAAC,GAAG,EAAE;YACrB,IAAI,EAAE,eAAe;YACrB,QAAQ,EAAE,KAAK;YACf,OAAO,EAAE,sBAAsB,MAAM,IAAI,SAAS,EAAE;SACrD,CAAC,CAAC;QAEH,gCAAgC;QAChC,IAAI,IAAI,CAAC,eAAe,CAAC,SAAS,CAAC,MAAM,GAAG,IAAI,EAAE,CAAC;YACjD,IAAI,CAAC,eAAe,CAAC,SAAS,CAAC,KAAK,EAAE,CAAC;QACzC,CAAC;IACH,CAAC;IAEM,oBAAoB,CAAC,MAAe;QACzC,IAAI,CAAC,eAAe,CAAC,eAAe,EAAE,CAAC;QAEvC,IAAI,CAAC,eAAe,CAAC,SAAS,CAAC,IAAI,CAAC;YAClC,SAAS,EAAE,IAAI,CAAC,GAAG,EAAE;YACrB,IAAI,EAAE,kBAAkB;YACxB,QAAQ,EAAE,MAAM;YAChB,OAAO,EAAE,yBAAyB,MAAM,IAAI,SAAS,EAAE;SACxD,CAAC,CAAC;QAEH,gCAAgC;QAChC,IAAI,IAAI,CAAC,eAAe,CAAC,SAAS,CAAC,MAAM,GAAG,IAAI,EAAE,CAAC;YACjD,IAAI,CAAC,eAAe,CAAC,SAAS,CAAC,KAAK,EAAE,CAAC;QACzC,CAAC;IACH,CAAC;IAEM,qBAAqB,CAAC,MAAe;QAC1C,IAAI,CAAC,eAAe,CAAC,gBAAgB,EAAE,CAAC;QAExC,IAAI,CAAC,eAAe,CAAC,SAAS,CAAC,IAAI,CAAC;YAClC,SAAS,EAAE,IAAI,CAAC,GAAG,EAAE;YACrB,IAAI,EAAE,mBAAmB;YACzB,QAAQ,EAAE,MAAM;YAChB,OAAO,EAAE,yBAAyB,MAAM,IAAI,SAAS,EAAE;SACxD,CAAC,CAAC;QAEH,gCAAgC;QAChC,IAAI,IAAI,CAAC,eAAe,CAAC,SAAS,CAAC,MAAM,GAAG,IAAI,EAAE,CAAC;YACjD,IAAI,CAAC,eAAe,CAAC,SAAS,CAAC,KAAK,EAAE,CAAC;QACzC,CAAC;IACH,CAAC;IAED,sCAAsC;IAC/B,KAAK,CAAC,eAAe;QAC1B,sEAAsE;QACtE,OAAO,IAAI,CAAC,YAAY,CAAC,GAAG,CAAC,cAAc,EAAE,GAAG,EAAE;YAChD,MAAM,YAAY,GAAG,IAAI,CAAC,QAAQ,CAAC,UAAU,CAAC,CAAC,CAAC,IAAI,CAAC,QAAQ,CAAC,UAAU,CAAC,UAAU,EAAE,CAAC,CAAC,CAAC,IAAI,CAAC;YAE7F,IAAI,CAAC,YAAY,EAAE,CAAC;gBAClB,OAAO;oBACL,eAAe,EAAE,IAAI,GAAG,EAAkB;oBAC1C,cAAc,EAAE,EAAE,gBAAgB,EAAE,CAAC,EAAE,iBAAiB,EAAE,CAAC,EAAE;oBAC7D,MAAM,EAAE,EAA0C;oBAClD,oBAAoB,EAAE,EAAE,OAAO,EAAE,CAAC,EAAE,QAAQ,EAAE,CAAC,EAAE;oBACjD,iBAAiB,EAAE,EAA2D;oBAC9E,cAAc,EAAE,IAAI,GAAG,EAAuC;oBAC9D,iBAAiB,EAAE,CAAC;oBACpB,aAAa,EAAE,CAAC;iBACjB,CAAC;YACJ,CAAC;YAED,gCAAgC;YAChC,MAAM,eAAe,GAAG,YAAY,CAAC,WAAW,CAAC,IAAI,EAAE,CAAC;YACxD,MAAM,iBAAiB,GAAG,YAAY,CAAC,UAAU,CAAC,OAAO,EAAE,CAAC;YAE5D,sBAAsB;YACtB,MAAM,cAAc,GAAG;gBACrB,gBAAgB,EAAE,iBAAiB,CAAC,EAAE;gBACtC,iBAAiB,EAAE,iBAAiB,CAAC,GAAG;aACzC,CAAC;YAEF,cAAc;YACd,MAAM,MAAM,GAAG,YAAY,CAAC,WAAW,CAAC,MAAM,CAAC,EAAE,CAAC,CAAC;YAEnD,6BAA6B;YAC7B,MAAM,oBAAoB,GAAG;gBAC3B,OAAO,EAAE,YAAY,CAAC,MAAM,CAAC,OAAO,EAAE;gBACtC,QAAQ,EAAE,YAAY,CAAC,MAAM,CAAC,QAAQ,EAAE;aACzC,CAAC;YAEF,8DAA8D;YAC9D,MAAM,iBAAiB,GAAG,YAAY,CAAC,UAAU,CAAC,OAAO,CAAC,GAAG,CAAC,CAAC;YAE/D,wBAAwB;YACxB,MAAM,cAAc,GAAG,YAAY,CAAC,UAAU,CAAC,IAAI,EAAE,CAAC;YAEtD,yBAAyB;YACzB,MAAM,iBAAiB,GAAG,YAAY,CAAC,QAAQ,CAAC,SAAS,EAAE,CAAC;YAC5D,MAAM,aAAa,GAAG,YAAY,CAAC,QAAQ,CAAC,KAAK,EAAE,CAAC;YAEpD,OAAO;gBACL,eAAe;gBACf,cAAc;gBACd,MAAM;gBACN,oBAAoB;gBACpB,iBAAiB;gBACjB,cAAc;gBACd,iBAAiB;gBACjB,aAAa;aACd,CAAC;QACJ,CAAC,EAAE,GAAG,CAAC,CAAC,CAAC,4CAA4C;IACvD,CAAC;IAED,8BAA8B;IAEtB,MAAM,CAAC,SAAS,CAAC,KAAa,IAAI,CAAC,GAAG,EAAE;QAC9C,OAAO,IAAI,CAAC,KAAK,CAAC,EAAE,GAAG,KAAK,CAAC,GAAG,KAAK,CAAC;IACxC,CAAC;IAEO,oBAAoB,CAAC,KAAqC;QAChE,MAAM,GAAG,GAAG,cAAc,CAAC,SAAS,EAAE,CAAC;QACvC,IAAI,MAAM,GAAG,IAAI,CAAC,kBAAkB,CAAC,GAAG,CAAC,GAAG,CAAC,CAAC;QAC9C,IAAI,CAAC,MAAM,EAAE,CAAC;YACZ,MAAM,GAAG,EAAE,IAAI,EAAE,CAAC,EAAE,QAAQ,EAAE,CAAC,EAAE,MAAM,EAAE,CAAC,EAAE,CAAC;YAC7C,IAAI,CAAC,kBAAkB,CAAC,GAAG,CAAC,GAAG,EAAE,MAAM,CAAC,CAAC;QAC3C,CAAC;QACD,MAAM,CAAC,KAAK,CAAC,EAAE,CAAC;IAClB,CAAC;IAEO,kBAAkB;QACxB,MAAM,GAAG,GAAG,cAAc,CAAC,SAAS,EAAE,CAAC;QACvC,IAAI,MAAM,GAAG,IAAI,CAAC,gBAAgB,CAAC,GAAG,CAAC,GAAG,CAAC,CAAC;QAC5C,IAAI,CAAC,MAAM,EAAE,CAAC;YACZ,MAAM,GAAG,EAAE,OAAO,EAAE,CAAC,EAAE,CAAC;YACxB,IAAI,CAAC,gBAAgB,CAAC,GAAG,CAAC,GAAG,EAAE,MAAM,CAAC,CAAC;QACzC,CAAC;QACD,MAAM,CAAC,OAAO,EAAE,CAAC;IACnB,CAAC;IAEO,eAAe;QACrB,MAAM,MAAM,GAAG,IAAI,CAAC,GAAG,EAAE,GAAG,QAAQ,CAAC,CAAC,MAAM;QAC5C,KAAK,MAAM,GAAG,IAAI,IAAI,CAAC,kBAAkB,CAAC,IAAI,EAAE,EAAE,CAAC;YACjD,IAAI,GAAG,GAAG,MAAM;gBAAE,IAAI,CAAC,kBAAkB,CAAC,MAAM,CAAC,GAAG,CAAC,CAAC;QACxD,CAAC;QACD,KAAK,MAAM,GAAG,IAAI,IAAI,CAAC,gBAAgB,CAAC,IAAI,EAAE,EAAE,CAAC;YAC/C,IAAI,GAAG,GAAG,MAAM;gBAAE,IAAI,CAAC,gBAAgB,CAAC,MAAM,CAAC,GAAG,CAAC,CAAC;QACtD,CAAC;IACH,CAAC;IAED;;OAEG;IACI,kBAAkB,CAAC,QAAgB,EAAE;QAK1C,IAAI,CAAC,eAAe,EAAE,CAAC;QACvB,MAAM,MAAM,GAAG,IAAI,CAAC,GAAG,EAAE,GAAG,KAAK,GAAG,OAAO,CAAC;QAC5C,MAAM,IAAI,GAAgD,EAAE,CAAC;QAC7D,MAAM,QAAQ,GAAgD,EAAE,CAAC;QACjE,MAAM,MAAM,GAAgD,EAAE,CAAC;QAE/D,MAAM,UAAU,GAAG,KAAK,CAAC,IAAI,CAAC,IAAI,CAAC,kBAAkB,CAAC,IAAI,EAAE,CAAC;aAC1D,MAAM,CAAC,CAAC,CAAC,EAAE,EAAE,CAAC,CAAC,IAAI,MAAM,CAAC;aAC1B,IAAI,CAAC,CAAC,CAAC,EAAE,CAAC,EAAE,EAAE,CAAC,CAAC,GAAG,CAAC,CAAC,CAAC;QAEzB,KAAK,MAAM,GAAG,IAAI,UAAU,EAAE,CAAC;YAC7B,MAAM,MAAM,GAAG,IAAI,CAAC,kBAAkB,CAAC,GAAG,CAAC,GAAG,CAAE,CAAC;YACjD,IAAI,CAAC,IAAI,CAAC,EAAE,SAAS,EAAE,GAAG,EAAE,KAAK,EAAE,MAAM,CAAC,IAAI,EAAE,CAAC,CAAC;YAClD,QAAQ,CAAC,IAAI,CAAC,EAAE,SAAS,EAAE,GAAG,EAAE,KAAK,EAAE,MAAM,CAAC,QAAQ,EAAE,CAAC,CAAC;YAC1D,MAAM,CAAC,IAAI,CAAC,EAAE,SAAS,EAAE,GAAG,EAAE,KAAK,EAAE,MAAM,CAAC,MAAM,EAAE,CAAC,CAAC;QACxD,CAAC;QAED,OAAO,EAAE,IAAI,EAAE,QAAQ,EAAE,MAAM,EAAE,CAAC;IACpC,CAAC;IAED;;OAEG;IACI,gBAAgB,CAAC,QAAgB,EAAE;QAGxC,IAAI,CAAC,eAAe,EAAE,CAAC;QACvB,MAAM,MAAM,GAAG,IAAI,CAAC,GAAG,EAAE,GAAG,KAAK,GAAG,OAAO,CAAC;QAC5C,MAAM,OAAO,GAAgD,EAAE,CAAC;QAEhE,MAAM,UAAU,GAAG,KAAK,CAAC,IAAI,CAAC,IAAI,CAAC,gBAAgB,CAAC,IAAI,EAAE,CAAC;aACxD,MAAM,CAAC,CAAC,CAAC,EAAE,EAAE,CAAC,CAAC,IAAI,MAAM,CAAC;aAC1B,IAAI,CAAC,CAAC,CAAC,EAAE,CAAC,EAAE,EAAE,CAAC,CAAC,GAAG,CAAC,CAAC,CAAC;QAEzB,KAAK,MAAM,GAAG,IAAI,UAAU,EAAE,CAAC;YAC7B,MAAM,MAAM,GAAG,IAAI,CAAC,gBAAgB,CAAC,GAAG,CAAC,GAAG,CAAE,CAAC;YAC/C,OAAO,CAAC,IAAI,CAAC,EAAE,SAAS,EAAE,GAAG,EAAE,KAAK,EAAE,MAAM,CAAC,OAAO,EAAE,CAAC,CAAC;QAC1D,CAAC;QAED,OAAO,EAAE,OAAO,EAAE,CAAC;IACrB,CAAC;CACF"}
@@ -0,0 +1 @@
1
+ export * from './classes.metricsmanager.js';
@@ -0,0 +1,2 @@
1
+ export * from './classes.metricsmanager.js';
2
+ //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiaW5kZXguanMiLCJzb3VyY2VSb290IjoiIiwic291cmNlcyI6WyIuLi8uLi8uLi90cy9tb25pdG9yaW5nL2luZGV4LnRzIl0sIm5hbWVzIjpbXSwibWFwcGluZ3MiOiJBQUFBLGNBQWMsNkJBQTZCLENBQUMifQ==