n8n-mcp 2.13.2 → 2.14.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.
- package/README.md +45 -0
- package/data/nodes.db +0 -0
- package/dist/mcp/handlers-n8n-manager.d.ts.map +1 -1
- package/dist/mcp/handlers-n8n-manager.js +6 -0
- package/dist/mcp/handlers-n8n-manager.js.map +1 -1
- package/dist/mcp/index.js +32 -0
- package/dist/mcp/index.js.map +1 -1
- package/dist/mcp/server.d.ts +2 -0
- package/dist/mcp/server.d.ts.map +1 -1
- package/dist/mcp/server.js +56 -19
- package/dist/mcp/server.js.map +1 -1
- package/dist/services/config-validator.d.ts +1 -0
- package/dist/services/config-validator.d.ts.map +1 -1
- package/dist/services/config-validator.js.map +1 -1
- package/dist/telemetry/batch-processor.d.ts +32 -0
- package/dist/telemetry/batch-processor.d.ts.map +1 -0
- package/dist/telemetry/batch-processor.js +266 -0
- package/dist/telemetry/batch-processor.js.map +1 -0
- package/dist/telemetry/config-manager.d.ts +28 -0
- package/dist/telemetry/config-manager.d.ts.map +1 -0
- package/dist/telemetry/config-manager.js +211 -0
- package/dist/telemetry/config-manager.js.map +1 -0
- package/dist/telemetry/event-tracker.d.ts +58 -0
- package/dist/telemetry/event-tracker.d.ts.map +1 -0
- package/dist/telemetry/event-tracker.js +295 -0
- package/dist/telemetry/event-tracker.js.map +1 -0
- package/dist/telemetry/event-validator.d.ts +78 -0
- package/dist/telemetry/event-validator.d.ts.map +1 -0
- package/dist/telemetry/event-validator.js +204 -0
- package/dist/telemetry/event-validator.js.map +1 -0
- package/dist/telemetry/index.d.ts +5 -0
- package/dist/telemetry/index.d.ts.map +1 -0
- package/dist/telemetry/index.js +11 -0
- package/dist/telemetry/index.js.map +1 -0
- package/dist/telemetry/performance-monitor.d.ts +113 -0
- package/dist/telemetry/performance-monitor.d.ts.map +1 -0
- package/dist/telemetry/performance-monitor.js +208 -0
- package/dist/telemetry/performance-monitor.js.map +1 -0
- package/dist/telemetry/rate-limiter.d.ts +30 -0
- package/dist/telemetry/rate-limiter.d.ts.map +1 -0
- package/dist/telemetry/rate-limiter.js +103 -0
- package/dist/telemetry/rate-limiter.js.map +1 -0
- package/dist/telemetry/telemetry-error.d.ts +44 -0
- package/dist/telemetry/telemetry-error.d.ts.map +1 -0
- package/dist/telemetry/telemetry-error.js +153 -0
- package/dist/telemetry/telemetry-error.js.map +1 -0
- package/dist/telemetry/telemetry-manager.d.ts +127 -0
- package/dist/telemetry/telemetry-manager.d.ts.map +1 -0
- package/dist/telemetry/telemetry-manager.js +182 -0
- package/dist/telemetry/telemetry-manager.js.map +1 -0
- package/dist/telemetry/telemetry-types.d.ts +69 -0
- package/dist/telemetry/telemetry-types.d.ts.map +1 -0
- package/dist/telemetry/telemetry-types.js +29 -0
- package/dist/telemetry/telemetry-types.js.map +1 -0
- package/dist/telemetry/workflow-sanitizer.d.ts +33 -0
- package/dist/telemetry/workflow-sanitizer.d.ts.map +1 -0
- package/dist/telemetry/workflow-sanitizer.js +190 -0
- package/dist/telemetry/workflow-sanitizer.js.map +1 -0
- package/package.json +2 -1
|
@@ -0,0 +1,153 @@
|
|
|
1
|
+
"use strict";
|
|
2
|
+
Object.defineProperty(exports, "__esModule", { value: true });
|
|
3
|
+
exports.TelemetryErrorAggregator = exports.TelemetryCircuitBreaker = exports.TelemetryError = exports.TelemetryErrorType = void 0;
|
|
4
|
+
const logger_1 = require("../utils/logger");
|
|
5
|
+
var telemetry_types_1 = require("./telemetry-types");
|
|
6
|
+
Object.defineProperty(exports, "TelemetryErrorType", { enumerable: true, get: function () { return telemetry_types_1.TelemetryErrorType; } });
|
|
7
|
+
class TelemetryError extends Error {
|
|
8
|
+
constructor(type, message, context, retryable = false) {
|
|
9
|
+
super(message);
|
|
10
|
+
this.name = 'TelemetryError';
|
|
11
|
+
this.type = type;
|
|
12
|
+
this.context = context;
|
|
13
|
+
this.timestamp = Date.now();
|
|
14
|
+
this.retryable = retryable;
|
|
15
|
+
Object.setPrototypeOf(this, TelemetryError.prototype);
|
|
16
|
+
}
|
|
17
|
+
toContext() {
|
|
18
|
+
return {
|
|
19
|
+
type: this.type,
|
|
20
|
+
message: this.message,
|
|
21
|
+
context: this.context,
|
|
22
|
+
timestamp: this.timestamp,
|
|
23
|
+
retryable: this.retryable
|
|
24
|
+
};
|
|
25
|
+
}
|
|
26
|
+
log() {
|
|
27
|
+
const logContext = {
|
|
28
|
+
type: this.type,
|
|
29
|
+
message: this.message,
|
|
30
|
+
...this.context
|
|
31
|
+
};
|
|
32
|
+
if (this.retryable) {
|
|
33
|
+
logger_1.logger.debug('Retryable telemetry error:', logContext);
|
|
34
|
+
}
|
|
35
|
+
else {
|
|
36
|
+
logger_1.logger.debug('Non-retryable telemetry error:', logContext);
|
|
37
|
+
}
|
|
38
|
+
}
|
|
39
|
+
}
|
|
40
|
+
exports.TelemetryError = TelemetryError;
|
|
41
|
+
class TelemetryCircuitBreaker {
|
|
42
|
+
constructor(failureThreshold = 5, resetTimeout = 60000, halfOpenRequests = 3) {
|
|
43
|
+
this.failureCount = 0;
|
|
44
|
+
this.lastFailureTime = 0;
|
|
45
|
+
this.state = 'closed';
|
|
46
|
+
this.halfOpenCount = 0;
|
|
47
|
+
this.failureThreshold = failureThreshold;
|
|
48
|
+
this.resetTimeout = resetTimeout;
|
|
49
|
+
this.halfOpenRequests = halfOpenRequests;
|
|
50
|
+
}
|
|
51
|
+
shouldAllow() {
|
|
52
|
+
const now = Date.now();
|
|
53
|
+
switch (this.state) {
|
|
54
|
+
case 'closed':
|
|
55
|
+
return true;
|
|
56
|
+
case 'open':
|
|
57
|
+
if (now - this.lastFailureTime > this.resetTimeout) {
|
|
58
|
+
this.state = 'half-open';
|
|
59
|
+
this.halfOpenCount = 0;
|
|
60
|
+
logger_1.logger.debug('Circuit breaker transitioning to half-open');
|
|
61
|
+
return true;
|
|
62
|
+
}
|
|
63
|
+
return false;
|
|
64
|
+
case 'half-open':
|
|
65
|
+
if (this.halfOpenCount < this.halfOpenRequests) {
|
|
66
|
+
this.halfOpenCount++;
|
|
67
|
+
return true;
|
|
68
|
+
}
|
|
69
|
+
return false;
|
|
70
|
+
default:
|
|
71
|
+
return false;
|
|
72
|
+
}
|
|
73
|
+
}
|
|
74
|
+
recordSuccess() {
|
|
75
|
+
if (this.state === 'half-open') {
|
|
76
|
+
if (this.halfOpenCount >= this.halfOpenRequests) {
|
|
77
|
+
this.state = 'closed';
|
|
78
|
+
this.failureCount = 0;
|
|
79
|
+
logger_1.logger.debug('Circuit breaker closed after successful recovery');
|
|
80
|
+
}
|
|
81
|
+
}
|
|
82
|
+
else if (this.state === 'closed') {
|
|
83
|
+
this.failureCount = 0;
|
|
84
|
+
}
|
|
85
|
+
}
|
|
86
|
+
recordFailure(error) {
|
|
87
|
+
this.failureCount++;
|
|
88
|
+
this.lastFailureTime = Date.now();
|
|
89
|
+
if (this.state === 'half-open') {
|
|
90
|
+
this.state = 'open';
|
|
91
|
+
logger_1.logger.debug('Circuit breaker opened from half-open state', { error: error?.message });
|
|
92
|
+
}
|
|
93
|
+
else if (this.state === 'closed' && this.failureCount >= this.failureThreshold) {
|
|
94
|
+
this.state = 'open';
|
|
95
|
+
logger_1.logger.debug(`Circuit breaker opened after ${this.failureCount} failures`, { error: error?.message });
|
|
96
|
+
}
|
|
97
|
+
}
|
|
98
|
+
getState() {
|
|
99
|
+
return {
|
|
100
|
+
state: this.state,
|
|
101
|
+
failureCount: this.failureCount,
|
|
102
|
+
canRetry: this.shouldAllow()
|
|
103
|
+
};
|
|
104
|
+
}
|
|
105
|
+
reset() {
|
|
106
|
+
this.state = 'closed';
|
|
107
|
+
this.failureCount = 0;
|
|
108
|
+
this.lastFailureTime = 0;
|
|
109
|
+
this.halfOpenCount = 0;
|
|
110
|
+
}
|
|
111
|
+
}
|
|
112
|
+
exports.TelemetryCircuitBreaker = TelemetryCircuitBreaker;
|
|
113
|
+
class TelemetryErrorAggregator {
|
|
114
|
+
constructor() {
|
|
115
|
+
this.errors = new Map();
|
|
116
|
+
this.errorDetails = [];
|
|
117
|
+
this.maxDetails = 100;
|
|
118
|
+
}
|
|
119
|
+
record(error) {
|
|
120
|
+
const count = this.errors.get(error.type) || 0;
|
|
121
|
+
this.errors.set(error.type, count + 1);
|
|
122
|
+
this.errorDetails.push(error.toContext());
|
|
123
|
+
if (this.errorDetails.length > this.maxDetails) {
|
|
124
|
+
this.errorDetails.shift();
|
|
125
|
+
}
|
|
126
|
+
}
|
|
127
|
+
getStats() {
|
|
128
|
+
const errorsByType = {};
|
|
129
|
+
let totalErrors = 0;
|
|
130
|
+
let mostCommonError;
|
|
131
|
+
let maxCount = 0;
|
|
132
|
+
for (const [type, count] of this.errors.entries()) {
|
|
133
|
+
errorsByType[type] = count;
|
|
134
|
+
totalErrors += count;
|
|
135
|
+
if (count > maxCount) {
|
|
136
|
+
maxCount = count;
|
|
137
|
+
mostCommonError = type;
|
|
138
|
+
}
|
|
139
|
+
}
|
|
140
|
+
return {
|
|
141
|
+
totalErrors,
|
|
142
|
+
errorsByType,
|
|
143
|
+
mostCommonError,
|
|
144
|
+
recentErrors: this.errorDetails.slice(-10)
|
|
145
|
+
};
|
|
146
|
+
}
|
|
147
|
+
reset() {
|
|
148
|
+
this.errors.clear();
|
|
149
|
+
this.errorDetails = [];
|
|
150
|
+
}
|
|
151
|
+
}
|
|
152
|
+
exports.TelemetryErrorAggregator = TelemetryErrorAggregator;
|
|
153
|
+
//# sourceMappingURL=telemetry-error.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"telemetry-error.js","sourceRoot":"","sources":["../../src/telemetry/telemetry-error.ts"],"names":[],"mappings":"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"}
|
|
@@ -0,0 +1,127 @@
|
|
|
1
|
+
export declare class TelemetryManager {
|
|
2
|
+
private static instance;
|
|
3
|
+
private supabase;
|
|
4
|
+
private configManager;
|
|
5
|
+
private eventTracker;
|
|
6
|
+
private batchProcessor;
|
|
7
|
+
private performanceMonitor;
|
|
8
|
+
private errorAggregator;
|
|
9
|
+
private isInitialized;
|
|
10
|
+
private constructor();
|
|
11
|
+
static getInstance(): TelemetryManager;
|
|
12
|
+
private ensureInitialized;
|
|
13
|
+
private initialize;
|
|
14
|
+
trackToolUsage(toolName: string, success: boolean, duration?: number): void;
|
|
15
|
+
trackWorkflowCreation(workflow: any, validationPassed: boolean): Promise<void>;
|
|
16
|
+
trackError(errorType: string, context: string, toolName?: string): void;
|
|
17
|
+
trackEvent(eventName: string, properties: Record<string, any>): void;
|
|
18
|
+
trackSessionStart(): void;
|
|
19
|
+
trackSearchQuery(query: string, resultsFound: number, searchType: string): void;
|
|
20
|
+
trackValidationDetails(nodeType: string, errorType: string, details: Record<string, any>): void;
|
|
21
|
+
trackToolSequence(previousTool: string, currentTool: string, timeDelta: number): void;
|
|
22
|
+
trackNodeConfiguration(nodeType: string, propertiesSet: number, usedDefaults: boolean): void;
|
|
23
|
+
trackPerformanceMetric(operation: string, duration: number, metadata?: Record<string, any>): void;
|
|
24
|
+
flush(): Promise<void>;
|
|
25
|
+
private isEnabled;
|
|
26
|
+
disable(): void;
|
|
27
|
+
enable(): void;
|
|
28
|
+
getStatus(): string;
|
|
29
|
+
getMetrics(): {
|
|
30
|
+
status: string;
|
|
31
|
+
initialized: boolean;
|
|
32
|
+
tracking: {
|
|
33
|
+
rateLimiter: {
|
|
34
|
+
currentEvents: number;
|
|
35
|
+
maxEvents: number;
|
|
36
|
+
windowMs: number;
|
|
37
|
+
droppedEvents: number;
|
|
38
|
+
utilizationPercent: number;
|
|
39
|
+
remainingCapacity: number;
|
|
40
|
+
arraySize: number;
|
|
41
|
+
maxArraySize: number;
|
|
42
|
+
memoryUsagePercent: number;
|
|
43
|
+
};
|
|
44
|
+
validator: {
|
|
45
|
+
errors: number;
|
|
46
|
+
successes: number;
|
|
47
|
+
total: number;
|
|
48
|
+
errorRate: number;
|
|
49
|
+
};
|
|
50
|
+
eventQueueSize: number;
|
|
51
|
+
workflowQueueSize: number;
|
|
52
|
+
performanceMetrics: Record<string, any>;
|
|
53
|
+
};
|
|
54
|
+
processing: import("./telemetry-types").TelemetryMetrics & {
|
|
55
|
+
circuitBreakerState: any;
|
|
56
|
+
deadLetterQueueSize: number;
|
|
57
|
+
};
|
|
58
|
+
errors: {
|
|
59
|
+
totalErrors: number;
|
|
60
|
+
errorsByType: Record<string, number>;
|
|
61
|
+
mostCommonError?: string;
|
|
62
|
+
recentErrors: import("./telemetry-types").TelemetryErrorContext[];
|
|
63
|
+
};
|
|
64
|
+
performance: {
|
|
65
|
+
summary: {
|
|
66
|
+
totalOperations: number;
|
|
67
|
+
averageDuration: number;
|
|
68
|
+
slowOperations: number;
|
|
69
|
+
operationsByType: {};
|
|
70
|
+
memoryUsage: {
|
|
71
|
+
heapUsed: number;
|
|
72
|
+
heapTotal: number;
|
|
73
|
+
external: number;
|
|
74
|
+
} | undefined;
|
|
75
|
+
uptimeMs: number;
|
|
76
|
+
overhead: {
|
|
77
|
+
percentage: number;
|
|
78
|
+
totalMs: number;
|
|
79
|
+
};
|
|
80
|
+
operationsInLastMinute?: undefined;
|
|
81
|
+
} | {
|
|
82
|
+
totalOperations: number;
|
|
83
|
+
operationsInLastMinute: number;
|
|
84
|
+
averageDuration: number;
|
|
85
|
+
slowOperations: number;
|
|
86
|
+
operationsByType: Record<string, {
|
|
87
|
+
count: number;
|
|
88
|
+
avgDuration: number;
|
|
89
|
+
}>;
|
|
90
|
+
memoryUsage: {
|
|
91
|
+
heapUsed: number;
|
|
92
|
+
heapTotal: number;
|
|
93
|
+
external: number;
|
|
94
|
+
} | undefined;
|
|
95
|
+
uptimeMs: number;
|
|
96
|
+
overhead: {
|
|
97
|
+
percentage: number;
|
|
98
|
+
totalMs: number;
|
|
99
|
+
};
|
|
100
|
+
};
|
|
101
|
+
percentiles: {
|
|
102
|
+
p50: number;
|
|
103
|
+
p75: number;
|
|
104
|
+
p90: number;
|
|
105
|
+
p95: number;
|
|
106
|
+
p99: number;
|
|
107
|
+
};
|
|
108
|
+
topSlowOperations: {
|
|
109
|
+
operation: string;
|
|
110
|
+
duration: number;
|
|
111
|
+
timestamp: number;
|
|
112
|
+
}[];
|
|
113
|
+
memoryTrend: {
|
|
114
|
+
trend: string;
|
|
115
|
+
delta: number;
|
|
116
|
+
};
|
|
117
|
+
recommendations: string[];
|
|
118
|
+
};
|
|
119
|
+
overhead: {
|
|
120
|
+
percentage: number;
|
|
121
|
+
impact: "minimal" | "low" | "moderate" | "high";
|
|
122
|
+
};
|
|
123
|
+
};
|
|
124
|
+
static resetInstance(): void;
|
|
125
|
+
}
|
|
126
|
+
export declare const telemetry: TelemetryManager;
|
|
127
|
+
//# sourceMappingURL=telemetry-manager.d.ts.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"telemetry-manager.d.ts","sourceRoot":"","sources":["../../src/telemetry/telemetry-manager.ts"],"names":[],"mappings":"AAcA,qBAAa,gBAAgB;IAC3B,OAAO,CAAC,MAAM,CAAC,QAAQ,CAAmB;IAC1C,OAAO,CAAC,QAAQ,CAA+B;IAC/C,OAAO,CAAC,aAAa,CAAyB;IAC9C,OAAO,CAAC,YAAY,CAAwB;IAC5C,OAAO,CAAC,cAAc,CAA0B;IAChD,OAAO,CAAC,kBAAkB,CAA8B;IACxD,OAAO,CAAC,eAAe,CAA2B;IAClD,OAAO,CAAC,aAAa,CAAkB;IAEvC,OAAO;IA0BP,MAAM,CAAC,WAAW,IAAI,gBAAgB;IAUtC,OAAO,CAAC,iBAAiB;IASzB,OAAO,CAAC,UAAU;IAiDlB,cAAc,CAAC,QAAQ,EAAE,MAAM,EAAE,OAAO,EAAE,OAAO,EAAE,QAAQ,CAAC,EAAE,MAAM,GAAG,IAAI;IAWrE,qBAAqB,CAAC,QAAQ,EAAE,GAAG,EAAE,gBAAgB,EAAE,OAAO,GAAG,OAAO,CAAC,IAAI,CAAC;IAyBpF,UAAU,CAAC,SAAS,EAAE,MAAM,EAAE,OAAO,EAAE,MAAM,EAAE,QAAQ,CAAC,EAAE,MAAM,GAAG,IAAI;IAQvE,UAAU,CAAC,SAAS,EAAE,MAAM,EAAE,UAAU,EAAE,MAAM,CAAC,MAAM,EAAE,GAAG,CAAC,GAAG,IAAI;IAQpE,iBAAiB,IAAI,IAAI;IAQzB,gBAAgB,CAAC,KAAK,EAAE,MAAM,EAAE,YAAY,EAAE,MAAM,EAAE,UAAU,EAAE,MAAM,GAAG,IAAI;IAO/E,sBAAsB,CAAC,QAAQ,EAAE,MAAM,EAAE,SAAS,EAAE,MAAM,EAAE,OAAO,EAAE,MAAM,CAAC,MAAM,EAAE,GAAG,CAAC,GAAG,IAAI;IAO/F,iBAAiB,CAAC,YAAY,EAAE,MAAM,EAAE,WAAW,EAAE,MAAM,EAAE,SAAS,EAAE,MAAM,GAAG,IAAI;IAOrF,sBAAsB,CAAC,QAAQ,EAAE,MAAM,EAAE,aAAa,EAAE,MAAM,EAAE,YAAY,EAAE,OAAO,GAAG,IAAI;IAO5F,sBAAsB,CAAC,SAAS,EAAE,MAAM,EAAE,QAAQ,EAAE,MAAM,EAAE,QAAQ,CAAC,EAAE,MAAM,CAAC,MAAM,EAAE,GAAG,CAAC,GAAG,IAAI;IAQ3F,KAAK,IAAI,OAAO,CAAC,IAAI,CAAC;IAwC5B,OAAO,CAAC,SAAS;IAOjB,OAAO,IAAI,IAAI;IAUf,MAAM,IAAI,IAAI;IAQd,SAAS,IAAI,MAAM;IAOnB,UAAU;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;IAeV,MAAM,CAAC,aAAa,IAAI,IAAI;CAI7B;AAUD,eAAO,MAAM,SAAS,EAAmC,gBAAgB,CAAC"}
|
|
@@ -0,0 +1,182 @@
|
|
|
1
|
+
"use strict";
|
|
2
|
+
Object.defineProperty(exports, "__esModule", { value: true });
|
|
3
|
+
exports.telemetry = exports.TelemetryManager = void 0;
|
|
4
|
+
const supabase_js_1 = require("@supabase/supabase-js");
|
|
5
|
+
const config_manager_1 = require("./config-manager");
|
|
6
|
+
const event_tracker_1 = require("./event-tracker");
|
|
7
|
+
const batch_processor_1 = require("./batch-processor");
|
|
8
|
+
const performance_monitor_1 = require("./performance-monitor");
|
|
9
|
+
const telemetry_types_1 = require("./telemetry-types");
|
|
10
|
+
const telemetry_error_1 = require("./telemetry-error");
|
|
11
|
+
const logger_1 = require("../utils/logger");
|
|
12
|
+
class TelemetryManager {
|
|
13
|
+
constructor() {
|
|
14
|
+
this.supabase = null;
|
|
15
|
+
this.isInitialized = false;
|
|
16
|
+
if (TelemetryManager.instance) {
|
|
17
|
+
throw new Error('Use TelemetryManager.getInstance() instead of new TelemetryManager()');
|
|
18
|
+
}
|
|
19
|
+
this.configManager = config_manager_1.TelemetryConfigManager.getInstance();
|
|
20
|
+
this.errorAggregator = new telemetry_error_1.TelemetryErrorAggregator();
|
|
21
|
+
this.performanceMonitor = new performance_monitor_1.TelemetryPerformanceMonitor();
|
|
22
|
+
this.eventTracker = new event_tracker_1.TelemetryEventTracker(() => this.configManager.getUserId(), () => this.isEnabled());
|
|
23
|
+
this.batchProcessor = new batch_processor_1.TelemetryBatchProcessor(null, () => this.isEnabled());
|
|
24
|
+
}
|
|
25
|
+
static getInstance() {
|
|
26
|
+
if (!TelemetryManager.instance) {
|
|
27
|
+
TelemetryManager.instance = new TelemetryManager();
|
|
28
|
+
}
|
|
29
|
+
return TelemetryManager.instance;
|
|
30
|
+
}
|
|
31
|
+
ensureInitialized() {
|
|
32
|
+
if (!this.isInitialized && this.configManager.isEnabled()) {
|
|
33
|
+
this.initialize();
|
|
34
|
+
}
|
|
35
|
+
}
|
|
36
|
+
initialize() {
|
|
37
|
+
if (!this.configManager.isEnabled()) {
|
|
38
|
+
logger_1.logger.debug('Telemetry disabled by user preference');
|
|
39
|
+
return;
|
|
40
|
+
}
|
|
41
|
+
const supabaseUrl = process.env.SUPABASE_URL || telemetry_types_1.TELEMETRY_BACKEND.URL;
|
|
42
|
+
const supabaseAnonKey = process.env.SUPABASE_ANON_KEY || telemetry_types_1.TELEMETRY_BACKEND.ANON_KEY;
|
|
43
|
+
try {
|
|
44
|
+
this.supabase = (0, supabase_js_1.createClient)(supabaseUrl, supabaseAnonKey, {
|
|
45
|
+
auth: {
|
|
46
|
+
persistSession: false,
|
|
47
|
+
autoRefreshToken: false,
|
|
48
|
+
},
|
|
49
|
+
realtime: {
|
|
50
|
+
params: {
|
|
51
|
+
eventsPerSecond: 1,
|
|
52
|
+
},
|
|
53
|
+
},
|
|
54
|
+
});
|
|
55
|
+
this.batchProcessor = new batch_processor_1.TelemetryBatchProcessor(this.supabase, () => this.isEnabled());
|
|
56
|
+
this.batchProcessor.start();
|
|
57
|
+
this.isInitialized = true;
|
|
58
|
+
logger_1.logger.debug('Telemetry initialized successfully');
|
|
59
|
+
}
|
|
60
|
+
catch (error) {
|
|
61
|
+
const telemetryError = new telemetry_error_1.TelemetryError(telemetry_error_1.TelemetryErrorType.INITIALIZATION_ERROR, 'Failed to initialize telemetry', { error: error instanceof Error ? error.message : String(error) });
|
|
62
|
+
this.errorAggregator.record(telemetryError);
|
|
63
|
+
telemetryError.log();
|
|
64
|
+
this.isInitialized = false;
|
|
65
|
+
}
|
|
66
|
+
}
|
|
67
|
+
trackToolUsage(toolName, success, duration) {
|
|
68
|
+
this.ensureInitialized();
|
|
69
|
+
this.performanceMonitor.startOperation('trackToolUsage');
|
|
70
|
+
this.eventTracker.trackToolUsage(toolName, success, duration);
|
|
71
|
+
this.eventTracker.updateToolSequence(toolName);
|
|
72
|
+
this.performanceMonitor.endOperation('trackToolUsage');
|
|
73
|
+
}
|
|
74
|
+
async trackWorkflowCreation(workflow, validationPassed) {
|
|
75
|
+
this.ensureInitialized();
|
|
76
|
+
this.performanceMonitor.startOperation('trackWorkflowCreation');
|
|
77
|
+
try {
|
|
78
|
+
await this.eventTracker.trackWorkflowCreation(workflow, validationPassed);
|
|
79
|
+
await this.flush();
|
|
80
|
+
}
|
|
81
|
+
catch (error) {
|
|
82
|
+
const telemetryError = error instanceof telemetry_error_1.TelemetryError
|
|
83
|
+
? error
|
|
84
|
+
: new telemetry_error_1.TelemetryError(telemetry_error_1.TelemetryErrorType.UNKNOWN_ERROR, 'Failed to track workflow', { error: String(error) });
|
|
85
|
+
this.errorAggregator.record(telemetryError);
|
|
86
|
+
}
|
|
87
|
+
finally {
|
|
88
|
+
this.performanceMonitor.endOperation('trackWorkflowCreation');
|
|
89
|
+
}
|
|
90
|
+
}
|
|
91
|
+
trackError(errorType, context, toolName) {
|
|
92
|
+
this.ensureInitialized();
|
|
93
|
+
this.eventTracker.trackError(errorType, context, toolName);
|
|
94
|
+
}
|
|
95
|
+
trackEvent(eventName, properties) {
|
|
96
|
+
this.ensureInitialized();
|
|
97
|
+
this.eventTracker.trackEvent(eventName, properties);
|
|
98
|
+
}
|
|
99
|
+
trackSessionStart() {
|
|
100
|
+
this.ensureInitialized();
|
|
101
|
+
this.eventTracker.trackSessionStart();
|
|
102
|
+
}
|
|
103
|
+
trackSearchQuery(query, resultsFound, searchType) {
|
|
104
|
+
this.eventTracker.trackSearchQuery(query, resultsFound, searchType);
|
|
105
|
+
}
|
|
106
|
+
trackValidationDetails(nodeType, errorType, details) {
|
|
107
|
+
this.eventTracker.trackValidationDetails(nodeType, errorType, details);
|
|
108
|
+
}
|
|
109
|
+
trackToolSequence(previousTool, currentTool, timeDelta) {
|
|
110
|
+
this.eventTracker.trackToolSequence(previousTool, currentTool, timeDelta);
|
|
111
|
+
}
|
|
112
|
+
trackNodeConfiguration(nodeType, propertiesSet, usedDefaults) {
|
|
113
|
+
this.eventTracker.trackNodeConfiguration(nodeType, propertiesSet, usedDefaults);
|
|
114
|
+
}
|
|
115
|
+
trackPerformanceMetric(operation, duration, metadata) {
|
|
116
|
+
this.eventTracker.trackPerformanceMetric(operation, duration, metadata);
|
|
117
|
+
}
|
|
118
|
+
async flush() {
|
|
119
|
+
this.ensureInitialized();
|
|
120
|
+
if (!this.isEnabled() || !this.supabase)
|
|
121
|
+
return;
|
|
122
|
+
this.performanceMonitor.startOperation('flush');
|
|
123
|
+
const events = this.eventTracker.getEventQueue();
|
|
124
|
+
const workflows = this.eventTracker.getWorkflowQueue();
|
|
125
|
+
this.eventTracker.clearEventQueue();
|
|
126
|
+
this.eventTracker.clearWorkflowQueue();
|
|
127
|
+
try {
|
|
128
|
+
await this.batchProcessor.flush(events, workflows);
|
|
129
|
+
}
|
|
130
|
+
catch (error) {
|
|
131
|
+
const telemetryError = error instanceof telemetry_error_1.TelemetryError
|
|
132
|
+
? error
|
|
133
|
+
: new telemetry_error_1.TelemetryError(telemetry_error_1.TelemetryErrorType.NETWORK_ERROR, 'Failed to flush telemetry', { error: String(error) }, true);
|
|
134
|
+
this.errorAggregator.record(telemetryError);
|
|
135
|
+
telemetryError.log();
|
|
136
|
+
}
|
|
137
|
+
finally {
|
|
138
|
+
const duration = this.performanceMonitor.endOperation('flush');
|
|
139
|
+
if (duration > 100) {
|
|
140
|
+
logger_1.logger.debug(`Telemetry flush took ${duration.toFixed(2)}ms`);
|
|
141
|
+
}
|
|
142
|
+
}
|
|
143
|
+
}
|
|
144
|
+
isEnabled() {
|
|
145
|
+
return this.isInitialized && this.configManager.isEnabled();
|
|
146
|
+
}
|
|
147
|
+
disable() {
|
|
148
|
+
this.configManager.disable();
|
|
149
|
+
this.batchProcessor.stop();
|
|
150
|
+
this.isInitialized = false;
|
|
151
|
+
this.supabase = null;
|
|
152
|
+
}
|
|
153
|
+
enable() {
|
|
154
|
+
this.configManager.enable();
|
|
155
|
+
this.initialize();
|
|
156
|
+
}
|
|
157
|
+
getStatus() {
|
|
158
|
+
return this.configManager.getStatus();
|
|
159
|
+
}
|
|
160
|
+
getMetrics() {
|
|
161
|
+
return {
|
|
162
|
+
status: this.isEnabled() ? 'enabled' : 'disabled',
|
|
163
|
+
initialized: this.isInitialized,
|
|
164
|
+
tracking: this.eventTracker.getStats(),
|
|
165
|
+
processing: this.batchProcessor.getMetrics(),
|
|
166
|
+
errors: this.errorAggregator.getStats(),
|
|
167
|
+
performance: this.performanceMonitor.getDetailedReport(),
|
|
168
|
+
overhead: this.performanceMonitor.getTelemetryOverhead()
|
|
169
|
+
};
|
|
170
|
+
}
|
|
171
|
+
static resetInstance() {
|
|
172
|
+
TelemetryManager.instance = undefined;
|
|
173
|
+
global.__telemetryManager = undefined;
|
|
174
|
+
}
|
|
175
|
+
}
|
|
176
|
+
exports.TelemetryManager = TelemetryManager;
|
|
177
|
+
const globalAny = global;
|
|
178
|
+
if (!globalAny.__telemetryManager) {
|
|
179
|
+
globalAny.__telemetryManager = TelemetryManager.getInstance();
|
|
180
|
+
}
|
|
181
|
+
exports.telemetry = globalAny.__telemetryManager;
|
|
182
|
+
//# sourceMappingURL=telemetry-manager.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"telemetry-manager.js","sourceRoot":"","sources":["../../src/telemetry/telemetry-manager.ts"],"names":[],"mappings":"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"}
|
|
@@ -0,0 +1,69 @@
|
|
|
1
|
+
export interface TelemetryEvent {
|
|
2
|
+
user_id: string;
|
|
3
|
+
event: string;
|
|
4
|
+
properties: Record<string, any>;
|
|
5
|
+
created_at?: string;
|
|
6
|
+
}
|
|
7
|
+
export interface WorkflowTelemetry {
|
|
8
|
+
user_id: string;
|
|
9
|
+
workflow_hash: string;
|
|
10
|
+
node_count: number;
|
|
11
|
+
node_types: string[];
|
|
12
|
+
has_trigger: boolean;
|
|
13
|
+
has_webhook: boolean;
|
|
14
|
+
complexity: 'simple' | 'medium' | 'complex';
|
|
15
|
+
sanitized_workflow: any;
|
|
16
|
+
created_at?: string;
|
|
17
|
+
}
|
|
18
|
+
export interface SanitizedWorkflow {
|
|
19
|
+
nodes: any[];
|
|
20
|
+
connections: any;
|
|
21
|
+
nodeCount: number;
|
|
22
|
+
nodeTypes: string[];
|
|
23
|
+
hasTrigger: boolean;
|
|
24
|
+
hasWebhook: boolean;
|
|
25
|
+
complexity: 'simple' | 'medium' | 'complex';
|
|
26
|
+
workflowHash: string;
|
|
27
|
+
}
|
|
28
|
+
export declare const TELEMETRY_CONFIG: {
|
|
29
|
+
readonly BATCH_FLUSH_INTERVAL: 5000;
|
|
30
|
+
readonly EVENT_QUEUE_THRESHOLD: 10;
|
|
31
|
+
readonly WORKFLOW_QUEUE_THRESHOLD: 5;
|
|
32
|
+
readonly MAX_RETRIES: 3;
|
|
33
|
+
readonly RETRY_DELAY: 1000;
|
|
34
|
+
readonly OPERATION_TIMEOUT: 5000;
|
|
35
|
+
readonly RATE_LIMIT_WINDOW: 60000;
|
|
36
|
+
readonly RATE_LIMIT_MAX_EVENTS: 100;
|
|
37
|
+
readonly MAX_QUEUE_SIZE: 1000;
|
|
38
|
+
readonly MAX_BATCH_SIZE: 50;
|
|
39
|
+
};
|
|
40
|
+
export declare const TELEMETRY_BACKEND: {
|
|
41
|
+
readonly URL: "https://ydyufsohxdfpopqbubwk.supabase.co";
|
|
42
|
+
readonly ANON_KEY: "eyJhbGciOiJIUzI1NiIsInR5cCI6IkpXVCJ9.eyJpc3MiOiJzdXBhYmFzZSIsInJlZiI6InlkeXVmc29oeGRmcG9wcWJ1YndrIiwicm9sZSI6ImFub24iLCJpYXQiOjE3NTg3OTYyMDAsImV4cCI6MjA3NDM3MjIwMH0.xESphg6h5ozaDsm4Vla3QnDJGc6Nc_cpfoqTHRynkCk";
|
|
43
|
+
};
|
|
44
|
+
export interface TelemetryMetrics {
|
|
45
|
+
eventsTracked: number;
|
|
46
|
+
eventsDropped: number;
|
|
47
|
+
eventsFailed: number;
|
|
48
|
+
batchesSent: number;
|
|
49
|
+
batchesFailed: number;
|
|
50
|
+
averageFlushTime: number;
|
|
51
|
+
lastFlushTime?: number;
|
|
52
|
+
rateLimitHits: number;
|
|
53
|
+
}
|
|
54
|
+
export declare enum TelemetryErrorType {
|
|
55
|
+
VALIDATION_ERROR = "VALIDATION_ERROR",
|
|
56
|
+
NETWORK_ERROR = "NETWORK_ERROR",
|
|
57
|
+
RATE_LIMIT_ERROR = "RATE_LIMIT_ERROR",
|
|
58
|
+
QUEUE_OVERFLOW_ERROR = "QUEUE_OVERFLOW_ERROR",
|
|
59
|
+
INITIALIZATION_ERROR = "INITIALIZATION_ERROR",
|
|
60
|
+
UNKNOWN_ERROR = "UNKNOWN_ERROR"
|
|
61
|
+
}
|
|
62
|
+
export interface TelemetryErrorContext {
|
|
63
|
+
type: TelemetryErrorType;
|
|
64
|
+
message: string;
|
|
65
|
+
context?: Record<string, any>;
|
|
66
|
+
timestamp: number;
|
|
67
|
+
retryable: boolean;
|
|
68
|
+
}
|
|
69
|
+
//# sourceMappingURL=telemetry-types.d.ts.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"telemetry-types.d.ts","sourceRoot":"","sources":["../../src/telemetry/telemetry-types.ts"],"names":[],"mappings":"AAKA,MAAM,WAAW,cAAc;IAC7B,OAAO,EAAE,MAAM,CAAC;IAChB,KAAK,EAAE,MAAM,CAAC;IACd,UAAU,EAAE,MAAM,CAAC,MAAM,EAAE,GAAG,CAAC,CAAC;IAChC,UAAU,CAAC,EAAE,MAAM,CAAC;CACrB;AAED,MAAM,WAAW,iBAAiB;IAChC,OAAO,EAAE,MAAM,CAAC;IAChB,aAAa,EAAE,MAAM,CAAC;IACtB,UAAU,EAAE,MAAM,CAAC;IACnB,UAAU,EAAE,MAAM,EAAE,CAAC;IACrB,WAAW,EAAE,OAAO,CAAC;IACrB,WAAW,EAAE,OAAO,CAAC;IACrB,UAAU,EAAE,QAAQ,GAAG,QAAQ,GAAG,SAAS,CAAC;IAC5C,kBAAkB,EAAE,GAAG,CAAC;IACxB,UAAU,CAAC,EAAE,MAAM,CAAC;CACrB;AAED,MAAM,WAAW,iBAAiB;IAChC,KAAK,EAAE,GAAG,EAAE,CAAC;IACb,WAAW,EAAE,GAAG,CAAC;IACjB,SAAS,EAAE,MAAM,CAAC;IAClB,SAAS,EAAE,MAAM,EAAE,CAAC;IACpB,UAAU,EAAE,OAAO,CAAC;IACpB,UAAU,EAAE,OAAO,CAAC;IACpB,UAAU,EAAE,QAAQ,GAAG,QAAQ,GAAG,SAAS,CAAC;IAC5C,YAAY,EAAE,MAAM,CAAC;CACtB;AAED,eAAO,MAAM,gBAAgB;;;;;;;;;;;CAkBnB,CAAC;AAEX,eAAO,MAAM,iBAAiB;;;CAGpB,CAAC;AAEX,MAAM,WAAW,gBAAgB;IAC/B,aAAa,EAAE,MAAM,CAAC;IACtB,aAAa,EAAE,MAAM,CAAC;IACtB,YAAY,EAAE,MAAM,CAAC;IACrB,WAAW,EAAE,MAAM,CAAC;IACpB,aAAa,EAAE,MAAM,CAAC;IACtB,gBAAgB,EAAE,MAAM,CAAC;IACzB,aAAa,CAAC,EAAE,MAAM,CAAC;IACvB,aAAa,EAAE,MAAM,CAAC;CACvB;AAED,oBAAY,kBAAkB;IAC5B,gBAAgB,qBAAqB;IACrC,aAAa,kBAAkB;IAC/B,gBAAgB,qBAAqB;IACrC,oBAAoB,yBAAyB;IAC7C,oBAAoB,yBAAyB;IAC7C,aAAa,kBAAkB;CAChC;AAED,MAAM,WAAW,qBAAqB;IACpC,IAAI,EAAE,kBAAkB,CAAC;IACzB,OAAO,EAAE,MAAM,CAAC;IAChB,OAAO,CAAC,EAAE,MAAM,CAAC,MAAM,EAAE,GAAG,CAAC,CAAC;IAC9B,SAAS,EAAE,MAAM,CAAC;IAClB,SAAS,EAAE,OAAO,CAAC;CACpB"}
|
|
@@ -0,0 +1,29 @@
|
|
|
1
|
+
"use strict";
|
|
2
|
+
Object.defineProperty(exports, "__esModule", { value: true });
|
|
3
|
+
exports.TelemetryErrorType = exports.TELEMETRY_BACKEND = exports.TELEMETRY_CONFIG = void 0;
|
|
4
|
+
exports.TELEMETRY_CONFIG = {
|
|
5
|
+
BATCH_FLUSH_INTERVAL: 5000,
|
|
6
|
+
EVENT_QUEUE_THRESHOLD: 10,
|
|
7
|
+
WORKFLOW_QUEUE_THRESHOLD: 5,
|
|
8
|
+
MAX_RETRIES: 3,
|
|
9
|
+
RETRY_DELAY: 1000,
|
|
10
|
+
OPERATION_TIMEOUT: 5000,
|
|
11
|
+
RATE_LIMIT_WINDOW: 60000,
|
|
12
|
+
RATE_LIMIT_MAX_EVENTS: 100,
|
|
13
|
+
MAX_QUEUE_SIZE: 1000,
|
|
14
|
+
MAX_BATCH_SIZE: 50,
|
|
15
|
+
};
|
|
16
|
+
exports.TELEMETRY_BACKEND = {
|
|
17
|
+
URL: 'https://ydyufsohxdfpopqbubwk.supabase.co',
|
|
18
|
+
ANON_KEY: 'eyJhbGciOiJIUzI1NiIsInR5cCI6IkpXVCJ9.eyJpc3MiOiJzdXBhYmFzZSIsInJlZiI6InlkeXVmc29oeGRmcG9wcWJ1YndrIiwicm9sZSI6ImFub24iLCJpYXQiOjE3NTg3OTYyMDAsImV4cCI6MjA3NDM3MjIwMH0.xESphg6h5ozaDsm4Vla3QnDJGc6Nc_cpfoqTHRynkCk'
|
|
19
|
+
};
|
|
20
|
+
var TelemetryErrorType;
|
|
21
|
+
(function (TelemetryErrorType) {
|
|
22
|
+
TelemetryErrorType["VALIDATION_ERROR"] = "VALIDATION_ERROR";
|
|
23
|
+
TelemetryErrorType["NETWORK_ERROR"] = "NETWORK_ERROR";
|
|
24
|
+
TelemetryErrorType["RATE_LIMIT_ERROR"] = "RATE_LIMIT_ERROR";
|
|
25
|
+
TelemetryErrorType["QUEUE_OVERFLOW_ERROR"] = "QUEUE_OVERFLOW_ERROR";
|
|
26
|
+
TelemetryErrorType["INITIALIZATION_ERROR"] = "INITIALIZATION_ERROR";
|
|
27
|
+
TelemetryErrorType["UNKNOWN_ERROR"] = "UNKNOWN_ERROR";
|
|
28
|
+
})(TelemetryErrorType || (exports.TelemetryErrorType = TelemetryErrorType = {}));
|
|
29
|
+
//# sourceMappingURL=telemetry-types.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"telemetry-types.js","sourceRoot":"","sources":["../../src/telemetry/telemetry-types.ts"],"names":[],"mappings":";;;AAmCa,QAAA,gBAAgB,GAAG;IAE9B,oBAAoB,EAAE,IAAI;IAC1B,qBAAqB,EAAE,EAAE;IACzB,wBAAwB,EAAE,CAAC;IAG3B,WAAW,EAAE,CAAC;IACd,WAAW,EAAE,IAAI;IACjB,iBAAiB,EAAE,IAAI;IAGvB,iBAAiB,EAAE,KAAK;IACxB,qBAAqB,EAAE,GAAG;IAG1B,cAAc,EAAE,IAAI;IACpB,cAAc,EAAE,EAAE;CACV,CAAC;AAEE,QAAA,iBAAiB,GAAG;IAC/B,GAAG,EAAE,0CAA0C;IAC/C,QAAQ,EAAE,kNAAkN;CACpN,CAAC;AAaX,IAAY,kBAOX;AAPD,WAAY,kBAAkB;IAC5B,2DAAqC,CAAA;IACrC,qDAA+B,CAAA;IAC/B,2DAAqC,CAAA;IACrC,mEAA6C,CAAA;IAC7C,mEAA6C,CAAA;IAC7C,qDAA+B,CAAA;AACjC,CAAC,EAPW,kBAAkB,kCAAlB,kBAAkB,QAO7B"}
|
|
@@ -0,0 +1,33 @@
|
|
|
1
|
+
interface WorkflowNode {
|
|
2
|
+
id: string;
|
|
3
|
+
name: string;
|
|
4
|
+
type: string;
|
|
5
|
+
position: [number, number];
|
|
6
|
+
parameters: any;
|
|
7
|
+
credentials?: any;
|
|
8
|
+
disabled?: boolean;
|
|
9
|
+
typeVersion?: number;
|
|
10
|
+
}
|
|
11
|
+
interface SanitizedWorkflow {
|
|
12
|
+
nodes: WorkflowNode[];
|
|
13
|
+
connections: any;
|
|
14
|
+
nodeCount: number;
|
|
15
|
+
nodeTypes: string[];
|
|
16
|
+
hasTrigger: boolean;
|
|
17
|
+
hasWebhook: boolean;
|
|
18
|
+
complexity: 'simple' | 'medium' | 'complex';
|
|
19
|
+
workflowHash: string;
|
|
20
|
+
}
|
|
21
|
+
export declare class WorkflowSanitizer {
|
|
22
|
+
private static readonly SENSITIVE_PATTERNS;
|
|
23
|
+
private static readonly SENSITIVE_FIELDS;
|
|
24
|
+
static sanitizeWorkflow(workflow: any): SanitizedWorkflow;
|
|
25
|
+
private static sanitizeNode;
|
|
26
|
+
private static sanitizeObject;
|
|
27
|
+
private static sanitizeString;
|
|
28
|
+
private static isSensitiveField;
|
|
29
|
+
private static sanitizeConnections;
|
|
30
|
+
static generateWorkflowHash(workflow: any): string;
|
|
31
|
+
}
|
|
32
|
+
export {};
|
|
33
|
+
//# sourceMappingURL=workflow-sanitizer.d.ts.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"workflow-sanitizer.d.ts","sourceRoot":"","sources":["../../src/telemetry/workflow-sanitizer.ts"],"names":[],"mappings":"AAOA,UAAU,YAAY;IACpB,EAAE,EAAE,MAAM,CAAC;IACX,IAAI,EAAE,MAAM,CAAC;IACb,IAAI,EAAE,MAAM,CAAC;IACb,QAAQ,EAAE,CAAC,MAAM,EAAE,MAAM,CAAC,CAAC;IAC3B,UAAU,EAAE,GAAG,CAAC;IAChB,WAAW,CAAC,EAAE,GAAG,CAAC;IAClB,QAAQ,CAAC,EAAE,OAAO,CAAC;IACnB,WAAW,CAAC,EAAE,MAAM,CAAC;CACtB;AAED,UAAU,iBAAiB;IACzB,KAAK,EAAE,YAAY,EAAE,CAAC;IACtB,WAAW,EAAE,GAAG,CAAC;IACjB,SAAS,EAAE,MAAM,CAAC;IAClB,SAAS,EAAE,MAAM,EAAE,CAAC;IACpB,UAAU,EAAE,OAAO,CAAC;IACpB,UAAU,EAAE,OAAO,CAAC;IACpB,UAAU,EAAE,QAAQ,GAAG,QAAQ,GAAG,SAAS,CAAC;IAC5C,YAAY,EAAE,MAAM,CAAC;CACtB;AAED,qBAAa,iBAAiB;IAC5B,OAAO,CAAC,MAAM,CAAC,QAAQ,CAAC,kBAAkB,CAsBxC;IAEF,OAAO,CAAC,MAAM,CAAC,QAAQ,CAAC,gBAAgB,CAoBtC;IAKF,MAAM,CAAC,gBAAgB,CAAC,QAAQ,EAAE,GAAG,GAAG,iBAAiB;IAwEzD,OAAO,CAAC,MAAM,CAAC,YAAY;IAiB3B,OAAO,CAAC,MAAM,CAAC,cAAc;IAsC7B,OAAO,CAAC,MAAM,CAAC,cAAc;IAwC7B,OAAO,CAAC,MAAM,CAAC,gBAAgB;IAU/B,OAAO,CAAC,MAAM,CAAC,mBAAmB;IAsClC,MAAM,CAAC,oBAAoB,CAAC,QAAQ,EAAE,GAAG,GAAG,MAAM;CAInD"}
|