n8n-mcp 2.13.1 → 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.
Files changed (79) hide show
  1. package/README.md +45 -0
  2. package/data/nodes.db +0 -0
  3. package/dist/database/node-repository.d.ts +5 -0
  4. package/dist/database/node-repository.d.ts.map +1 -1
  5. package/dist/database/node-repository.js +90 -0
  6. package/dist/database/node-repository.js.map +1 -1
  7. package/dist/errors/validation-service-error.d.ts +10 -0
  8. package/dist/errors/validation-service-error.d.ts.map +1 -0
  9. package/dist/errors/validation-service-error.js +26 -0
  10. package/dist/errors/validation-service-error.js.map +1 -0
  11. package/dist/mcp/handlers-n8n-manager.d.ts.map +1 -1
  12. package/dist/mcp/handlers-n8n-manager.js +6 -0
  13. package/dist/mcp/handlers-n8n-manager.js.map +1 -1
  14. package/dist/mcp/index.js +32 -0
  15. package/dist/mcp/index.js.map +1 -1
  16. package/dist/mcp/server.d.ts +2 -0
  17. package/dist/mcp/server.d.ts.map +1 -1
  18. package/dist/mcp/server.js +57 -19
  19. package/dist/mcp/server.js.map +1 -1
  20. package/dist/services/config-validator.d.ts +1 -0
  21. package/dist/services/config-validator.d.ts.map +1 -1
  22. package/dist/services/config-validator.js.map +1 -1
  23. package/dist/services/enhanced-config-validator.d.ts +6 -0
  24. package/dist/services/enhanced-config-validator.d.ts.map +1 -1
  25. package/dist/services/enhanced-config-validator.js +127 -0
  26. package/dist/services/enhanced-config-validator.js.map +1 -1
  27. package/dist/services/operation-similarity-service.d.ts +32 -0
  28. package/dist/services/operation-similarity-service.d.ts.map +1 -0
  29. package/dist/services/operation-similarity-service.js +341 -0
  30. package/dist/services/operation-similarity-service.js.map +1 -0
  31. package/dist/services/resource-similarity-service.d.ts +33 -0
  32. package/dist/services/resource-similarity-service.d.ts.map +1 -0
  33. package/dist/services/resource-similarity-service.js +358 -0
  34. package/dist/services/resource-similarity-service.js.map +1 -0
  35. package/dist/telemetry/batch-processor.d.ts +32 -0
  36. package/dist/telemetry/batch-processor.d.ts.map +1 -0
  37. package/dist/telemetry/batch-processor.js +266 -0
  38. package/dist/telemetry/batch-processor.js.map +1 -0
  39. package/dist/telemetry/config-manager.d.ts +28 -0
  40. package/dist/telemetry/config-manager.d.ts.map +1 -0
  41. package/dist/telemetry/config-manager.js +211 -0
  42. package/dist/telemetry/config-manager.js.map +1 -0
  43. package/dist/telemetry/event-tracker.d.ts +58 -0
  44. package/dist/telemetry/event-tracker.d.ts.map +1 -0
  45. package/dist/telemetry/event-tracker.js +295 -0
  46. package/dist/telemetry/event-tracker.js.map +1 -0
  47. package/dist/telemetry/event-validator.d.ts +78 -0
  48. package/dist/telemetry/event-validator.d.ts.map +1 -0
  49. package/dist/telemetry/event-validator.js +204 -0
  50. package/dist/telemetry/event-validator.js.map +1 -0
  51. package/dist/telemetry/index.d.ts +5 -0
  52. package/dist/telemetry/index.d.ts.map +1 -0
  53. package/dist/telemetry/index.js +11 -0
  54. package/dist/telemetry/index.js.map +1 -0
  55. package/dist/telemetry/performance-monitor.d.ts +113 -0
  56. package/dist/telemetry/performance-monitor.d.ts.map +1 -0
  57. package/dist/telemetry/performance-monitor.js +208 -0
  58. package/dist/telemetry/performance-monitor.js.map +1 -0
  59. package/dist/telemetry/rate-limiter.d.ts +30 -0
  60. package/dist/telemetry/rate-limiter.d.ts.map +1 -0
  61. package/dist/telemetry/rate-limiter.js +103 -0
  62. package/dist/telemetry/rate-limiter.js.map +1 -0
  63. package/dist/telemetry/telemetry-error.d.ts +44 -0
  64. package/dist/telemetry/telemetry-error.d.ts.map +1 -0
  65. package/dist/telemetry/telemetry-error.js +153 -0
  66. package/dist/telemetry/telemetry-error.js.map +1 -0
  67. package/dist/telemetry/telemetry-manager.d.ts +127 -0
  68. package/dist/telemetry/telemetry-manager.d.ts.map +1 -0
  69. package/dist/telemetry/telemetry-manager.js +182 -0
  70. package/dist/telemetry/telemetry-manager.js.map +1 -0
  71. package/dist/telemetry/telemetry-types.d.ts +69 -0
  72. package/dist/telemetry/telemetry-types.d.ts.map +1 -0
  73. package/dist/telemetry/telemetry-types.js +29 -0
  74. package/dist/telemetry/telemetry-types.js.map +1 -0
  75. package/dist/telemetry/workflow-sanitizer.d.ts +33 -0
  76. package/dist/telemetry/workflow-sanitizer.d.ts.map +1 -0
  77. package/dist/telemetry/workflow-sanitizer.js +190 -0
  78. package/dist/telemetry/workflow-sanitizer.js.map +1 -0
  79. 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"}