@rudderstack/integrations-lib 0.2.48 → 0.2.50
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/build/cluster/manager.d.ts.map +1 -1
- package/build/cluster/manager.js +9 -5
- package/build/index.d.ts +1 -0
- package/build/index.d.ts.map +1 -1
- package/build/index.js +2 -1
- package/build/mock_utils/axios_client_mock_util.d.ts +5 -0
- package/build/mock_utils/axios_client_mock_util.d.ts.map +1 -0
- package/build/mock_utils/axios_client_mock_util.js +13 -0
- package/build/mock_utils/index.d.ts +2 -0
- package/build/mock_utils/index.d.ts.map +1 -0
- package/build/mock_utils/index.js +18 -0
- package/build/network/clients/axios_client.d.ts +6 -5
- package/build/network/clients/axios_client.d.ts.map +1 -1
- package/build/network/clients/axios_client.js +66 -40
- package/build/network/clients/types.d.ts +65 -5
- package/build/network/clients/types.d.ts.map +1 -1
- package/build/network/clients/types.js +1 -1
- package/build/network/factory.d.ts +12 -2
- package/build/network/factory.d.ts.map +1 -1
- package/build/network/factory.js +24 -1
- package/build/sdks/common/base-sdk.d.ts +64 -0
- package/build/sdks/common/base-sdk.d.ts.map +1 -0
- package/build/sdks/common/base-sdk.js +182 -0
- package/build/sdks/common/index.d.ts +3 -0
- package/build/sdks/common/index.d.ts.map +1 -0
- package/build/sdks/common/index.js +7 -0
- package/build/sdks/common/types.d.ts +13 -0
- package/build/sdks/common/types.d.ts.map +1 -0
- package/build/sdks/common/types.js +3 -0
- package/build/sdks/criteoAudience/criteoAudience.d.ts +11 -39
- package/build/sdks/criteoAudience/criteoAudience.d.ts.map +1 -1
- package/build/sdks/criteoAudience/criteoAudience.js +33 -69
- package/build/sdks/criteoAudience/types.d.ts +3 -0
- package/build/sdks/criteoAudience/types.d.ts.map +1 -1
- package/build/sdks/criteoAudience/types.js +1 -1
- package/build/sdks/customerio_audience/index.d.ts +11 -15
- package/build/sdks/customerio_audience/index.d.ts.map +1 -1
- package/build/sdks/customerio_audience/index.js +23 -34
- package/build/sdks/customerio_audience/type.d.ts +3 -0
- package/build/sdks/customerio_audience/type.d.ts.map +1 -1
- package/build/sdks/customerio_audience/type.js +1 -1
- package/build/sdks/googleAdsRestAPI/googleAds.d.ts +16 -17
- package/build/sdks/googleAdsRestAPI/googleAds.d.ts.map +1 -1
- package/build/sdks/googleAdsRestAPI/googleAds.js +44 -37
- package/build/sdks/googleAdsRestAPI/types.d.ts +3 -0
- package/build/sdks/googleAdsRestAPI/types.d.ts.map +1 -1
- package/build/sdks/googleAdsRestAPI/types.js +1 -1
- package/build/sdks/index.d.ts +1 -0
- package/build/sdks/index.d.ts.map +1 -1
- package/build/sdks/index.js +5 -1
- package/build/sdks/sfmc/index.d.ts +1 -1
- package/build/sdks/sfmc/index.d.ts.map +1 -1
- package/build/sdks/sfmc/index.js +4 -3
- package/build/sdks/zoho/types.d.ts +3 -0
- package/build/sdks/zoho/types.d.ts.map +1 -1
- package/build/sdks/zoho/types.js +1 -1
- package/build/sdks/zoho/zoho.d.ts +13 -17
- package/build/sdks/zoho/zoho.d.ts.map +1 -1
- package/build/sdks/zoho/zoho.js +44 -51
- package/mock/axios_client_mock_util.d.ts +2 -0
- package/mock/axios_client_mock_util.d.ts.map +1 -1
- package/mock/axios_client_mock_util.js +6 -3
- package/package.json +1 -1
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"manager.d.ts","sourceRoot":"","sources":["../../src/cluster/manager.ts"],"names":[],"mappings":"AAGA,OAAO,EAAE,YAAY,EAAE,MAAM,QAAQ,CAAC;AAEtC,OAAO,EACL,qBAAqB,EACrB,oBAAoB,EAMrB,MAAM,SAAS,CAAC;AAGjB;;;;;;;;;GASG;AACH,qBAAa,cAAe,SAAQ,YAAY;IAC9C,OAAO,CAAC,QAAQ,CAAC,OAAO,CAAkC;IAE1D,OAAO,CAAC,QAAQ,CAAC,OAAO,CAAkC;IAE1D,OAAO,CAAC,OAAO,CAAS;IAExB,OAAO,CAAC,cAAc,CAAS;IAE/B,OAAO,CAAC,eAAe,CAA8B;IAErD,OAAO,CAAC,mBAAmB,CAA+B;IAE1D,OAAO,CAAC,cAAc,CAAyC;gBAEnD,OAAO,GAAE,qBAA0B;IAM/C;;;;OAIG;IACH,OAAO,CAAC,UAAU;IAUlB;;;;OAIG;IACU,KAAK,IAAI,OAAO,CAAC,IAAI,CAAC;IASnC;;OAEG;IACI,QAAQ,CAAC,MAAM,CAAC,EAAE,MAAM,GAAG,OAAO,CAAC,IAAI,CAAC;IAqB/C;;OAEG;IACH,OAAO,CAAC,mBAAmB;IAU3B;;OAEG;IACH,OAAO,CAAC,oBAAoB;IAO5B;;OAEG;YACW,YAAY;IAqB1B;;OAEG;YACW,WAAW;IAUzB;;OAEG;IACH,OAAO,CAAC,yBAAyB;IAWjC;;OAEG;IACH,OAAO,CAAC,0BAA0B;IAkBlC;;OAEG;IACH,OAAO,CAAC,WAAW;IAuBnB;;OAEG;IACH,OAAO,CAAC,mBAAmB;IAqB3B;;OAEG;IACH,OAAO,CAAC,gBAAgB;IAWxB;;OAEG;IACH,OAAO,CAAC,qBAAqB;IAM7B;;OAEG;IACH,OAAO,CAAC,oBAAoB;IAO5B;;OAEG;IACH,OAAO,CAAC,kBAAkB;IAkB1B;;OAEG;IACH,OAAO,CAAC,gBAAgB;IAkBxB;;OAEG;IACH,OAAO,CAAC,iBAAiB;IAiCzB;;OAEG;IACH,OAAO,CAAC,gBAAgB;
|
|
1
|
+
{"version":3,"file":"manager.d.ts","sourceRoot":"","sources":["../../src/cluster/manager.ts"],"names":[],"mappings":"AAGA,OAAO,EAAE,YAAY,EAAE,MAAM,QAAQ,CAAC;AAEtC,OAAO,EACL,qBAAqB,EACrB,oBAAoB,EAMrB,MAAM,SAAS,CAAC;AAGjB;;;;;;;;;GASG;AACH,qBAAa,cAAe,SAAQ,YAAY;IAC9C,OAAO,CAAC,QAAQ,CAAC,OAAO,CAAkC;IAE1D,OAAO,CAAC,QAAQ,CAAC,OAAO,CAAkC;IAE1D,OAAO,CAAC,OAAO,CAAS;IAExB,OAAO,CAAC,cAAc,CAAS;IAE/B,OAAO,CAAC,eAAe,CAA8B;IAErD,OAAO,CAAC,mBAAmB,CAA+B;IAE1D,OAAO,CAAC,cAAc,CAAyC;gBAEnD,OAAO,GAAE,qBAA0B;IAM/C;;;;OAIG;IACH,OAAO,CAAC,UAAU;IAUlB;;;;OAIG;IACU,KAAK,IAAI,OAAO,CAAC,IAAI,CAAC;IASnC;;OAEG;IACI,QAAQ,CAAC,MAAM,CAAC,EAAE,MAAM,GAAG,OAAO,CAAC,IAAI,CAAC;IAqB/C;;OAEG;IACH,OAAO,CAAC,mBAAmB;IAU3B;;OAEG;IACH,OAAO,CAAC,oBAAoB;IAO5B;;OAEG;YACW,YAAY;IAqB1B;;OAEG;YACW,WAAW;IAUzB;;OAEG;IACH,OAAO,CAAC,yBAAyB;IAWjC;;OAEG;IACH,OAAO,CAAC,0BAA0B;IAkBlC;;OAEG;IACH,OAAO,CAAC,WAAW;IAuBnB;;OAEG;IACH,OAAO,CAAC,mBAAmB;IAqB3B;;OAEG;IACH,OAAO,CAAC,gBAAgB;IAWxB;;OAEG;IACH,OAAO,CAAC,qBAAqB;IAM7B;;OAEG;IACH,OAAO,CAAC,oBAAoB;IAO5B;;OAEG;IACH,OAAO,CAAC,kBAAkB;IAkB1B;;OAEG;IACH,OAAO,CAAC,gBAAgB;IAkBxB;;OAEG;IACH,OAAO,CAAC,iBAAiB;IAiCzB;;OAEG;IACH,OAAO,CAAC,gBAAgB;IA4BxB,OAAO,CAAC,WAAW;IAInB,OAAO,CAAC,kBAAkB;IAM1B;;OAEG;IACH,OAAO,CAAC,0BAA0B;IAsBlC;;OAEG;YACW,eAAe;IA2B7B;;OAEG;YACW,kBAAkB;IAwChC;;OAEG;YACW,uBAAuB;IAOrC;;OAEG;IACH,OAAO,CAAC,mBAAmB;IAU3B;;OAEG;YACW,cAAc;IAwB5B;;OAEG;IACI,cAAc,IAAI,MAAM;IAI/B;;OAEG;IACI,aAAa,IAAI,KAAK,CAAC;QAAE,EAAE,EAAE,MAAM,CAAC;QAAC,GAAG,EAAE,MAAM,CAAC;QAAC,YAAY,EAAE,MAAM,CAAA;KAAE,CAAC;IAQhF;;OAEG;IACI,SAAS,IAAI,OAAO;IAI3B;;OAEG;IACI,UAAU,IAAI,OAAO;CAG7B;AAGD,MAAM,WAAW,qBAAqB;IACpC,EAAE,CAAC,CAAC,SAAS,MAAM,oBAAoB,EAAE,KAAK,EAAE,CAAC,EAAE,QAAQ,EAAE,oBAAoB,CAAC,CAAC,CAAC,GAAG,IAAI,CAAC;IAC5F,IAAI,CAAC,CAAC,SAAS,MAAM,oBAAoB,EACvC,KAAK,EAAE,CAAC,EACR,GAAG,IAAI,EAAE,UAAU,CAAC,oBAAoB,CAAC,CAAC,CAAC,CAAC,GAC3C,OAAO,CAAC;CACZ"}
|
package/build/cluster/manager.js
CHANGED
|
@@ -323,16 +323,20 @@ class ClusterManager extends events_1.EventEmitter {
|
|
|
323
323
|
* Handles worker exit events
|
|
324
324
|
*/
|
|
325
325
|
handleWorkerExit(worker, code, signal) {
|
|
326
|
-
|
|
326
|
+
const workerId = this.getWorkerId(worker);
|
|
327
327
|
this.emit('worker:died', worker, code, signal);
|
|
328
328
|
const workerState = this.workers.get(worker.id);
|
|
329
|
-
if (!workerState)
|
|
329
|
+
if (!workerState) {
|
|
330
|
+
logger.warn(`Unknown worker ${workerId} (pid: ${worker.process.pid}) exited with code ${code} and signal ${signal}`);
|
|
330
331
|
return;
|
|
332
|
+
}
|
|
331
333
|
this.workers.delete(worker.id);
|
|
332
334
|
// If we're shutting down or worker was killed intentionally, don't restart
|
|
333
335
|
if (this.isShuttingDown || workerState.isShuttingDown) {
|
|
336
|
+
logger.info(`Worker ${workerId} (pid: ${worker.process.pid}) exited with code ${code} and signal ${signal}`);
|
|
334
337
|
return;
|
|
335
338
|
}
|
|
339
|
+
logger.error(`Worker ${workerId} (pid: ${worker.process.pid}) exited unexpectedly with code ${code} and signal ${signal}`);
|
|
336
340
|
// Handle unexpected exit
|
|
337
341
|
this.handleUnexpectedWorkerExit(workerState);
|
|
338
342
|
}
|
|
@@ -367,7 +371,7 @@ class ClusterManager extends events_1.EventEmitter {
|
|
|
367
371
|
* Shuts down the primary process
|
|
368
372
|
*/
|
|
369
373
|
async shutdownPrimary(signal) {
|
|
370
|
-
logger.
|
|
374
|
+
logger.warn(`Primary process (pid: ${process.pid}) shutting down (signal: ${signal ?? 'manual'})`);
|
|
371
375
|
this.stopHealthMonitoring();
|
|
372
376
|
this.removeSignalHandlers();
|
|
373
377
|
// Shutdown all workers
|
|
@@ -435,7 +439,7 @@ class ClusterManager extends events_1.EventEmitter {
|
|
|
435
439
|
* Shuts down a worker process
|
|
436
440
|
*/
|
|
437
441
|
async shutdownWorker(signal) {
|
|
438
|
-
logger.
|
|
442
|
+
logger.warn(`Worker ${this.getCurrentWorkerId()} (pid: ${process.pid}) shutting down (signal: ${signal ?? 'manual'})`);
|
|
439
443
|
this.removeSignalHandlers();
|
|
440
444
|
// Execute worker shutdown function
|
|
441
445
|
await (0, utils_1.safeExecute)(() => (0, utils_1.timeout)(this.options.workerShutdownFn(signal), this.options.shutdownTimeout, 'worker shutdown timeout'), `Error in worker ${this.getCurrentWorkerId()} (pid: ${process.pid}) shutdown function`);
|
|
@@ -472,4 +476,4 @@ class ClusterManager extends events_1.EventEmitter {
|
|
|
472
476
|
}
|
|
473
477
|
}
|
|
474
478
|
exports.ClusterManager = ClusterManager;
|
|
475
|
-
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"manager.js","sourceRoot":"","sources":["../../src/cluster/manager.ts"],"names":[],"mappings":"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","sourcesContent":["/* eslint-disable class-methods-use-this */\n/* eslint-disable no-param-reassign */\nimport { Worker } from 'cluster';\nimport { EventEmitter } from 'events';\nimport * as logger from '../logger';\nimport {\n  ClusterManagerOptions,\n  ClusterManagerEvents,\n  WorkerState,\n  IPCMessage,\n  PingMessage,\n  PongMessage,\n  ShutdownMessage,\n} from './types';\nimport { delay, timeout, safeExecute, validateAndDefaultOptions } from './utils';\n\n/**\n * ClusterManager - A cluster lifecycle management system\n *\n * The manager supports the following features:\n * - Graceful shutdown with configurable timeout\n * - Worker health monitoring with ping/pong mechanism\n * - Automatic worker restart with configurable limits\n * - Signal handling for shutdown triggers\n * - Flexible primary and worker function handlers\n */\nexport class ClusterManager extends EventEmitter {\n  private readonly options: Required<ClusterManagerOptions>;\n\n  private readonly workers = new Map<number, WorkerState>();\n\n  private started = false;\n\n  private isShuttingDown = false;\n\n  private shutdownPromise: Promise<void> | null = null;\n\n  private healthCheckInterval: NodeJS.Timeout | null = null;\n\n  private signalHandlers = new Map<NodeJS.Signals, () => void>();\n\n  constructor(options: ClusterManagerOptions = {}) {\n    super();\n    this.options = validateAndDefaultOptions(options);\n    this.initialize();\n  }\n\n  /**\n   * Initialize the cluster manager with primary process configuration\n   *\n   * @see {@link https://nodejs.org/docs/latest/api/cluster.html#clustersetupprimaryoptions Node.js cluster.setupPrimary()}\n   */\n  private initialize(): void {\n    // Only call setupPrimary in the primary process\n    if (this.options.cluster.isPrimary) {\n      this.options.cluster.setupPrimary({\n        serialization: this.options.serialization,\n      });\n    }\n    this.setupSignalHandlers();\n  }\n\n  /**\n   * Starts the cluster manager\n   * In primary process: starts workers and health monitoring\n   * In worker process: executes worker function\n   */\n  public async start(): Promise<void> {\n    if (this.options.cluster.isPrimary) {\n      await this.startPrimary();\n    } else {\n      await this.startWorker();\n    }\n    this.started = true;\n  }\n\n  /**\n   * Initiates graceful shutdown of the cluster\n   */\n  public shutdown(signal?: string): Promise<void> {\n    if (!this.started) {\n      return Promise.resolve();\n    }\n\n    if (this.shutdownPromise) {\n      return this.shutdownPromise;\n    }\n\n    this.isShuttingDown = true;\n    this.emit('shutdown:started', signal);\n\n    if (this.options.cluster.isPrimary) {\n      this.shutdownPromise = this.shutdownPrimary(signal);\n    } else {\n      this.shutdownPromise = this.shutdownWorker(signal);\n    }\n\n    return this.shutdownPromise;\n  }\n\n  /**\n   * Sets up signal handlers for graceful shutdown\n   */\n  private setupSignalHandlers(): void {\n    this.options.shutdownSignals.forEach((signal) => {\n      const handler = () => {\n        this.shutdown(signal);\n      };\n      this.signalHandlers.set(signal, handler);\n      process.on(signal, handler);\n    });\n  }\n\n  /**\n   * Removes signal handlers\n   */\n  private removeSignalHandlers(): void {\n    Array.from(this.signalHandlers.entries()).forEach(([signal, handler]) => {\n      process.removeListener(signal, handler);\n    });\n    this.signalHandlers.clear();\n  }\n\n  /**\n   * Starts the primary process\n   */\n  private async startPrimary(): Promise<void> {\n    logger.info(\n      `Primary process (pid: ${process.pid}) starting with ${this.options.numWorkers} workers`,\n    );\n\n    // Execute primary initialization function, any error will stop the cluster from starting\n    await this.options.primaryFn();\n\n    // Set up cluster event handlers\n    this.setupClusterEventHandlers();\n\n    // Spawn initial workers\n    for (let i = 0; i < this.options.numWorkers; i += 1) {\n      const workerId = i + 1; // Worker IDs start from 1\n      this.spawnWorker(workerId);\n    }\n\n    // Start health monitoring\n    this.startHealthMonitoring();\n  }\n\n  /**\n   * Starts a worker process\n   */\n  private async startWorker(): Promise<void> {\n    logger.info(`Worker ${this.getCurrentWorkerId()} (pid: ${process.pid}) starting`);\n\n    // Set up IPC message handlers\n    this.setupWorkerMessageHandlers();\n\n    // Execute worker initialization function, any error will be propagated\n    await this.options.workerFn();\n  }\n\n  /**\n   * Sets up cluster event handlers for the primary process\n   */\n  private setupClusterEventHandlers(): void {\n    this.options.cluster.on('exit', (worker: Worker, code: number, signal: string) => {\n      this.handleWorkerExit(worker, code, signal);\n    });\n\n    this.options.cluster.on('online', (worker: Worker) => {\n      logger.info(`Worker ${this.getWorkerId(worker)} (pid: ${worker.process.pid}) is online`);\n      this.emit('worker:started', worker);\n    });\n  }\n\n  /**\n   * Sets up IPC message handlers for worker processes\n   */\n  private setupWorkerMessageHandlers(): void {\n    process.on('message', (message: IPCMessage) => {\n      switch (message.type) {\n        case 'ping':\n          this.handleWorkerPing(message);\n          break;\n        case 'shutdown':\n          this.shutdown(message.signal);\n          break;\n        default:\n          if (!message.type.includes('Metrics')) {\n            logger.warn(`ignoring unknown message type in worker ${process.pid}: ${message.type}`);\n          }\n          break;\n      }\n    });\n  }\n\n  /**\n   * Spawns a new worker and sets up its state\n   */\n  private spawnWorker(id: number): Worker {\n    const worker = this.options.cluster.fork({\n      WORKER_ID: id,\n    });\n    const workerState: WorkerState = {\n      id,\n      worker,\n      restartCount: 0,\n      lastPing: Date.now(),\n      pendingPing: false,\n      isShuttingDown: false,\n    };\n\n    this.workers.set(worker.id, workerState);\n\n    // Set up worker message handler\n    worker.on('message', (message: IPCMessage) => {\n      this.handleWorkerMessage(worker, message);\n    });\n\n    return worker;\n  }\n\n  /**\n   * Handles messages from workers\n   */\n  private handleWorkerMessage(worker: Worker, message: IPCMessage): void {\n    const workerState = this.workers.get(worker.id);\n    if (!workerState) return;\n\n    switch (message.type) {\n      case 'pong':\n        workerState.lastPing = Date.now();\n        workerState.pendingPing = false;\n        break;\n      default:\n        if (!message.type.includes('Metrics')) {\n          logger.warn(\n            `Received unknown message type from worker ${this.getWorkerId(worker)} (pid: ${\n              worker.process.pid\n            }): ${message.type}`,\n          );\n        }\n        break;\n    }\n  }\n\n  /**\n   * Handles ping messages in worker processes\n   */\n  private handleWorkerPing(message: PingMessage): void {\n    const pongMessage: PongMessage = {\n      type: 'pong',\n      timestamp: message.timestamp,\n    };\n\n    if (process.send) {\n      process.send(pongMessage);\n    }\n  }\n\n  /**\n   * Starts health monitoring for all workers\n   */\n  private startHealthMonitoring(): void {\n    this.healthCheckInterval = setInterval(() => {\n      this.performHealthCheck();\n    }, this.options.pingFrequency);\n  }\n\n  /**\n   * Stops health monitoring\n   */\n  private stopHealthMonitoring(): void {\n    if (this.healthCheckInterval) {\n      clearInterval(this.healthCheckInterval);\n      this.healthCheckInterval = null;\n    }\n  }\n\n  /**\n   * Performs health check on all workers\n   */\n  private performHealthCheck(): void {\n    if (this.isShuttingDown) return;\n\n    Array.from(this.workers.values())\n      .filter((workerState) => !workerState.isShuttingDown)\n      .forEach((workerState) => {\n        const timeSinceLastPing = Date.now() - workerState.lastPing;\n\n        if (workerState.pendingPing && timeSinceLastPing > this.options.pingTimeout) {\n          // Worker is stuck, handle it\n          this.handleStuckWorker(workerState);\n        } else if (!workerState.pendingPing) {\n          // Send ping to worker\n          this.sendPingToWorker(workerState);\n        }\n      });\n  }\n\n  /**\n   * Sends a ping message to a worker\n   */\n  private sendPingToWorker(workerState: WorkerState): void {\n    const pingMessage: PingMessage = {\n      type: 'ping',\n      timestamp: Date.now(),\n    };\n\n    workerState.pendingPing = true;\n    try {\n      workerState.worker.send(pingMessage);\n    } catch (error) {\n      logger.error(\n        `Failed to send ping to worker ${workerState.id} (pid: ${\n          workerState.worker.process.pid\n        }): ${error instanceof Error ? error.message : String(error)}`,\n      );\n    }\n  }\n\n  /**\n   * Handles a stuck worker\n   */\n  private handleStuckWorker(workerState: WorkerState): void {\n    logger.error(\n      `Worker ${workerState.id} (pid: ${workerState.worker.process.pid}) is stuck, killing it`,\n    );\n    this.emit('worker:stuck', workerState.worker);\n\n    // Remove worker state\n    this.workers.delete(workerState.worker.id);\n\n    // Kill the worker\n    workerState.worker.kill('SIGKILL');\n\n    // Determine if we should spawn a replacement\n    const shouldSpawn = this.options.stuckWorkerRespawnFunc(workerState.worker);\n\n    if (shouldSpawn && !this.isShuttingDown) {\n      logger.info(\n        `Spawning replacement worker for stuck worker ${workerState.id} (pid: ${workerState.worker.process.pid})`,\n      );\n      const { restartCount } = workerState; // Preserve restart count\n      const newWorker = this.spawnWorker(workerState.id);\n      const newWorkerState = this.workers.get(newWorker.id);\n      if (newWorkerState) {\n        newWorkerState.restartCount = restartCount;\n      }\n    } else {\n      logger.error(\n        `Triggering cluster shutdown due to stuck worker ${workerState.id} (pid: ${workerState.worker.process.pid})`,\n      );\n      this.shutdown('STUCK_WORKER');\n    }\n  }\n\n  /**\n   * Handles worker exit events\n   */\n  private handleWorkerExit(worker: Worker, code: number | null, signal: string | null): void {\n    logger.info(\n      `Worker ${this.getWorkerId(worker)} (pid: ${\n        worker.process.pid\n      }) died with code ${code} and signal ${signal}`,\n    );\n    this.emit('worker:died', worker, code, signal);\n\n    const workerState = this.workers.get(worker.id);\n    if (!workerState) return;\n\n    this.workers.delete(worker.id);\n\n    // If we're shutting down or worker was killed intentionally, don't restart\n    if (this.isShuttingDown || workerState.isShuttingDown) {\n      return;\n    }\n\n    // Handle unexpected exit\n    this.handleUnexpectedWorkerExit(workerState);\n  }\n\n  private getWorkerId(worker: Worker): number {\n    return this.workers.get(worker.id)?.id ?? worker.id;\n  }\n\n  private getCurrentWorkerId(): number {\n    const envWorkerId =\n      process.env.WORKER_ID !== undefined ? Number(process.env.WORKER_ID) : undefined;\n    return envWorkerId ?? this.options.cluster.worker?.id ?? -1;\n  }\n\n  /**\n   * Handles unexpected worker exits with restart logic\n   */\n  private handleUnexpectedWorkerExit(workerState: WorkerState): void {\n    const restartCount = workerState.restartCount + 1;\n\n    if (restartCount <= this.options.restartMaxTimes) {\n      logger.error(\n        `Restarting worker ${workerState.id} (pid: ${workerState.worker.process.pid}) (attempt ${restartCount}/${this.options.restartMaxTimes})`,\n      );\n      const newWorker = this.spawnWorker(workerState.id);\n      const newWorkerState = this.workers.get(newWorker.id);\n      if (newWorkerState) {\n        newWorkerState.restartCount = restartCount;\n      }\n      this.emit('worker:restarted', newWorker, workerState.restartCount);\n    } else {\n      logger.error(\n        `Restart limit (${this.options.restartMaxTimes}) exceeded for worker ${workerState.id} (pid: ${workerState.worker.process.pid}), shutting down cluster`,\n      );\n      this.emit('worker:restart-limit-exceeded', workerState.worker, workerState.restartCount);\n      this.shutdown('RESTART_LIMIT_EXCEEDED');\n    }\n  }\n\n  /**\n   * Shuts down the primary process\n   */\n  private async shutdownPrimary(signal?: string): Promise<void> {\n    logger.info(\n      `Primary process (pid: ${process.pid}) shutting down (signal: ${signal ?? 'manual'})`,\n    );\n\n    this.stopHealthMonitoring();\n    this.removeSignalHandlers();\n\n    // Shutdown all workers\n    await this.shutdownAllWorkers(signal);\n\n    // Execute primary shutdown function\n    await safeExecute(\n      () =>\n        timeout(\n          this.options.primaryShutdownFn(signal),\n          this.options.shutdownTimeout,\n          'primary shutdown timeout',\n        ),\n      'Error in primary shutdown function',\n    );\n\n    logger.info(`Primary process (pid: ${process.pid}) shutdown completed`);\n    this.emit('shutdown:completed');\n    process.exit(0);\n  }\n\n  /**\n   * Shuts down all workers gracefully\n   */\n  private async shutdownAllWorkers(signal?: string): Promise<void> {\n    if (this.workers.size === 0) return;\n\n    logger.info(`Shutting down ${this.workers.size} workers...`);\n\n    // Mark all workers as shutting down and send shutdown message\n    Array.from(this.workers.values()).forEach((workerState) => {\n      workerState.isShuttingDown = true;\n      // Only send shutdown message if worker is still connected\n      if (!workerState.worker.isDead() && workerState.worker.process.connected) {\n        const shutdownMessage: ShutdownMessage = {\n          type: 'shutdown',\n          signal,\n        };\n        try {\n          workerState.worker.send(shutdownMessage);\n        } catch (error) {\n          // Worker IPC channel is already closed, which is fine\n          logger.warn(\n            `Failed to send shutdown message to worker ${workerState.id} (pid: ${\n              workerState.worker.process.pid\n            }): ${error instanceof Error ? error.message : String(error)}`,\n          );\n        }\n      }\n    });\n\n    // Wait for workers to exit gracefully or timeout\n    try {\n      await timeout(\n        this.waitForAllWorkersToExit(),\n        this.options.shutdownTimeout,\n        'Worker shutdown timeout',\n      );\n    } catch (error) {\n      logger.error('Graceful shutdown for workers timed out, forcing shutdown');\n      this.forceKillAllWorkers();\n    }\n  }\n\n  /**\n   * Waits for all workers to exit\n   */\n  private async waitForAllWorkersToExit(): Promise<void> {\n    while (this.workers.size > 0) {\n      // eslint-disable-next-line no-await-in-loop\n      await delay(100);\n    }\n  }\n\n  /**\n   * Force kills all remaining workers\n   */\n  private forceKillAllWorkers(): void {\n    Array.from(this.workers.values()).forEach((workerState) => {\n      logger.error(\n        `Force killing worker ${workerState.id} (pid: ${workerState.worker.process.pid})`,\n      );\n      workerState.worker.kill('SIGKILL');\n    });\n    this.workers.clear();\n  }\n\n  /**\n   * Shuts down a worker process\n   */\n  private async shutdownWorker(signal?: string): Promise<void> {\n    logger.info(\n      `Worker ${this.getCurrentWorkerId()} (pid: ${process.pid}) shutting down (signal: ${\n        signal ?? 'manual'\n      })`,\n    );\n\n    this.removeSignalHandlers();\n\n    // Execute worker shutdown function\n    await safeExecute(\n      () =>\n        timeout(\n          this.options.workerShutdownFn(signal),\n          this.options.shutdownTimeout,\n          'worker shutdown timeout',\n        ),\n      `Error in worker ${this.getCurrentWorkerId()} (pid: ${process.pid}) shutdown function`,\n    );\n\n    logger.info(`Worker ${this.getCurrentWorkerId()} (pid: ${process.pid}) shutdown completed`);\n    process.exit(0);\n  }\n\n  /**\n   * Gets the current number of active workers\n   */\n  public getWorkerCount(): number {\n    return this.workers.size;\n  }\n\n  /**\n   * Gets information about all workers\n   */\n  public getWorkerInfo(): Array<{ id: number; pid: number; restartCount: number }> {\n    return Array.from(this.workers.values()).map((state) => ({\n      id: state.id,\n      pid: state.worker.process.pid ?? -1,\n      restartCount: state.restartCount,\n    }));\n  }\n\n  /**\n   * Checks if the cluster is currently started\n   */\n  public isStarted(): boolean {\n    return this.started;\n  }\n\n  /**\n   * Checks if the cluster is currently shutting down\n   */\n  public isShutdown(): boolean {\n    return this.isShuttingDown;\n  }\n}\n\n// Type-safe event emitter interface\nexport interface ClusterManagerEmitter {\n  on<K extends keyof ClusterManagerEvents>(event: K, listener: ClusterManagerEvents[K]): this;\n  emit<K extends keyof ClusterManagerEvents>(\n    event: K,\n    ...args: Parameters<ClusterManagerEvents[K]>\n  ): boolean;\n}\n"]}
|
|
479
|
+
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"manager.js","sourceRoot":"","sources":["../../src/cluster/manager.ts"],"names":[],"mappings":"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","sourcesContent":["/* eslint-disable class-methods-use-this */\n/* eslint-disable no-param-reassign */\nimport { Worker } from 'cluster';\nimport { EventEmitter } from 'events';\nimport * as logger from '../logger';\nimport {\n  ClusterManagerOptions,\n  ClusterManagerEvents,\n  WorkerState,\n  IPCMessage,\n  PingMessage,\n  PongMessage,\n  ShutdownMessage,\n} from './types';\nimport { delay, timeout, safeExecute, validateAndDefaultOptions } from './utils';\n\n/**\n * ClusterManager - A cluster lifecycle management system\n *\n * The manager supports the following features:\n * - Graceful shutdown with configurable timeout\n * - Worker health monitoring with ping/pong mechanism\n * - Automatic worker restart with configurable limits\n * - Signal handling for shutdown triggers\n * - Flexible primary and worker function handlers\n */\nexport class ClusterManager extends EventEmitter {\n  private readonly options: Required<ClusterManagerOptions>;\n\n  private readonly workers = new Map<number, WorkerState>();\n\n  private started = false;\n\n  private isShuttingDown = false;\n\n  private shutdownPromise: Promise<void> | null = null;\n\n  private healthCheckInterval: NodeJS.Timeout | null = null;\n\n  private signalHandlers = new Map<NodeJS.Signals, () => void>();\n\n  constructor(options: ClusterManagerOptions = {}) {\n    super();\n    this.options = validateAndDefaultOptions(options);\n    this.initialize();\n  }\n\n  /**\n   * Initialize the cluster manager with primary process configuration\n   *\n   * @see {@link https://nodejs.org/docs/latest/api/cluster.html#clustersetupprimaryoptions Node.js cluster.setupPrimary()}\n   */\n  private initialize(): void {\n    // Only call setupPrimary in the primary process\n    if (this.options.cluster.isPrimary) {\n      this.options.cluster.setupPrimary({\n        serialization: this.options.serialization,\n      });\n    }\n    this.setupSignalHandlers();\n  }\n\n  /**\n   * Starts the cluster manager\n   * In primary process: starts workers and health monitoring\n   * In worker process: executes worker function\n   */\n  public async start(): Promise<void> {\n    if (this.options.cluster.isPrimary) {\n      await this.startPrimary();\n    } else {\n      await this.startWorker();\n    }\n    this.started = true;\n  }\n\n  /**\n   * Initiates graceful shutdown of the cluster\n   */\n  public shutdown(signal?: string): Promise<void> {\n    if (!this.started) {\n      return Promise.resolve();\n    }\n\n    if (this.shutdownPromise) {\n      return this.shutdownPromise;\n    }\n\n    this.isShuttingDown = true;\n    this.emit('shutdown:started', signal);\n\n    if (this.options.cluster.isPrimary) {\n      this.shutdownPromise = this.shutdownPrimary(signal);\n    } else {\n      this.shutdownPromise = this.shutdownWorker(signal);\n    }\n\n    return this.shutdownPromise;\n  }\n\n  /**\n   * Sets up signal handlers for graceful shutdown\n   */\n  private setupSignalHandlers(): void {\n    this.options.shutdownSignals.forEach((signal) => {\n      const handler = () => {\n        this.shutdown(signal);\n      };\n      this.signalHandlers.set(signal, handler);\n      process.on(signal, handler);\n    });\n  }\n\n  /**\n   * Removes signal handlers\n   */\n  private removeSignalHandlers(): void {\n    Array.from(this.signalHandlers.entries()).forEach(([signal, handler]) => {\n      process.removeListener(signal, handler);\n    });\n    this.signalHandlers.clear();\n  }\n\n  /**\n   * Starts the primary process\n   */\n  private async startPrimary(): Promise<void> {\n    logger.info(\n      `Primary process (pid: ${process.pid}) starting with ${this.options.numWorkers} workers`,\n    );\n\n    // Execute primary initialization function, any error will stop the cluster from starting\n    await this.options.primaryFn();\n\n    // Set up cluster event handlers\n    this.setupClusterEventHandlers();\n\n    // Spawn initial workers\n    for (let i = 0; i < this.options.numWorkers; i += 1) {\n      const workerId = i + 1; // Worker IDs start from 1\n      this.spawnWorker(workerId);\n    }\n\n    // Start health monitoring\n    this.startHealthMonitoring();\n  }\n\n  /**\n   * Starts a worker process\n   */\n  private async startWorker(): Promise<void> {\n    logger.info(`Worker ${this.getCurrentWorkerId()} (pid: ${process.pid}) starting`);\n\n    // Set up IPC message handlers\n    this.setupWorkerMessageHandlers();\n\n    // Execute worker initialization function, any error will be propagated\n    await this.options.workerFn();\n  }\n\n  /**\n   * Sets up cluster event handlers for the primary process\n   */\n  private setupClusterEventHandlers(): void {\n    this.options.cluster.on('exit', (worker: Worker, code: number, signal: string) => {\n      this.handleWorkerExit(worker, code, signal);\n    });\n\n    this.options.cluster.on('online', (worker: Worker) => {\n      logger.info(`Worker ${this.getWorkerId(worker)} (pid: ${worker.process.pid}) is online`);\n      this.emit('worker:started', worker);\n    });\n  }\n\n  /**\n   * Sets up IPC message handlers for worker processes\n   */\n  private setupWorkerMessageHandlers(): void {\n    process.on('message', (message: IPCMessage) => {\n      switch (message.type) {\n        case 'ping':\n          this.handleWorkerPing(message);\n          break;\n        case 'shutdown':\n          this.shutdown(message.signal);\n          break;\n        default:\n          if (!message.type.includes('Metrics')) {\n            logger.warn(`ignoring unknown message type in worker ${process.pid}: ${message.type}`);\n          }\n          break;\n      }\n    });\n  }\n\n  /**\n   * Spawns a new worker and sets up its state\n   */\n  private spawnWorker(id: number): Worker {\n    const worker = this.options.cluster.fork({\n      WORKER_ID: id,\n    });\n    const workerState: WorkerState = {\n      id,\n      worker,\n      restartCount: 0,\n      lastPing: Date.now(),\n      pendingPing: false,\n      isShuttingDown: false,\n    };\n\n    this.workers.set(worker.id, workerState);\n\n    // Set up worker message handler\n    worker.on('message', (message: IPCMessage) => {\n      this.handleWorkerMessage(worker, message);\n    });\n\n    return worker;\n  }\n\n  /**\n   * Handles messages from workers\n   */\n  private handleWorkerMessage(worker: Worker, message: IPCMessage): void {\n    const workerState = this.workers.get(worker.id);\n    if (!workerState) return;\n\n    switch (message.type) {\n      case 'pong':\n        workerState.lastPing = Date.now();\n        workerState.pendingPing = false;\n        break;\n      default:\n        if (!message.type.includes('Metrics')) {\n          logger.warn(\n            `Received unknown message type from worker ${this.getWorkerId(worker)} (pid: ${\n              worker.process.pid\n            }): ${message.type}`,\n          );\n        }\n        break;\n    }\n  }\n\n  /**\n   * Handles ping messages in worker processes\n   */\n  private handleWorkerPing(message: PingMessage): void {\n    const pongMessage: PongMessage = {\n      type: 'pong',\n      timestamp: message.timestamp,\n    };\n\n    if (process.send) {\n      process.send(pongMessage);\n    }\n  }\n\n  /**\n   * Starts health monitoring for all workers\n   */\n  private startHealthMonitoring(): void {\n    this.healthCheckInterval = setInterval(() => {\n      this.performHealthCheck();\n    }, this.options.pingFrequency);\n  }\n\n  /**\n   * Stops health monitoring\n   */\n  private stopHealthMonitoring(): void {\n    if (this.healthCheckInterval) {\n      clearInterval(this.healthCheckInterval);\n      this.healthCheckInterval = null;\n    }\n  }\n\n  /**\n   * Performs health check on all workers\n   */\n  private performHealthCheck(): void {\n    if (this.isShuttingDown) return;\n\n    Array.from(this.workers.values())\n      .filter((workerState) => !workerState.isShuttingDown)\n      .forEach((workerState) => {\n        const timeSinceLastPing = Date.now() - workerState.lastPing;\n\n        if (workerState.pendingPing && timeSinceLastPing > this.options.pingTimeout) {\n          // Worker is stuck, handle it\n          this.handleStuckWorker(workerState);\n        } else if (!workerState.pendingPing) {\n          // Send ping to worker\n          this.sendPingToWorker(workerState);\n        }\n      });\n  }\n\n  /**\n   * Sends a ping message to a worker\n   */\n  private sendPingToWorker(workerState: WorkerState): void {\n    const pingMessage: PingMessage = {\n      type: 'ping',\n      timestamp: Date.now(),\n    };\n\n    workerState.pendingPing = true;\n    try {\n      workerState.worker.send(pingMessage);\n    } catch (error) {\n      logger.error(\n        `Failed to send ping to worker ${workerState.id} (pid: ${\n          workerState.worker.process.pid\n        }): ${error instanceof Error ? error.message : String(error)}`,\n      );\n    }\n  }\n\n  /**\n   * Handles a stuck worker\n   */\n  private handleStuckWorker(workerState: WorkerState): void {\n    logger.error(\n      `Worker ${workerState.id} (pid: ${workerState.worker.process.pid}) is stuck, killing it`,\n    );\n    this.emit('worker:stuck', workerState.worker);\n\n    // Remove worker state\n    this.workers.delete(workerState.worker.id);\n\n    // Kill the worker\n    workerState.worker.kill('SIGKILL');\n\n    // Determine if we should spawn a replacement\n    const shouldSpawn = this.options.stuckWorkerRespawnFunc(workerState.worker);\n\n    if (shouldSpawn && !this.isShuttingDown) {\n      logger.info(\n        `Spawning replacement worker for stuck worker ${workerState.id} (pid: ${workerState.worker.process.pid})`,\n      );\n      const { restartCount } = workerState; // Preserve restart count\n      const newWorker = this.spawnWorker(workerState.id);\n      const newWorkerState = this.workers.get(newWorker.id);\n      if (newWorkerState) {\n        newWorkerState.restartCount = restartCount;\n      }\n    } else {\n      logger.error(\n        `Triggering cluster shutdown due to stuck worker ${workerState.id} (pid: ${workerState.worker.process.pid})`,\n      );\n      this.shutdown('STUCK_WORKER');\n    }\n  }\n\n  /**\n   * Handles worker exit events\n   */\n  private handleWorkerExit(worker: Worker, code: number | null, signal: string | null): void {\n    const workerId = this.getWorkerId(worker);\n    this.emit('worker:died', worker, code, signal);\n\n    const workerState = this.workers.get(worker.id);\n    if (!workerState) {\n      logger.warn(\n        `Unknown worker ${workerId} (pid: ${worker.process.pid}) exited with code ${code} and signal ${signal}`,\n      );\n      return;\n    }\n\n    this.workers.delete(worker.id);\n\n    // If we're shutting down or worker was killed intentionally, don't restart\n    if (this.isShuttingDown || workerState.isShuttingDown) {\n      logger.info(\n        `Worker ${workerId} (pid: ${worker.process.pid}) exited with code ${code} and signal ${signal}`,\n      );\n      return;\n    }\n    logger.error(\n      `Worker ${workerId} (pid: ${worker.process.pid}) exited unexpectedly with code ${code} and signal ${signal}`,\n    );\n    // Handle unexpected exit\n    this.handleUnexpectedWorkerExit(workerState);\n  }\n\n  private getWorkerId(worker: Worker): number {\n    return this.workers.get(worker.id)?.id ?? worker.id;\n  }\n\n  private getCurrentWorkerId(): number {\n    const envWorkerId =\n      process.env.WORKER_ID !== undefined ? Number(process.env.WORKER_ID) : undefined;\n    return envWorkerId ?? this.options.cluster.worker?.id ?? -1;\n  }\n\n  /**\n   * Handles unexpected worker exits with restart logic\n   */\n  private handleUnexpectedWorkerExit(workerState: WorkerState): void {\n    const restartCount = workerState.restartCount + 1;\n\n    if (restartCount <= this.options.restartMaxTimes) {\n      logger.error(\n        `Restarting worker ${workerState.id} (pid: ${workerState.worker.process.pid}) (attempt ${restartCount}/${this.options.restartMaxTimes})`,\n      );\n      const newWorker = this.spawnWorker(workerState.id);\n      const newWorkerState = this.workers.get(newWorker.id);\n      if (newWorkerState) {\n        newWorkerState.restartCount = restartCount;\n      }\n      this.emit('worker:restarted', newWorker, workerState.restartCount);\n    } else {\n      logger.error(\n        `Restart limit (${this.options.restartMaxTimes}) exceeded for worker ${workerState.id} (pid: ${workerState.worker.process.pid}), shutting down cluster`,\n      );\n      this.emit('worker:restart-limit-exceeded', workerState.worker, workerState.restartCount);\n      this.shutdown('RESTART_LIMIT_EXCEEDED');\n    }\n  }\n\n  /**\n   * Shuts down the primary process\n   */\n  private async shutdownPrimary(signal?: string): Promise<void> {\n    logger.warn(\n      `Primary process (pid: ${process.pid}) shutting down (signal: ${signal ?? 'manual'})`,\n    );\n\n    this.stopHealthMonitoring();\n    this.removeSignalHandlers();\n\n    // Shutdown all workers\n    await this.shutdownAllWorkers(signal);\n\n    // Execute primary shutdown function\n    await safeExecute(\n      () =>\n        timeout(\n          this.options.primaryShutdownFn(signal),\n          this.options.shutdownTimeout,\n          'primary shutdown timeout',\n        ),\n      'Error in primary shutdown function',\n    );\n\n    logger.info(`Primary process (pid: ${process.pid}) shutdown completed`);\n    this.emit('shutdown:completed');\n    process.exit(0);\n  }\n\n  /**\n   * Shuts down all workers gracefully\n   */\n  private async shutdownAllWorkers(signal?: string): Promise<void> {\n    if (this.workers.size === 0) return;\n\n    logger.info(`Shutting down ${this.workers.size} workers...`);\n\n    // Mark all workers as shutting down and send shutdown message\n    Array.from(this.workers.values()).forEach((workerState) => {\n      workerState.isShuttingDown = true;\n      // Only send shutdown message if worker is still connected\n      if (!workerState.worker.isDead() && workerState.worker.process.connected) {\n        const shutdownMessage: ShutdownMessage = {\n          type: 'shutdown',\n          signal,\n        };\n        try {\n          workerState.worker.send(shutdownMessage);\n        } catch (error) {\n          // Worker IPC channel is already closed, which is fine\n          logger.warn(\n            `Failed to send shutdown message to worker ${workerState.id} (pid: ${\n              workerState.worker.process.pid\n            }): ${error instanceof Error ? error.message : String(error)}`,\n          );\n        }\n      }\n    });\n\n    // Wait for workers to exit gracefully or timeout\n    try {\n      await timeout(\n        this.waitForAllWorkersToExit(),\n        this.options.shutdownTimeout,\n        'Worker shutdown timeout',\n      );\n    } catch (error) {\n      logger.error('Graceful shutdown for workers timed out, forcing shutdown');\n      this.forceKillAllWorkers();\n    }\n  }\n\n  /**\n   * Waits for all workers to exit\n   */\n  private async waitForAllWorkersToExit(): Promise<void> {\n    while (this.workers.size > 0) {\n      // eslint-disable-next-line no-await-in-loop\n      await delay(100);\n    }\n  }\n\n  /**\n   * Force kills all remaining workers\n   */\n  private forceKillAllWorkers(): void {\n    Array.from(this.workers.values()).forEach((workerState) => {\n      logger.error(\n        `Force killing worker ${workerState.id} (pid: ${workerState.worker.process.pid})`,\n      );\n      workerState.worker.kill('SIGKILL');\n    });\n    this.workers.clear();\n  }\n\n  /**\n   * Shuts down a worker process\n   */\n  private async shutdownWorker(signal?: string): Promise<void> {\n    logger.warn(\n      `Worker ${this.getCurrentWorkerId()} (pid: ${process.pid}) shutting down (signal: ${\n        signal ?? 'manual'\n      })`,\n    );\n\n    this.removeSignalHandlers();\n\n    // Execute worker shutdown function\n    await safeExecute(\n      () =>\n        timeout(\n          this.options.workerShutdownFn(signal),\n          this.options.shutdownTimeout,\n          'worker shutdown timeout',\n        ),\n      `Error in worker ${this.getCurrentWorkerId()} (pid: ${process.pid}) shutdown function`,\n    );\n\n    logger.info(`Worker ${this.getCurrentWorkerId()} (pid: ${process.pid}) shutdown completed`);\n    process.exit(0);\n  }\n\n  /**\n   * Gets the current number of active workers\n   */\n  public getWorkerCount(): number {\n    return this.workers.size;\n  }\n\n  /**\n   * Gets information about all workers\n   */\n  public getWorkerInfo(): Array<{ id: number; pid: number; restartCount: number }> {\n    return Array.from(this.workers.values()).map((state) => ({\n      id: state.id,\n      pid: state.worker.process.pid ?? -1,\n      restartCount: state.restartCount,\n    }));\n  }\n\n  /**\n   * Checks if the cluster is currently started\n   */\n  public isStarted(): boolean {\n    return this.started;\n  }\n\n  /**\n   * Checks if the cluster is currently shutting down\n   */\n  public isShutdown(): boolean {\n    return this.isShuttingDown;\n  }\n}\n\n// Type-safe event emitter interface\nexport interface ClusterManagerEmitter {\n  on<K extends keyof ClusterManagerEvents>(event: K, listener: ClusterManagerEvents[K]): this;\n  emit<K extends keyof ClusterManagerEvents>(\n    event: K,\n    ...args: Parameters<ClusterManagerEvents[K]>\n  ): boolean;\n}\n"]}
|
package/build/index.d.ts
CHANGED
package/build/index.d.ts.map
CHANGED
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"index.d.ts","sourceRoot":"","sources":["../src/index.ts"],"names":[],"mappings":"AAAA,OAAO,QAAQ,MAAM,iBAAiB,CAAC;AAEvC,cAAc,SAAS,CAAC;AACxB,cAAc,QAAQ,CAAC;AACvB,cAAc,UAAU,CAAC;AACzB,cAAc,UAAU,CAAC;AACzB,cAAc,qBAAqB,CAAC;AACpC,cAAc,WAAW,CAAC;AAC1B,cAAc,SAAS,CAAC;AACxB,cAAc,aAAa,CAAC;AAC5B,cAAc,QAAQ,CAAC;AACvB,cAAc,WAAW,CAAC;AAC1B,cAAc,iBAAiB,CAAC;AAChC,cAAc,cAAc,CAAC;AAC7B,OAAO,EAAE,QAAQ,EAAE,CAAC"}
|
|
1
|
+
{"version":3,"file":"index.d.ts","sourceRoot":"","sources":["../src/index.ts"],"names":[],"mappings":"AAAA,OAAO,QAAQ,MAAM,iBAAiB,CAAC;AAEvC,cAAc,SAAS,CAAC;AACxB,cAAc,QAAQ,CAAC;AACvB,cAAc,UAAU,CAAC;AACzB,cAAc,UAAU,CAAC;AACzB,cAAc,qBAAqB,CAAC;AACpC,cAAc,WAAW,CAAC;AAC1B,cAAc,SAAS,CAAC;AACxB,cAAc,aAAa,CAAC;AAC5B,cAAc,QAAQ,CAAC;AACvB,cAAc,WAAW,CAAC;AAC1B,cAAc,iBAAiB,CAAC;AAChC,cAAc,cAAc,CAAC;AAC7B,cAAc,cAAc,CAAC;AAC7B,OAAO,EAAE,QAAQ,EAAE,CAAC"}
|
package/build/index.js
CHANGED
|
@@ -32,4 +32,5 @@ __exportStar(require("./sdks"), exports);
|
|
|
32
32
|
__exportStar(require("./cluster"), exports);
|
|
33
33
|
__exportStar(require("./feature-flags"), exports);
|
|
34
34
|
__exportStar(require("./auth-types"), exports);
|
|
35
|
-
|
|
35
|
+
__exportStar(require("./mock_utils"), exports);
|
|
36
|
+
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiaW5kZXguanMiLCJzb3VyY2VSb290IjoiIiwic291cmNlcyI6WyIuLi9zcmMvaW5kZXgudHMiXSwibmFtZXMiOltdLCJtYXBwaW5ncyI6Ijs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7QUFBQSxnRUFBdUM7QUFlOUIsbUJBZkYsbUJBQVEsQ0FlRTtBQWJqQiwwQ0FBd0I7QUFDeEIseUNBQXVCO0FBQ3ZCLDJDQUF5QjtBQUN6QiwyQ0FBeUI7QUFDekIsc0RBQW9DO0FBQ3BDLDRDQUEwQjtBQUMxQiwwQ0FBd0I7QUFDeEIsOENBQTRCO0FBQzVCLHlDQUF1QjtBQUN2Qiw0Q0FBMEI7QUFDMUIsa0RBQWdDO0FBQ2hDLCtDQUE2QjtBQUM3QiwrQ0FBNkIiLCJzb3VyY2VzQ29udGVudCI6WyJpbXBvcnQgc2V0VmFsdWUgZnJvbSAnLi9saWIvc2V0LXZhbHVlJztcblxuZXhwb3J0ICogZnJvbSAnLi90eXBlcyc7XG5leHBvcnQgKiBmcm9tICcuL3RhZ3MnO1xuZXhwb3J0ICogZnJvbSAnLi9lcnJvcnMnO1xuZXhwb3J0ICogZnJvbSAnLi9sb2dnZXInO1xuZXhwb3J0ICogZnJvbSAnLi9zdHJ1Y3R1cmVkLWxvZ2dlcic7XG5leHBvcnQgKiBmcm9tICcuL25ldHdvcmsnO1xuZXhwb3J0ICogZnJvbSAnLi91dGlscyc7XG5leHBvcnQgKiBmcm9tICcuL2NvbnN0YW50cyc7XG5leHBvcnQgKiBmcm9tICcuL3Nka3MnO1xuZXhwb3J0ICogZnJvbSAnLi9jbHVzdGVyJztcbmV4cG9ydCAqIGZyb20gJy4vZmVhdHVyZS1mbGFncyc7XG5leHBvcnQgKiBmcm9tICcuL2F1dGgtdHlwZXMnO1xuZXhwb3J0ICogZnJvbSAnLi9tb2NrX3V0aWxzJztcbmV4cG9ydCB7IHNldFZhbHVlIH07XG4iXX0=
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"axios_client_mock_util.d.ts","sourceRoot":"","sources":["../../src/mock_utils/axios_client_mock_util.ts"],"names":[],"mappings":"AAAA,OAAO,YAAY,MAAM,OAAO,CAAC;AACjC,OAAO,WAAW,MAAM,oBAAoB,CAAC;AAE7C,eAAO,MAAM,gBAAgB,aAE3B,CAAC;AAGH,OAAO,EAAE,YAAY,EAAE,CAAC"}
|
|
@@ -0,0 +1,13 @@
|
|
|
1
|
+
"use strict";
|
|
2
|
+
var __importDefault = (this && this.__importDefault) || function (mod) {
|
|
3
|
+
return (mod && mod.__esModule) ? mod : { "default": mod };
|
|
4
|
+
};
|
|
5
|
+
Object.defineProperty(exports, "__esModule", { value: true });
|
|
6
|
+
exports.axiosFromLib = exports.mockAxiosFromLib = void 0;
|
|
7
|
+
const axios_1 = __importDefault(require("axios"));
|
|
8
|
+
exports.axiosFromLib = axios_1.default;
|
|
9
|
+
const axios_mock_adapter_1 = __importDefault(require("axios-mock-adapter"));
|
|
10
|
+
exports.mockAxiosFromLib = new axios_mock_adapter_1.default(axios_1.default, {
|
|
11
|
+
onNoMatch: 'throwException',
|
|
12
|
+
});
|
|
13
|
+
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiYXhpb3NfY2xpZW50X21vY2tfdXRpbC5qcyIsInNvdXJjZVJvb3QiOiIiLCJzb3VyY2VzIjpbIi4uLy4uL3NyYy9tb2NrX3V0aWxzL2F4aW9zX2NsaWVudF9tb2NrX3V0aWwudHMiXSwibmFtZXMiOltdLCJtYXBwaW5ncyI6Ijs7Ozs7O0FBQUEsa0RBQWlDO0FBUXhCLHVCQVJGLGVBQVksQ0FRRTtBQVByQiw0RUFBNkM7QUFFaEMsUUFBQSxnQkFBZ0IsR0FBRyxJQUFJLDRCQUFXLENBQUMsZUFBbUIsRUFBRTtJQUNuRSxTQUFTLEVBQUUsZ0JBQWdCO0NBQzVCLENBQUMsQ0FBQyIsInNvdXJjZXNDb250ZW50IjpbImltcG9ydCBheGlvc0Zyb21MaWIgZnJvbSAnYXhpb3MnO1xuaW1wb3J0IE1vY2tBZGFwdGVyIGZyb20gJ2F4aW9zLW1vY2stYWRhcHRlcic7XG5cbmV4cG9ydCBjb25zdCBtb2NrQXhpb3NGcm9tTGliID0gbmV3IE1vY2tBZGFwdGVyKGF4aW9zRnJvbUxpYiBhcyBhbnksIHtcbiAgb25Ob01hdGNoOiAndGhyb3dFeGNlcHRpb24nLFxufSk7XG5cbi8vIHdlIGFyZSBleHBvcnRpbmcgYXhpb3NGcm9tTGliIHRvIG1vY2sgdGhlIGF4aW9zIGxpYnJhcnkgaW4gdHJhbnNmb3JtZXIgdGVzdHNcbmV4cG9ydCB7IGF4aW9zRnJvbUxpYiB9O1xuIl19
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"index.d.ts","sourceRoot":"","sources":["../../src/mock_utils/index.ts"],"names":[],"mappings":"AAAA,cAAc,0BAA0B,CAAC"}
|
|
@@ -0,0 +1,18 @@
|
|
|
1
|
+
"use strict";
|
|
2
|
+
var __createBinding = (this && this.__createBinding) || (Object.create ? (function(o, m, k, k2) {
|
|
3
|
+
if (k2 === undefined) k2 = k;
|
|
4
|
+
var desc = Object.getOwnPropertyDescriptor(m, k);
|
|
5
|
+
if (!desc || ("get" in desc ? !m.__esModule : desc.writable || desc.configurable)) {
|
|
6
|
+
desc = { enumerable: true, get: function() { return m[k]; } };
|
|
7
|
+
}
|
|
8
|
+
Object.defineProperty(o, k2, desc);
|
|
9
|
+
}) : (function(o, m, k, k2) {
|
|
10
|
+
if (k2 === undefined) k2 = k;
|
|
11
|
+
o[k2] = m[k];
|
|
12
|
+
}));
|
|
13
|
+
var __exportStar = (this && this.__exportStar) || function(m, exports) {
|
|
14
|
+
for (var p in m) if (p !== "default" && !Object.prototype.hasOwnProperty.call(exports, p)) __createBinding(exports, m, p);
|
|
15
|
+
};
|
|
16
|
+
Object.defineProperty(exports, "__esModule", { value: true });
|
|
17
|
+
__exportStar(require("./axios_client_mock_util"), exports);
|
|
18
|
+
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiaW5kZXguanMiLCJzb3VyY2VSb290IjoiIiwic291cmNlcyI6WyIuLi8uLi9zcmMvbW9ja191dGlscy9pbmRleC50cyJdLCJuYW1lcyI6W10sIm1hcHBpbmdzIjoiOzs7Ozs7Ozs7Ozs7Ozs7O0FBQUEsMkRBQXlDIiwic291cmNlc0NvbnRlbnQiOlsiZXhwb3J0ICogZnJvbSAnLi9heGlvc19jbGllbnRfbW9ja191dGlsJztcbiJdfQ==
|
|
@@ -1,5 +1,5 @@
|
|
|
1
1
|
import { AxiosRequestConfig } from 'axios';
|
|
2
|
-
import { ApiResponse, HttpClient, ResponseParser } from './types';
|
|
2
|
+
import { ApiResponse, HttpClient, ResponseParser, AxiosClientObservabilityConfig } from './types';
|
|
3
3
|
/**
|
|
4
4
|
* A wrapper around axios to make http requests
|
|
5
5
|
*
|
|
@@ -27,12 +27,13 @@ import { ApiResponse, HttpClient, ResponseParser } from './types';
|
|
|
27
27
|
export declare class AxiosClient implements HttpClient {
|
|
28
28
|
private options;
|
|
29
29
|
private instance;
|
|
30
|
-
|
|
30
|
+
private observabilityConfig;
|
|
31
|
+
constructor(options?: AxiosRequestConfig, observabilityConfig?: AxiosClientObservabilityConfig);
|
|
31
32
|
private makeRequest;
|
|
32
33
|
get<T>(url: string, options?: AxiosRequestConfig, responseParser?: ResponseParser<T>): Promise<ApiResponse<T>>;
|
|
33
|
-
post<T>(url: string, data?:
|
|
34
|
-
put<T>(url: string, data?:
|
|
35
|
-
patch<T>(url: string, data?:
|
|
34
|
+
post<T>(url: string, data?: unknown, options?: AxiosRequestConfig, responseParser?: ResponseParser<T>): Promise<ApiResponse<T>>;
|
|
35
|
+
put<T>(url: string, data?: unknown, options?: AxiosRequestConfig, responseParser?: ResponseParser<T>): Promise<ApiResponse<T>>;
|
|
36
|
+
patch<T>(url: string, data?: unknown, options?: AxiosRequestConfig, responseParser?: ResponseParser<T>): Promise<ApiResponse<T>>;
|
|
36
37
|
delete<T>(url: string, options?: AxiosRequestConfig, responseParser?: ResponseParser<T>): Promise<ApiResponse<T>>;
|
|
37
38
|
}
|
|
38
39
|
//# sourceMappingURL=axios_client.d.ts.map
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"axios_client.d.ts","sourceRoot":"","sources":["../../../src/network/clients/axios_client.ts"],"names":[],"mappings":"AACA,OAAc,EAAE,kBAAkB,EAA6B,MAAM,OAAO,CAAC;AAI7E,OAAO,EAAE,WAAW,EAAE,UAAU,EAAE,cAAc,EAAE,MAAM,SAAS,CAAC;
|
|
1
|
+
{"version":3,"file":"axios_client.d.ts","sourceRoot":"","sources":["../../../src/network/clients/axios_client.ts"],"names":[],"mappings":"AACA,OAAc,EAAE,kBAAkB,EAA6B,MAAM,OAAO,CAAC;AAI7E,OAAO,EAAE,WAAW,EAAE,UAAU,EAAE,cAAc,EAAE,8BAA8B,EAAE,MAAM,SAAS,CAAC;AAGlG;;;;;;;;;;;;;;;;;;;;;;;GAuBG;AACH,qBAAa,WAAY,YAAW,UAAU;IAC5C,OAAO,CAAC,OAAO,CAAqB;IAEpC,OAAO,CAAC,QAAQ,CAAgB;IAEhC,OAAO,CAAC,mBAAmB,CAAiC;gBAEhD,OAAO,CAAC,EAAE,kBAAkB,EAAE,mBAAmB,CAAC,EAAE,8BAA8B;YA4BhF,WAAW;IA2IZ,GAAG,CAAC,CAAC,EAChB,GAAG,EAAE,MAAM,EACX,OAAO,CAAC,EAAE,kBAAkB,EAC5B,cAAc,CAAC,EAAE,cAAc,CAAC,CAAC,CAAC,GACjC,OAAO,CAAC,WAAW,CAAC,CAAC,CAAC,CAAC;IAWb,IAAI,CAAC,CAAC,EACjB,GAAG,EAAE,MAAM,EACX,IAAI,CAAC,EAAE,OAAO,EACd,OAAO,CAAC,EAAE,kBAAkB,EAC5B,cAAc,CAAC,EAAE,cAAc,CAAC,CAAC,CAAC,GACjC,OAAO,CAAC,WAAW,CAAC,CAAC,CAAC,CAAC;IAYb,GAAG,CAAC,CAAC,EAChB,GAAG,EAAE,MAAM,EACX,IAAI,CAAC,EAAE,OAAO,EACd,OAAO,CAAC,EAAE,kBAAkB,EAC5B,cAAc,CAAC,EAAE,cAAc,CAAC,CAAC,CAAC,GACjC,OAAO,CAAC,WAAW,CAAC,CAAC,CAAC,CAAC;IAYb,KAAK,CAAC,CAAC,EAClB,GAAG,EAAE,MAAM,EACX,IAAI,CAAC,EAAE,OAAO,EACd,OAAO,CAAC,EAAE,kBAAkB,EAC5B,cAAc,CAAC,EAAE,cAAc,CAAC,CAAC,CAAC,GACjC,OAAO,CAAC,WAAW,CAAC,CAAC,CAAC,CAAC;IAYb,MAAM,CAAC,CAAC,EACnB,GAAG,EAAE,MAAM,EACX,OAAO,CAAC,EAAE,kBAAkB,EAC5B,cAAc,CAAC,EAAE,cAAc,CAAC,CAAC,CAAC,GACjC,OAAO,CAAC,WAAW,CAAC,CAAC,CAAC,CAAC;CAY3B"}
|
|
@@ -1,44 +1,11 @@
|
|
|
1
1
|
"use strict";
|
|
2
|
-
var __createBinding = (this && this.__createBinding) || (Object.create ? (function(o, m, k, k2) {
|
|
3
|
-
if (k2 === undefined) k2 = k;
|
|
4
|
-
var desc = Object.getOwnPropertyDescriptor(m, k);
|
|
5
|
-
if (!desc || ("get" in desc ? !m.__esModule : desc.writable || desc.configurable)) {
|
|
6
|
-
desc = { enumerable: true, get: function() { return m[k]; } };
|
|
7
|
-
}
|
|
8
|
-
Object.defineProperty(o, k2, desc);
|
|
9
|
-
}) : (function(o, m, k, k2) {
|
|
10
|
-
if (k2 === undefined) k2 = k;
|
|
11
|
-
o[k2] = m[k];
|
|
12
|
-
}));
|
|
13
|
-
var __setModuleDefault = (this && this.__setModuleDefault) || (Object.create ? (function(o, v) {
|
|
14
|
-
Object.defineProperty(o, "default", { enumerable: true, value: v });
|
|
15
|
-
}) : function(o, v) {
|
|
16
|
-
o["default"] = v;
|
|
17
|
-
});
|
|
18
|
-
var __importStar = (this && this.__importStar) || (function () {
|
|
19
|
-
var ownKeys = function(o) {
|
|
20
|
-
ownKeys = Object.getOwnPropertyNames || function (o) {
|
|
21
|
-
var ar = [];
|
|
22
|
-
for (var k in o) if (Object.prototype.hasOwnProperty.call(o, k)) ar[ar.length] = k;
|
|
23
|
-
return ar;
|
|
24
|
-
};
|
|
25
|
-
return ownKeys(o);
|
|
26
|
-
};
|
|
27
|
-
return function (mod) {
|
|
28
|
-
if (mod && mod.__esModule) return mod;
|
|
29
|
-
var result = {};
|
|
30
|
-
if (mod != null) for (var k = ownKeys(mod), i = 0; i < k.length; i++) if (k[i] !== "default") __createBinding(result, mod, k[i]);
|
|
31
|
-
__setModuleDefault(result, mod);
|
|
32
|
-
return result;
|
|
33
|
-
};
|
|
34
|
-
})();
|
|
35
2
|
var __importDefault = (this && this.__importDefault) || function (mod) {
|
|
36
3
|
return (mod && mod.__esModule) ? mod : { "default": mod };
|
|
37
4
|
};
|
|
38
5
|
Object.defineProperty(exports, "__esModule", { value: true });
|
|
39
6
|
exports.AxiosClient = void 0;
|
|
40
7
|
/* eslint-disable require-await */
|
|
41
|
-
const axios_1 =
|
|
8
|
+
const axios_1 = __importDefault(require("axios"));
|
|
42
9
|
const http_1 = __importDefault(require("http"));
|
|
43
10
|
const https_1 = __importDefault(require("https"));
|
|
44
11
|
const constants_1 = require("../../constants");
|
|
@@ -68,7 +35,7 @@ const utils_1 = require("../../utils");
|
|
|
68
35
|
* }
|
|
69
36
|
*/
|
|
70
37
|
class AxiosClient {
|
|
71
|
-
constructor(options) {
|
|
38
|
+
constructor(options, observabilityConfig) {
|
|
72
39
|
const defaultOptions = {
|
|
73
40
|
timeout: 1000 * 10,
|
|
74
41
|
// `withCredentials` indicates whether or not cross-site Access-Control requests should be made using credentials
|
|
@@ -86,23 +53,58 @@ class AxiosClient {
|
|
|
86
53
|
};
|
|
87
54
|
this.options = { ...defaultOptions, ...options };
|
|
88
55
|
this.instance = axios_1.default.create(this.options);
|
|
56
|
+
// Merge with default config to eliminate null checks
|
|
57
|
+
const defaultObservabilityConfig = {
|
|
58
|
+
logger: undefined,
|
|
59
|
+
statsClient: undefined,
|
|
60
|
+
defaultStatTags: {},
|
|
61
|
+
};
|
|
62
|
+
this.observabilityConfig = { ...defaultObservabilityConfig, ...observabilityConfig };
|
|
89
63
|
}
|
|
90
64
|
async makeRequest(config, responseParser) {
|
|
91
|
-
|
|
65
|
+
const startTime = Date.now();
|
|
66
|
+
// Extract metadata for logging/metrics
|
|
67
|
+
const method = config.method?.toUpperCase() || 'UNKNOWN';
|
|
68
|
+
const url = config.url || 'unknown';
|
|
69
|
+
const statTags = {
|
|
70
|
+
requestMethod: method,
|
|
71
|
+
endpointPath: url,
|
|
72
|
+
...this.observabilityConfig.defaultStatTags,
|
|
73
|
+
};
|
|
74
|
+
// Optional request logging
|
|
75
|
+
this.observabilityConfig.logger?.requestLog(`[HTTP] ${method} ${url} request`, {
|
|
76
|
+
method,
|
|
77
|
+
url,
|
|
78
|
+
statTags,
|
|
79
|
+
});
|
|
92
80
|
try {
|
|
93
81
|
const requestConfig = config;
|
|
94
82
|
const response = await this.instance.request(requestConfig);
|
|
95
83
|
const { status, data, headers } = response;
|
|
84
|
+
const duration = Date.now() - startTime;
|
|
85
|
+
// Add status code to statTags for better observability
|
|
86
|
+
const successStatTags = {
|
|
87
|
+
...statTags,
|
|
88
|
+
statusCode: status,
|
|
89
|
+
};
|
|
90
|
+
// Optional response logging
|
|
91
|
+
this.observabilityConfig.logger?.responseLog(`[HTTP] ${method} ${url} response`, {
|
|
92
|
+
statusCode: status,
|
|
93
|
+
duration,
|
|
94
|
+
statTags: successStatTags,
|
|
95
|
+
});
|
|
96
|
+
// Optional success metrics
|
|
97
|
+
this.observabilityConfig.statsClient?.timing('outgoing_request_latency', duration, successStatTags);
|
|
98
|
+
this.observabilityConfig.statsClient?.increment('outgoing_request_count', 1, successStatTags);
|
|
96
99
|
if (responseParser) {
|
|
97
100
|
try {
|
|
98
101
|
const parsedData = responseParser(data);
|
|
99
|
-
|
|
102
|
+
return {
|
|
100
103
|
type: 'success',
|
|
101
104
|
statusCode: status,
|
|
102
105
|
responseBody: parsedData,
|
|
103
106
|
headers,
|
|
104
107
|
};
|
|
105
|
-
return output;
|
|
106
108
|
}
|
|
107
109
|
catch (error) {
|
|
108
110
|
const unknownError = error;
|
|
@@ -117,7 +119,31 @@ class AxiosClient {
|
|
|
117
119
|
return { type: 'success', statusCode: status, responseBody: data, headers };
|
|
118
120
|
}
|
|
119
121
|
catch (error) {
|
|
120
|
-
|
|
122
|
+
const duration = Date.now() - startTime;
|
|
123
|
+
// Determine status code for error metrics
|
|
124
|
+
let errorStatusCode = 500; // Default to 500 for network/unknown errors
|
|
125
|
+
if (axios_1.default.isAxiosError(error)) {
|
|
126
|
+
const axiosError = error;
|
|
127
|
+
if (axiosError.response) {
|
|
128
|
+
errorStatusCode = axiosError.response.status;
|
|
129
|
+
}
|
|
130
|
+
}
|
|
131
|
+
// Add status code and error flag to statTags for better observability
|
|
132
|
+
const errorStatTags = {
|
|
133
|
+
...statTags,
|
|
134
|
+
statusCode: errorStatusCode,
|
|
135
|
+
error: true,
|
|
136
|
+
};
|
|
137
|
+
// Optional error logging
|
|
138
|
+
this.observabilityConfig.logger?.error?.(`[HTTP] ${method} ${url} error`, {
|
|
139
|
+
error: error.message,
|
|
140
|
+
duration,
|
|
141
|
+
statTags: errorStatTags,
|
|
142
|
+
});
|
|
143
|
+
// Optional error metrics
|
|
144
|
+
this.observabilityConfig.statsClient?.timing('outgoing_request_latency', duration, errorStatTags);
|
|
145
|
+
this.observabilityConfig.statsClient?.increment('outgoing_request_count', 1, errorStatTags);
|
|
146
|
+
if (axios_1.default.isAxiosError(error)) {
|
|
121
147
|
const axiosError = error;
|
|
122
148
|
if (axiosError.response) {
|
|
123
149
|
const { response } = axiosError;
|
|
@@ -206,4 +232,4 @@ class AxiosClient {
|
|
|
206
232
|
}
|
|
207
233
|
}
|
|
208
234
|
exports.AxiosClient = AxiosClient;
|
|
209
|
-
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"axios_client.js","sourceRoot":"","sources":["../../../src/network/clients/axios_client.ts"],"names":[],"mappings":";;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;AAAA,kCAAkC;AAClC,+CAA6E;AAC7E,gDAAwB;AACxB,kDAA0B;AAC1B,+CAAyD;AAEzD,uCAAyC;AAEzC;;;;;;;;;;;;;;;;;;;;;;;GAuBG;AACH,MAAa,WAAW;IAKtB,YAAY,OAA4B;QACtC,MAAM,cAAc,GAAG;YACrB,OAAO,EAAE,IAAI,GAAG,EAAE;YAClB,iHAAiH;YACjH,eAAe,EAAE,KAAK;YACtB,sFAAsF;YACtF,gBAAgB,EAAE,MAAM;YACxB,wGAAwG;YACxG,aAAa,EAAE,IAAI,GAAG,IAAI,GAAG,EAAE;YAC/B,+EAA+E;YAC/E,YAAY,EAAE,CAAC;YACf,qFAAqF;YACrF,SAAS,EAAE,IAAI,cAAI,CAAC,KAAK,CAAC,EAAE,SAAS,EAAE,IAAI,EAAE,CAAC;YAC9C,kIAAkI;YAClI,UAAU,EAAE,IAAI,eAAK,CAAC,KAAK,CAAC,EAAE,SAAS,EAAE,IAAI,EAAE,CAAC;SACjD,CAAC;QACF,IAAI,CAAC,OAAO,GAAG,EAAE,GAAG,cAAc,EAAE,GAAG,OAAO,EAAE,CAAC;QACjD,IAAI,CAAC,QAAQ,GAAG,eAAK,CAAC,MAAM,CAAC,IAAI,CAAC,OAAO,CAAC,CAAC;IAC7C,CAAC;IAEO,KAAK,CAAC,WAAW,CACvB,MAA0B,EAC1B,cAAkC;QAElC,IAAI,MAAsB,CAAC;QAC3B,IAAI,CAAC;YACH,MAAM,aAAa,GAAG,MAAM,CAAC;YAC7B,MAAM,QAAQ,GAAG,MAAM,IAAI,CAAC,QAAQ,CAAC,OAAO,CAAC,aAAa,CAAC,CAAC;YAC5D,MAAM,EAAE,MAAM,EAAE,IAAI,EAAE,OAAO,EAAE,GAAG,QAAQ,CAAC;YAE3C,IAAI,cAAc,EAAE,CAAC;gBACnB,IAAI,CAAC;oBACH,MAAM,UAAU,GAAG,cAAc,CAAC,IAAI,CAAC,CAAC;oBACxC,MAAM,GAAG;wBACP,IAAI,EAAE,SAAS;wBACf,UAAU,EAAE,MAAM;wBAClB,YAAY,EAAE,UAAU;wBACxB,OAAO;qBACR,CAAC;oBACF,OAAO,MAAM,CAAC;gBAChB,CAAC;gBAAC,OAAO,KAAK,EAAE,CAAC;oBACf,MAAM,YAAY,GAAG,KAAc,CAAC;oBACpC,OAAO;wBACL,IAAI,EAAE,cAAc;wBACpB,qCAAqC;wBACrC,UAAU,EAAE,YAAY,CAAC,MAAM,IAAI,GAAG;wBACtC,OAAO,EAAE,kCAAkC,YAAY,CAAC,OAAO,EAAE;qBAClE,CAAC;gBACJ,CAAC;YACH,CAAC;YACD,OAAO,EAAE,IAAI,EAAE,SAAS,EAAE,UAAU,EAAE,MAAM,EAAE,YAAY,EAAE,IAAI,EAAE,OAAO,EAAE,CAAC;QAC9E,CAAC;QAAC,OAAO,KAAK,EAAE,CAAC;YACf,IAAI,KAAK,YAAY,kBAAU,EAAE,CAAC;gBAChC,MAAM,UAAU,GAAG,KAAmB,CAAC;gBACvC,IAAI,UAAU,CAAC,QAAQ,EAAE,CAAC;oBACxB,MAAM,EAAE,QAAQ,EAAE,GAAG,UAAU,CAAC;oBAChC,OAAO;wBACL,IAAI,EAAE,mBAAmB;wBACzB,UAAU,EAAE,QAAQ,CAAC,MAAM;wBAC3B,OAAO,EAAE,QAAQ,CAAC,UAAU;wBAC5B,YAAY,EAAE,QAAQ,CAAC,IAAI;wBAC3B,OAAO,EAAE,QAAQ,CAAC,OAAO;qBAC1B,CAAC;gBACJ,CAAC;gBACD,IAAI,UAAU,CAAC,IAAI,EAAE,CAAC;oBACpB,MAAM,IAAI,GAAG,kCAAsB,CAAC,UAAU,CAAC,IAAI,CAAC,CAAC;oBACrD,IAAI,CAAC,IAAI,EAAE,CAAC;wBACV,OAAO;4BACL,IAAI,EAAE,cAAc;4BACpB,UAAU,EAAE,GAAG;4BACf,OAAO,EAAE,iBAAiB,UAAU,CAAC,OAAO,EAAE;yBAC/C,CAAC;oBACJ,CAAC;oBACD,OAAO;wBACL,IAAI,EAAE,cAAc;wBACpB,UAAU,EAAE,IAAI,CAAC,MAAM;wBACvB,OAAO,EAAE,IAAI,CAAC,OAAO;qBACtB,CAAC;gBACJ,CAAC;YACH,CAAC;YAED,MAAM,YAAY,GAAG,KAAc,CAAC;YACpC,MAAM,MAAM,GAAG,GAAG,CAAC;YACnB,MAAM,OAAO,GAAG,YAAY,CAAC,OAAO,IAAI,eAAe,CAAC;YAExD,OAAO,EAAE,IAAI,EAAE,cAAc,EAAE,UAAU,EAAE,MAAM,EAAE,OAAO,EAAE,CAAC;QAC/D,CAAC;IACH,CAAC;IAEM,KAAK,CAAC,GAAG,CACd,GAAW,EACX,OAA4B,EAC5B,cAAkC;QAElC,IAAI,MAAM,GAAuB;YAC/B,MAAM,EAAE,KAAK;YACb,GAAG;SACJ,CAAC;QACF,IAAI,IAAA,kBAAU,EAAC,OAAO,CAAC,EAAE,CAAC;YACxB,MAAM,GAAG,EAAE,GAAG,MAAM,EAAE,GAAG,OAAO,EAAE,CAAC;QACrC,CAAC;QACD,OAAO,IAAI,CAAC,WAAW,CAAI,MAAM,EAAE,cAAc,CAAC,CAAC;IACrD,CAAC;IAEM,KAAK,CAAC,IAAI,CACf,GAAW,EACX,IAAU,EACV,OAA4B,EAC5B,cAAkC;QAElC,IAAI,MAAM,GAAuB;YAC/B,MAAM,EAAE,MAAM;YACd,GAAG;YACH,IAAI;SACL,CAAC;QACF,IAAI,IAAA,kBAAU,EAAC,OAAO,CAAC,EAAE,CAAC;YACxB,MAAM,GAAG,EAAE,GAAG,MAAM,EAAE,GAAG,OAAO,EAAE,CAAC;QACrC,CAAC;QACD,OAAO,IAAI,CAAC,WAAW,CAAI,MAAM,EAAE,cAAc,CAAC,CAAC;IACrD,CAAC;IAEM,KAAK,CAAC,GAAG,CACd,GAAW,EACX,IAAU,EACV,OAA4B,EAC5B,cAAkC;QAElC,IAAI,MAAM,GAAuB;YAC/B,MAAM,EAAE,KAAK;YACb,GAAG;YACH,IAAI;SACL,CAAC;QACF,IAAI,IAAA,kBAAU,EAAC,OAAO,CAAC,EAAE,CAAC;YACxB,MAAM,GAAG,EAAE,GAAG,MAAM,EAAE,GAAG,OAAO,EAAE,CAAC;QACrC,CAAC;QACD,OAAO,IAAI,CAAC,WAAW,CAAI,MAAM,EAAE,cAAc,CAAC,CAAC;IACrD,CAAC;IAEM,KAAK,CAAC,KAAK,CAChB,GAAW,EACX,IAAU,EACV,OAA4B,EAC5B,cAAkC;QAElC,IAAI,MAAM,GAAuB;YAC/B,MAAM,EAAE,OAAO;YACf,GAAG;YACH,IAAI;SACL,CAAC;QACF,IAAI,IAAA,kBAAU,EAAC,OAAO,CAAC,EAAE,CAAC;YACxB,MAAM,GAAG,EAAE,GAAG,MAAM,EAAE,GAAG,OAAO,EAAE,CAAC;QACrC,CAAC;QACD,OAAO,IAAI,CAAC,WAAW,CAAI,MAAM,EAAE,cAAc,CAAC,CAAC;IACrD,CAAC;IAEM,KAAK,CAAC,MAAM,CACjB,GAAW,EACX,OAA4B,EAC5B,cAAkC;QAElC,IAAI,MAAM,GAAuB;YAC/B,MAAM,EAAE,QAAQ;YAChB,GAAG;SACJ,CAAC;QACF,IAAI,IAAA,kBAAU,EAAC,OAAO,CAAC,EAAE,CAAC;YACxB,MAAM,GAAG,EAAE,GAAG,MAAM,EAAE,GAAG,OAAO,EAAE,CAAC;QACrC,CAAC;QACD,OAAO,IAAI,CAAC,WAAW,CAAI,MAAM,EAAE,cAAc,CAAC,CAAC;IACrD,CAAC;CAGF;AAhLD,kCAgLC","sourcesContent":["/* eslint-disable require-await */\nimport axios, { AxiosRequestConfig, AxiosError, AxiosInstance } from 'axios';\nimport http from 'http';\nimport https from 'https';\nimport { NETWORK_STATUS_ERR_MAP } from '../../constants';\nimport { ApiResponse, HttpClient, ResponseParser } from './types';\nimport { isNotEmpty } from '../../utils';\n\n/**\n * A wrapper around axios to make http requests\n *\n * @class AxiosClient\n * @classdesc\n * The `AxiosClient` class is a wrapper around the axios library that provides a simplified interface for making HTTP requests. It handles various types of errors and provides a consistent response format.\n *\n * @param {AxiosRequestConfig} options - The default options for the http client\n *\n * @example\n * const axiosClient = new AxiosClient({ timeout: 1000 * 10 });\n * const response = await axiosClient.post(\"https://example.com\", { foo: \"bar\" });\n * if (response.type === \"success\") {\n *   console.log(response.statusCode);\n *   console.log(response.responseBody);\n * } else if (response.type === \"application-error\") {\n *   console.log(response.statusCode);\n *   console.log(response.message);\n *   console.log(response.responseBody);\n * } else if (response.type === \"client-error\") {\n *   console.log(response.statusCode);\n *   console.log(response.message);\n * }\n */\nexport class AxiosClient implements HttpClient {\n  private options: AxiosRequestConfig;\n\n  private instance: AxiosInstance;\n\n  constructor(options?: AxiosRequestConfig) {\n    const defaultOptions = {\n      timeout: 1000 * 10,\n      // `withCredentials` indicates whether or not cross-site Access-Control requests should be made using credentials\n      withCredentials: false,\n      // `responseEncoding` indicates encoding to use for decoding responses (Node.js only),\n      responseEncoding: 'utf8',\n      // `maxBodyLength` (Node only option) defines the max size of the http request content in bytes allowed,\n      maxBodyLength: 1000 * 1000 * 10,\n      // `maxRedirects` defines the maximum number of redirects to follow in node.js,\n      maxRedirects: 5,\n      // `httpAgent` and `httpsAgent` define a custom agent to be used when performing http\n      httpAgent: new http.Agent({ keepAlive: true }),\n      // and https requests, respectively, in node.js. This allows options to be added like `keepAlive` that are not enabled by default.\n      httpsAgent: new https.Agent({ keepAlive: true }),\n    };\n    this.options = { ...defaultOptions, ...options };\n    this.instance = axios.create(this.options);\n  }\n\n  private async makeRequest<T>(\n    config: AxiosRequestConfig,\n    responseParser?: ResponseParser<T>,\n  ): Promise<ApiResponse<T>> {\n    let output: ApiResponse<T>;\n    try {\n      const requestConfig = config;\n      const response = await this.instance.request(requestConfig);\n      const { status, data, headers } = response;\n\n      if (responseParser) {\n        try {\n          const parsedData = responseParser(data);\n          output = {\n            type: 'success',\n            statusCode: status,\n            responseBody: parsedData,\n            headers,\n          };\n          return output;\n        } catch (error) {\n          const unknownError = error as Error;\n          return {\n            type: 'client-error',\n            // @ts-expect-error: Error has status\n            statusCode: unknownError.status || 500,\n            message: `Failed to parse response data: ${unknownError.message}`,\n          };\n        }\n      }\n      return { type: 'success', statusCode: status, responseBody: data, headers };\n    } catch (error) {\n      if (error instanceof AxiosError) {\n        const axiosError = error as AxiosError;\n        if (axiosError.response) {\n          const { response } = axiosError;\n          return {\n            type: 'application-error',\n            statusCode: response.status,\n            message: response.statusText,\n            responseBody: response.data,\n            headers: response.headers,\n          };\n        }\n        if (axiosError.code) {\n          const resp = NETWORK_STATUS_ERR_MAP[axiosError.code];\n          if (!resp) {\n            return {\n              type: 'client-error',\n              statusCode: 500,\n              message: `Unknown Error:${axiosError.message}`,\n            };\n          }\n          return {\n            type: 'client-error',\n            statusCode: resp.status,\n            message: resp.message,\n          };\n        }\n      }\n\n      const unknownError = error as Error;\n      const status = 500;\n      const message = unknownError.message || 'Unknown Error';\n\n      return { type: 'client-error', statusCode: status, message };\n    }\n  }\n\n  public async get<T>(\n    url: string,\n    options?: AxiosRequestConfig,\n    responseParser?: ResponseParser<T>,\n  ): Promise<ApiResponse<T>> {\n    let config: AxiosRequestConfig = {\n      method: 'get',\n      url,\n    };\n    if (isNotEmpty(options)) {\n      config = { ...config, ...options };\n    }\n    return this.makeRequest<T>(config, responseParser);\n  }\n\n  public async post<T>(\n    url: string,\n    data?: any,\n    options?: AxiosRequestConfig,\n    responseParser?: ResponseParser<T>,\n  ): Promise<ApiResponse<T>> {\n    let config: AxiosRequestConfig = {\n      method: 'post',\n      url,\n      data,\n    };\n    if (isNotEmpty(options)) {\n      config = { ...config, ...options };\n    }\n    return this.makeRequest<T>(config, responseParser);\n  }\n\n  public async put<T>(\n    url: string,\n    data?: any,\n    options?: AxiosRequestConfig,\n    responseParser?: ResponseParser<T>,\n  ): Promise<ApiResponse<T>> {\n    let config: AxiosRequestConfig = {\n      method: 'put',\n      url,\n      data,\n    };\n    if (isNotEmpty(options)) {\n      config = { ...config, ...options };\n    }\n    return this.makeRequest<T>(config, responseParser);\n  }\n\n  public async patch<T>(\n    url: string,\n    data?: any,\n    options?: AxiosRequestConfig,\n    responseParser?: ResponseParser<T>,\n  ): Promise<ApiResponse<T>> {\n    let config: AxiosRequestConfig = {\n      method: 'patch',\n      url,\n      data,\n    };\n    if (isNotEmpty(options)) {\n      config = { ...config, ...options };\n    }\n    return this.makeRequest<T>(config, responseParser);\n  }\n\n  public async delete<T>(\n    url: string,\n    options?: AxiosRequestConfig,\n    responseParser?: ResponseParser<T>,\n  ): Promise<ApiResponse<T>> {\n    let config: AxiosRequestConfig = {\n      method: 'delete',\n      url,\n    };\n    if (isNotEmpty(options)) {\n      config = { ...config, ...options };\n    }\n    return this.makeRequest<T>(config, responseParser);\n  }\n\n  // Add other HTTP methods as needed\n}\n"]}
|
|
235
|
+
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"axios_client.js","sourceRoot":"","sources":["../../../src/network/clients/axios_client.ts"],"names":[],"mappings":"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","sourcesContent":["/* eslint-disable require-await */\nimport axios, { AxiosRequestConfig, AxiosError, AxiosInstance } from 'axios';\nimport http from 'http';\nimport https from 'https';\nimport { NETWORK_STATUS_ERR_MAP } from '../../constants';\nimport { ApiResponse, HttpClient, ResponseParser, AxiosClientObservabilityConfig } from './types';\nimport { isNotEmpty } from '../../utils';\n\n/**\n * A wrapper around axios to make http requests\n *\n * @class AxiosClient\n * @classdesc\n * The `AxiosClient` class is a wrapper around the axios library that provides a simplified interface for making HTTP requests. It handles various types of errors and provides a consistent response format.\n *\n * @param {AxiosRequestConfig} options - The default options for the http client\n *\n * @example\n * const axiosClient = new AxiosClient({ timeout: 1000 * 10 });\n * const response = await axiosClient.post(\"https://example.com\", { foo: \"bar\" });\n * if (response.type === \"success\") {\n *   console.log(response.statusCode);\n *   console.log(response.responseBody);\n * } else if (response.type === \"application-error\") {\n *   console.log(response.statusCode);\n *   console.log(response.message);\n *   console.log(response.responseBody);\n * } else if (response.type === \"client-error\") {\n *   console.log(response.statusCode);\n *   console.log(response.message);\n * }\n */\nexport class AxiosClient implements HttpClient {\n  private options: AxiosRequestConfig;\n\n  private instance: AxiosInstance;\n\n  private observabilityConfig: AxiosClientObservabilityConfig;\n\n  constructor(options?: AxiosRequestConfig, observabilityConfig?: AxiosClientObservabilityConfig) {\n    const defaultOptions = {\n      timeout: 1000 * 10,\n      // `withCredentials` indicates whether or not cross-site Access-Control requests should be made using credentials\n      withCredentials: false,\n      // `responseEncoding` indicates encoding to use for decoding responses (Node.js only),\n      responseEncoding: 'utf8',\n      // `maxBodyLength` (Node only option) defines the max size of the http request content in bytes allowed,\n      maxBodyLength: 1000 * 1000 * 10,\n      // `maxRedirects` defines the maximum number of redirects to follow in node.js,\n      maxRedirects: 5,\n      // `httpAgent` and `httpsAgent` define a custom agent to be used when performing http\n      httpAgent: new http.Agent({ keepAlive: true }),\n      // and https requests, respectively, in node.js. This allows options to be added like `keepAlive` that are not enabled by default.\n      httpsAgent: new https.Agent({ keepAlive: true }),\n    };\n    this.options = { ...defaultOptions, ...options };\n    this.instance = axios.create(this.options);\n\n    // Merge with default config to eliminate null checks\n    const defaultObservabilityConfig: AxiosClientObservabilityConfig = {\n      logger: undefined,\n      statsClient: undefined,\n      defaultStatTags: {},\n    };\n    this.observabilityConfig = { ...defaultObservabilityConfig, ...observabilityConfig };\n  }\n\n  private async makeRequest<T>(\n    config: AxiosRequestConfig,\n    responseParser?: ResponseParser<T>,\n  ): Promise<ApiResponse<T>> {\n    const startTime = Date.now();\n    // Extract metadata for logging/metrics\n    const method = config.method?.toUpperCase() || 'UNKNOWN';\n    const url = config.url || 'unknown';\n    const statTags = {\n      requestMethod: method,\n      endpointPath: url,\n      ...this.observabilityConfig.defaultStatTags,\n    };\n\n    // Optional request logging\n    this.observabilityConfig.logger?.requestLog(`[HTTP] ${method} ${url} request`, {\n      method,\n      url,\n      statTags,\n    });\n\n    try {\n      const requestConfig = config;\n      const response = await this.instance.request(requestConfig);\n      const { status, data, headers } = response;\n      const duration = Date.now() - startTime;\n\n      // Add status code to statTags for better observability\n      const successStatTags = {\n        ...statTags,\n        statusCode: status,\n      };\n\n      // Optional response logging\n      this.observabilityConfig.logger?.responseLog(`[HTTP] ${method} ${url} response`, {\n        statusCode: status,\n        duration,\n        statTags: successStatTags,\n      });\n\n      // Optional success metrics\n      this.observabilityConfig.statsClient?.timing(\n        'outgoing_request_latency',\n        duration,\n        successStatTags,\n      );\n      this.observabilityConfig.statsClient?.increment('outgoing_request_count', 1, successStatTags);\n\n      if (responseParser) {\n        try {\n          const parsedData = responseParser(data);\n          return {\n            type: 'success',\n            statusCode: status,\n            responseBody: parsedData,\n            headers,\n          };\n        } catch (error) {\n          const unknownError = error as Error;\n          return {\n            type: 'client-error',\n            // @ts-expect-error: Error has status\n            statusCode: unknownError.status || 500,\n            message: `Failed to parse response data: ${unknownError.message}`,\n          };\n        }\n      }\n      return { type: 'success', statusCode: status, responseBody: data, headers };\n    } catch (error) {\n      const duration = Date.now() - startTime;\n\n      // Determine status code for error metrics\n      let errorStatusCode = 500; // Default to 500 for network/unknown errors\n      if (axios.isAxiosError(error)) {\n        const axiosError = error as AxiosError;\n        if (axiosError.response) {\n          errorStatusCode = axiosError.response.status;\n        }\n      }\n\n      // Add status code and error flag to statTags for better observability\n      const errorStatTags = {\n        ...statTags,\n        statusCode: errorStatusCode,\n        error: true,\n      };\n\n      // Optional error logging\n      this.observabilityConfig.logger?.error?.(`[HTTP] ${method} ${url} error`, {\n        error: (error as Error).message,\n        duration,\n        statTags: errorStatTags,\n      });\n\n      // Optional error metrics\n      this.observabilityConfig.statsClient?.timing(\n        'outgoing_request_latency',\n        duration,\n        errorStatTags,\n      );\n      this.observabilityConfig.statsClient?.increment('outgoing_request_count', 1, errorStatTags);\n\n      if (axios.isAxiosError(error)) {\n        const axiosError = error as AxiosError;\n        if (axiosError.response) {\n          const { response } = axiosError;\n          return {\n            type: 'application-error',\n            statusCode: response.status,\n            message: response.statusText,\n            responseBody: response.data,\n            headers: response.headers,\n          };\n        }\n        if (axiosError.code) {\n          const resp = NETWORK_STATUS_ERR_MAP[axiosError.code];\n          if (!resp) {\n            return {\n              type: 'client-error',\n              statusCode: 500,\n              message: `Unknown Error:${axiosError.message}`,\n            };\n          }\n          return {\n            type: 'client-error',\n            statusCode: resp.status,\n            message: resp.message,\n          };\n        }\n      }\n\n      const unknownError = error as Error;\n      const status = 500;\n      const message = unknownError.message || 'Unknown Error';\n\n      return { type: 'client-error', statusCode: status, message };\n    }\n  }\n\n  public async get<T>(\n    url: string,\n    options?: AxiosRequestConfig,\n    responseParser?: ResponseParser<T>,\n  ): Promise<ApiResponse<T>> {\n    let config: AxiosRequestConfig = {\n      method: 'get',\n      url,\n    };\n    if (isNotEmpty(options)) {\n      config = { ...config, ...options };\n    }\n    return this.makeRequest<T>(config, responseParser);\n  }\n\n  public async post<T>(\n    url: string,\n    data?: unknown,\n    options?: AxiosRequestConfig,\n    responseParser?: ResponseParser<T>,\n  ): Promise<ApiResponse<T>> {\n    let config: AxiosRequestConfig = {\n      method: 'post',\n      url,\n      data,\n    };\n    if (isNotEmpty(options)) {\n      config = { ...config, ...options };\n    }\n    return this.makeRequest<T>(config, responseParser);\n  }\n\n  public async put<T>(\n    url: string,\n    data?: unknown,\n    options?: AxiosRequestConfig,\n    responseParser?: ResponseParser<T>,\n  ): Promise<ApiResponse<T>> {\n    let config: AxiosRequestConfig = {\n      method: 'put',\n      url,\n      data,\n    };\n    if (isNotEmpty(options)) {\n      config = { ...config, ...options };\n    }\n    return this.makeRequest<T>(config, responseParser);\n  }\n\n  public async patch<T>(\n    url: string,\n    data?: unknown,\n    options?: AxiosRequestConfig,\n    responseParser?: ResponseParser<T>,\n  ): Promise<ApiResponse<T>> {\n    let config: AxiosRequestConfig = {\n      method: 'patch',\n      url,\n      data,\n    };\n    if (isNotEmpty(options)) {\n      config = { ...config, ...options };\n    }\n    return this.makeRequest<T>(config, responseParser);\n  }\n\n  public async delete<T>(\n    url: string,\n    options?: AxiosRequestConfig,\n    responseParser?: ResponseParser<T>,\n  ): Promise<ApiResponse<T>> {\n    let config: AxiosRequestConfig = {\n      method: 'delete',\n      url,\n    };\n    if (isNotEmpty(options)) {\n      config = { ...config, ...options };\n    }\n    return this.makeRequest<T>(config, responseParser);\n  }\n\n  // Add other HTTP methods as needed\n}\n"]}
|