n8n-nodes-amazon-selling-partner-dnangelx 0.0.2 → 0.0.5

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 (104) hide show
  1. package/dist/credentials/AmazonSpApi.credentials.d.ts +9 -0
  2. package/dist/credentials/AmazonSpApi.credentials.js +212 -0
  3. package/dist/credentials/AmazonSpApi.credentials.js.map +1 -0
  4. package/dist/nodes/AmazonSellingPartner/AmazonSellingPartner.node.d.ts +1 -1
  5. package/dist/nodes/AmazonSellingPartner/AmazonSellingPartner.node.js +142 -33
  6. package/dist/nodes/AmazonSellingPartner/AmazonSellingPartner.node.js.map +1 -1
  7. package/dist/nodes/AmazonSellingPartner/AmazonSellingPartner.node.json +1 -1
  8. package/dist/nodes/AmazonSellingPartner/amazonSpApi.svg +25 -0
  9. package/dist/nodes/AmazonSellingPartner/core/AuditLogger.d.ts +67 -0
  10. package/dist/nodes/AmazonSellingPartner/core/AuditLogger.js +296 -0
  11. package/dist/nodes/AmazonSellingPartner/core/AuditLogger.js.map +1 -0
  12. package/dist/nodes/AmazonSellingPartner/core/ErrorHandler.d.ts +6 -0
  13. package/dist/nodes/AmazonSellingPartner/core/ErrorHandler.js +82 -0
  14. package/dist/nodes/AmazonSellingPartner/core/ErrorHandler.js.map +1 -0
  15. package/dist/nodes/AmazonSellingPartner/core/MetricsCollector.d.ts +48 -0
  16. package/dist/nodes/AmazonSellingPartner/core/MetricsCollector.js +181 -0
  17. package/dist/nodes/AmazonSellingPartner/core/MetricsCollector.js.map +1 -0
  18. package/dist/nodes/AmazonSellingPartner/core/RateLimiter.d.ts +43 -0
  19. package/dist/nodes/AmazonSellingPartner/core/RateLimiter.js +260 -0
  20. package/dist/nodes/AmazonSellingPartner/core/RateLimiter.js.map +1 -0
  21. package/dist/nodes/AmazonSellingPartner/core/SecurityValidator.d.ts +35 -0
  22. package/dist/nodes/AmazonSellingPartner/core/SecurityValidator.js +383 -0
  23. package/dist/nodes/AmazonSellingPartner/core/SecurityValidator.js.map +1 -0
  24. package/dist/nodes/AmazonSellingPartner/core/rateLimitConfig.d.ts +14 -0
  25. package/dist/nodes/AmazonSellingPartner/core/rateLimitConfig.js +93 -0
  26. package/dist/nodes/AmazonSellingPartner/core/rateLimitConfig.js.map +1 -0
  27. package/dist/nodes/AmazonSellingPartner/descriptions/Analytics.description.d.ts +3 -0
  28. package/dist/nodes/AmazonSellingPartner/descriptions/Analytics.description.js +27 -0
  29. package/dist/nodes/AmazonSellingPartner/descriptions/Analytics.description.js.map +1 -0
  30. package/dist/nodes/AmazonSellingPartner/descriptions/DataKiosk.description.d.ts +3 -0
  31. package/dist/nodes/AmazonSellingPartner/descriptions/DataKiosk.description.js +196 -0
  32. package/dist/nodes/AmazonSellingPartner/descriptions/DataKiosk.description.js.map +1 -0
  33. package/dist/nodes/AmazonSellingPartner/descriptions/Finance.description.d.ts +3 -0
  34. package/dist/nodes/AmazonSellingPartner/descriptions/Finance.description.js +341 -0
  35. package/dist/nodes/AmazonSellingPartner/descriptions/Finance.description.js.map +1 -0
  36. package/dist/nodes/AmazonSellingPartner/descriptions/Invoices.description.d.ts +3 -0
  37. package/dist/nodes/AmazonSellingPartner/descriptions/Invoices.description.js +312 -0
  38. package/dist/nodes/AmazonSellingPartner/descriptions/Invoices.description.js.map +1 -0
  39. package/dist/nodes/AmazonSellingPartner/descriptions/Listings.description.d.ts +3 -0
  40. package/dist/nodes/AmazonSellingPartner/descriptions/Listings.description.js +292 -0
  41. package/dist/nodes/AmazonSellingPartner/descriptions/Listings.description.js.map +1 -0
  42. package/dist/nodes/AmazonSellingPartner/descriptions/Orders.description.d.ts +3 -0
  43. package/dist/nodes/AmazonSellingPartner/descriptions/Orders.description.js +202 -0
  44. package/dist/nodes/AmazonSellingPartner/descriptions/Orders.description.js.map +1 -0
  45. package/dist/nodes/AmazonSellingPartner/descriptions/Reports.description.d.ts +3 -0
  46. package/dist/nodes/AmazonSellingPartner/descriptions/Reports.description.js +289 -0
  47. package/dist/nodes/AmazonSellingPartner/descriptions/Reports.description.js.map +1 -0
  48. package/dist/nodes/AmazonSellingPartner/descriptions/Shipments.description.d.ts +3 -0
  49. package/dist/nodes/AmazonSellingPartner/descriptions/Shipments.description.js +181 -0
  50. package/dist/nodes/AmazonSellingPartner/descriptions/Shipments.description.js.map +1 -0
  51. package/dist/nodes/AmazonSellingPartner/helpers/LwaClient.d.ts +10 -0
  52. package/dist/nodes/AmazonSellingPartner/helpers/LwaClient.js +79 -0
  53. package/dist/nodes/AmazonSellingPartner/helpers/LwaClient.js.map +1 -0
  54. package/dist/nodes/AmazonSellingPartner/helpers/RdtClient.d.ts +11 -0
  55. package/dist/nodes/AmazonSellingPartner/helpers/RdtClient.js +66 -0
  56. package/dist/nodes/AmazonSellingPartner/helpers/RdtClient.js.map +1 -0
  57. package/dist/nodes/AmazonSellingPartner/helpers/ReportDownloader.d.ts +16 -0
  58. package/dist/nodes/AmazonSellingPartner/helpers/ReportDownloader.js +65 -0
  59. package/dist/nodes/AmazonSellingPartner/helpers/ReportDownloader.js.map +1 -0
  60. package/dist/nodes/AmazonSellingPartner/helpers/SigV4Signer.d.ts +4 -0
  61. package/dist/nodes/AmazonSellingPartner/helpers/SigV4Signer.js +76 -0
  62. package/dist/nodes/AmazonSellingPartner/helpers/SigV4Signer.js.map +1 -0
  63. package/dist/nodes/AmazonSellingPartner/helpers/SpApiRequest.d.ts +23 -0
  64. package/dist/nodes/AmazonSellingPartner/helpers/SpApiRequest.js +208 -0
  65. package/dist/nodes/AmazonSellingPartner/helpers/SpApiRequest.js.map +1 -0
  66. package/dist/nodes/AmazonSellingPartner/helpers/downloadPresigned.d.ts +4 -0
  67. package/dist/nodes/AmazonSellingPartner/helpers/downloadPresigned.js +16 -0
  68. package/dist/nodes/AmazonSellingPartner/helpers/downloadPresigned.js.map +1 -0
  69. package/dist/nodes/AmazonSellingPartner/helpers/graphql.d.ts +1 -0
  70. package/dist/nodes/AmazonSellingPartner/helpers/graphql.js +13 -0
  71. package/dist/nodes/AmazonSellingPartner/helpers/graphql.js.map +1 -0
  72. package/dist/nodes/AmazonSellingPartner/operations/Analytics.operations.d.ts +2 -0
  73. package/dist/nodes/AmazonSellingPartner/operations/Analytics.operations.js +66 -0
  74. package/dist/nodes/AmazonSellingPartner/operations/Analytics.operations.js.map +1 -0
  75. package/dist/nodes/AmazonSellingPartner/operations/DataKiosk.operations.d.ts +2 -0
  76. package/dist/nodes/AmazonSellingPartner/operations/DataKiosk.operations.js +249 -0
  77. package/dist/nodes/AmazonSellingPartner/operations/DataKiosk.operations.js.map +1 -0
  78. package/dist/nodes/AmazonSellingPartner/operations/Finance.operations.d.ts +2 -0
  79. package/dist/nodes/AmazonSellingPartner/operations/Finance.operations.js +444 -0
  80. package/dist/nodes/AmazonSellingPartner/operations/Finance.operations.js.map +1 -0
  81. package/dist/nodes/AmazonSellingPartner/operations/Invoices.operations.d.ts +4 -0
  82. package/dist/nodes/AmazonSellingPartner/operations/Invoices.operations.js +224 -0
  83. package/dist/nodes/AmazonSellingPartner/operations/Invoices.operations.js.map +1 -0
  84. package/dist/nodes/AmazonSellingPartner/operations/Listings.operations.d.ts +2 -0
  85. package/dist/nodes/AmazonSellingPartner/operations/Listings.operations.js +426 -0
  86. package/dist/nodes/AmazonSellingPartner/operations/Listings.operations.js.map +1 -0
  87. package/dist/nodes/AmazonSellingPartner/operations/Orders.operations.d.ts +2 -0
  88. package/dist/nodes/AmazonSellingPartner/operations/Orders.operations.js +169 -0
  89. package/dist/nodes/AmazonSellingPartner/operations/Orders.operations.js.map +1 -0
  90. package/dist/nodes/AmazonSellingPartner/operations/Reports.operations.d.ts +2 -0
  91. package/dist/nodes/AmazonSellingPartner/operations/Reports.operations.js +434 -0
  92. package/dist/nodes/AmazonSellingPartner/operations/Reports.operations.js.map +1 -0
  93. package/dist/nodes/AmazonSellingPartner/operations/Shipments.operations.d.ts +2 -0
  94. package/dist/nodes/AmazonSellingPartner/operations/Shipments.operations.js +78 -0
  95. package/dist/nodes/AmazonSellingPartner/operations/Shipments.operations.js.map +1 -0
  96. package/dist/nodes/AmazonSellingPartner/operations/analytics/constants.d.ts +126 -0
  97. package/dist/nodes/AmazonSellingPartner/operations/analytics/constants.js +213 -0
  98. package/dist/nodes/AmazonSellingPartner/operations/analytics/constants.js.map +1 -0
  99. package/dist/package.json +12 -4
  100. package/dist/tsconfig.tsbuildinfo +1 -1
  101. package/package.json +11 -3
  102. package/dist/credentials/AmazonSellingPartnerOAuth2Api.credentials.d.ts +0 -17
  103. package/dist/credentials/AmazonSellingPartnerOAuth2Api.credentials.js +0 -177
  104. package/dist/credentials/AmazonSellingPartnerOAuth2Api.credentials.js.map +0 -1
