@wikicasa-dev/node-common 4.7.12 → 5.0.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.
@@ -44,30 +44,96 @@ export declare class CallPool {
44
44
  private readonly httpsAgent?;
45
45
  private readonly httpAgent?;
46
46
  constructor(config: CallPoolConfig);
47
+ /**
48
+ * Merge caller-supplied Axios config with proxy, agent, and header defaults.
49
+ *
50
+ * @param config - Optional Axios request overrides
51
+ * @returns Merged Axios configuration
52
+ */
47
53
  private buildAxiosConfig;
54
+ /**
55
+ * Record a call timestamp and prune entries older than one minute (thread-safe).
56
+ */
48
57
  private updateCallStack;
58
+ /**
59
+ * Execute a single task through the rate limiter with automatic retry on transient failures.
60
+ *
61
+ * @param call - Async factory to execute
62
+ * @param resolve - Promise resolve callback
63
+ * @param reject - Promise reject callback
64
+ * @param remainingAttempts - Number of retry attempts left
65
+ */
49
66
  private executeLimited;
67
+ /**
68
+ * Perform an HTTP request immediately, bypassing the pool queue.
69
+ *
70
+ * @param url - Request URL
71
+ * @param config - Optional Axios request configuration
72
+ * @returns Axios response
73
+ */
50
74
  directCall(url: string, config?: AxiosRequestConfig): Promise<AxiosResponse>;
75
+ /**
76
+ * Enqueue an HTTP request to be executed when a concurrency slot is available.
77
+ *
78
+ * @param url - Request URL
79
+ * @param config - Optional Axios request configuration
80
+ * @returns Axios response once the request completes
81
+ */
51
82
  call(url: string, config?: AxiosRequestConfig): Promise<AxiosResponse>;
83
+ /**
84
+ * Pick a random modern browser User-Agent string for request rotation.
85
+ *
86
+ * @returns Random User-Agent string or null if none matches
87
+ */
52
88
  private getRandomUserAgent;
89
+ /**
90
+ * Add a custom async task to the pool queue and return its result when complete.
91
+ *
92
+ * @param call - Async factory function to enqueue
93
+ * @returns Resolved value from the call
94
+ */
53
95
  enqueue(call: () => Promise<any>): Promise<any>;
96
+ /**
97
+ * Drain the queue by dispatching tasks up to the current adaptive concurrency limit.
98
+ */
54
99
  private schedule;
100
+ /**
101
+ * Adjust adaptive concurrency based on mean response time and update the progress display.
102
+ *
103
+ * @param startTime - High-resolution timestamp when the task started
104
+ */
55
105
  private updateMetrics;
56
106
  print(): string;
107
+ /**
108
+ * Rebuild the visual progress bar string with pool stats (active, queued, mean time, calls/min).
109
+ */
57
110
  updatePrint(): Promise<void>;
58
111
  /**
59
- * Restituisce il numero di chiamate attualmente in coda
60
- * @returns {number} Il numero di chiamate in coda
112
+ * Returns the number of calls currently queued
113
+ * @returns The number of queued calls
61
114
  */
62
115
  queueLength(): number;
63
116
  /**
64
- * Aspetta che tutte le chiamate in coda siano completate
65
- * @param checkInterval Intervallo in millisecondi tra i controlli dello stato della coda (default: 1000ms)
66
- * @returns Promise che si risolve quando la coda è vuota e non ci sono chiamate attive
117
+ * Waits for all queued calls to complete
118
+ * @param checkInterval Milliseconds between queue status checks (default: 1000ms)
119
+ * @returns Promise that resolves when the queue is empty and no calls are active
67
120
  */
68
121
  finish(checkInterval?: number): Promise<void>;
122
+ /**
123
+ * Count HTTP calls made in the last 60 seconds (thread-safe).
124
+ *
125
+ * @returns Number of calls within the last minute
126
+ */
69
127
  getActualCallsPerMinute(): Promise<number>;
128
+ /**
129
+ * Return the cumulative number of calls made since pool creation.
130
+ *
131
+ * @returns Total call count
132
+ */
70
133
  getTotalCalls(): number;
134
+ /**
135
+ * Wait for all pending tasks to finish, then release all internal resources.
136
+ */
71
137
  destroy(): Promise<void>;
72
138
  }
73
139
  export {};
@@ -1,4 +1,4 @@
1
- import throttledQueue from "throttled-queue";
1
+ import { throttledQueue } from "throttled-queue";
2
2
  import { Console, COLORS } from "./Console.js";
3
3
  import { EventEmitter } from "events";
4
4
  import axios from "axios";
