@resolveio/server-lib 22.0.2 → 22.0.3

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.
@@ -33,6 +33,9 @@ export declare class MethodManager {
33
33
  private _debugCallMethodCronJobHits;
34
34
  private _debugSendQueueHits;
35
35
  private _enableDebug;
36
+ private _ready;
37
+ private _readyEmitter;
38
+ private _readyError;
36
39
  private _localActiveCounts;
37
40
  private _localWaitQueues;
38
41
  clientDir: string;
@@ -40,6 +43,15 @@ export declare class MethodManager {
40
43
  constructor();
41
44
  static create(websocketManager: WebSocketManager, monitorManagerFunction: MonitorManagerFunction, isWorkersEnabled: any, isWorkerInstance: any): MethodManager;
42
45
  private initialize;
46
+ private markReady;
47
+ private markReadyFailure;
48
+ onReady(callback: () => void): () => void;
49
+ private waitForReadyEvent;
50
+ private waitForReadyError;
51
+ private waitForReadyTimeout;
52
+ isReady(): boolean;
53
+ getReadyError(): any;
54
+ waitUntilReady(timeoutMs?: number): Promise<void>;
43
55
  getMethod(methodName: string): MethodAllModel;
44
56
  methods(method: MethodModel): void;
45
57
  private reportMethodError;
@@ -86,9 +86,11 @@ Object.defineProperty(exports, "__esModule", { value: true });
86
86
  exports.MethodManager = exports.AWS = void 0;
87
87
  var client_s3_1 = require("@aws-sdk/client-s3");
88
88
  var client_sesv2_1 = require("@aws-sdk/client-sesv2");
89
+ var events_1 = require("events");
89
90
  var fs = require("fs");
90
91
  var nodemailer = require("nodemailer");
91
92
  var path = require("path");
93
+ var promises_1 = require("timers/promises");
92
94
  var email_history_collection_1 = require("../collections/email-history.collection");
93
95
  var flag_collection_1 = require("../collections/flag.collection");
94
96
  var log_collection_1 = require("../collections/log.collection");
@@ -290,6 +292,9 @@ var MethodManager = /** @class */ (function () {
290
292
  this._debugCallMethodCronJobHits = 0;
291
293
  this._debugSendQueueHits = 0;
292
294
  this._enableDebug = false;
295
+ this._ready = false;
296
+ this._readyEmitter = new events_1.EventEmitter();
297
+ this._readyError = null;
293
298
  this._localActiveCounts = new Map();
294
299
  this._localWaitQueues = new Map();
295
300
  this.clientDir = '';
@@ -327,12 +332,13 @@ var MethodManager = /** @class */ (function () {
327
332
  }
328
333
  }
329
334
  setImmediate(function () { return __awaiter(_this, void 0, void 0, function () {
330
- var flag;
335
+ var flag, error_2;
331
336
  return __generator(this, function (_a) {
332
337
  switch (_a.label) {
333
- case 0:
334
- // Methods
335
- return [4 /*yield*/, (0, cron_jobs_1.loadServerCronJobs)()];
338
+ case 0:
339
+ _a.trys.push([0, 4, , 5]);
340
+ // Methods
341
+ return [4 /*yield*/, (0, cron_jobs_1.loadServerCronJobs)()];
336
342
  case 1:
337
343
  // Methods
338
344
  _a.sent();
@@ -363,7 +369,14 @@ var MethodManager = /** @class */ (function () {
363
369
  return [4 /*yield*/, this.loadPendingEmails()];
364
370
  case 3:
365
371
  _a.sent();
366
- return [2 /*return*/];
372
+ this.markReady();
373
+ return [3 /*break*/, 5];
374
+ case 4:
375
+ error_2 = _a.sent();
376
+ console.error(new Date(), 'Method Manager init failed', error_2);
377
+ this.markReadyFailure(error_2);
378
+ return [3 /*break*/, 5];
379
+ case 5: return [2 /*return*/];
367
380
  }
368
381
  });
369
382
  }); });
@@ -423,6 +436,116 @@ var MethodManager = /** @class */ (function () {
423
436
  this.setupEmailWatcher();
424
437
  }
425
438
  };
439
+ MethodManager.prototype.markReady = function () {
440
+ if (this._ready) {
441
+ return;
442
+ }
443
+ this._ready = true;
444
+ this._readyEmitter.emit('ready');
445
+ this._readyEmitter.removeAllListeners('ready');
446
+ this._readyEmitter.removeAllListeners('readyError');
447
+ };
448
+ MethodManager.prototype.markReadyFailure = function (error) {
449
+ if (this._ready) {
450
+ return;
451
+ }
452
+ this._readyError = error;
453
+ this._readyEmitter.emit('readyError', error);
454
+ this._readyEmitter.removeAllListeners('ready');
455
+ this._readyEmitter.removeAllListeners('readyError');
456
+ };
457
+ MethodManager.prototype.onReady = function (callback) {
458
+ var _this = this;
459
+ if (this._ready) {
460
+ callback();
461
+ return function () { };
462
+ }
463
+ if (this._readyError) {
464
+ return function () { };
465
+ }
466
+ var handleReady = function () {
467
+ callback();
468
+ };
469
+ this._readyEmitter.once('ready', handleReady);
470
+ return function () {
471
+ _this._readyEmitter.removeListener('ready', handleReady);
472
+ };
473
+ };
474
+ MethodManager.prototype.waitForReadyEvent = function () {
475
+ return __awaiter(this, void 0, void 0, function () {
476
+ return __generator(this, function (_a) {
477
+ switch (_a.label) {
478
+ case 0: return [4 /*yield*/, (0, events_1.once)(this._readyEmitter, 'ready')];
479
+ case 1:
480
+ _a.sent();
481
+ return [2 /*return*/];
482
+ }
483
+ });
484
+ });
485
+ };
486
+ MethodManager.prototype.waitForReadyError = function () {
487
+ return __awaiter(this, void 0, void 0, function () {
488
+ var _a, error;
489
+ return __generator(this, function (_b) {
490
+ switch (_b.label) {
491
+ case 0: return [4 /*yield*/, (0, events_1.once)(this._readyEmitter, 'readyError')];
492
+ case 1:
493
+ _a = __read.apply(void 0, [_b.sent(), 1]), error = _a[0];
494
+ throw error || new Error('MethodManager failed to initialize');
495
+ }
496
+ });
497
+ });
498
+ };
499
+ MethodManager.prototype.waitForReadyTimeout = function (timeoutMs) {
500
+ return __awaiter(this, void 0, void 0, function () {
501
+ return __generator(this, function (_a) {
502
+ switch (_a.label) {
503
+ case 0: return [4 /*yield*/, (0, promises_1.setTimeout)(timeoutMs)];
504
+ case 1:
505
+ _a.sent();
506
+ throw new Error('MethodManager ready timeout');
507
+ }
508
+ });
509
+ });
510
+ };
511
+ MethodManager.prototype.isReady = function () {
512
+ return this._ready;
513
+ };
514
+ MethodManager.prototype.getReadyError = function () {
515
+ return this._readyError;
516
+ };
517
+ MethodManager.prototype.waitUntilReady = function () {
518
+ return __awaiter(this, arguments, void 0, function (timeoutMs) {
519
+ if (timeoutMs === void 0) { timeoutMs = 30000; }
520
+ return __generator(this, function (_a) {
521
+ switch (_a.label) {
522
+ case 0:
523
+ if (this._ready) {
524
+ return [2 /*return*/];
525
+ }
526
+ if (this._readyError) {
527
+ throw this._readyError;
528
+ }
529
+ if (!(!timeoutMs || timeoutMs <= 0)) return [3 /*break*/, 2];
530
+ return [4 /*yield*/, Promise.race([
531
+ this.waitForReadyEvent(),
532
+ this.waitForReadyError()
533
+ ])];
534
+ case 1:
535
+ _a.sent();
536
+ return [2 /*return*/];
537
+ case 2: return [4 /*yield*/, Promise.race([
538
+ this.waitForReadyEvent(),
539
+ this.waitForReadyError(),
540
+ this.waitForReadyTimeout(timeoutMs)
541
+ ])];
542
+ case 3:
543
+ _a.sent();
544
+ return [2 /*return*/];
545
+ }
546
+ });
547
+ });
548
+ };
426
549
  MethodManager.prototype.getMethod = function (methodName) {
427
550
  return this._methods[methodName];
428
551
  };
@@ -686,7 +809,7 @@ var MethodManager = /** @class */ (function () {
686
809
  !methodName.startsWith('monitor-') &&
687
810
  !methodName.startsWith('log');
688
811
  executeWithExistingSession_1 = function () { return __awaiter(_this, void 0, void 0, function () {
689
- var monitor, res, error_2, err_3, _a, normalizedError, resolvedCorrelationId, error_3;
812
+ var monitor, res, error_3, err_3, _a, normalizedError, resolvedCorrelationId, error_4;
690
813
  var _b;
691
814
  return __generator(this, function (_c) {
692
815
  switch (_c.label) {
@@ -716,8 +839,8 @@ var MethodManager = /** @class */ (function () {
716
839
  _c.sent();
717
840
  return [3 /*break*/, 6];
718
841
  case 5:
719
- error_2 = _c.sent();
720
- console.error('Error recording text message metric:', error_2);
842
+ error_3 = _c.sent();
843
+ console.error('Error recording text message metric:', error_3);
721
844
  return [3 /*break*/, 6];
722
845
  case 6: return [2 /*return*/, res];
723
846
  case 7:
@@ -760,8 +883,8 @@ var MethodManager = /** @class */ (function () {
760
883
  _c.sent();
761
884
  return [3 /*break*/, 12];
762
885
  case 11:
763
- error_3 = _c.sent();
764
- console.error('Error recording text message metric:', error_3);
886
+ error_4 = _c.sent();
887
+ console.error('Error recording text message metric:', error_4);
765
888
  return [3 /*break*/, 12];
766
889
  case 12:
767
890
  if (!!process.env.IS_WORKER_INSTANCE) return [3 /*break*/, 14];
@@ -791,7 +914,7 @@ var MethodManager = /** @class */ (function () {
791
914
  if (shouldStartTransaction) {
792
915
  monitor_2 = null;
793
916
  return [2 /*return*/, resolveio_server_app_1.ResolveIOServer.getMongoManager().oneTimeTransaction(function () { return __awaiter(_this, void 0, void 0, function () {
794
- var res, error_4, err_4, _a, normalizedError, resolvedCorrelationId, error_5;
917
+ var res, error_5, err_4, _a, normalizedError, resolvedCorrelationId, error_6;
795
918
  var _b;
796
919
  return __generator(this, function (_c) {
797
920
  switch (_c.label) {
@@ -822,8 +945,8 @@ var MethodManager = /** @class */ (function () {
822
945
  _c.sent();
823
946
  return [3 /*break*/, 6];
824
947
  case 5:
825
- error_4 = _c.sent();
826
- console.error('Error recording text message metric:', error_4);
948
+ error_5 = _c.sent();
949
+ console.error('Error recording text message metric:', error_5);
827
950
  return [3 /*break*/, 6];
828
951
  case 6: return [2 /*return*/, res];
829
952
  case 7:
@@ -866,8 +989,8 @@ var MethodManager = /** @class */ (function () {
866
989
  _c.sent();
867
990
  return [3 /*break*/, 12];
868
991
  case 11:
869
- error_5 = _c.sent();
870
- console.error('Error recording text message metric:', error_5);
992
+ error_6 = _c.sent();
993
+ console.error('Error recording text message metric:', error_6);
871
994
  return [3 /*break*/, 12];
872
995
  case 12:
873
996
  if (!!process.env.IS_WORKER_INSTANCE) return [3 /*break*/, 14];
@@ -1209,7 +1332,7 @@ var MethodManager = /** @class */ (function () {
1209
1332
  }
1210
1333
  emailProvider = (!mailOptions.force_ses && this_1._mailerCustom) ? 'custom' : 'ses';
1211
1334
  (!mailOptions.force_ses && this_1._mailerCustom ? this_1._mailerCustom : this_1._mailerSES).sendMail(mailOptions, function (err) { return __awaiter(_this, void 0, void 0, function () {
1212
- var metricStatus, error_6, error_7;
1335
+ var metricStatus, error_7, error_8;
1213
1336
  return __generator(this, function (_a) {
1214
1337
  switch (_a.label) {
1215
1338
  case 0:
@@ -1246,12 +1369,12 @@ var MethodManager = /** @class */ (function () {
1246
1369
  _a.label = 7;
1247
1370
  case 7: return [3 /*break*/, 14];
1248
1371
  case 8:
1249
- error_6 = _a.sent();
1250
- console.error('Error in sendMail callback:', error_6);
1372
+ error_7 = _a.sent();
1373
+ console.error('Error in sendMail callback:', error_7);
1251
1374
  return [4 /*yield*/, email_history_collection_1.EmailHistories.updateOne({ _id: emailHistory._id }, {
1252
1375
  $set: {
1253
1376
  status: 'failed',
1254
- error: typeof error_6 === 'string' ? error_6 : this.safeStringify(error_6),
1377
+ error: typeof error_7 === 'string' ? error_7 : this.safeStringify(error_7),
1255
1378
  completedAt: new Date(),
1256
1379
  },
1257
1380
  })];
@@ -1271,8 +1394,8 @@ var MethodManager = /** @class */ (function () {
1271
1394
  _a.sent();
1272
1395
  return [3 /*break*/, 13];
1273
1396
  case 12:
1274
- error_7 = _a.sent();
1275
- console.error('Error recording email metric:', error_7);
1397
+ error_8 = _a.sent();
1398
+ console.error('Error recording email metric:', error_8);
1276
1399
  return [3 /*break*/, 13];
1277
1400
  case 13: return [7 /*endfinally*/];
1278
1401
  case 14: return [2 /*return*/];
@@ -1 +1 @@
1
- {"version":3,"sources":["../../src/managers/method.manager.ts"],"names":[],"mappings":"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","file":"method.manager.js","sourcesContent":["import { S3 } from '@aws-sdk/client-s3';\nimport { SESv2Client, SendEmailCommand } from '@aws-sdk/client-sesv2';\nimport * as fs from 'fs';\nimport * as nodemailer from 'nodemailer';\nimport * as path from 'path';\nimport { EmailHistories } from '../collections/email-history.collection';\nimport { Flags } from '../collections/flag.collection';\nimport { Logs } from '../collections/log.collection';\nimport { loadServerCronJobs } from '../fixtures/cron-jobs';\nimport { loadServerInit } from '../fixtures/init';\nimport { loadAccountMethods } from '../methods/accounts';\nimport { loadAWSMethods } from '../methods/aws';\nimport { loadAiTerminalMethods } from '../methods/ai-terminal';\nimport { loadCollectionMethods } from '../methods/collections';\nimport { loadCounterMethods } from '../methods/counters';\nimport { loadCronJobMethods } from '../methods/cron-jobs';\nimport { loadFlagUpdatesMethods } from '../methods/flag-updates';\nimport { loadFlagMethods } from '../methods/flags';\nimport { loadLogMethods } from '../methods/logs';\nimport { loadMonitorMethods } from '../methods/monitor';\nimport { loadMongoExplorerMethods } from '../methods/mongo-explorer';\nimport { loadPublicationMethods } from '../methods/publications';\nimport { loadPDFMethods } from '../methods/pdf';\nimport { loadReportBuilderMethods } from '../methods/report-builder';\nimport { loadSupportMethods } from '../methods/support';\nimport { EmailHistoryModel, EmailHistoryOccurrence } from '../models/email-history.model';\nimport { MethodAllModel, MethodModel } from '../models/method.model';\nimport { ResolveIOServer } from '../resolveio-server-app';\nimport { getBinarySize, objectIdHexString } from '../util/common';\nimport { ErrorReporter } from '../util/error-reporter';\nimport { ensureErrorWithCorrelation, getCorrelationId, runWithCorrelationContext } from '../util/error-tracking';\nimport { MonitorManagerFunction } from './monitor.manager';\nimport { WebSocketManager } from './websocket.manager';\nimport { recordEmailMetric, recordTextMessageMetric } from './communication-metric.manager';\n\ninterface SendEmailOptions {\n\tcorrelationId?: string;\n\tmeta?: Record<string, any>;\n}\n\nfunction appendCorrelationIdToSubject(subject: string, correlationId?: string): string {\n\tif (!correlationId) {\n\t\treturn subject;\n\t}\n\n\tconst correlationTag = `[${correlationId}]`;\n\n\tif (subject && subject.includes(correlationTag)) {\n\t\treturn subject;\n\t}\n\n\treturn `${subject} ${correlationTag}`.trim();\n}\n\nfunction createEmailOccurrence(subject: string, text?: string, html?: string, meta?: Record<string, any>): EmailHistoryOccurrence {\n\treturn {\n\t\t_id: objectIdHexString(),\n\t\tcreatedAt: new Date(),\n\t\tsubject,\n\t\ttext,\n\t\thtml,\n\t\tmeta\n\t};\n}\n\nfunction formatGroupedEmailContent(correlationId: string, occurrences: EmailHistoryOccurrence[]): { text: string; html: string } {\n\tconst lines: string[] = [];\n\tlines.push(`Correlation ID: ${correlationId}`);\n\n\toccurrences.forEach((occurrence, index) => {\n\t\tconst timestamp = occurrence.createdAt instanceof Date ? occurrence.createdAt.toISOString() : new Date(occurrence.createdAt).toISOString();\n\t\tlines.push('');\n\t\tlines.push(`Occurrence #${index + 1} (${timestamp})`);\n\t\tlines.push(`Subject: ${occurrence.subject}`);\n\t\tif (occurrence.text) {\n\t\t\tlines.push(occurrence.text);\n\t\t}\n\t});\n\n\tconst htmlSections = occurrences.map((occurrence, index) => {\n\t\tconst timestamp = occurrence.createdAt instanceof Date ? occurrence.createdAt.toISOString() : new Date(occurrence.createdAt).toISOString();\n\t\tconst escapedText = occurrence.text ? occurrence.text.replace(/&/g, '&amp;').replace(/</g, '&lt;').replace(/>/g, '&gt;') : '';\n\t\treturn `<div><h4>Occurrence #${index + 1} (${timestamp})</h4><p><strong>Subject:</strong> ${occurrence.subject}</p>${escapedText ? `<pre>${escapedText}</pre>` : ''}</div>`;\n\t});\n\n\tconst html = [\n\t\t`<p><strong>Correlation ID:</strong> ${correlationId}</p>`,\n\t\t...htmlSections\n\t].join('');\n\n\treturn {\n\t\ttext: lines.join('\\n'),\n\t\thtml\n\t};\n}\n\nfunction createNodeMailerSESV2Transport(sesClient: SESv2Client): nodemailer.Transporter {\n\tconst transport: any = {\n\t\tname: 'resolveio-sesv2-transport',\n\t\tversion: '1.0.0',\n\t\tsend: (mail: any, callback: any) => {\n\t\t\tconst stream = mail.message.createReadStream();\n\t\t\tconst chunks: Uint8Array[] = [];\n\t\t\tlet didFinish = false;\n\n\t\t\tconst finish = (error: any, info?: any) => {\n\t\t\t\tif (didFinish) {\n\t\t\t\t\treturn;\n\t\t\t\t}\n\n\t\t\t\tdidFinish = true;\n\t\t\t\tcallback(error, info);\n\t\t\t};\n\n\t\t\tstream.on('data', (chunk) => {\n\t\t\t\tconst chunkData = Buffer.isBuffer(chunk) ? chunk : Buffer.from(chunk);\n\t\t\t\tchunks.push(new Uint8Array(chunkData));\n\t\t\t});\n\n\t\t\tstream.on('error', (error) => {\n\t\t\t\tfinish(error);\n\t\t\t});\n\n\t\t\tstream.on('end', async () => {\n\t\t\t\ttry {\n\t\t\t\t\tconst rawData = Buffer.concat(chunks);\n\t\t\t\t\tconst rawMessageData = new Uint8Array(rawData);\n\t\t\t\t\tconst envelope = typeof mail.message.getEnvelope === 'function' ? mail.message.getEnvelope() : mail.data?.envelope;\n\n\t\t\t\t\tconst fromEmailAddress = envelope?.from || undefined;\n\t\t\t\t\tconst toAddresses = envelope?.to\n\t\t\t\t\t\t? (Array.isArray(envelope.to) ? envelope.to : [envelope.to]).filter(Boolean)\n\t\t\t\t\t\t: [];\n\n\t\t\t\t\tconst replyToAddresses = mail.data?.replyTo\n\t\t\t\t\t\t? (Array.isArray(mail.data.replyTo) ? mail.data.replyTo : [mail.data.replyTo]).filter(Boolean)\n\t\t\t\t\t\t: undefined;\n\n\t\t\t\t\tconst response = await sesClient.send(new SendEmailCommand({\n\t\t\t\t\t\tFromEmailAddress: fromEmailAddress,\n\t\t\t\t\t\tDestination: toAddresses.length ? { ToAddresses: toAddresses } : undefined,\n\t\t\t\t\t\tReplyToAddresses: replyToAddresses,\n\t\t\t\t\t\t\tContent: {\n\t\t\t\t\t\t\t\tRaw: {\n\t\t\t\t\t\t\t\t\tData: rawMessageData\n\t\t\t\t\t\t\t\t}\n\t\t\t\t\t\t\t}\n\t\t\t\t\t\t}));\n\n\t\t\t\t\tfinish(null, {\n\t\t\t\t\t\tenvelope,\n\t\t\t\t\t\tmessageId: response.MessageId,\n\t\t\t\t\t\tresponse: response.MessageId\n\t\t\t\t\t});\n\t\t\t\t}\n\t\t\t\tcatch (error) {\n\t\t\t\t\tfinish(error);\n\t\t\t\t}\n\t\t\t});\n\t\t}\n\t};\n\n\treturn nodemailer.createTransport(transport);\n}\n\nexport class AWS {\n\tprivate _s3: S3 = null;\n\tprivate _s3USEast1: S3 = null;\n\n\tconstructor() {}\n\n\tpublic create() {\n\t\tconst aws = new AWS();\n\t\taws.initialize();\n\t\treturn aws;\n\t}\n\n\tprivate initialize() {\n\n\t}\n\n\tpublic s3(): S3 {\n\t\tif (this._s3) {\n\t\t\treturn this._s3;\n\t\t}\n\n\t\tthis._s3 = new S3({\n\t\t\tcredentials: {\n\t\t\t\taccessKeyId: process.env.AWS_ACCESS_KEY,\n\t\t\t\tsecretAccessKey: process.env.AWS_SECRET_ACCESS_KEY\n\t\t\t},\n\t\t\tregion: process.env.AWS_REGION,\n\t\t\tapiVersion: '2006-03-01'\n\t\t});\n\n\t\treturn this._s3;\n\t}\n\n\tpublic s3USEast1(): S3 {\n\t\tif (process.env.AWS_REGION === 'us-east-1') {\n\t\t\treturn this.s3();\n\t\t}\n\t\telse {\n\t\t\tif (this._s3USEast1) {\n\t\t\t\treturn this._s3USEast1;\n\t\t\t}\n\t\t\t\n\t\t\tthis._s3USEast1 = new S3({\n\t\t\t\tcredentials: {\n\t\t\t\t\taccessKeyId: process.env.AWS_ACCESS_KEY,\n\t\t\t\t\tsecretAccessKey: process.env.AWS_SECRET_ACCESS_KEY\n\t\t\t\t},\n\t\t\t\tregion: 'us-east-1',\n\t\t\t\tapiVersion: '2006-03-01'\n\t\t\t});\n\t\n\t\t\treturn this._s3USEast1;\n\t\t}\n\t}\n}\n\nexport class MethodManager {\n\tprivate _websocketManager: WebSocketManager;\n\tpublic _methods: MethodModel = {};\n\tprivate _mailerSES: nodemailer.Transporter;\n\tprivate _mailerCustom: nodemailer.Transporter;\n\tprivate _aws: AWS;\n\tprivate _monitorManagerFunction: MonitorManagerFunction;\n\tprivate _isWorkersEnabled = false;\n\tprivate _isWorkerInstance = false;\n\n\tprivate emailQueue: Set<string> = new Set(); // Set to store pending email IDs\n\tprivate isEmailProcessing = false;\n\tprivate readonly _emailProcessingDelayMs = 5000;\n\n\tprivate _debugcallMethodHits = 0;\n\tprivate _debugCallMethodHits = 0;\n\tprivate _debugCallMethodCronJobHits = 0;\n\tprivate _debugSendQueueHits = 0;\n\tprivate _enableDebug = false;\n\n\tprivate _localActiveCounts: Map<string, number> = new Map();\n\tprivate _localWaitQueues: Map<string, Array<() => void>> = new Map();\n\n\tpublic clientDir = '';\n\tpublic serverConfig: Record<string, any> = {};\n\n\tconstructor() {}\n\n\tstatic create(websocketManager: WebSocketManager, monitorManagerFunction: MonitorManagerFunction, isWorkersEnabled, isWorkerInstance) {\n\t\tconst methodManager = new MethodManager();\n\t\tmethodManager.initialize(websocketManager, monitorManagerFunction, isWorkersEnabled, isWorkerInstance);\n\t\treturn methodManager;\n\t}\n\n\tprivate initialize(websocketManager: WebSocketManager, monitorManagerFunction: MonitorManagerFunction, isWorkersEnabled, isWorkerInstance) {\n\t\tthis._websocketManager = websocketManager;\n\t\tthis._monitorManagerFunction = monitorManagerFunction;\n\t\tthis._isWorkersEnabled = isWorkersEnabled;\n\t\tthis._isWorkerInstance = isWorkerInstance;\n\t\t\n\t\tthis.clientDir = ResolveIOServer.getClientDir();\n\t\tthis.serverConfig = ResolveIOServer.getServerConfig();\n\n\t\t// Fixtures\n\t\tif (!process.env.IS_WORKERS_ENABLED || process.env.IS_WORKERS_ENABLED === 'false' || (process.env.IS_WORKER_INSTANCE === 'true' && process.env.WORKER_INDEX === '0')) {\n\t\t\tif (!process.env.NODE_APP_INSTANCE || process.env.NODE_APP_INSTANCE === '0') {\n\t\t\t\tsetTimeout(async () => {\n\t\t\t\t\tconsole.log(new Date(), 'Start Server Fixture');\n\t\t\t\t\tawait loadServerInit();\n\t\t\t\t\tconsole.log(new Date(), 'End Server Fixture');\n\t\t\t\t}, 5000);\n\t\t\t}\n\t\t}\n\t\t\n\t\tsetImmediate(async () => {\n\t\t\t// Methods\n\t\t\tawait loadServerCronJobs();\n\n\t\t\tloadAccountMethods(this);\n\t\t\tloadAWSMethods(this);\n\t\t\tloadAiTerminalMethods(this);\n\t\t\tloadCollectionMethods(this);\n\t\t\tloadCounterMethods(this);\n\t\t\tloadLogMethods(this);\n\t\t\tloadPDFMethods(this);\n\t\t\tloadCronJobMethods(this);\n\t\t\tloadFlagMethods(this);\n\t\t\tloadFlagUpdatesMethods(this);\n\t\t\tloadReportBuilderMethods(this);\n\t\t\tloadSupportMethods(this);\n\t\t\tloadMonitorMethods(this);\n\t\t\tloadMongoExplorerMethods(this);\n\t\t\tloadPublicationMethods(this);\n\n\t\t\tlet flag = await Flags.findOne({type: 'Enable Debug'});\n\t\n\t\t\tif (flag && flag.value) {\n\t\t\t\tthis._enableDebug = true;\n\t\t\t}\n\t\t\telse {\n\t\t\t\tthis._enableDebug = false;\n\t\t\t}\n\n\t\t\tawait this.loadPendingEmails();\n\t\t\t});\n\t\t\t\n\t\t\tthis._aws = new AWS();\n\n\t\t\tconst sesRegion = process.env.AWS_SES_REGION || process.env.AWS_REGION || process.env.AWS_DEFAULT_REGION || 'us-east-1';\n\t\t\tconst sesCredentials = process.env.AWS_ACCESS_KEY && process.env.AWS_SECRET_ACCESS_KEY ? {\n\t\t\t\taccessKeyId: process.env.AWS_ACCESS_KEY,\n\t\t\t\tsecretAccessKey: process.env.AWS_SECRET_ACCESS_KEY,\n\t\t\t\tsessionToken: process.env.AWS_SESSION_TOKEN\n\t\t\t} : undefined;\n\n\t\t\tthis._mailerSES = createNodeMailerSESV2Transport(new SESv2Client({\n\t\t\t\tregion: sesRegion,\n\t\t\t\tcredentials: sesCredentials\n\t\t\t}));\n\t\t\t\n\t\t\tif (!ResolveIOServer.getSESMail()) {\n\t\t\t\tthis._mailerCustom = nodemailer.createTransport({\n\t\t\t\t\thost: ResolveIOServer.getServerConfig()['MAIL_HOST'], // 'smtp.office365.com', // Office 365 server\n\t\t\t\t\tport: ResolveIOServer.getServerConfig()['MAIL_PORT'], //587, // secure SMTP\n\t\t\t\tsecure: false, // false for TLS - as a boolean not string - but the default is false so just remove this completely\n\t\t\t\tauth: {\n\t\t\t\t\tuser: ResolveIOServer.getServerConfig()['MAIL_USERNAME'],\n\t\t\t\t\tpass: ResolveIOServer.getServerConfig()['MAIL_PASSWORD']\n\t\t\t\t},\n\t\t\t\ttls: {\n\t\t\t\t\tciphers: 'SSLv3'\n\t\t\t\t}\n\t\t\t});\n\t\t}\n\n\t\tsetInterval(async () => {\n\t\t\tlet flag = await Flags.findOne({type: 'Enable Debug'});\n\t\n\t\t\tif (flag && flag.value) {\n\t\t\t\tthis._enableDebug = true;\n\t\t\t}\n\t\t\telse {\n\t\t\t\tthis._enableDebug = false;\n\t\t\t}\n\n\t\t\tif (this._enableDebug) {\n\t\t\t\tconsole.log(new Date(), 'Method Manager', 'Send Queue Hits', this._debugSendQueueHits);\n\t\t\t\tconsole.log(new Date(), 'Method Manager', 'Call Method Internal Hits', this._debugcallMethodHits);\n\t\t\t\tconsole.log(new Date(), 'Method Manager', 'Call Method Hits', this._debugCallMethodHits);\n\t\t\t\tconsole.log(new Date(), 'Method Manager', 'Call Method Cron Hits', this._debugCallMethodCronJobHits);\n\t\t\t}\n\n\t\t\tthis._debugcallMethodHits = 0;\n\t\t\tthis._debugCallMethodHits = 0;\n\t\t\tthis._debugCallMethodCronJobHits = 0;\n\t\t\tthis._debugSendQueueHits = 0;\n\t\t}, 60000);\n\n\t\tif (!this._isWorkersEnabled || this._isWorkerInstance) {\n\t\t\tthis.setupEmailWatcher();\n\t\t}\n\t}\n\n\tpublic getMethod(methodName: string): MethodAllModel {\n\t\treturn this._methods[methodName];\n\t}\n\n\t// Add methods to private methods object\n\tpublic methods(method: MethodModel) {\n\t\tthis._methods = Object.assign(this._methods, method);\n\t}\n\n\tprivate async reportMethodError(\n\t\tsubject: string,\n\t\tcorrelationId: string,\n\t\tcontext: Record<string, any> | string,\n\t\tmeta: Record<string, any>,\n\t\tstack?: string\n\t) {\n\t\tconst metadata = Object.assign({}, meta || {});\n\t\tif (correlationId && !metadata.correlationId) {\n\t\t\tmetadata.correlationId = correlationId;\n\t\t}\n\n\t\tawait ErrorReporter.report({\n\t\t\tsourceApp: 'method-manager',\n\t\t\tmessage: subject,\n\t\t\tenvironment: this.serverConfig?.ROOT_URL,\n\t\t\tclientSlug: ResolveIOServer.getClientName(),\n\t\t\tclientName: this.serverConfig?.CLIENT_NAME,\n\t\t\tseverity: 'error',\n\t\t\tstack,\n\t\t\tcontext,\n\t\t\tmetadata,\n\t\t\tcorrelationId\n\t\t});\n\t}\n\n\tpublic async callMethodCron(method: string, ...methodData: any[]) {\n\t\tthis._debugCallMethodCronJobHits += 1;\n\n\t\tconst existingCorrelationId = getCorrelationId();\n\t\tconst correlationId = existingCorrelationId || objectIdHexString();\n\n\t\tconst execute = async () => {\n\t\t\tconst cronMethod = this._methods[method];\n\n\t\t\tif (!cronMethod) {\n\t\t\t\tconsole.log('No Method: ' + method);\n\n\t\t\t\tawait this.reportMethodError(\n\t\t\t\t\t'SERVER - Error Detected - ' + this.serverConfig['CLIENT_NAME'],\n\t\t\t\t\tcorrelationId,\n\t\t\t\t\t{ message: 'No Method registered for cron execution', method },\n\t\t\t\t\t{ context: 'callMethodCron', method }\n\t\t\t\t);\n\n\t\t\t\tthrow new Error('No Method: ' + method);\n\t\t\t}\n\t\t\t\n\t\t\tif ((methodData.length > 1 || methodData[0]) && !cronMethod.skipValidation) {\n\t\t\t\tif (!cronMethod.check) {\n\t\t\t\t\tconsole.error(new Date(), 'No Check Function For Cron Method ' + method);\n\n\t\t\t\t\tawait this.reportMethodError(\n\t\t\t\t\t\t'SERVER - Error Detected - ' + this.serverConfig['CLIENT_NAME'],\n\t\t\t\t\t\tcorrelationId,\n\t\t\t\t\t\t{ message: 'Missing check function for cron method', method },\n\t\t\t\t\t\t{ context: 'callMethodCron-validation', method }\n\t\t\t\t\t);\n\t\t\n\t\t\t\t\tthrow new Error('No Check Function For Cron Method ' + method);\n\t\t\t\t}\n\t\t\t\telse if (!cronMethod.check._schema) {\n\t\t\t\t\tconsole.error(new Date(), 'No Check Schema For Cron Method ' + method);\n\n\t\t\t\t\tawait this.reportMethodError(\n\t\t\t\t\t\t'SERVER - Error Detected - ' + this.serverConfig['CLIENT_NAME'],\n\t\t\t\t\t\tcorrelationId,\n\t\t\t\t\t\t{ message: 'Missing check schema for cron method', method },\n\t\t\t\t\t\t{ context: 'callMethodCron-validation', method }\n\t\t\t\t\t);\n\t\t\n\t\t\t\t\tthrow new Error('No Check Schema For Cron Method ' + method);\n\t\t\t\t}\n\t\t\t\telse {\n\t\t\t\t\tconst valObj = {};\n\t\t\t\t\tconst valKeys = Object.keys(cronMethod.check._schema);\n\n\t\t\t\t\tconst rootKeys = valKeys.filter(a => !a.includes('.'));\n\t\t\t\t\t\n\t\t\t\t\tfor (let i = 0; i < methodData.length; i++) {\n\t\t\t\t\t\tvalObj[rootKeys[i]] = methodData[i];\n\t\t\t\t\t}\n\n\t\t\t\t\ttry {\n\t\t\t\t\t\tcronMethod.check.validate(valObj);\n\t\t\t\t\t}\n\t\t\t\t\tcatch (err) {\n\t\t\t\t\t\tconsole.error(new Date(), 'Error in Cron Method Check (' + method + ')', err);\n\n\t\t\t\t\t\tconst { error: normalizedError, correlationId: resolvedCorrelationId } = ensureErrorWithCorrelation(err, correlationId);\n\n\t\t\t\t\t\tawait this.reportMethodError(\n\t\t\t\t\t\t\t'SERVER - Error Detected - ' + this.serverConfig['CLIENT_NAME'],\n\t\t\t\t\t\t\tresolvedCorrelationId,\n\t\t\t\t\t\t\t{\n\t\t\t\t\t\t\t\tmessage: 'Match error on cron method',\n\t\t\t\t\t\t\t\tmethod,\n\t\t\t\t\t\t\t\tdata: valObj,\n\t\t\t\t\t\t\t\tvalidationError: normalizedError\n\t\t\t\t\t\t\t},\n\t\t\t\t\t\t\t{ context: 'callMethodCron-validation-error', method },\n\t\t\t\t\t\t\tnormalizedError.stack\n\t\t\t\t\t\t);\n\t\t\t\t\t\tnormalizedError.message = `${new Date().toISOString()} - Error in Cron Method Check (${method}): ${normalizedError.message}`;\n\n\t\t\t\t\t\tthrow normalizedError;\n\t\t\t\t\t}\n\t\t\t\t}\n\t\t\t}\n\n\t\t\tconst monitor = this._monitorManagerFunction.startMonitorFunction('Cron Method', method, '', '', methodData);\n\n\t\t\ttry {\n\t\t\t\tconst res = await cronMethod.function.call(Object.assign({}, this, MethodManager.prototype, {id_user: '', user: '', id_ws: ''}), ...methodData);\n\t\t\t\treturn res;\n\t\t\t}\n\t\t\tcatch (err) {\n\t\t\t\tconst { error: normalizedError, correlationId: resolvedCorrelationId } = ensureErrorWithCorrelation(err, correlationId);\n\n\t\t\t\tawait this.reportMethodError(\n\t\t\t\t\t'SERVER - Error Detected - ' + this.serverConfig['CLIENT_NAME'],\n\t\t\t\t\tresolvedCorrelationId,\n\t\t\t\t\t{\n\t\t\t\t\t\tmessage: 'Error detected during cron method execution',\n\t\t\t\t\t\tmethod,\n\t\t\t\t\t\tdata: methodData,\n\t\t\t\t\t\terror: normalizedError\n\t\t\t\t\t},\n\t\t\t\t\t{ context: 'callMethodCron-execution', method },\n\t\t\t\t\tnormalizedError.stack\n\t\t\t\t);\n\t\t\t\t\n\t\t\t\tnormalizedError.message = `${new Date().toISOString()} - Error in Cron Method (${method}): ${normalizedError.message}`;\n\t\t\t\t\n\t\t\t\tthrow normalizedError;\n\t\t\t}\n\t\t\tfinally {\n\t\t\t\tawait this._monitorManagerFunction.finishMonitorFunction(monitor);\n\t\t\t}\n\t\t};\n\n\t\treturn await runWithCorrelationContext(correlationId, execute);\n\t}\n\n\t// Call/run method internal (No Emit on Socket)\n\tpublic async callMethod(methodName: string, ...methodData: any[]): Promise<any> {\n\t\tthis._debugcallMethodHits += 1;\n\n\t\tconst existingCorrelationId = getCorrelationId();\n\t\tconst correlationId = existingCorrelationId || objectIdHexString();\n\n\t\treturn await runWithCorrelationContext(correlationId, async () => await this.callMethodInternal(correlationId, methodName, methodData));\n\t}\n\n\tprivate async callMethodInternal(correlationId: string, methodName: string, methodData: any[]): Promise<any> {\n\t\tconst method = this.getMethod(methodName);\n\n\t\tif (!method) {\n\t\t\tconsole.log('No Method: ' + methodName);\n\t\t\tthrow new Error(`No Method: ${methodName}`);\n\t\t}\n\n\t\tconst shouldTrackTextMetric = this.shouldTrackTextMessageMetric(methodName);\n\t\tconst textMetricProvider = shouldTrackTextMetric ? this.getTextMessageProvider() : undefined;\n\n\t\tlet releaseLocalConcurrency = await this.acquireLocalConcurrency(methodName, method.maxConcurrency);\n\n\t\ttry {\n\t\t\tif ((methodData.length > 1 || (methodData[0] && typeof methodData[0] !== 'function')) && !method.skipValidation) {\n\t\t\t\tif (!method.check) {\n\t\t\t\t\tconsole.error(new Date(), 'No Check Function For Method ' + methodName);\n\t\t\t\t\tthrow new Error(`No Check Function For Method: ${methodName}`);\n\t\t\t\t}\n\t\t\t\telse if (!method.check._schema) {\n\t\t\t\t\tconsole.error(new Date(), 'No Check Schema For Method ' + methodName);\n\t\t\t\t\tthrow new Error(`No Check Schema For Method: ${methodName}`);\n\t\t\t\t}\n\t\t\t}\n\n\t\t\tif (methodName !== 'insertSubscriptionLog' && \n\t\t\t\tmethodName !== 'getDataURIfromURL' && \n\t\t\t\tmethodName !== 'processAirdropDistribution' && \n\t\t\t\tmethodName !== 'incCounter' && \n\t\t\t\tmethodName !== 'supportCreateBillingUser' && \n\t\t\t\tmethodName !== 'countCollectionWithQuery' &&\n\t\t\t\tmethodName !== 'countWithQuery' &&\n\t\t\t\tmethodName !== 'qbFetchRequests' &&\n\t\t\t\tmethodName !== 'qbHandleResponse'\n\t\t\t) {\n\t\t\t\tif (\n\t\t\t\t\tResolveIOServer.getServerConfig()['ROOT_URL'] !== 'https://resolveio.com'\n\t\t\t\t&& ResolveIOServer.getServerConfig()['ROOT_URL'] !== 'http://localhost:4200'\n\t\t\t\t) {\n\t\t\t\t\t\t\tResolveIOServer.getLocalLogManager().writeLog({\n\t\t\t\t\t\t\t\ttype: 'log',\n\t\t\t\t\t\t\t\tdata: {\n\t\t\t\t\t\t\t\t\t_id: objectIdHexString(),\n\t\t\t\t\t\t\t\t\tcreatedAt: new Date(),\n\t\t\t\t\t\t\t\t\ttype: 'callMethod',\n\t\t\t\t\t\t\t\t\tcollection: '',\n\t\t\t\t\t\t\t\t\tid_document: '',\n\t\t\t\t\t\t\t\t\tpayload: getBinarySize(JSON.stringify([methodData])) < 1000000 ? JSON.stringify([methodData], null, 2) : 'Too Big',\n\t\t\t\t\t\t\t\t\tmethod: methodName,\n\t\t\t\t\t\t\t\t\tid_user: this['id_user'] || '',\n\t\t\t\t\t\t\t\t\tuser: this['user'] || '', \n\t\t\t\t\t\t\t\t\tmessageId: 0,\n\t\t\t\t\t\t\t\t\troute: '',\n\t\t\t\t\t\t\t\t\tinstance_index: process.env.NODE_APP_INSTANCE || '0',\n\t\t\t\t\t\t\t\t\tcorrelationId\n\t\t\t\t\t\t\t\t}\n\t\t\t\t\t\t\t});\n\t\t\t\t}\n\t\t\t\telse {\n\t\t\t\t\tawait Logs.insertOne({\n\t\t\t\t\t\t_id: objectIdHexString(),\n\t\t\t\t\t\ttype: 'callMethod',\n\t\t\t\t\t\tcollection: '',\n\t\t\t\t\t\tid_document: '',\n\t\t\t\t\t\tpayload: getBinarySize(JSON.stringify([methodData])) < 1000000 ? JSON.stringify([methodData], null, 2) : 'Too Big',\n\t\t\t\t\t\tmethod: methodName,\n\t\t\t\t\t\tid_user: this['id_user'] || '',\n\t\t\t\t\t\tuser: this['user'] || '',\n\t\t\t\t\t\tmessageId: 0,\n\t\t\t\t\t\troute: '',\n\t\t\t\t\t\tclient: 'ResolveIO',\n\t\t\t\t\t\tinstance: 'backend.resolveio.com',\n\t\t\t\t\t\tinstance_index: process.env.NODE_APP_INSTANCE || '0',\n\t\t\t\t\t\tcorrelationId\n\t\t\t\t\t})\n\t\t\t\t};\n\t\t\t}\n\n\t\t\tconst methodCallback = typeof(methodData[methodData.length - 1]) === 'function' ? methodData[methodData.length - 1] : null;\n\t\t\tconst functionMethodData = methodCallback ? methodData.slice(0, -1) : methodData;\n\n\t\t\tconst session = ResolveIOServer.getMongoManager().getSession();\n\t\t\tconst shouldStartTransaction = !method.bypassSession &&\n\t\t\t\t!session && \n\t\t\t\t![\n\t\t\t\t\t'insertErrorLog', // CIRCULAR LOOP - DO NOT REMOVE\n\t\t\t\t\t'countWithQuery', // MONGO SESSIONS/TRANSACTIONS DONT WORK WITH COUNTS\n\t\t\t\t\t'sendEmail' // ALWAYS SEND SO ALWAYS HAVE RECORD - DONT ROLL BACK - BYPASS SESSION\n\t\t\t\t].includes(methodName) &&\n\t\t\t\t!methodName.startsWith('monitor-') &&\n\t\t\t\t!methodName.startsWith('log');\n\n\t\t\tconst executeWithExistingSession = async () => {\n\t\t\t\t// console.log(new Date(), 'Calling Method - Existing Session', methodName);\n\t\t\t\tlet monitor = this._monitorManagerFunction.startMonitorFunction('Method', methodName, this['user'] || '', '', functionMethodData);\n\n\t\t\t\ttry {\n\t\t\t\t\tlet res = await method.function.call(Object.assign({}, this, MethodManager.prototype), ...functionMethodData);\n\n\t\t\t\t\tif (methodCallback) {\n\t\t\t\t\t\tmethodCallback(null, res);\n\t\t\t\t\t}\n\n\t\t\t\t\tif (shouldTrackTextMetric) {\n\t\t\t\t\t\ttry {\n\t\t\t\t\t\t\tawait recordTextMessageMetric({\n\t\t\t\t\t\t\t\tstatus: 'sent',\n\t\t\t\t\t\t\t\tprovider: textMetricProvider,\n\t\t\t\t\t\t\t\tmetadata: {\n\t\t\t\t\t\t\t\t\tmethod: methodName\n\t\t\t\t\t\t\t\t}\n\t\t\t\t\t\t\t});\n\t\t\t\t\t\t}\n\t\t\t\t\t\tcatch (error) {\n\t\t\t\t\t\t\tconsole.error('Error recording text message metric:', error);\n\t\t\t\t\t\t}\n\t\t\t\t\t}\n\n\t\t\t\t\treturn res;\n\t\t\t\t}\n\t\t\t\tcatch (err) {\n\t\t\t\t\tif (err.code === 112 || err.codeName === 'WriteConflict' || err.code === 251 || err.codeName === 'NoSuchTransaction') {\n\t\t\t\t\t\tthrow err; // Write error, retry\n\t\t\t\t\t}\n\n\t\t\t\t\tconst { error: normalizedError, correlationId: resolvedCorrelationId } = ensureErrorWithCorrelation(err, correlationId);\n\n\t\t\t\t\tconsole.log(JSON.stringify([new Date(), 'Error Method Manager - Run Method - Existing Session', methodName, {\n\t\t\t\t\t\tcode: normalizedError.code,\n\t\t\t\t\t\tcodeName: normalizedError.codeName,\n\t\t\t\t\t\tmessage: normalizedError.message,\n\t\t\t\t\t\tstack: normalizedError.stack,\n\t\t\t\t\t\tcorrelationId: resolvedCorrelationId\n\t\t\t\t\t}], null, 2));\n\n\t\t\t\t\tawait this.reportMethodError(\n\t\t\t\t\t\t'SERVER - Error Detected - ' + this.serverConfig['CLIENT_NAME'],\n\t\t\t\t\t\tresolvedCorrelationId,\n\t\t\t\t\t\t{\n\t\t\t\t\t\t\tmessage: 'Error detected during method execution (existing session)',\n\t\t\t\t\t\t\tmethod: methodName,\n\t\t\t\t\t\t\tdata: methodData,\n\t\t\t\t\t\t\terror: normalizedError\n\t\t\t\t\t\t},\n\t\t\t\t\t\t{ context: 'callMethod-existing-session', methodName },\n\t\t\t\t\t\tnormalizedError.stack\n\t\t\t\t\t);\n\t\t\t\t\tnormalizedError.message = `${new Date().toISOString()} - Error in Method (${methodName}) - Existing Session: ${normalizedError.message}`;\n\n\t\t\t\t\tif (methodCallback) {\n\t\t\t\t\t\tmethodCallback(normalizedError, null);\n\t\t\t\t\t}\n\n\t\t\t\t\tif (shouldTrackTextMetric) {\n\t\t\t\t\t\ttry {\n\t\t\t\t\t\t\tawait recordTextMessageMetric({\n\t\t\t\t\t\t\t\tstatus: 'failed',\n\t\t\t\t\t\t\t\tprovider: textMetricProvider,\n\t\t\t\t\t\t\t\tmetadata: {\n\t\t\t\t\t\t\t\t\tmethod: methodName\n\t\t\t\t\t\t\t\t}\n\t\t\t\t\t\t\t});\n\t\t\t\t\t\t}\n\t\t\t\t\t\tcatch (error) {\n\t\t\t\t\t\t\tconsole.error('Error recording text message metric:', error);\n\t\t\t\t\t\t}\n\t\t\t\t\t}\n\n\t\t\t\t\tif (!process.env.IS_WORKER_INSTANCE) {\n\t\t\t\t\t\tawait this.callMethod(\n\t\t\t\t\t\t\t'insertErrorLog',\n\t\t\t\t\t\t\t`Error in Method: ${methodName}`,\n\t\t\t\t\t\t\t{\n\t\t\t\t\t\t\t\tmethod: methodName,\n\t\t\t\t\t\t\t\tmethodData,\n\t\t\t\t\t\t\t\terror: {\n\t\t\t\t\t\t\t\t\tmessage: normalizedError.message,\n\t\t\t\t\t\t\t\t\tstack: normalizedError.stack,\n\t\t\t\t\t\t\t\t\tcode: normalizedError.code,\n\t\t\t\t\t\t\t\t\tcodeName: normalizedError.codeName\n\t\t\t\t\t\t\t\t},\n\t\t\t\t\t\t\t\tcorrelationId: resolvedCorrelationId\n\t\t\t\t\t\t\t}\n\t\t\t\t\t\t);\n\t\t\t\t\t}\n\t\t\t\t\t\n\t\t\t\t\tthrow normalizedError;\n\t\t\t\t}\n\t\t\t\tfinally {\n\t\t\t\t\tawait this._monitorManagerFunction.finishMonitorFunction(monitor);\n\t\t\t\t}\n\t\t\t};\n\n\t\t\tif (shouldStartTransaction) {\n\t\t\t\tlet monitor = null;\n\t\t\t\t\n\t\t\t\treturn ResolveIOServer.getMongoManager().oneTimeTransaction(async () => {\n\t\t\t\t\t// console.log(new Date(), 'Calling Method - New Session', methodName);\n\n\t\t\t\t\tmonitor = this._monitorManagerFunction.startMonitorFunction('Method', methodName, this['user'] || '', '', functionMethodData);\n\t\t\t\t\t\n\t\t\t\t\ttry {\n\t\t\t\t\t\tlet res = await method.function.call(Object.assign({}, this, MethodManager.prototype), ...functionMethodData);\n\n\t\t\t\t\t\tif (methodCallback) {\n\t\t\t\t\t\t\tmethodCallback(null, res);\n\t\t\t\t\t\t}\n\n\t\t\t\t\t\tif (shouldTrackTextMetric) {\n\t\t\t\t\t\t\ttry {\n\t\t\t\t\t\t\t\tawait recordTextMessageMetric({\n\t\t\t\t\t\t\t\t\tstatus: 'sent',\n\t\t\t\t\t\t\t\t\tprovider: textMetricProvider,\n\t\t\t\t\t\t\t\t\tmetadata: {\n\t\t\t\t\t\t\t\t\t\tmethod: methodName\n\t\t\t\t\t\t\t\t\t}\n\t\t\t\t\t\t\t\t});\n\t\t\t\t\t\t\t}\n\t\t\t\t\t\t\tcatch (error) {\n\t\t\t\t\t\t\t\tconsole.error('Error recording text message metric:', error);\n\t\t\t\t\t\t\t}\n\t\t\t\t\t\t}\n\n\t\t\t\t\t\treturn res;\n\t\t\t\t\t}\n\t\t\t\t\tcatch (err) {\n\t\t\t\t\t\tif (err.code === 112 || err.codeName === 'WriteConflict' || err.code === 251 || err.codeName === 'NoSuchTransaction') {\n\t\t\t\t\t\t\tthrow err; // Write error, retry\n\t\t\t\t\t\t}\n\n\t\t\t\t\t\tconst { error: normalizedError, correlationId: resolvedCorrelationId } = ensureErrorWithCorrelation(err, correlationId);\n\n\t\t\t\t\t\tconsole.log(JSON.stringify([new Date(), 'Error Method Manager - Run Method - New Session', methodName, {\n\t\t\t\t\t\t\tcode: normalizedError.code,\n\t\t\t\t\t\t\tcodeName: normalizedError.codeName,\n\t\t\t\t\t\t\tmessage: normalizedError.message,\n\t\t\t\t\t\t\tstack: normalizedError.stack,\n\t\t\t\t\t\t\tcorrelationId: resolvedCorrelationId\n\t\t\t\t\t\t}], null, 2));\n\n\t\t\t\t\t\tawait this.reportMethodError(\n\t\t\t\t\t\t\t'SERVER - Error Detected - ' + this.serverConfig['CLIENT_NAME'],\n\t\t\t\t\t\t\tresolvedCorrelationId,\n\t\t\t\t\t\t\t{\n\t\t\t\t\t\t\t\tmessage: 'Error detected during method execution (new session)',\n\t\t\t\t\t\t\t\tmethod: methodName,\n\t\t\t\t\t\t\t\tdata: methodData,\n\t\t\t\t\t\t\t\terror: normalizedError\n\t\t\t\t\t\t\t},\n\t\t\t\t\t\t\t{ context: 'callMethod-new-session', methodName },\n\t\t\t\t\t\t\tnormalizedError.stack\n\t\t\t\t\t\t);\n\t\t\t\t\t\tnormalizedError.message = `${new Date().toISOString()} - Error in Method With Session (${methodName}) - New Session: ${normalizedError.message}`;\n\n\t\t\t\t\t\tif (methodCallback) {\n\t\t\t\t\t\t\tmethodCallback(normalizedError, null);\n\t\t\t\t\t\t}\n\n\t\t\t\t\t\tif (shouldTrackTextMetric) {\n\t\t\t\t\t\t\ttry {\n\t\t\t\t\t\t\t\tawait recordTextMessageMetric({\n\t\t\t\t\t\t\t\t\tstatus: 'failed',\n\t\t\t\t\t\t\t\t\tprovider: textMetricProvider,\n\t\t\t\t\t\t\t\t\tmetadata: {\n\t\t\t\t\t\t\t\t\t\tmethod: methodName\n\t\t\t\t\t\t\t\t\t}\n\t\t\t\t\t\t\t\t});\n\t\t\t\t\t\t\t}\n\t\t\t\t\t\t\tcatch (error) {\n\t\t\t\t\t\t\t\tconsole.error('Error recording text message metric:', error);\n\t\t\t\t\t\t\t}\n\t\t\t\t\t\t}\n\n\t\t\t\t\t\tif (!process.env.IS_WORKER_INSTANCE) {\n\t\t\t\t\t\t\tawait this.callMethod(\n\t\t\t\t\t\t\t\t'insertErrorLog',\n\t\t\t\t\t\t\t\t`Error in Method: ${methodName}`,\n\t\t\t\t\t\t\t\t{\n\t\t\t\t\t\t\t\t\tmethod: methodName,\n\t\t\t\t\t\t\t\t\tmethodData,\n\t\t\t\t\t\t\t\t\terror: {\n\t\t\t\t\t\t\t\t\t\tmessage: normalizedError.message,\n\t\t\t\t\t\t\t\t\t\tstack: normalizedError.stack,\n\t\t\t\t\t\t\t\t\t\tcode: normalizedError.code,\n\t\t\t\t\t\t\t\t\t\tcodeName: normalizedError.codeName\n\t\t\t\t\t\t\t\t\t},\n\t\t\t\t\t\t\t\t\tcorrelationId: resolvedCorrelationId\n\t\t\t\t\t\t\t\t}\n\t\t\t\t\t\t\t);\n\t\t\t\t\t\t}\n\n\t\t\t\t\t\tthrow normalizedError;\n\t\t\t\t\t}\n\t\t\t\t\tfinally {\n\t\t\t\t\t\tawait this._monitorManagerFunction.finishMonitorFunction(monitor);\n\t\t\t\t\t}\n\t\t\t\t});\n\t\t\t}\n\t\t\telse if (method.bypassSession && session) {\n\t\t\t\treturn ResolveIOServer.getMongoManager().runWithoutSession(async () => await executeWithExistingSession());\n\t\t\t}\n\t\t\telse {\n\t\t\t\treturn executeWithExistingSession();\n\t\t\t}\n\t\t}\n\t\tfinally {\n\t\t\treleaseLocalConcurrency();\n\t\t}\n\t}\n\n\tprivate async acquireLocalConcurrency(methodName: string, maxConcurrency?: number): Promise<() => void> {\n\t\tif (!maxConcurrency || maxConcurrency < 1) {\n\t\t\treturn () => {};\n\t\t}\n\n\t\tlet current = this._localActiveCounts.get(methodName) || 0;\n\n\t\tif (current < maxConcurrency) {\n\t\t\tthis._localActiveCounts.set(methodName, current + 1);\n\t\t\treturn this.createLocalRelease(methodName);\n\t\t}\n\n\t\t// eslint-disable-next-line no-restricted-syntax\n\t\treturn new Promise((resolve) => {\n\t\t\tlet queue = this._localWaitQueues.get(methodName);\n\n\t\t\tif (!queue) {\n\t\t\t\tqueue = [];\n\t\t\t\tthis._localWaitQueues.set(methodName, queue);\n\t\t\t}\n\n\t\t\tqueue.push(() => {\n\t\t\t\tlet curr = this._localActiveCounts.get(methodName) || 0;\n\t\t\t\tthis._localActiveCounts.set(methodName, curr + 1);\n\t\t\t\tresolve(this.createLocalRelease(methodName));\n\t\t\t});\n\t\t});\n\t}\n\n\tprivate createLocalRelease(methodName: string): () => void {\n\t\tlet released = false;\n\n\t\treturn () => {\n\t\t\tif (released) {\n\t\t\t\treturn;\n\t\t\t}\n\n\t\t\treleased = true;\n\n\t\t\tlet current = this._localActiveCounts.get(methodName) || 0;\n\t\t\tthis._localActiveCounts.set(methodName, current > 0 ? current - 1 : 0);\n\n\t\t\tlet queue = this._localWaitQueues.get(methodName);\n\n\t\t\tif (queue && queue.length) {\n\t\t\t\tlet next = queue.shift();\n\n\t\t\t\tif (next) {\n\t\t\t\t\tnext();\n\t\t\t\t}\n\t\t\t}\n\t\t};\n\t}\n\n\tsetupEmailWatcher() {\n\t\tconst changeStream = EmailHistories.watchCollection([]);\n\n\t\tchangeStream.on('change', async (change) => {\n\t\t\tif (change.operationType === 'insert' && change.fullDocument && change.fullDocument.status === 'pending') {\n\t\t\t\tthis.emailQueue.add(change.fullDocument._id.toString());\n\t\t\t\tawait this.tryProcessEmail();\n\t\t\t}\n\t\t\telse if (change.operationType === 'update' || change.operationType === 'replace') {\n\t\t\t\tconst updatedEmail = change.fullDocument;\n\t\t\t\tif (updatedEmail && updatedEmail.status !== 'pending' && this.emailQueue.has(updatedEmail._id.toString())) {\n\t\t\t\t\tthis.emailQueue.delete(updatedEmail._id.toString());\n\t\t\t\t}\n\t\t\t}\n\t\t})\n\t\t.on('error', async err => {\n\t\t\tconsole.error('Email history changestream error', err);\n\t\t\tawait changeStream.close();\n\t\t})\n\t\t.on('close', () => {\n\t\t\tthis.setupEmailWatcher();\n\t\t});\n\t}\n\n\tasync loadPendingEmails() {\n\t\t// Load any pending emails on startup\n\t\tconst pendingEmails = await EmailHistories.find({ status: 'pending' }, {sort: {_id: 1}});\n\t\tfor (const email of pendingEmails) {\n\t\t\tthis.emailQueue.add(email._id.toString());\n\t\t}\n\t\t// Try to process emails\n\t\tawait this.tryProcessEmail();\n\t}\n\n\tasync tryProcessEmail() {\n\t\tif (this.isEmailProcessing || this.emailQueue.size === 0) {\n\t\t\treturn;\n\t\t}\n\t\n\t\tthis.isEmailProcessing = true;\n\t\n\t\ttry {\n\t\t\twhile (this.emailQueue.size > 0) {\n\t\t\t\tconst emailId = this.emailQueue.values().next().value;\n\t\t\t\tthis.emailQueue.delete(emailId);\n\t\n\t\t\t\tconst pendingEmail = await EmailHistories.findOne(\n\t\t\t\t\t{\n\t\t\t\t\t\t_id: emailId,\n\t\t\t\t\t\tstatus: 'pending',\n\t\t\t\t\t}\n\t\t\t\t);\n\n\t\t\t\tif (!pendingEmail) {\n\t\t\t\t\tcontinue;\n\t\t\t\t}\n\n\t\t\t\tlet queuedAt: Date;\n\t\t\t\tif (pendingEmail.date instanceof Date) {\n\t\t\t\t\tqueuedAt = pendingEmail.date;\n\t\t\t\t}\n\t\t\t\telse if (pendingEmail.createdAt instanceof Date) {\n\t\t\t\t\tqueuedAt = pendingEmail.createdAt;\n\t\t\t\t}\n\t\t\t\telse {\n\t\t\t\t\tqueuedAt = new Date();\n\t\t\t\t}\n\n\t\t\t\tconst timeSinceQueued = Date.now() - queuedAt.getTime();\n\t\t\t\tconst remainingDelay = this._emailProcessingDelayMs - timeSinceQueued;\n\n\t\t\t\tif (remainingDelay > 0) {\n\t\t\t\t\t// eslint-disable-next-line no-restricted-syntax\n\t\t\t\t\tawait new Promise(resolve => setTimeout(resolve, remainingDelay));\n\t\t\t\t}\n\n\t\t\t\tconst emailHistory = await EmailHistories.findOneAndUpdate(\n\t\t\t\t\t{\n\t\t\t\t\t\t_id: emailId,\n\t\t\t\t\t\tstatus: 'pending',\n\t\t\t\t\t},\n\t\t\t\t\t{\n\t\t\t\t\t\t$set: { status: 'processing', processingAt: new Date() },\n\t\t\t\t\t}\n\t\t\t\t);\n\t\n\t\t\t\tif (!emailHistory) {\n\t\t\t\t\tcontinue;\n\t\t\t\t}\n\t\n\t\t\t\t// Fetch and process attachments\n if (emailHistory.attachments && emailHistory.attachments.length > 0) {\n\t\t\t\t\tconst validAttachments: any[] = [];\n\t\t\t\t\tlet attachmentError = false;\n\n\t\t\t\t\tfor (const att of emailHistory.attachments) {\n\t\t\t\t\t\tif (att.path && att.path.startsWith('http')) {\n\t\t\t\t\t\t\ttry {\n\t\t\t\t\t\t\t\tconst response = await fetch(att.path);\n\t\t\t\t\t\t\t\tif (!response.ok) {\n\t\t\t\t\t\t\t\t\tattachmentError = true;\n\t\t\t\t\t\t\t\t\tcontinue;\n\t\t\t\t\t\t\t\t}\n\t\t\t\t\t\t\t\tconst arrayBuffer = await response.arrayBuffer();\n\t\t\t\t\t\t\t\tconst buffer = Buffer.from(arrayBuffer);\n\n\t\t\t\t\t\t\t\t// Check the size of the attachment\n\t\t\t\t\t\t\t\tconst maxSize = 20 * 1024 * 1024; // 20MB in bytes\n\t\t\t\t\t\t\t\tif (buffer.length <= maxSize) {\n\t\t\t\t\t\t\t\t\t// Attachment is within size limits, include it\n\t\t\t\t\t\t\t\t\tatt.content = buffer;\n\t\t\t\t\t\t\t\t\tdelete att.path;\n\t\t\t\t\t\t\t\t\tvalidAttachments.push(att);\n\t\t\t\t\t\t\t\t}\n\t\t\t\t\t\t\t}\n\t\t\t\t\t\t\tcatch (err) {\n\t\t\t\t\t\t\t\tconsole.error('Failed to fetch attachment:', err);\n\t\t\t\t\t\t\t\tattachmentError = true;\n\t\t\t\t\t\t\t}\n\t\t\t\t\t\t}\n\t\t\t\t\t\telse {\n\t\t\t\t\t\t\tvalidAttachments.push(att);\n\t\t\t\t\t\t}\n\t\t\t\t\t}\n\n\t\t\t\t\temailHistory.attachments = validAttachments;\n\t\t\t\t\tif (attachmentError) {\n\t\t\t\t\t\t\temailHistory.text =\n\t\t\t\t\t\t\t\t\t(typeof emailHistory.text === 'string' ? emailHistory.text : '') +\n\t\t\t\t\t\t\t\t\t'\\n\\nCould not load attachments.';\n\t\t\t\t\t\t\temailHistory.html =\n\t\t\t\t\t\t\t\t\t(typeof emailHistory.html === 'string' ? emailHistory.html : '') +\n\t\t\t\t\t\t\t\t\t'<p>Could not load attachments.</p>';\n\t\t\t\t\t}\n }\n\t\n\t\t\t\t// Prepare email options\n\t\t\t\tconst mailOptions: any = {\n\t\t\t\t\treplyTo: emailHistory.reply_to || (ResolveIOServer.getServerConfig()['MAIL_REPLY_TO'] || undefined),\n\t\t\t\t\tfrom: emailHistory.send_from || ResolveIOServer.getServerConfig().MAIL_FROM,\n\t\t\t\t\tto: emailHistory.email,\n\t\t\t\t\tsubject:\n\t\t\t\t\t\t(ResolveIOServer.getServerConfig()['ROOT_URL'].match(/https:\\/\\/dev\\./) ||\n\t\t\t\t\t\tResolveIOServer.getServerConfig()['ROOT_URL'].match(/https:\\/\\/www\\.dev\\./)\n\t\t\t\t\t\t\t? '(DEV SERVER) - '\n\t\t\t\t\t\t\t: '') + emailHistory.subject,\n\t\t\t\t\ttext: typeof emailHistory.text === 'string' ? emailHistory.text : '',\n\t\t\t\t\thtml: typeof emailHistory.html === 'string' ? emailHistory.html : '',\n\t\t\t\t\tattachments: emailHistory.attachments || [],\n\t\t\t\t\tforce_ses: emailHistory.force_ses\n\t\t\t\t};\n\t\n\t\t\t\t// Process attachments before sending\n\t\t\t\tif (mailOptions.attachments && mailOptions.attachments.length > 0) {\n\t\t\t\t\tmailOptions.attachments = mailOptions.attachments.map((att) => {\n\t\t\t\t\t\tconst newAtt = { ...att };\n\t\t\t\t\t\t// Handle attachments stored as BinData or Buffer\n\t\t\t\t\t\tif (newAtt.content && typeof newAtt.content === 'object' && !(newAtt.content instanceof Buffer)) {\n\t\t\t\t\t\t\t// Convert MongoDB's Binary data to Buffer\n\t\t\t\t\t\t\tif (newAtt.content._bsontype === 'Binary' && newAtt.content.sub_type === 0) {\n\t\t\t\t\t\t\t\tnewAtt.content = Buffer.from(newAtt.content.buffer);\n\t\t\t\t\t\t\t}\n\t\t\t\t\t\t\telse {\n\t\t\t\t\t\t\t\t// Handle other types if necessary\n\t\t\t\t\t\t\t\tnewAtt.content = Buffer.from(newAtt.content);\n\t\t\t\t\t\t\t}\n\t\t\t\t\t\t}\n\t\t\t\t\t\t// Handle attachments stored as Base64 strings\n\t\t\t\t\t\telse if (typeof newAtt.content === 'string' && newAtt.encoding === 'base64') {\n\t\t\t\t\t\t\tnewAtt.content = Buffer.from(newAtt.content, 'base64');\n\t\t\t\t\t\t\tdelete newAtt.encoding;\n\t\t\t\t\t\t}\n\t\t\t\t\t\t// Ensure the content is a Buffer\n\t\t\t\t\t\telse if (typeof newAtt.content === 'string') {\n\t\t\t\t\t\t\tnewAtt.content = Buffer.from(newAtt.content);\n\t\t\t\t\t\t}\n\t\t\t\t\t\treturn newAtt;\n\t\t\t\t\t});\n\t\t\t\t}\n\t\n\t\t\t\t// Send the email\n\t\t\t\tconst emailProvider = (!mailOptions.force_ses && this._mailerCustom) ? 'custom' : 'ses';\n\t\t\t\t(!mailOptions.force_ses && this._mailerCustom ? this._mailerCustom : this._mailerSES).sendMail(mailOptions, async err => {\n\t\t\t\t\tconst metricStatus = err ? 'failed' : 'sent';\n\n\t\t\t\t\ttry {\n\t\t\t\t\t\tif (err) {\n\t\t\t\t\t\t\tconsole.error('Failed to send email:', err);\n\t\t\t\t\t\t\tawait EmailHistories.updateOne(\n\t\t\t\t\t\t\t\t{ _id: emailHistory._id },\n\t\t\t\t\t\t\t\t{\n\t\t\t\t\t\t\t\t\t$set: {\n\t\t\t\t\t\t\t\t\t\tstatus: 'failed',\n\t\t\t\t\t\t\t\t\t\terror: typeof err === 'string' ? err : this.safeStringify(err),\n\t\t\t\t\t\t\t\t\t\tcompletedAt: new Date(),\n\t\t\t\t\t\t\t\t\t},\n\t\t\t\t\t\t\t\t}\n\t\t\t\t\t\t\t);\n\t\t\t\t\t\t}\n\t\t\t\t\t\telse {\n\t\t\t\t\t\t\tif (emailHistory.email === 'dev@resolveio.com') {\n\t\t\t\t\t\t\t\tawait EmailHistories.deleteOne({ _id: emailHistory._id });\n\t\t\t\t\t\t\t}\n\t\t\t\t\t\t\telse {\n\t\t\t\t\t\t\t\tawait EmailHistories.updateOne(\n\t\t\t\t\t\t\t\t\t{ _id: emailHistory._id },\n\t\t\t\t\t\t\t\t\t{\n\t\t\t\t\t\t\t\t\t\t$set: {\n\t\t\t\t\t\t\t\t\t\t\tstatus: 'completed',\n\t\t\t\t\t\t\t\t\t\t\tcompletedAt: new Date(),\n\t\t\t\t\t\t\t\t\t\t},\n\t\t\t\t\t\t\t\t\t}\n\t\t\t\t\t\t\t\t);\n\t\t\t\t\t\t\t}\n\t\t\t\t\t\t}\n\t\t\t\t\t}\n\t\t\t\t\tcatch (error) {\n\t\t\t\t\t\tconsole.error('Error in sendMail callback:', error);\n\t\t\t\t\t\tawait EmailHistories.updateOne(\n\t\t\t\t\t\t\t{ _id: emailHistory._id },\n\t\t\t\t\t\t\t{\n\t\t\t\t\t\t\t\t$set: {\n\t\t\t\t\t\t\t\t\tstatus: 'failed',\n\t\t\t\t\t\t\t\t\terror: typeof error === 'string' ? error : this.safeStringify(error),\n\t\t\t\t\t\t\t\t\tcompletedAt: new Date(),\n\t\t\t\t\t\t\t\t},\n\t\t\t\t\t\t\t}\n\t\t\t\t\t\t);\n\t\t\t\t\t}\n\t\t\t\t\tfinally {\n\t\t\t\t\t\ttry {\n\t\t\t\t\t\t\tawait recordEmailMetric({\n\t\t\t\t\t\t\t\tstatus: metricStatus,\n\t\t\t\t\t\t\t\tprovider: emailProvider,\n\t\t\t\t\t\t\t\tmetadata: {\n\t\t\t\t\t\t\t\t\tmethod: 'sendEmail'\n\t\t\t\t\t\t\t\t}\n\t\t\t\t\t\t\t});\n\t\t\t\t\t\t}\n\t\t\t\t\t\tcatch (error) {\n\t\t\t\t\t\t\tconsole.error('Error recording email metric:', error);\n\t\t\t\t\t\t}\n\t\t\t\t\t}\n\t\t\t\t});\n\t\n\t\t\t\t// Wait for at least one second before sending the next email\n\t\t\t\t// eslint-disable-next-line no-restricted-syntax\n\t\t\t\tawait new Promise((resolve) => setTimeout(resolve, 1000));\n\t\t\t}\n\t\t}\n\t\tcatch (err) {\n\t\t\tconsole.error('Error processing email queue:', err);\n\t\t}\n\t\tfinally {\n\t\t\tthis.isEmailProcessing = false;\n\t\t\t// Check if new emails arrived while processing\n\t\t\tif (this.emailQueue.size > 0) {\n\t\t\t\tawait this.tryProcessEmail();\n\t\t\t}\n\t\t}\n\t}\n\n\tprivate shouldTrackTextMessageMetric(methodName: string): boolean {\n\t\tconst normalized = String(methodName || '').trim().toLowerCase();\n\t\tif (!normalized) {\n\t\t\treturn false;\n\t\t}\n\n\t\treturn normalized.startsWith('sendsms') || normalized.startsWith('sendtext');\n\t}\n\n\tprivate getTextMessageProvider(): string | undefined {\n\t\tconst provider = this.serverConfig?.['SMS_PROVIDER'] || '';\n\t\tif (typeof provider === 'string' && provider.trim().length) {\n\t\t\treturn provider.trim().toLowerCase();\n\t\t}\n\n\t\tif (this.serverConfig?.['TWILIO_SID'] || this.serverConfig?.['TWILIO_AUTH_TOKEN']) {\n\t\t\treturn 'twilio';\n\t\t}\n\n\t\treturn undefined;\n\t}\n\n\tsafeStringify(obj)\n\t{\n\t\ttry\n\t\t{\n\t\t\treturn JSON.stringify(obj, this.getCircularReplacer());\n\t\t}\n\t\tcatch (e)\n\t\t{\n\t\t\treturn `Error in JSON stringifying: ${e.message}`;\n\t\t}\n\t}\n\n\tgetCircularReplacer()\n\t{\n\t\tconst seen = new WeakSet();\n\t\treturn (key, value) =>\n\t\t{\n\t\t\tif (typeof value === \"object\" && value !== null)\n\t\t\t{\n\t\t\t\tif (seen.has(value))\n\t\t\t\t{\n\t\t\t\t\treturn \"[Circular]\";\n\t\t\t\t}\n\t\t\t\tseen.add(value);\n\t\t\t}\n\t\t\treturn value;\n\t\t};\n\t}\n\n\tprivate async tryMergeEmailOccurrence(\n\t\temail: string,\n\t\tsubject: string,\n\t\tcorrelationId: string,\n\t\toccurrence: EmailHistoryOccurrence,\n\t\tmeta?: Record<string, any>\n\t): Promise<EmailHistoryModel | null> {\n\t\tconst existing = await EmailHistories.findOne(\n\t\t\t{\n\t\t\t\temail,\n\t\t\t\tcorrelationId,\n\t\t\t\tstatus: 'pending'\n\t\t\t},\n\t\t\t{ sort: { date: 1 } }\n\t\t);\n\n\t\tif (!existing) {\n\t\t\treturn null;\n\t\t}\n\n\t\tconst normalizedOccurrences: EmailHistoryOccurrence[] = Array.isArray(existing.occurrences) && existing.occurrences.length\n\t\t\t? existing.occurrences.map((item: EmailHistoryOccurrence) => ({\n\t\t\t\t_id: item._id || objectIdHexString(),\n\t\t\t\tcreatedAt: item.createdAt instanceof Date ? item.createdAt : new Date(item.createdAt),\n\t\t\t\tsubject: item.subject || existing.subject || '',\n\t\t\t\ttext: item.text,\n\t\t\t\thtml: item.html,\n\t\t\t\tmeta: item.meta\n\t\t\t}))\n\t\t\t: [createEmailOccurrence(\n\t\t\t\texisting.subject || '',\n\t\t\t\ttypeof existing.text === 'string' ? existing.text : undefined,\n\t\t\t\ttypeof existing.html === 'string' ? existing.html : undefined,\n\t\t\t\texisting.meta\n\t\t\t)];\n\n\t\tnormalizedOccurrences.push(occurrence);\n\n\t\tconst { text: aggregatedText, html: aggregatedHtml } = formatGroupedEmailContent(correlationId, normalizedOccurrences);\n\n\t\tconst updated = await EmailHistories.findOneAndUpdate(\n\t\t\t{\n\t\t\t\t_id: existing._id,\n\t\t\t\tstatus: 'pending'\n\t\t\t},\n\t\t\t{\n\t\t\t\t$set: {\n\t\t\t\t\tsubject,\n\t\t\t\t\ttext: aggregatedText,\n\t\t\t\t\thtml: aggregatedHtml,\n\t\t\t\t\toccurrences: normalizedOccurrences,\n\t\t\t\t\tmeta: meta || existing.meta,\n\t\t\t\t\tupdatedAt: new Date()\n\t\t\t\t}\n\t\t\t},\n\t\t\t{ returnDocument: 'after' }\n\t\t);\n\n\t\treturn updated || null;\n\t}\n\n\tpublic async sendEmail(\n\t\tsendTo: string,\n\t\tsubject: string,\n\t\ttext?: string | null,\n\t\thtml?: string | null,\n\t\tattachments?: any[] | null,\n\t\tsend_from?: string | null,\n\t\treply_to?: string | null,\n\t\tforce_ses = false,\n\t\tlocal_override = false,\n\t\toptions?: SendEmailOptions\n\t) {\n\t\t// Modify sendTo in development environments\n\t\tif (\n\t\t\t(ResolveIOServer.getServerConfig()['ROOT_URL'].match(/https:\\/\\/dev\\./) ||\n\t\t\t\tResolveIOServer.getServerConfig()['ROOT_URL'].match(/https:\\/\\/www\\.dev\\./) ||\n\t\t\t\tResolveIOServer.getServerConfig()['ROOT_URL'] === 'http://localhost:4200') &&\n\t\t\t!sendTo.match(/\\@resolveio\\.com/)\n\t\t) {\n\t\t\tsendTo = 'dev@resolveio.com';\n\t\t}\n\n\t\tconst normalizedSubject = subject || '';\n\t\tconst correlationId = options?.correlationId;\n\t\tconst finalSubject = appendCorrelationIdToSubject(normalizedSubject, correlationId);\n\t\tconst groupByCorrelationId = !!correlationId;\n\t\tconst normalizedText = typeof text === 'string' ? text : '';\n\t\tconst normalizedHtml = typeof html === 'string' ? html : '';\n\t\tconst occurrence = groupByCorrelationId\n\t\t\t? createEmailOccurrence(normalizedSubject, normalizedText, normalizedHtml, options?.meta)\n\t\t\t: null;\n\t\tlet allowGrouping = groupByCorrelationId;\n\n\t\tif (sendTo) {\n\t\t\tif (\n\t\t\t\tResolveIOServer.getServerConfig()['ROOT_URL'] !== 'http://localhost:4200' ||\n\t\t\t\tlocal_override\n\t\t\t) {\n\t\t\t\tlet normalizedAttachments: any[] = [];\n\t\t\t\tif (Array.isArray(attachments)) {\n\t\t\t\t\tnormalizedAttachments = attachments.slice();\n\t\t\t\t}\n\t\t\t\telse if (attachments) {\n\t\t\t\t\tnormalizedAttachments = [attachments];\n\t\t\t\t}\n\n\t\t\t\tnormalizedAttachments = normalizedAttachments.map(att => {\n\t\t\t\t\tconst newAtt = { ...att };\n\t\t\t\t\tif (Buffer.isBuffer(newAtt.content)) {\n\t\t\t\t\t\tnewAtt.content = newAtt.content.toString('base64');\n\t\t\t\t\t\tnewAtt.encoding = 'base64';\n\t\t\t\t\t}\n\t\t\t\t\treturn newAtt;\n\t\t\t\t});\n\n\t\t\t\tif (normalizedAttachments.length > 0) {\n\t\t\t\t\tallowGrouping = false;\n\t\t\t\t}\n\n\t\t\t\tif (allowGrouping && occurrence && correlationId) {\n\t\t\t\t\tconst merged = await this.tryMergeEmailOccurrence(sendTo, finalSubject, correlationId, occurrence, options?.meta);\n\t\t\t\t\tif (merged) {\n\t\t\t\t\t\treturn merged;\n\t\t\t\t\t}\n\t\t\t\t}\n\n\t\t\t\tconst emailHistory: EmailHistoryModel = {\n\t\t\t\t\t_id: objectIdHexString(),\n\t\t\t\t\t__v: 0,\n\t\t\t\t\tdate: new Date(),\n\t\t\t\t\tid_user: this['id_user'] || '',\n\t\t\t\t\tuser: this['user'] || '',\n\t\t\t\t\temail: sendTo,\n\t\t\t\t\tsubject: finalSubject,\n\t\t\t\t\ttext: normalizedText,\n\t\t\t\t\thtml: normalizedHtml,\n\t\t\t\t\tattachments: normalizedAttachments,\n\t\t\t\t\tsend_from: send_from || '',\n\t\t\t\t\treply_to: reply_to || '',\n\t\t\t\t\tstatus: 'pending',\n\t\t\t\t\terror: '',\n\t\t\t\t\tforce_ses\n\t\t\t\t};\n\n\t\t\t\tif (allowGrouping && occurrence && correlationId) {\n\t\t\t\t\tconst { text: aggregatedText, html: aggregatedHtml } = formatGroupedEmailContent(correlationId, [occurrence]);\n\t\t\t\t\temailHistory.text = aggregatedText;\n\t\t\t\t\temailHistory.html = aggregatedHtml;\n\t\t\t\t\temailHistory.occurrences = [occurrence];\n\t\t\t\t\temailHistory.correlationId = correlationId;\n\t\t\t\t\tif (options?.meta) {\n\t\t\t\t\t\temailHistory.meta = options.meta;\n\t\t\t\t\t}\n\t\t\t\t}\n\t\t\t\telse {\n\t\t\t\t\tif (correlationId) {\n\t\t\t\t\t\temailHistory.correlationId = correlationId;\n\t\t\t\t\t}\n\t\t\t\t\tif (options?.meta) {\n\t\t\t\t\t\temailHistory.meta = options.meta;\n\t\t\t\t\t}\n\t\t\t\t}\n\n\t\t\t\ttry {\n\t\t\t\t\tlet history = await EmailHistories.insertOne(emailHistory);\n\t\t\t\t\treturn history;\n\t\t\t\t}\n\t\t\t\tcatch (err) {\n\t\t\t\t\tconsole.error('Failed to queue email:', err);\n\t\t\t\t\terr.message = `Failed to queue email: ${err.message}`;\n\t\t\t\t\tthrow err;\n\t\t\t\t}\n\t\t\t}\n\t\t\telse {\n\t\t\t\tconsole.log(\n\t\t\t\t\t'Send email',\n\t\t\t\t\tsendTo,\n\t\t\t\t\tfinalSubject,\n\t\t\t\t\tnormalizedText,\n\t\t\t\t\tnormalizedHtml,\n\t\t\t\t\tattachments,\n\t\t\t\t\tsend_from,\n\t\t\t\t\tforce_ses,\n\t\t\t\t\tcorrelationId\n\t\t\t\t);\n\t\t\t\t\n\t\t\t\treturn true;\n\t\t\t}\n\t\t}\n\t\telse {\n\t\t\treturn true;\n\t\t}\n\t}\n\n\tpublic getAWS(): AWS {\n\t\treturn this._aws;\n\t}\n\n\tpublic readFile(fileName) {\n\t\tif (fs.existsSync(path.join(__dirname, ('../private/' + fileName)))) {\n\t\t\ttry {\n\t\t\t\treturn fs.readFileSync(path.join(__dirname, ('../private/' + fileName)), 'utf-8');\n\t\t\t}\n\t\t\tcatch (err) {\n\t\t\t\terr.message = `Error in readFile: ${err.message}`;\n\t\t\t\tthrow err;\n\t\t\t}\n\t\t}\n\t\telse {\n\t\t\tif (fs.existsSync(path.join(ResolveIOServer.getClientDir(), ('./private/' + fileName)))) {\n\t\t\t\ttry {\n\t\t\t\t\treturn fs.readFileSync(path.join(ResolveIOServer.getClientDir(), ('./private/' + fileName)), 'utf-8');\n\t\t\t\t}\n\t\t\t\tcatch (err) {\n\t\t\t\t\terr.message = `Error in readFile: ${err.message}`;\n\t\t\t\t\tthrow err;\n\t\t\t\t}\n\t\t\t}\n\t\t}\n\n\t\tthrow new Error ('Error in readFile: File Not Found');\n\t}\n\n\tpublic readImage(fileName) {\n\t\tif (fs.existsSync(path.join(__dirname, ('../private/' + fileName)))) {\n\t\t\ttry {\n\t\t\t\treturn fs.readFileSync(path.join(__dirname, ('../private/' + fileName)), 'base64');\n\t\t\t}\n\t\t\tcatch (err) {\n\t\t\t\terr.message = `Error in readImage: ${err.message}`;\n\t\t\t\tthrow err;\n\t\t\t}\n\t\t}\n\t\telse {\n\t\t\tif (fs.existsSync(path.join(ResolveIOServer.getClientDir(), ('./private/' + fileName)))) {\n\t\t\t\ttry {\n\t\t\t\t\treturn fs.readFileSync(path.join(ResolveIOServer.getClientDir(), ('./private/' + fileName)), 'base64');\n\t\t\t\t}\n\t\t\t\tcatch (err) {\n\t\t\t\t\terr.message = `Error in readImage: ${err.message}`;\n\t\t\t\t\tthrow err;\n\t\t\t\t}\n\t\t\t}\n\t\t}\n\n\t\tthrow new Error ('Error in readImage: File Not Found');\n\t}\n\n\tpublic getEnableDebug() {\n\t\treturn this._enableDebug;\n\t}\n}\n"]}
1
+ {"version":3,"sources":["../../src/managers/method.manager.ts"],"names":[],"mappings":"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","file":"method.manager.js","sourcesContent":["import { S3 } from '@aws-sdk/client-s3';\nimport { SESv2Client, SendEmailCommand } from '@aws-sdk/client-sesv2';\nimport { EventEmitter, once } from 'events';\nimport * as fs from 'fs';\nimport * as nodemailer from 'nodemailer';\nimport * as path from 'path';\nimport { setTimeout as delay } from 'timers/promises';\nimport { EmailHistories } from '../collections/email-history.collection';\nimport { Flags } from '../collections/flag.collection';\nimport { Logs } from '../collections/log.collection';\nimport { loadServerCronJobs } from '../fixtures/cron-jobs';\nimport { loadServerInit } from '../fixtures/init';\nimport { loadAccountMethods } from '../methods/accounts';\nimport { loadAWSMethods } from '../methods/aws';\nimport { loadAiTerminalMethods } from '../methods/ai-terminal';\nimport { loadCollectionMethods } from '../methods/collections';\nimport { loadCounterMethods } from '../methods/counters';\nimport { loadCronJobMethods } from '../methods/cron-jobs';\nimport { loadFlagUpdatesMethods } from '../methods/flag-updates';\nimport { loadFlagMethods } from '../methods/flags';\nimport { loadLogMethods } from '../methods/logs';\nimport { loadMonitorMethods } from '../methods/monitor';\nimport { loadMongoExplorerMethods } from '../methods/mongo-explorer';\nimport { loadPublicationMethods } from '../methods/publications';\nimport { loadPDFMethods } from '../methods/pdf';\nimport { loadReportBuilderMethods } from '../methods/report-builder';\nimport { loadSupportMethods } from '../methods/support';\nimport { EmailHistoryModel, EmailHistoryOccurrence } from '../models/email-history.model';\nimport { MethodAllModel, MethodModel } from '../models/method.model';\nimport { ResolveIOServer } from '../resolveio-server-app';\nimport { getBinarySize, objectIdHexString } from '../util/common';\nimport { ErrorReporter } from '../util/error-reporter';\nimport { ensureErrorWithCorrelation, getCorrelationId, runWithCorrelationContext } from '../util/error-tracking';\nimport { MonitorManagerFunction } from './monitor.manager';\nimport { WebSocketManager } from './websocket.manager';\nimport { recordEmailMetric, recordTextMessageMetric } from './communication-metric.manager';\n\ninterface SendEmailOptions {\n\tcorrelationId?: string;\n\tmeta?: Record<string, any>;\n}\n\nfunction appendCorrelationIdToSubject(subject: string, correlationId?: string): string {\n\tif (!correlationId) {\n\t\treturn subject;\n\t}\n\n\tconst correlationTag = `[${correlationId}]`;\n\n\tif (subject && subject.includes(correlationTag)) {\n\t\treturn subject;\n\t}\n\n\treturn `${subject} ${correlationTag}`.trim();\n}\n\nfunction createEmailOccurrence(subject: string, text?: string, html?: string, meta?: Record<string, any>): EmailHistoryOccurrence {\n\treturn {\n\t\t_id: objectIdHexString(),\n\t\tcreatedAt: new Date(),\n\t\tsubject,\n\t\ttext,\n\t\thtml,\n\t\tmeta\n\t};\n}\n\nfunction formatGroupedEmailContent(correlationId: string, occurrences: EmailHistoryOccurrence[]): { text: string; html: string } {\n\tconst lines: string[] = [];\n\tlines.push(`Correlation ID: ${correlationId}`);\n\n\toccurrences.forEach((occurrence, index) => {\n\t\tconst timestamp = occurrence.createdAt instanceof Date ? occurrence.createdAt.toISOString() : new Date(occurrence.createdAt).toISOString();\n\t\tlines.push('');\n\t\tlines.push(`Occurrence #${index + 1} (${timestamp})`);\n\t\tlines.push(`Subject: ${occurrence.subject}`);\n\t\tif (occurrence.text) {\n\t\t\tlines.push(occurrence.text);\n\t\t}\n\t});\n\n\tconst htmlSections = occurrences.map((occurrence, index) => {\n\t\tconst timestamp = occurrence.createdAt instanceof Date ? occurrence.createdAt.toISOString() : new Date(occurrence.createdAt).toISOString();\n\t\tconst escapedText = occurrence.text ? occurrence.text.replace(/&/g, '&amp;').replace(/</g, '&lt;').replace(/>/g, '&gt;') : '';\n\t\treturn `<div><h4>Occurrence #${index + 1} (${timestamp})</h4><p><strong>Subject:</strong> ${occurrence.subject}</p>${escapedText ? `<pre>${escapedText}</pre>` : ''}</div>`;\n\t});\n\n\tconst html = [\n\t\t`<p><strong>Correlation ID:</strong> ${correlationId}</p>`,\n\t\t...htmlSections\n\t].join('');\n\n\treturn {\n\t\ttext: lines.join('\\n'),\n\t\thtml\n\t};\n}\n\nfunction createNodeMailerSESV2Transport(sesClient: SESv2Client): nodemailer.Transporter {\n\tconst transport: any = {\n\t\tname: 'resolveio-sesv2-transport',\n\t\tversion: '1.0.0',\n\t\tsend: (mail: any, callback: any) => {\n\t\t\tconst stream = mail.message.createReadStream();\n\t\t\tconst chunks: Uint8Array[] = [];\n\t\t\tlet didFinish = false;\n\n\t\t\tconst finish = (error: any, info?: any) => {\n\t\t\t\tif (didFinish) {\n\t\t\t\t\treturn;\n\t\t\t\t}\n\n\t\t\t\tdidFinish = true;\n\t\t\t\tcallback(error, info);\n\t\t\t};\n\n\t\t\tstream.on('data', (chunk) => {\n\t\t\t\tconst chunkData = Buffer.isBuffer(chunk) ? chunk : Buffer.from(chunk);\n\t\t\t\tchunks.push(new Uint8Array(chunkData));\n\t\t\t});\n\n\t\t\tstream.on('error', (error) => {\n\t\t\t\tfinish(error);\n\t\t\t});\n\n\t\t\tstream.on('end', async () => {\n\t\t\t\ttry {\n\t\t\t\t\tconst rawData = Buffer.concat(chunks);\n\t\t\t\t\tconst rawMessageData = new Uint8Array(rawData);\n\t\t\t\t\tconst envelope = typeof mail.message.getEnvelope === 'function' ? mail.message.getEnvelope() : mail.data?.envelope;\n\n\t\t\t\t\tconst fromEmailAddress = envelope?.from || undefined;\n\t\t\t\t\tconst toAddresses = envelope?.to\n\t\t\t\t\t\t? (Array.isArray(envelope.to) ? envelope.to : [envelope.to]).filter(Boolean)\n\t\t\t\t\t\t: [];\n\n\t\t\t\t\tconst replyToAddresses = mail.data?.replyTo\n\t\t\t\t\t\t? (Array.isArray(mail.data.replyTo) ? mail.data.replyTo : [mail.data.replyTo]).filter(Boolean)\n\t\t\t\t\t\t: undefined;\n\n\t\t\t\t\tconst response = await sesClient.send(new SendEmailCommand({\n\t\t\t\t\t\tFromEmailAddress: fromEmailAddress,\n\t\t\t\t\t\tDestination: toAddresses.length ? { ToAddresses: toAddresses } : undefined,\n\t\t\t\t\t\tReplyToAddresses: replyToAddresses,\n\t\t\t\t\t\t\tContent: {\n\t\t\t\t\t\t\t\tRaw: {\n\t\t\t\t\t\t\t\t\tData: rawMessageData\n\t\t\t\t\t\t\t\t}\n\t\t\t\t\t\t\t}\n\t\t\t\t\t\t}));\n\n\t\t\t\t\tfinish(null, {\n\t\t\t\t\t\tenvelope,\n\t\t\t\t\t\tmessageId: response.MessageId,\n\t\t\t\t\t\tresponse: response.MessageId\n\t\t\t\t\t});\n\t\t\t\t}\n\t\t\t\tcatch (error) {\n\t\t\t\t\tfinish(error);\n\t\t\t\t}\n\t\t\t});\n\t\t}\n\t};\n\n\treturn nodemailer.createTransport(transport);\n}\n\nexport class AWS {\n\tprivate _s3: S3 = null;\n\tprivate _s3USEast1: S3 = null;\n\n\tconstructor() {}\n\n\tpublic create() {\n\t\tconst aws = new AWS();\n\t\taws.initialize();\n\t\treturn aws;\n\t}\n\n\tprivate initialize() {\n\n\t}\n\n\tpublic s3(): S3 {\n\t\tif (this._s3) {\n\t\t\treturn this._s3;\n\t\t}\n\n\t\tthis._s3 = new S3({\n\t\t\tcredentials: {\n\t\t\t\taccessKeyId: process.env.AWS_ACCESS_KEY,\n\t\t\t\tsecretAccessKey: process.env.AWS_SECRET_ACCESS_KEY\n\t\t\t},\n\t\t\tregion: process.env.AWS_REGION,\n\t\t\tapiVersion: '2006-03-01'\n\t\t});\n\n\t\treturn this._s3;\n\t}\n\n\tpublic s3USEast1(): S3 {\n\t\tif (process.env.AWS_REGION === 'us-east-1') {\n\t\t\treturn this.s3();\n\t\t}\n\t\telse {\n\t\t\tif (this._s3USEast1) {\n\t\t\t\treturn this._s3USEast1;\n\t\t\t}\n\t\t\t\n\t\t\tthis._s3USEast1 = new S3({\n\t\t\t\tcredentials: {\n\t\t\t\t\taccessKeyId: process.env.AWS_ACCESS_KEY,\n\t\t\t\t\tsecretAccessKey: process.env.AWS_SECRET_ACCESS_KEY\n\t\t\t\t},\n\t\t\t\tregion: 'us-east-1',\n\t\t\t\tapiVersion: '2006-03-01'\n\t\t\t});\n\t\n\t\t\treturn this._s3USEast1;\n\t\t}\n\t}\n}\n\nexport class MethodManager {\n\tprivate _websocketManager: WebSocketManager;\n\tpublic _methods: MethodModel = {};\n\tprivate _mailerSES: nodemailer.Transporter;\n\tprivate _mailerCustom: nodemailer.Transporter;\n\tprivate _aws: AWS;\n\tprivate _monitorManagerFunction: MonitorManagerFunction;\n\tprivate _isWorkersEnabled = false;\n\tprivate _isWorkerInstance = false;\n\n\tprivate emailQueue: Set<string> = new Set(); // Set to store pending email IDs\n\tprivate isEmailProcessing = false;\n\tprivate readonly _emailProcessingDelayMs = 5000;\n\n\tprivate _debugcallMethodHits = 0;\n\tprivate _debugCallMethodHits = 0;\n\tprivate _debugCallMethodCronJobHits = 0;\n\tprivate _debugSendQueueHits = 0;\n\tprivate _enableDebug = false;\n\tprivate _ready = false;\n\tprivate _readyEmitter = new EventEmitter();\n\tprivate _readyError: any = null;\n\n\tprivate _localActiveCounts: Map<string, number> = new Map();\n\tprivate _localWaitQueues: Map<string, Array<() => void>> = new Map();\n\n\tpublic clientDir = '';\n\tpublic serverConfig: Record<string, any> = {};\n\n\tconstructor() {}\n\n\tstatic create(websocketManager: WebSocketManager, monitorManagerFunction: MonitorManagerFunction, isWorkersEnabled, isWorkerInstance) {\n\t\tconst methodManager = new MethodManager();\n\t\tmethodManager.initialize(websocketManager, monitorManagerFunction, isWorkersEnabled, isWorkerInstance);\n\t\treturn methodManager;\n\t}\n\n\tprivate initialize(websocketManager: WebSocketManager, monitorManagerFunction: MonitorManagerFunction, isWorkersEnabled, isWorkerInstance) {\n\t\tthis._websocketManager = websocketManager;\n\t\tthis._monitorManagerFunction = monitorManagerFunction;\n\t\tthis._isWorkersEnabled = isWorkersEnabled;\n\t\tthis._isWorkerInstance = isWorkerInstance;\n\t\t\n\t\tthis.clientDir = ResolveIOServer.getClientDir();\n\t\tthis.serverConfig = ResolveIOServer.getServerConfig();\n\n\t\t// Fixtures\n\t\tif (!process.env.IS_WORKERS_ENABLED || process.env.IS_WORKERS_ENABLED === 'false' || (process.env.IS_WORKER_INSTANCE === 'true' && process.env.WORKER_INDEX === '0')) {\n\t\t\tif (!process.env.NODE_APP_INSTANCE || process.env.NODE_APP_INSTANCE === '0') {\n\t\t\t\tsetTimeout(async () => {\n\t\t\t\t\tconsole.log(new Date(), 'Start Server Fixture');\n\t\t\t\t\tawait loadServerInit();\n\t\t\t\t\tconsole.log(new Date(), 'End Server Fixture');\n\t\t\t\t}, 5000);\n\t\t\t}\n\t\t}\n\t\t\n\t\tsetImmediate(async () => {\n\t\t\ttry {\n\t\t\t\t// Methods\n\t\t\t\tawait loadServerCronJobs();\n\n\t\t\t\tloadAccountMethods(this);\n\t\t\t\tloadAWSMethods(this);\n\t\t\t\tloadAiTerminalMethods(this);\n\t\t\t\tloadCollectionMethods(this);\n\t\t\t\tloadCounterMethods(this);\n\t\t\t\tloadLogMethods(this);\n\t\t\t\tloadPDFMethods(this);\n\t\t\t\tloadCronJobMethods(this);\n\t\t\t\tloadFlagMethods(this);\n\t\t\t\tloadFlagUpdatesMethods(this);\n\t\t\t\tloadReportBuilderMethods(this);\n\t\t\t\tloadSupportMethods(this);\n\t\t\t\tloadMonitorMethods(this);\n\t\t\t\tloadMongoExplorerMethods(this);\n\t\t\t\tloadPublicationMethods(this);\n\n\t\t\t\tlet flag = await Flags.findOne({type: 'Enable Debug'});\n\t\t\n\t\t\t\tif (flag && flag.value) {\n\t\t\t\t\tthis._enableDebug = true;\n\t\t\t\t}\n\t\t\t\telse {\n\t\t\t\t\tthis._enableDebug = false;\n\t\t\t\t}\n\n\t\t\t\tawait this.loadPendingEmails();\n\t\t\t\tthis.markReady();\n\t\t\t}\n\t\t\tcatch (error) {\n\t\t\t\tconsole.error(new Date(), 'Method Manager init failed', error);\n\t\t\t\tthis.markReadyFailure(error);\n\t\t\t}\n\t\t});\n\t\t\t\n\t\t\tthis._aws = new AWS();\n\n\t\t\tconst sesRegion = process.env.AWS_SES_REGION || process.env.AWS_REGION || process.env.AWS_DEFAULT_REGION || 'us-east-1';\n\t\t\tconst sesCredentials = process.env.AWS_ACCESS_KEY && process.env.AWS_SECRET_ACCESS_KEY ? {\n\t\t\t\taccessKeyId: process.env.AWS_ACCESS_KEY,\n\t\t\t\tsecretAccessKey: process.env.AWS_SECRET_ACCESS_KEY,\n\t\t\t\tsessionToken: process.env.AWS_SESSION_TOKEN\n\t\t\t} : undefined;\n\n\t\t\tthis._mailerSES = createNodeMailerSESV2Transport(new SESv2Client({\n\t\t\t\tregion: sesRegion,\n\t\t\t\tcredentials: sesCredentials\n\t\t\t}));\n\t\t\t\n\t\t\tif (!ResolveIOServer.getSESMail()) {\n\t\t\t\tthis._mailerCustom = nodemailer.createTransport({\n\t\t\t\t\thost: ResolveIOServer.getServerConfig()['MAIL_HOST'], // 'smtp.office365.com', // Office 365 server\n\t\t\t\t\tport: ResolveIOServer.getServerConfig()['MAIL_PORT'], //587, // secure SMTP\n\t\t\t\tsecure: false, // false for TLS - as a boolean not string - but the default is false so just remove this completely\n\t\t\t\tauth: {\n\t\t\t\t\tuser: ResolveIOServer.getServerConfig()['MAIL_USERNAME'],\n\t\t\t\t\tpass: ResolveIOServer.getServerConfig()['MAIL_PASSWORD']\n\t\t\t\t},\n\t\t\t\ttls: {\n\t\t\t\t\tciphers: 'SSLv3'\n\t\t\t\t}\n\t\t\t});\n\t\t}\n\n\t\tsetInterval(async () => {\n\t\t\tlet flag = await Flags.findOne({type: 'Enable Debug'});\n\t\n\t\t\tif (flag && flag.value) {\n\t\t\t\tthis._enableDebug = true;\n\t\t\t}\n\t\t\telse {\n\t\t\t\tthis._enableDebug = false;\n\t\t\t}\n\n\t\t\tif (this._enableDebug) {\n\t\t\t\tconsole.log(new Date(), 'Method Manager', 'Send Queue Hits', this._debugSendQueueHits);\n\t\t\t\tconsole.log(new Date(), 'Method Manager', 'Call Method Internal Hits', this._debugcallMethodHits);\n\t\t\t\tconsole.log(new Date(), 'Method Manager', 'Call Method Hits', this._debugCallMethodHits);\n\t\t\t\tconsole.log(new Date(), 'Method Manager', 'Call Method Cron Hits', this._debugCallMethodCronJobHits);\n\t\t\t}\n\n\t\t\tthis._debugcallMethodHits = 0;\n\t\t\tthis._debugCallMethodHits = 0;\n\t\t\tthis._debugCallMethodCronJobHits = 0;\n\t\t\tthis._debugSendQueueHits = 0;\n\t\t}, 60000);\n\n\t\tif (!this._isWorkersEnabled || this._isWorkerInstance) {\n\t\t\tthis.setupEmailWatcher();\n\t\t}\n\t}\n\n\tprivate markReady(): void {\n\t\tif (this._ready) {\n\t\t\treturn;\n\t\t}\n\t\tthis._ready = true;\n\t\tthis._readyEmitter.emit('ready');\n\t\tthis._readyEmitter.removeAllListeners('ready');\n\t\tthis._readyEmitter.removeAllListeners('readyError');\n\t}\n\n\tprivate markReadyFailure(error: any): void {\n\t\tif (this._ready) {\n\t\t\treturn;\n\t\t}\n\t\tthis._readyError = error;\n\t\tthis._readyEmitter.emit('readyError', error);\n\t\tthis._readyEmitter.removeAllListeners('ready');\n\t\tthis._readyEmitter.removeAllListeners('readyError');\n\t}\n\n\tpublic onReady(callback: () => void): () => void {\n\t\tif (this._ready) {\n\t\t\tcallback();\n\t\t\treturn () => {};\n\t\t}\n\t\tif (this._readyError) {\n\t\t\treturn () => {};\n\t\t}\n\n\t\tconst handleReady = () => {\n\t\t\tcallback();\n\t\t};\n\n\t\tthis._readyEmitter.once('ready', handleReady);\n\n\t\treturn () => {\n\t\t\tthis._readyEmitter.removeListener('ready', handleReady);\n\t\t};\n\t}\n\n\tprivate async waitForReadyEvent(): Promise<void> {\n\t\tawait once(this._readyEmitter, 'ready');\n\t}\n\n\tprivate async waitForReadyError(): Promise<void> {\n\t\tconst [error] = await once(this._readyEmitter, 'readyError');\n\t\tthrow error || new Error('MethodManager failed to initialize');\n\t}\n\n\tprivate async waitForReadyTimeout(timeoutMs: number): Promise<void> {\n\t\tawait delay(timeoutMs);\n\t\tthrow new Error('MethodManager ready timeout');\n\t}\n\n\tpublic isReady(): boolean {\n\t\treturn this._ready;\n\t}\n\n\tpublic getReadyError(): any {\n\t\treturn this._readyError;\n\t}\n\n\tpublic async waitUntilReady(timeoutMs: number = 30000): Promise<void> {\n\t\tif (this._ready) {\n\t\t\treturn;\n\t\t}\n\t\tif (this._readyError) {\n\t\t\tthrow this._readyError;\n\t\t}\n\t\tif (!timeoutMs || timeoutMs <= 0) {\n\t\t\tawait Promise.race([\n\t\t\t\tthis.waitForReadyEvent(),\n\t\t\t\tthis.waitForReadyError()\n\t\t\t]);\n\t\t\treturn;\n\t\t}\n\t\tawait Promise.race([\n\t\t\tthis.waitForReadyEvent(),\n\t\t\tthis.waitForReadyError(),\n\t\t\tthis.waitForReadyTimeout(timeoutMs)\n\t\t]);\n\t}\n\n\tpublic getMethod(methodName: string): MethodAllModel {\n\t\treturn this._methods[methodName];\n\t}\n\n\t// Add methods to private methods object\n\tpublic methods(method: MethodModel) {\n\t\tthis._methods = Object.assign(this._methods, method);\n\t}\n\n\tprivate async reportMethodError(\n\t\tsubject: string,\n\t\tcorrelationId: string,\n\t\tcontext: Record<string, any> | string,\n\t\tmeta: Record<string, any>,\n\t\tstack?: string\n\t) {\n\t\tconst metadata = Object.assign({}, meta || {});\n\t\tif (correlationId && !metadata.correlationId) {\n\t\t\tmetadata.correlationId = correlationId;\n\t\t}\n\n\t\tawait ErrorReporter.report({\n\t\t\tsourceApp: 'method-manager',\n\t\t\tmessage: subject,\n\t\t\tenvironment: this.serverConfig?.ROOT_URL,\n\t\t\tclientSlug: ResolveIOServer.getClientName(),\n\t\t\tclientName: this.serverConfig?.CLIENT_NAME,\n\t\t\tseverity: 'error',\n\t\t\tstack,\n\t\t\tcontext,\n\t\t\tmetadata,\n\t\t\tcorrelationId\n\t\t});\n\t}\n\n\tpublic async callMethodCron(method: string, ...methodData: any[]) {\n\t\tthis._debugCallMethodCronJobHits += 1;\n\n\t\tconst existingCorrelationId = getCorrelationId();\n\t\tconst correlationId = existingCorrelationId || objectIdHexString();\n\n\t\tconst execute = async () => {\n\t\t\tconst cronMethod = this._methods[method];\n\n\t\t\tif (!cronMethod) {\n\t\t\t\tconsole.log('No Method: ' + method);\n\n\t\t\t\tawait this.reportMethodError(\n\t\t\t\t\t'SERVER - Error Detected - ' + this.serverConfig['CLIENT_NAME'],\n\t\t\t\t\tcorrelationId,\n\t\t\t\t\t{ message: 'No Method registered for cron execution', method },\n\t\t\t\t\t{ context: 'callMethodCron', method }\n\t\t\t\t);\n\n\t\t\t\tthrow new Error('No Method: ' + method);\n\t\t\t}\n\t\t\t\n\t\t\tif ((methodData.length > 1 || methodData[0]) && !cronMethod.skipValidation) {\n\t\t\t\tif (!cronMethod.check) {\n\t\t\t\t\tconsole.error(new Date(), 'No Check Function For Cron Method ' + method);\n\n\t\t\t\t\tawait this.reportMethodError(\n\t\t\t\t\t\t'SERVER - Error Detected - ' + this.serverConfig['CLIENT_NAME'],\n\t\t\t\t\t\tcorrelationId,\n\t\t\t\t\t\t{ message: 'Missing check function for cron method', method },\n\t\t\t\t\t\t{ context: 'callMethodCron-validation', method }\n\t\t\t\t\t);\n\t\t\n\t\t\t\t\tthrow new Error('No Check Function For Cron Method ' + method);\n\t\t\t\t}\n\t\t\t\telse if (!cronMethod.check._schema) {\n\t\t\t\t\tconsole.error(new Date(), 'No Check Schema For Cron Method ' + method);\n\n\t\t\t\t\tawait this.reportMethodError(\n\t\t\t\t\t\t'SERVER - Error Detected - ' + this.serverConfig['CLIENT_NAME'],\n\t\t\t\t\t\tcorrelationId,\n\t\t\t\t\t\t{ message: 'Missing check schema for cron method', method },\n\t\t\t\t\t\t{ context: 'callMethodCron-validation', method }\n\t\t\t\t\t);\n\t\t\n\t\t\t\t\tthrow new Error('No Check Schema For Cron Method ' + method);\n\t\t\t\t}\n\t\t\t\telse {\n\t\t\t\t\tconst valObj = {};\n\t\t\t\t\tconst valKeys = Object.keys(cronMethod.check._schema);\n\n\t\t\t\t\tconst rootKeys = valKeys.filter(a => !a.includes('.'));\n\t\t\t\t\t\n\t\t\t\t\tfor (let i = 0; i < methodData.length; i++) {\n\t\t\t\t\t\tvalObj[rootKeys[i]] = methodData[i];\n\t\t\t\t\t}\n\n\t\t\t\t\ttry {\n\t\t\t\t\t\tcronMethod.check.validate(valObj);\n\t\t\t\t\t}\n\t\t\t\t\tcatch (err) {\n\t\t\t\t\t\tconsole.error(new Date(), 'Error in Cron Method Check (' + method + ')', err);\n\n\t\t\t\t\t\tconst { error: normalizedError, correlationId: resolvedCorrelationId } = ensureErrorWithCorrelation(err, correlationId);\n\n\t\t\t\t\t\tawait this.reportMethodError(\n\t\t\t\t\t\t\t'SERVER - Error Detected - ' + this.serverConfig['CLIENT_NAME'],\n\t\t\t\t\t\t\tresolvedCorrelationId,\n\t\t\t\t\t\t\t{\n\t\t\t\t\t\t\t\tmessage: 'Match error on cron method',\n\t\t\t\t\t\t\t\tmethod,\n\t\t\t\t\t\t\t\tdata: valObj,\n\t\t\t\t\t\t\t\tvalidationError: normalizedError\n\t\t\t\t\t\t\t},\n\t\t\t\t\t\t\t{ context: 'callMethodCron-validation-error', method },\n\t\t\t\t\t\t\tnormalizedError.stack\n\t\t\t\t\t\t);\n\t\t\t\t\t\tnormalizedError.message = `${new Date().toISOString()} - Error in Cron Method Check (${method}): ${normalizedError.message}`;\n\n\t\t\t\t\t\tthrow normalizedError;\n\t\t\t\t\t}\n\t\t\t\t}\n\t\t\t}\n\n\t\t\tconst monitor = this._monitorManagerFunction.startMonitorFunction('Cron Method', method, '', '', methodData);\n\n\t\t\ttry {\n\t\t\t\tconst res = await cronMethod.function.call(Object.assign({}, this, MethodManager.prototype, {id_user: '', user: '', id_ws: ''}), ...methodData);\n\t\t\t\treturn res;\n\t\t\t}\n\t\t\tcatch (err) {\n\t\t\t\tconst { error: normalizedError, correlationId: resolvedCorrelationId } = ensureErrorWithCorrelation(err, correlationId);\n\n\t\t\t\tawait this.reportMethodError(\n\t\t\t\t\t'SERVER - Error Detected - ' + this.serverConfig['CLIENT_NAME'],\n\t\t\t\t\tresolvedCorrelationId,\n\t\t\t\t\t{\n\t\t\t\t\t\tmessage: 'Error detected during cron method execution',\n\t\t\t\t\t\tmethod,\n\t\t\t\t\t\tdata: methodData,\n\t\t\t\t\t\terror: normalizedError\n\t\t\t\t\t},\n\t\t\t\t\t{ context: 'callMethodCron-execution', method },\n\t\t\t\t\tnormalizedError.stack\n\t\t\t\t);\n\t\t\t\t\n\t\t\t\tnormalizedError.message = `${new Date().toISOString()} - Error in Cron Method (${method}): ${normalizedError.message}`;\n\t\t\t\t\n\t\t\t\tthrow normalizedError;\n\t\t\t}\n\t\t\tfinally {\n\t\t\t\tawait this._monitorManagerFunction.finishMonitorFunction(monitor);\n\t\t\t}\n\t\t};\n\n\t\treturn await runWithCorrelationContext(correlationId, execute);\n\t}\n\n\t// Call/run method internal (No Emit on Socket)\n\tpublic async callMethod(methodName: string, ...methodData: any[]): Promise<any> {\n\t\tthis._debugcallMethodHits += 1;\n\n\t\tconst existingCorrelationId = getCorrelationId();\n\t\tconst correlationId = existingCorrelationId || objectIdHexString();\n\n\t\treturn await runWithCorrelationContext(correlationId, async () => await this.callMethodInternal(correlationId, methodName, methodData));\n\t}\n\n\tprivate async callMethodInternal(correlationId: string, methodName: string, methodData: any[]): Promise<any> {\n\t\tconst method = this.getMethod(methodName);\n\n\t\tif (!method) {\n\t\t\tconsole.log('No Method: ' + methodName);\n\t\t\tthrow new Error(`No Method: ${methodName}`);\n\t\t}\n\n\t\tconst shouldTrackTextMetric = this.shouldTrackTextMessageMetric(methodName);\n\t\tconst textMetricProvider = shouldTrackTextMetric ? this.getTextMessageProvider() : undefined;\n\n\t\tlet releaseLocalConcurrency = await this.acquireLocalConcurrency(methodName, method.maxConcurrency);\n\n\t\ttry {\n\t\t\tif ((methodData.length > 1 || (methodData[0] && typeof methodData[0] !== 'function')) && !method.skipValidation) {\n\t\t\t\tif (!method.check) {\n\t\t\t\t\tconsole.error(new Date(), 'No Check Function For Method ' + methodName);\n\t\t\t\t\tthrow new Error(`No Check Function For Method: ${methodName}`);\n\t\t\t\t}\n\t\t\t\telse if (!method.check._schema) {\n\t\t\t\t\tconsole.error(new Date(), 'No Check Schema For Method ' + methodName);\n\t\t\t\t\tthrow new Error(`No Check Schema For Method: ${methodName}`);\n\t\t\t\t}\n\t\t\t}\n\n\t\t\tif (methodName !== 'insertSubscriptionLog' && \n\t\t\t\tmethodName !== 'getDataURIfromURL' && \n\t\t\t\tmethodName !== 'processAirdropDistribution' && \n\t\t\t\tmethodName !== 'incCounter' && \n\t\t\t\tmethodName !== 'supportCreateBillingUser' && \n\t\t\t\tmethodName !== 'countCollectionWithQuery' &&\n\t\t\t\tmethodName !== 'countWithQuery' &&\n\t\t\t\tmethodName !== 'qbFetchRequests' &&\n\t\t\t\tmethodName !== 'qbHandleResponse'\n\t\t\t) {\n\t\t\t\tif (\n\t\t\t\t\tResolveIOServer.getServerConfig()['ROOT_URL'] !== 'https://resolveio.com'\n\t\t\t\t&& ResolveIOServer.getServerConfig()['ROOT_URL'] !== 'http://localhost:4200'\n\t\t\t\t) {\n\t\t\t\t\t\t\tResolveIOServer.getLocalLogManager().writeLog({\n\t\t\t\t\t\t\t\ttype: 'log',\n\t\t\t\t\t\t\t\tdata: {\n\t\t\t\t\t\t\t\t\t_id: objectIdHexString(),\n\t\t\t\t\t\t\t\t\tcreatedAt: new Date(),\n\t\t\t\t\t\t\t\t\ttype: 'callMethod',\n\t\t\t\t\t\t\t\t\tcollection: '',\n\t\t\t\t\t\t\t\t\tid_document: '',\n\t\t\t\t\t\t\t\t\tpayload: getBinarySize(JSON.stringify([methodData])) < 1000000 ? JSON.stringify([methodData], null, 2) : 'Too Big',\n\t\t\t\t\t\t\t\t\tmethod: methodName,\n\t\t\t\t\t\t\t\t\tid_user: this['id_user'] || '',\n\t\t\t\t\t\t\t\t\tuser: this['user'] || '', \n\t\t\t\t\t\t\t\t\tmessageId: 0,\n\t\t\t\t\t\t\t\t\troute: '',\n\t\t\t\t\t\t\t\t\tinstance_index: process.env.NODE_APP_INSTANCE || '0',\n\t\t\t\t\t\t\t\t\tcorrelationId\n\t\t\t\t\t\t\t\t}\n\t\t\t\t\t\t\t});\n\t\t\t\t}\n\t\t\t\telse {\n\t\t\t\t\tawait Logs.insertOne({\n\t\t\t\t\t\t_id: objectIdHexString(),\n\t\t\t\t\t\ttype: 'callMethod',\n\t\t\t\t\t\tcollection: '',\n\t\t\t\t\t\tid_document: '',\n\t\t\t\t\t\tpayload: getBinarySize(JSON.stringify([methodData])) < 1000000 ? JSON.stringify([methodData], null, 2) : 'Too Big',\n\t\t\t\t\t\tmethod: methodName,\n\t\t\t\t\t\tid_user: this['id_user'] || '',\n\t\t\t\t\t\tuser: this['user'] || '',\n\t\t\t\t\t\tmessageId: 0,\n\t\t\t\t\t\troute: '',\n\t\t\t\t\t\tclient: 'ResolveIO',\n\t\t\t\t\t\tinstance: 'backend.resolveio.com',\n\t\t\t\t\t\tinstance_index: process.env.NODE_APP_INSTANCE || '0',\n\t\t\t\t\t\tcorrelationId\n\t\t\t\t\t})\n\t\t\t\t};\n\t\t\t}\n\n\t\t\tconst methodCallback = typeof(methodData[methodData.length - 1]) === 'function' ? methodData[methodData.length - 1] : null;\n\t\t\tconst functionMethodData = methodCallback ? methodData.slice(0, -1) : methodData;\n\n\t\t\tconst session = ResolveIOServer.getMongoManager().getSession();\n\t\t\tconst shouldStartTransaction = !method.bypassSession &&\n\t\t\t\t!session && \n\t\t\t\t![\n\t\t\t\t\t'insertErrorLog', // CIRCULAR LOOP - DO NOT REMOVE\n\t\t\t\t\t'countWithQuery', // MONGO SESSIONS/TRANSACTIONS DONT WORK WITH COUNTS\n\t\t\t\t\t'sendEmail' // ALWAYS SEND SO ALWAYS HAVE RECORD - DONT ROLL BACK - BYPASS SESSION\n\t\t\t\t].includes(methodName) &&\n\t\t\t\t!methodName.startsWith('monitor-') &&\n\t\t\t\t!methodName.startsWith('log');\n\n\t\t\tconst executeWithExistingSession = async () => {\n\t\t\t\t// console.log(new Date(), 'Calling Method - Existing Session', methodName);\n\t\t\t\tlet monitor = this._monitorManagerFunction.startMonitorFunction('Method', methodName, this['user'] || '', '', functionMethodData);\n\n\t\t\t\ttry {\n\t\t\t\t\tlet res = await method.function.call(Object.assign({}, this, MethodManager.prototype), ...functionMethodData);\n\n\t\t\t\t\tif (methodCallback) {\n\t\t\t\t\t\tmethodCallback(null, res);\n\t\t\t\t\t}\n\n\t\t\t\t\tif (shouldTrackTextMetric) {\n\t\t\t\t\t\ttry {\n\t\t\t\t\t\t\tawait recordTextMessageMetric({\n\t\t\t\t\t\t\t\tstatus: 'sent',\n\t\t\t\t\t\t\t\tprovider: textMetricProvider,\n\t\t\t\t\t\t\t\tmetadata: {\n\t\t\t\t\t\t\t\t\tmethod: methodName\n\t\t\t\t\t\t\t\t}\n\t\t\t\t\t\t\t});\n\t\t\t\t\t\t}\n\t\t\t\t\t\tcatch (error) {\n\t\t\t\t\t\t\tconsole.error('Error recording text message metric:', error);\n\t\t\t\t\t\t}\n\t\t\t\t\t}\n\n\t\t\t\t\treturn res;\n\t\t\t\t}\n\t\t\t\tcatch (err) {\n\t\t\t\t\tif (err.code === 112 || err.codeName === 'WriteConflict' || err.code === 251 || err.codeName === 'NoSuchTransaction') {\n\t\t\t\t\t\tthrow err; // Write error, retry\n\t\t\t\t\t}\n\n\t\t\t\t\tconst { error: normalizedError, correlationId: resolvedCorrelationId } = ensureErrorWithCorrelation(err, correlationId);\n\n\t\t\t\t\tconsole.log(JSON.stringify([new Date(), 'Error Method Manager - Run Method - Existing Session', methodName, {\n\t\t\t\t\t\tcode: normalizedError.code,\n\t\t\t\t\t\tcodeName: normalizedError.codeName,\n\t\t\t\t\t\tmessage: normalizedError.message,\n\t\t\t\t\t\tstack: normalizedError.stack,\n\t\t\t\t\t\tcorrelationId: resolvedCorrelationId\n\t\t\t\t\t}], null, 2));\n\n\t\t\t\t\tawait this.reportMethodError(\n\t\t\t\t\t\t'SERVER - Error Detected - ' + this.serverConfig['CLIENT_NAME'],\n\t\t\t\t\t\tresolvedCorrelationId,\n\t\t\t\t\t\t{\n\t\t\t\t\t\t\tmessage: 'Error detected during method execution (existing session)',\n\t\t\t\t\t\t\tmethod: methodName,\n\t\t\t\t\t\t\tdata: methodData,\n\t\t\t\t\t\t\terror: normalizedError\n\t\t\t\t\t\t},\n\t\t\t\t\t\t{ context: 'callMethod-existing-session', methodName },\n\t\t\t\t\t\tnormalizedError.stack\n\t\t\t\t\t);\n\t\t\t\t\tnormalizedError.message = `${new Date().toISOString()} - Error in Method (${methodName}) - Existing Session: ${normalizedError.message}`;\n\n\t\t\t\t\tif (methodCallback) {\n\t\t\t\t\t\tmethodCallback(normalizedError, null);\n\t\t\t\t\t}\n\n\t\t\t\t\tif (shouldTrackTextMetric) {\n\t\t\t\t\t\ttry {\n\t\t\t\t\t\t\tawait recordTextMessageMetric({\n\t\t\t\t\t\t\t\tstatus: 'failed',\n\t\t\t\t\t\t\t\tprovider: textMetricProvider,\n\t\t\t\t\t\t\t\tmetadata: {\n\t\t\t\t\t\t\t\t\tmethod: methodName\n\t\t\t\t\t\t\t\t}\n\t\t\t\t\t\t\t});\n\t\t\t\t\t\t}\n\t\t\t\t\t\tcatch (error) {\n\t\t\t\t\t\t\tconsole.error('Error recording text message metric:', error);\n\t\t\t\t\t\t}\n\t\t\t\t\t}\n\n\t\t\t\t\tif (!process.env.IS_WORKER_INSTANCE) {\n\t\t\t\t\t\tawait this.callMethod(\n\t\t\t\t\t\t\t'insertErrorLog',\n\t\t\t\t\t\t\t`Error in Method: ${methodName}`,\n\t\t\t\t\t\t\t{\n\t\t\t\t\t\t\t\tmethod: methodName,\n\t\t\t\t\t\t\t\tmethodData,\n\t\t\t\t\t\t\t\terror: {\n\t\t\t\t\t\t\t\t\tmessage: normalizedError.message,\n\t\t\t\t\t\t\t\t\tstack: normalizedError.stack,\n\t\t\t\t\t\t\t\t\tcode: normalizedError.code,\n\t\t\t\t\t\t\t\t\tcodeName: normalizedError.codeName\n\t\t\t\t\t\t\t\t},\n\t\t\t\t\t\t\t\tcorrelationId: resolvedCorrelationId\n\t\t\t\t\t\t\t}\n\t\t\t\t\t\t);\n\t\t\t\t\t}\n\t\t\t\t\t\n\t\t\t\t\tthrow normalizedError;\n\t\t\t\t}\n\t\t\t\tfinally {\n\t\t\t\t\tawait this._monitorManagerFunction.finishMonitorFunction(monitor);\n\t\t\t\t}\n\t\t\t};\n\n\t\t\tif (shouldStartTransaction) {\n\t\t\t\tlet monitor = null;\n\t\t\t\t\n\t\t\t\treturn ResolveIOServer.getMongoManager().oneTimeTransaction(async () => {\n\t\t\t\t\t// console.log(new Date(), 'Calling Method - New Session', methodName);\n\n\t\t\t\t\tmonitor = this._monitorManagerFunction.startMonitorFunction('Method', methodName, this['user'] || '', '', functionMethodData);\n\t\t\t\t\t\n\t\t\t\t\ttry {\n\t\t\t\t\t\tlet res = await method.function.call(Object.assign({}, this, MethodManager.prototype), ...functionMethodData);\n\n\t\t\t\t\t\tif (methodCallback) {\n\t\t\t\t\t\t\tmethodCallback(null, res);\n\t\t\t\t\t\t}\n\n\t\t\t\t\t\tif (shouldTrackTextMetric) {\n\t\t\t\t\t\t\ttry {\n\t\t\t\t\t\t\t\tawait recordTextMessageMetric({\n\t\t\t\t\t\t\t\t\tstatus: 'sent',\n\t\t\t\t\t\t\t\t\tprovider: textMetricProvider,\n\t\t\t\t\t\t\t\t\tmetadata: {\n\t\t\t\t\t\t\t\t\t\tmethod: methodName\n\t\t\t\t\t\t\t\t\t}\n\t\t\t\t\t\t\t\t});\n\t\t\t\t\t\t\t}\n\t\t\t\t\t\t\tcatch (error) {\n\t\t\t\t\t\t\t\tconsole.error('Error recording text message metric:', error);\n\t\t\t\t\t\t\t}\n\t\t\t\t\t\t}\n\n\t\t\t\t\t\treturn res;\n\t\t\t\t\t}\n\t\t\t\t\tcatch (err) {\n\t\t\t\t\t\tif (err.code === 112 || err.codeName === 'WriteConflict' || err.code === 251 || err.codeName === 'NoSuchTransaction') {\n\t\t\t\t\t\t\tthrow err; // Write error, retry\n\t\t\t\t\t\t}\n\n\t\t\t\t\t\tconst { error: normalizedError, correlationId: resolvedCorrelationId } = ensureErrorWithCorrelation(err, correlationId);\n\n\t\t\t\t\t\tconsole.log(JSON.stringify([new Date(), 'Error Method Manager - Run Method - New Session', methodName, {\n\t\t\t\t\t\t\tcode: normalizedError.code,\n\t\t\t\t\t\t\tcodeName: normalizedError.codeName,\n\t\t\t\t\t\t\tmessage: normalizedError.message,\n\t\t\t\t\t\t\tstack: normalizedError.stack,\n\t\t\t\t\t\t\tcorrelationId: resolvedCorrelationId\n\t\t\t\t\t\t}], null, 2));\n\n\t\t\t\t\t\tawait this.reportMethodError(\n\t\t\t\t\t\t\t'SERVER - Error Detected - ' + this.serverConfig['CLIENT_NAME'],\n\t\t\t\t\t\t\tresolvedCorrelationId,\n\t\t\t\t\t\t\t{\n\t\t\t\t\t\t\t\tmessage: 'Error detected during method execution (new session)',\n\t\t\t\t\t\t\t\tmethod: methodName,\n\t\t\t\t\t\t\t\tdata: methodData,\n\t\t\t\t\t\t\t\terror: normalizedError\n\t\t\t\t\t\t\t},\n\t\t\t\t\t\t\t{ context: 'callMethod-new-session', methodName },\n\t\t\t\t\t\t\tnormalizedError.stack\n\t\t\t\t\t\t);\n\t\t\t\t\t\tnormalizedError.message = `${new Date().toISOString()} - Error in Method With Session (${methodName}) - New Session: ${normalizedError.message}`;\n\n\t\t\t\t\t\tif (methodCallback) {\n\t\t\t\t\t\t\tmethodCallback(normalizedError, null);\n\t\t\t\t\t\t}\n\n\t\t\t\t\t\tif (shouldTrackTextMetric) {\n\t\t\t\t\t\t\ttry {\n\t\t\t\t\t\t\t\tawait recordTextMessageMetric({\n\t\t\t\t\t\t\t\t\tstatus: 'failed',\n\t\t\t\t\t\t\t\t\tprovider: textMetricProvider,\n\t\t\t\t\t\t\t\t\tmetadata: {\n\t\t\t\t\t\t\t\t\t\tmethod: methodName\n\t\t\t\t\t\t\t\t\t}\n\t\t\t\t\t\t\t\t});\n\t\t\t\t\t\t\t}\n\t\t\t\t\t\t\tcatch (error) {\n\t\t\t\t\t\t\t\tconsole.error('Error recording text message metric:', error);\n\t\t\t\t\t\t\t}\n\t\t\t\t\t\t}\n\n\t\t\t\t\t\tif (!process.env.IS_WORKER_INSTANCE) {\n\t\t\t\t\t\t\tawait this.callMethod(\n\t\t\t\t\t\t\t\t'insertErrorLog',\n\t\t\t\t\t\t\t\t`Error in Method: ${methodName}`,\n\t\t\t\t\t\t\t\t{\n\t\t\t\t\t\t\t\t\tmethod: methodName,\n\t\t\t\t\t\t\t\t\tmethodData,\n\t\t\t\t\t\t\t\t\terror: {\n\t\t\t\t\t\t\t\t\t\tmessage: normalizedError.message,\n\t\t\t\t\t\t\t\t\t\tstack: normalizedError.stack,\n\t\t\t\t\t\t\t\t\t\tcode: normalizedError.code,\n\t\t\t\t\t\t\t\t\t\tcodeName: normalizedError.codeName\n\t\t\t\t\t\t\t\t\t},\n\t\t\t\t\t\t\t\t\tcorrelationId: resolvedCorrelationId\n\t\t\t\t\t\t\t\t}\n\t\t\t\t\t\t\t);\n\t\t\t\t\t\t}\n\n\t\t\t\t\t\tthrow normalizedError;\n\t\t\t\t\t}\n\t\t\t\t\tfinally {\n\t\t\t\t\t\tawait this._monitorManagerFunction.finishMonitorFunction(monitor);\n\t\t\t\t\t}\n\t\t\t\t});\n\t\t\t}\n\t\t\telse if (method.bypassSession && session) {\n\t\t\t\treturn ResolveIOServer.getMongoManager().runWithoutSession(async () => await executeWithExistingSession());\n\t\t\t}\n\t\t\telse {\n\t\t\t\treturn executeWithExistingSession();\n\t\t\t}\n\t\t}\n\t\tfinally {\n\t\t\treleaseLocalConcurrency();\n\t\t}\n\t}\n\n\tprivate async acquireLocalConcurrency(methodName: string, maxConcurrency?: number): Promise<() => void> {\n\t\tif (!maxConcurrency || maxConcurrency < 1) {\n\t\t\treturn () => {};\n\t\t}\n\n\t\tlet current = this._localActiveCounts.get(methodName) || 0;\n\n\t\tif (current < maxConcurrency) {\n\t\t\tthis._localActiveCounts.set(methodName, current + 1);\n\t\t\treturn this.createLocalRelease(methodName);\n\t\t}\n\n\t\t// eslint-disable-next-line no-restricted-syntax\n\t\treturn new Promise((resolve) => {\n\t\t\tlet queue = this._localWaitQueues.get(methodName);\n\n\t\t\tif (!queue) {\n\t\t\t\tqueue = [];\n\t\t\t\tthis._localWaitQueues.set(methodName, queue);\n\t\t\t}\n\n\t\t\tqueue.push(() => {\n\t\t\t\tlet curr = this._localActiveCounts.get(methodName) || 0;\n\t\t\t\tthis._localActiveCounts.set(methodName, curr + 1);\n\t\t\t\tresolve(this.createLocalRelease(methodName));\n\t\t\t});\n\t\t});\n\t}\n\n\tprivate createLocalRelease(methodName: string): () => void {\n\t\tlet released = false;\n\n\t\treturn () => {\n\t\t\tif (released) {\n\t\t\t\treturn;\n\t\t\t}\n\n\t\t\treleased = true;\n\n\t\t\tlet current = this._localActiveCounts.get(methodName) || 0;\n\t\t\tthis._localActiveCounts.set(methodName, current > 0 ? current - 1 : 0);\n\n\t\t\tlet queue = this._localWaitQueues.get(methodName);\n\n\t\t\tif (queue && queue.length) {\n\t\t\t\tlet next = queue.shift();\n\n\t\t\t\tif (next) {\n\t\t\t\t\tnext();\n\t\t\t\t}\n\t\t\t}\n\t\t};\n\t}\n\n\tsetupEmailWatcher() {\n\t\tconst changeStream = EmailHistories.watchCollection([]);\n\n\t\tchangeStream.on('change', async (change) => {\n\t\t\tif (change.operationType === 'insert' && change.fullDocument && change.fullDocument.status === 'pending') {\n\t\t\t\tthis.emailQueue.add(change.fullDocument._id.toString());\n\t\t\t\tawait this.tryProcessEmail();\n\t\t\t}\n\t\t\telse if (change.operationType === 'update' || change.operationType === 'replace') {\n\t\t\t\tconst updatedEmail = change.fullDocument;\n\t\t\t\tif (updatedEmail && updatedEmail.status !== 'pending' && this.emailQueue.has(updatedEmail._id.toString())) {\n\t\t\t\t\tthis.emailQueue.delete(updatedEmail._id.toString());\n\t\t\t\t}\n\t\t\t}\n\t\t})\n\t\t.on('error', async err => {\n\t\t\tconsole.error('Email history changestream error', err);\n\t\t\tawait changeStream.close();\n\t\t})\n\t\t.on('close', () => {\n\t\t\tthis.setupEmailWatcher();\n\t\t});\n\t}\n\n\tasync loadPendingEmails() {\n\t\t// Load any pending emails on startup\n\t\tconst pendingEmails = await EmailHistories.find({ status: 'pending' }, {sort: {_id: 1}});\n\t\tfor (const email of pendingEmails) {\n\t\t\tthis.emailQueue.add(email._id.toString());\n\t\t}\n\t\t// Try to process emails\n\t\tawait this.tryProcessEmail();\n\t}\n\n\tasync tryProcessEmail() {\n\t\tif (this.isEmailProcessing || this.emailQueue.size === 0) {\n\t\t\treturn;\n\t\t}\n\t\n\t\tthis.isEmailProcessing = true;\n\t\n\t\ttry {\n\t\t\twhile (this.emailQueue.size > 0) {\n\t\t\t\tconst emailId = this.emailQueue.values().next().value;\n\t\t\t\tthis.emailQueue.delete(emailId);\n\t\n\t\t\t\tconst pendingEmail = await EmailHistories.findOne(\n\t\t\t\t\t{\n\t\t\t\t\t\t_id: emailId,\n\t\t\t\t\t\tstatus: 'pending',\n\t\t\t\t\t}\n\t\t\t\t);\n\n\t\t\t\tif (!pendingEmail) {\n\t\t\t\t\tcontinue;\n\t\t\t\t}\n\n\t\t\t\tlet queuedAt: Date;\n\t\t\t\tif (pendingEmail.date instanceof Date) {\n\t\t\t\t\tqueuedAt = pendingEmail.date;\n\t\t\t\t}\n\t\t\t\telse if (pendingEmail.createdAt instanceof Date) {\n\t\t\t\t\tqueuedAt = pendingEmail.createdAt;\n\t\t\t\t}\n\t\t\t\telse {\n\t\t\t\t\tqueuedAt = new Date();\n\t\t\t\t}\n\n\t\t\t\tconst timeSinceQueued = Date.now() - queuedAt.getTime();\n\t\t\t\tconst remainingDelay = this._emailProcessingDelayMs - timeSinceQueued;\n\n\t\t\t\tif (remainingDelay > 0) {\n\t\t\t\t\t// eslint-disable-next-line no-restricted-syntax\n\t\t\t\t\tawait new Promise(resolve => setTimeout(resolve, remainingDelay));\n\t\t\t\t}\n\n\t\t\t\tconst emailHistory = await EmailHistories.findOneAndUpdate(\n\t\t\t\t\t{\n\t\t\t\t\t\t_id: emailId,\n\t\t\t\t\t\tstatus: 'pending',\n\t\t\t\t\t},\n\t\t\t\t\t{\n\t\t\t\t\t\t$set: { status: 'processing', processingAt: new Date() },\n\t\t\t\t\t}\n\t\t\t\t);\n\t\n\t\t\t\tif (!emailHistory) {\n\t\t\t\t\tcontinue;\n\t\t\t\t}\n\t\n\t\t\t\t// Fetch and process attachments\n if (emailHistory.attachments && emailHistory.attachments.length > 0) {\n\t\t\t\t\tconst validAttachments: any[] = [];\n\t\t\t\t\tlet attachmentError = false;\n\n\t\t\t\t\tfor (const att of emailHistory.attachments) {\n\t\t\t\t\t\tif (att.path && att.path.startsWith('http')) {\n\t\t\t\t\t\t\ttry {\n\t\t\t\t\t\t\t\tconst response = await fetch(att.path);\n\t\t\t\t\t\t\t\tif (!response.ok) {\n\t\t\t\t\t\t\t\t\tattachmentError = true;\n\t\t\t\t\t\t\t\t\tcontinue;\n\t\t\t\t\t\t\t\t}\n\t\t\t\t\t\t\t\tconst arrayBuffer = await response.arrayBuffer();\n\t\t\t\t\t\t\t\tconst buffer = Buffer.from(arrayBuffer);\n\n\t\t\t\t\t\t\t\t// Check the size of the attachment\n\t\t\t\t\t\t\t\tconst maxSize = 20 * 1024 * 1024; // 20MB in bytes\n\t\t\t\t\t\t\t\tif (buffer.length <= maxSize) {\n\t\t\t\t\t\t\t\t\t// Attachment is within size limits, include it\n\t\t\t\t\t\t\t\t\tatt.content = buffer;\n\t\t\t\t\t\t\t\t\tdelete att.path;\n\t\t\t\t\t\t\t\t\tvalidAttachments.push(att);\n\t\t\t\t\t\t\t\t}\n\t\t\t\t\t\t\t}\n\t\t\t\t\t\t\tcatch (err) {\n\t\t\t\t\t\t\t\tconsole.error('Failed to fetch attachment:', err);\n\t\t\t\t\t\t\t\tattachmentError = true;\n\t\t\t\t\t\t\t}\n\t\t\t\t\t\t}\n\t\t\t\t\t\telse {\n\t\t\t\t\t\t\tvalidAttachments.push(att);\n\t\t\t\t\t\t}\n\t\t\t\t\t}\n\n\t\t\t\t\temailHistory.attachments = validAttachments;\n\t\t\t\t\tif (attachmentError) {\n\t\t\t\t\t\t\temailHistory.text =\n\t\t\t\t\t\t\t\t\t(typeof emailHistory.text === 'string' ? emailHistory.text : '') +\n\t\t\t\t\t\t\t\t\t'\\n\\nCould not load attachments.';\n\t\t\t\t\t\t\temailHistory.html =\n\t\t\t\t\t\t\t\t\t(typeof emailHistory.html === 'string' ? emailHistory.html : '') +\n\t\t\t\t\t\t\t\t\t'<p>Could not load attachments.</p>';\n\t\t\t\t\t}\n }\n\t\n\t\t\t\t// Prepare email options\n\t\t\t\tconst mailOptions: any = {\n\t\t\t\t\treplyTo: emailHistory.reply_to || (ResolveIOServer.getServerConfig()['MAIL_REPLY_TO'] || undefined),\n\t\t\t\t\tfrom: emailHistory.send_from || ResolveIOServer.getServerConfig().MAIL_FROM,\n\t\t\t\t\tto: emailHistory.email,\n\t\t\t\t\tsubject:\n\t\t\t\t\t\t(ResolveIOServer.getServerConfig()['ROOT_URL'].match(/https:\\/\\/dev\\./) ||\n\t\t\t\t\t\tResolveIOServer.getServerConfig()['ROOT_URL'].match(/https:\\/\\/www\\.dev\\./)\n\t\t\t\t\t\t\t? '(DEV SERVER) - '\n\t\t\t\t\t\t\t: '') + emailHistory.subject,\n\t\t\t\t\ttext: typeof emailHistory.text === 'string' ? emailHistory.text : '',\n\t\t\t\t\thtml: typeof emailHistory.html === 'string' ? emailHistory.html : '',\n\t\t\t\t\tattachments: emailHistory.attachments || [],\n\t\t\t\t\tforce_ses: emailHistory.force_ses\n\t\t\t\t};\n\t\n\t\t\t\t// Process attachments before sending\n\t\t\t\tif (mailOptions.attachments && mailOptions.attachments.length > 0) {\n\t\t\t\t\tmailOptions.attachments = mailOptions.attachments.map((att) => {\n\t\t\t\t\t\tconst newAtt = { ...att };\n\t\t\t\t\t\t// Handle attachments stored as BinData or Buffer\n\t\t\t\t\t\tif (newAtt.content && typeof newAtt.content === 'object' && !(newAtt.content instanceof Buffer)) {\n\t\t\t\t\t\t\t// Convert MongoDB's Binary data to Buffer\n\t\t\t\t\t\t\tif (newAtt.content._bsontype === 'Binary' && newAtt.content.sub_type === 0) {\n\t\t\t\t\t\t\t\tnewAtt.content = Buffer.from(newAtt.content.buffer);\n\t\t\t\t\t\t\t}\n\t\t\t\t\t\t\telse {\n\t\t\t\t\t\t\t\t// Handle other types if necessary\n\t\t\t\t\t\t\t\tnewAtt.content = Buffer.from(newAtt.content);\n\t\t\t\t\t\t\t}\n\t\t\t\t\t\t}\n\t\t\t\t\t\t// Handle attachments stored as Base64 strings\n\t\t\t\t\t\telse if (typeof newAtt.content === 'string' && newAtt.encoding === 'base64') {\n\t\t\t\t\t\t\tnewAtt.content = Buffer.from(newAtt.content, 'base64');\n\t\t\t\t\t\t\tdelete newAtt.encoding;\n\t\t\t\t\t\t}\n\t\t\t\t\t\t// Ensure the content is a Buffer\n\t\t\t\t\t\telse if (typeof newAtt.content === 'string') {\n\t\t\t\t\t\t\tnewAtt.content = Buffer.from(newAtt.content);\n\t\t\t\t\t\t}\n\t\t\t\t\t\treturn newAtt;\n\t\t\t\t\t});\n\t\t\t\t}\n\t\n\t\t\t\t// Send the email\n\t\t\t\tconst emailProvider = (!mailOptions.force_ses && this._mailerCustom) ? 'custom' : 'ses';\n\t\t\t\t(!mailOptions.force_ses && this._mailerCustom ? this._mailerCustom : this._mailerSES).sendMail(mailOptions, async err => {\n\t\t\t\t\tconst metricStatus = err ? 'failed' : 'sent';\n\n\t\t\t\t\ttry {\n\t\t\t\t\t\tif (err) {\n\t\t\t\t\t\t\tconsole.error('Failed to send email:', err);\n\t\t\t\t\t\t\tawait EmailHistories.updateOne(\n\t\t\t\t\t\t\t\t{ _id: emailHistory._id },\n\t\t\t\t\t\t\t\t{\n\t\t\t\t\t\t\t\t\t$set: {\n\t\t\t\t\t\t\t\t\t\tstatus: 'failed',\n\t\t\t\t\t\t\t\t\t\terror: typeof err === 'string' ? err : this.safeStringify(err),\n\t\t\t\t\t\t\t\t\t\tcompletedAt: new Date(),\n\t\t\t\t\t\t\t\t\t},\n\t\t\t\t\t\t\t\t}\n\t\t\t\t\t\t\t);\n\t\t\t\t\t\t}\n\t\t\t\t\t\telse {\n\t\t\t\t\t\t\tif (emailHistory.email === 'dev@resolveio.com') {\n\t\t\t\t\t\t\t\tawait EmailHistories.deleteOne({ _id: emailHistory._id });\n\t\t\t\t\t\t\t}\n\t\t\t\t\t\t\telse {\n\t\t\t\t\t\t\t\tawait EmailHistories.updateOne(\n\t\t\t\t\t\t\t\t\t{ _id: emailHistory._id },\n\t\t\t\t\t\t\t\t\t{\n\t\t\t\t\t\t\t\t\t\t$set: {\n\t\t\t\t\t\t\t\t\t\t\tstatus: 'completed',\n\t\t\t\t\t\t\t\t\t\t\tcompletedAt: new Date(),\n\t\t\t\t\t\t\t\t\t\t},\n\t\t\t\t\t\t\t\t\t}\n\t\t\t\t\t\t\t\t);\n\t\t\t\t\t\t\t}\n\t\t\t\t\t\t}\n\t\t\t\t\t}\n\t\t\t\t\tcatch (error) {\n\t\t\t\t\t\tconsole.error('Error in sendMail callback:', error);\n\t\t\t\t\t\tawait EmailHistories.updateOne(\n\t\t\t\t\t\t\t{ _id: emailHistory._id },\n\t\t\t\t\t\t\t{\n\t\t\t\t\t\t\t\t$set: {\n\t\t\t\t\t\t\t\t\tstatus: 'failed',\n\t\t\t\t\t\t\t\t\terror: typeof error === 'string' ? error : this.safeStringify(error),\n\t\t\t\t\t\t\t\t\tcompletedAt: new Date(),\n\t\t\t\t\t\t\t\t},\n\t\t\t\t\t\t\t}\n\t\t\t\t\t\t);\n\t\t\t\t\t}\n\t\t\t\t\tfinally {\n\t\t\t\t\t\ttry {\n\t\t\t\t\t\t\tawait recordEmailMetric({\n\t\t\t\t\t\t\t\tstatus: metricStatus,\n\t\t\t\t\t\t\t\tprovider: emailProvider,\n\t\t\t\t\t\t\t\tmetadata: {\n\t\t\t\t\t\t\t\t\tmethod: 'sendEmail'\n\t\t\t\t\t\t\t\t}\n\t\t\t\t\t\t\t});\n\t\t\t\t\t\t}\n\t\t\t\t\t\tcatch (error) {\n\t\t\t\t\t\t\tconsole.error('Error recording email metric:', error);\n\t\t\t\t\t\t}\n\t\t\t\t\t}\n\t\t\t\t});\n\t\n\t\t\t\t// Wait for at least one second before sending the next email\n\t\t\t\t// eslint-disable-next-line no-restricted-syntax\n\t\t\t\tawait new Promise((resolve) => setTimeout(resolve, 1000));\n\t\t\t}\n\t\t}\n\t\tcatch (err) {\n\t\t\tconsole.error('Error processing email queue:', err);\n\t\t}\n\t\tfinally {\n\t\t\tthis.isEmailProcessing = false;\n\t\t\t// Check if new emails arrived while processing\n\t\t\tif (this.emailQueue.size > 0) {\n\t\t\t\tawait this.tryProcessEmail();\n\t\t\t}\n\t\t}\n\t}\n\n\tprivate shouldTrackTextMessageMetric(methodName: string): boolean {\n\t\tconst normalized = String(methodName || '').trim().toLowerCase();\n\t\tif (!normalized) {\n\t\t\treturn false;\n\t\t}\n\n\t\treturn normalized.startsWith('sendsms') || normalized.startsWith('sendtext');\n\t}\n\n\tprivate getTextMessageProvider(): string | undefined {\n\t\tconst provider = this.serverConfig?.['SMS_PROVIDER'] || '';\n\t\tif (typeof provider === 'string' && provider.trim().length) {\n\t\t\treturn provider.trim().toLowerCase();\n\t\t}\n\n\t\tif (this.serverConfig?.['TWILIO_SID'] || this.serverConfig?.['TWILIO_AUTH_TOKEN']) {\n\t\t\treturn 'twilio';\n\t\t}\n\n\t\treturn undefined;\n\t}\n\n\tsafeStringify(obj)\n\t{\n\t\ttry\n\t\t{\n\t\t\treturn JSON.stringify(obj, this.getCircularReplacer());\n\t\t}\n\t\tcatch (e)\n\t\t{\n\t\t\treturn `Error in JSON stringifying: ${e.message}`;\n\t\t}\n\t}\n\n\tgetCircularReplacer()\n\t{\n\t\tconst seen = new WeakSet();\n\t\treturn (key, value) =>\n\t\t{\n\t\t\tif (typeof value === \"object\" && value !== null)\n\t\t\t{\n\t\t\t\tif (seen.has(value))\n\t\t\t\t{\n\t\t\t\t\treturn \"[Circular]\";\n\t\t\t\t}\n\t\t\t\tseen.add(value);\n\t\t\t}\n\t\t\treturn value;\n\t\t};\n\t}\n\n\tprivate async tryMergeEmailOccurrence(\n\t\temail: string,\n\t\tsubject: string,\n\t\tcorrelationId: string,\n\t\toccurrence: EmailHistoryOccurrence,\n\t\tmeta?: Record<string, any>\n\t): Promise<EmailHistoryModel | null> {\n\t\tconst existing = await EmailHistories.findOne(\n\t\t\t{\n\t\t\t\temail,\n\t\t\t\tcorrelationId,\n\t\t\t\tstatus: 'pending'\n\t\t\t},\n\t\t\t{ sort: { date: 1 } }\n\t\t);\n\n\t\tif (!existing) {\n\t\t\treturn null;\n\t\t}\n\n\t\tconst normalizedOccurrences: EmailHistoryOccurrence[] = Array.isArray(existing.occurrences) && existing.occurrences.length\n\t\t\t? existing.occurrences.map((item: EmailHistoryOccurrence) => ({\n\t\t\t\t_id: item._id || objectIdHexString(),\n\t\t\t\tcreatedAt: item.createdAt instanceof Date ? item.createdAt : new Date(item.createdAt),\n\t\t\t\tsubject: item.subject || existing.subject || '',\n\t\t\t\ttext: item.text,\n\t\t\t\thtml: item.html,\n\t\t\t\tmeta: item.meta\n\t\t\t}))\n\t\t\t: [createEmailOccurrence(\n\t\t\t\texisting.subject || '',\n\t\t\t\ttypeof existing.text === 'string' ? existing.text : undefined,\n\t\t\t\ttypeof existing.html === 'string' ? existing.html : undefined,\n\t\t\t\texisting.meta\n\t\t\t)];\n\n\t\tnormalizedOccurrences.push(occurrence);\n\n\t\tconst { text: aggregatedText, html: aggregatedHtml } = formatGroupedEmailContent(correlationId, normalizedOccurrences);\n\n\t\tconst updated = await EmailHistories.findOneAndUpdate(\n\t\t\t{\n\t\t\t\t_id: existing._id,\n\t\t\t\tstatus: 'pending'\n\t\t\t},\n\t\t\t{\n\t\t\t\t$set: {\n\t\t\t\t\tsubject,\n\t\t\t\t\ttext: aggregatedText,\n\t\t\t\t\thtml: aggregatedHtml,\n\t\t\t\t\toccurrences: normalizedOccurrences,\n\t\t\t\t\tmeta: meta || existing.meta,\n\t\t\t\t\tupdatedAt: new Date()\n\t\t\t\t}\n\t\t\t},\n\t\t\t{ returnDocument: 'after' }\n\t\t);\n\n\t\treturn updated || null;\n\t}\n\n\tpublic async sendEmail(\n\t\tsendTo: string,\n\t\tsubject: string,\n\t\ttext?: string | null,\n\t\thtml?: string | null,\n\t\tattachments?: any[] | null,\n\t\tsend_from?: string | null,\n\t\treply_to?: string | null,\n\t\tforce_ses = false,\n\t\tlocal_override = false,\n\t\toptions?: SendEmailOptions\n\t) {\n\t\t// Modify sendTo in development environments\n\t\tif (\n\t\t\t(ResolveIOServer.getServerConfig()['ROOT_URL'].match(/https:\\/\\/dev\\./) ||\n\t\t\t\tResolveIOServer.getServerConfig()['ROOT_URL'].match(/https:\\/\\/www\\.dev\\./) ||\n\t\t\t\tResolveIOServer.getServerConfig()['ROOT_URL'] === 'http://localhost:4200') &&\n\t\t\t!sendTo.match(/\\@resolveio\\.com/)\n\t\t) {\n\t\t\tsendTo = 'dev@resolveio.com';\n\t\t}\n\n\t\tconst normalizedSubject = subject || '';\n\t\tconst correlationId = options?.correlationId;\n\t\tconst finalSubject = appendCorrelationIdToSubject(normalizedSubject, correlationId);\n\t\tconst groupByCorrelationId = !!correlationId;\n\t\tconst normalizedText = typeof text === 'string' ? text : '';\n\t\tconst normalizedHtml = typeof html === 'string' ? html : '';\n\t\tconst occurrence = groupByCorrelationId\n\t\t\t? createEmailOccurrence(normalizedSubject, normalizedText, normalizedHtml, options?.meta)\n\t\t\t: null;\n\t\tlet allowGrouping = groupByCorrelationId;\n\n\t\tif (sendTo) {\n\t\t\tif (\n\t\t\t\tResolveIOServer.getServerConfig()['ROOT_URL'] !== 'http://localhost:4200' ||\n\t\t\t\tlocal_override\n\t\t\t) {\n\t\t\t\tlet normalizedAttachments: any[] = [];\n\t\t\t\tif (Array.isArray(attachments)) {\n\t\t\t\t\tnormalizedAttachments = attachments.slice();\n\t\t\t\t}\n\t\t\t\telse if (attachments) {\n\t\t\t\t\tnormalizedAttachments = [attachments];\n\t\t\t\t}\n\n\t\t\t\tnormalizedAttachments = normalizedAttachments.map(att => {\n\t\t\t\t\tconst newAtt = { ...att };\n\t\t\t\t\tif (Buffer.isBuffer(newAtt.content)) {\n\t\t\t\t\t\tnewAtt.content = newAtt.content.toString('base64');\n\t\t\t\t\t\tnewAtt.encoding = 'base64';\n\t\t\t\t\t}\n\t\t\t\t\treturn newAtt;\n\t\t\t\t});\n\n\t\t\t\tif (normalizedAttachments.length > 0) {\n\t\t\t\t\tallowGrouping = false;\n\t\t\t\t}\n\n\t\t\t\tif (allowGrouping && occurrence && correlationId) {\n\t\t\t\t\tconst merged = await this.tryMergeEmailOccurrence(sendTo, finalSubject, correlationId, occurrence, options?.meta);\n\t\t\t\t\tif (merged) {\n\t\t\t\t\t\treturn merged;\n\t\t\t\t\t}\n\t\t\t\t}\n\n\t\t\t\tconst emailHistory: EmailHistoryModel = {\n\t\t\t\t\t_id: objectIdHexString(),\n\t\t\t\t\t__v: 0,\n\t\t\t\t\tdate: new Date(),\n\t\t\t\t\tid_user: this['id_user'] || '',\n\t\t\t\t\tuser: this['user'] || '',\n\t\t\t\t\temail: sendTo,\n\t\t\t\t\tsubject: finalSubject,\n\t\t\t\t\ttext: normalizedText,\n\t\t\t\t\thtml: normalizedHtml,\n\t\t\t\t\tattachments: normalizedAttachments,\n\t\t\t\t\tsend_from: send_from || '',\n\t\t\t\t\treply_to: reply_to || '',\n\t\t\t\t\tstatus: 'pending',\n\t\t\t\t\terror: '',\n\t\t\t\t\tforce_ses\n\t\t\t\t};\n\n\t\t\t\tif (allowGrouping && occurrence && correlationId) {\n\t\t\t\t\tconst { text: aggregatedText, html: aggregatedHtml } = formatGroupedEmailContent(correlationId, [occurrence]);\n\t\t\t\t\temailHistory.text = aggregatedText;\n\t\t\t\t\temailHistory.html = aggregatedHtml;\n\t\t\t\t\temailHistory.occurrences = [occurrence];\n\t\t\t\t\temailHistory.correlationId = correlationId;\n\t\t\t\t\tif (options?.meta) {\n\t\t\t\t\t\temailHistory.meta = options.meta;\n\t\t\t\t\t}\n\t\t\t\t}\n\t\t\t\telse {\n\t\t\t\t\tif (correlationId) {\n\t\t\t\t\t\temailHistory.correlationId = correlationId;\n\t\t\t\t\t}\n\t\t\t\t\tif (options?.meta) {\n\t\t\t\t\t\temailHistory.meta = options.meta;\n\t\t\t\t\t}\n\t\t\t\t}\n\n\t\t\t\ttry {\n\t\t\t\t\tlet history = await EmailHistories.insertOne(emailHistory);\n\t\t\t\t\treturn history;\n\t\t\t\t}\n\t\t\t\tcatch (err) {\n\t\t\t\t\tconsole.error('Failed to queue email:', err);\n\t\t\t\t\terr.message = `Failed to queue email: ${err.message}`;\n\t\t\t\t\tthrow err;\n\t\t\t\t}\n\t\t\t}\n\t\t\telse {\n\t\t\t\tconsole.log(\n\t\t\t\t\t'Send email',\n\t\t\t\t\tsendTo,\n\t\t\t\t\tfinalSubject,\n\t\t\t\t\tnormalizedText,\n\t\t\t\t\tnormalizedHtml,\n\t\t\t\t\tattachments,\n\t\t\t\t\tsend_from,\n\t\t\t\t\tforce_ses,\n\t\t\t\t\tcorrelationId\n\t\t\t\t);\n\t\t\t\t\n\t\t\t\treturn true;\n\t\t\t}\n\t\t}\n\t\telse {\n\t\t\treturn true;\n\t\t}\n\t}\n\n\tpublic getAWS(): AWS {\n\t\treturn this._aws;\n\t}\n\n\tpublic readFile(fileName) {\n\t\tif (fs.existsSync(path.join(__dirname, ('../private/' + fileName)))) {\n\t\t\ttry {\n\t\t\t\treturn fs.readFileSync(path.join(__dirname, ('../private/' + fileName)), 'utf-8');\n\t\t\t}\n\t\t\tcatch (err) {\n\t\t\t\terr.message = `Error in readFile: ${err.message}`;\n\t\t\t\tthrow err;\n\t\t\t}\n\t\t}\n\t\telse {\n\t\t\tif (fs.existsSync(path.join(ResolveIOServer.getClientDir(), ('./private/' + fileName)))) {\n\t\t\t\ttry {\n\t\t\t\t\treturn fs.readFileSync(path.join(ResolveIOServer.getClientDir(), ('./private/' + fileName)), 'utf-8');\n\t\t\t\t}\n\t\t\t\tcatch (err) {\n\t\t\t\t\terr.message = `Error in readFile: ${err.message}`;\n\t\t\t\t\tthrow err;\n\t\t\t\t}\n\t\t\t}\n\t\t}\n\n\t\tthrow new Error ('Error in readFile: File Not Found');\n\t}\n\n\tpublic readImage(fileName) {\n\t\tif (fs.existsSync(path.join(__dirname, ('../private/' + fileName)))) {\n\t\t\ttry {\n\t\t\t\treturn fs.readFileSync(path.join(__dirname, ('../private/' + fileName)), 'base64');\n\t\t\t}\n\t\t\tcatch (err) {\n\t\t\t\terr.message = `Error in readImage: ${err.message}`;\n\t\t\t\tthrow err;\n\t\t\t}\n\t\t}\n\t\telse {\n\t\t\tif (fs.existsSync(path.join(ResolveIOServer.getClientDir(), ('./private/' + fileName)))) {\n\t\t\t\ttry {\n\t\t\t\t\treturn fs.readFileSync(path.join(ResolveIOServer.getClientDir(), ('./private/' + fileName)), 'base64');\n\t\t\t\t}\n\t\t\t\tcatch (err) {\n\t\t\t\t\terr.message = `Error in readImage: ${err.message}`;\n\t\t\t\t\tthrow err;\n\t\t\t\t}\n\t\t\t}\n\t\t}\n\n\t\tthrow new Error ('Error in readImage: File Not Found');\n\t}\n\n\tpublic getEnableDebug() {\n\t\treturn this._enableDebug;\n\t}\n}\n"]}
@@ -88,9 +88,15 @@ var WorkerServerManager = /** @class */ (function () {
88
88
  return workerServerManager;
89
89
  };
90
90
  WorkerServerManager.prototype.initialize = function (methodManager, serverConfig) {
91
+ var _this = this;
91
92
  this._methodManager = methodManager;
92
93
  this._serverConfig = serverConfig;
93
- this.startWorkerInstance();
94
+ if (this._methodManager && typeof this._methodManager.onReady === 'function') {
95
+ this._methodManager.onReady(function () { return _this.startWorkerInstance(); });
96
+ }
97
+ else {
98
+ this.startWorkerInstance();
99
+ }
94
100
  };
95
101
  WorkerServerManager.prototype.startWorkerInstance = function () {
96
102
  var _this = this;
@@ -246,7 +252,7 @@ var WorkerServerManager = /** @class */ (function () {
246
252
  };
247
253
  WorkerServerManager.prototype.handleIncomingTask = function (ws, data) {
248
254
  return __awaiter(this, void 0, void 0, function () {
249
- var taskId, messageId, method, params, userContext, receivedAt, queuedAt, dispatchedAt, queueWaitMs, dispatchDelayMs, timedOut, timeoutHandle, managerThis, result, packedResult, meta, publicationPayload, publicationMeta, isPublicationResponse, payload, err_1, errorAt_1, runMs_1, totalMs_1, errorAt, runMs, totalMs;
255
+ var taskId, messageId, method, params, userContext, receivedAt, queuedAt, dispatchedAt, queueWaitMs, dispatchDelayMs, missingMethod, error_1, timedOut, timeoutHandle, managerThis, result, packedResult, meta, publicationPayload, publicationMeta, isPublicationResponse, payload, err_1, errorAt_1, runMs_1, totalMs_1, errorAt, runMs, totalMs;
250
256
  var _a;
251
257
  var _this = this;
252
258
  var _b;
@@ -260,14 +266,23 @@ var WorkerServerManager = /** @class */ (function () {
260
266
  queueWaitMs = queuedAt && dispatchedAt ? (0, common_1.round)(dispatchedAt - queuedAt) : (queuedAt ? (0, common_1.round)(receivedAt - queuedAt) : null);
261
267
  dispatchDelayMs = dispatchedAt ? (0, common_1.round)(receivedAt - dispatchedAt) : null;
262
268
  this._runningTasks.push(taskId);
263
- if (!(!taskId || !method || !this._methodManager.getMethod(method))) return [3 /*break*/, 3];
264
- if (!!this._methodManager.getMethod(method)) return [3 /*break*/, 2];
269
+ missingMethod = !method || !this._methodManager.getMethod(method);
270
+ if (!(!taskId || !method || missingMethod)) return [3 /*break*/, 5];
271
+ if (!missingMethod) return [3 /*break*/, 4];
265
272
  console.error(new Date(), 'No method in method manager for handleIncomingTask worker server', method);
266
- return [4 /*yield*/, this._methodManager.callMethod('insertErrorLog', "No Method in worker server handleIncomingTask: ".concat(method, " - ").concat(JSON.stringify(data, null, 2)))];
273
+ if (!this._methodManager.getMethod('insertErrorLog')) return [3 /*break*/, 4];
274
+ _c.label = 1;
267
275
  case 1:
268
- _c.sent();
269
- _c.label = 2;
276
+ _c.trys.push([1, 3, , 4]);
277
+ return [4 /*yield*/, this._methodManager.callMethod('insertErrorLog', "No Method in worker server handleIncomingTask: ".concat(method, " - ").concat(JSON.stringify(data, null, 2)))];
270
278
  case 2:
279
+ _c.sent();
280
+ return [3 /*break*/, 4];
281
+ case 3:
282
+ error_1 = _c.sent();
283
+ console.error(new Date(), 'insertErrorLog failed in worker-server', error_1);
284
+ return [3 /*break*/, 4];
285
+ case 4:
271
286
  // console.log('Invalid task message received', data);
272
287
  this.logWorkerEvent('workerTaskInvalid', {
273
288
  taskId: taskId,
@@ -286,7 +301,7 @@ var WorkerServerManager = /** @class */ (function () {
286
301
  result: 'Invalid task'
287
302
  });
288
303
  return [2 /*return*/];
289
- case 3:
304
+ case 5:
290
305
  timedOut = false;
291
306
  timeoutHandle = setTimeout(function () { return __awaiter(_this, void 0, void 0, function () {
292
307
  var timeoutAt, runMs, totalMs;
@@ -323,9 +338,9 @@ var WorkerServerManager = /** @class */ (function () {
323
338
  }
324
339
  });
325
340
  }); }, ((_b = this._methodManager.getMethod(method)) === null || _b === void 0 ? void 0 : _b.timeoutOverride) || (1000 * 60 * 2));
326
- _c.label = 4;
327
- case 4:
328
- _c.trys.push([4, 6, , 8]);
341
+ _c.label = 6;
342
+ case 6:
343
+ _c.trys.push([6, 8, , 10]);
329
344
  managerThis = Object.assign({}, this._methodManager, method_manager_1.MethodManager.prototype, {
330
345
  id_user: (userContext === null || userContext === void 0 ? void 0 : userContext.id_user) || '',
331
346
  user: (userContext === null || userContext === void 0 ? void 0 : userContext.user) || '',
@@ -335,7 +350,7 @@ var WorkerServerManager = /** @class */ (function () {
335
350
  console.log(new Date(), 'Running method', method);
336
351
  }
337
352
  return [4 /*yield*/, (_a = this._methodManager.callMethod).call.apply(_a, __spreadArray([managerThis, method], __read(params), false))];
338
- case 5:
353
+ case 7:
339
354
  result = _c.sent();
340
355
  packedResult = null;
341
356
  meta = null;
@@ -390,8 +405,8 @@ var WorkerServerManager = /** @class */ (function () {
390
405
  if (this._methodManager.getEnableDebug()) {
391
406
  console.log(new Date(), 'Done with Task', JSON.stringify(this._runningTasks, null, 2));
392
407
  }
393
- return [3 /*break*/, 8];
394
- case 6:
408
+ return [3 /*break*/, 10];
409
+ case 8:
395
410
  err_1 = _c.sent();
396
411
  if (!timedOut) {
397
412
  clearTimeout(timeoutHandle);
@@ -438,11 +453,11 @@ var WorkerServerManager = /** @class */ (function () {
438
453
  });
439
454
  console.error(new Date(), "Error in Method: ".concat(method, " - ").concat(JSON.stringify(data, null, 2)));
440
455
  return [4 /*yield*/, this._methodManager.callMethod('insertErrorLog', "Error in Method: ".concat(method, " - ").concat(JSON.stringify(data, null, 2)))];
441
- case 7:
456
+ case 9:
442
457
  _c.sent();
443
458
  this._runningTasks = this._runningTasks.filter(function (a) { return a !== taskId; });
444
- return [3 /*break*/, 8];
445
- case 8: return [2 /*return*/];
459
+ return [3 /*break*/, 10];
460
+ case 10: return [2 /*return*/];
446
461
  }
447
462
  });
448
463
  });
@@ -1 +1 @@
1
- {"version":3,"sources":["../../src/managers/worker-server.manager.ts"],"names":[],"mappings":"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","file":"worker-server.manager.js","sourcesContent":["import { pack, unpack } from 'msgpackr';\nimport * as WebSocket from 'ws';\nimport { TaskPayload, TaskResponse } from '../models/server-message.model';\nimport { dateReviver, round } from '../util/common';\nimport { MethodManager } from './method.manager';\n\nexport class WorkerServerManager {\n private _methodManager: MethodManager;\n private _serverConfig;\n private _runningTasks = [];\n\tprivate _taskLogThresholdMs = 200;\n\n constructor() {}\n \n static create(methodManager: MethodManager, serverConfig) {\n const workerServerManager = new WorkerServerManager();\n workerServerManager.initialize(methodManager, serverConfig);\n return workerServerManager;\n }\n\n public initialize(methodManager: MethodManager, serverConfig) {\n this._methodManager = methodManager;\n this._serverConfig = serverConfig;\n this.startWorkerInstance();\n }\n\n private startWorkerInstance() {\n console.log(new Date(), 'Worker instance started, connecting to main server via WebSocket...');\n \n const workerIndex = encodeURIComponent(String(process.env.WORKER_INDEX || ''));\n const workerInstance = encodeURIComponent(String(process.env.NODE_APP_INSTANCE || ''));\n let wsUrl = this._serverConfig['SERVER_URL'] + '/websocket?workerToken=' + this._serverConfig['WORKER_TOKEN'] + '&workerIndex=' + workerIndex + '&workerInstance=' + workerInstance;\n const ws = new WebSocket(wsUrl);\n \n let lastComm = new Date();\n let interval = null;\n let missedPongs = 0;\n const heartbeatIntervalMs = 15000;\n const maxMissedPongs = 2;\n const maxSilenceMs = heartbeatIntervalMs * (maxMissedPongs + 1);\n let openTimeout = null;\n let opened = false;\n \n // Set timeout if the socket never opens\n openTimeout = setTimeout(() => {\n if (!opened) {\n console.error(new Date(), 'WebSocket connection timeout. Retrying...');\n ws.terminate(); // force close if still connecting\n }\n }, 10000); // 10 seconds timeout\n \n ws.on('open', () => {\n opened = true;\n clearTimeout(openTimeout);\n \n console.log(new Date(), 'Connected to main server as worker', process.env.WORKER_INDEX, process.env.NODE_APP_INSTANCE);\n this.sendWorkerResponse(ws, 'ping');\n \n interval = setInterval(() => {\n const now = Date.now();\n const last = lastComm ? lastComm.getTime() : 0;\n const silenceMs = last ? now - last : maxSilenceMs + 1;\n if (silenceMs > maxSilenceMs || missedPongs > maxMissedPongs) {\n ws.close();\n return;\n }\n missedPongs += 1;\n this.sendWorkerResponse(ws, 'ping');\n }, heartbeatIntervalMs);\n });\n \n\t\tws.on('message', async (rawData: WebSocket.RawData) => {\n\t\t\tlastComm = new Date();\n\t\t\tif (typeof rawData === 'string') {\n\t\t\t\tif (this._methodManager.getEnableDebug()) {\n\t\t\t\t\tconsole.log(new Date(), 'Message Recv', rawData);\n\t\t\t\t}\n\n\t\t\t\tif (rawData === 'ping') {\n\t\t\t\t\tif (this._methodManager.getEnableDebug()) {\n\t\t\t\t\t\tconsole.log(new Date(), 'Recv Ping, Sending Pong');\n\t\t\t\t\t}\n\t\t\t\t\t\n\t\t\t\t\tthis.sendWorkerResponse(ws, 'pong');\n\t\t\t\t}\n\t\t\t\telse if (rawData === 'pong') {\n\t\t\t\t\tif (this._methodManager.getEnableDebug()) {\n\t\t\t\t\t\tconsole.log(new Date(), 'Recv Pong');\n\t\t\t\t\t}\n\t\t\t\t\tmissedPongs = 0;\n\t\t\t\t}\n\t\t\t\telse {\n\t\t\t\t\tlet msg: any;\n\t\t\t\t\ttry {\n\t\t\t\t\t\tmsg = JSON.parse(rawData, dateReviver);\n\t\t\t\t\t}\n\t\t\t\t\tcatch (e) {\n\t\t\t\t\t\tconsole.error('Worker parse error', e);\n\t\t\t\t\t\treturn;\n\t\t\t\t\t}\n\t\n\t\t\t\t\tif (msg.type === 'task') {\n\t\t\t\t\t\tawait this.handleIncomingTask(ws, msg);\n\t\t\t\t\t}\n\t\t\t\t}\n\n\t\t\t\treturn;\n\t\t\t}\n\n\t\t\tlet messageBuffer: Buffer;\n\n\t\t\tif (Buffer.isBuffer(rawData)) {\n\t\t\t\tmessageBuffer = rawData;\n\t\t\t}\n\t\t\telse if (Array.isArray(rawData)) {\n\t\t\t\tconst chunks = rawData as unknown as ReadonlyArray<Uint8Array>;\n\t\t\t\tmessageBuffer = Buffer.concat(chunks);\n\t\t\t}\n\t\t\telse if (rawData instanceof ArrayBuffer) {\n\t\t\t\tmessageBuffer = Buffer.from(rawData);\n\t\t\t}\n\t\t\telse if (ArrayBuffer.isView(rawData)) {\n\t\t\t\tconst view = rawData as NodeJS.ArrayBufferView;\n\t\t\t\tmessageBuffer = Buffer.from(view.buffer, view.byteOffset, view.byteLength);\n\t\t\t}\n\t\t\telse {\n\t\t\t\tmessageBuffer = Buffer.from(rawData as any);\n\t\t\t}\n\n\t\t\tif (this._methodManager.getEnableDebug()) {\n\t\t\t\tconsole.log(new Date(), 'Message Recv (binary)', messageBuffer.length);\n\t\t\t}\n\n\t\t\tif (messageBuffer.length === 4) {\n\t\t\t\tlet heartbeat = messageBuffer.toString('utf8');\n\n\t\t\t\tif (heartbeat === 'ping') {\n\t\t\t\t\tif (this._methodManager.getEnableDebug()) {\n\t\t\t\t\t\tconsole.log(new Date(), 'Recv Ping (binary), Sending Pong');\n\t\t\t\t\t}\n\n\t\t\t\t\tthis.sendWorkerResponse(ws, 'pong');\n\t\t\t\t\treturn;\n\t\t\t\t}\n\t\t\t\telse if (heartbeat === 'pong') {\n\t\t\t\t\tif (this._methodManager.getEnableDebug()) {\n\t\t\t\t\t\tconsole.log(new Date(), 'Recv Pong (binary)');\n\t\t\t\t\t}\n\t\t\t\t\tmissedPongs = 0;\n\t\t\t\t\treturn;\n\t\t\t\t}\n\t\t\t}\n\n\t\t\tlet msg: TaskPayload;\n\n\t\t\ttry {\n\t\t\t\tmsg = unpack(messageBuffer);\n\t\t\t}\n\t\t\tcatch (e) {\n\t\t\t\tconsole.error('Worker binary parse error', e);\n\t\t\t\treturn;\n\t\t\t}\n\n\t\t\tif (msg.type === 'task') {\n\t\t\t\tawait this.handleIncomingTask(ws, msg);\n\t\t\t}\n\t\t});\n \n ws.on('close', () => {\n console.log(new Date(), 'Disconnected from main server. Reconnecting in 1s...');\n setTimeout(() => {\n this.startWorkerInstance();\n }, 1000);\n \n if (interval) {\n clearInterval(interval);\n }\n clearTimeout(openTimeout);\n });\n \n\t\tws.on('error', (err) => {\n\t\t\tconst message = err?.message || '';\n\t\t\tconst isRestartNoise = message.includes('Unexpected server response: 502');\n\t\t\tif (!isRestartNoise) {\n\t\t\t\tconsole.error(new Date(), 'Worker WS error:', err);\n\t\t\t}\n\t\t\telse if (this._methodManager.getEnableDebug()) {\n\t\t\t\tconsole.log(new Date(), 'Worker WS reconnecting after main restart', message);\n\t\t\t}\n\t\t\tws.close();\n\t\t});\n }\n\n private async handleIncomingTask(ws: WebSocket.WebSocket, data: TaskPayload) {\n let { taskId, messageId, method, params, userContext } = data;\n\t\tconst receivedAt = Date.now();\n\t\tconst queuedAt = data.queuedAt;\n\t\tconst dispatchedAt = data.dispatchedAt;\n\t\tconst queueWaitMs = queuedAt && dispatchedAt ? round(dispatchedAt - queuedAt) : (queuedAt ? round(receivedAt - queuedAt) : null);\n\t\tconst dispatchDelayMs = dispatchedAt ? round(receivedAt - dispatchedAt) : null;\n this._runningTasks.push(taskId);\n if (!taskId || !method || !this._methodManager.getMethod(method)) {\n if (!this._methodManager.getMethod(method)) {\n console.error(new Date(), 'No method in method manager for handleIncomingTask worker server', method);\n await this._methodManager.callMethod('insertErrorLog', `No Method in worker server handleIncomingTask: ${method} - ${JSON.stringify(data, null, 2)}`);\n }\n\n // console.log('Invalid task message received', data);\n\t\t\tthis.logWorkerEvent('workerTaskInvalid', {\n\t\t\t\ttaskId,\n\t\t\t\tmethod,\n\t\t\t\tmessageId,\n\t\t\t\tqueueWaitMs,\n\t\t\t\tdispatchDelayMs,\n\t\t\t\tuserContext,\n\t\t\t\tparams\n\t\t\t});\n this.sendWorkerResponse(ws, {\n type: 'taskComplete',\n taskId,\n messageId,\n error: true,\n result: 'Invalid task'\n });\n\n return;\n }\n\n let timedOut = false;\n let timeoutHandle = setTimeout(async () => {\n timedOut = true;\n\t\t\tconst timeoutAt = Date.now();\n\t\t\tconst runMs = round(timeoutAt - receivedAt);\n\t\t\tconst totalMs = queuedAt ? round(timeoutAt - queuedAt) : null;\n console.error(new Date(), 'Worker timed out on task:', taskId, 'Method:', method);\n\n\t\t\tthis.logWorkerEvent('workerTaskTimeout', {\n\t\t\t\ttaskId,\n\t\t\t\tmethod,\n\t\t\t\tmessageId,\n\t\t\t\trunMs,\n\t\t\t\tqueueWaitMs,\n\t\t\t\tdispatchDelayMs,\n\t\t\t\ttotalMs,\n\t\t\t\tuserContext,\n\t\t\t\tparams\n\t\t\t});\n\n this.sendWorkerResponse(ws, {\n type: 'taskComplete',\n taskId,\n messageId,\n error: true,\n result: 'Task timed out'\n });\n\n await this._methodManager.callMethod('insertErrorLog', `Timeout in Method: ${method} - ${JSON.stringify(data, null, 2)}`);\n }, this._methodManager.getMethod(method)?.timeoutOverride || (1000 * 60 * 2));\n\n try {\n let managerThis = Object.assign({}, this._methodManager, MethodManager.prototype, {\n id_user: userContext?.id_user || '',\n user: userContext?.user || '',\n id_ws: userContext?.id_ws || ''\n });\n\n if (this._methodManager.getEnableDebug()) {\n console.log(new Date(), 'Running method', method);\n }\n\n\t\t\tlet result = await this._methodManager.callMethod.call(managerThis, method, ...params);\n\t\t\tlet packedResult: Uint8Array | Buffer = null;\n\t\t\tlet meta: Record<string, any> = null;\n\t\t\tlet publicationPayload: any = undefined;\n\t\t\tlet publicationMeta: Record<string, any> = null;\n\t\t\tconst isPublicationResponse = !!(result && result.__publicationResponse);\n\n\t\t\ttry {\n\t\t\t\tif (isPublicationResponse) {\n\t\t\t\t\tpublicationPayload = result.payload;\n\t\t\t\t\tpublicationMeta = {\n\t\t\t\t\t\ttype: 'publication',\n\t\t\t\t\t\tpublication: result.publication,\n\t\t\t\t\t\tsubscriptionData: result.subscriptionData,\n\t\t\t\t\t\tuserSpecific: result.userSpecific,\n\t\t\t\t\t\tsnapshot: result.snapshot\n\t\t\t\t\t};\n\t\t\t\t}\n\n\t\t\t\tif (isPublicationResponse) {\n\t\t\t\t\tmeta = publicationMeta;\n\t\t\t\t\tpackedResult = <Buffer>pack(publicationPayload);\n\t\t\t\t\tresult = null;\n\t\t\t\t}\n\t\t\t\telse {\n\t\t\t\t\tpackedResult = <Buffer>pack(result);\n\t\t\t\t}\n\t\t\t}\n\t\t\tcatch (packErr) {\n\t\t\t\tconsole.error(new Date(), 'Worker pack error', packErr);\n\t\t\t\tif (isPublicationResponse) {\n\t\t\t\t\tmeta = publicationMeta;\n\t\t\t\t\tresult = publicationPayload;\n\t\t\t\t}\n\t\t\t}\n\n\n\t\t\tif (this._methodManager.getEnableDebug()) {\n\t\t\t\tconsole.log(new Date(), 'Finished method', method);\n\t\t\t}\n\n\t\t\tif (!timedOut) {\n\t\t\t\tclearTimeout(timeoutHandle);\n\t\t\t\tconst payload: TaskResponse = {\n\t\t\t\t\ttype: 'taskComplete',\n\t\t\t\t\ttaskId,\n\t\t\t\t\tmessageId,\n\t\t\t\t\terror: false,\n\t\t\t\t\tresult: packedResult ? null : result,\n\t\t\t\t\tpackedResult,\n\t\t\t\t\tencoding: 'msgpack',\n\t\t\t\t\tmeta\n\t\t\t\t};\n\n\t\t\t\tthis.sendWorkerResponse(ws, payload);\n\t\t\t}\n\n this._runningTasks = this._runningTasks.filter(a => a !== taskId);\n \n if (this._methodManager.getEnableDebug()) {\n console.log(new Date(), 'Done with Task', JSON.stringify(this._runningTasks, null, 2));\n }\n }\n catch (err) {\n if (!timedOut) {\n clearTimeout(timeoutHandle);\n\t\t\t\tconst errorAt = Date.now();\n\t\t\t\tconst runMs = round(errorAt - receivedAt);\n\t\t\t\tconst totalMs = queuedAt ? round(errorAt - queuedAt) : null;\n console.error('Worker failed task:', taskId, 'Method:', method, err);\n err.message = 'Worker failed task:' + taskId + ' Method:' + method + ' - ' + err.message;\n\t\t\t\tthis.logWorkerEvent('workerTaskError', {\n\t\t\t\t\ttaskId,\n\t\t\t\t\tmethod,\n\t\t\t\t\tmessageId,\n\t\t\t\t\trunMs,\n\t\t\t\t\tqueueWaitMs,\n\t\t\t\t\tdispatchDelayMs,\n\t\t\t\t\ttotalMs,\n\t\t\t\t\tuserContext,\n\t\t\t\t\tparams,\n\t\t\t\t\terror: err\n\t\t\t\t});\n this.sendWorkerResponse(ws, {\n type: 'taskComplete',\n taskId,\n messageId,\n error: true,\n result: err || 'Unknown error'\n });\n throw err;\n }\n\n\t\t\tconst errorAt = Date.now();\n\t\t\tconst runMs = round(errorAt - receivedAt);\n\t\t\tconst totalMs = queuedAt ? round(errorAt - queuedAt) : null;\n\t\t\tthis.logWorkerEvent('workerTaskError', {\n\t\t\t\ttaskId,\n\t\t\t\tmethod,\n\t\t\t\tmessageId,\n\t\t\t\trunMs,\n\t\t\t\tqueueWaitMs,\n\t\t\t\tdispatchDelayMs,\n\t\t\t\ttotalMs,\n\t\t\t\tuserContext,\n\t\t\t\tparams,\n\t\t\t\terror: err\n\t\t\t});\n\n console.error(new Date(), `Error in Method: ${method} - ${JSON.stringify(data, null, 2)}`);\n \n await this._methodManager.callMethod('insertErrorLog', `Error in Method: ${method} - ${JSON.stringify(data, null, 2)}`);\n \n this._runningTasks = this._runningTasks.filter(a => a !== taskId);\n }\n }\n\n\tprivate logWorkerEvent(event: string, details: Record<string, any>) {\n\t\tconsole.log(this.safeStringify({\n\t\t\tts: new Date().toISOString(),\n\t\t\tevent,\n\t\t\t...details\n\t\t}));\n\t}\n\n\tprivate safeStringify(value: any): string {\n\t\ttry {\n\t\t\tconst seen = new WeakSet();\n\t\t\treturn JSON.stringify(value, (key, val) => {\n\t\t\t\tif (key === '__proto__') {\n\t\t\t\t\treturn undefined;\n\t\t\t\t}\n\t\t\t\tif (typeof val === 'bigint') {\n\t\t\t\t\treturn val.toString();\n\t\t\t\t}\n\t\t\t\tif (val instanceof Error) {\n\t\t\t\t\treturn {\n\t\t\t\t\t\tname: val.name,\n\t\t\t\t\t\tmessage: val.message,\n\t\t\t\t\t\tstack: val.stack\n\t\t\t\t\t};\n\t\t\t\t}\n\t\t\t\tif (val && typeof val === 'object') {\n\t\t\t\t\tif (seen.has(val)) {\n\t\t\t\t\t\treturn '[Circular]';\n\t\t\t\t\t}\n\t\t\t\t\tseen.add(val);\n\t\t\t\t}\n\t\t\t\treturn val;\n\t\t\t});\n\t\t}\n\t\tcatch (err) {\n\t\t\treturn JSON.stringify({\n\t\t\t\terror: 'safeStringifyFailed',\n\t\t\t\tmessage: err?.message || String(err)\n\t\t\t});\n\t\t}\n\t}\n\n\tpublic sendWorkerResponse(ws, payload: TaskResponse | string) {\n\t\tif (this._methodManager.getEnableDebug()) {\n\t\t\tconsole.log(new Date(), 'Sending', typeof payload === 'string' ? payload : '[binary]');\n\t\t}\n\n\t\tif (ws && ws.readyState === WebSocket.OPEN) {\n\t\t\ttry {\n\t\t\t\tif (typeof payload === 'string') {\n\t\t\t\t\tws.send(payload);\n\t\t\t\t}\n\t\t\t\telse {\n\t\t\t\t\tws.send(pack(payload));\n\t\t\t\t}\n\t\t\t}\n\t\t\tcatch (err) {\n\t\t\t\tconsole.error('Failed to send worker response:', err);\n\t\t\t}\n\t\t}\n\t\telse if (ws) {\n\t\t\tws.close();\n\t\t}\n\t}\n}\n"]}
1
+ {"version":3,"sources":["../../src/managers/worker-server.manager.ts"],"names":[],"mappings":"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","file":"worker-server.manager.js","sourcesContent":["import { pack, unpack } from 'msgpackr';\nimport * as WebSocket from 'ws';\nimport { TaskPayload, TaskResponse } from '../models/server-message.model';\nimport { dateReviver, round } from '../util/common';\nimport { MethodManager } from './method.manager';\n\nexport class WorkerServerManager {\n private _methodManager: MethodManager;\n private _serverConfig;\n private _runningTasks = [];\n\tprivate _taskLogThresholdMs = 200;\n\n constructor() {}\n \n static create(methodManager: MethodManager, serverConfig) {\n const workerServerManager = new WorkerServerManager();\n workerServerManager.initialize(methodManager, serverConfig);\n return workerServerManager;\n }\n\n public initialize(methodManager: MethodManager, serverConfig) {\n this._methodManager = methodManager;\n this._serverConfig = serverConfig;\n\t\tif (this._methodManager && typeof this._methodManager.onReady === 'function') {\n\t\t\tthis._methodManager.onReady(() => this.startWorkerInstance());\n\t\t}\n\t\telse {\n\t\t\tthis.startWorkerInstance();\n\t\t}\n }\n\n private startWorkerInstance() {\n console.log(new Date(), 'Worker instance started, connecting to main server via WebSocket...');\n \n const workerIndex = encodeURIComponent(String(process.env.WORKER_INDEX || ''));\n const workerInstance = encodeURIComponent(String(process.env.NODE_APP_INSTANCE || ''));\n let wsUrl = this._serverConfig['SERVER_URL'] + '/websocket?workerToken=' + this._serverConfig['WORKER_TOKEN'] + '&workerIndex=' + workerIndex + '&workerInstance=' + workerInstance;\n const ws = new WebSocket(wsUrl);\n \n let lastComm = new Date();\n let interval = null;\n let missedPongs = 0;\n const heartbeatIntervalMs = 15000;\n const maxMissedPongs = 2;\n const maxSilenceMs = heartbeatIntervalMs * (maxMissedPongs + 1);\n let openTimeout = null;\n let opened = false;\n \n // Set timeout if the socket never opens\n openTimeout = setTimeout(() => {\n if (!opened) {\n console.error(new Date(), 'WebSocket connection timeout. Retrying...');\n ws.terminate(); // force close if still connecting\n }\n }, 10000); // 10 seconds timeout\n \n ws.on('open', () => {\n opened = true;\n clearTimeout(openTimeout);\n \n console.log(new Date(), 'Connected to main server as worker', process.env.WORKER_INDEX, process.env.NODE_APP_INSTANCE);\n this.sendWorkerResponse(ws, 'ping');\n \n interval = setInterval(() => {\n const now = Date.now();\n const last = lastComm ? lastComm.getTime() : 0;\n const silenceMs = last ? now - last : maxSilenceMs + 1;\n if (silenceMs > maxSilenceMs || missedPongs > maxMissedPongs) {\n ws.close();\n return;\n }\n missedPongs += 1;\n this.sendWorkerResponse(ws, 'ping');\n }, heartbeatIntervalMs);\n });\n \n\t\tws.on('message', async (rawData: WebSocket.RawData) => {\n\t\t\tlastComm = new Date();\n\t\t\tif (typeof rawData === 'string') {\n\t\t\t\tif (this._methodManager.getEnableDebug()) {\n\t\t\t\t\tconsole.log(new Date(), 'Message Recv', rawData);\n\t\t\t\t}\n\n\t\t\t\tif (rawData === 'ping') {\n\t\t\t\t\tif (this._methodManager.getEnableDebug()) {\n\t\t\t\t\t\tconsole.log(new Date(), 'Recv Ping, Sending Pong');\n\t\t\t\t\t}\n\t\t\t\t\t\n\t\t\t\t\tthis.sendWorkerResponse(ws, 'pong');\n\t\t\t\t}\n\t\t\t\telse if (rawData === 'pong') {\n\t\t\t\t\tif (this._methodManager.getEnableDebug()) {\n\t\t\t\t\t\tconsole.log(new Date(), 'Recv Pong');\n\t\t\t\t\t}\n\t\t\t\t\tmissedPongs = 0;\n\t\t\t\t}\n\t\t\t\telse {\n\t\t\t\t\tlet msg: any;\n\t\t\t\t\ttry {\n\t\t\t\t\t\tmsg = JSON.parse(rawData, dateReviver);\n\t\t\t\t\t}\n\t\t\t\t\tcatch (e) {\n\t\t\t\t\t\tconsole.error('Worker parse error', e);\n\t\t\t\t\t\treturn;\n\t\t\t\t\t}\n\t\n\t\t\t\t\tif (msg.type === 'task') {\n\t\t\t\t\t\tawait this.handleIncomingTask(ws, msg);\n\t\t\t\t\t}\n\t\t\t\t}\n\n\t\t\t\treturn;\n\t\t\t}\n\n\t\t\tlet messageBuffer: Buffer;\n\n\t\t\tif (Buffer.isBuffer(rawData)) {\n\t\t\t\tmessageBuffer = rawData;\n\t\t\t}\n\t\t\telse if (Array.isArray(rawData)) {\n\t\t\t\tconst chunks = rawData as unknown as ReadonlyArray<Uint8Array>;\n\t\t\t\tmessageBuffer = Buffer.concat(chunks);\n\t\t\t}\n\t\t\telse if (rawData instanceof ArrayBuffer) {\n\t\t\t\tmessageBuffer = Buffer.from(rawData);\n\t\t\t}\n\t\t\telse if (ArrayBuffer.isView(rawData)) {\n\t\t\t\tconst view = rawData as NodeJS.ArrayBufferView;\n\t\t\t\tmessageBuffer = Buffer.from(view.buffer, view.byteOffset, view.byteLength);\n\t\t\t}\n\t\t\telse {\n\t\t\t\tmessageBuffer = Buffer.from(rawData as any);\n\t\t\t}\n\n\t\t\tif (this._methodManager.getEnableDebug()) {\n\t\t\t\tconsole.log(new Date(), 'Message Recv (binary)', messageBuffer.length);\n\t\t\t}\n\n\t\t\tif (messageBuffer.length === 4) {\n\t\t\t\tlet heartbeat = messageBuffer.toString('utf8');\n\n\t\t\t\tif (heartbeat === 'ping') {\n\t\t\t\t\tif (this._methodManager.getEnableDebug()) {\n\t\t\t\t\t\tconsole.log(new Date(), 'Recv Ping (binary), Sending Pong');\n\t\t\t\t\t}\n\n\t\t\t\t\tthis.sendWorkerResponse(ws, 'pong');\n\t\t\t\t\treturn;\n\t\t\t\t}\n\t\t\t\telse if (heartbeat === 'pong') {\n\t\t\t\t\tif (this._methodManager.getEnableDebug()) {\n\t\t\t\t\t\tconsole.log(new Date(), 'Recv Pong (binary)');\n\t\t\t\t\t}\n\t\t\t\t\tmissedPongs = 0;\n\t\t\t\t\treturn;\n\t\t\t\t}\n\t\t\t}\n\n\t\t\tlet msg: TaskPayload;\n\n\t\t\ttry {\n\t\t\t\tmsg = unpack(messageBuffer);\n\t\t\t}\n\t\t\tcatch (e) {\n\t\t\t\tconsole.error('Worker binary parse error', e);\n\t\t\t\treturn;\n\t\t\t}\n\n\t\t\tif (msg.type === 'task') {\n\t\t\t\tawait this.handleIncomingTask(ws, msg);\n\t\t\t}\n\t\t});\n \n ws.on('close', () => {\n console.log(new Date(), 'Disconnected from main server. Reconnecting in 1s...');\n setTimeout(() => {\n this.startWorkerInstance();\n }, 1000);\n \n if (interval) {\n clearInterval(interval);\n }\n clearTimeout(openTimeout);\n });\n \n\t\tws.on('error', (err) => {\n\t\t\tconst message = err?.message || '';\n\t\t\tconst isRestartNoise = message.includes('Unexpected server response: 502');\n\t\t\tif (!isRestartNoise) {\n\t\t\t\tconsole.error(new Date(), 'Worker WS error:', err);\n\t\t\t}\n\t\t\telse if (this._methodManager.getEnableDebug()) {\n\t\t\t\tconsole.log(new Date(), 'Worker WS reconnecting after main restart', message);\n\t\t\t}\n\t\t\tws.close();\n\t\t});\n }\n\n private async handleIncomingTask(ws: WebSocket.WebSocket, data: TaskPayload) {\n let { taskId, messageId, method, params, userContext } = data;\n\t\tconst receivedAt = Date.now();\n\t\tconst queuedAt = data.queuedAt;\n\t\tconst dispatchedAt = data.dispatchedAt;\n\t\tconst queueWaitMs = queuedAt && dispatchedAt ? round(dispatchedAt - queuedAt) : (queuedAt ? round(receivedAt - queuedAt) : null);\n\t\tconst dispatchDelayMs = dispatchedAt ? round(receivedAt - dispatchedAt) : null;\n this._runningTasks.push(taskId);\n const missingMethod = !method || !this._methodManager.getMethod(method);\n if (!taskId || !method || missingMethod) {\n if (missingMethod) {\n console.error(new Date(), 'No method in method manager for handleIncomingTask worker server', method);\n\t\t\t\tif (this._methodManager.getMethod('insertErrorLog')) {\n\t\t\t\t\ttry {\n\t\t\t\t\t\tawait this._methodManager.callMethod('insertErrorLog', `No Method in worker server handleIncomingTask: ${method} - ${JSON.stringify(data, null, 2)}`);\n\t\t\t\t\t}\n\t\t\t\t\tcatch (error) {\n\t\t\t\t\t\tconsole.error(new Date(), 'insertErrorLog failed in worker-server', error);\n\t\t\t\t\t}\n\t\t\t\t}\n }\n\n // console.log('Invalid task message received', data);\n\t\t\tthis.logWorkerEvent('workerTaskInvalid', {\n\t\t\t\ttaskId,\n\t\t\t\tmethod,\n\t\t\t\tmessageId,\n\t\t\t\tqueueWaitMs,\n\t\t\t\tdispatchDelayMs,\n\t\t\t\tuserContext,\n\t\t\t\tparams\n\t\t\t});\n this.sendWorkerResponse(ws, {\n type: 'taskComplete',\n taskId,\n messageId,\n error: true,\n result: 'Invalid task'\n });\n\n return;\n }\n\n let timedOut = false;\n let timeoutHandle = setTimeout(async () => {\n timedOut = true;\n\t\t\tconst timeoutAt = Date.now();\n\t\t\tconst runMs = round(timeoutAt - receivedAt);\n\t\t\tconst totalMs = queuedAt ? round(timeoutAt - queuedAt) : null;\n console.error(new Date(), 'Worker timed out on task:', taskId, 'Method:', method);\n\n\t\t\tthis.logWorkerEvent('workerTaskTimeout', {\n\t\t\t\ttaskId,\n\t\t\t\tmethod,\n\t\t\t\tmessageId,\n\t\t\t\trunMs,\n\t\t\t\tqueueWaitMs,\n\t\t\t\tdispatchDelayMs,\n\t\t\t\ttotalMs,\n\t\t\t\tuserContext,\n\t\t\t\tparams\n\t\t\t});\n\n this.sendWorkerResponse(ws, {\n type: 'taskComplete',\n taskId,\n messageId,\n error: true,\n result: 'Task timed out'\n });\n\n await this._methodManager.callMethod('insertErrorLog', `Timeout in Method: ${method} - ${JSON.stringify(data, null, 2)}`);\n }, this._methodManager.getMethod(method)?.timeoutOverride || (1000 * 60 * 2));\n\n try {\n let managerThis = Object.assign({}, this._methodManager, MethodManager.prototype, {\n id_user: userContext?.id_user || '',\n user: userContext?.user || '',\n id_ws: userContext?.id_ws || ''\n });\n\n if (this._methodManager.getEnableDebug()) {\n console.log(new Date(), 'Running method', method);\n }\n\n\t\t\tlet result = await this._methodManager.callMethod.call(managerThis, method, ...params);\n\t\t\tlet packedResult: Uint8Array | Buffer = null;\n\t\t\tlet meta: Record<string, any> = null;\n\t\t\tlet publicationPayload: any = undefined;\n\t\t\tlet publicationMeta: Record<string, any> = null;\n\t\t\tconst isPublicationResponse = !!(result && result.__publicationResponse);\n\n\t\t\ttry {\n\t\t\t\tif (isPublicationResponse) {\n\t\t\t\t\tpublicationPayload = result.payload;\n\t\t\t\t\tpublicationMeta = {\n\t\t\t\t\t\ttype: 'publication',\n\t\t\t\t\t\tpublication: result.publication,\n\t\t\t\t\t\tsubscriptionData: result.subscriptionData,\n\t\t\t\t\t\tuserSpecific: result.userSpecific,\n\t\t\t\t\t\tsnapshot: result.snapshot\n\t\t\t\t\t};\n\t\t\t\t}\n\n\t\t\t\tif (isPublicationResponse) {\n\t\t\t\t\tmeta = publicationMeta;\n\t\t\t\t\tpackedResult = <Buffer>pack(publicationPayload);\n\t\t\t\t\tresult = null;\n\t\t\t\t}\n\t\t\t\telse {\n\t\t\t\t\tpackedResult = <Buffer>pack(result);\n\t\t\t\t}\n\t\t\t}\n\t\t\tcatch (packErr) {\n\t\t\t\tconsole.error(new Date(), 'Worker pack error', packErr);\n\t\t\t\tif (isPublicationResponse) {\n\t\t\t\t\tmeta = publicationMeta;\n\t\t\t\t\tresult = publicationPayload;\n\t\t\t\t}\n\t\t\t}\n\n\n\t\t\tif (this._methodManager.getEnableDebug()) {\n\t\t\t\tconsole.log(new Date(), 'Finished method', method);\n\t\t\t}\n\n\t\t\tif (!timedOut) {\n\t\t\t\tclearTimeout(timeoutHandle);\n\t\t\t\tconst payload: TaskResponse = {\n\t\t\t\t\ttype: 'taskComplete',\n\t\t\t\t\ttaskId,\n\t\t\t\t\tmessageId,\n\t\t\t\t\terror: false,\n\t\t\t\t\tresult: packedResult ? null : result,\n\t\t\t\t\tpackedResult,\n\t\t\t\t\tencoding: 'msgpack',\n\t\t\t\t\tmeta\n\t\t\t\t};\n\n\t\t\t\tthis.sendWorkerResponse(ws, payload);\n\t\t\t}\n\n this._runningTasks = this._runningTasks.filter(a => a !== taskId);\n \n if (this._methodManager.getEnableDebug()) {\n console.log(new Date(), 'Done with Task', JSON.stringify(this._runningTasks, null, 2));\n }\n }\n catch (err) {\n if (!timedOut) {\n clearTimeout(timeoutHandle);\n\t\t\t\tconst errorAt = Date.now();\n\t\t\t\tconst runMs = round(errorAt - receivedAt);\n\t\t\t\tconst totalMs = queuedAt ? round(errorAt - queuedAt) : null;\n console.error('Worker failed task:', taskId, 'Method:', method, err);\n err.message = 'Worker failed task:' + taskId + ' Method:' + method + ' - ' + err.message;\n\t\t\t\tthis.logWorkerEvent('workerTaskError', {\n\t\t\t\t\ttaskId,\n\t\t\t\t\tmethod,\n\t\t\t\t\tmessageId,\n\t\t\t\t\trunMs,\n\t\t\t\t\tqueueWaitMs,\n\t\t\t\t\tdispatchDelayMs,\n\t\t\t\t\ttotalMs,\n\t\t\t\t\tuserContext,\n\t\t\t\t\tparams,\n\t\t\t\t\terror: err\n\t\t\t\t});\n this.sendWorkerResponse(ws, {\n type: 'taskComplete',\n taskId,\n messageId,\n error: true,\n result: err || 'Unknown error'\n });\n throw err;\n }\n\n\t\t\tconst errorAt = Date.now();\n\t\t\tconst runMs = round(errorAt - receivedAt);\n\t\t\tconst totalMs = queuedAt ? round(errorAt - queuedAt) : null;\n\t\t\tthis.logWorkerEvent('workerTaskError', {\n\t\t\t\ttaskId,\n\t\t\t\tmethod,\n\t\t\t\tmessageId,\n\t\t\t\trunMs,\n\t\t\t\tqueueWaitMs,\n\t\t\t\tdispatchDelayMs,\n\t\t\t\ttotalMs,\n\t\t\t\tuserContext,\n\t\t\t\tparams,\n\t\t\t\terror: err\n\t\t\t});\n\n console.error(new Date(), `Error in Method: ${method} - ${JSON.stringify(data, null, 2)}`);\n \n await this._methodManager.callMethod('insertErrorLog', `Error in Method: ${method} - ${JSON.stringify(data, null, 2)}`);\n \n this._runningTasks = this._runningTasks.filter(a => a !== taskId);\n }\n }\n\n\tprivate logWorkerEvent(event: string, details: Record<string, any>) {\n\t\tconsole.log(this.safeStringify({\n\t\t\tts: new Date().toISOString(),\n\t\t\tevent,\n\t\t\t...details\n\t\t}));\n\t}\n\n\tprivate safeStringify(value: any): string {\n\t\ttry {\n\t\t\tconst seen = new WeakSet();\n\t\t\treturn JSON.stringify(value, (key, val) => {\n\t\t\t\tif (key === '__proto__') {\n\t\t\t\t\treturn undefined;\n\t\t\t\t}\n\t\t\t\tif (typeof val === 'bigint') {\n\t\t\t\t\treturn val.toString();\n\t\t\t\t}\n\t\t\t\tif (val instanceof Error) {\n\t\t\t\t\treturn {\n\t\t\t\t\t\tname: val.name,\n\t\t\t\t\t\tmessage: val.message,\n\t\t\t\t\t\tstack: val.stack\n\t\t\t\t\t};\n\t\t\t\t}\n\t\t\t\tif (val && typeof val === 'object') {\n\t\t\t\t\tif (seen.has(val)) {\n\t\t\t\t\t\treturn '[Circular]';\n\t\t\t\t\t}\n\t\t\t\t\tseen.add(val);\n\t\t\t\t}\n\t\t\t\treturn val;\n\t\t\t});\n\t\t}\n\t\tcatch (err) {\n\t\t\treturn JSON.stringify({\n\t\t\t\terror: 'safeStringifyFailed',\n\t\t\t\tmessage: err?.message || String(err)\n\t\t\t});\n\t\t}\n\t}\n\n\tpublic sendWorkerResponse(ws, payload: TaskResponse | string) {\n\t\tif (this._methodManager.getEnableDebug()) {\n\t\t\tconsole.log(new Date(), 'Sending', typeof payload === 'string' ? payload : '[binary]');\n\t\t}\n\n\t\tif (ws && ws.readyState === WebSocket.OPEN) {\n\t\t\ttry {\n\t\t\t\tif (typeof payload === 'string') {\n\t\t\t\t\tws.send(payload);\n\t\t\t\t}\n\t\t\t\telse {\n\t\t\t\t\tws.send(pack(payload));\n\t\t\t\t}\n\t\t\t}\n\t\t\tcatch (err) {\n\t\t\t\tconsole.error('Failed to send worker response:', err);\n\t\t\t}\n\t\t}\n\t\telse if (ws) {\n\t\t\tws.close();\n\t\t}\n\t}\n}\n"]}
package/package.json CHANGED
@@ -1,6 +1,6 @@
1
1
  {
2
2
  "name": "@resolveio/server-lib",
3
- "version": "22.0.2",
3
+ "version": "22.0.3",
4
4
  "description": "",
5
5
  "scripts": {
6
6
  "package": "./build_package.sh",