@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
|
-
|
|
335
|
-
|
|
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
|
-
|
|
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,
|
|
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
|
-
|
|
720
|
-
console.error('Error recording text message metric:',
|
|
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
|
-
|
|
764
|
-
console.error('Error recording text message metric:',
|
|
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,
|
|
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
|
-
|
|
826
|
-
console.error('Error recording text message metric:',
|
|
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
|
-
|
|
870
|
-
console.error('Error recording text message metric:',
|
|
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,
|
|
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
|
-
|
|
1250
|
-
console.error('Error in sendMail callback:',
|
|
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
|
|
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
|
-
|
|
1275
|
-
console.error('Error recording email metric:',
|
|
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, '&').replace(/</g, '<').replace(/>/g, '>') : '';\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, '&').replace(/</g, '<').replace(/>/g, '>') : '';\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.
|
|
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
|
-
|
|
264
|
-
if (
|
|
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
|
-
|
|
273
|
+
if (!this._methodManager.getMethod('insertErrorLog')) return [3 /*break*/, 4];
|
|
274
|
+
_c.label = 1;
|
|
267
275
|
case 1:
|
|
268
|
-
_c.
|
|
269
|
-
|
|
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
|
|
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 =
|
|
327
|
-
case
|
|
328
|
-
_c.trys.push([
|
|
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
|
|
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*/,
|
|
394
|
-
case
|
|
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
|
|
456
|
+
case 9:
|
|
442
457
|
_c.sent();
|
|
443
458
|
this._runningTasks = this._runningTasks.filter(function (a) { return a !== taskId; });
|
|
444
|
-
return [3 /*break*/,
|
|
445
|
-
case
|
|
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"]}
|