@@ -0,0 +1,43 @@
1
+ interface RateLimiterMetrics {
2
+ queueLength: number;
3
+ waitTimeMs: number;
4
+ rateLimitHits: number;
5
+ activeGroups: number;
6
+ }
7
+ interface DistributedBackend {
8
+ getTokens(groupKey: string): Promise<number>;
9
+ consumeTokens(groupKey: string, count: number): Promise<boolean>;
10
+ refillTokens(groupKey: string, tokens: number, maxTokens: number): Promise<void>;
11
+ }
12
+ export declare class RateLimiter {
13
+ private limits;
14
+ private readonly QUEUE_TIMEOUT;
15
+ private readonly MAX_RETRIES;
16
+ private readonly BASE_RETRY_DELAY;
17
+ private readonly MAX_RETRY_DELAY;
18
+ private distributedBackend?;
19
+ private metrics;
20
+ constructor(options?: {
21
+ queueTimeout?: number;
22
+ distributedBackend?: DistributedBackend;
23
+ });
24
+ waitForToken(groupKey: string, retryCount?: number): Promise<void>;
25
+ updateFromHeaders(groupKey: string, headers: Record<string, string>): void;
26
+ getMetrics(): RateLimiterMetrics & {
27
+ groupDetails: Record<string, {
28
+ queueLength: number;
29
+ tokens: number;
30
+ maxTokens: number;
31
+ }>;
32
+ };
33
+ private getRateLimit;
34
+ private refillTokens;
35
+ private processQueue;
36
+ private calculateRetryDelay;
37
+ private recordRateLimitHit;
38
+ private updateQueueMetrics;
39
+ private updateMetrics;
40
+ private startMetricsCollection;
41
+ cleanup(): void;
42
+ }
43
+ export {};
@@ -0,0 +1,260 @@
1
+ "use strict";
2
+ Object.defineProperty(exports, "__esModule", { value: true });
3
+ exports.RateLimiter = void 0;
4
+ const n8n_workflow_1 = require("n8n-workflow");
5
+ const MetricsCollector_1 = require("./MetricsCollector");
6
+ const rateLimitConfig_1 = require("./rateLimitConfig");
7
+ class RateLimiter {
8
+ constructor(options = {}) {
9
+ this.limits = new Map();
10
+ this.MAX_RETRIES = 10;
11
+ this.BASE_RETRY_DELAY = 2000;
12
+ this.MAX_RETRY_DELAY = 60000;
13
+ this.metrics = {
14
+ queueLength: 0,
15
+ waitTimeMs: 0,
16
+ rateLimitHits: 0,
17
+ activeGroups: 0,
18
+ };
19
+ this.QUEUE_TIMEOUT = options.queueTimeout || parseInt(process.env.RATE_LIMIT_QUEUE_TIMEOUT || '300000');
20
+ this.distributedBackend = options.distributedBackend;
21
+ this.startMetricsCollection();
22
+ }
23
+ async waitForToken(groupKey, retryCount = 0) {
24
+ const startTime = Date.now();
25
+ const rateLimit = this.getRateLimit(groupKey);
26
+ try {
27
+ if (this.distributedBackend) {
28
+ const success = await this.distributedBackend.consumeTokens(groupKey, 1);
29
+ if (success) {
30
+ const waitTime = Date.now() - startTime;
31
+ this.updateMetrics({ waitTimeMs: waitTime });
32
+ return;
33
+ }
34
+ }
35
+ else {
36
+ await this.refillTokens(rateLimit.bucket);
37
+ if (rateLimit.bucket.tokens >= 1) {
38
+ rateLimit.bucket.tokens -= 1;
39
+ const waitTime = Date.now() - startTime;
40
+ this.updateMetrics({ waitTimeMs: waitTime });
41
+ return;
42
+ }
43
+ }
44
+ this.recordRateLimitHit(groupKey);
45
+ return new Promise((resolve, reject) => {
46
+ const queueItem = {
47
+ resolve: () => {
48
+ const waitTime = Date.now() - startTime;
49
+ this.updateMetrics({ waitTimeMs: waitTime });
50
+ resolve();
51
+ },
52
+ reject,
53
+ timestamp: Date.now(),
54
+ groupKey,
55
+ };
56
+ rateLimit.requestQueue.push(queueItem);
57
+ this.updateQueueMetrics();
58
+ setTimeout(() => {
59
+ const index = rateLimit.requestQueue.indexOf(queueItem);
60
+ if (index !== -1) {
61
+ rateLimit.requestQueue.splice(index, 1);
62
+ this.updateQueueMetrics();
63
+ if (retryCount < this.MAX_RETRIES) {
64
+ const delay = this.calculateRetryDelay(retryCount);
65
+ setTimeout(() => {
66
+ this.waitForToken(groupKey, retryCount + 1)
67
+ .then(resolve)
68
+ .catch(reject);
69
+ }, delay);
70
+ }
71
+ else {
72
+ reject(new n8n_workflow_1.NodeOperationError({}, `Request timeout: Rate limit queue exceeded maximum wait time after ${retryCount} retries`, { description: `The request was queued for too long due to rate limiting for group: ${groupKey}` }));
73
+ }
74
+ }
75
+ }, this.QUEUE_TIMEOUT);
76
+ this.processQueue(groupKey);
77
+ });
78
+ }
79
+ catch (error) {
80
+ const waitTime = Date.now() - startTime;
81
+ this.updateMetrics({ waitTimeMs: waitTime });
82
+ throw error;
83
+ }
84
+ }
85
+ updateFromHeaders(groupKey, headers) {
86
+ const rateLimitHeader = headers['x-amzn-ratelimit-limit'];
87
+ if (!rateLimitHeader)
88
+ return;
89
+ try {
90
+ const [rate, burst] = rateLimitHeader.split(':').map(Number);
91
+ if (rate && burst) {
92
+ const rateLimit = this.getRateLimit(groupKey);
93
+ const newConfig = {
94
+ rate,
95
+ burst,
96
+ description: `Updated from API headers for ${groupKey}`
97
+ };
98
+ if ((0, rateLimitConfig_1.validateRateLimitConfig)(newConfig)) {
99
+ rateLimit.bucket.refillRate = rate;
100
+ rateLimit.bucket.maxTokens = burst;
101
+ rateLimit.bucket.config = newConfig;
102
+ rateLimit.bucket.tokens = Math.min(rateLimit.bucket.tokens, burst);
103
+ if (this.distributedBackend) {
104
+ this.distributedBackend.refillTokens(groupKey, rateLimit.bucket.tokens, burst);
105
+ }
106
+ }
107
+ }
108
+ }
109
+ catch (error) {
110
+ console.warn(`Failed to parse rate limit header for ${groupKey}:`, error);
111
+ }
112
+ }
113
+ getMetrics() {
114
+ const groupDetails = {};
115
+ for (const [groupKey, rateLimit] of this.limits.entries()) {
116
+ groupDetails[groupKey] = {
117
+ queueLength: rateLimit.requestQueue.length,
118
+ tokens: Math.floor(rateLimit.bucket.tokens),
119
+ maxTokens: rateLimit.bucket.maxTokens,
120
+ };
121
+ }
122
+ return {
123
+ ...this.metrics,
124
+ activeGroups: this.limits.size,
125
+ groupDetails,
126
+ };
127
+ }
128
+ getRateLimit(groupKey) {
129
+ if (!this.limits.has(groupKey)) {
130
+ const config = (0, rateLimitConfig_1.getRateLimitConfig)(groupKey);
131
+ if (!(0, rateLimitConfig_1.validateRateLimitConfig)(config)) {
132
+ throw new Error(`Invalid rate limit configuration for group: ${groupKey}`);
133
+ }
134
+ this.limits.set(groupKey, {
135
+ bucket: {
136
+ tokens: config.burst,
137
+ maxTokens: config.burst,
138
+ refillRate: config.rate,
139
+ lastRefill: Date.now(),
140
+ config,
141
+ },
142
+ requestQueue: [],
143
+ });
144
+ }
145
+ return this.limits.get(groupKey);
146
+ }
147
+ async refillTokens(bucket) {
148
+ const now = Date.now();
149
+ const timePassed = (now - bucket.lastRefill) / 1000;
150
+ const tokensToAdd = timePassed * bucket.refillRate;
151
+ bucket.tokens = Math.min(bucket.maxTokens, bucket.tokens + tokensToAdd);
152
+ bucket.lastRefill = now;
153
+ if (this.distributedBackend) {
154
+ await this.distributedBackend.refillTokens('', bucket.tokens, bucket.maxTokens);
155
+ }
156
+ }
157
+ processQueue(groupKey) {
158
+ const rateLimit = this.getRateLimit(groupKey);
159
+ if (rateLimit.processingInterval) {
160
+ return;
161
+ }
162
+ rateLimit.processingInterval = setInterval(async () => {
163
+ try {
164
+ if (this.distributedBackend) {
165
+ while (rateLimit.requestQueue.length > 0) {
166
+ const success = await this.distributedBackend.consumeTokens(groupKey, 1);
167
+ if (!success)
168
+ break;
169
+ const queueItem = rateLimit.requestQueue.shift();
170
+ queueItem.resolve();
171
+ }
172
+ }
173
+ else {
174
+ await this.refillTokens(rateLimit.bucket);
175
+ while (rateLimit.requestQueue.length > 0 && rateLimit.bucket.tokens >= 1) {
176
+ const queueItem = rateLimit.requestQueue.shift();
177
+ rateLimit.bucket.tokens -= 1;
178
+ queueItem.resolve();
179
+ }
180
+ }
181
+ const now = Date.now();
182
+ const initialLength = rateLimit.requestQueue.length;
183
+ rateLimit.requestQueue = rateLimit.requestQueue.filter(item => {
184
+ if (now - item.timestamp > this.QUEUE_TIMEOUT) {
185
+ item.reject(new n8n_workflow_1.NodeOperationError({}, 'Request timeout: Exceeded maximum queue wait time', { description: `Request for group ${groupKey} timed out in queue` }));
186
+ return false;
187
+ }
188
+ return true;
189
+ });
190
+ if (initialLength !== rateLimit.requestQueue.length) {
191
+ this.updateQueueMetrics();
192
+ }
193
+ if (rateLimit.requestQueue.length === 0) {
194
+ if (rateLimit.processingInterval) {
195
+ clearInterval(rateLimit.processingInterval);
196
+ rateLimit.processingInterval = undefined;
197
+ }
198
+ }
199
+ }
200
+ catch (error) {
201
+ console.error(`Error processing rate limit queue for ${groupKey}:`, error);
202
+ }
203
+ }, 1000);
204
+ }
205
+ calculateRetryDelay(retryCount) {
206
+ const exponentialDelay = Math.min(this.BASE_RETRY_DELAY * Math.pow(2, retryCount), this.MAX_RETRY_DELAY);
207
+ const jitter = Math.random() * 0.1 * exponentialDelay;
208
+ return exponentialDelay + jitter;
209
+ }
210
+ recordRateLimitHit(groupKey) {
211
+ this.metrics.rateLimitHits++;
212
+ MetricsCollector_1.metricsCollector.recordRateLimitHit(groupKey);
213
+ }
214
+ updateQueueMetrics() {
215
+ let totalQueueLength = 0;
216
+ for (const rateLimit of this.limits.values()) {
217
+ totalQueueLength += rateLimit.requestQueue.length;
218
+ }
219
+ this.metrics.queueLength = totalQueueLength;
220
+ }
221
+ updateMetrics(updates) {
222
+ Object.assign(this.metrics, updates);
223
+ }
224
+ startMetricsCollection() {
225
+ const timer = setInterval(() => {
226
+ const metrics = this.getMetrics();
227
+ MetricsCollector_1.metricsCollector.recordMetric('rate_limiter_queue_length', metrics.queueLength);
228
+ MetricsCollector_1.metricsCollector.recordMetric('rate_limiter_active_groups', metrics.activeGroups);
229
+ for (const [groupKey, details] of Object.entries(metrics.groupDetails)) {
230
+ MetricsCollector_1.metricsCollector.recordMetric('rate_limiter_group_queue_length', details.queueLength, { group: groupKey });
231
+ MetricsCollector_1.metricsCollector.recordMetric('rate_limiter_group_tokens', details.tokens, { group: groupKey });
232
+ }
233
+ }, 30000);
234
+ if (typeof timer.unref === 'function') {
235
+ timer.unref();
236
+ }
237
+ }
238
+ cleanup() {
239
+ for (const rateLimit of this.limits.values()) {
240
+ if (rateLimit.processingInterval) {
241
+ clearInterval(rateLimit.processingInterval);
242
+ rateLimit.processingInterval = undefined;
243
+ }
244
+ const queued = [...rateLimit.requestQueue];
245
+ rateLimit.requestQueue.length = 0;
246
+ this.updateQueueMetrics();
247
+ process.nextTick(() => {
248
+ for (const item of queued) {
249
+ try {
250
+ item.reject(new Error('Rate limiter shutting down'));
251
+ }
252
+ catch { }
253
+ }
254
+ });
255
+ }
256
+ this.limits.clear();
257
+ }
258
+ }
259
+ exports.RateLimiter = RateLimiter;
260
+ //# sourceMappingURL=RateLimiter.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"RateLimiter.js","sourceRoot":"","sources":["../../../../nodes/AmazonSellingPartner/core/RateLimiter.ts"],"names":[],"mappings":"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"}
@@ -0,0 +1,35 @@
1
+ export interface ValidationRule {
2
+ field: string;
3
+ required?: boolean;
4
+ type?: 'string' | 'number' | 'boolean' | 'array' | 'object' | 'date';
5
+ minLength?: number;
6
+ maxLength?: number;
7
+ pattern?: RegExp;
8
+ allowedValues?: any[];
9
+ sanitize?: boolean;
10
+ customValidator?: (value: any) => boolean | string;
11
+ }
12
+ export interface ValidationResult {
13
+ isValid: boolean;
14
+ errors: string[];
15
+ sanitizedData?: any;
16
+ }
17
+ export declare class SecurityValidator {
18
+ private readonly suspiciousPatterns;
19
+ private readonly marketplaceIdPattern;
20
+ private readonly datePattern;
21
+ validateInput(data: any, rules: ValidationRule[], nodeId: string): ValidationResult;
22
+ validateMarketplaceIds(marketplaceIds: string[], nodeId: string): ValidationResult;
23
+ validateDateRange(createdAfter: string, createdBefore: string, nodeId: string): ValidationResult;
24
+ sanitizeString(input: string): string;
25
+ detectSuspiciousPatterns(input: string, nodeId: string): boolean;
26
+ validateCredentials(credentials: any, nodeId: string, useAwsSigning?: boolean): ValidationResult;
27
+ validateApiParameters(params: Record<string, any>, nodeId: string): ValidationResult;
28
+ checkRateLimitCompliance(endpoint: string, nodeId: string): boolean;
29
+ validateEnvironmentIsolation(credentials: any, nodeId: string): ValidationResult;
30
+ private validateField;
31
+ private validateType;
32
+ private getNestedValue;
33
+ private setNestedValue;
34
+ }
35
+ export declare const securityValidator: SecurityValidator;