@@ -73,7 +73,7 @@ export class CallPool {
73
73
  this.concurrency = (this.config.minConcurrency + this.config.maxConcurrency) / 2;
74
74
  this.queue = [];
75
75
  this.activeCount = 0;
76
- this.limiter = throttledQueue(this.config.limitCall, this.config.limitInterval, true);
76
+ this.limiter = throttledQueue({ maxPerInterval: this.config.limitCall, interval: this.config.limitInterval, evenlySpaced: true });
77
77
  this.updatePrint();
78
78
  this.agent = new Agent({
79
79
  maxSockets: 100,
@@ -88,6 +88,12 @@ export class CallPool {
88
88
  this.httpAgent = new HttpsProxyAgent(proxyUrl);
89
89
  }
90
90
  }
91
+ /**
92
+ * Merge caller-supplied Axios config with proxy, agent, and header defaults.
93
+ *
94
+ * @param config - Optional Axios request overrides
95
+ * @returns Merged Axios configuration
96
+ */
91
97
  buildAxiosConfig(config) {
92
98
  return _.merge({
93
99
  method: "GET",
@@ -113,6 +119,9 @@ export class CallPool {
113
119
  },
114
120
  }, config);
115
121
  }
122
+ /**
123
+ * Record a call timestamp and prune entries older than one minute (thread-safe).
124
+ */
116
125
  async updateCallStack() {
117
126
  await this.callStackMutex.runExclusive(() => {
118
127
  this.totalCalls++;
@@ -122,6 +131,14 @@ export class CallPool {
122
131
  this.callStack = this.callStack.filter(timestamp => timestamp > oneMinuteAgo);
123
132
  });
124
133
  }
134
+ /**
135
+ * Execute a single task through the rate limiter with automatic retry on transient failures.
136
+ *
137
+ * @param call - Async factory to execute
138
+ * @param resolve - Promise resolve callback
139
+ * @param reject - Promise reject callback
140
+ * @param remainingAttempts - Number of retry attempts left
141
+ */
125
142
  executeLimited(call, resolve, reject, remainingAttempts = this.config.retry?.attempts) {
126
143
  const time = performance.now();
127
144
  this.activeCount++;
@@ -133,7 +150,7 @@ export class CallPool {
133
150
  }
134
151
  catch (error) {
135
152
  if (this.config.retry?.shouldRetry?.(error) && remainingAttempts > 0) {
136
- Console.log(`${this.config.name}: Rimetto in coda il tentativo. Tentativi rimasti: ${remainingAttempts - 1}`);
153
+ Console.warn("Retrying queued call", { pool: this.config.name, remainingAttempts: remainingAttempts - 1 });
137
154
  await sleep(this.config.retry.delayMs);
138
155
  this.executeLimited(call, resolve, reject, remainingAttempts - 1);
139
156
  }
@@ -148,9 +165,29 @@ export class CallPool {
148
165
  }
149
166
  });
150
167
  }
168
+ /**
169
+ * Perform an HTTP request immediately, bypassing the pool queue.
170
+ *
171
+ * @param url - Request URL
172
+ * @param config - Optional Axios request configuration
173
+ * @returns Axios response
174
+ */
151
175
  async directCall(url, config) {
152
- return axios(url, this.buildAxiosConfig(config));
176
+ try {
177
+ return await axios(url, this.buildAxiosConfig(config));
178
+ }
179
+ catch (error) {
180
+ Console.error("Direct call failed", { pool: this.config.name, url, error });
181
+ throw error;
182
+ }
153
183
  }
184
+ /**
185
+ * Enqueue an HTTP request to be executed when a concurrency slot is available.
186
+ *
187
+ * @param url - Request URL
188
+ * @param config - Optional Axios request configuration
189
+ * @returns Axios response once the request completes
190
+ */
154
191
  call(url, config) {
155
192
  return new Promise((resolve, reject) => {
156
193
  this.queue.push({
@@ -161,6 +198,11 @@ export class CallPool {
161
198
  this.schedule();
162
199
  });
163
200
  }
201
+ /**
202
+ * Pick a random modern browser User-Agent string for request rotation.
203
+ *
204
+ * @returns Random User-Agent string or null if none matches
205
+ */
164
206
  getRandomUserAgent() {
165
207
  const browsers = [
166
208
  { name: "Chrome", version: 109 },
@@ -171,6 +213,12 @@ export class CallPool {
171
213
  return browsers.some(b => b.name === ua.browserName && b.version <= parseInt(ua.browserVersion));
172
214
  });
173
215
  }
216
+ /**
217
+ * Add a custom async task to the pool queue and return its result when complete.
218
+ *
219
+ * @param call - Async factory function to enqueue
220
+ * @returns Resolved value from the call
221
+ */
174
222
  enqueue(call) {
175
223
  return new Promise((resolve, reject) => {
176
224
  this.queue.push({
@@ -181,6 +229,9 @@ export class CallPool {
181
229
  this.schedule();
182
230
  });
183
231
  }
232
+ /**
233
+ * Drain the queue by dispatching tasks up to the current adaptive concurrency limit.
234
+ */
184
235
  schedule() {
185
236
  if (this.isScheduling)
186
237
  return;
@@ -198,6 +249,11 @@ export class CallPool {
198
249
  this.isScheduling = false;
199
250
  }
200
251
  }
252
+ /**
253
+ * Adjust adaptive concurrency based on mean response time and update the progress display.
254
+ *
255
+ * @param startTime - High-resolution timestamp when the task started
256
+ */
201
257
  updateMetrics(startTime) {
202
258
  this.clock--;
203
259
  if (this.clock < 0) {
@@ -217,6 +273,9 @@ export class CallPool {
217
273
  print() {
218
274
  return this._print;
219
275
  }
276
+ /**
277
+ * Rebuild the visual progress bar string with pool stats (active, queued, mean time, calls/min).
278
+ */
220
279
  async updatePrint() {
221
280
  const textStart = `${Console.color(this.config.name.padEnd(16), COLORS.YELLOW)} [POOL][`;
222
281
  const callsPerMinute = await this.getActualCallsPerMinute();
@@ -232,31 +291,44 @@ export class CallPool {
232
291
  //Console.forceSummaryLinesRefresh();
233
292
  }
234
293
  /**
235
- * Restituisce il numero di chiamate attualmente in coda
236
- * @returns {number} Il numero di chiamate in coda
294
+ * Returns the number of calls currently queued
295
+ * @returns The number of queued calls
237
296
  */
238
297
  queueLength() {
239
298
  return this.queue.length;
240
299
  }
241
300
  /**
242
- * Aspetta che tutte le chiamate in coda siano completate
243
- * @param checkInterval Intervallo in millisecondi tra i controlli dello stato della coda (default: 1000ms)
244
- * @returns Promise che si risolve quando la coda è vuota e non ci sono chiamate attive
301
+ * Waits for all queued calls to complete
302
+ * @param checkInterval Milliseconds between queue status checks (default: 1000ms)
303
+ * @returns Promise that resolves when the queue is empty and no calls are active
245
304
  */
246
305
  async finish(checkInterval = 1000) {
247
306
  while (this.queue.length > 0 || this.activeCount > 0) {
248
307
  await sleep(checkInterval);
249
308
  }
250
309
  }
310
+ /**
311
+ * Count HTTP calls made in the last 60 seconds (thread-safe).
312
+ *
313
+ * @returns Number of calls within the last minute
314
+ */
251
315
  async getActualCallsPerMinute() {
252
316
  return await this.callStackMutex.runExclusive(() => {
253
317
  const oneMinuteAgo = Date.now() - this.MINUTE_IN_MS;
254
318
  return this.callStack.filter(timestamp => timestamp > oneMinuteAgo).length;
255
319
  });
256
320
  }
321
+ /**
322
+ * Return the cumulative number of calls made since pool creation.
323
+ *
324
+ * @returns Total call count
325
+ */
257
326
  getTotalCalls() {
258
327
  return this.totalCalls;
259
328
  }
329
+ /**
330
+ * Wait for all pending tasks to finish, then release all internal resources.
331
+ */
260
332
  async destroy() {
261
333
  await this.finish();
262
334
  this.queue = [];
@@ -264,6 +336,7 @@ export class CallPool {
264
336
  this.limiter = null;
265
337
  this.agent.destroy();
266
338
  Console.removeSummaryLine(this.config.name);
339
+ Console.debug("Pool destroyed", { pool: this.config.name, totalCalls: this.totalCalls });
267
340
  }
268
341
  }
269
342
  //# sourceMappingURL=CallPool.js.map
@@ -1 +1 @@
1
- {"version":3,"file":"CallPool.js","sourceRoot":"","sources":["../../src/CallPool.ts"],"names":[],"mappings":"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"}
1
+ {"version":3,"file":"CallPool.js","sourceRoot":"","sources":["../../src/CallPool.ts"],"names":[],"mappings":"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"}
@@ -20,15 +20,16 @@ export declare enum LOG_LEVEL {
20
20
  DEBUG = "debug",
21
21
  VERBOSE = "verbose"
22
22
  }
23
- interface LogOptions {
23
+ export type LogParams = Record<string, unknown>;
24
+ export interface LogOptions {
24
25
  level?: LOG_LEVEL;
25
26
  color?: COLORS;
26
27
  spinner?: boolean;
27
28
  prefix?: string;
28
- [key: string]: any;
29
29
  }
30
30
  interface LogHistoryEntry {
31
31
  message: string;
32
+ params?: LogParams;
32
33
  prefix?: string;
33
34
  color: COLORS;
34
35
  timestamp: Date;
@@ -65,56 +66,16 @@ export declare class Console implements LoggerService {
65
66
  * Costruttore pubblico per permettere l'istanziazione diretta.
66
67
  */
67
68
  constructor();
69
+ private static formatParamValue;
70
+ private static formatParams;
68
71
  private static getEffectiveLevel;
69
72
  private static shouldLog;
70
- /**
71
- * Helper method to convert string or LogOptions to LogOptions
72
- * @param options string | LogOptions
73
- * @returns LogOptions
74
- */
75
- private static normalizeOptions;
76
- /**
77
- * Scrittura generica su console
78
- * @param message string
79
- * @param logOptions LogOptions
80
- * @returns void
81
- */
82
- static log(message: string, logOptions?: LogOptions): void;
83
- /**
84
- * Scrittura di un errore
85
- * @param message string
86
- * @param logOptions LogOptions
87
- * @returns void
88
- */
89
- static error(message: string, logOptions?: LogOptions): void;
90
- /**
91
- * Scrittura di un avviso
92
- * @param message string
93
- * @param logOptions LogOptions
94
- * @returns void
95
- */
96
- static warn(message: string, logOptions?: LogOptions): void;
97
- /**
98
- * Scrittura di un successo
99
- * @param message string
100
- * @param logOptions LogOptions
101
- * @returns void
102
- */
103
- static success(message: string, logOptions?: LogOptions): void;
104
- /**
105
- * Scrittura di un debug
106
- * @param message string
107
- * @param logOptions LogOptions
108
- * @returns void
109
- */
110
- static debug(message: string, logOptions?: LogOptions): void;
111
- /**
112
- * Scrittura di un verbose
113
- * @param message string
114
- * @param logOptions LogOptions
115
- * @returns void
116
- */
117
- static verbose(message: string, logOptions?: LogOptions): void;
73
+ static log(message: string, params?: LogParams, options?: LogOptions): void;
74
+ static error(message: string, params?: LogParams, options?: LogOptions): void;
75
+ static warn(message: string, params?: LogParams, options?: LogOptions): void;
76
+ static success(message: string, params?: LogParams, options?: LogOptions): void;
77
+ static debug(message: string, params?: LogParams, options?: LogOptions): void;
78
+ static verbose(message: string, params?: LogParams, options?: LogOptions): void;
118
79
  /**
119
80
  * Aggiunge una riga di riepilogo (summary) in fondo allo schermo
120
81
  * @param fn funzione che restituisce la stringa di testo
@@ -150,14 +111,19 @@ export declare class Console implements LoggerService {
150
111
  * @returns string
151
112
  */
152
113
  static color(str: string, color: COLORS): string;
153
- error(message: any, logOptions?: LogOptions | string): void;
154
- warn(message: any, logOptions?: LogOptions | string): void;
155
- log(message: any, logOptions?: LogOptions | string): void;
156
- debug(message: any, logOptions?: LogOptions | string): void;
157
- verbose(message: any, logOptions?: LogOptions | string): void;
114
+ error(message: any, ...args: any[]): void;
115
+ warn(message: any, ...args: any[]): void;
116
+ log(message: any, ...args: any[]): void;
117
+ debug(message: any, ...args: any[]): void;
118
+ verbose(message: any, ...args: any[]): void;
158
119
  appendSummaryLine(fn: () => string, color?: COLORS, id?: string): void;
159
120
  removeSummaryLine(id: string): void;
160
121
  clearSummaryLines(): void;
122
+ /**
123
+ * Adapter for NestJS LoggerService rest args.
124
+ * Handles: (params, options), (params), (contextString), ()
125
+ */
126
+ private extractArgs;
161
127
  /**
162
128
  * Si assicura che lo schermo sia stato creato (lazy init).
163
129
  * @returns void
@@ -165,9 +131,6 @@ export declare class Console implements LoggerService {
165
131
  private static ensureInitialized;
166
132
  /**
167
133
  * Logica comune per stampare messaggi, con o senza spinner.
168
- * @param message string
169
- * @param logOptions LogOptions
170
- * @returns void
171
134
  */
172
135
  private static write;
173
136
  /**