@resolveio/server-lib 20.7.93 → 20.7.95

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.
@@ -31,10 +31,10 @@ export declare class MethodManager {
31
31
  constructor();
32
32
  static create(websocketManager: WebSocketManager, monitorManagerFunction: MonitorManagerFunction, isWorkersEnabled: any, isWorkerInstance: any): MethodManager;
33
33
  private initialize;
34
- getMethod(method: string): MethodAllModel;
34
+ getMethod(methodName: string): MethodAllModel;
35
35
  methods(method: MethodModel): void;
36
36
  callMethodCron(method: string, ...methodData: any[]): Promise<any>;
37
- callMethod(method: string, ...methodData: any[]): Promise<any>;
37
+ callMethod(methodName: string, ...methodData: any[]): Promise<any>;
38
38
  setupEmailWatcher(): Promise<void>;
39
39
  loadPendingEmails(): Promise<void>;
40
40
  tryProcessEmail(): Promise<void>;
@@ -1,2 +1,2 @@
1
- "use strict";var __assign=this&&this.__assign||function(){return(__assign=Object.assign||function(e){for(var t,r=1,o=arguments.length;r<o;r++)for(var n in t=arguments[r])Object.prototype.hasOwnProperty.call(t,n)&&(e[n]=t[n]);return e}).apply(this,arguments)},__awaiter=this&&this.__awaiter||function(e,o,n,s){return new(n=n||Promise)(function(r,t){function fulfilled(e){try{step(s.next(e))}catch(e){t(e)}}function rejected(e){try{step(s.throw(e))}catch(e){t(e)}}function step(e){var t;e.done?r(e.value):((t=e.value)instanceof n?t:new n(function(e){e(t)})).then(fulfilled,rejected)}step((s=s.apply(e,o||[])).next())})},__generator=this&&this.__generator||function(o,n){var s,i,a,c={label:0,sent:function(){if(1&a[0])throw a[1];return a[1]},trys:[],ops:[]},l={next:verb(0),throw:verb(1),return:verb(2)};return"function"==typeof Symbol&&(l[Symbol.iterator]=function(){return this}),l;function verb(r){return function(e){var t=[r,e];if(s)throw new TypeError("Generator is already executing.");for(;c=l&&t[l=0]?0:c;)try{if(s=1,i&&(a=2&t[0]?i.return:t[0]?i.throw||((a=i.return)&&a.call(i),0):i.next)&&!(a=a.call(i,t[1])).done)return a;switch(i=0,(t=a?[2&t[0],a.value]:t)[0]){case 0:case 1:a=t;break;case 4:return c.label++,{value:t[1],done:!1};case 5:c.label++,i=t[1],t=[0];continue;case 7:t=c.ops.pop(),c.trys.pop();continue;default:if(!(a=0<(a=c.trys).length&&a[a.length-1])&&(6===t[0]||2===t[0])){c=0;continue}if(3===t[0]&&(!a||t[1]>a[0]&&t[1]<a[3]))c.label=t[1];else if(6===t[0]&&c.label<a[1])c.label=a[1],a=t;else{if(!(a&&c.label<a[2])){a[2]&&c.ops.pop(),c.trys.pop();continue}c.label=a[2],c.ops.push(t)}}t=n.call(o,c)}catch(e){t=[6,e],i=0}finally{s=a=0}if(5&t[0])throw t[1];return{value:t[0]?t[1]:void 0,done:!0}}}},__read=this&&this.__read||function(e,t){var r="function"==typeof Symbol&&e[Symbol.iterator];if(!r)return e;var o,n,s=r.call(e),i=[];try{for(;(void 0===t||0<t--)&&!(o=s.next()).done;)i.push(o.value)}catch(e){n={error:e}}finally{try{o&&!o.done&&(r=s.return)&&r.call(s)}finally{if(n)throw n.error}}return i},__spreadArray=this&&this.__spreadArray||function(e,t,r){if(r||2===arguments.length)for(var o,n=0,s=t.length;n<s;n++)!o&&n in t||((o=o||Array.prototype.slice.call(t,0,n))[n]=t[n]);return e.concat(o||Array.prototype.slice.call(t))},__values=this&&this.__values||function(e){var t="function"==typeof Symbol&&Symbol.iterator,r=t&&e[t],o=0;if(r)return r.call(e);if(e&&"number"==typeof e.length)return{next:function(){return{value:(e=e&&o>=e.length?void 0:e)&&e[o++],done:!e}}};throw new TypeError(t?"Object is not iterable.":"Symbol.iterator is not defined.")},client_s3_1=(Object.defineProperty(exports,"__esModule",{value:!0}),exports.MethodManager=exports.AWS=void 0,require("@aws-sdk/client-s3")),fs=require("fs"),nodemailer=require("nodemailer"),sesTransport=require("nodemailer-ses-transport"),path=require("path"),email_history_collection_1=require("../collections/email-history.collection"),log_collection_1=require("../collections/log.collection"),cron_jobs_1=require("../fixtures/cron-jobs"),init_1=require("../fixtures/init"),accounts_1=require("../methods/accounts"),aws_1=require("../methods/aws"),collections_1=require("../methods/collections"),counters_1=require("../methods/counters"),cron_jobs_2=require("../methods/cron-jobs"),flag_updates_1=require("../methods/flag-updates"),flags_1=require("../methods/flags"),logs_1=require("../methods/logs"),monitor_1=require("../methods/monitor"),pdf_1=require("../methods/pdf"),report_builder_1=require("../methods/report-builder"),support_1=require("../methods/support"),resolveio_server_app_1=require("../resolveio-server-app"),common_1=require("../util/common"),AWS=function(){function AWS(){this._s3=null,this._s3USEast1=null}return AWS.prototype.create=function(){var e=new AWS;return e.initialize(),e},AWS.prototype.initialize=function(){},AWS.prototype.s3=function(){return this._s3||(this._s3=new client_s3_1.S3({credentials:{accessKeyId:process.env.AWS_ACCESS_KEY,secretAccessKey:process.env.AWS_SECRET_ACCESS_KEY},region:process.env.AWS_REGION,apiVersion:"2006-03-01"})),this._s3},AWS.prototype.s3USEast1=function(){return"us-east-1"===process.env.AWS_REGION?this.s3():(this._s3USEast1||(this._s3USEast1=new client_s3_1.S3({credentials:{accessKeyId:process.env.AWS_ACCESS_KEY,secretAccessKey:process.env.AWS_SECRET_ACCESS_KEY},region:"us-east-1",apiVersion:"2006-03-01"})),this._s3USEast1)},AWS}(),MethodManager=(exports.AWS=AWS,function(){function MethodManager(){this._methods={},this._isWorkersEnabled=!1,this._isWorkerInstance=!1,this.emailQueue=new Set,this.isEmailProcessing=!1,this._debugcallMethodHits=0,this._debugCallMethodHits=0,this._debugCallMethodCronJobHits=0,this._debugSendQueueHits=0,this.clientDir="",this.serverConfig=""}return MethodManager.create=function(e,t,r,o){var n=new MethodManager;return n.initialize(e,t,r,o),n},MethodManager.prototype.initialize=function(e,t,r,o){var n=this;this._websocketManager=e,this._monitorManagerFunction=t,this._isWorkersEnabled=r,this._isWorkerInstance=o,this.clientDir=resolveio_server_app_1.ResolveIOServer.getClientDir(),this.serverConfig=resolveio_server_app_1.ResolveIOServer.getServerConfig(),process.env.IS_WORKERS_ENABLED&&"false"!==process.env.IS_WORKERS_ENABLED&&("true"!==process.env.IS_WORKER_INSTANCE||"0"!==process.env.WORKER_INDEX)||process.env.NODE_APP_INSTANCE&&"0"!==process.env.NODE_APP_INSTANCE||setTimeout(function(){return __awaiter(n,void 0,void 0,function(){return __generator(this,function(e){switch(e.label){case 0:return console.log(new Date,"Start Server Fixture"),[4,(0,init_1.loadServerInit)()];case 1:return e.sent(),console.log(new Date,"End Server Fixture"),[2]}})})},5e3),setImmediate(function(){return __awaiter(n,void 0,void 0,function(){return __generator(this,function(e){switch(e.label){case 0:return[4,(0,cron_jobs_1.loadServerCronJobs)()];case 1:return e.sent(),(0,accounts_1.loadAccountMethods)(this),(0,aws_1.loadAWSMethods)(this),(0,collections_1.loadCollectionMethods)(this),(0,counters_1.loadCounterMethods)(this),(0,logs_1.loadLogMethods)(this),(0,pdf_1.loadPDFMethods)(this),(0,cron_jobs_2.loadCronJobMethods)(this),(0,flags_1.loadFlagMethods)(this),(0,flag_updates_1.loadFlagUpdatesMethods)(this),(0,report_builder_1.loadReportBuilderMethods)(this),(0,support_1.loadSupportMethods)(this),(0,monitor_1.loadMonitorMethods)(this),[2]}})})}),this._aws=new AWS,resolveio_server_app_1.ResolveIOServer.getSESMail()?this._mailer=nodemailer.createTransport(sesTransport({accessKeyId:process.env.AWS_ACCESS_KEY,secretAccessKey:process.env.AWS_SECRET_ACCESS_KEY,region:process.env.AWS_SES_REGION})):this._mailer=nodemailer.createTransport({host:resolveio_server_app_1.ResolveIOServer.getServerConfig().MAIL_HOST,port:resolveio_server_app_1.ResolveIOServer.getServerConfig().MAIL_PORT,secure:!1,auth:{user:resolveio_server_app_1.ResolveIOServer.getServerConfig().MAIL_USERNAME,pass:resolveio_server_app_1.ResolveIOServer.getServerConfig().MAIL_PASSWORD},tls:{ciphers:"SSLv3"}}),setInterval(function(){resolveio_server_app_1.ResolveIOServer.getMainServer().getSubscriptionManager()&&resolveio_server_app_1.ResolveIOServer.getMainServer().getSubscriptionManager().getEnableDebug()&&(console.log(new Date,"Method Manager","Send Queue Hits",n._debugSendQueueHits),console.log(new Date,"Method Manager","Call Method Internal Hits",n._debugcallMethodHits),console.log(new Date,"Method Manager","Call Method Hits",n._debugCallMethodHits),console.log(new Date,"Method Manager","Call Method Cron Hits",n._debugCallMethodCronJobHits)),n._debugcallMethodHits=0,n._debugCallMethodHits=0,n._debugCallMethodCronJobHits=0,n._debugSendQueueHits=0},6e4),this._isWorkersEnabled&&!this._isWorkerInstance||setImmediate(function(){return __awaiter(n,void 0,void 0,function(){return __generator(this,function(e){switch(e.label){case 0:return[4,this.setupEmailWatcher()];case 1:return e.sent(),[2]}})})})},MethodManager.prototype.getMethod=function(e){return this._methods[e]},MethodManager.prototype.methods=function(e){this._methods=Object.assign(this._methods,e)},MethodManager.prototype.callMethodCron=function(c){for(var l=[],e=1;e<arguments.length;e++)l[e-1]=arguments[e];return __awaiter(this,void 0,void 0,function(){var t,r,o,n,s,i,a;return __generator(this,function(e){switch(e.label){case 0:return(this._debugCallMethodCronJobHits+=1,this._methods[c])?[3,2]:(console.log("No Method: "+c),[4,this.sendEmail("dev@resolveio.com","SERVER - Error Detected - "+resolveio_server_app_1.ResolveIOServer.getServerConfig().CLIENT_NAME,"No Method: "+c)]);case 1:throw e.sent(),new Error("No Method: "+c);case 2:return!(1<l.length||l[0])||this._methods[c].skipValidation?[3,10]:this._methods[c].check?[3,4]:(console.error(new Date,"No Check Function For Cron Method "+c),[4,this.sendEmail("dev@resolveio.com","SERVER - Error Detected - "+resolveio_server_app_1.ResolveIOServer.getServerConfig().CLIENT_NAME,"No Check Function For Cron Method "+c)]);case 3:throw e.sent(),new Error("No Check Function For Cron Method "+c);case 4:return this._methods[c].check._schema?[3,6]:(console.error(new Date,"No Check Schema For Cron Method "+c),[4,this.sendEmail("dev@resolveio.com","SERVER - Error Detected - "+resolveio_server_app_1.ResolveIOServer.getServerConfig().CLIENT_NAME,"No Check Function For Cron Method "+c)]);case 5:throw e.sent(),new Error("No Check Schema For Cron Method "+c);case 6:for(t={},a=Object.keys(this._methods[c].check._schema),r=a.filter(function(e){return!e.includes(".")}),o=0;o<l.length;o++)t[r[o]]=l[o];e.label=7;case 7:return e.trys.push([7,8,,10]),this._methods[c].check.validate(t),[3,10];case 8:return n=e.sent(),console.error(new Date,"Error in Cron Method Check ("+c+")",n),[4,this.sendEmail("dev@resolveio.com","SERVER - Error Detected - "+resolveio_server_app_1.ResolveIOServer.getServerConfig().CLIENT_NAME,"Match Error On Cron Method "+c+"\n\nData Being Checked\n"+JSON.stringify(t,null,2)+"\n\nErrors\n"+JSON.stringify(n,null,2))];case 9:throw e.sent(),n.message="".concat((new Date).toISOString()," - Error in Cron Method Check (").concat(c,"): ").concat(n.message),n;case 10:s=this._monitorManagerFunction.startMonitorFunction("Cron Method",c,"","",l),e.label=11;case 11:return e.trys.push([11,13,15,17]),[4,(a=this._methods[c].function).call.apply(a,__spreadArray([Object.assign({},this,MethodManager.prototype,{id_user:"",user:"",id_ws:""})],__read(l),!1))];case 12:return[2,e.sent()];case 13:return i=e.sent(),[4,this.sendEmail("dev@resolveio.com","SERVER - Error Detected - "+resolveio_server_app_1.ResolveIOServer.getServerConfig().CLIENT_NAME,"Error Detected During Cron Method "+c+" - (callMethodCron)\n\nData \n"+JSON.stringify(l,null,2)+"\n\nErrors\n"+JSON.stringify(i,null,2))];case 14:throw e.sent(),i.message="".concat((new Date).toISOString()," - Error in Cron Method (").concat(c,"): ").concat(i.message),i;case 15:return[4,this._monitorManagerFunction.finishMonitorFunction(s)];case 16:return e.sent(),[7];case 17:return[2]}})})},MethodManager.prototype.callMethod=function(a){for(var c=[],e=1;e<arguments.length;e++)c[e-1]=arguments[e];return __awaiter(this,void 0,void 0,function(){var o,n,t,r,s,i=this;return __generator(this,function(e){switch(e.label){case 0:if(this._debugcallMethodHits+=1,!this._methods[a])throw console.log("No Method: "+a),new Error("No Method: ".concat(a));if((1<c.length||c[0]&&"function"!=typeof c[0])&&!this._methods[a].skipValidation){if(!this._methods[a].check)throw console.error(new Date,"No Check Function For Method "+a),new Error("No Check Function For Method: ".concat(a));if(!this._methods[a].check._schema)throw console.error(new Date,"No Check Schema For Method "+a),new Error("No Check Schema For Method: ".concat(a))}return"insertSubscriptionLog"===a||"getDataURIfromURL"===a||"processAirdropDistribution"===a||"incCounter"===a||"supportCreateBillingUser"===a||"countCollectionWithQuery"===a?[3,4]:"https://resolveio.com"===resolveio_server_app_1.ResolveIOServer.getServerConfig().ROOT_URL||"http://localhost:4200"===resolveio_server_app_1.ResolveIOServer.getServerConfig().ROOT_URL?[3,1]:(resolveio_server_app_1.ResolveIOServer.getLocalLogManager().writeLog({type:"log",data:{_id:(0,common_1.objectIdHexString)(),createdAt:new Date,type:"callMethod",collection:"",id_document:"",payload:(0,common_1.getBinarySize)(JSON.stringify([c]))<1e6?JSON.stringify([c],null,2):"Too Big",method:a,id_user:this.id_user||"",user:this.user||"",messageId:0,route:""}}),[3,3]);case 1:return[4,log_collection_1.Logs.insertOne({_id:(0,common_1.objectIdHexString)(),type:"callMethod",collection:"",id_document:"",payload:(0,common_1.getBinarySize)(JSON.stringify([c]))<1e6?JSON.stringify([c],null,2):"Too Big",method:a,id_user:this.id_user||"",user:this.user||"",messageId:0,route:"",client:"ResolveIO",instance:"backend.resolveio.com",instance_index:process.env.NODE_APP_INSTANCE||""})];case 2:e.sent(),e.label=3;case 3:e.label=4;case 4:return(o="function"==typeof c[c.length-1]?c.slice(0,-1):c,resolveio_server_app_1.ResolveIOServer.getMongoManager().getSession()||["insertErrorLog","countWithQuery","sendEmail"].includes(a)||a.startsWith("monitor-")||a.startsWith("log"))?[3,5]:(n=null,[2,resolveio_server_app_1.ResolveIOServer.getMongoManager().oneTimeTransaction(function(){return __awaiter(i,void 0,void 0,function(){var t,r;return __generator(this,function(e){switch(e.label){case 0:n=this._monitorManagerFunction.startMonitorFunction("Method",a,this.user||"","",o),e.label=1;case 1:return e.trys.push([1,3,7,9]),[4,(r=this._methods[a].function).call.apply(r,__spreadArray([Object.assign({},this,MethodManager.prototype)],__read(o),!1))];case 2:return r=e.sent(),c[c.length-1]&&"function"==typeof c[c.length-1]&&c[c.length-1](null,r),[2,r];case 3:if(112===(t=e.sent()).code||"WriteConflict"===t.codeName)throw t;return console.log(JSON.stringify([new Date,"Error Method Manager - Run Method - New Session",a,{code:t.code,codeName:t.codeName,message:t.message,stack:t.stack}],null,2)),[4,this.sendEmail("dev@resolveio.com","SERVER - Error Detected - "+resolveio_server_app_1.ResolveIOServer.getServerConfig().CLIENT_NAME,"Error Detected During Method "+a+" - (callMethod)\n\nData \n"+JSON.stringify(c,null,2)+"\n\nErrors\n"+JSON.stringify(t,null,2))];case 4:return e.sent(),t.message="".concat((new Date).toISOString()," - Error in Method With Session (").concat(a,") - New Session: ").concat(t.message),c[c.length-1]&&"function"==typeof c[c.length-1]&&c[c.length-1](t,null),process.env.IS_WORKER_INSTANCE?[3,6]:[4,this.callMethod("insertErrorLog","Error in Method: ".concat(a," - ").concat(JSON.stringify(c,null,2)))];case 5:e.sent(),e.label=6;case 6:throw t;case 7:return[4,this._monitorManagerFunction.finishMonitorFunction(n)];case 8:return e.sent(),[7];case 9:return[2]}})})})]);case 5:t=this._monitorManagerFunction.startMonitorFunction("Method",a,this.user||"","",o),e.label=6;case 6:return e.trys.push([6,8,12,14]),[4,(s=this._methods[a].function).call.apply(s,__spreadArray([Object.assign({},this,MethodManager.prototype)],__read(o),!1))];case 7:return s=e.sent(),c[c.length-1]&&"function"==typeof c[c.length-1]&&c[c.length-1](null,s),[2,s];case 8:if(112===(r=e.sent()).code||"WriteConflict"===r.codeName)throw r;return console.log(JSON.stringify([new Date,"Error Method Manager - Run Method - Existing Session",a,{code:r.code,codeName:r.codeName,message:r.message,stack:r.stack}],null,2)),[4,this.sendEmail("dev@resolveio.com","SERVER - Error Detected - "+resolveio_server_app_1.ResolveIOServer.getServerConfig().CLIENT_NAME,"Error Detected During Method "+a+" - (callMethod)\n\nData \n"+JSON.stringify(c,null,2)+"\n\nErrors\n"+JSON.stringify(r,null,2))];case 9:return e.sent(),r.message="".concat((new Date).toISOString()," - Error in Method (").concat(a,") - Existing Session: ").concat(r.message),c[c.length-1]&&"function"==typeof c[c.length-1]&&c[c.length-1](r,null),process.env.IS_WORKER_INSTANCE?[3,11]:[4,this.callMethod("insertErrorLog","Error in Method: ".concat(a," - ").concat(JSON.stringify(c,null,2)))];case 10:e.sent(),e.label=11;case 11:throw r;case 12:return[4,this._monitorManagerFunction.finishMonitorFunction(t)];case 13:return e.sent(),[7];case 14:return[2]}})})},MethodManager.prototype.setupEmailWatcher=function(){return __awaiter(this,void 0,void 0,function(){var r,o=this;return __generator(this,function(e){switch(e.label){case 0:return(r=email_history_collection_1.EmailHistories.watchCollection([])).on("change",function(r){return __awaiter(o,void 0,void 0,function(){var t;return __generator(this,function(e){switch(e.label){case 0:return"insert"===r.operationType&&r.fullDocument&&"pending"===r.fullDocument.status?(this.emailQueue.add(r.fullDocument._id.toString()),[4,this.tryProcessEmail()]):[3,2];case 1:return e.sent(),[3,3];case 2:"update"!==r.operationType&&"replace"!==r.operationType||(t=r.fullDocument)&&"pending"!==t.status&&this.emailQueue.has(t._id.toString())&&this.emailQueue.delete(t._id.toString()),e.label=3;case 3:return[2]}})})}).on("error",function(t){return __awaiter(o,void 0,void 0,function(){return __generator(this,function(e){switch(e.label){case 0:return console.error("Email history changestream error",t),[4,r.close()];case 1:return e.sent(),[2]}})})}).on("close",function(){return __awaiter(o,void 0,void 0,function(){return __generator(this,function(e){switch(e.label){case 0:return[4,this.setupEmailWatcher()];case 1:return e.sent(),[2]}})})}),[4,this.loadPendingEmails()];case 1:return e.sent(),[2]}})})},MethodManager.prototype.loadPendingEmails=function(){return __awaiter(this,void 0,void 0,function(){var t,r,o,n,s,i;return __generator(this,function(e){switch(e.label){case 0:return[4,email_history_collection_1.EmailHistories.find({status:"pending"},{sort:{_id:1}})];case 1:t=e.sent();try{for(r=__values(t),o=r.next();!o.done;o=r.next())n=o.value,this.emailQueue.add(n._id.toString())}catch(e){s={error:e}}finally{try{o&&!o.done&&(i=r.return)&&i.call(r)}finally{if(s)throw s.error}}return[4,this.tryProcessEmail()];case 2:return e.sent(),[2]}})})},MethodManager.prototype.tryProcessEmail=function(){return __awaiter(this,void 0,void 0,function(){var t,u,r,h=this;return __generator(this,function(e){switch(e.label){case 0:if(this.isEmailProcessing||0===this.emailQueue.size)return[2];this.isEmailProcessing=!0,e.label=1;case 1:e.trys.push([1,5,6,9]),t=function(){var o,t,r,n,s,i,a,c,l;return __generator(this,function(e){switch(e.label){case 0:return s=u.emailQueue.values().next().value,u.emailQueue.delete(s),[4,email_history_collection_1.EmailHistories.findOneAndUpdate({_id:s,status:"pending"},{$set:{status:"processing",processingAt:new Date}})];case 1:if(!(o=e.sent()))return[2,"continue"];if(!(o.attachments&&0<o.attachments.length))return[3,14];e.label=2;case 2:e.trys.push([2,12,,14]),e.label=3;case 3:e.trys.push([3,9,10,11]),c=void 0,t=__values(o.attachments),r=t.next(),e.label=4;case 4:return r.done?[3,8]:(n=r.value).path&&n.path.startsWith("http")?[4,fetch(n.path)]:[3,7];case 5:if((s=e.sent()).ok)return[4,s.arrayBuffer()];throw new Error("Failed to fetch attachment: ".concat(n.path));case 6:i=e.sent(),i=Buffer.from(i),i.length<=20971520&&(n.content=i,delete n.path),e.label=7;case 7:return r=t.next(),[3,4];case 8:return[3,11];case 9:return i=e.sent(),c={error:i},[3,11];case 10:try{r&&!r.done&&(l=t.return)&&l.call(t)}finally{if(c)throw c.error}return[7];case 11:return[3,14];case 12:return a=e.sent(),console.error("Failed to fetch attachment:",a),[4,email_history_collection_1.EmailHistories.updateOne({_id:o._id},{$set:{status:"failed",error:"string"==typeof a?a:u.safeStringify(a),completedAt:new Date}})];case 13:return e.sent(),[2,"continue"];case 14:return(a={replyTo:o.reply_to||resolveio_server_app_1.ResolveIOServer.getServerConfig().MAIL_REPLY_TO||void 0,from:o.send_from||resolveio_server_app_1.ResolveIOServer.getServerConfig().MAIL_FROM,to:o.email,subject:(resolveio_server_app_1.ResolveIOServer.getServerConfig().ROOT_URL.match(/https:\/\/dev\./)||resolveio_server_app_1.ResolveIOServer.getServerConfig().ROOT_URL.match(/https:\/\/www\.dev\./)?"(DEV SERVER) - ":"")+o.subject,text:"string"==typeof o.text?o.text:"",html:"string"==typeof o.html?o.html:"",attachments:o.attachments||[]}).attachments&&0<a.attachments.length&&(a.attachments=a.attachments.map(function(e){e=__assign({},e);return!e.content||"object"!=typeof e.content||e.content instanceof Buffer?"string"==typeof e.content&&"base64"===e.encoding?(e.content=Buffer.from(e.content,"base64"),delete e.encoding):"string"==typeof e.content&&(e.content=Buffer.from(e.content)):"Binary"===e.content._bsontype&&0===e.content.sub_type?e.content=Buffer.from(e.content.buffer):e.content=Buffer.from(e.content),e})),u._mailer.sendMail(a,function(r){return __awaiter(h,void 0,void 0,function(){var t;return __generator(this,function(e){switch(e.label){case 0:return(e.trys.push([0,7,,9]),r)?(console.error("Failed to send email:",r),[4,email_history_collection_1.EmailHistories.updateOne({_id:o._id},{$set:{status:"failed",error:"string"==typeof r?r:this.safeStringify(r),completedAt:new Date}})]):[3,2];case 1:return e.sent(),[3,6];case 2:return"dev@resolveio.com"!==o.email?[3,4]:[4,email_history_collection_1.EmailHistories.deleteOne({_id:o._id})];case 3:return e.sent(),[3,6];case 4:return[4,email_history_collection_1.EmailHistories.updateOne({_id:o._id},{$set:{status:"completed",completedAt:new Date}})];case 5:e.sent(),e.label=6;case 6:return[3,9];case 7:return t=e.sent(),console.error("Error in sendMail callback:",t),[4,email_history_collection_1.EmailHistories.updateOne({_id:o._id},{$set:{status:"failed",error:"string"==typeof t?t:this.safeStringify(t),completedAt:new Date}})];case 8:return e.sent(),[3,9];case 9:return[2]}})})}),[4,new Promise(function(e){return setTimeout(e,1e3)})];case 15:return e.sent(),[2]}})},u=this,e.label=2;case 2:return 0<this.emailQueue.size?[5,t()]:[3,4];case 3:return e.sent(),[3,2];case 4:return[3,9];case 5:return r=e.sent(),console.error("Error processing email queue:",r),[3,9];case 6:return(this.isEmailProcessing=!1,0<this.emailQueue.size)?[4,this.tryProcessEmail()]:[3,8];case 7:e.sent(),e.label=8;case 8:return[7];case 9:return[2]}})})},MethodManager.prototype.safeStringify=function(e){try{return JSON.stringify(e,this.getCircularReplacer())}catch(e){return"Error in JSON stringifying: ".concat(e.message)}},MethodManager.prototype.getCircularReplacer=function(){var r=new WeakSet;return function(e,t){if("object"==typeof t&&null!==t){if(r.has(t))return"[Circular]";r.add(t)}return t}},MethodManager.prototype.sendEmail=function(o,n,s,i,a,c,l,u){return void 0===u&&(u=!1),__awaiter(this,void 0,void 0,function(){var t,r;return __generator(this,function(e){switch(e.label){case 0:if(!(o=!resolveio_server_app_1.ResolveIOServer.getServerConfig().ROOT_URL.match(/https:\/\/dev\./)&&!resolveio_server_app_1.ResolveIOServer.getServerConfig().ROOT_URL.match(/https:\/\/www\.dev\./)&&"http://localhost:4200"!==resolveio_server_app_1.ResolveIOServer.getServerConfig().ROOT_URL||o.match(/\@resolveio\.com/)?o:"dev@resolveio.com"))return[3,7];if("http://localhost:4200"===resolveio_server_app_1.ResolveIOServer.getServerConfig().ROOT_URL&&!u)return[3,5];a=a||[],a=(a=Array.isArray(a)?a:[a]).map(function(e){e=__assign({},e);return Buffer.isBuffer(e.content)&&(e.content=e.content.toString("base64"),e.encoding="base64"),e}),t={_id:(0,common_1.objectIdHexString)(),__v:0,date:new Date,id_user:this.id_user||"",user:this.user||"",email:o,subject:n||"",text:s||"",html:i||"",attachments:a||[],send_from:c||"",reply_to:l||"",status:"pending",error:""},e.label=1;case 1:return e.trys.push([1,3,,4]),[4,email_history_collection_1.EmailHistories.insertOne(t)];case 2:return[2,e.sent()];case 3:throw r=e.sent(),console.error("Failed to queue email:",r),r.message="Failed to queue email: ".concat(r.message),r;case 4:return[3,6];case 5:return console.log("Send email",o,n,s,i,a,c),[2,!0];case 6:return[3,8];case 7:return[2,!0];case 8:return[2]}})})},MethodManager.prototype.getAWS=function(){return this._aws},MethodManager.prototype.readFile=function(e){if(fs.existsSync(path.join(__dirname,"../private/"+e)))try{return fs.readFileSync(path.join(__dirname,"../private/"+e),"utf-8")}catch(e){throw e.message="Error in readFile: ".concat(e.message),e}else if(fs.existsSync(path.join(resolveio_server_app_1.ResolveIOServer.getClientDir(),"./private/"+e)))try{return fs.readFileSync(path.join(resolveio_server_app_1.ResolveIOServer.getClientDir(),"./private/"+e),"utf-8")}catch(e){throw e.message="Error in readFile: ".concat(e.message),e}throw new Error("Error in readFile: File Not Found")},MethodManager.prototype.readImage=function(e){if(fs.existsSync(path.join(__dirname,"../private/"+e)))try{return fs.readFileSync(path.join(__dirname,"../private/"+e),"base64")}catch(e){throw e.message="Error in readImage: ".concat(e.message),e}else if(fs.existsSync(path.join(resolveio_server_app_1.ResolveIOServer.getClientDir(),"./private/"+e)))try{return fs.readFileSync(path.join(resolveio_server_app_1.ResolveIOServer.getClientDir(),"./private/"+e),"base64")}catch(e){throw e.message="Error in readImage: ".concat(e.message),e}throw new Error("Error in readImage: File Not Found")},MethodManager}());exports.MethodManager=MethodManager;
1
+ "use strict";var __assign=this&&this.__assign||function(){return(__assign=Object.assign||function(e){for(var t,r=1,o=arguments.length;r<o;r++)for(var n in t=arguments[r])Object.prototype.hasOwnProperty.call(t,n)&&(e[n]=t[n]);return e}).apply(this,arguments)},__awaiter=this&&this.__awaiter||function(e,o,n,s){return new(n=n||Promise)(function(r,t){function fulfilled(e){try{step(s.next(e))}catch(e){t(e)}}function rejected(e){try{step(s.throw(e))}catch(e){t(e)}}function step(e){var t;e.done?r(e.value):((t=e.value)instanceof n?t:new n(function(e){e(t)})).then(fulfilled,rejected)}step((s=s.apply(e,o||[])).next())})},__generator=this&&this.__generator||function(o,n){var s,i,a,c={label:0,sent:function(){if(1&a[0])throw a[1];return a[1]},trys:[],ops:[]},l={next:verb(0),throw:verb(1),return:verb(2)};return"function"==typeof Symbol&&(l[Symbol.iterator]=function(){return this}),l;function verb(r){return function(e){var t=[r,e];if(s)throw new TypeError("Generator is already executing.");for(;c=l&&t[l=0]?0:c;)try{if(s=1,i&&(a=2&t[0]?i.return:t[0]?i.throw||((a=i.return)&&a.call(i),0):i.next)&&!(a=a.call(i,t[1])).done)return a;switch(i=0,(t=a?[2&t[0],a.value]:t)[0]){case 0:case 1:a=t;break;case 4:return c.label++,{value:t[1],done:!1};case 5:c.label++,i=t[1],t=[0];continue;case 7:t=c.ops.pop(),c.trys.pop();continue;default:if(!(a=0<(a=c.trys).length&&a[a.length-1])&&(6===t[0]||2===t[0])){c=0;continue}if(3===t[0]&&(!a||t[1]>a[0]&&t[1]<a[3]))c.label=t[1];else if(6===t[0]&&c.label<a[1])c.label=a[1],a=t;else{if(!(a&&c.label<a[2])){a[2]&&c.ops.pop(),c.trys.pop();continue}c.label=a[2],c.ops.push(t)}}t=n.call(o,c)}catch(e){t=[6,e],i=0}finally{s=a=0}if(5&t[0])throw t[1];return{value:t[0]?t[1]:void 0,done:!0}}}},__read=this&&this.__read||function(e,t){var r="function"==typeof Symbol&&e[Symbol.iterator];if(!r)return e;var o,n,s=r.call(e),i=[];try{for(;(void 0===t||0<t--)&&!(o=s.next()).done;)i.push(o.value)}catch(e){n={error:e}}finally{try{o&&!o.done&&(r=s.return)&&r.call(s)}finally{if(n)throw n.error}}return i},__spreadArray=this&&this.__spreadArray||function(e,t,r){if(r||2===arguments.length)for(var o,n=0,s=t.length;n<s;n++)!o&&n in t||((o=o||Array.prototype.slice.call(t,0,n))[n]=t[n]);return e.concat(o||Array.prototype.slice.call(t))},__values=this&&this.__values||function(e){var t="function"==typeof Symbol&&Symbol.iterator,r=t&&e[t],o=0;if(r)return r.call(e);if(e&&"number"==typeof e.length)return{next:function(){return{value:(e=e&&o>=e.length?void 0:e)&&e[o++],done:!e}}};throw new TypeError(t?"Object is not iterable.":"Symbol.iterator is not defined.")},client_s3_1=(Object.defineProperty(exports,"__esModule",{value:!0}),exports.MethodManager=exports.AWS=void 0,require("@aws-sdk/client-s3")),fs=require("fs"),nodemailer=require("nodemailer"),sesTransport=require("nodemailer-ses-transport"),path=require("path"),email_history_collection_1=require("../collections/email-history.collection"),log_collection_1=require("../collections/log.collection"),cron_jobs_1=require("../fixtures/cron-jobs"),init_1=require("../fixtures/init"),accounts_1=require("../methods/accounts"),aws_1=require("../methods/aws"),collections_1=require("../methods/collections"),counters_1=require("../methods/counters"),cron_jobs_2=require("../methods/cron-jobs"),flag_updates_1=require("../methods/flag-updates"),flags_1=require("../methods/flags"),logs_1=require("../methods/logs"),monitor_1=require("../methods/monitor"),pdf_1=require("../methods/pdf"),report_builder_1=require("../methods/report-builder"),support_1=require("../methods/support"),resolveio_server_app_1=require("../resolveio-server-app"),common_1=require("../util/common"),AWS=function(){function AWS(){this._s3=null,this._s3USEast1=null}return AWS.prototype.create=function(){var e=new AWS;return e.initialize(),e},AWS.prototype.initialize=function(){},AWS.prototype.s3=function(){return this._s3||(this._s3=new client_s3_1.S3({credentials:{accessKeyId:process.env.AWS_ACCESS_KEY,secretAccessKey:process.env.AWS_SECRET_ACCESS_KEY},region:process.env.AWS_REGION,apiVersion:"2006-03-01"})),this._s3},AWS.prototype.s3USEast1=function(){return"us-east-1"===process.env.AWS_REGION?this.s3():(this._s3USEast1||(this._s3USEast1=new client_s3_1.S3({credentials:{accessKeyId:process.env.AWS_ACCESS_KEY,secretAccessKey:process.env.AWS_SECRET_ACCESS_KEY},region:"us-east-1",apiVersion:"2006-03-01"})),this._s3USEast1)},AWS}(),MethodManager=(exports.AWS=AWS,function(){function MethodManager(){this._methods={},this._isWorkersEnabled=!1,this._isWorkerInstance=!1,this.emailQueue=new Set,this.isEmailProcessing=!1,this._debugcallMethodHits=0,this._debugCallMethodHits=0,this._debugCallMethodCronJobHits=0,this._debugSendQueueHits=0,this.clientDir="",this.serverConfig=""}return MethodManager.create=function(e,t,r,o){var n=new MethodManager;return n.initialize(e,t,r,o),n},MethodManager.prototype.initialize=function(e,t,r,o){var n=this;this._websocketManager=e,this._monitorManagerFunction=t,this._isWorkersEnabled=r,this._isWorkerInstance=o,this.clientDir=resolveio_server_app_1.ResolveIOServer.getClientDir(),this.serverConfig=resolveio_server_app_1.ResolveIOServer.getServerConfig(),process.env.IS_WORKERS_ENABLED&&"false"!==process.env.IS_WORKERS_ENABLED&&("true"!==process.env.IS_WORKER_INSTANCE||"0"!==process.env.WORKER_INDEX)||process.env.NODE_APP_INSTANCE&&"0"!==process.env.NODE_APP_INSTANCE||setTimeout(function(){return __awaiter(n,void 0,void 0,function(){return __generator(this,function(e){switch(e.label){case 0:return console.log(new Date,"Start Server Fixture"),[4,(0,init_1.loadServerInit)()];case 1:return e.sent(),console.log(new Date,"End Server Fixture"),[2]}})})},5e3),setImmediate(function(){return __awaiter(n,void 0,void 0,function(){return __generator(this,function(e){switch(e.label){case 0:return[4,(0,cron_jobs_1.loadServerCronJobs)()];case 1:return e.sent(),(0,accounts_1.loadAccountMethods)(this),(0,aws_1.loadAWSMethods)(this),(0,collections_1.loadCollectionMethods)(this),(0,counters_1.loadCounterMethods)(this),(0,logs_1.loadLogMethods)(this),(0,pdf_1.loadPDFMethods)(this),(0,cron_jobs_2.loadCronJobMethods)(this),(0,flags_1.loadFlagMethods)(this),(0,flag_updates_1.loadFlagUpdatesMethods)(this),(0,report_builder_1.loadReportBuilderMethods)(this),(0,support_1.loadSupportMethods)(this),(0,monitor_1.loadMonitorMethods)(this),[2]}})})}),this._aws=new AWS,resolveio_server_app_1.ResolveIOServer.getSESMail()?this._mailer=nodemailer.createTransport(sesTransport({accessKeyId:process.env.AWS_ACCESS_KEY,secretAccessKey:process.env.AWS_SECRET_ACCESS_KEY,region:process.env.AWS_SES_REGION})):this._mailer=nodemailer.createTransport({host:resolveio_server_app_1.ResolveIOServer.getServerConfig().MAIL_HOST,port:resolveio_server_app_1.ResolveIOServer.getServerConfig().MAIL_PORT,secure:!1,auth:{user:resolveio_server_app_1.ResolveIOServer.getServerConfig().MAIL_USERNAME,pass:resolveio_server_app_1.ResolveIOServer.getServerConfig().MAIL_PASSWORD},tls:{ciphers:"SSLv3"}}),setInterval(function(){resolveio_server_app_1.ResolveIOServer.getMainServer().getSubscriptionManager()&&resolveio_server_app_1.ResolveIOServer.getMainServer().getSubscriptionManager().getEnableDebug()&&(console.log(new Date,"Method Manager","Send Queue Hits",n._debugSendQueueHits),console.log(new Date,"Method Manager","Call Method Internal Hits",n._debugcallMethodHits),console.log(new Date,"Method Manager","Call Method Hits",n._debugCallMethodHits),console.log(new Date,"Method Manager","Call Method Cron Hits",n._debugCallMethodCronJobHits)),n._debugcallMethodHits=0,n._debugCallMethodHits=0,n._debugCallMethodCronJobHits=0,n._debugSendQueueHits=0},6e4),this._isWorkersEnabled&&!this._isWorkerInstance||setImmediate(function(){return __awaiter(n,void 0,void 0,function(){return __generator(this,function(e){switch(e.label){case 0:return[4,this.setupEmailWatcher()];case 1:return e.sent(),[2]}})})})},MethodManager.prototype.getMethod=function(e){return this._methods[e]},MethodManager.prototype.methods=function(e){this._methods=Object.assign(this._methods,e)},MethodManager.prototype.callMethodCron=function(c){for(var l=[],e=1;e<arguments.length;e++)l[e-1]=arguments[e];return __awaiter(this,void 0,void 0,function(){var t,r,o,n,s,i,a;return __generator(this,function(e){switch(e.label){case 0:return(this._debugCallMethodCronJobHits+=1,this._methods[c])?[3,2]:(console.log("No Method: "+c),[4,this.sendEmail("dev@resolveio.com","SERVER - Error Detected - "+resolveio_server_app_1.ResolveIOServer.getServerConfig().CLIENT_NAME,"No Method: "+c)]);case 1:throw e.sent(),new Error("No Method: "+c);case 2:return!(1<l.length||l[0])||this._methods[c].skipValidation?[3,10]:this._methods[c].check?[3,4]:(console.error(new Date,"No Check Function For Cron Method "+c),[4,this.sendEmail("dev@resolveio.com","SERVER - Error Detected - "+resolveio_server_app_1.ResolveIOServer.getServerConfig().CLIENT_NAME,"No Check Function For Cron Method "+c)]);case 3:throw e.sent(),new Error("No Check Function For Cron Method "+c);case 4:return this._methods[c].check._schema?[3,6]:(console.error(new Date,"No Check Schema For Cron Method "+c),[4,this.sendEmail("dev@resolveio.com","SERVER - Error Detected - "+resolveio_server_app_1.ResolveIOServer.getServerConfig().CLIENT_NAME,"No Check Function For Cron Method "+c)]);case 5:throw e.sent(),new Error("No Check Schema For Cron Method "+c);case 6:for(t={},a=Object.keys(this._methods[c].check._schema),r=a.filter(function(e){return!e.includes(".")}),o=0;o<l.length;o++)t[r[o]]=l[o];e.label=7;case 7:return e.trys.push([7,8,,10]),this._methods[c].check.validate(t),[3,10];case 8:return n=e.sent(),console.error(new Date,"Error in Cron Method Check ("+c+")",n),[4,this.sendEmail("dev@resolveio.com","SERVER - Error Detected - "+resolveio_server_app_1.ResolveIOServer.getServerConfig().CLIENT_NAME,"Match Error On Cron Method "+c+"\n\nData Being Checked\n"+JSON.stringify(t,null,2)+"\n\nErrors\n"+JSON.stringify(n,null,2))];case 9:throw e.sent(),n.message="".concat((new Date).toISOString()," - Error in Cron Method Check (").concat(c,"): ").concat(n.message),n;case 10:s=this._monitorManagerFunction.startMonitorFunction("Cron Method",c,"","",l),e.label=11;case 11:return e.trys.push([11,13,15,17]),[4,(a=this._methods[c].function).call.apply(a,__spreadArray([Object.assign({},this,MethodManager.prototype,{id_user:"",user:"",id_ws:""})],__read(l),!1))];case 12:return[2,e.sent()];case 13:return i=e.sent(),[4,this.sendEmail("dev@resolveio.com","SERVER - Error Detected - "+resolveio_server_app_1.ResolveIOServer.getServerConfig().CLIENT_NAME,"Error Detected During Cron Method "+c+" - (callMethodCron)\n\nData \n"+JSON.stringify(l,null,2)+"\n\nErrors\n"+JSON.stringify(i,null,2))];case 14:throw e.sent(),i.message="".concat((new Date).toISOString()," - Error in Cron Method (").concat(c,"): ").concat(i.message),i;case 15:return[4,this._monitorManagerFunction.finishMonitorFunction(s)];case 16:return e.sent(),[7];case 17:return[2]}})})},MethodManager.prototype.callMethod=function(l){for(var u=[],e=1;e<arguments.length;e++)u[e-1]=arguments[e];return __awaiter(this,void 0,void 0,function(){var o,n,s,t,r,i,a,c=this;return __generator(this,function(e){switch(e.label){case 0:if(this._debugcallMethodHits+=1,!(o=this.getMethod(l)))throw console.log("No Method: "+l),new Error("No Method: ".concat(l));if((1<u.length||u[0]&&"function"!=typeof u[0])&&!o.skipValidation){if(!o.check)throw console.error(new Date,"No Check Function For Method "+l),new Error("No Check Function For Method: ".concat(l));if(!o.check._schema)throw console.error(new Date,"No Check Schema For Method "+l),new Error("No Check Schema For Method: ".concat(l))}return"insertSubscriptionLog"===l||"getDataURIfromURL"===l||"processAirdropDistribution"===l||"incCounter"===l||"supportCreateBillingUser"===l||"countCollectionWithQuery"===l?[3,4]:"https://resolveio.com"===resolveio_server_app_1.ResolveIOServer.getServerConfig().ROOT_URL||"http://localhost:4200"===resolveio_server_app_1.ResolveIOServer.getServerConfig().ROOT_URL?[3,1]:(resolveio_server_app_1.ResolveIOServer.getLocalLogManager().writeLog({type:"log",data:{_id:(0,common_1.objectIdHexString)(),createdAt:new Date,type:"callMethod",collection:"",id_document:"",payload:(0,common_1.getBinarySize)(JSON.stringify([u]))<1e6?JSON.stringify([u],null,2):"Too Big",methodName:l,id_user:this.id_user||"",user:this.user||"",messageId:0,route:""}}),[3,3]);case 1:return[4,log_collection_1.Logs.insertOne({_id:(0,common_1.objectIdHexString)(),type:"callMethod",collection:"",id_document:"",payload:(0,common_1.getBinarySize)(JSON.stringify([u]))<1e6?JSON.stringify([u],null,2):"Too Big",method:l,id_user:this.id_user||"",user:this.user||"",messageId:0,route:"",client:"ResolveIO",instance:"backend.resolveio.com",instance_index:process.env.NODE_APP_INSTANCE||""})];case 2:e.sent(),e.label=3;case 3:e.label=4;case 4:return(n="function"==typeof u[u.length-1]?u.slice(0,-1):u,a=resolveio_server_app_1.ResolveIOServer.getMongoManager().getSession(),o.bypassSession||a||["insertErrorLog","countWithQuery","sendEmail"].includes(l)||l.startsWith("monitor-")||l.startsWith("log"))?[3,5]:(s=null,[2,resolveio_server_app_1.ResolveIOServer.getMongoManager().oneTimeTransaction(function(){return __awaiter(c,void 0,void 0,function(){var t,r;return __generator(this,function(e){switch(e.label){case 0:s=this._monitorManagerFunction.startMonitorFunction("Method",l,this.user||"","",n),e.label=1;case 1:return e.trys.push([1,3,7,9]),[4,(r=o.function).call.apply(r,__spreadArray([Object.assign({},this,MethodManager.prototype)],__read(n),!1))];case 2:return r=e.sent(),u[u.length-1]&&"function"==typeof u[u.length-1]&&u[u.length-1](null,r),[2,r];case 3:if(112===(t=e.sent()).code||"WriteConflict"===t.codeName)throw t;return console.log(JSON.stringify([new Date,"Error Method Manager - Run Method - New Session",l,{code:t.code,codeName:t.codeName,message:t.message,stack:t.stack}],null,2)),[4,this.sendEmail("dev@resolveio.com","SERVER - Error Detected - "+resolveio_server_app_1.ResolveIOServer.getServerConfig().CLIENT_NAME,"Error Detected During Method "+l+" - (callMethod)\n\nData \n"+JSON.stringify(u,null,2)+"\n\nErrors\n"+JSON.stringify(t,null,2))];case 4:return e.sent(),t.message="".concat((new Date).toISOString()," - Error in Method With Session (").concat(l,") - New Session: ").concat(t.message),u[u.length-1]&&"function"==typeof u[u.length-1]&&u[u.length-1](t,null),process.env.IS_WORKER_INSTANCE?[3,6]:[4,this.callMethod("insertErrorLog","Error in Method: ".concat(l," - ").concat(JSON.stringify(u,null,2)))];case 5:e.sent(),e.label=6;case 6:throw t;case 7:return[4,this._monitorManagerFunction.finishMonitorFunction(s)];case 8:return e.sent(),[7];case 9:return[2]}})})})]);case 5:t=this._monitorManagerFunction.startMonitorFunction("Method",l,this.user||"","",n),e.label=6;case 6:return e.trys.push([6,8,12,14]),[4,(a=o.function).call.apply(a,__spreadArray([Object.assign({},this,MethodManager.prototype)],__read(n),!1))];case 7:return r=e.sent(),u[u.length-1]&&"function"==typeof u[u.length-1]&&u[u.length-1](null,r),[2,r];case 8:if(112===(i=e.sent()).code||"WriteConflict"===i.codeName)throw i;return console.log(JSON.stringify([new Date,"Error Method Manager - Run Method - Existing Session",l,{code:i.code,codeName:i.codeName,message:i.message,stack:i.stack}],null,2)),[4,this.sendEmail("dev@resolveio.com","SERVER - Error Detected - "+resolveio_server_app_1.ResolveIOServer.getServerConfig().CLIENT_NAME,"Error Detected During Method "+l+" - (callMethod)\n\nData \n"+JSON.stringify(u,null,2)+"\n\nErrors\n"+JSON.stringify(i,null,2))];case 9:return e.sent(),i.message="".concat((new Date).toISOString()," - Error in Method (").concat(l,") - Existing Session: ").concat(i.message),u[u.length-1]&&"function"==typeof u[u.length-1]&&u[u.length-1](i,null),process.env.IS_WORKER_INSTANCE?[3,11]:[4,this.callMethod("insertErrorLog","Error in Method: ".concat(l," - ").concat(JSON.stringify(u,null,2)))];case 10:e.sent(),e.label=11;case 11:throw i;case 12:return[4,this._monitorManagerFunction.finishMonitorFunction(t)];case 13:return e.sent(),[7];case 14:return[2]}})})},MethodManager.prototype.setupEmailWatcher=function(){return __awaiter(this,void 0,void 0,function(){var r,o=this;return __generator(this,function(e){switch(e.label){case 0:return(r=email_history_collection_1.EmailHistories.watchCollection([])).on("change",function(r){return __awaiter(o,void 0,void 0,function(){var t;return __generator(this,function(e){switch(e.label){case 0:return"insert"===r.operationType&&r.fullDocument&&"pending"===r.fullDocument.status?(this.emailQueue.add(r.fullDocument._id.toString()),[4,this.tryProcessEmail()]):[3,2];case 1:return e.sent(),[3,3];case 2:"update"!==r.operationType&&"replace"!==r.operationType||(t=r.fullDocument)&&"pending"!==t.status&&this.emailQueue.has(t._id.toString())&&this.emailQueue.delete(t._id.toString()),e.label=3;case 3:return[2]}})})}).on("error",function(t){return __awaiter(o,void 0,void 0,function(){return __generator(this,function(e){switch(e.label){case 0:return console.error("Email history changestream error",t),[4,r.close()];case 1:return e.sent(),[2]}})})}).on("close",function(){return __awaiter(o,void 0,void 0,function(){return __generator(this,function(e){switch(e.label){case 0:return[4,this.setupEmailWatcher()];case 1:return e.sent(),[2]}})})}),[4,this.loadPendingEmails()];case 1:return e.sent(),[2]}})})},MethodManager.prototype.loadPendingEmails=function(){return __awaiter(this,void 0,void 0,function(){var t,r,o,n,s,i;return __generator(this,function(e){switch(e.label){case 0:return[4,email_history_collection_1.EmailHistories.find({status:"pending"},{sort:{_id:1}})];case 1:t=e.sent();try{for(r=__values(t),o=r.next();!o.done;o=r.next())n=o.value,this.emailQueue.add(n._id.toString())}catch(e){s={error:e}}finally{try{o&&!o.done&&(i=r.return)&&i.call(r)}finally{if(s)throw s.error}}return[4,this.tryProcessEmail()];case 2:return e.sent(),[2]}})})},MethodManager.prototype.tryProcessEmail=function(){return __awaiter(this,void 0,void 0,function(){var t,u,r,h=this;return __generator(this,function(e){switch(e.label){case 0:if(this.isEmailProcessing||0===this.emailQueue.size)return[2];this.isEmailProcessing=!0,e.label=1;case 1:e.trys.push([1,5,6,9]),t=function(){var o,t,r,n,s,i,a,c,l;return __generator(this,function(e){switch(e.label){case 0:return s=u.emailQueue.values().next().value,u.emailQueue.delete(s),[4,email_history_collection_1.EmailHistories.findOneAndUpdate({_id:s,status:"pending"},{$set:{status:"processing",processingAt:new Date}})];case 1:if(!(o=e.sent()))return[2,"continue"];if(!(o.attachments&&0<o.attachments.length))return[3,14];e.label=2;case 2:e.trys.push([2,12,,14]),e.label=3;case 3:e.trys.push([3,9,10,11]),c=void 0,t=__values(o.attachments),r=t.next(),e.label=4;case 4:return r.done?[3,8]:(n=r.value).path&&n.path.startsWith("http")?[4,fetch(n.path)]:[3,7];case 5:if((s=e.sent()).ok)return[4,s.arrayBuffer()];throw new Error("Failed to fetch attachment: ".concat(n.path));case 6:i=e.sent(),i=Buffer.from(i),i.length<=20971520&&(n.content=i,delete n.path),e.label=7;case 7:return r=t.next(),[3,4];case 8:return[3,11];case 9:return i=e.sent(),c={error:i},[3,11];case 10:try{r&&!r.done&&(l=t.return)&&l.call(t)}finally{if(c)throw c.error}return[7];case 11:return[3,14];case 12:return a=e.sent(),console.error("Failed to fetch attachment:",a),[4,email_history_collection_1.EmailHistories.updateOne({_id:o._id},{$set:{status:"failed",error:"string"==typeof a?a:u.safeStringify(a),completedAt:new Date}})];case 13:return e.sent(),[2,"continue"];case 14:return(a={replyTo:o.reply_to||resolveio_server_app_1.ResolveIOServer.getServerConfig().MAIL_REPLY_TO||void 0,from:o.send_from||resolveio_server_app_1.ResolveIOServer.getServerConfig().MAIL_FROM,to:o.email,subject:(resolveio_server_app_1.ResolveIOServer.getServerConfig().ROOT_URL.match(/https:\/\/dev\./)||resolveio_server_app_1.ResolveIOServer.getServerConfig().ROOT_URL.match(/https:\/\/www\.dev\./)?"(DEV SERVER) - ":"")+o.subject,text:"string"==typeof o.text?o.text:"",html:"string"==typeof o.html?o.html:"",attachments:o.attachments||[]}).attachments&&0<a.attachments.length&&(a.attachments=a.attachments.map(function(e){e=__assign({},e);return!e.content||"object"!=typeof e.content||e.content instanceof Buffer?"string"==typeof e.content&&"base64"===e.encoding?(e.content=Buffer.from(e.content,"base64"),delete e.encoding):"string"==typeof e.content&&(e.content=Buffer.from(e.content)):"Binary"===e.content._bsontype&&0===e.content.sub_type?e.content=Buffer.from(e.content.buffer):e.content=Buffer.from(e.content),e})),u._mailer.sendMail(a,function(r){return __awaiter(h,void 0,void 0,function(){var t;return __generator(this,function(e){switch(e.label){case 0:return(e.trys.push([0,7,,9]),r)?(console.error("Failed to send email:",r),[4,email_history_collection_1.EmailHistories.updateOne({_id:o._id},{$set:{status:"failed",error:"string"==typeof r?r:this.safeStringify(r),completedAt:new Date}})]):[3,2];case 1:return e.sent(),[3,6];case 2:return"dev@resolveio.com"!==o.email?[3,4]:[4,email_history_collection_1.EmailHistories.deleteOne({_id:o._id})];case 3:return e.sent(),[3,6];case 4:return[4,email_history_collection_1.EmailHistories.updateOne({_id:o._id},{$set:{status:"completed",completedAt:new Date}})];case 5:e.sent(),e.label=6;case 6:return[3,9];case 7:return t=e.sent(),console.error("Error in sendMail callback:",t),[4,email_history_collection_1.EmailHistories.updateOne({_id:o._id},{$set:{status:"failed",error:"string"==typeof t?t:this.safeStringify(t),completedAt:new Date}})];case 8:return e.sent(),[3,9];case 9:return[2]}})})}),[4,new Promise(function(e){return setTimeout(e,1e3)})];case 15:return e.sent(),[2]}})},u=this,e.label=2;case 2:return 0<this.emailQueue.size?[5,t()]:[3,4];case 3:return e.sent(),[3,2];case 4:return[3,9];case 5:return r=e.sent(),console.error("Error processing email queue:",r),[3,9];case 6:return(this.isEmailProcessing=!1,0<this.emailQueue.size)?[4,this.tryProcessEmail()]:[3,8];case 7:e.sent(),e.label=8;case 8:return[7];case 9:return[2]}})})},MethodManager.prototype.safeStringify=function(e){try{return JSON.stringify(e,this.getCircularReplacer())}catch(e){return"Error in JSON stringifying: ".concat(e.message)}},MethodManager.prototype.getCircularReplacer=function(){var r=new WeakSet;return function(e,t){if("object"==typeof t&&null!==t){if(r.has(t))return"[Circular]";r.add(t)}return t}},MethodManager.prototype.sendEmail=function(o,n,s,i,a,c,l,u){return void 0===u&&(u=!1),__awaiter(this,void 0,void 0,function(){var t,r;return __generator(this,function(e){switch(e.label){case 0:if(!(o=!resolveio_server_app_1.ResolveIOServer.getServerConfig().ROOT_URL.match(/https:\/\/dev\./)&&!resolveio_server_app_1.ResolveIOServer.getServerConfig().ROOT_URL.match(/https:\/\/www\.dev\./)&&"http://localhost:4200"!==resolveio_server_app_1.ResolveIOServer.getServerConfig().ROOT_URL||o.match(/\@resolveio\.com/)?o:"dev@resolveio.com"))return[3,7];if("http://localhost:4200"===resolveio_server_app_1.ResolveIOServer.getServerConfig().ROOT_URL&&!u)return[3,5];a=a||[],a=(a=Array.isArray(a)?a:[a]).map(function(e){e=__assign({},e);return Buffer.isBuffer(e.content)&&(e.content=e.content.toString("base64"),e.encoding="base64"),e}),t={_id:(0,common_1.objectIdHexString)(),__v:0,date:new Date,id_user:this.id_user||"",user:this.user||"",email:o,subject:n||"",text:s||"",html:i||"",attachments:a||[],send_from:c||"",reply_to:l||"",status:"pending",error:""},e.label=1;case 1:return e.trys.push([1,3,,4]),[4,email_history_collection_1.EmailHistories.insertOne(t)];case 2:return[2,e.sent()];case 3:throw r=e.sent(),console.error("Failed to queue email:",r),r.message="Failed to queue email: ".concat(r.message),r;case 4:return[3,6];case 5:return console.log("Send email",o,n,s,i,a,c),[2,!0];case 6:return[3,8];case 7:return[2,!0];case 8:return[2]}})})},MethodManager.prototype.getAWS=function(){return this._aws},MethodManager.prototype.readFile=function(e){if(fs.existsSync(path.join(__dirname,"../private/"+e)))try{return fs.readFileSync(path.join(__dirname,"../private/"+e),"utf-8")}catch(e){throw e.message="Error in readFile: ".concat(e.message),e}else if(fs.existsSync(path.join(resolveio_server_app_1.ResolveIOServer.getClientDir(),"./private/"+e)))try{return fs.readFileSync(path.join(resolveio_server_app_1.ResolveIOServer.getClientDir(),"./private/"+e),"utf-8")}catch(e){throw e.message="Error in readFile: ".concat(e.message),e}throw new Error("Error in readFile: File Not Found")},MethodManager.prototype.readImage=function(e){if(fs.existsSync(path.join(__dirname,"../private/"+e)))try{return fs.readFileSync(path.join(__dirname,"../private/"+e),"base64")}catch(e){throw e.message="Error in readImage: ".concat(e.message),e}else if(fs.existsSync(path.join(resolveio_server_app_1.ResolveIOServer.getClientDir(),"./private/"+e)))try{return fs.readFileSync(path.join(resolveio_server_app_1.ResolveIOServer.getClientDir(),"./private/"+e),"base64")}catch(e){throw e.message="Error in readImage: ".concat(e.message),e}throw new Error("Error in readImage: File Not Found")},MethodManager}());exports.MethodManager=MethodManager;
2
2
  //# sourceMappingURL=method.manager.js.map
@@ -1 +1 @@
1
- {"version":3,"sources":["../../src/managers/method.manager.ts"],"names":["client_s3_1","require","fs","nodemailer","sesTransport","path","email_history_collection_1","log_collection_1","cron_jobs_1","init_1","accounts_1","aws_1","collections_1","counters_1","cron_jobs_2","flag_updates_1","flags_1","logs_1","monitor_1","pdf_1","report_builder_1","support_1","resolveio_server_app_1","common_1","AWS","this","_s3","_s3USEast1","prototype","create","aws","initialize","s3","S3","credentials","accessKeyId","process","env","AWS_ACCESS_KEY","secretAccessKey","AWS_SECRET_ACCESS_KEY","region","AWS_REGION","apiVersion","s3USEast1","MethodManager","exports","_methods","_isWorkersEnabled","_isWorkerInstance","emailQueue","Set","isEmailProcessing","_debugcallMethodHits","_debugCallMethodHits","_debugCallMethodCronJobHits","_debugSendQueueHits","clientDir","serverConfig","websocketManager","monitorManagerFunction","isWorkersEnabled","isWorkerInstance","methodManager","_this","_websocketManager","_monitorManagerFunction","ResolveIOServer","getClientDir","getServerConfig","IS_WORKERS_ENABLED","IS_WORKER_INSTANCE","WORKER_INDEX","NODE_APP_INSTANCE","setTimeout","__awaiter","console","log","Date","loadServerInit","_a","sent","setImmediate","loadServerCronJobs","loadAccountMethods","loadAWSMethods","loadCollectionMethods","loadCounterMethods","loadLogMethods","loadPDFMethods","loadCronJobMethods","loadFlagMethods","loadFlagUpdatesMethods","loadReportBuilderMethods","loadSupportMethods","loadMonitorMethods","_aws","getSESMail","_mailer","createTransport","AWS_SES_REGION","host","port","secure","auth","user","pass","tls","ciphers","setInterval","getMainServer","getSubscriptionManager","getEnableDebug","setupEmailWatcher","getMethod","method","methods","Object","assign","callMethodCron","methodData","_i","arguments","length","sendEmail","_b","Error","skipValidation","check","error","_schema","valObj","valKeys","keys","rootKeys","filter","a","includes","i","validate","err_1","JSON","stringify","message","concat","toISOString","monitor","startMonitorFunction","function","call","apply","__spreadArray","id_user","id_ws","__read","err_2","finishMonitorFunction","callMethod","getLocalLogManager","writeLog","type","data","_id","objectIdHexString","createdAt","collection","id_document","payload","getBinarySize","messageId","route","Logs","insertOne","client","instance","instance_index","functionMethodData","slice","getMongoManager","getSession","startsWith","monitor_2","oneTimeTransaction","res","code","err_4","codeName","stack","err_3","changeStream","EmailHistories","watchCollection","on","change","operationType","fullDocument","status","add","toString","tryProcessEmail","updatedEmail","has","delete","err","close","loadPendingEmails","find","sort","pendingEmails","pendingEmails_1","__values","pendingEmails_1_1","next","done","email","value","size","emailId","this_1","values","findOneAndUpdate","$set","processingAt","emailHistory","_e","attachments","e_2","_c","att","fetch","response","ok","arrayBuffer","buffer","Buffer","from","content","err_6","updateOne","safeStringify","completedAt","mailOptions","replyTo","reply_to","undefined","send_from","MAIL_FROM","to","subject","match","text","html","map","newAtt","__assign","encoding","_bsontype","sub_type","sendMail","deleteOne","error_1","Promise","resolve","err_5","obj","getCircularReplacer","e","seen","WeakSet","key","sendTo","local_override","Array","isArray","isBuffer","__v","date","err_7","getAWS","readFile","fileName","existsSync","join","__dirname","readFileSync","readImage"],"mappings":"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","file":"method.manager.js","sourcesContent":["import { S3 } from '@aws-sdk/client-s3';\nimport * as fs from 'fs';\nimport * as nodemailer from 'nodemailer';\nimport * as sesTransport from 'nodemailer-ses-transport';\nimport * as path from 'path';\nimport { EmailHistories } from '../collections/email-history.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 { 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 { loadPDFMethods } from '../methods/pdf';\nimport { loadReportBuilderMethods } from '../methods/report-builder';\nimport { loadSupportMethods } from '../methods/support';\nimport { EmailHistoryModel } 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 { MonitorManagerFunction } from './monitor.manager';\nimport { WebSocketManager } from './websocket.manager';\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 _mailer: 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\n\tprivate _debugcallMethodHits = 0;\n\tprivate _debugCallMethodHits = 0;\n\tprivate _debugCallMethodCronJobHits = 0;\n\tprivate _debugSendQueueHits = 0;\n\n\tpublic clientDir = '';\n\tpublic serverConfig = '';\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\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});\n\t\t\n\t\tthis._aws = new AWS();\n\t\t\n\t\tif (ResolveIOServer.getSESMail()) {\n\t\t\tthis._mailer = nodemailer.createTransport(sesTransport({\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\tregion: process.env.AWS_SES_REGION\n\t\t\t}));\n\t\t}\n\t\telse {\n\t\t\tthis._mailer = nodemailer.createTransport({\n\t\t\t\thost: ResolveIOServer.getServerConfig()['MAIL_HOST'], // 'smtp.office365.com', // Office 365 server\n\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(() => {\n\t\t\tif (ResolveIOServer.getMainServer().getSubscriptionManager() && ResolveIOServer.getMainServer().getSubscriptionManager().getEnableDebug()) {\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\tsetImmediate(async () => {\n\t\t\t\tawait this.setupEmailWatcher();\n\t\t\t});\n\t\t}\n\t}\n\n\tpublic getMethod(method: string): MethodAllModel {\n\t\treturn this._methods[method];\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\tpublic async callMethodCron(method: string, ...methodData: any[]) {\n\t\tthis._debugCallMethodCronJobHits += 1;\n\n\t\tif (!this._methods[method]) {\n\t\t\tconsole.log('No Method: ' + method);\n\n\t\t\tawait this.sendEmail('dev@resolveio.com', 'SERVER - Error Detected - ' + ResolveIOServer.getServerConfig()['CLIENT_NAME'], 'No Method: ' + method);\n\n\t\t\tthrow new Error('No Method: ' + method);\n\t\t}\n\t\t\n\t\tif ((methodData.length > 1 || methodData[0]) && !this._methods[method].skipValidation) {\n\t\t\tif (!this._methods[method].check) {\n\t\t\t\tconsole.error(new Date(), 'No Check Function For Cron Method ' + method);\n\n\t\t\t\tawait this.sendEmail('dev@resolveio.com', 'SERVER - Error Detected - ' + ResolveIOServer.getServerConfig()['CLIENT_NAME'], 'No Check Function For Cron Method ' + method);\n\t\n\t\t\t\tthrow new Error('No Check Function For Cron Method ' + method);\n\t\t\t}\n\t\t\telse if (!this._methods[method].check._schema) {\n\t\t\t\tconsole.error(new Date(), 'No Check Schema For Cron Method ' + method);\n\n\t\t\t\tawait this.sendEmail('dev@resolveio.com', 'SERVER - Error Detected - ' + ResolveIOServer.getServerConfig()['CLIENT_NAME'], 'No Check Function For Cron Method ' + method);\n\t\n\t\t\t\tthrow new Error('No Check Schema For Cron Method ' + method);\n\t\t\t}\n\t\t\telse {\n\t\t\t\tlet valObj = {};\n\t\t\t\tlet valKeys = Object.keys(this._methods[method].check._schema);\n\n\t\t\t\tlet rootKeys = valKeys.filter(a => !a.includes('.'));\n\t\t\t\t\n\t\t\t\tfor (let i = 0; i < methodData.length; i++) {\n\t\t\t\t\tvalObj[rootKeys[i]] = methodData[i];\n\t\t\t\t}\n\n\t\t\t\ttry {\n\t\t\t\t\tthis._methods[method].check.validate(valObj);\n\t\t\t\t}\n\t\t\t\tcatch (err) {\n\t\t\t\t\tconsole.error(new Date(), 'Error in Cron Method Check (' + method + ')', err);\n\n\t\t\t\t\tawait this.sendEmail('dev@resolveio.com', 'SERVER - Error Detected - ' + ResolveIOServer.getServerConfig()['CLIENT_NAME'], 'Match Error On Cron Method ' + method + '\\n\\nData Being Checked\\n' + JSON.stringify(valObj, null, 2) + '\\n\\nErrors\\n' + JSON.stringify(err, null, 2));\n\t\t\t\t\terr.message = `${new Date().toISOString()} - Error in Cron Method Check (${method}): ${err.message}`;\n\n\t\t\t\t\tthrow err;\n\t\t\t\t}\n\t\t\t}\n\t\t}\n\n\t\tlet monitor = this._monitorManagerFunction.startMonitorFunction('Cron Method', method, '', '', methodData);\n\n\t\ttry {\n\t\t\tlet res = await this._methods[method].function.call(Object.assign({}, this, MethodManager.prototype, {id_user: '', user: '', id_ws: ''}), ...methodData);\n\t\t\treturn res;\n\t\t}\n\t\tcatch (err) {\n\t\t\tawait this.sendEmail('dev@resolveio.com', 'SERVER - Error Detected - ' + ResolveIOServer.getServerConfig()['CLIENT_NAME'], 'Error Detected During Cron Method ' + method + ' - (callMethodCron)\\n\\nData \\n' + JSON.stringify(methodData, null, 2) + '\\n\\nErrors\\n' + JSON.stringify(err, null, 2));\n\t\t\t\n\t\t\terr.message = `${new Date().toISOString()} - Error in Cron Method (${method}): ${err.message}`;\n\t\t\t\n\t\t\tthrow err;\n\t\t}\n\t\tfinally {\n\t\t\tawait this._monitorManagerFunction.finishMonitorFunction(monitor);\n\t\t}\n\t}\n\n\t// Call/run method internal (No Emit on Socket)\n\tpublic async callMethod(method: string, ...methodData: any[]): Promise<any> {\n\t\tthis._debugcallMethodHits += 1;\n\n\t\tif (!this._methods[method]) {\n\t\t\tconsole.log('No Method: ' + method);\n\t\t\tthrow new Error(`No Method: ${method}`);\n\t\t}\n\n\t\tif ((methodData.length > 1 || (methodData[0] && typeof methodData[0] !== 'function')) && !this._methods[method].skipValidation) {\n\t\t\tif (!this._methods[method].check) {\n\t\t\t\tconsole.error(new Date(), 'No Check Function For Method ' + method);\n\t\t\t\tthrow new Error(`No Check Function For Method: ${method}`);\n\t\t\t}\n\t\t\telse if (!this._methods[method].check._schema) {\n\t\t\t\tconsole.error(new Date(), 'No Check Schema For Method ' + method);\n\t\t\t\tthrow new Error(`No Check Schema For Method: ${method}`);\n\t\t\t}\n\t\t}\n\n\t\tif (method !== 'insertSubscriptionLog' && method !== 'getDataURIfromURL' && method !== 'processAirdropDistribution' && method !== 'incCounter' && method !== 'supportCreateBillingUser' && method !== 'countCollectionWithQuery') {\n\t\t\tif (\n\t\t\t\tResolveIOServer.getServerConfig()['ROOT_URL'] !== 'https://resolveio.com'\n\t\t\t&& ResolveIOServer.getServerConfig()['ROOT_URL'] !== 'http://localhost:4200'\n\t\t\t) {\n\t\t\t\tResolveIOServer.getLocalLogManager().writeLog({\n\t\t\t\t\ttype: 'log',\n\t\t\t\t\tdata: {\n\t\t\t\t\t\t_id: objectIdHexString(),\n\t\t\t\t\t\tcreatedAt: new Date(),\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: method,\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}\n\t\t\t\t});\n\t\t\t}\n\t\t\telse {\n\t\t\t\tawait Logs.insertOne({\n\t\t\t\t\t_id: objectIdHexString(),\n\t\t\t\t\ttype: 'callMethod',\n\t\t\t\t\tcollection: '',\n\t\t\t\t\tid_document: '',\n\t\t\t\t\tpayload: getBinarySize(JSON.stringify([methodData])) < 1000000 ? JSON.stringify([methodData], null, 2) : 'Too Big',\n\t\t\t\t\tmethod: method,\n\t\t\t\t\tid_user: this['id_user'] || '',\n\t\t\t\t\tuser: this['user'] || '',\n\t\t\t\t\tmessageId: 0,\n\t\t\t\t\troute: '',\n\t\t\t\t\tclient: 'ResolveIO',\n\t\t\t\t\tinstance: 'backend.resolveio.com',\n\t\t\t\t\tinstance_index: process.env.NODE_APP_INSTANCE || ''\n\t\t\t\t})\n\t\t\t};\n\t\t}\n\n\t\tlet functionMethodData = typeof(methodData[methodData.length - 1]) === 'function' ? methodData.slice(0, -1) : methodData;\n\n\t\tconst session = ResolveIOServer.getMongoManager().getSession();\n\n\t\tif (!session && \n\t\t\t![\n\t\t\t\t'insertErrorLog', // CIRCULAR LOOP - DO NOT REMOVE\n\t\t\t\t'countWithQuery', // MONGO SESSIONS/TRANSACTIONS DONT WORTH WITH COUNTS\n\t\t\t\t'sendEmail' // ALWAYS SEND SO ALWAYS HAVE RECORD - DONT ROLL BACK - BYPASS SESSION\n\t\t\t].includes(method) &&\n\t\t\t!method.startsWith('monitor-') &&\n\t\t\t!method.startsWith('log')\n\t\t) {\n\t\t\tlet monitor = null;\n\t\t\t\n\t\t\treturn ResolveIOServer.getMongoManager().oneTimeTransaction(async () => {\n\t\t\t\tmonitor = this._monitorManagerFunction.startMonitorFunction('Method', method, this['user'] || '', '', functionMethodData);\n\t\t\t\t\n\t\t\t\ttry {\n\t\t\t\t\tlet res = await this._methods[method].function.call(Object.assign({}, this, MethodManager.prototype), ...functionMethodData);\n\n\t\t\t\t\tif (methodData[methodData.length - 1] && typeof(methodData[methodData.length - 1]) === 'function') {\n\t\t\t\t\t\tmethodData[methodData.length - 1](null, res);\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') {\n\t\t\t\t\t\tthrow err; // Write error, retry\n\t\t\t\t\t}\n\n\t\t\t\t\tconsole.log(JSON.stringify([new Date(), 'Error Method Manager - Run Method - New Session', method, {\n\t\t\t\t\t\tcode: err.code,\n\t\t\t\t\t\tcodeName: err.codeName,\n\t\t\t\t\t\tmessage: err.message,\n\t\t\t\t\t\tstack: err.stack\n\t\t\t\t\t}], null, 2));\n\n\t\t\t\t\tawait this.sendEmail('dev@resolveio.com', 'SERVER - Error Detected - ' + ResolveIOServer.getServerConfig()['CLIENT_NAME'], 'Error Detected During Method ' + method + ' - (callMethod)\\n\\nData \\n' + JSON.stringify(methodData, null, 2) + '\\n\\nErrors\\n' + JSON.stringify(err, null, 2));\n\t\t\t\t\terr.message = `${new Date().toISOString()} - Error in Method With Session (${method}) - New Session: ${err.message}`;\n\n\t\t\t\t\tif (methodData[methodData.length - 1] && typeof(methodData[methodData.length - 1]) === 'function') {\n\t\t\t\t\t\tmethodData[methodData.length - 1](err, null);\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('insertErrorLog', `Error in Method: ${method} - ${JSON.stringify(methodData, null, 2)}`);\n\t\t\t\t\t}\n\n\t\t\t\t\tthrow err;\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\t\t}\n\t\telse {\n\t\t\tlet monitor = this._monitorManagerFunction.startMonitorFunction('Method', method, this['user'] || '', '', functionMethodData);\n\t\t\t\n\t\t\ttry {\n\t\t\t\tlet res = await this._methods[method].function.call(Object.assign({}, this, MethodManager.prototype), ...functionMethodData);\n\n\t\t\t\tif (methodData[methodData.length - 1] && typeof(methodData[methodData.length - 1]) === 'function') {\n\t\t\t\t\tmethodData[methodData.length - 1](null, res);\n\t\t\t\t}\n\n\t\t\t\treturn res;\n\t\t\t}\n\t\t\tcatch (err) {\n\t\t\t\tif (err.code === 112 || err.codeName === 'WriteConflict') {\n\t\t\t\t\tthrow err; // Write error, retry\n\t\t\t\t}\n\n\t\t\t\tconsole.log(JSON.stringify([new Date(), 'Error Method Manager - Run Method - Existing Session', method, {\n\t\t\t\t\tcode: err.code,\n\t\t\t\t\tcodeName: err.codeName,\n\t\t\t\t\tmessage: err.message,\n\t\t\t\t\tstack: err.stack\n\t\t\t\t}], null, 2));\n\n\t\t\t\tawait this.sendEmail('dev@resolveio.com', 'SERVER - Error Detected - ' + ResolveIOServer.getServerConfig()['CLIENT_NAME'], 'Error Detected During Method ' + method + ' - (callMethod)\\n\\nData \\n' + JSON.stringify(methodData, null, 2) + '\\n\\nErrors\\n' + JSON.stringify(err, null, 2));\n\t\t\t\terr.message = `${new Date().toISOString()} - Error in Method (${method}) - Existing Session: ${err.message}`;\n\t\t\t\t\n\t\t\t\tif (methodData[methodData.length - 1] && typeof(methodData[methodData.length - 1]) === 'function') {\n\t\t\t\t\tmethodData[methodData.length - 1](err, null);\n\t\t\t\t}\n\n\t\t\t\tif (!process.env.IS_WORKER_INSTANCE) {\n\t\t\t\t\tawait this.callMethod('insertErrorLog', `Error in Method: ${method} - ${JSON.stringify(methodData, null, 2)}`);\n\t\t\t\t}\n\t\t\t\t\n\t\t\t\tthrow err;\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\t}\n\n\tasync setupEmailWatcher() {\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', async () => {\n\t\t\tawait this.setupEmailWatcher();\n\t\t});\n\n\t\tawait this.loadPendingEmails();\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 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\t\t\t\tif (emailHistory.attachments && emailHistory.attachments.length > 0) {\n\t\t\t\t\ttry {\n\t\t\t\t\t\tfor (let att of emailHistory.attachments) {\n\t\t\t\t\t\t\tif (att.path && att.path.startsWith('http')) {\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\tthrow new Error(`Failed to fetch attachment: ${att.path}`);\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\t\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}\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 (err) {\n\t\t\t\t\t\tconsole.error('Failed to fetch attachment:', err);\n\t\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 err === 'string' ? err : this.safeStringify(err),\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\t// Skip to the next email\n\t\t\t\t\t\tcontinue;\n\t\t\t\t\t}\n\t\t\t\t}\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};\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\tthis._mailer.sendMail(mailOptions, async err => {\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});\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\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\tpublic async sendEmail(\n\t\tsendTo: string,\n\t\tsubject: string,\n\t\ttext?: string,\n\t\thtml?: string,\n\t\tattachments?: any[],\n\t\tsend_from?: string,\n\t\treply_to?: string,\n\t\tlocal_override = false\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\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\tif (!attachments) {\n\t\t\t\t\tattachments = [];\n\t\t\t\t}\n\n\t\t\t\tif (!Array.isArray(attachments)) {\n\t\t\t\t\tattachments = [attachments];\n\t\t\t\t}\n\n\t\t\t\t// Process attachments before saving\n\t\t\t\tattachments = attachments.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\t// Queue the email in MongoDB\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: subject || '',\n\t\t\t\t\ttext: text || '',\n\t\t\t\t\thtml: html || '',\n\t\t\t\t\tattachments: attachments || [],\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};\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\tsubject,\n\t\t\t\t\ttext,\n\t\t\t\t\thtml,\n\t\t\t\t\tattachments,\n\t\t\t\t\tsend_from\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}"]}
1
+ {"version":3,"sources":["../../src/managers/method.manager.ts"],"names":["client_s3_1","require","fs","nodemailer","sesTransport","path","email_history_collection_1","log_collection_1","cron_jobs_1","init_1","accounts_1","aws_1","collections_1","counters_1","cron_jobs_2","flag_updates_1","flags_1","logs_1","monitor_1","pdf_1","report_builder_1","support_1","resolveio_server_app_1","common_1","AWS","this","_s3","_s3USEast1","prototype","create","aws","initialize","s3","S3","credentials","accessKeyId","process","env","AWS_ACCESS_KEY","secretAccessKey","AWS_SECRET_ACCESS_KEY","region","AWS_REGION","apiVersion","s3USEast1","MethodManager","exports","_methods","_isWorkersEnabled","_isWorkerInstance","emailQueue","Set","isEmailProcessing","_debugcallMethodHits","_debugCallMethodHits","_debugCallMethodCronJobHits","_debugSendQueueHits","clientDir","serverConfig","websocketManager","monitorManagerFunction","isWorkersEnabled","isWorkerInstance","methodManager","_this","_websocketManager","_monitorManagerFunction","ResolveIOServer","getClientDir","getServerConfig","IS_WORKERS_ENABLED","IS_WORKER_INSTANCE","WORKER_INDEX","NODE_APP_INSTANCE","setTimeout","__awaiter","console","log","Date","loadServerInit","_a","sent","setImmediate","loadServerCronJobs","loadAccountMethods","loadAWSMethods","loadCollectionMethods","loadCounterMethods","loadLogMethods","loadPDFMethods","loadCronJobMethods","loadFlagMethods","loadFlagUpdatesMethods","loadReportBuilderMethods","loadSupportMethods","loadMonitorMethods","_aws","getSESMail","_mailer","createTransport","AWS_SES_REGION","host","port","secure","auth","user","pass","tls","ciphers","setInterval","getMainServer","getSubscriptionManager","getEnableDebug","setupEmailWatcher","getMethod","methodName","methods","method","Object","assign","callMethodCron","methodData","_i","arguments","length","sendEmail","_b","Error","skipValidation","check","error","_schema","valObj","valKeys","keys","rootKeys","filter","a","includes","i","validate","err_1","JSON","stringify","message","concat","toISOString","monitor","startMonitorFunction","function","call","apply","__spreadArray","id_user","id_ws","__read","err_2","finishMonitorFunction","callMethod","getLocalLogManager","writeLog","type","data","_id","objectIdHexString","createdAt","collection","id_document","payload","getBinarySize","messageId","route","Logs","insertOne","client","instance","instance_index","functionMethodData","slice","session","getMongoManager","getSession","bypassSession","startsWith","monitor_2","oneTimeTransaction","res","code","err_4","codeName","stack","err_3","changeStream","EmailHistories","watchCollection","on","change","operationType","fullDocument","status","add","toString","tryProcessEmail","updatedEmail","has","delete","err","close","loadPendingEmails","find","sort","pendingEmails","pendingEmails_1","__values","pendingEmails_1_1","next","done","email","value","size","emailId","this_1","values","findOneAndUpdate","$set","processingAt","emailHistory","_e","attachments","e_2","_c","att","fetch","response","ok","arrayBuffer","buffer","Buffer","from","content","err_6","updateOne","safeStringify","completedAt","mailOptions","replyTo","reply_to","undefined","send_from","MAIL_FROM","to","subject","match","text","html","map","newAtt","__assign","encoding","_bsontype","sub_type","sendMail","deleteOne","error_1","Promise","resolve","err_5","obj","getCircularReplacer","e","seen","WeakSet","key","sendTo","local_override","Array","isArray","isBuffer","__v","date","err_7","getAWS","readFile","fileName","existsSync","join","__dirname","readFileSync","readImage"],"mappings":"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","file":"method.manager.js","sourcesContent":["import { S3 } from '@aws-sdk/client-s3';\nimport * as fs from 'fs';\nimport * as nodemailer from 'nodemailer';\nimport * as sesTransport from 'nodemailer-ses-transport';\nimport * as path from 'path';\nimport { EmailHistories } from '../collections/email-history.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 { 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 { loadPDFMethods } from '../methods/pdf';\nimport { loadReportBuilderMethods } from '../methods/report-builder';\nimport { loadSupportMethods } from '../methods/support';\nimport { EmailHistoryModel } 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 { MonitorManagerFunction } from './monitor.manager';\nimport { WebSocketManager } from './websocket.manager';\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 _mailer: 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\n\tprivate _debugcallMethodHits = 0;\n\tprivate _debugCallMethodHits = 0;\n\tprivate _debugCallMethodCronJobHits = 0;\n\tprivate _debugSendQueueHits = 0;\n\n\tpublic clientDir = '';\n\tpublic serverConfig = '';\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\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});\n\t\t\n\t\tthis._aws = new AWS();\n\t\t\n\t\tif (ResolveIOServer.getSESMail()) {\n\t\t\tthis._mailer = nodemailer.createTransport(sesTransport({\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\tregion: process.env.AWS_SES_REGION\n\t\t\t}));\n\t\t}\n\t\telse {\n\t\t\tthis._mailer = nodemailer.createTransport({\n\t\t\t\thost: ResolveIOServer.getServerConfig()['MAIL_HOST'], // 'smtp.office365.com', // Office 365 server\n\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(() => {\n\t\t\tif (ResolveIOServer.getMainServer().getSubscriptionManager() && ResolveIOServer.getMainServer().getSubscriptionManager().getEnableDebug()) {\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\tsetImmediate(async () => {\n\t\t\t\tawait this.setupEmailWatcher();\n\t\t\t});\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\tpublic async callMethodCron(method: string, ...methodData: any[]) {\n\t\tthis._debugCallMethodCronJobHits += 1;\n\n\t\tif (!this._methods[method]) {\n\t\t\tconsole.log('No Method: ' + method);\n\n\t\t\tawait this.sendEmail('dev@resolveio.com', 'SERVER - Error Detected - ' + ResolveIOServer.getServerConfig()['CLIENT_NAME'], 'No Method: ' + method);\n\n\t\t\tthrow new Error('No Method: ' + method);\n\t\t}\n\t\t\n\t\tif ((methodData.length > 1 || methodData[0]) && !this._methods[method].skipValidation) {\n\t\t\tif (!this._methods[method].check) {\n\t\t\t\tconsole.error(new Date(), 'No Check Function For Cron Method ' + method);\n\n\t\t\t\tawait this.sendEmail('dev@resolveio.com', 'SERVER - Error Detected - ' + ResolveIOServer.getServerConfig()['CLIENT_NAME'], 'No Check Function For Cron Method ' + method);\n\t\n\t\t\t\tthrow new Error('No Check Function For Cron Method ' + method);\n\t\t\t}\n\t\t\telse if (!this._methods[method].check._schema) {\n\t\t\t\tconsole.error(new Date(), 'No Check Schema For Cron Method ' + method);\n\n\t\t\t\tawait this.sendEmail('dev@resolveio.com', 'SERVER - Error Detected - ' + ResolveIOServer.getServerConfig()['CLIENT_NAME'], 'No Check Function For Cron Method ' + method);\n\t\n\t\t\t\tthrow new Error('No Check Schema For Cron Method ' + method);\n\t\t\t}\n\t\t\telse {\n\t\t\t\tlet valObj = {};\n\t\t\t\tlet valKeys = Object.keys(this._methods[method].check._schema);\n\n\t\t\t\tlet rootKeys = valKeys.filter(a => !a.includes('.'));\n\t\t\t\t\n\t\t\t\tfor (let i = 0; i < methodData.length; i++) {\n\t\t\t\t\tvalObj[rootKeys[i]] = methodData[i];\n\t\t\t\t}\n\n\t\t\t\ttry {\n\t\t\t\t\tthis._methods[method].check.validate(valObj);\n\t\t\t\t}\n\t\t\t\tcatch (err) {\n\t\t\t\t\tconsole.error(new Date(), 'Error in Cron Method Check (' + method + ')', err);\n\n\t\t\t\t\tawait this.sendEmail('dev@resolveio.com', 'SERVER - Error Detected - ' + ResolveIOServer.getServerConfig()['CLIENT_NAME'], 'Match Error On Cron Method ' + method + '\\n\\nData Being Checked\\n' + JSON.stringify(valObj, null, 2) + '\\n\\nErrors\\n' + JSON.stringify(err, null, 2));\n\t\t\t\t\terr.message = `${new Date().toISOString()} - Error in Cron Method Check (${method}): ${err.message}`;\n\n\t\t\t\t\tthrow err;\n\t\t\t\t}\n\t\t\t}\n\t\t}\n\n\t\tlet monitor = this._monitorManagerFunction.startMonitorFunction('Cron Method', method, '', '', methodData);\n\n\t\ttry {\n\t\t\tlet res = await this._methods[method].function.call(Object.assign({}, this, MethodManager.prototype, {id_user: '', user: '', id_ws: ''}), ...methodData);\n\t\t\treturn res;\n\t\t}\n\t\tcatch (err) {\n\t\t\tawait this.sendEmail('dev@resolveio.com', 'SERVER - Error Detected - ' + ResolveIOServer.getServerConfig()['CLIENT_NAME'], 'Error Detected During Cron Method ' + method + ' - (callMethodCron)\\n\\nData \\n' + JSON.stringify(methodData, null, 2) + '\\n\\nErrors\\n' + JSON.stringify(err, null, 2));\n\t\t\t\n\t\t\terr.message = `${new Date().toISOString()} - Error in Cron Method (${method}): ${err.message}`;\n\t\t\t\n\t\t\tthrow err;\n\t\t}\n\t\tfinally {\n\t\t\tawait this._monitorManagerFunction.finishMonitorFunction(monitor);\n\t\t}\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\tlet 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\tif ((methodData.length > 1 || (methodData[0] && typeof methodData[0] !== 'function')) && !method.skipValidation) {\n\t\t\tif (!method.check) {\n\t\t\t\tconsole.error(new Date(), 'No Check Function For Method ' + methodName);\n\t\t\t\tthrow new Error(`No Check Function For Method: ${methodName}`);\n\t\t\t}\n\t\t\telse if (!method.check._schema) {\n\t\t\t\tconsole.error(new Date(), 'No Check Schema For Method ' + methodName);\n\t\t\t\tthrow new Error(`No Check Schema For Method: ${methodName}`);\n\t\t\t}\n\t\t}\n\n\t\tif (methodName !== 'insertSubscriptionLog' && methodName !== 'getDataURIfromURL' && methodName !== 'processAirdropDistribution' && methodName !== 'incCounter' && methodName !== 'supportCreateBillingUser' && methodName !== 'countCollectionWithQuery') {\n\t\t\tif (\n\t\t\t\tResolveIOServer.getServerConfig()['ROOT_URL'] !== 'https://resolveio.com'\n\t\t\t&& ResolveIOServer.getServerConfig()['ROOT_URL'] !== 'http://localhost:4200'\n\t\t\t) {\n\t\t\t\tResolveIOServer.getLocalLogManager().writeLog({\n\t\t\t\t\ttype: 'log',\n\t\t\t\t\tdata: {\n\t\t\t\t\t\t_id: objectIdHexString(),\n\t\t\t\t\t\tcreatedAt: new Date(),\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\tmethodName: 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}\n\t\t\t\t});\n\t\t\t}\n\t\t\telse {\n\t\t\t\tawait Logs.insertOne({\n\t\t\t\t\t_id: objectIdHexString(),\n\t\t\t\t\ttype: 'callMethod',\n\t\t\t\t\tcollection: '',\n\t\t\t\t\tid_document: '',\n\t\t\t\t\tpayload: getBinarySize(JSON.stringify([methodData])) < 1000000 ? JSON.stringify([methodData], null, 2) : 'Too Big',\n\t\t\t\t\tmethod: methodName,\n\t\t\t\t\tid_user: this['id_user'] || '',\n\t\t\t\t\tuser: this['user'] || '',\n\t\t\t\t\tmessageId: 0,\n\t\t\t\t\troute: '',\n\t\t\t\t\tclient: 'ResolveIO',\n\t\t\t\t\tinstance: 'backend.resolveio.com',\n\t\t\t\t\tinstance_index: process.env.NODE_APP_INSTANCE || ''\n\t\t\t\t})\n\t\t\t};\n\t\t}\n\n\t\tlet functionMethodData = typeof(methodData[methodData.length - 1]) === 'function' ? methodData.slice(0, -1) : methodData;\n\n\t\tconst session = ResolveIOServer.getMongoManager().getSession();\n\n\t\tif (!method.bypassSession &&\n\t\t\t!session && \n\t\t\t![\n\t\t\t\t'insertErrorLog', // CIRCULAR LOOP - DO NOT REMOVE\n\t\t\t\t'countWithQuery', // MONGO SESSIONS/TRANSACTIONS DONT WORTH WITH COUNTS\n\t\t\t\t'sendEmail' // ALWAYS SEND SO ALWAYS HAVE RECORD - DONT ROLL BACK - BYPASS SESSION\n\t\t\t].includes(methodName) &&\n\t\t\t!methodName.startsWith('monitor-') &&\n\t\t\t!methodName.startsWith('log')\n\t\t) {\n\t\t\tlet monitor = null;\n\t\t\t\n\t\t\treturn ResolveIOServer.getMongoManager().oneTimeTransaction(async () => {\n\t\t\t\tmonitor = this._monitorManagerFunction.startMonitorFunction('Method', methodName, this['user'] || '', '', functionMethodData);\n\t\t\t\t\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 (methodData[methodData.length - 1] && typeof(methodData[methodData.length - 1]) === 'function') {\n\t\t\t\t\t\tmethodData[methodData.length - 1](null, res);\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') {\n\t\t\t\t\t\tthrow err; // Write error, retry\n\t\t\t\t\t}\n\n\t\t\t\t\tconsole.log(JSON.stringify([new Date(), 'Error Method Manager - Run Method - New Session', methodName, {\n\t\t\t\t\t\tcode: err.code,\n\t\t\t\t\t\tcodeName: err.codeName,\n\t\t\t\t\t\tmessage: err.message,\n\t\t\t\t\t\tstack: err.stack\n\t\t\t\t\t}], null, 2));\n\n\t\t\t\t\tawait this.sendEmail('dev@resolveio.com', 'SERVER - Error Detected - ' + ResolveIOServer.getServerConfig()['CLIENT_NAME'], 'Error Detected During Method ' + methodName + ' - (callMethod)\\n\\nData \\n' + JSON.stringify(methodData, null, 2) + '\\n\\nErrors\\n' + JSON.stringify(err, null, 2));\n\t\t\t\t\terr.message = `${new Date().toISOString()} - Error in Method With Session (${methodName}) - New Session: ${err.message}`;\n\n\t\t\t\t\tif (methodData[methodData.length - 1] && typeof(methodData[methodData.length - 1]) === 'function') {\n\t\t\t\t\t\tmethodData[methodData.length - 1](err, null);\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('insertErrorLog', `Error in Method: ${methodName} - ${JSON.stringify(methodData, null, 2)}`);\n\t\t\t\t\t}\n\n\t\t\t\t\tthrow err;\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\t\t}\n\t\telse {\n\t\t\tlet monitor = this._monitorManagerFunction.startMonitorFunction('Method', methodName, this['user'] || '', '', functionMethodData);\n\t\t\t\n\t\t\ttry {\n\t\t\t\tlet res = await method.function.call(Object.assign({}, this, MethodManager.prototype), ...functionMethodData);\n\n\t\t\t\tif (methodData[methodData.length - 1] && typeof(methodData[methodData.length - 1]) === 'function') {\n\t\t\t\t\tmethodData[methodData.length - 1](null, res);\n\t\t\t\t}\n\n\t\t\t\treturn res;\n\t\t\t}\n\t\t\tcatch (err) {\n\t\t\t\tif (err.code === 112 || err.codeName === 'WriteConflict') {\n\t\t\t\t\tthrow err; // Write error, retry\n\t\t\t\t}\n\n\t\t\t\tconsole.log(JSON.stringify([new Date(), 'Error Method Manager - Run Method - Existing Session', methodName, {\n\t\t\t\t\tcode: err.code,\n\t\t\t\t\tcodeName: err.codeName,\n\t\t\t\t\tmessage: err.message,\n\t\t\t\t\tstack: err.stack\n\t\t\t\t}], null, 2));\n\n\t\t\t\tawait this.sendEmail('dev@resolveio.com', 'SERVER - Error Detected - ' + ResolveIOServer.getServerConfig()['CLIENT_NAME'], 'Error Detected During Method ' + methodName + ' - (callMethod)\\n\\nData \\n' + JSON.stringify(methodData, null, 2) + '\\n\\nErrors\\n' + JSON.stringify(err, null, 2));\n\t\t\t\terr.message = `${new Date().toISOString()} - Error in Method (${methodName}) - Existing Session: ${err.message}`;\n\t\t\t\t\n\t\t\t\tif (methodData[methodData.length - 1] && typeof(methodData[methodData.length - 1]) === 'function') {\n\t\t\t\t\tmethodData[methodData.length - 1](err, null);\n\t\t\t\t}\n\n\t\t\t\tif (!process.env.IS_WORKER_INSTANCE) {\n\t\t\t\t\tawait this.callMethod('insertErrorLog', `Error in Method: ${methodName} - ${JSON.stringify(methodData, null, 2)}`);\n\t\t\t\t}\n\t\t\t\t\n\t\t\t\tthrow err;\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\t}\n\n\tasync setupEmailWatcher() {\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', async () => {\n\t\t\tawait this.setupEmailWatcher();\n\t\t});\n\n\t\tawait this.loadPendingEmails();\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 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\t\t\t\tif (emailHistory.attachments && emailHistory.attachments.length > 0) {\n\t\t\t\t\ttry {\n\t\t\t\t\t\tfor (let att of emailHistory.attachments) {\n\t\t\t\t\t\t\tif (att.path && att.path.startsWith('http')) {\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\tthrow new Error(`Failed to fetch attachment: ${att.path}`);\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\t\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}\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 (err) {\n\t\t\t\t\t\tconsole.error('Failed to fetch attachment:', err);\n\t\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 err === 'string' ? err : this.safeStringify(err),\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\t// Skip to the next email\n\t\t\t\t\t\tcontinue;\n\t\t\t\t\t}\n\t\t\t\t}\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};\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\tthis._mailer.sendMail(mailOptions, async err => {\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});\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\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\tpublic async sendEmail(\n\t\tsendTo: string,\n\t\tsubject: string,\n\t\ttext?: string,\n\t\thtml?: string,\n\t\tattachments?: any[],\n\t\tsend_from?: string,\n\t\treply_to?: string,\n\t\tlocal_override = false\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\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\tif (!attachments) {\n\t\t\t\t\tattachments = [];\n\t\t\t\t}\n\n\t\t\t\tif (!Array.isArray(attachments)) {\n\t\t\t\t\tattachments = [attachments];\n\t\t\t\t}\n\n\t\t\t\t// Process attachments before saving\n\t\t\t\tattachments = attachments.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\t// Queue the email in MongoDB\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: subject || '',\n\t\t\t\t\ttext: text || '',\n\t\t\t\t\thtml: html || '',\n\t\t\t\t\tattachments: attachments || [],\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};\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\tsubject,\n\t\t\t\t\ttext,\n\t\t\t\t\thtml,\n\t\t\t\t\tattachments,\n\t\t\t\t\tsend_from\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}"]}
package/methods/pdf.js CHANGED
@@ -1,2 +1,2 @@
1
- "use strict";var __awaiter=this&&this.__awaiter||function(t,a,r,i){return new(r=r||Promise)(function(n,e){function fulfilled(t){try{step(i.next(t))}catch(t){e(t)}}function rejected(t){try{step(i.throw(t))}catch(t){e(t)}}function step(t){var e;t.done?n(t.value):((e=t.value)instanceof r?e:new r(function(t){t(e)})).then(fulfilled,rejected)}step((i=i.apply(t,a||[])).next())})},__generator=this&&this.__generator||function(a,r){var i,s,o,l={label:0,sent:function(){if(1&o[0])throw o[1];return o[1]},trys:[],ops:[]},f={next:verb(0),throw:verb(1),return:verb(2)};return"function"==typeof Symbol&&(f[Symbol.iterator]=function(){return this}),f;function verb(n){return function(t){var e=[n,t];if(i)throw new TypeError("Generator is already executing.");for(;l=f&&e[f=0]?0:l;)try{if(i=1,s&&(o=2&e[0]?s.return:e[0]?s.throw||((o=s.return)&&o.call(s),0):s.next)&&!(o=o.call(s,e[1])).done)return o;switch(s=0,(e=o?[2&e[0],o.value]:e)[0]){case 0:case 1:o=e;break;case 4:return l.label++,{value:e[1],done:!1};case 5:l.label++,s=e[1],e=[0];continue;case 7:e=l.ops.pop(),l.trys.pop();continue;default:if(!(o=0<(o=l.trys).length&&o[o.length-1])&&(6===e[0]||2===e[0])){l=0;continue}if(3===e[0]&&(!o||e[1]>o[0]&&e[1]<o[3]))l.label=e[1];else if(6===e[0]&&l.label<o[1])l.label=o[1],o=e;else{if(!(o&&l.label<o[2])){o[2]&&l.ops.pop(),l.trys.pop();continue}l.label=o[2],l.ops.push(e)}}e=r.call(a,l)}catch(t){e=[6,t],s=0}finally{i=o=0}if(5&e[0])throw e[1];return{value:e[0]?e[1]:void 0,done:!0}}}},fs=(Object.defineProperty(exports,"__esModule",{value:!0}),exports.loadPDFMethods=void 0,require("fs")),path=require("path"),pdf_lib_1=require("pdf-lib"),puppeteer=require("puppeteer"),simpl_schema_1=require("simpl-schema"),flag_collection_1=require("../collections/flag.collection"),pdfCnt=0;function loadPDFMethods(t){t.methods({generatePDF:{check:new simpl_schema_1.default({html:{type:String},fileName:{type:String},orientation:{type:String,optional:!0},fontSize:{type:String,optional:!0},upload:{type:Boolean,optional:!0},uploadFileOrder:{type:Number,optional:!0},uploadFileType:{type:String,optional:!0}}),function:function(p,g,u,h,b,w,m){return void 0===u&&(u="portrait"),void 0===h&&(h="12px"),void 0===b&&(b=!1),void 0===w&&(w=-1),void 0===m&&(m=""),__awaiter(this,void 0,void 0,function(){var e,n,a,r,i,s,o,l,f,c,d;return __generator(this,function(t){switch(t.label){case 0:return e=["--disable-dev-shm-usage","--no-sandbox","--disable-setuid-sandbox","--disable-accelerated-2d-canvas","--disable-gpu","--allow-file-access-from-files","--enable-local-file-accesses","--font-render-hinting=none"],n=null,[4,flag_collection_1.Flags.findOne({type:"Enable Debug PDF"})];case 1:return(a=t.sent())&&a.value?[4,puppeteer.launch({headless:!1,devtools:!0,args:e,ignoreDefaultArgs:["--disable-extensions"]})]:[3,3];case 2:return n=t.sent(),[3,5];case 3:return[4,puppeteer.launch({headless:!0,devtools:!1,args:e,ignoreDefaultArgs:["--disable-extensions"]})];case 4:n=t.sent(),t.label=5;case 5:return[4,n.newPage()];case 6:return r=t.sent(),o="",o=fs.existsSync(path.join(__dirname,"../private/fonts/dejavuserif.woff"))?path.join(__dirname,"../private/fonts/"):fs.existsSync(path.join(this.clientDir,"./private/fonts/dejavuserif.woff"))?path.join(this.clientDir,"./private/fonts/"):"/usr/share/fonts/dejavu/",l="data:application/font-woff;base64,"+Buffer.from(fs.readFileSync(o+"dejavuserif.woff").buffer).toString("base64"),i="data:application/font-woff;base64,"+Buffer.from(fs.readFileSync(o+"dejavuserif-bold.woff").buffer).toString("base64"),s="data:application/font-woff;base64,"+Buffer.from(fs.readFileSync(o+"dejavuserif-italic.woff").buffer).toString("base64"),o="data:application/font-woff;base64,"+Buffer.from(fs.readFileSync(o+"dejavuserif-bolditalic.woff").buffer).toString("base64"),l='\n\t\t\t\t\t<head>\n\t\t\t\t\t\t<style type="text/css">\n\t\t\t\t\t\t\t@font-face {\n\t\t\t\t\t\t\t\tfont-family: \'Dejavu Serif\';\n\t\t\t\t\t\t\t\tfont-style: normal;\n\t\t\t\t\t\t\t\tfont-weight: normal;\n\t\t\t\t\t\t\t\tsrc: url("'+l+"\") format('woff');\n\t\t\t\t\t\t\t}\n\n\t\t\t\t\t\t\t@font-face {\n\t\t\t\t\t\t\t\tfont-family: 'Dejavu Serif';\n\t\t\t\t\t\t\t\tfont-style: normal;\n\t\t\t\t\t\t\t\tfont-weight: bold;\n\t\t\t\t\t\t\t\tsrc: url(\""+i+"\") format('woff');\n\t\t\t\t\t\t\t}\n\n\t\t\t\t\t\t\t@font-face {\n\t\t\t\t\t\t\t\tfont-family: 'Dejavu Serif';\n\t\t\t\t\t\t\t\tfont-style: italic;\n\t\t\t\t\t\t\t\tfont-weight: normal;\n\t\t\t\t\t\t\t\tsrc: url(\""+s+"\") format('woff');\n\t\t\t\t\t\t\t}\n\n\t\t\t\t\t\t\t@font-face {\n\t\t\t\t\t\t\t\tfont-family: 'Dejavu Serif';\n\t\t\t\t\t\t\t\tfont-style: italic;\n\t\t\t\t\t\t\t\tfont-weight: bold;\n\t\t\t\t\t\t\t\tsrc: url(\""+o+"\") format('woff');\n\t\t\t\t\t\t\t}\n\t\t\t\t\t\t\t\n\t\t\t\t\t\t\tbody {\n\t\t\t\t\t\t\t\tfont-family: 'Dejavu Serif', serif;\n\t\t\t\t\t\t\t\tfont-size: "+(h||"12px")+";\n\t\t\t\t\t\t\t}\n\n\t\t\t\t\t\t\t.row {\n\t\t\t\t\t\t\t\tdisplay: -webkit-flex;\n\t\t\t\t\t\t\t\tdisplay: flex;\n\t\t\t\t\t\t\t\tflex-wrap: wrap;\n\t\t\t\t\t\t\t\t-webkit-flex-wrap: wrap;\n\t\t\t\t\t\t\t\tpage-break-inside: avoid !important;\n\t\t\t\t\t\t\t}\n\n\t\t\t\t\t\t\t.page-break {\n\t\t\t\t\t\t\t\tpage-break-before: always !important;\n\t\t\t\t\t\t\t\tpadding-top: 1px;\n\t\t\t\t\t\t\t}\n\n\t\t\t\t\t\t\t.cell {\n\t\t\t\t\t\t\t\tbox-sizing: border-box;\n\t\t\t\t\t\t\t\tpadding : 2px;\n\t\t\t\t\t\t\t\t-webkit-flex: 1;\n\t\t\t\t\t\t\t\tword-wrap: break-word;\n\t\t\t\t\t\t\t}\n\n\t\t\t\t\t\t\t.cell-no-padding {\n\t\t\t\t\t\t\t\tbox-sizing: border-box;\n\t\t\t\t\t\t\t\t-webkit-flex: 1;\n\t\t\t\t\t\t\t\tword-wrap: break-word;\n\t\t\t\t\t\t\t}\n\n\t\t\t\t\t\t\t.centered {\n\t\t\t\t\t\t\t\t-webkit-justify-content: center;\n\t\t\t\t\t\t\t\t-webkit-align-items: center;\n\t\t\t\t\t\t\t\tdisplay: -webkit-flex;\n\t\t\t\t\t\t\t\ttext-align: center;\n\t\t\t\t\t\t\t}\n\n\t\t\t\t\t\t\t.centered-left {\n\t\t\t\t\t\t\t\t-webkit-align-items: center;\n\t\t\t\t\t\t\t\tdisplay: -webkit-flex;\n\t\t\t\t\t\t\t\t-webkit-justify-content: flex-start;\n\t\t\t\t\t\t\t}\n\n\t\t\t\t\t\t\t.centered-right {\n\t\t\t\t\t\t\t\t-webkit-justify-content: flex-end;\n\t\t\t\t\t\t\t\t-webkit-align-items: center;\n\t\t\t\t\t\t\t\tdisplay: -webkit-flex;\n\t\t\t\t\t\t\t}\n\t\t\t\t\t\t\t\n\t\t\t\t\t\t\t.box {\n\t\t\t\t\t\t\t\tborder: 1px solid black;\n\t\t\t\t\t\t\t\tmargin: -1px 0px 0px -1px;\n\t\t\t\t\t\t\t}\n\n\t\t\t\t\t\t\t.boxNoBorder {\n\t\t\t\t\t\t\t\tmargin: -1px 0px 0px -1px;\n\t\t\t\t\t\t\t}\n\n\t\t\t\t\t\t\tpre {\n\t\t\t\t\t\t\t\twhite-space: pre-wrap; /* css-3 */\n\t\t\t\t\t\t\t\twhite-space: -moz-pre-wrap; /* Mozilla, since 1999 */\n\t\t\t\t\t\t\t\twhite-space: -pre-wrap; /* Opera 4-6 */\n\t\t\t\t\t\t\t\twhite-space: -o-pre-wrap; /* Opera 7 */\n\t\t\t\t\t\t\t\tword-wrap: break-word; /* Internet Explorer 5.5+ */\n\t\t\t\t\t\t\t\tfont-size: 12px;\n\t\t\t\t\t\t\t\tfont-family: 'Dejavu Serif'; \n\t\t\t\t\t\t\t}\n\t\t\t\t\t\t</style>\n\t\t\t\t\t</head>\n\t\t\t\t\t<body>\n\t\t\t\t"+p.replace(new RegExp("flex-basis:","g"),"-webkit-flex-basis:").replace(new RegExp("flex:","g"),"-webkit-flex:")+"</body>",[4,r.setContent(l,{waitUntil:["domcontentloaded","load","networkidle0"]})];case 7:return t.sent(),[4,r.evaluateHandle("document.fonts.ready")];case 8:return t.sent(),f=pdfCnt+++"-"+g.replace(new RegExp(/[^0-9\.a-zA-Z]/g),""),[4,r.pdf({scale:1,landscape:"portrait"!==u,format:"letter",margin:{top:"1cm",bottom:"1cm",left:"1cm",right:"1cm"},printBackground:!0,displayHeaderFooter:!0,headerTemplate:"\n\t\t\t\t\t\t<style>\n\t\t\t\t\t\t\t#header { \n\t\t\t\t\t\t\t\tpadding: 0 0 10px 10px !important; \n\t\t\t\t\t\t\t}\n\t\t\t\t\t\t</style>\n\t\t\t\t\t\t<span></span>\n\t\t\t\t\t",footerTemplate:'\n\t\t\t\t\t\t<style>\n\t\t\t\t\t\t\t#footer { \n\t\t\t\t\t\t\t\tpadding: 0 0 10px 10px !important;\n\t\t\t\t\t\t\t\tfont-size: 10px;\n\t\t\t\t\t\t\t\tfont-family: san-serif;\n\t\t\t\t\t\t\t}\n\t\t\t\t\t\t</style>\n\t\t\t\t\t\t<div style="padding-bottom: 2px; padding-right: 15px; text-align: right; width: 100%;">\n\t\t\t\t\t\t\tPage&nbsp;<span class="pageNumber"></span>&nbsp;of&nbsp;<span class="totalPages"></span>\n\t\t\t\t\t\t</div>\n\t\t\t\t\t',path:path.join(__dirname,f),timeout:0})];case 9:return(t.sent(),a&&a.value)?"landscape"!==u?[3,11]:[4,r.setViewport({width:1100,height:850})]:[3,13];case 10:return t.sent(),[3,13];case 11:return[4,r.setViewport({width:850,height:1100})];case 12:t.sent(),t.label=13;case 13:return[4,n.close()];case 14:if(t.sent(),!fs.existsSync(path.join(__dirname,f)))throw console.log("No tmp file ",f),new Error("Error in Generate PDF: No tmp file");try{return c=fs.readFileSync(path.join(__dirname,f)),fs.unlinkSync(path.join(__dirname,f)),b?(d="data:application/pdf;base64,"+Buffer.from(c).toString("base64"),[2,this.callMethod("uploadFileAndSave",g,d,4*Math.ceil(d.length/3),null!==w?w:-1,m,!1)]):[2,"data:application/pdf;base64,"+Buffer.from(c).toString("base64")]}catch(t){throw t.message="Error in Generate PDF: No file - "+t.message,t}return[2]}})})},workerTaskWeight:2},generatePDFNoPageNumber:{check:new simpl_schema_1.default({html:{type:String},fileName:{type:String},orientation:{type:String,optional:!0},fontSize:{type:String,optional:!0},upload:{type:Boolean,optional:!0},uploadFileOrder:{type:Number,optional:!0},uploadFileType:{type:String,optional:!0}}),function:function(d,p,g,u,h,b,w){return void 0===g&&(g="portrait"),void 0===u&&(u="12px"),void 0===h&&(h=!1),void 0===b&&(b=-1),void 0===w&&(w=""),__awaiter(this,void 0,void 0,function(){var e,n,a,r,i,s,o,l,f,c;return __generator(this,function(t){switch(t.label){case 0:return a=["--disable-dev-shm-usage","--no-sandbox","--disable-setuid-sandbox","--disable-accelerated-2d-canvas","--disable-gpu","--allow-file-access-from-files","--enable-local-file-accesses","--font-render-hinting=none"],[4,puppeteer.launch({headless:!0,devtools:!1,args:a,ignoreDefaultArgs:["--disable-extensions"]})];case 1:return[4,(e=t.sent()).newPage()];case 2:return n=t.sent(),a="",a=fs.existsSync(path.join(__dirname,"../private/fonts/dejavuserif.woff"))?path.join(__dirname,"../private/fonts/"):fs.existsSync(path.join(this.clientDir,"./private/fonts/dejavuserif.woff"))?path.join(this.clientDir,"./private/fonts/"):"/usr/share/fonts/dejavu/",o="data:application/font-woff;base64,"+Buffer.from(fs.readFileSync(a+"dejavuserif.woff").buffer).toString("base64"),r="data:application/font-woff;base64,"+Buffer.from(fs.readFileSync(a+"dejavuserif-bold.woff").buffer).toString("base64"),i="data:application/font-woff;base64,"+Buffer.from(fs.readFileSync(a+"dejavuserif-italic.woff").buffer).toString("base64"),s="data:application/font-woff;base64,"+Buffer.from(fs.readFileSync(a+"dejavuserif-bolditalic.woff").buffer).toString("base64"),o='\n\t\t\t\t\t<head>\n\t\t\t\t\t\t<style type="text/css">\n\t\t\t\t\t\t\t@font-face {\n\t\t\t\t\t\t\t\tfont-family: \'Dejavu Serif\';\n\t\t\t\t\t\t\t\tfont-style: normal;\n\t\t\t\t\t\t\t\tfont-weight: normal;\n\t\t\t\t\t\t\t\tsrc: url("'+o+"\") format('woff');\n\t\t\t\t\t\t\t}\n\n\t\t\t\t\t\t\t@font-face {\n\t\t\t\t\t\t\t\tfont-family: 'Dejavu Serif';\n\t\t\t\t\t\t\t\tfont-style: normal;\n\t\t\t\t\t\t\t\tfont-weight: bold;\n\t\t\t\t\t\t\t\tsrc: url(\""+r+"\") format('woff');\n\t\t\t\t\t\t\t}\n\n\t\t\t\t\t\t\t@font-face {\n\t\t\t\t\t\t\t\tfont-family: 'Dejavu Serif';\n\t\t\t\t\t\t\t\tfont-style: italic;\n\t\t\t\t\t\t\t\tfont-weight: normal;\n\t\t\t\t\t\t\t\tsrc: url(\""+i+"\") format('woff');\n\t\t\t\t\t\t\t}\n\n\t\t\t\t\t\t\t@font-face {\n\t\t\t\t\t\t\t\tfont-family: 'Dejavu Serif';\n\t\t\t\t\t\t\t\tfont-style: italic;\n\t\t\t\t\t\t\t\tfont-weight: bold;\n\t\t\t\t\t\t\t\tsrc: url(\""+s+"\") format('woff');\n\t\t\t\t\t\t\t}\n\t\t\t\t\t\t\t\n\t\t\t\t\t\t\tbody {\n\t\t\t\t\t\t\t\tfont-family: 'Dejavu Serif', serif;\n\t\t\t\t\t\t\t\tfont-size: "+(u||"12px")+";\n\t\t\t\t\t\t\t}\n\n\t\t\t\t\t\t\t.row {\n\t\t\t\t\t\t\t\tdisplay: -webkit-flex;\n\t\t\t\t\t\t\t\tdisplay: flex;\n\t\t\t\t\t\t\t\tflex-wrap: wrap;\n\t\t\t\t\t\t\t\t-webkit-flex-wrap: wrap;\n\t\t\t\t\t\t\t\tpage-break-inside: avoid !important;\n\t\t\t\t\t\t\t}\n\n\t\t\t\t\t\t\t.page-break {\n\t\t\t\t\t\t\t\tpage-break-before: always !important;\n\t\t\t\t\t\t\t\tpadding-top: 1px;\n\t\t\t\t\t\t\t}\n\n\t\t\t\t\t\t\t.cell {\n\t\t\t\t\t\t\t\tbox-sizing: border-box;\n\t\t\t\t\t\t\t\tpadding : 2px;\n\t\t\t\t\t\t\t\t-webkit-flex: 1;\n\t\t\t\t\t\t\t\tword-wrap: break-word;\n\t\t\t\t\t\t\t}\n\n\t\t\t\t\t\t\t.cell-no-padding {\n\t\t\t\t\t\t\t\tbox-sizing: border-box;\n\t\t\t\t\t\t\t\t-webkit-flex: 1;\n\t\t\t\t\t\t\t\tword-wrap: break-word;\n\t\t\t\t\t\t\t}\n\n\t\t\t\t\t\t\t.centered {\n\t\t\t\t\t\t\t\t-webkit-justify-content: center;\n\t\t\t\t\t\t\t\t-webkit-align-items: center;\n\t\t\t\t\t\t\t\tdisplay: -webkit-flex;\n\t\t\t\t\t\t\t\ttext-align: center;\n\t\t\t\t\t\t\t}\n\n\t\t\t\t\t\t\t.centered-left {\n\t\t\t\t\t\t\t\t-webkit-align-items: center;\n\t\t\t\t\t\t\t\tdisplay: -webkit-flex;\n\t\t\t\t\t\t\t\t-webkit-justify-content: flex-start;\n\t\t\t\t\t\t\t}\n\n\t\t\t\t\t\t\t.centered-right {\n\t\t\t\t\t\t\t\t-webkit-justify-content: flex-end;\n\t\t\t\t\t\t\t\t-webkit-align-items: center;\n\t\t\t\t\t\t\t\tdisplay: -webkit-flex;\n\t\t\t\t\t\t\t}\n\t\t\t\t\t\t\t\n\t\t\t\t\t\t\t.box {\n\t\t\t\t\t\t\t\tborder: 1px solid black;\n\t\t\t\t\t\t\t\tmargin: -1px 0px 0px -1px;\n\t\t\t\t\t\t\t}\n\n\t\t\t\t\t\t\t.boxNoBorder {\n\t\t\t\t\t\t\t\tmargin: -1px 0px 0px -1px;\n\t\t\t\t\t\t\t}\n\n\t\t\t\t\t\t\tpre {\n\t\t\t\t\t\t\t\twhite-space: pre-wrap; /* css-3 */\n\t\t\t\t\t\t\t\twhite-space: -moz-pre-wrap; /* Mozilla, since 1999 */\n\t\t\t\t\t\t\t\twhite-space: -pre-wrap; /* Opera 4-6 */\n\t\t\t\t\t\t\t\twhite-space: -o-pre-wrap; /* Opera 7 */\n\t\t\t\t\t\t\t\tword-wrap: break-word; /* Internet Explorer 5.5+ */\n\t\t\t\t\t\t\t\tfont-size: 12px;\n\t\t\t\t\t\t\t\tfont-family: 'Dejavu Serif'; \n\t\t\t\t\t\t\t}\n\t\t\t\t\t\t</style>\n\t\t\t\t\t\t<meta charset=\"UTF-8\">\n\t\t\t\t\t</head>\n\t\t\t\t\t<body>\n\t\t\t\t"+d.replace(new RegExp("flex-basis:","g"),"-webkit-flex-basis:").replace(new RegExp("flex:","g"),"-webkit-flex:")+"</body>",[4,n.setContent(o,{waitUntil:["domcontentloaded","load","networkidle0"]})];case 3:return t.sent(),[4,n.evaluateHandle("document.fonts.ready")];case 4:return t.sent(),l=pdfCnt+++"-"+p.replace(new RegExp(/[^0-9\.a-zA-Z]/g),""),[4,n.pdf({scale:1,landscape:"portrait"!==g,format:"letter",margin:{top:"1cm",bottom:"1cm",left:"1cm",right:"1cm"},printBackground:!0,displayHeaderFooter:!0,headerTemplate:"\n\t\t\t\t\t\t<style>\n\t\t\t\t\t\t\t#header { \n\t\t\t\t\t\t\t\tpadding: 0 0 10px 10px !important; \n\t\t\t\t\t\t\t}\n\t\t\t\t\t\t</style>\n\t\t\t\t\t\t<span></span>\n\t\t\t\t\t",footerTemplate:'\n\t\t\t\t\t<style>\n\t\t\t\t\t\t#footer { \n\t\t\t\t\t\t\tpadding: 0 0 10px 10px !important;\n\t\t\t\t\t\t\tfont-size: 10px;\n\t\t\t\t\t\t\tfont-family: san-serif;\n\t\t\t\t\t\t}\n\t\t\t\t\t</style>\n\t\t\t\t\t<div style="padding-bottom: 2px; padding-right: 15px; text-align: right; width: 100%;">\n\t\t\t\t\t\t\n\t\t\t\t\t</div>\n\t\t\t\t\t',path:path.join(__dirname,l),timeout:0})];case 5:return t.sent(),[4,e.close()];case 6:if(t.sent(),!fs.existsSync(path.join(__dirname,l)))throw console.log("No tmp file ",l),new Error("Error in Generate PDF No Page Number: No tmp file");try{return f=fs.readFileSync(path.join(__dirname,l)),fs.unlinkSync(path.join(__dirname,l)),h?(c="data:application/pdf;base64,"+Buffer.from(f).toString("base64"),[2,this.callMethod("uploadFileAndSave",p,c,4*Math.ceil(c.length/3),null!==b?b:-1,w,!1)]):[2,"data:application/pdf;base64,"+Buffer.from(f).toString("base64")]}catch(t){throw t.message="Error in Generate PDF No Page Number: No file - "+t.message,t}return[2]}})})},workerTaskWeight:2},mergePDFResolve:{check:new simpl_schema_1.default({fileKeys:{type:Array},"fileKeys.$":{type:String},fileName:{type:String},fileType:{type:String,optional:!0}}),function:function(g,u,h){return __awaiter(this,void 0,void 0,function(){var e,n,a,r,i,s,o,l,f,c,d,p=this;return __generator(this,function(t){switch(t.label){case 0:return t.trys.push([0,25,,26]),[4,this.callMethod("getSignedUrls",g,900)];case 1:return(c=t.sent())&&c.length?(e=[],c.forEach(function(t){e.push(p.callMethod("getDataURIfromURL",t))}),[4,Promise.all(e)]):[3,24];case 2:return n=t.sent(),[4,pdf_lib_1.PDFDocument.create()];case 3:a=t.sent(),r=0,t.label=4;case 4:if(!(r<n.length))return[3,22];if(!(i=n[r]))return[3,20];t.label=5;case 5:return(t.trys.push([5,18,,19]),i.startsWith("data:application/pdf;base64,"))?[4,pdf_lib_1.PDFDocument.load(i,{updateMetadata:!1,parseSpeed:pdf_lib_1.ParseSpeeds.Fastest,ignoreEncryption:!0})]:[3,8];case 6:return s=t.sent(),[4,a.copyPages(s,s.getPageIndices())];case 7:return t.sent().forEach(function(t){a.addPage(t)}),[3,17];case 8:return i.startsWith("data:image/jpeg;base64,/9j/")||i.startsWith("data:image/png;base64,/9j/")?[4,pdf_lib_1.PDFDocument.create()]:[3,12];case 9:return[4,(s=t.sent()).embedJpg(i)];case 10:return o=t.sent(),l=s.addPage(),f=o.scaleToFit(.75*l.getWidth(),.75*l.getHeight()),l.drawImage(o,{x:l.getWidth()/2-f.width/2,y:l.getHeight()/2-f.height/2,width:f.width,height:f.height}),[4,a.copyPages(s,s.getPageIndices())];case 11:return t.sent().forEach(function(t){a.addPage(t)}),[3,17];case 12:return i.startsWith("data:image/png;base64,iVBOR")?[4,pdf_lib_1.PDFDocument.create()]:[3,16];case 13:return[4,(s=t.sent()).embedPng(i)];case 14:return o=t.sent(),l=s.addPage(),f=o.scaleToFit(.75*l.getWidth(),.75*l.getHeight()),l.drawImage(o,{x:l.getWidth()/2-f.width/2,y:l.getHeight()/2-f.height/2,width:f.width,height:f.height}),[4,a.copyPages(s,s.getPageIndices())];case 15:return t.sent().forEach(function(t){a.addPage(t)}),[3,17];case 16:throw console.log("Error - unsupported!!",i.slice(0,60)),new Error("Error in Merge PDF Resolve: Unsupported document type - "+i.slice(0,60));case 17:return[3,19];case 18:throw c=t.sent(),console.log("Error processing fileData:",i.slice(0,60),c.message),c.message="Error in Merge PDF Resolve: Error processing fileData: ".concat(i.slice(0,60)," - ").concat(c.message),c;case 19:return[3,21];case 20:throw console.log("Error - no filedata!!",i),new Error("Error in Merge PDF Resolve: No File Data");case 21:return r++,[3,4];case 22:return[4,a.save()];case 23:return d=t.sent(),d="data:application/pdf;base64,"+Buffer.from(d).toString("base64"),[2,this.callMethod("uploadFileAndSave",u,d,4*Math.ceil(d.length/3),-1,h,!1)];case 24:return[3,26];case 25:throw(d=t.sent()).message="Error in Merge PDF Resolve: PDF Merge - Get Signed URLs - "+d.message,d;case 26:return[2]}})})},workerTaskWeight:2},mergePDFResolveNoSave:{check:new simpl_schema_1.default({fileKeys:{type:Array},"fileKeys.$":{type:String}}),function:function(g){return __awaiter(this,void 0,void 0,function(){var e,n,a,r,i,s,o,l,f,c,d,p=this;return __generator(this,function(t){switch(t.label){case 0:return t.trys.push([0,26,,27]),[4,this.callMethod("getSignedUrls",g,900)];case 1:return(c=t.sent())&&c.length?(e=[],c.forEach(function(t){e.push(p.callMethod("getDataURIfromURL",t))}),[4,Promise.all(e)]):[3,24];case 2:return n=t.sent(),[4,pdf_lib_1.PDFDocument.create()];case 3:a=t.sent(),r=0,t.label=4;case 4:if(!(r<n.length))return[3,22];if(!(i=n[r]))return[3,20];t.label=5;case 5:return(t.trys.push([5,18,,19]),i.startsWith("data:application/pdf;base64,"))?[4,pdf_lib_1.PDFDocument.load(i,{updateMetadata:!1,parseSpeed:pdf_lib_1.ParseSpeeds.Fastest,ignoreEncryption:!0})]:[3,8];case 6:return s=t.sent(),[4,a.copyPages(s,s.getPageIndices())];case 7:return t.sent().forEach(function(t){a.addPage(t)}),[3,17];case 8:return i.startsWith("data:image/jpeg;base64,/9j/")||i.startsWith("data:image/png;base64,/9j/")?[4,pdf_lib_1.PDFDocument.create()]:[3,12];case 9:return[4,(s=t.sent()).embedJpg(i)];case 10:return o=t.sent(),l=s.addPage(),f=o.scaleToFit(.75*l.getWidth(),.75*l.getHeight()),l.drawImage(o,{x:l.getWidth()/2-f.width/2,y:l.getHeight()/2-f.height/2,width:f.width,height:f.height}),[4,a.copyPages(s,s.getPageIndices())];case 11:return t.sent().forEach(function(t){a.addPage(t)}),[3,17];case 12:return i.startsWith("data:image/png;base64,iVBOR")?[4,pdf_lib_1.PDFDocument.create()]:[3,16];case 13:return[4,(s=t.sent()).embedPng(i)];case 14:return o=t.sent(),l=s.addPage(),f=o.scaleToFit(.75*l.getWidth(),.75*l.getHeight()),l.drawImage(o,{x:l.getWidth()/2-f.width/2,y:l.getHeight()/2-f.height/2,width:f.width,height:f.height}),[4,a.copyPages(s,s.getPageIndices())];case 15:return t.sent().forEach(function(t){a.addPage(t)}),[3,17];case 16:console.log("Error - unsupported!!",i.slice(0,60)),t.label=17;case 17:return[3,19];case 18:return c=t.sent(),console.log("Error processing fileData:",i.slice(0,60),c),[3,19];case 19:return[3,21];case 20:console.log("Error - no filedata!!",i),t.label=21;case 21:return r++,[3,4];case 22:return[4,a.save()];case 23:return d=t.sent(),[2,"data:application/pdf;base64,"+Buffer.from(d).toString("base64")];case 24:throw new Error("Error in Merge PDF Resolve No Save: No signed urls");case 25:return[3,27];case 26:throw(d=t.sent()).message="Error in Merge PDF Resolve: ".concat(d.message),d;case 27:return[2]}})})},workerTaskWeight:2},mergePDFResolveHtml:{check:new simpl_schema_1.default({htmls:{type:Array},"htmls.$":{type:String},fileName:{type:String},fileType:{type:String,optional:!0},save:{type:Boolean,optional:!0}}),function:function(c,d,p,g){return void 0===g&&(g=!0),__awaiter(this,void 0,void 0,function(){var e,n,a,r,i,s,o,l,f;return __generator(this,function(t){switch(t.label){case 0:return[4,pdf_lib_1.PDFDocument.create()];case 1:e=t.sent(),n=0,t.label=2;case 2:if(!(n<c.length))return[3,20];if(!(a=c[n]))return[3,18];t.label=3;case 3:return(t.trys.push([3,16,,17]),a.startsWith("data:application/pdf;base64,"))?[4,pdf_lib_1.PDFDocument.load(a,{updateMetadata:!1,parseSpeed:pdf_lib_1.ParseSpeeds.Fastest,ignoreEncryption:!0})]:[3,6];case 4:return r=t.sent(),[4,e.copyPages(r,r.getPageIndices())];case 5:return t.sent().forEach(function(t){e.addPage(t)}),[3,15];case 6:return a.startsWith("data:image/jpeg;base64,/9j/")||a.startsWith("data:image/png;base64,/9j/")?[4,pdf_lib_1.PDFDocument.create()]:[3,10];case 7:return[4,(r=t.sent()).embedJpg(a)];case 8:return i=t.sent(),s=r.addPage(),o=i.scaleToFit(.75*s.getWidth(),.75*s.getHeight()),s.drawImage(i,{x:s.getWidth()/2-o.width/2,y:s.getHeight()/2-o.height/2,width:o.width,height:o.height}),[4,e.copyPages(r,r.getPageIndices())];case 9:return t.sent().forEach(function(t){e.addPage(t)}),[3,15];case 10:return a.startsWith("data:image/png;base64,iVBOR")?[4,pdf_lib_1.PDFDocument.create()]:[3,14];case 11:return[4,(r=t.sent()).embedPng(a)];case 12:return i=t.sent(),s=r.addPage(),o=i.scaleToFit(.75*s.getWidth(),.75*s.getHeight()),s.drawImage(i,{x:s.getWidth()/2-o.width/2,y:s.getHeight()/2-o.height/2,width:o.width,height:o.height}),[4,e.copyPages(r,r.getPageIndices())];case 13:return t.sent().forEach(function(t){e.addPage(t)}),[3,15];case 14:throw console.log("Error - unsupported!!",a.slice(0,60)),new Error("Error in Merge PDF Resolve HTML: Unsupported file - "+a.slice(0,60));case 15:return[3,17];case 16:throw l=t.sent(),console.log("Error processing fileData:",a.slice(0,60),l),l.message="Error in Merge PDF Resolve HTML: Error processing filedata - ".concat(l.message),l;case 17:return[3,19];case 18:throw console.log("Error - no filedata!!",a),new Error("Error in Merge PDF Resolve HTML: No File data");case 19:return n++,[3,2];case 20:return[4,e.save()];case 21:return l=t.sent(),f="data:application/pdf;base64,"+Buffer.from(l).toString("base64"),g?[2,this.callMethod("uploadFileAndSave",d,f,4*Math.ceil(f.length/3),-1,p,!1)]:[2,f]}})})},workerTaskWeight:2}})}exports.loadPDFMethods=loadPDFMethods;
1
+ "use strict";var __awaiter=this&&this.__awaiter||function(t,a,r,i){return new(r=r||Promise)(function(n,e){function fulfilled(t){try{step(i.next(t))}catch(t){e(t)}}function rejected(t){try{step(i.throw(t))}catch(t){e(t)}}function step(t){var e;t.done?n(t.value):((e=t.value)instanceof r?e:new r(function(t){t(e)})).then(fulfilled,rejected)}step((i=i.apply(t,a||[])).next())})},__generator=this&&this.__generator||function(a,r){var i,o,s,l={label:0,sent:function(){if(1&s[0])throw s[1];return s[1]},trys:[],ops:[]},f={next:verb(0),throw:verb(1),return:verb(2)};return"function"==typeof Symbol&&(f[Symbol.iterator]=function(){return this}),f;function verb(n){return function(t){var e=[n,t];if(i)throw new TypeError("Generator is already executing.");for(;l=f&&e[f=0]?0:l;)try{if(i=1,o&&(s=2&e[0]?o.return:e[0]?o.throw||((s=o.return)&&s.call(o),0):o.next)&&!(s=s.call(o,e[1])).done)return s;switch(o=0,(e=s?[2&e[0],s.value]:e)[0]){case 0:case 1:s=e;break;case 4:return l.label++,{value:e[1],done:!1};case 5:l.label++,o=e[1],e=[0];continue;case 7:e=l.ops.pop(),l.trys.pop();continue;default:if(!(s=0<(s=l.trys).length&&s[s.length-1])&&(6===e[0]||2===e[0])){l=0;continue}if(3===e[0]&&(!s||e[1]>s[0]&&e[1]<s[3]))l.label=e[1];else if(6===e[0]&&l.label<s[1])l.label=s[1],s=e;else{if(!(s&&l.label<s[2])){s[2]&&l.ops.pop(),l.trys.pop();continue}l.label=s[2],l.ops.push(e)}}e=r.call(a,l)}catch(t){e=[6,t],o=0}finally{i=s=0}if(5&e[0])throw e[1];return{value:e[0]?e[1]:void 0,done:!0}}}},fs=(Object.defineProperty(exports,"__esModule",{value:!0}),exports.loadPDFMethods=void 0,require("fs")),path=require("path"),pdf_lib_1=require("pdf-lib"),puppeteer=require("puppeteer"),simpl_schema_1=require("simpl-schema"),flag_collection_1=require("../collections/flag.collection"),common_1=require("../util/common");function loadPDFMethods(t){t.methods({generatePDF:{check:new simpl_schema_1.default({html:{type:String},fileName:{type:String},orientation:{type:String,optional:!0},fontSize:{type:String,optional:!0},upload:{type:Boolean,optional:!0},uploadFileOrder:{type:Number,optional:!0},uploadFileType:{type:String,optional:!0}}),function:function(p,g,u,h,b,m,w){return void 0===u&&(u="portrait"),void 0===h&&(h="12px"),void 0===b&&(b=!1),void 0===m&&(m=-1),void 0===w&&(w=""),__awaiter(this,void 0,void 0,function(){var e,n,a,r,i,o,s,l,f,c,d;return __generator(this,function(t){switch(t.label){case 0:return e=["--disable-dev-shm-usage","--no-sandbox","--disable-setuid-sandbox","--disable-accelerated-2d-canvas","--disable-gpu","--allow-file-access-from-files","--enable-local-file-accesses","--font-render-hinting=none"],n=null,[4,flag_collection_1.Flags.findOne({type:"Enable Debug PDF"})];case 1:return(a=t.sent())&&a.value?[4,puppeteer.launch({headless:!1,devtools:!0,args:e,ignoreDefaultArgs:["--disable-extensions"]})]:[3,3];case 2:return n=t.sent(),[3,5];case 3:return[4,puppeteer.launch({headless:!0,devtools:!1,args:e,ignoreDefaultArgs:["--disable-extensions"]})];case 4:n=t.sent(),t.label=5;case 5:return[4,n.newPage()];case 6:return r=t.sent(),s="",s=fs.existsSync(path.join(__dirname,"../private/fonts/dejavuserif.woff"))?path.join(__dirname,"../private/fonts/"):fs.existsSync(path.join(this.clientDir,"./private/fonts/dejavuserif.woff"))?path.join(this.clientDir,"./private/fonts/"):"/usr/share/fonts/dejavu/",l="data:application/font-woff;base64,"+Buffer.from(fs.readFileSync(s+"dejavuserif.woff").buffer).toString("base64"),i="data:application/font-woff;base64,"+Buffer.from(fs.readFileSync(s+"dejavuserif-bold.woff").buffer).toString("base64"),o="data:application/font-woff;base64,"+Buffer.from(fs.readFileSync(s+"dejavuserif-italic.woff").buffer).toString("base64"),s="data:application/font-woff;base64,"+Buffer.from(fs.readFileSync(s+"dejavuserif-bolditalic.woff").buffer).toString("base64"),l='\n\t\t\t\t\t<head>\n\t\t\t\t\t\t<style type="text/css">\n\t\t\t\t\t\t\t@font-face {\n\t\t\t\t\t\t\t\tfont-family: \'Dejavu Serif\';\n\t\t\t\t\t\t\t\tfont-style: normal;\n\t\t\t\t\t\t\t\tfont-weight: normal;\n\t\t\t\t\t\t\t\tsrc: url("'+l+"\") format('woff');\n\t\t\t\t\t\t\t}\n\n\t\t\t\t\t\t\t@font-face {\n\t\t\t\t\t\t\t\tfont-family: 'Dejavu Serif';\n\t\t\t\t\t\t\t\tfont-style: normal;\n\t\t\t\t\t\t\t\tfont-weight: bold;\n\t\t\t\t\t\t\t\tsrc: url(\""+i+"\") format('woff');\n\t\t\t\t\t\t\t}\n\n\t\t\t\t\t\t\t@font-face {\n\t\t\t\t\t\t\t\tfont-family: 'Dejavu Serif';\n\t\t\t\t\t\t\t\tfont-style: italic;\n\t\t\t\t\t\t\t\tfont-weight: normal;\n\t\t\t\t\t\t\t\tsrc: url(\""+o+"\") format('woff');\n\t\t\t\t\t\t\t}\n\n\t\t\t\t\t\t\t@font-face {\n\t\t\t\t\t\t\t\tfont-family: 'Dejavu Serif';\n\t\t\t\t\t\t\t\tfont-style: italic;\n\t\t\t\t\t\t\t\tfont-weight: bold;\n\t\t\t\t\t\t\t\tsrc: url(\""+s+"\") format('woff');\n\t\t\t\t\t\t\t}\n\t\t\t\t\t\t\t\n\t\t\t\t\t\t\tbody {\n\t\t\t\t\t\t\t\tfont-family: 'Dejavu Serif', serif;\n\t\t\t\t\t\t\t\tfont-size: "+(h||"12px")+";\n\t\t\t\t\t\t\t}\n\n\t\t\t\t\t\t\t.row {\n\t\t\t\t\t\t\t\tdisplay: -webkit-flex;\n\t\t\t\t\t\t\t\tdisplay: flex;\n\t\t\t\t\t\t\t\tflex-wrap: wrap;\n\t\t\t\t\t\t\t\t-webkit-flex-wrap: wrap;\n\t\t\t\t\t\t\t\tpage-break-inside: avoid !important;\n\t\t\t\t\t\t\t}\n\n\t\t\t\t\t\t\t.page-break {\n\t\t\t\t\t\t\t\tpage-break-before: always !important;\n\t\t\t\t\t\t\t\tpadding-top: 1px;\n\t\t\t\t\t\t\t}\n\n\t\t\t\t\t\t\t.cell {\n\t\t\t\t\t\t\t\tbox-sizing: border-box;\n\t\t\t\t\t\t\t\tpadding : 2px;\n\t\t\t\t\t\t\t\t-webkit-flex: 1;\n\t\t\t\t\t\t\t\tword-wrap: break-word;\n\t\t\t\t\t\t\t}\n\n\t\t\t\t\t\t\t.cell-no-padding {\n\t\t\t\t\t\t\t\tbox-sizing: border-box;\n\t\t\t\t\t\t\t\t-webkit-flex: 1;\n\t\t\t\t\t\t\t\tword-wrap: break-word;\n\t\t\t\t\t\t\t}\n\n\t\t\t\t\t\t\t.centered {\n\t\t\t\t\t\t\t\t-webkit-justify-content: center;\n\t\t\t\t\t\t\t\t-webkit-align-items: center;\n\t\t\t\t\t\t\t\tdisplay: -webkit-flex;\n\t\t\t\t\t\t\t\ttext-align: center;\n\t\t\t\t\t\t\t}\n\n\t\t\t\t\t\t\t.centered-left {\n\t\t\t\t\t\t\t\t-webkit-align-items: center;\n\t\t\t\t\t\t\t\tdisplay: -webkit-flex;\n\t\t\t\t\t\t\t\t-webkit-justify-content: flex-start;\n\t\t\t\t\t\t\t}\n\n\t\t\t\t\t\t\t.centered-right {\n\t\t\t\t\t\t\t\t-webkit-justify-content: flex-end;\n\t\t\t\t\t\t\t\t-webkit-align-items: center;\n\t\t\t\t\t\t\t\tdisplay: -webkit-flex;\n\t\t\t\t\t\t\t}\n\t\t\t\t\t\t\t\n\t\t\t\t\t\t\t.box {\n\t\t\t\t\t\t\t\tborder: 1px solid black;\n\t\t\t\t\t\t\t\tmargin: -1px 0px 0px -1px;\n\t\t\t\t\t\t\t}\n\n\t\t\t\t\t\t\t.boxNoBorder {\n\t\t\t\t\t\t\t\tmargin: -1px 0px 0px -1px;\n\t\t\t\t\t\t\t}\n\n\t\t\t\t\t\t\tpre {\n\t\t\t\t\t\t\t\twhite-space: pre-wrap; /* css-3 */\n\t\t\t\t\t\t\t\twhite-space: -moz-pre-wrap; /* Mozilla, since 1999 */\n\t\t\t\t\t\t\t\twhite-space: -pre-wrap; /* Opera 4-6 */\n\t\t\t\t\t\t\t\twhite-space: -o-pre-wrap; /* Opera 7 */\n\t\t\t\t\t\t\t\tword-wrap: break-word; /* Internet Explorer 5.5+ */\n\t\t\t\t\t\t\t\tfont-size: 12px;\n\t\t\t\t\t\t\t\tfont-family: 'Dejavu Serif'; \n\t\t\t\t\t\t\t}\n\t\t\t\t\t\t</style>\n\t\t\t\t\t</head>\n\t\t\t\t\t<body>\n\t\t\t\t"+p.replace(new RegExp("flex-basis:","g"),"-webkit-flex-basis:").replace(new RegExp("flex:","g"),"-webkit-flex:")+"</body>",[4,r.setContent(l,{waitUntil:["domcontentloaded","load","networkidle0"]})];case 7:return t.sent(),[4,r.evaluateHandle("document.fonts.ready")];case 8:return t.sent(),f=(0,common_1.objectIdHexString)()+".pdf",[4,r.pdf({scale:1,landscape:"portrait"!==u,format:"letter",margin:{top:"1cm",bottom:"1cm",left:"1cm",right:"1cm"},printBackground:!0,displayHeaderFooter:!0,headerTemplate:"\n\t\t\t\t\t\t<style>\n\t\t\t\t\t\t\t#header { \n\t\t\t\t\t\t\t\tpadding: 0 0 10px 10px !important; \n\t\t\t\t\t\t\t}\n\t\t\t\t\t\t</style>\n\t\t\t\t\t\t<span></span>\n\t\t\t\t\t",footerTemplate:'\n\t\t\t\t\t\t<style>\n\t\t\t\t\t\t\t#footer { \n\t\t\t\t\t\t\t\tpadding: 0 0 10px 10px !important;\n\t\t\t\t\t\t\t\tfont-size: 10px;\n\t\t\t\t\t\t\t\tfont-family: san-serif;\n\t\t\t\t\t\t\t}\n\t\t\t\t\t\t</style>\n\t\t\t\t\t\t<div style="padding-bottom: 2px; padding-right: 15px; text-align: right; width: 100%;">\n\t\t\t\t\t\t\tPage&nbsp;<span class="pageNumber"></span>&nbsp;of&nbsp;<span class="totalPages"></span>\n\t\t\t\t\t\t</div>\n\t\t\t\t\t',path:path.join(__dirname,f),timeout:0})];case 9:return(t.sent(),a&&a.value)?"landscape"!==u?[3,11]:[4,r.setViewport({width:1100,height:850})]:[3,13];case 10:return t.sent(),[3,13];case 11:return[4,r.setViewport({width:850,height:1100})];case 12:t.sent(),t.label=13;case 13:return[4,n.close()];case 14:if(t.sent(),!fs.existsSync(path.join(__dirname,f)))throw console.log("No tmp file ",f),new Error("Error in Generate PDF: No tmp file");try{return c=fs.readFileSync(path.join(__dirname,f)),fs.unlinkSync(path.join(__dirname,f)),b?(d="data:application/pdf;base64,"+Buffer.from(c).toString("base64"),[2,this.callMethod("uploadFileAndSave",g,d,4*Math.ceil(d.length/3),null!==m?m:-1,w,!1)]):[2,"data:application/pdf;base64,"+Buffer.from(c).toString("base64")]}catch(t){throw t.message="Error in Generate PDF: No file - "+t.message,t}return[2]}})})},workerTaskWeight:2},generatePDFNoPageNumber:{check:new simpl_schema_1.default({html:{type:String},fileName:{type:String},orientation:{type:String,optional:!0},fontSize:{type:String,optional:!0},upload:{type:Boolean,optional:!0},uploadFileOrder:{type:Number,optional:!0},uploadFileType:{type:String,optional:!0}}),function:function(d,p,g,u,h,b,m){return void 0===g&&(g="portrait"),void 0===u&&(u="12px"),void 0===h&&(h=!1),void 0===b&&(b=-1),void 0===m&&(m=""),__awaiter(this,void 0,void 0,function(){var e,n,a,r,i,o,s,l,f,c;return __generator(this,function(t){switch(t.label){case 0:return a=["--disable-dev-shm-usage","--no-sandbox","--disable-setuid-sandbox","--disable-accelerated-2d-canvas","--disable-gpu","--allow-file-access-from-files","--enable-local-file-accesses","--font-render-hinting=none"],[4,puppeteer.launch({headless:!0,devtools:!1,args:a,ignoreDefaultArgs:["--disable-extensions"]})];case 1:return[4,(e=t.sent()).newPage()];case 2:return n=t.sent(),a="",a=fs.existsSync(path.join(__dirname,"../private/fonts/dejavuserif.woff"))?path.join(__dirname,"../private/fonts/"):fs.existsSync(path.join(this.clientDir,"./private/fonts/dejavuserif.woff"))?path.join(this.clientDir,"./private/fonts/"):"/usr/share/fonts/dejavu/",s="data:application/font-woff;base64,"+Buffer.from(fs.readFileSync(a+"dejavuserif.woff").buffer).toString("base64"),r="data:application/font-woff;base64,"+Buffer.from(fs.readFileSync(a+"dejavuserif-bold.woff").buffer).toString("base64"),i="data:application/font-woff;base64,"+Buffer.from(fs.readFileSync(a+"dejavuserif-italic.woff").buffer).toString("base64"),o="data:application/font-woff;base64,"+Buffer.from(fs.readFileSync(a+"dejavuserif-bolditalic.woff").buffer).toString("base64"),s='\n\t\t\t\t\t<head>\n\t\t\t\t\t\t<style type="text/css">\n\t\t\t\t\t\t\t@font-face {\n\t\t\t\t\t\t\t\tfont-family: \'Dejavu Serif\';\n\t\t\t\t\t\t\t\tfont-style: normal;\n\t\t\t\t\t\t\t\tfont-weight: normal;\n\t\t\t\t\t\t\t\tsrc: url("'+s+"\") format('woff');\n\t\t\t\t\t\t\t}\n\n\t\t\t\t\t\t\t@font-face {\n\t\t\t\t\t\t\t\tfont-family: 'Dejavu Serif';\n\t\t\t\t\t\t\t\tfont-style: normal;\n\t\t\t\t\t\t\t\tfont-weight: bold;\n\t\t\t\t\t\t\t\tsrc: url(\""+r+"\") format('woff');\n\t\t\t\t\t\t\t}\n\n\t\t\t\t\t\t\t@font-face {\n\t\t\t\t\t\t\t\tfont-family: 'Dejavu Serif';\n\t\t\t\t\t\t\t\tfont-style: italic;\n\t\t\t\t\t\t\t\tfont-weight: normal;\n\t\t\t\t\t\t\t\tsrc: url(\""+i+"\") format('woff');\n\t\t\t\t\t\t\t}\n\n\t\t\t\t\t\t\t@font-face {\n\t\t\t\t\t\t\t\tfont-family: 'Dejavu Serif';\n\t\t\t\t\t\t\t\tfont-style: italic;\n\t\t\t\t\t\t\t\tfont-weight: bold;\n\t\t\t\t\t\t\t\tsrc: url(\""+o+"\") format('woff');\n\t\t\t\t\t\t\t}\n\t\t\t\t\t\t\t\n\t\t\t\t\t\t\tbody {\n\t\t\t\t\t\t\t\tfont-family: 'Dejavu Serif', serif;\n\t\t\t\t\t\t\t\tfont-size: "+(u||"12px")+";\n\t\t\t\t\t\t\t}\n\n\t\t\t\t\t\t\t.row {\n\t\t\t\t\t\t\t\tdisplay: -webkit-flex;\n\t\t\t\t\t\t\t\tdisplay: flex;\n\t\t\t\t\t\t\t\tflex-wrap: wrap;\n\t\t\t\t\t\t\t\t-webkit-flex-wrap: wrap;\n\t\t\t\t\t\t\t\tpage-break-inside: avoid !important;\n\t\t\t\t\t\t\t}\n\n\t\t\t\t\t\t\t.page-break {\n\t\t\t\t\t\t\t\tpage-break-before: always !important;\n\t\t\t\t\t\t\t\tpadding-top: 1px;\n\t\t\t\t\t\t\t}\n\n\t\t\t\t\t\t\t.cell {\n\t\t\t\t\t\t\t\tbox-sizing: border-box;\n\t\t\t\t\t\t\t\tpadding : 2px;\n\t\t\t\t\t\t\t\t-webkit-flex: 1;\n\t\t\t\t\t\t\t\tword-wrap: break-word;\n\t\t\t\t\t\t\t}\n\n\t\t\t\t\t\t\t.cell-no-padding {\n\t\t\t\t\t\t\t\tbox-sizing: border-box;\n\t\t\t\t\t\t\t\t-webkit-flex: 1;\n\t\t\t\t\t\t\t\tword-wrap: break-word;\n\t\t\t\t\t\t\t}\n\n\t\t\t\t\t\t\t.centered {\n\t\t\t\t\t\t\t\t-webkit-justify-content: center;\n\t\t\t\t\t\t\t\t-webkit-align-items: center;\n\t\t\t\t\t\t\t\tdisplay: -webkit-flex;\n\t\t\t\t\t\t\t\ttext-align: center;\n\t\t\t\t\t\t\t}\n\n\t\t\t\t\t\t\t.centered-left {\n\t\t\t\t\t\t\t\t-webkit-align-items: center;\n\t\t\t\t\t\t\t\tdisplay: -webkit-flex;\n\t\t\t\t\t\t\t\t-webkit-justify-content: flex-start;\n\t\t\t\t\t\t\t}\n\n\t\t\t\t\t\t\t.centered-right {\n\t\t\t\t\t\t\t\t-webkit-justify-content: flex-end;\n\t\t\t\t\t\t\t\t-webkit-align-items: center;\n\t\t\t\t\t\t\t\tdisplay: -webkit-flex;\n\t\t\t\t\t\t\t}\n\t\t\t\t\t\t\t\n\t\t\t\t\t\t\t.box {\n\t\t\t\t\t\t\t\tborder: 1px solid black;\n\t\t\t\t\t\t\t\tmargin: -1px 0px 0px -1px;\n\t\t\t\t\t\t\t}\n\n\t\t\t\t\t\t\t.boxNoBorder {\n\t\t\t\t\t\t\t\tmargin: -1px 0px 0px -1px;\n\t\t\t\t\t\t\t}\n\n\t\t\t\t\t\t\tpre {\n\t\t\t\t\t\t\t\twhite-space: pre-wrap; /* css-3 */\n\t\t\t\t\t\t\t\twhite-space: -moz-pre-wrap; /* Mozilla, since 1999 */\n\t\t\t\t\t\t\t\twhite-space: -pre-wrap; /* Opera 4-6 */\n\t\t\t\t\t\t\t\twhite-space: -o-pre-wrap; /* Opera 7 */\n\t\t\t\t\t\t\t\tword-wrap: break-word; /* Internet Explorer 5.5+ */\n\t\t\t\t\t\t\t\tfont-size: 12px;\n\t\t\t\t\t\t\t\tfont-family: 'Dejavu Serif'; \n\t\t\t\t\t\t\t}\n\t\t\t\t\t\t</style>\n\t\t\t\t\t\t<meta charset=\"UTF-8\">\n\t\t\t\t\t</head>\n\t\t\t\t\t<body>\n\t\t\t\t"+d.replace(new RegExp("flex-basis:","g"),"-webkit-flex-basis:").replace(new RegExp("flex:","g"),"-webkit-flex:")+"</body>",[4,n.setContent(s,{waitUntil:["domcontentloaded","load","networkidle0"]})];case 3:return t.sent(),[4,n.evaluateHandle("document.fonts.ready")];case 4:return t.sent(),l=(0,common_1.objectIdHexString)()+".pdf",[4,n.pdf({scale:1,landscape:"portrait"!==g,format:"letter",margin:{top:"1cm",bottom:"1cm",left:"1cm",right:"1cm"},printBackground:!0,displayHeaderFooter:!0,headerTemplate:"\n\t\t\t\t\t\t<style>\n\t\t\t\t\t\t\t#header { \n\t\t\t\t\t\t\t\tpadding: 0 0 10px 10px !important; \n\t\t\t\t\t\t\t}\n\t\t\t\t\t\t</style>\n\t\t\t\t\t\t<span></span>\n\t\t\t\t\t",footerTemplate:'\n\t\t\t\t\t<style>\n\t\t\t\t\t\t#footer { \n\t\t\t\t\t\t\tpadding: 0 0 10px 10px !important;\n\t\t\t\t\t\t\tfont-size: 10px;\n\t\t\t\t\t\t\tfont-family: san-serif;\n\t\t\t\t\t\t}\n\t\t\t\t\t</style>\n\t\t\t\t\t<div style="padding-bottom: 2px; padding-right: 15px; text-align: right; width: 100%;">\n\t\t\t\t\t\t\n\t\t\t\t\t</div>\n\t\t\t\t\t',path:path.join(__dirname,l),timeout:0})];case 5:return t.sent(),[4,e.close()];case 6:if(t.sent(),!fs.existsSync(path.join(__dirname,l)))throw console.log("No tmp file ",l),new Error("Error in Generate PDF No Page Number: No tmp file");try{return f=fs.readFileSync(path.join(__dirname,l)),fs.unlinkSync(path.join(__dirname,l)),h?(c="data:application/pdf;base64,"+Buffer.from(f).toString("base64"),[2,this.callMethod("uploadFileAndSave",p,c,4*Math.ceil(c.length/3),null!==b?b:-1,m,!1)]):[2,"data:application/pdf;base64,"+Buffer.from(f).toString("base64")]}catch(t){throw t.message="Error in Generate PDF No Page Number: No file - "+t.message,t}return[2]}})})},workerTaskWeight:2},mergePDFResolve:{check:new simpl_schema_1.default({fileKeys:{type:Array},"fileKeys.$":{type:String},fileName:{type:String},fileType:{type:String,optional:!0}}),function:function(g,u,h){return __awaiter(this,void 0,void 0,function(){var e,n,a,r,i,o,s,l,f,c,d,p=this;return __generator(this,function(t){switch(t.label){case 0:return t.trys.push([0,25,,26]),[4,this.callMethod("getSignedUrls",g,900)];case 1:return(c=t.sent())&&c.length?(e=[],c.forEach(function(t){e.push(p.callMethod("getDataURIfromURL",t))}),[4,Promise.all(e)]):[3,24];case 2:return n=t.sent(),[4,pdf_lib_1.PDFDocument.create()];case 3:a=t.sent(),r=0,t.label=4;case 4:if(!(r<n.length))return[3,22];if(!(i=n[r]))return[3,20];t.label=5;case 5:return(t.trys.push([5,18,,19]),i.startsWith("data:application/pdf;base64,"))?[4,pdf_lib_1.PDFDocument.load(i,{updateMetadata:!1,parseSpeed:pdf_lib_1.ParseSpeeds.Fastest,ignoreEncryption:!0})]:[3,8];case 6:return o=t.sent(),[4,a.copyPages(o,o.getPageIndices())];case 7:return t.sent().forEach(function(t){a.addPage(t)}),[3,17];case 8:return i.startsWith("data:image/jpeg;base64,/9j/")||i.startsWith("data:image/png;base64,/9j/")?[4,pdf_lib_1.PDFDocument.create()]:[3,12];case 9:return[4,(o=t.sent()).embedJpg(i)];case 10:return s=t.sent(),l=o.addPage(),f=s.scaleToFit(.75*l.getWidth(),.75*l.getHeight()),l.drawImage(s,{x:l.getWidth()/2-f.width/2,y:l.getHeight()/2-f.height/2,width:f.width,height:f.height}),[4,a.copyPages(o,o.getPageIndices())];case 11:return t.sent().forEach(function(t){a.addPage(t)}),[3,17];case 12:return i.startsWith("data:image/png;base64,iVBOR")?[4,pdf_lib_1.PDFDocument.create()]:[3,16];case 13:return[4,(o=t.sent()).embedPng(i)];case 14:return s=t.sent(),l=o.addPage(),f=s.scaleToFit(.75*l.getWidth(),.75*l.getHeight()),l.drawImage(s,{x:l.getWidth()/2-f.width/2,y:l.getHeight()/2-f.height/2,width:f.width,height:f.height}),[4,a.copyPages(o,o.getPageIndices())];case 15:return t.sent().forEach(function(t){a.addPage(t)}),[3,17];case 16:throw console.log("Error - unsupported!!",i.slice(0,60)),new Error("Error in Merge PDF Resolve: Unsupported document type - "+i.slice(0,60));case 17:return[3,19];case 18:throw c=t.sent(),console.log("Error processing fileData:",i.slice(0,60),c.message),c.message="Error in Merge PDF Resolve: Error processing fileData: ".concat(i.slice(0,60)," - ").concat(c.message),c;case 19:return[3,21];case 20:throw console.log("Error - no filedata!!",i),new Error("Error in Merge PDF Resolve: No File Data");case 21:return r++,[3,4];case 22:return[4,a.save()];case 23:return d=t.sent(),d="data:application/pdf;base64,"+Buffer.from(d).toString("base64"),[2,this.callMethod("uploadFileAndSave",u,d,4*Math.ceil(d.length/3),-1,h,!1)];case 24:return[3,26];case 25:throw(d=t.sent()).message="Error in Merge PDF Resolve: PDF Merge - Get Signed URLs - "+d.message,d;case 26:return[2]}})})},workerTaskWeight:2},mergePDFResolveNoSave:{check:new simpl_schema_1.default({fileKeys:{type:Array},"fileKeys.$":{type:String}}),function:function(g){return __awaiter(this,void 0,void 0,function(){var e,n,a,r,i,o,s,l,f,c,d,p=this;return __generator(this,function(t){switch(t.label){case 0:return t.trys.push([0,26,,27]),[4,this.callMethod("getSignedUrls",g,900)];case 1:return(c=t.sent())&&c.length?(e=[],c.forEach(function(t){e.push(p.callMethod("getDataURIfromURL",t))}),[4,Promise.all(e)]):[3,24];case 2:return n=t.sent(),[4,pdf_lib_1.PDFDocument.create()];case 3:a=t.sent(),r=0,t.label=4;case 4:if(!(r<n.length))return[3,22];if(!(i=n[r]))return[3,20];t.label=5;case 5:return(t.trys.push([5,18,,19]),i.startsWith("data:application/pdf;base64,"))?[4,pdf_lib_1.PDFDocument.load(i,{updateMetadata:!1,parseSpeed:pdf_lib_1.ParseSpeeds.Fastest,ignoreEncryption:!0})]:[3,8];case 6:return o=t.sent(),[4,a.copyPages(o,o.getPageIndices())];case 7:return t.sent().forEach(function(t){a.addPage(t)}),[3,17];case 8:return i.startsWith("data:image/jpeg;base64,/9j/")||i.startsWith("data:image/png;base64,/9j/")?[4,pdf_lib_1.PDFDocument.create()]:[3,12];case 9:return[4,(o=t.sent()).embedJpg(i)];case 10:return s=t.sent(),l=o.addPage(),f=s.scaleToFit(.75*l.getWidth(),.75*l.getHeight()),l.drawImage(s,{x:l.getWidth()/2-f.width/2,y:l.getHeight()/2-f.height/2,width:f.width,height:f.height}),[4,a.copyPages(o,o.getPageIndices())];case 11:return t.sent().forEach(function(t){a.addPage(t)}),[3,17];case 12:return i.startsWith("data:image/png;base64,iVBOR")?[4,pdf_lib_1.PDFDocument.create()]:[3,16];case 13:return[4,(o=t.sent()).embedPng(i)];case 14:return s=t.sent(),l=o.addPage(),f=s.scaleToFit(.75*l.getWidth(),.75*l.getHeight()),l.drawImage(s,{x:l.getWidth()/2-f.width/2,y:l.getHeight()/2-f.height/2,width:f.width,height:f.height}),[4,a.copyPages(o,o.getPageIndices())];case 15:return t.sent().forEach(function(t){a.addPage(t)}),[3,17];case 16:console.log("Error - unsupported!!",i.slice(0,60)),t.label=17;case 17:return[3,19];case 18:return c=t.sent(),console.log("Error processing fileData:",i.slice(0,60),c),[3,19];case 19:return[3,21];case 20:console.log("Error - no filedata!!",i),t.label=21;case 21:return r++,[3,4];case 22:return[4,a.save()];case 23:return d=t.sent(),[2,"data:application/pdf;base64,"+Buffer.from(d).toString("base64")];case 24:throw new Error("Error in Merge PDF Resolve No Save: No signed urls");case 25:return[3,27];case 26:throw(d=t.sent()).message="Error in Merge PDF Resolve: ".concat(d.message),d;case 27:return[2]}})})},workerTaskWeight:2},mergePDFResolveHtml:{check:new simpl_schema_1.default({htmls:{type:Array},"htmls.$":{type:String},fileName:{type:String},fileType:{type:String,optional:!0},save:{type:Boolean,optional:!0}}),function:function(c,d,p,g){return void 0===g&&(g=!0),__awaiter(this,void 0,void 0,function(){var e,n,a,r,i,o,s,l,f;return __generator(this,function(t){switch(t.label){case 0:return[4,pdf_lib_1.PDFDocument.create()];case 1:e=t.sent(),n=0,t.label=2;case 2:if(!(n<c.length))return[3,20];if(!(a=c[n]))return[3,18];t.label=3;case 3:return(t.trys.push([3,16,,17]),a.startsWith("data:application/pdf;base64,"))?[4,pdf_lib_1.PDFDocument.load(a,{updateMetadata:!1,parseSpeed:pdf_lib_1.ParseSpeeds.Fastest,ignoreEncryption:!0})]:[3,6];case 4:return r=t.sent(),[4,e.copyPages(r,r.getPageIndices())];case 5:return t.sent().forEach(function(t){e.addPage(t)}),[3,15];case 6:return a.startsWith("data:image/jpeg;base64,/9j/")||a.startsWith("data:image/png;base64,/9j/")?[4,pdf_lib_1.PDFDocument.create()]:[3,10];case 7:return[4,(r=t.sent()).embedJpg(a)];case 8:return i=t.sent(),o=r.addPage(),s=i.scaleToFit(.75*o.getWidth(),.75*o.getHeight()),o.drawImage(i,{x:o.getWidth()/2-s.width/2,y:o.getHeight()/2-s.height/2,width:s.width,height:s.height}),[4,e.copyPages(r,r.getPageIndices())];case 9:return t.sent().forEach(function(t){e.addPage(t)}),[3,15];case 10:return a.startsWith("data:image/png;base64,iVBOR")?[4,pdf_lib_1.PDFDocument.create()]:[3,14];case 11:return[4,(r=t.sent()).embedPng(a)];case 12:return i=t.sent(),o=r.addPage(),s=i.scaleToFit(.75*o.getWidth(),.75*o.getHeight()),o.drawImage(i,{x:o.getWidth()/2-s.width/2,y:o.getHeight()/2-s.height/2,width:s.width,height:s.height}),[4,e.copyPages(r,r.getPageIndices())];case 13:return t.sent().forEach(function(t){e.addPage(t)}),[3,15];case 14:throw console.log("Error - unsupported!!",a.slice(0,60)),new Error("Error in Merge PDF Resolve HTML: Unsupported file - "+a.slice(0,60));case 15:return[3,17];case 16:throw l=t.sent(),console.log("Error processing fileData:",a.slice(0,60),l),l.message="Error in Merge PDF Resolve HTML: Error processing filedata - ".concat(l.message),l;case 17:return[3,19];case 18:throw console.log("Error - no filedata!!",a),new Error("Error in Merge PDF Resolve HTML: No File data");case 19:return n++,[3,2];case 20:return[4,e.save()];case 21:return l=t.sent(),f="data:application/pdf;base64,"+Buffer.from(l).toString("base64"),g?[2,this.callMethod("uploadFileAndSave",d,f,4*Math.ceil(f.length/3),-1,p,!1)]:[2,f]}})})},workerTaskWeight:2}})}exports.loadPDFMethods=loadPDFMethods;
2
2
  //# sourceMappingURL=pdf.js.map
@@ -1 +1 @@
1
- {"version":3,"sources":["../../src/methods/pdf.ts"],"names":["fs","require","path","pdf_lib_1","puppeteer","simpl_schema_1","flag_collection_1","pdfCnt","loadPDFMethods","methodManager","methods","generatePDF","check","default","html","type","String","fileName","orientation","optional","fontSize","upload","Boolean","uploadFileOrder","Number","uploadFileType","function","args","browser","Flags","findOne","enableDebugFlag","_a","sent","value","launch","headless","devtools","ignoreDefaultArgs","newPage","page","pathToFont","existsSync","join","__dirname","this","clientDir","dejavuserif_woff","Buffer","from","readFileSync","buffer","toString","dejavuserifBold_woff","dejavuserifItalic_woff","dejavuserifBoldItalic_woff","content","replace","RegExp","setContent","waitUntil","evaluateHandle","tmpFileName","pdf","scale","landscape","format","margin","top","bottom","left","right","printBackground","displayHeaderFooter","headerTemplate","footerTemplate","timeout","setViewport","width","height","close","console","log","Error","data","unlinkSync","fileData","callMethod","Math","ceil","length","errRead","message","workerTaskWeight","generatePDFNoPageNumber","mergePDFResolve","fileKeys","Array","fileKeys.$","fileType","resSigneds","promises_1","forEach","signedUrl","push","_this","Promise","all","fileDatas","PDFDocument","create","mergedPdf_1","i","startsWith","load","updateMetadata","parseSpeed","ParseSpeeds","Fastest","ignoreEncryption","copyPages","getPageIndices","addPage","embedJpg","img","imgDim","scaleToFit","getWidth","getHeight","drawImage","x","y","embedPng","slice","error_1","concat","save","mergedPDFUint8","b64PDF","err_1","mergePDFResolveNoSave","promises_2","mergedPdf_2","error_2","err_2","mergePDFResolveHtml","htmls","htmls.$","mergedPdf","error_3","exports"],"mappings":"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","file":"pdf.js","sourcesContent":["import * as fs from 'fs';\nimport * as path from 'path';\nimport { ParseSpeeds, PDFDocument } from 'pdf-lib';\nimport * as puppeteer from 'puppeteer';\nimport SimpleSchema from 'simpl-schema';\nimport { Flags } from '../collections/flag.collection';\nimport { MethodManager } from '../managers/method.manager';\n\nlet pdfCnt = 0;\n\nexport function loadPDFMethods(methodManager: MethodManager) {\n\tmethodManager.methods({\n\t\tgeneratePDF: {\n\t\t\tcheck: new SimpleSchema({\n\t\t\t\thtml: {\n\t\t\t\t\ttype: String\n\t\t\t\t},\n\t\t\t\tfileName: {\n\t\t\t\t\ttype: String\n\t\t\t\t},\n\t\t\t\torientation: {\n\t\t\t\t\ttype: String,\n\t\t\t\t\toptional: true\n\t\t\t\t},\n\t\t\t\tfontSize: {\n\t\t\t\t\ttype: String,\n\t\t\t\t\toptional: true\n\t\t\t\t},\n\t\t\t\tupload: {\n\t\t\t\t\ttype: Boolean,\n\t\t\t\t\toptional: true\n\t\t\t\t},\n\t\t\t\tuploadFileOrder: {\n\t\t\t\t\ttype: Number,\n\t\t\t\t\toptional: true\n\t\t\t\t},\n\t\t\t\tuploadFileType: {\n\t\t\t\t\ttype: String,\n\t\t\t\t\toptional: true\n\t\t\t\t}\n\t\t\t}),\n\t\t\tfunction: async function(html, fileName, orientation = 'portrait', fontSize = '12px', upload = false, uploadFileOrder = -1, uploadFileType = '') {\n\t\t\t\t// console.log(new Date(), 'GENERATE PDF CALL', fileName, orientation, fontSize, upload);\n\n\t\t\t\tconst args = [\n\t\t\t\t\t\"--disable-dev-shm-usage\",\n\t\t\t\t\t\"--no-sandbox\",\n\t\t\t\t\t\"--disable-setuid-sandbox\",\n\t\t\t\t\t\"--disable-accelerated-2d-canvas\",\n\t\t\t\t\t\"--disable-gpu\",\n\t\t\t\t\t\"--allow-file-access-from-files\", \n\t\t\t\t\t\"--enable-local-file-accesses\",\n\t\t\t\t\t'--font-render-hinting=none'\n\t\t\t\t];\n\n\t\t\t\tlet browser = null;\n\n\t\t\t\tlet enableDebugFlag = await Flags.findOne({type: 'Enable Debug PDF'});\n\t\t\t\t\n\t\t\t\tif (enableDebugFlag && enableDebugFlag.value) {\n\t\t\t\t\tbrowser = await puppeteer.launch({\n\t\t\t\t\t\theadless: false, // run in headless mode\n\t\t\t\t\t\tdevtools: true, // run with dev tools\n\t\t\t\t\t\targs,\n\t\t\t\t\t\tignoreDefaultArgs: [\"--disable-extensions\"]\n\t\t\t\t\t}); // run browser\n\t\t\t\t}\n\t\t\t\telse {\n\t\t\t\t\tbrowser = await puppeteer.launch({\n\t\t\t\t\t\theadless: true, // run in headless mode\n\t\t\t\t\t\tdevtools: false, // run with dev tools\n\t\t\t\t\t\targs,\n\t\t\t\t\t\tignoreDefaultArgs: [\"--disable-extensions\"]\n\t\t\t\t\t}); // run browser\n\t\t\t\t}\n\t\t\t\t\n\t\t\t\tconst page = await browser.newPage(); // create new tab\n\n\t\t\t\tlet pathToFont = '';\n\n\t\t\t\tif (fs.existsSync(path.join(__dirname, ('../private/fonts/dejavuserif.woff')))) {\n\t\t\t\t\tpathToFont = path.join(__dirname, ('../private/fonts/'));\n\t\t\t\t}\n\t\t\t\telse {\n\t\t\t\t\tif (fs.existsSync(path.join(this.clientDir, ('./private/fonts/dejavuserif.woff')))) {\n\t\t\t\t\t\tpathToFont = path.join(this.clientDir, ('./private/fonts/'));\n\t\t\t\t\t}\n\t\t\t\t\telse {\n\t\t\t\t\t\tpathToFont = '/usr/share/fonts/dejavu/';\n\t\t\t\t\t}\n\t\t\t\t}\n\n\t\t\t\tlet dejavuserif_woff = 'data:application/font-woff;base64,' + Buffer.from(fs.readFileSync(pathToFont + 'dejavuserif.woff').buffer).toString('base64');\n\t\t\t\tlet dejavuserifBold_woff = 'data:application/font-woff;base64,' + Buffer.from(fs.readFileSync(pathToFont + 'dejavuserif-bold.woff').buffer).toString('base64');\n\t\t\t\tlet dejavuserifItalic_woff = 'data:application/font-woff;base64,' + Buffer.from(fs.readFileSync(pathToFont + 'dejavuserif-italic.woff').buffer).toString('base64');\n\t\t\t\tlet dejavuserifBoldItalic_woff = 'data:application/font-woff;base64,' + Buffer.from(fs.readFileSync(pathToFont + 'dejavuserif-bolditalic.woff').buffer).toString('base64');\n\n\t\t\t\tlet content = `\n\t\t\t\t\t<head>\n\t\t\t\t\t\t<style type=\"text/css\">\n\t\t\t\t\t\t\t@font-face {\n\t\t\t\t\t\t\t\tfont-family: 'Dejavu Serif';\n\t\t\t\t\t\t\t\tfont-style: normal;\n\t\t\t\t\t\t\t\tfont-weight: normal;\n\t\t\t\t\t\t\t\tsrc: url(\"` + dejavuserif_woff + `\") format('woff');\n\t\t\t\t\t\t\t}\n\n\t\t\t\t\t\t\t@font-face {\n\t\t\t\t\t\t\t\tfont-family: 'Dejavu Serif';\n\t\t\t\t\t\t\t\tfont-style: normal;\n\t\t\t\t\t\t\t\tfont-weight: bold;\n\t\t\t\t\t\t\t\tsrc: url(\"` + dejavuserifBold_woff + `\") format('woff');\n\t\t\t\t\t\t\t}\n\n\t\t\t\t\t\t\t@font-face {\n\t\t\t\t\t\t\t\tfont-family: 'Dejavu Serif';\n\t\t\t\t\t\t\t\tfont-style: italic;\n\t\t\t\t\t\t\t\tfont-weight: normal;\n\t\t\t\t\t\t\t\tsrc: url(\"` + dejavuserifItalic_woff + `\") format('woff');\n\t\t\t\t\t\t\t}\n\n\t\t\t\t\t\t\t@font-face {\n\t\t\t\t\t\t\t\tfont-family: 'Dejavu Serif';\n\t\t\t\t\t\t\t\tfont-style: italic;\n\t\t\t\t\t\t\t\tfont-weight: bold;\n\t\t\t\t\t\t\t\tsrc: url(\"` + dejavuserifBoldItalic_woff + `\") format('woff');\n\t\t\t\t\t\t\t}\n\t\t\t\t\t\t\t\n\t\t\t\t\t\t\tbody {\n\t\t\t\t\t\t\t\tfont-family: 'Dejavu Serif', serif;\n\t\t\t\t\t\t\t\tfont-size: ` + (fontSize ? fontSize : '12px') + `;\n\t\t\t\t\t\t\t}\n\n\t\t\t\t\t\t\t.row {\n\t\t\t\t\t\t\t\tdisplay: -webkit-flex;\n\t\t\t\t\t\t\t\tdisplay: flex;\n\t\t\t\t\t\t\t\tflex-wrap: wrap;\n\t\t\t\t\t\t\t\t-webkit-flex-wrap: wrap;\n\t\t\t\t\t\t\t\tpage-break-inside: avoid !important;\n\t\t\t\t\t\t\t}\n\n\t\t\t\t\t\t\t.page-break {\n\t\t\t\t\t\t\t\tpage-break-before: always !important;\n\t\t\t\t\t\t\t\tpadding-top: 1px;\n\t\t\t\t\t\t\t}\n\n\t\t\t\t\t\t\t.cell {\n\t\t\t\t\t\t\t\tbox-sizing: border-box;\n\t\t\t\t\t\t\t\tpadding : 2px;\n\t\t\t\t\t\t\t\t-webkit-flex: 1;\n\t\t\t\t\t\t\t\tword-wrap: break-word;\n\t\t\t\t\t\t\t}\n\n\t\t\t\t\t\t\t.cell-no-padding {\n\t\t\t\t\t\t\t\tbox-sizing: border-box;\n\t\t\t\t\t\t\t\t-webkit-flex: 1;\n\t\t\t\t\t\t\t\tword-wrap: break-word;\n\t\t\t\t\t\t\t}\n\n\t\t\t\t\t\t\t.centered {\n\t\t\t\t\t\t\t\t-webkit-justify-content: center;\n\t\t\t\t\t\t\t\t-webkit-align-items: center;\n\t\t\t\t\t\t\t\tdisplay: -webkit-flex;\n\t\t\t\t\t\t\t\ttext-align: center;\n\t\t\t\t\t\t\t}\n\n\t\t\t\t\t\t\t.centered-left {\n\t\t\t\t\t\t\t\t-webkit-align-items: center;\n\t\t\t\t\t\t\t\tdisplay: -webkit-flex;\n\t\t\t\t\t\t\t\t-webkit-justify-content: flex-start;\n\t\t\t\t\t\t\t}\n\n\t\t\t\t\t\t\t.centered-right {\n\t\t\t\t\t\t\t\t-webkit-justify-content: flex-end;\n\t\t\t\t\t\t\t\t-webkit-align-items: center;\n\t\t\t\t\t\t\t\tdisplay: -webkit-flex;\n\t\t\t\t\t\t\t}\n\t\t\t\t\t\t\t\n\t\t\t\t\t\t\t.box {\n\t\t\t\t\t\t\t\tborder: 1px solid black;\n\t\t\t\t\t\t\t\tmargin: -1px 0px 0px -1px;\n\t\t\t\t\t\t\t}\n\n\t\t\t\t\t\t\t.boxNoBorder {\n\t\t\t\t\t\t\t\tmargin: -1px 0px 0px -1px;\n\t\t\t\t\t\t\t}\n\n\t\t\t\t\t\t\tpre {\n\t\t\t\t\t\t\t\twhite-space: pre-wrap; /* css-3 */\n\t\t\t\t\t\t\t\twhite-space: -moz-pre-wrap; /* Mozilla, since 1999 */\n\t\t\t\t\t\t\t\twhite-space: -pre-wrap; /* Opera 4-6 */\n\t\t\t\t\t\t\t\twhite-space: -o-pre-wrap; /* Opera 7 */\n\t\t\t\t\t\t\t\tword-wrap: break-word; /* Internet Explorer 5.5+ */\n\t\t\t\t\t\t\t\tfont-size: 12px;\n\t\t\t\t\t\t\t\tfont-family: 'Dejavu Serif'; \n\t\t\t\t\t\t\t}\n\t\t\t\t\t\t</style>\n\t\t\t\t\t</head>\n\t\t\t\t\t<body>\n\t\t\t\t` + html.replace(new RegExp('flex-basis:', 'g'), '-webkit-flex-basis:').replace(new RegExp('flex:', 'g'), '-webkit-flex:') + '</body>';\n\n\t\t\t\tawait page.setContent(content, { waitUntil: ['domcontentloaded', 'load', 'networkidle0'] });\n\t\t\t\tawait page.evaluateHandle('document.fonts.ready');\n\t\t\t\t\n\t\t\t\tlet tmpFileName = (pdfCnt++) + '-' + fileName.replace(new RegExp(/[^0-9\\.a-zA-Z]/g), '');\t\n\t\t\t\n\t\t\t\tawait page.pdf({\n\t\t\t\t\tscale: 1,\n\t\t\t\t\tlandscape: orientation === 'portrait' ? false : true,\n\t\t\t\t\tformat: 'letter',\n\t\t\t\t\tmargin: {\n\t\t\t\t\t\ttop: '1cm',\n\t\t\t\t\t\tbottom: '1cm',\n\t\t\t\t\t\tleft: '1cm',\n\t\t\t\t\t\tright: '1cm'\n\t\t\t\t\t},\n\t\t\t\t\tprintBackground: true,\n\t\t\t\t\tdisplayHeaderFooter: true,\n\t\t\t\t\theaderTemplate: `\n\t\t\t\t\t\t<style>\n\t\t\t\t\t\t\t#header { \n\t\t\t\t\t\t\t\tpadding: 0 0 10px 10px !important; \n\t\t\t\t\t\t\t}\n\t\t\t\t\t\t</style>\n\t\t\t\t\t\t<span></span>\n\t\t\t\t\t`,\n\t\t\t\t\tfooterTemplate: `\n\t\t\t\t\t\t<style>\n\t\t\t\t\t\t\t#footer { \n\t\t\t\t\t\t\t\tpadding: 0 0 10px 10px !important;\n\t\t\t\t\t\t\t\tfont-size: 10px;\n\t\t\t\t\t\t\t\tfont-family: san-serif;\n\t\t\t\t\t\t\t}\n\t\t\t\t\t\t</style>\n\t\t\t\t\t\t<div style=\"padding-bottom: 2px; padding-right: 15px; text-align: right; width: 100%;\">\n\t\t\t\t\t\t\tPage&nbsp;<span class=\"pageNumber\"></span>&nbsp;of&nbsp;<span class=\"totalPages\"></span>\n\t\t\t\t\t\t</div>\n\t\t\t\t\t`,\n\t\t\t\t\tpath: path.join(__dirname, (tmpFileName)),\n\t\t\t\t\ttimeout: 0\n\t\t\t\t});\n\n\t\t\t\tif (enableDebugFlag && enableDebugFlag.value) {\n\t\t\t\t\t// Set viewport dimensions based on orientation\n\t\t\t\t\tif (orientation === 'landscape') {\n\t\t\t\t\t\tawait page.setViewport({ width: 1100, height: 850 });\n\t\t\t\t\t} \n\t\t\t\t\telse {\n\t\t\t\t\t\tawait page.setViewport({ width: 850, height: 1100 });\n\t\t\t\t\t}\n\t\t\t\t}\n\n\t\t\t\tawait browser.close();\n\t\t\t\t\n\t\t\t\tif (fs.existsSync(path.join(__dirname, (tmpFileName)))) {\n\t\t\t\t\ttry {\n\t\t\t\t\t\tlet data = fs.readFileSync(path.join(__dirname, (tmpFileName)));\n\t\t\t\t\t\tfs.unlinkSync(path.join(__dirname, (tmpFileName)));\n\t\t\t\t\t\tif (!upload) {\n\t\t\t\t\t\t\treturn 'data:application/pdf;base64,' + Buffer.from(data).toString('base64');\n\t\t\t\t\t\t}\n\t\t\t\t\t\telse {\n\t\t\t\t\t\t\tlet fileData = 'data:application/pdf;base64,' + Buffer.from(data).toString('base64');\n\t\t\t\t\t\t\treturn this.callMethod('uploadFileAndSave', fileName, fileData, (4 * Math.ceil(fileData.length / 3)), uploadFileOrder !== null ? uploadFileOrder : -1, uploadFileType, false);\n\t\t\t\t\t\t}\n\t\t\t\t\t}\n\t\t\t\t\tcatch (errRead) {\n\t\t\t\t\t\terrRead.message = 'Error in Generate PDF: No file - ' + errRead.message;\n\t\t\t\t\t\tthrow errRead;\n\t\t\t\t\t}\n\t\t\t\t}\n\t\t\t\telse {\n\t\t\t\t\tconsole.log('No tmp file ', tmpFileName);\n\t\t\t\t\tthrow new Error('Error in Generate PDF: No tmp file');\n\t\t\t\t}\n\t\t\t},\n\t\t\tworkerTaskWeight: 2\n\t\t},\n\t\tgeneratePDFNoPageNumber: {\n\t\t\tcheck: new SimpleSchema({\n\t\t\t\thtml: {\n\t\t\t\t\ttype: String\n\t\t\t\t},\n\t\t\t\tfileName: {\n\t\t\t\t\ttype: String\n\t\t\t\t},\n\t\t\t\torientation: {\n\t\t\t\t\ttype: String,\n\t\t\t\t\toptional: true\n\t\t\t\t},\n\t\t\t\tfontSize: {\n\t\t\t\t\ttype: String,\n\t\t\t\t\toptional: true\n\t\t\t\t},\n\t\t\t\tupload: {\n\t\t\t\t\ttype: Boolean,\n\t\t\t\t\toptional: true\n\t\t\t\t},\n\t\t\t\tuploadFileOrder: {\n\t\t\t\t\ttype: Number,\n\t\t\t\t\toptional: true\n\t\t\t\t},\n\t\t\t\tuploadFileType: {\n\t\t\t\t\ttype: String,\n\t\t\t\t\toptional: true\n\t\t\t\t}\n\t\t\t}),\n\t\t\tfunction: async function(html, fileName, orientation = 'portrait', fontSize = '12px', upload = false, uploadFileOrder = -1, uploadFileType = '') {\n\t\t\t\t// console.log(new Date(), 'GENERATE PDF CALL', fileName, orientation, fontSize, upload);\n\n\t\t\t\tconst args = [\n\t\t\t\t\t\"--disable-dev-shm-usage\",\n\t\t\t\t\t\"--no-sandbox\",\n\t\t\t\t\t\"--disable-setuid-sandbox\",\n\t\t\t\t\t\"--disable-accelerated-2d-canvas\",\n\t\t\t\t\t\"--disable-gpu\",\n\t\t\t\t\t\"--allow-file-access-from-files\", \n\t\t\t\t\t\"--enable-local-file-accesses\",\n\t\t\t\t\t'--font-render-hinting=none'\n\t\t\t\t];\n\n\t\t\t\tconst browser = await puppeteer.launch({\n\t\t\t\t\theadless: true, // run in headless mode\n\t\t\t\t\tdevtools: false, // run with dev tools\n\t\t\t\t\targs,\n\t\t\t\t\tignoreDefaultArgs: [\"--disable-extensions\"]\n\t\t\t\t}); // run browser\n\t\t\t\t\n\t\t\t\tconst page = await browser.newPage(); // create new tab\n\n\t\t\t\tlet pathToFont = '';\n\n\t\t\t\tif (fs.existsSync(path.join(__dirname, ('../private/fonts/dejavuserif.woff')))) {\n\t\t\t\t\tpathToFont = path.join(__dirname, ('../private/fonts/'));\n\t\t\t\t}\n\t\t\t\telse {\n\t\t\t\t\tif (fs.existsSync(path.join(this.clientDir, ('./private/fonts/dejavuserif.woff')))) {\n\t\t\t\t\t\tpathToFont = path.join(this.clientDir, ('./private/fonts/'));\n\t\t\t\t\t}\n\t\t\t\t\telse {\n\t\t\t\t\t\tpathToFont = '/usr/share/fonts/dejavu/';\n\t\t\t\t\t}\n\t\t\t\t}\n\n\t\t\t\tlet dejavuserif_woff = 'data:application/font-woff;base64,' + Buffer.from(fs.readFileSync(pathToFont + 'dejavuserif.woff').buffer).toString('base64');\n\t\t\t\tlet dejavuserifBold_woff = 'data:application/font-woff;base64,' + Buffer.from(fs.readFileSync(pathToFont + 'dejavuserif-bold.woff').buffer).toString('base64');\n\t\t\t\tlet dejavuserifItalic_woff = 'data:application/font-woff;base64,' + Buffer.from(fs.readFileSync(pathToFont + 'dejavuserif-italic.woff').buffer).toString('base64');\n\t\t\t\tlet dejavuserifBoldItalic_woff = 'data:application/font-woff;base64,' + Buffer.from(fs.readFileSync(pathToFont + 'dejavuserif-bolditalic.woff').buffer).toString('base64');\n\n\t\t\t\tlet content = `\n\t\t\t\t\t<head>\n\t\t\t\t\t\t<style type=\"text/css\">\n\t\t\t\t\t\t\t@font-face {\n\t\t\t\t\t\t\t\tfont-family: 'Dejavu Serif';\n\t\t\t\t\t\t\t\tfont-style: normal;\n\t\t\t\t\t\t\t\tfont-weight: normal;\n\t\t\t\t\t\t\t\tsrc: url(\"` + dejavuserif_woff + `\") format('woff');\n\t\t\t\t\t\t\t}\n\n\t\t\t\t\t\t\t@font-face {\n\t\t\t\t\t\t\t\tfont-family: 'Dejavu Serif';\n\t\t\t\t\t\t\t\tfont-style: normal;\n\t\t\t\t\t\t\t\tfont-weight: bold;\n\t\t\t\t\t\t\t\tsrc: url(\"` + dejavuserifBold_woff + `\") format('woff');\n\t\t\t\t\t\t\t}\n\n\t\t\t\t\t\t\t@font-face {\n\t\t\t\t\t\t\t\tfont-family: 'Dejavu Serif';\n\t\t\t\t\t\t\t\tfont-style: italic;\n\t\t\t\t\t\t\t\tfont-weight: normal;\n\t\t\t\t\t\t\t\tsrc: url(\"` + dejavuserifItalic_woff + `\") format('woff');\n\t\t\t\t\t\t\t}\n\n\t\t\t\t\t\t\t@font-face {\n\t\t\t\t\t\t\t\tfont-family: 'Dejavu Serif';\n\t\t\t\t\t\t\t\tfont-style: italic;\n\t\t\t\t\t\t\t\tfont-weight: bold;\n\t\t\t\t\t\t\t\tsrc: url(\"` + dejavuserifBoldItalic_woff + `\") format('woff');\n\t\t\t\t\t\t\t}\n\t\t\t\t\t\t\t\n\t\t\t\t\t\t\tbody {\n\t\t\t\t\t\t\t\tfont-family: 'Dejavu Serif', serif;\n\t\t\t\t\t\t\t\tfont-size: ` + (fontSize ? fontSize : '12px') + `;\n\t\t\t\t\t\t\t}\n\n\t\t\t\t\t\t\t.row {\n\t\t\t\t\t\t\t\tdisplay: -webkit-flex;\n\t\t\t\t\t\t\t\tdisplay: flex;\n\t\t\t\t\t\t\t\tflex-wrap: wrap;\n\t\t\t\t\t\t\t\t-webkit-flex-wrap: wrap;\n\t\t\t\t\t\t\t\tpage-break-inside: avoid !important;\n\t\t\t\t\t\t\t}\n\n\t\t\t\t\t\t\t.page-break {\n\t\t\t\t\t\t\t\tpage-break-before: always !important;\n\t\t\t\t\t\t\t\tpadding-top: 1px;\n\t\t\t\t\t\t\t}\n\n\t\t\t\t\t\t\t.cell {\n\t\t\t\t\t\t\t\tbox-sizing: border-box;\n\t\t\t\t\t\t\t\tpadding : 2px;\n\t\t\t\t\t\t\t\t-webkit-flex: 1;\n\t\t\t\t\t\t\t\tword-wrap: break-word;\n\t\t\t\t\t\t\t}\n\n\t\t\t\t\t\t\t.cell-no-padding {\n\t\t\t\t\t\t\t\tbox-sizing: border-box;\n\t\t\t\t\t\t\t\t-webkit-flex: 1;\n\t\t\t\t\t\t\t\tword-wrap: break-word;\n\t\t\t\t\t\t\t}\n\n\t\t\t\t\t\t\t.centered {\n\t\t\t\t\t\t\t\t-webkit-justify-content: center;\n\t\t\t\t\t\t\t\t-webkit-align-items: center;\n\t\t\t\t\t\t\t\tdisplay: -webkit-flex;\n\t\t\t\t\t\t\t\ttext-align: center;\n\t\t\t\t\t\t\t}\n\n\t\t\t\t\t\t\t.centered-left {\n\t\t\t\t\t\t\t\t-webkit-align-items: center;\n\t\t\t\t\t\t\t\tdisplay: -webkit-flex;\n\t\t\t\t\t\t\t\t-webkit-justify-content: flex-start;\n\t\t\t\t\t\t\t}\n\n\t\t\t\t\t\t\t.centered-right {\n\t\t\t\t\t\t\t\t-webkit-justify-content: flex-end;\n\t\t\t\t\t\t\t\t-webkit-align-items: center;\n\t\t\t\t\t\t\t\tdisplay: -webkit-flex;\n\t\t\t\t\t\t\t}\n\t\t\t\t\t\t\t\n\t\t\t\t\t\t\t.box {\n\t\t\t\t\t\t\t\tborder: 1px solid black;\n\t\t\t\t\t\t\t\tmargin: -1px 0px 0px -1px;\n\t\t\t\t\t\t\t}\n\n\t\t\t\t\t\t\t.boxNoBorder {\n\t\t\t\t\t\t\t\tmargin: -1px 0px 0px -1px;\n\t\t\t\t\t\t\t}\n\n\t\t\t\t\t\t\tpre {\n\t\t\t\t\t\t\t\twhite-space: pre-wrap; /* css-3 */\n\t\t\t\t\t\t\t\twhite-space: -moz-pre-wrap; /* Mozilla, since 1999 */\n\t\t\t\t\t\t\t\twhite-space: -pre-wrap; /* Opera 4-6 */\n\t\t\t\t\t\t\t\twhite-space: -o-pre-wrap; /* Opera 7 */\n\t\t\t\t\t\t\t\tword-wrap: break-word; /* Internet Explorer 5.5+ */\n\t\t\t\t\t\t\t\tfont-size: 12px;\n\t\t\t\t\t\t\t\tfont-family: 'Dejavu Serif'; \n\t\t\t\t\t\t\t}\n\t\t\t\t\t\t</style>\n\t\t\t\t\t\t<meta charset=\"UTF-8\">\n\t\t\t\t\t</head>\n\t\t\t\t\t<body>\n\t\t\t\t` + html.replace(new RegExp('flex-basis:', 'g'), '-webkit-flex-basis:').replace(new RegExp('flex:', 'g'), '-webkit-flex:') + '</body>';\n\n\t\t\t\tawait page.setContent(content, { waitUntil: ['domcontentloaded', 'load', 'networkidle0'] });\n\t\t\t\tawait page.evaluateHandle('document.fonts.ready');\n\t\t\t\t\n\t\t\t\tlet tmpFileName = (pdfCnt++) + '-' + fileName.replace(new RegExp(/[^0-9\\.a-zA-Z]/g), '');\t\n\t\t\t\n\t\t\t\tawait page.pdf({\n\t\t\t\t\tscale: 1,\n\t\t\t\t\tlandscape: orientation === 'portrait' ? false : true,\n\t\t\t\t\tformat: 'letter',\n\t\t\t\t\tmargin: {\n\t\t\t\t\t\ttop: '1cm',\n\t\t\t\t\t\tbottom: '1cm',\n\t\t\t\t\t\tleft: '1cm',\n\t\t\t\t\t\tright: '1cm'\n\t\t\t\t\t},\n\t\t\t\t\tprintBackground: true,\n\t\t\t\t\tdisplayHeaderFooter: true,\n\t\t\t\t\theaderTemplate: `\n\t\t\t\t\t\t<style>\n\t\t\t\t\t\t\t#header { \n\t\t\t\t\t\t\t\tpadding: 0 0 10px 10px !important; \n\t\t\t\t\t\t\t}\n\t\t\t\t\t\t</style>\n\t\t\t\t\t\t<span></span>\n\t\t\t\t\t`,\n\t\t\t\t\tfooterTemplate: `\n\t\t\t\t\t<style>\n\t\t\t\t\t\t#footer { \n\t\t\t\t\t\t\tpadding: 0 0 10px 10px !important;\n\t\t\t\t\t\t\tfont-size: 10px;\n\t\t\t\t\t\t\tfont-family: san-serif;\n\t\t\t\t\t\t}\n\t\t\t\t\t</style>\n\t\t\t\t\t<div style=\"padding-bottom: 2px; padding-right: 15px; text-align: right; width: 100%;\">\n\t\t\t\t\t\t\n\t\t\t\t\t</div>\n\t\t\t\t\t`,\n\t\t\t\t\tpath: path.join(__dirname, (tmpFileName)),\n\t\t\t\t\ttimeout: 0\n\t\t\t\t});\n\t\t\t\tawait browser.close();\n\t\t\t\t\n\t\t\t\tif (fs.existsSync(path.join(__dirname, (tmpFileName)))) {\n\t\t\t\t\ttry {\n\t\t\t\t\t\tlet data = fs.readFileSync(path.join(__dirname, (tmpFileName)))\n\t\t\t\t\t\tfs.unlinkSync(path.join(__dirname, (tmpFileName)));\n\t\t\t\t\t\tif (!upload) {\n\t\t\t\t\t\t\treturn 'data:application/pdf;base64,' + Buffer.from(data).toString('base64');\n\t\t\t\t\t\t}\n\t\t\t\t\t\telse {\n\t\t\t\t\t\t\tlet fileData = 'data:application/pdf;base64,' + Buffer.from(data).toString('base64');\n\t\t\t\t\t\t\treturn this.callMethod('uploadFileAndSave', fileName, fileData, (4 * Math.ceil(fileData.length / 3)), uploadFileOrder !== null ? uploadFileOrder : -1, uploadFileType, false);\n\t\t\t\t\t\t}\n\t\t\t\t\t}\n\t\t\t\t\tcatch (errRead) {\n\t\t\t\t\t\terrRead.message = 'Error in Generate PDF No Page Number: No file - ' + errRead.message;\n\t\t\t\t\t\tthrow errRead;\n\t\t\t\t\t}\n\t\t\t\t}\n\t\t\t\telse {\n\t\t\t\t\tconsole.log('No tmp file ', tmpFileName);\n\t\t\t\t\tthrow new Error('Error in Generate PDF No Page Number: No tmp file');\n\t\t\t\t}\n\t\t\t},\n\t\t\tworkerTaskWeight: 2\n\t\t},\n\t\tmergePDFResolve: {\n\t\t\tcheck: new SimpleSchema({\n\t\t\t\tfileKeys: {\n\t\t\t\t\ttype: Array\n\t\t\t\t},\n\t\t\t\t'fileKeys.$': {\n\t\t\t\t\ttype: String\n\t\t\t\t},\n\t\t\t\tfileName: {\n\t\t\t\t\ttype: String\n\t\t\t\t},\n\t\t\t\tfileType: {\n\t\t\t\t\ttype: String,\n\t\t\t\t\toptional: true\n\t\t\t\t}\n\t\t\t}),\n\t\t\tfunction: async function(fileKeys: string[], fileName: string, fileType?: string) {\n\t\t\t\ttry {\n\t\t\t\t\tlet resSigneds = await this.callMethod('getSignedUrls', fileKeys, 900);\n\n\t\t\t\t\tif (resSigneds && resSigneds.length) {\n\t\t\t\t\t\tlet promises = [];\n\t\n\t\t\t\t\t\tresSigneds.forEach((signedUrl) => {\n\t\t\t\t\t\t\tpromises.push(this.callMethod('getDataURIfromURL', signedUrl));\n\t\t\t\t\t\t});\n\t\t\t\t\t\t\n\t\t\t\t\t\tlet fileDatas = await Promise.all(promises);\n\t\t\t\t\t\tconst mergedPdf = await PDFDocument.create();\n\n\t\t\t\t\t\tfor (let i = 0; i < fileDatas.length; i++) {\n\t\t\t\t\t\t\tlet fileData = fileDatas[i];\n\n\t\t\t\t\t\t\tif (fileData) {\n\t\t\t\t\t\t\t\ttry {\n\t\t\t\t\t\t\t\t\tif (fileData.startsWith('data:application/pdf;base64,')) {\n\t\t\t\t\t\t\t\t\t\tconst pdf = await PDFDocument.load(fileData, { updateMetadata: false, parseSpeed: ParseSpeeds.Fastest, ignoreEncryption: true });\n\t\t\t\t\t\t\t\t\t\tconst copiedPages = await mergedPdf.copyPages(pdf, pdf.getPageIndices());\n\t\t\t\t\t\t\t\t\t\tcopiedPages.forEach((page) => {\n\t\t\t\t\t\t\t\t\t\t\tmergedPdf.addPage(page);\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\telse if (fileData.startsWith('data:image/jpeg;base64,/9j/') || fileData.startsWith('data:image/png;base64,/9j/')) {\n\t\t\t\t\t\t\t\t\t\tconst pdf = await PDFDocument.create();\n\t\t\t\t\t\t\t\t\t\tconst img = await pdf.embedJpg(fileData);\n\t\t\t\t\t\t\t\t\t\tconst page = pdf.addPage();\n\t\t\t\t\t\t\t\t\t\tlet imgDim = img.scaleToFit(page.getWidth() * 0.75, page.getHeight() * 0.75);\n\t\t\t\t\t\t\t\t\t\tpage.drawImage(img, {\n\t\t\t\t\t\t\t\t\t\t\tx: page.getWidth() / 2 - imgDim.width / 2,\n\t\t\t\t\t\t\t\t\t\t\ty: page.getHeight() / 2 - imgDim.height / 2,\n\t\t\t\t\t\t\t\t\t\t\twidth: imgDim.width,\n\t\t\t\t\t\t\t\t\t\t\theight: imgDim.height,\n\t\t\t\t\t\t\t\t\t\t});\n\t\t\t\t\t\t\t\t\t\tconst copiedPages = await mergedPdf.copyPages(pdf, pdf.getPageIndices());\n\t\t\t\t\t\t\t\t\t\tcopiedPages.forEach((page) => {\n\t\t\t\t\t\t\t\t\t\t\tmergedPdf.addPage(page);\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\telse if (fileData.startsWith('data:image/png;base64,iVBOR')) {\n\t\t\t\t\t\t\t\t\t\tconst pdf = await PDFDocument.create();\n\t\t\t\t\t\t\t\t\t\tconst img = await pdf.embedPng(fileData);\n\t\t\t\t\t\t\t\t\t\tconst page = pdf.addPage();\n\t\t\t\t\t\t\t\t\t\tlet imgDim = img.scaleToFit(page.getWidth() * 0.75, page.getHeight() * 0.75);\n\t\t\t\t\t\t\t\t\t\tpage.drawImage(img, {\n\t\t\t\t\t\t\t\t\t\t\tx: page.getWidth() / 2 - imgDim.width / 2,\n\t\t\t\t\t\t\t\t\t\t\ty: page.getHeight() / 2 - imgDim.height / 2,\n\t\t\t\t\t\t\t\t\t\t\twidth: imgDim.width,\n\t\t\t\t\t\t\t\t\t\t\theight: imgDim.height,\n\t\t\t\t\t\t\t\t\t\t});\n\t\t\t\t\t\t\t\t\t\tconst copiedPages = await mergedPdf.copyPages(pdf, pdf.getPageIndices());\n\t\t\t\t\t\t\t\t\t\tcopiedPages.forEach((page) => {\n\t\t\t\t\t\t\t\t\t\t\tmergedPdf.addPage(page);\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\telse {\n\t\t\t\t\t\t\t\t\t\tconsole.log('Error - unsupported!!', fileData.slice(0, 60));\n\t\t\t\t\t\t\t\t\t\tthrow new Error('Error in Merge PDF Resolve: Unsupported document type - ' + fileData.slice(0, 60));\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\tcatch (error) {\n\t\t\t\t\t\t\t\t\tconsole.log('Error processing fileData:', fileData.slice(0, 60), error.message);\n\t\t\t\t\t\t\t\t\terror.message = `Error in Merge PDF Resolve: Error processing fileData: ${fileData.slice(0, 60)} - ${error.message}`;\n\t\t\t\t\t\t\t\t\tthrow error;\n\t\t\t\t\t\t\t\t}\n\t\t\t\t\t\t\t}\n\t\t\t\t\t\t\telse {\n\t\t\t\t\t\t\t\tconsole.log('Error - no filedata!!', fileData);\n\t\t\t\t\t\t\t\tthrow new Error('Error in Merge PDF Resolve: No File Data');\n\t\t\t\t\t\t\t}\n\t\t\t\t\t\t}\n\n\t\t\t\t\t\tlet mergedPDFUint8 = await mergedPdf.save();\n\n\t\t\t\t\t\tconst b64PDF = 'data:application/pdf;base64,' + Buffer.from(mergedPDFUint8).toString('base64');\n\n\t\t\t\t\t\treturn this.callMethod('uploadFileAndSave', fileName, b64PDF, (4 * Math.ceil(b64PDF.length / 3)), -1, fileType, false);\n\t\t\t\t\t}\n\t\t\t\t\telse {\n\t\t\t\t\t\t\n\t\t\t\t\t}\n\t\t\t\t}\n\t\t\t\tcatch (err) {\n\t\t\t\t\terr.message = 'Error in Merge PDF Resolve: PDF Merge - Get Signed URLs - ' + err.message;\n\t\t\t\t\t\n\t\t\t\t\tthrow err;\n\t\t\t\t}\n\t\t\t},\n\t\t\tworkerTaskWeight: 2\n\t\t},\t\t\n\t\tmergePDFResolveNoSave: {\n\t\t\tcheck: new SimpleSchema({\n\t\t\t\tfileKeys: {\n\t\t\t\t\ttype: Array\n\t\t\t\t},\n\t\t\t\t'fileKeys.$': {\n\t\t\t\t\ttype: String\n\t\t\t\t}\n\t\t\t}),\n\t\t\tfunction: async function(fileKeys: string[]) {\n\t\t\t\ttry {\n\t\t\t\t\tlet resSigneds = await this.callMethod('getSignedUrls', fileKeys, 900);\n\t\t\t\t\tif (resSigneds && resSigneds.length) {\n\t\t\t\t\t\tlet promises = [];\n\n\t\t\t\t\t\tresSigneds.forEach((signedUrl) => {\n\t\t\t\t\t\t\tpromises.push(this.callMethod('getDataURIfromURL', signedUrl));\n\t\t\t\t\t\t});\n\t\t\t\t\t\t\n\t\t\t\t\t\tlet fileDatas = await Promise.all(promises);\n\t\t\t\t\t\tconst mergedPdf = await PDFDocument.create();\n\n\t\t\t\t\t\tfor (let i = 0; i < fileDatas.length; i++) {\n\t\t\t\t\t\t\tlet fileData = fileDatas[i];\n\n\t\t\t\t\t\t\tif (fileData) {\n\t\t\t\t\t\t\t\ttry {\n\t\t\t\t\t\t\t\t\tif (fileData.startsWith('data:application/pdf;base64,')) {\n\t\t\t\t\t\t\t\t\t\tconst pdf = await PDFDocument.load(fileData, { updateMetadata: false, parseSpeed: ParseSpeeds.Fastest, ignoreEncryption: true});\n\t\t\t\t\t\t\t\t\t\tconst copiedPages = await mergedPdf.copyPages(pdf, pdf.getPageIndices());\n\t\t\t\t\t\t\t\t\t\tcopiedPages.forEach((page) => {\n\t\t\t\t\t\t\t\t\t\t\tmergedPdf.addPage(page);\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\telse if (fileData.startsWith('data:image/jpeg;base64,/9j/') || fileData.startsWith('data:image/png;base64,/9j/')) {\n\t\t\t\t\t\t\t\t\t\tconst pdf = await PDFDocument.create();\n\t\t\t\t\t\t\t\t\t\tconst img = await pdf.embedJpg(fileData);\n\t\t\t\t\t\t\t\t\t\tconst page = pdf.addPage();\n\t\t\t\t\t\t\t\t\t\tlet imgDim = img.scaleToFit(page.getWidth() * 0.75, page.getHeight() * 0.75);\n\t\t\t\t\t\t\t\t\t\tpage.drawImage(img, {\n\t\t\t\t\t\t\t\t\t\t\tx: page.getWidth() / 2 - imgDim.width / 2,\n\t\t\t\t\t\t\t\t\t\t\ty: page.getHeight() / 2 - imgDim.height / 2,\n\t\t\t\t\t\t\t\t\t\t\twidth: imgDim.width,\n\t\t\t\t\t\t\t\t\t\t\theight: imgDim.height,\n\t\t\t\t\t\t\t\t\t\t});\n\t\t\t\t\t\t\t\t\t\tconst copiedPages = await mergedPdf.copyPages(pdf, pdf.getPageIndices());\n\t\t\t\t\t\t\t\t\t\tcopiedPages.forEach((page) => {\n\t\t\t\t\t\t\t\t\t\t\tmergedPdf.addPage(page);\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\telse if (fileData.startsWith('data:image/png;base64,iVBOR')) {\n\t\t\t\t\t\t\t\t\t\tconst pdf = await PDFDocument.create();\n\t\t\t\t\t\t\t\t\t\tconst img = await pdf.embedPng(fileData);\n\t\t\t\t\t\t\t\t\t\tconst page = pdf.addPage();\n\t\t\t\t\t\t\t\t\t\tlet imgDim = img.scaleToFit(page.getWidth() * 0.75, page.getHeight() * 0.75);\n\t\t\t\t\t\t\t\t\t\tpage.drawImage(img, {\n\t\t\t\t\t\t\t\t\t\t\tx: page.getWidth() / 2 - imgDim.width / 2,\n\t\t\t\t\t\t\t\t\t\t\ty: page.getHeight() / 2 - imgDim.height / 2,\n\t\t\t\t\t\t\t\t\t\t\twidth: imgDim.width,\n\t\t\t\t\t\t\t\t\t\t\theight: imgDim.height,\n\t\t\t\t\t\t\t\t\t\t});\n\t\t\t\t\t\t\t\t\t\tconst copiedPages = await mergedPdf.copyPages(pdf, pdf.getPageIndices());\n\t\t\t\t\t\t\t\t\t\tcopiedPages.forEach((page) => {\n\t\t\t\t\t\t\t\t\t\t\tmergedPdf.addPage(page);\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\telse {\n\t\t\t\t\t\t\t\t\t\tconsole.log('Error - unsupported!!', fileData.slice(0, 60));\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\tcatch (error) {\n\t\t\t\t\t\t\t\t\tconsole.log('Error processing fileData:', fileData.slice(0, 60), error);\n\t\t\t\t\t\t\t\t}\n\t\t\t\t\t\t\t}\n\t\t\t\t\t\t\telse {\n\t\t\t\t\t\t\t\tconsole.log('Error - no filedata!!', fileData);\n\t\t\t\t\t\t\t}\n\t\t\t\t\t\t}\n\n\t\t\t\t\t\tlet mergedPDFUint8 = await mergedPdf.save();\n\n\t\t\t\t\t\tconst b64PDF = 'data:application/pdf;base64,' + Buffer.from(mergedPDFUint8).toString('base64');\n\t\t\t\t\t\t\n\t\t\t\t\t\treturn b64PDF;\n\t\t\t\t\t}\n\t\t\t\t\telse {\n\t\t\t\t\t\tthrow new Error('Error in Merge PDF Resolve No Save: No signed urls');\n\t\t\t\t\t}\n\t\t\t\t}\n\t\t\t\tcatch (err) {\n\t\t\t\t\terr.message = `Error in Merge PDF Resolve: ${err.message}`;\n\t\t\t\t\tthrow err;\n\t\t\t\t}\n\t\t\t},\n\t\t\tworkerTaskWeight: 2\n\t\t},\n\t\tmergePDFResolveHtml: {\n\t\t\tcheck: new SimpleSchema({\n\t\t\t\thtmls: {\n\t\t\t\t\ttype: Array\n\t\t\t\t},\n\t\t\t\t'htmls.$': {\n\t\t\t\t\ttype: String\n\t\t\t\t},\n\t\t\t\tfileName: {\n\t\t\t\t\ttype: String\n\t\t\t\t},\n\t\t\t\tfileType: {\n\t\t\t\t\ttype: String,\n\t\t\t\t\toptional: true\n\t\t\t\t},\n\t\t\t\tsave: {\n\t\t\t\t\ttype: Boolean,\n\t\t\t\t\toptional: true\n\t\t\t\t}\n\t\t\t}),\n\t\t\tfunction: async function(htmls: string[], fileName: string, fileType?: string, save = true) {\n\t\t\t\tconst mergedPdf = await PDFDocument.create();\n\n\t\t\t\tfor (let i = 0; i < htmls.length; i++) {\n\t\t\t\t\tlet fileData = htmls[i];\n\n\t\t\t\t\tif (fileData) {\n\t\t\t\t\t\ttry {\n\t\t\t\t\t\t\tif (fileData.startsWith('data:application/pdf;base64,')) {\n\t\t\t\t\t\t\t\tconst pdf = await PDFDocument.load(fileData, { updateMetadata: false, parseSpeed: ParseSpeeds.Fastest, ignoreEncryption: true });\n\t\t\t\t\t\t\t\tconst copiedPages = await mergedPdf.copyPages(pdf, pdf.getPageIndices());\n\t\t\t\t\t\t\t\tcopiedPages.forEach((page) => {\n\t\t\t\t\t\t\t\t\tmergedPdf.addPage(page);\n\t\t\t\t\t\t\t\t});\n\t\t\t\t\t\t\t}\n\t\t\t\t\t\t\telse if (fileData.startsWith('data:image/jpeg;base64,/9j/') || fileData.startsWith('data:image/png;base64,/9j/')) {\n\t\t\t\t\t\t\t\tconst pdf = await PDFDocument.create();\n\t\t\t\t\t\t\t\tconst img = await pdf.embedJpg(fileData);\n\t\t\t\t\t\t\t\tconst page = pdf.addPage();\n\t\t\t\t\t\t\t\tlet imgDim = img.scaleToFit(page.getWidth() * 0.75, page.getHeight() * 0.75);\n\t\t\t\t\t\t\t\tpage.drawImage(img, {\n\t\t\t\t\t\t\t\t\tx: page.getWidth() / 2 - imgDim.width / 2,\n\t\t\t\t\t\t\t\t\ty: page.getHeight() / 2 - imgDim.height / 2,\n\t\t\t\t\t\t\t\t\twidth: imgDim.width,\n\t\t\t\t\t\t\t\t\theight: imgDim.height,\n\t\t\t\t\t\t\t\t});\n\t\t\t\t\t\t\t\tconst copiedPages = await mergedPdf.copyPages(pdf, pdf.getPageIndices());\n\t\t\t\t\t\t\t\tcopiedPages.forEach((page) => {\n\t\t\t\t\t\t\t\t\tmergedPdf.addPage(page);\n\t\t\t\t\t\t\t\t});\n\t\t\t\t\t\t\t}\n\t\t\t\t\t\t\telse if (fileData.startsWith('data:image/png;base64,iVBOR')) {\n\t\t\t\t\t\t\t\tconst pdf = await PDFDocument.create();\n\t\t\t\t\t\t\t\tconst img = await pdf.embedPng(fileData);\n\t\t\t\t\t\t\t\tconst page = pdf.addPage();\n\t\t\t\t\t\t\t\tlet imgDim = img.scaleToFit(page.getWidth() * 0.75, page.getHeight() * 0.75);\n\t\t\t\t\t\t\t\tpage.drawImage(img, {\n\t\t\t\t\t\t\t\t\tx: page.getWidth() / 2 - imgDim.width / 2,\n\t\t\t\t\t\t\t\t\ty: page.getHeight() / 2 - imgDim.height / 2,\n\t\t\t\t\t\t\t\t\twidth: imgDim.width,\n\t\t\t\t\t\t\t\t\theight: imgDim.height,\n\t\t\t\t\t\t\t\t});\n\t\t\t\t\t\t\t\tconst copiedPages = await mergedPdf.copyPages(pdf, pdf.getPageIndices());\n\t\t\t\t\t\t\t\tcopiedPages.forEach((page) => {\n\t\t\t\t\t\t\t\t\tmergedPdf.addPage(page);\n\t\t\t\t\t\t\t\t});\n\t\t\t\t\t\t\t}\n\t\t\t\t\t\t\telse {\n\t\t\t\t\t\t\t\tconsole.log('Error - unsupported!!', fileData.slice(0, 60));\n\t\t\t\t\t\t\t\tthrow new Error('Error in Merge PDF Resolve HTML: Unsupported file - ' + fileData.slice(0, 60));\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.log('Error processing fileData:', fileData.slice(0, 60), error);\n\t\t\t\t\t\t\terror.message = `Error in Merge PDF Resolve HTML: Error processing filedata - ${error.message}`;\n\t\t\t\t\t\t\tthrow error;\n\t\t\t\t\t\t}\n\t\t\t\t\t}\n\t\t\t\t\telse {\n\t\t\t\t\t\tconsole.log('Error - no filedata!!', fileData);\n\t\t\t\t\t\tthrow new Error('Error in Merge PDF Resolve HTML: No File data');\n\t\t\t\t\t}\n\t\t\t\t}\n\n\t\t\t\tlet mergedPDFUint8 = await mergedPdf.save();\n\n\t\t\t\tconst b64PDF = 'data:application/pdf;base64,' + Buffer.from(mergedPDFUint8).toString('base64');\n\n\t\t\t\tif (save) {\n\t\t\t\t\treturn this.callMethod('uploadFileAndSave', fileName, b64PDF, (4 * Math.ceil(b64PDF.length / 3)), -1, fileType, false);\n\t\t\t\t}\n\t\t\t\telse {\n\t\t\t\t\treturn b64PDF;\n\t\t\t\t}\n\t\t\t},\n\t\t\tworkerTaskWeight: 2\n\t\t}\n\t});\n}"]}
1
+ {"version":3,"sources":["../../src/methods/pdf.ts"],"names":["fs","require","path","pdf_lib_1","puppeteer","simpl_schema_1","flag_collection_1","common_1","loadPDFMethods","methodManager","methods","generatePDF","check","default","html","type","String","fileName","orientation","optional","fontSize","upload","Boolean","uploadFileOrder","Number","uploadFileType","function","args","browser","Flags","findOne","enableDebugFlag","_a","sent","value","launch","headless","devtools","ignoreDefaultArgs","newPage","page","pathToFont","existsSync","join","__dirname","this","clientDir","dejavuserif_woff","Buffer","from","readFileSync","buffer","toString","dejavuserifBold_woff","dejavuserifItalic_woff","dejavuserifBoldItalic_woff","content","replace","RegExp","setContent","waitUntil","evaluateHandle","tmpFileName","objectIdHexString","pdf","scale","landscape","format","margin","top","bottom","left","right","printBackground","displayHeaderFooter","headerTemplate","footerTemplate","timeout","setViewport","width","height","close","console","log","Error","data","unlinkSync","fileData","callMethod","Math","ceil","length","errRead","message","workerTaskWeight","generatePDFNoPageNumber","mergePDFResolve","fileKeys","Array","fileKeys.$","fileType","resSigneds","promises_1","forEach","signedUrl","push","_this","Promise","all","fileDatas","PDFDocument","create","mergedPdf_1","i","startsWith","load","updateMetadata","parseSpeed","ParseSpeeds","Fastest","ignoreEncryption","copyPages","getPageIndices","addPage","embedJpg","img","imgDim","scaleToFit","getWidth","getHeight","drawImage","x","y","embedPng","slice","error_1","concat","save","mergedPDFUint8","b64PDF","err_1","mergePDFResolveNoSave","promises_2","mergedPdf_2","error_2","err_2","mergePDFResolveHtml","htmls","htmls.$","mergedPdf","error_3","exports"],"mappings":"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","file":"pdf.js","sourcesContent":["import * as fs from 'fs';\nimport * as path from 'path';\nimport { ParseSpeeds, PDFDocument } from 'pdf-lib';\nimport * as puppeteer from 'puppeteer';\nimport SimpleSchema from 'simpl-schema';\nimport { Flags } from '../collections/flag.collection';\nimport { MethodManager } from '../managers/method.manager';\nimport { objectIdHexString } from '../util/common';\n\nexport function loadPDFMethods(methodManager: MethodManager) {\n\tmethodManager.methods({\n\t\tgeneratePDF: {\n\t\t\tcheck: new SimpleSchema({\n\t\t\t\thtml: {\n\t\t\t\t\ttype: String\n\t\t\t\t},\n\t\t\t\tfileName: {\n\t\t\t\t\ttype: String\n\t\t\t\t},\n\t\t\t\torientation: {\n\t\t\t\t\ttype: String,\n\t\t\t\t\toptional: true\n\t\t\t\t},\n\t\t\t\tfontSize: {\n\t\t\t\t\ttype: String,\n\t\t\t\t\toptional: true\n\t\t\t\t},\n\t\t\t\tupload: {\n\t\t\t\t\ttype: Boolean,\n\t\t\t\t\toptional: true\n\t\t\t\t},\n\t\t\t\tuploadFileOrder: {\n\t\t\t\t\ttype: Number,\n\t\t\t\t\toptional: true\n\t\t\t\t},\n\t\t\t\tuploadFileType: {\n\t\t\t\t\ttype: String,\n\t\t\t\t\toptional: true\n\t\t\t\t}\n\t\t\t}),\n\t\t\tfunction: async function(html, fileName, orientation = 'portrait', fontSize = '12px', upload = false, uploadFileOrder = -1, uploadFileType = '') {\n\t\t\t\t// console.log(new Date(), 'GENERATE PDF CALL', fileName, orientation, fontSize, upload);\n\n\t\t\t\tconst args = [\n\t\t\t\t\t\"--disable-dev-shm-usage\",\n\t\t\t\t\t\"--no-sandbox\",\n\t\t\t\t\t\"--disable-setuid-sandbox\",\n\t\t\t\t\t\"--disable-accelerated-2d-canvas\",\n\t\t\t\t\t\"--disable-gpu\",\n\t\t\t\t\t\"--allow-file-access-from-files\", \n\t\t\t\t\t\"--enable-local-file-accesses\",\n\t\t\t\t\t'--font-render-hinting=none'\n\t\t\t\t];\n\n\t\t\t\tlet browser = null;\n\n\t\t\t\tlet enableDebugFlag = await Flags.findOne({type: 'Enable Debug PDF'});\n\t\t\t\t\n\t\t\t\tif (enableDebugFlag && enableDebugFlag.value) {\n\t\t\t\t\tbrowser = await puppeteer.launch({\n\t\t\t\t\t\theadless: false, // run in headless mode\n\t\t\t\t\t\tdevtools: true, // run with dev tools\n\t\t\t\t\t\targs,\n\t\t\t\t\t\tignoreDefaultArgs: [\"--disable-extensions\"]\n\t\t\t\t\t}); // run browser\n\t\t\t\t}\n\t\t\t\telse {\n\t\t\t\t\tbrowser = await puppeteer.launch({\n\t\t\t\t\t\theadless: true, // run in headless mode\n\t\t\t\t\t\tdevtools: false, // run with dev tools\n\t\t\t\t\t\targs,\n\t\t\t\t\t\tignoreDefaultArgs: [\"--disable-extensions\"]\n\t\t\t\t\t}); // run browser\n\t\t\t\t}\n\t\t\t\t\n\t\t\t\tconst page = await browser.newPage(); // create new tab\n\n\t\t\t\tlet pathToFont = '';\n\n\t\t\t\tif (fs.existsSync(path.join(__dirname, ('../private/fonts/dejavuserif.woff')))) {\n\t\t\t\t\tpathToFont = path.join(__dirname, ('../private/fonts/'));\n\t\t\t\t}\n\t\t\t\telse {\n\t\t\t\t\tif (fs.existsSync(path.join(this.clientDir, ('./private/fonts/dejavuserif.woff')))) {\n\t\t\t\t\t\tpathToFont = path.join(this.clientDir, ('./private/fonts/'));\n\t\t\t\t\t}\n\t\t\t\t\telse {\n\t\t\t\t\t\tpathToFont = '/usr/share/fonts/dejavu/';\n\t\t\t\t\t}\n\t\t\t\t}\n\n\t\t\t\tlet dejavuserif_woff = 'data:application/font-woff;base64,' + Buffer.from(fs.readFileSync(pathToFont + 'dejavuserif.woff').buffer).toString('base64');\n\t\t\t\tlet dejavuserifBold_woff = 'data:application/font-woff;base64,' + Buffer.from(fs.readFileSync(pathToFont + 'dejavuserif-bold.woff').buffer).toString('base64');\n\t\t\t\tlet dejavuserifItalic_woff = 'data:application/font-woff;base64,' + Buffer.from(fs.readFileSync(pathToFont + 'dejavuserif-italic.woff').buffer).toString('base64');\n\t\t\t\tlet dejavuserifBoldItalic_woff = 'data:application/font-woff;base64,' + Buffer.from(fs.readFileSync(pathToFont + 'dejavuserif-bolditalic.woff').buffer).toString('base64');\n\n\t\t\t\tlet content = `\n\t\t\t\t\t<head>\n\t\t\t\t\t\t<style type=\"text/css\">\n\t\t\t\t\t\t\t@font-face {\n\t\t\t\t\t\t\t\tfont-family: 'Dejavu Serif';\n\t\t\t\t\t\t\t\tfont-style: normal;\n\t\t\t\t\t\t\t\tfont-weight: normal;\n\t\t\t\t\t\t\t\tsrc: url(\"` + dejavuserif_woff + `\") format('woff');\n\t\t\t\t\t\t\t}\n\n\t\t\t\t\t\t\t@font-face {\n\t\t\t\t\t\t\t\tfont-family: 'Dejavu Serif';\n\t\t\t\t\t\t\t\tfont-style: normal;\n\t\t\t\t\t\t\t\tfont-weight: bold;\n\t\t\t\t\t\t\t\tsrc: url(\"` + dejavuserifBold_woff + `\") format('woff');\n\t\t\t\t\t\t\t}\n\n\t\t\t\t\t\t\t@font-face {\n\t\t\t\t\t\t\t\tfont-family: 'Dejavu Serif';\n\t\t\t\t\t\t\t\tfont-style: italic;\n\t\t\t\t\t\t\t\tfont-weight: normal;\n\t\t\t\t\t\t\t\tsrc: url(\"` + dejavuserifItalic_woff + `\") format('woff');\n\t\t\t\t\t\t\t}\n\n\t\t\t\t\t\t\t@font-face {\n\t\t\t\t\t\t\t\tfont-family: 'Dejavu Serif';\n\t\t\t\t\t\t\t\tfont-style: italic;\n\t\t\t\t\t\t\t\tfont-weight: bold;\n\t\t\t\t\t\t\t\tsrc: url(\"` + dejavuserifBoldItalic_woff + `\") format('woff');\n\t\t\t\t\t\t\t}\n\t\t\t\t\t\t\t\n\t\t\t\t\t\t\tbody {\n\t\t\t\t\t\t\t\tfont-family: 'Dejavu Serif', serif;\n\t\t\t\t\t\t\t\tfont-size: ` + (fontSize ? fontSize : '12px') + `;\n\t\t\t\t\t\t\t}\n\n\t\t\t\t\t\t\t.row {\n\t\t\t\t\t\t\t\tdisplay: -webkit-flex;\n\t\t\t\t\t\t\t\tdisplay: flex;\n\t\t\t\t\t\t\t\tflex-wrap: wrap;\n\t\t\t\t\t\t\t\t-webkit-flex-wrap: wrap;\n\t\t\t\t\t\t\t\tpage-break-inside: avoid !important;\n\t\t\t\t\t\t\t}\n\n\t\t\t\t\t\t\t.page-break {\n\t\t\t\t\t\t\t\tpage-break-before: always !important;\n\t\t\t\t\t\t\t\tpadding-top: 1px;\n\t\t\t\t\t\t\t}\n\n\t\t\t\t\t\t\t.cell {\n\t\t\t\t\t\t\t\tbox-sizing: border-box;\n\t\t\t\t\t\t\t\tpadding : 2px;\n\t\t\t\t\t\t\t\t-webkit-flex: 1;\n\t\t\t\t\t\t\t\tword-wrap: break-word;\n\t\t\t\t\t\t\t}\n\n\t\t\t\t\t\t\t.cell-no-padding {\n\t\t\t\t\t\t\t\tbox-sizing: border-box;\n\t\t\t\t\t\t\t\t-webkit-flex: 1;\n\t\t\t\t\t\t\t\tword-wrap: break-word;\n\t\t\t\t\t\t\t}\n\n\t\t\t\t\t\t\t.centered {\n\t\t\t\t\t\t\t\t-webkit-justify-content: center;\n\t\t\t\t\t\t\t\t-webkit-align-items: center;\n\t\t\t\t\t\t\t\tdisplay: -webkit-flex;\n\t\t\t\t\t\t\t\ttext-align: center;\n\t\t\t\t\t\t\t}\n\n\t\t\t\t\t\t\t.centered-left {\n\t\t\t\t\t\t\t\t-webkit-align-items: center;\n\t\t\t\t\t\t\t\tdisplay: -webkit-flex;\n\t\t\t\t\t\t\t\t-webkit-justify-content: flex-start;\n\t\t\t\t\t\t\t}\n\n\t\t\t\t\t\t\t.centered-right {\n\t\t\t\t\t\t\t\t-webkit-justify-content: flex-end;\n\t\t\t\t\t\t\t\t-webkit-align-items: center;\n\t\t\t\t\t\t\t\tdisplay: -webkit-flex;\n\t\t\t\t\t\t\t}\n\t\t\t\t\t\t\t\n\t\t\t\t\t\t\t.box {\n\t\t\t\t\t\t\t\tborder: 1px solid black;\n\t\t\t\t\t\t\t\tmargin: -1px 0px 0px -1px;\n\t\t\t\t\t\t\t}\n\n\t\t\t\t\t\t\t.boxNoBorder {\n\t\t\t\t\t\t\t\tmargin: -1px 0px 0px -1px;\n\t\t\t\t\t\t\t}\n\n\t\t\t\t\t\t\tpre {\n\t\t\t\t\t\t\t\twhite-space: pre-wrap; /* css-3 */\n\t\t\t\t\t\t\t\twhite-space: -moz-pre-wrap; /* Mozilla, since 1999 */\n\t\t\t\t\t\t\t\twhite-space: -pre-wrap; /* Opera 4-6 */\n\t\t\t\t\t\t\t\twhite-space: -o-pre-wrap; /* Opera 7 */\n\t\t\t\t\t\t\t\tword-wrap: break-word; /* Internet Explorer 5.5+ */\n\t\t\t\t\t\t\t\tfont-size: 12px;\n\t\t\t\t\t\t\t\tfont-family: 'Dejavu Serif'; \n\t\t\t\t\t\t\t}\n\t\t\t\t\t\t</style>\n\t\t\t\t\t</head>\n\t\t\t\t\t<body>\n\t\t\t\t` + html.replace(new RegExp('flex-basis:', 'g'), '-webkit-flex-basis:').replace(new RegExp('flex:', 'g'), '-webkit-flex:') + '</body>';\n\n\t\t\t\tawait page.setContent(content, { waitUntil: ['domcontentloaded', 'load', 'networkidle0'] });\n\t\t\t\tawait page.evaluateHandle('document.fonts.ready');\n\t\t\t\t\n\t\t\t\tlet tmpFileName = objectIdHexString() + '.pdf';\n\t\t\t\n\t\t\t\tawait page.pdf({\n\t\t\t\t\tscale: 1,\n\t\t\t\t\tlandscape: orientation === 'portrait' ? false : true,\n\t\t\t\t\tformat: 'letter',\n\t\t\t\t\tmargin: {\n\t\t\t\t\t\ttop: '1cm',\n\t\t\t\t\t\tbottom: '1cm',\n\t\t\t\t\t\tleft: '1cm',\n\t\t\t\t\t\tright: '1cm'\n\t\t\t\t\t},\n\t\t\t\t\tprintBackground: true,\n\t\t\t\t\tdisplayHeaderFooter: true,\n\t\t\t\t\theaderTemplate: `\n\t\t\t\t\t\t<style>\n\t\t\t\t\t\t\t#header { \n\t\t\t\t\t\t\t\tpadding: 0 0 10px 10px !important; \n\t\t\t\t\t\t\t}\n\t\t\t\t\t\t</style>\n\t\t\t\t\t\t<span></span>\n\t\t\t\t\t`,\n\t\t\t\t\tfooterTemplate: `\n\t\t\t\t\t\t<style>\n\t\t\t\t\t\t\t#footer { \n\t\t\t\t\t\t\t\tpadding: 0 0 10px 10px !important;\n\t\t\t\t\t\t\t\tfont-size: 10px;\n\t\t\t\t\t\t\t\tfont-family: san-serif;\n\t\t\t\t\t\t\t}\n\t\t\t\t\t\t</style>\n\t\t\t\t\t\t<div style=\"padding-bottom: 2px; padding-right: 15px; text-align: right; width: 100%;\">\n\t\t\t\t\t\t\tPage&nbsp;<span class=\"pageNumber\"></span>&nbsp;of&nbsp;<span class=\"totalPages\"></span>\n\t\t\t\t\t\t</div>\n\t\t\t\t\t`,\n\t\t\t\t\tpath: path.join(__dirname, (tmpFileName)),\n\t\t\t\t\ttimeout: 0\n\t\t\t\t});\n\n\t\t\t\tif (enableDebugFlag && enableDebugFlag.value) {\n\t\t\t\t\t// Set viewport dimensions based on orientation\n\t\t\t\t\tif (orientation === 'landscape') {\n\t\t\t\t\t\tawait page.setViewport({ width: 1100, height: 850 });\n\t\t\t\t\t} \n\t\t\t\t\telse {\n\t\t\t\t\t\tawait page.setViewport({ width: 850, height: 1100 });\n\t\t\t\t\t}\n\t\t\t\t}\n\n\t\t\t\tawait browser.close();\n\t\t\t\t\n\t\t\t\tif (fs.existsSync(path.join(__dirname, (tmpFileName)))) {\n\t\t\t\t\ttry {\n\t\t\t\t\t\tlet data = fs.readFileSync(path.join(__dirname, (tmpFileName)));\n\t\t\t\t\t\tfs.unlinkSync(path.join(__dirname, (tmpFileName)));\n\t\t\t\t\t\tif (!upload) {\n\t\t\t\t\t\t\treturn 'data:application/pdf;base64,' + Buffer.from(data).toString('base64');\n\t\t\t\t\t\t}\n\t\t\t\t\t\telse {\n\t\t\t\t\t\t\tlet fileData = 'data:application/pdf;base64,' + Buffer.from(data).toString('base64');\n\t\t\t\t\t\t\treturn this.callMethod('uploadFileAndSave', fileName, fileData, (4 * Math.ceil(fileData.length / 3)), uploadFileOrder !== null ? uploadFileOrder : -1, uploadFileType, false);\n\t\t\t\t\t\t}\n\t\t\t\t\t}\n\t\t\t\t\tcatch (errRead) {\n\t\t\t\t\t\terrRead.message = 'Error in Generate PDF: No file - ' + errRead.message;\n\t\t\t\t\t\tthrow errRead;\n\t\t\t\t\t}\n\t\t\t\t}\n\t\t\t\telse {\n\t\t\t\t\tconsole.log('No tmp file ', tmpFileName);\n\t\t\t\t\tthrow new Error('Error in Generate PDF: No tmp file');\n\t\t\t\t}\n\t\t\t},\n\t\t\tworkerTaskWeight: 2\n\t\t},\n\t\tgeneratePDFNoPageNumber: {\n\t\t\tcheck: new SimpleSchema({\n\t\t\t\thtml: {\n\t\t\t\t\ttype: String\n\t\t\t\t},\n\t\t\t\tfileName: {\n\t\t\t\t\ttype: String\n\t\t\t\t},\n\t\t\t\torientation: {\n\t\t\t\t\ttype: String,\n\t\t\t\t\toptional: true\n\t\t\t\t},\n\t\t\t\tfontSize: {\n\t\t\t\t\ttype: String,\n\t\t\t\t\toptional: true\n\t\t\t\t},\n\t\t\t\tupload: {\n\t\t\t\t\ttype: Boolean,\n\t\t\t\t\toptional: true\n\t\t\t\t},\n\t\t\t\tuploadFileOrder: {\n\t\t\t\t\ttype: Number,\n\t\t\t\t\toptional: true\n\t\t\t\t},\n\t\t\t\tuploadFileType: {\n\t\t\t\t\ttype: String,\n\t\t\t\t\toptional: true\n\t\t\t\t}\n\t\t\t}),\n\t\t\tfunction: async function(html, fileName, orientation = 'portrait', fontSize = '12px', upload = false, uploadFileOrder = -1, uploadFileType = '') {\n\t\t\t\t// console.log(new Date(), 'GENERATE PDF CALL', fileName, orientation, fontSize, upload);\n\n\t\t\t\tconst args = [\n\t\t\t\t\t\"--disable-dev-shm-usage\",\n\t\t\t\t\t\"--no-sandbox\",\n\t\t\t\t\t\"--disable-setuid-sandbox\",\n\t\t\t\t\t\"--disable-accelerated-2d-canvas\",\n\t\t\t\t\t\"--disable-gpu\",\n\t\t\t\t\t\"--allow-file-access-from-files\", \n\t\t\t\t\t\"--enable-local-file-accesses\",\n\t\t\t\t\t'--font-render-hinting=none'\n\t\t\t\t];\n\n\t\t\t\tconst browser = await puppeteer.launch({\n\t\t\t\t\theadless: true, // run in headless mode\n\t\t\t\t\tdevtools: false, // run with dev tools\n\t\t\t\t\targs,\n\t\t\t\t\tignoreDefaultArgs: [\"--disable-extensions\"]\n\t\t\t\t}); // run browser\n\t\t\t\t\n\t\t\t\tconst page = await browser.newPage(); // create new tab\n\n\t\t\t\tlet pathToFont = '';\n\n\t\t\t\tif (fs.existsSync(path.join(__dirname, ('../private/fonts/dejavuserif.woff')))) {\n\t\t\t\t\tpathToFont = path.join(__dirname, ('../private/fonts/'));\n\t\t\t\t}\n\t\t\t\telse {\n\t\t\t\t\tif (fs.existsSync(path.join(this.clientDir, ('./private/fonts/dejavuserif.woff')))) {\n\t\t\t\t\t\tpathToFont = path.join(this.clientDir, ('./private/fonts/'));\n\t\t\t\t\t}\n\t\t\t\t\telse {\n\t\t\t\t\t\tpathToFont = '/usr/share/fonts/dejavu/';\n\t\t\t\t\t}\n\t\t\t\t}\n\n\t\t\t\tlet dejavuserif_woff = 'data:application/font-woff;base64,' + Buffer.from(fs.readFileSync(pathToFont + 'dejavuserif.woff').buffer).toString('base64');\n\t\t\t\tlet dejavuserifBold_woff = 'data:application/font-woff;base64,' + Buffer.from(fs.readFileSync(pathToFont + 'dejavuserif-bold.woff').buffer).toString('base64');\n\t\t\t\tlet dejavuserifItalic_woff = 'data:application/font-woff;base64,' + Buffer.from(fs.readFileSync(pathToFont + 'dejavuserif-italic.woff').buffer).toString('base64');\n\t\t\t\tlet dejavuserifBoldItalic_woff = 'data:application/font-woff;base64,' + Buffer.from(fs.readFileSync(pathToFont + 'dejavuserif-bolditalic.woff').buffer).toString('base64');\n\n\t\t\t\tlet content = `\n\t\t\t\t\t<head>\n\t\t\t\t\t\t<style type=\"text/css\">\n\t\t\t\t\t\t\t@font-face {\n\t\t\t\t\t\t\t\tfont-family: 'Dejavu Serif';\n\t\t\t\t\t\t\t\tfont-style: normal;\n\t\t\t\t\t\t\t\tfont-weight: normal;\n\t\t\t\t\t\t\t\tsrc: url(\"` + dejavuserif_woff + `\") format('woff');\n\t\t\t\t\t\t\t}\n\n\t\t\t\t\t\t\t@font-face {\n\t\t\t\t\t\t\t\tfont-family: 'Dejavu Serif';\n\t\t\t\t\t\t\t\tfont-style: normal;\n\t\t\t\t\t\t\t\tfont-weight: bold;\n\t\t\t\t\t\t\t\tsrc: url(\"` + dejavuserifBold_woff + `\") format('woff');\n\t\t\t\t\t\t\t}\n\n\t\t\t\t\t\t\t@font-face {\n\t\t\t\t\t\t\t\tfont-family: 'Dejavu Serif';\n\t\t\t\t\t\t\t\tfont-style: italic;\n\t\t\t\t\t\t\t\tfont-weight: normal;\n\t\t\t\t\t\t\t\tsrc: url(\"` + dejavuserifItalic_woff + `\") format('woff');\n\t\t\t\t\t\t\t}\n\n\t\t\t\t\t\t\t@font-face {\n\t\t\t\t\t\t\t\tfont-family: 'Dejavu Serif';\n\t\t\t\t\t\t\t\tfont-style: italic;\n\t\t\t\t\t\t\t\tfont-weight: bold;\n\t\t\t\t\t\t\t\tsrc: url(\"` + dejavuserifBoldItalic_woff + `\") format('woff');\n\t\t\t\t\t\t\t}\n\t\t\t\t\t\t\t\n\t\t\t\t\t\t\tbody {\n\t\t\t\t\t\t\t\tfont-family: 'Dejavu Serif', serif;\n\t\t\t\t\t\t\t\tfont-size: ` + (fontSize ? fontSize : '12px') + `;\n\t\t\t\t\t\t\t}\n\n\t\t\t\t\t\t\t.row {\n\t\t\t\t\t\t\t\tdisplay: -webkit-flex;\n\t\t\t\t\t\t\t\tdisplay: flex;\n\t\t\t\t\t\t\t\tflex-wrap: wrap;\n\t\t\t\t\t\t\t\t-webkit-flex-wrap: wrap;\n\t\t\t\t\t\t\t\tpage-break-inside: avoid !important;\n\t\t\t\t\t\t\t}\n\n\t\t\t\t\t\t\t.page-break {\n\t\t\t\t\t\t\t\tpage-break-before: always !important;\n\t\t\t\t\t\t\t\tpadding-top: 1px;\n\t\t\t\t\t\t\t}\n\n\t\t\t\t\t\t\t.cell {\n\t\t\t\t\t\t\t\tbox-sizing: border-box;\n\t\t\t\t\t\t\t\tpadding : 2px;\n\t\t\t\t\t\t\t\t-webkit-flex: 1;\n\t\t\t\t\t\t\t\tword-wrap: break-word;\n\t\t\t\t\t\t\t}\n\n\t\t\t\t\t\t\t.cell-no-padding {\n\t\t\t\t\t\t\t\tbox-sizing: border-box;\n\t\t\t\t\t\t\t\t-webkit-flex: 1;\n\t\t\t\t\t\t\t\tword-wrap: break-word;\n\t\t\t\t\t\t\t}\n\n\t\t\t\t\t\t\t.centered {\n\t\t\t\t\t\t\t\t-webkit-justify-content: center;\n\t\t\t\t\t\t\t\t-webkit-align-items: center;\n\t\t\t\t\t\t\t\tdisplay: -webkit-flex;\n\t\t\t\t\t\t\t\ttext-align: center;\n\t\t\t\t\t\t\t}\n\n\t\t\t\t\t\t\t.centered-left {\n\t\t\t\t\t\t\t\t-webkit-align-items: center;\n\t\t\t\t\t\t\t\tdisplay: -webkit-flex;\n\t\t\t\t\t\t\t\t-webkit-justify-content: flex-start;\n\t\t\t\t\t\t\t}\n\n\t\t\t\t\t\t\t.centered-right {\n\t\t\t\t\t\t\t\t-webkit-justify-content: flex-end;\n\t\t\t\t\t\t\t\t-webkit-align-items: center;\n\t\t\t\t\t\t\t\tdisplay: -webkit-flex;\n\t\t\t\t\t\t\t}\n\t\t\t\t\t\t\t\n\t\t\t\t\t\t\t.box {\n\t\t\t\t\t\t\t\tborder: 1px solid black;\n\t\t\t\t\t\t\t\tmargin: -1px 0px 0px -1px;\n\t\t\t\t\t\t\t}\n\n\t\t\t\t\t\t\t.boxNoBorder {\n\t\t\t\t\t\t\t\tmargin: -1px 0px 0px -1px;\n\t\t\t\t\t\t\t}\n\n\t\t\t\t\t\t\tpre {\n\t\t\t\t\t\t\t\twhite-space: pre-wrap; /* css-3 */\n\t\t\t\t\t\t\t\twhite-space: -moz-pre-wrap; /* Mozilla, since 1999 */\n\t\t\t\t\t\t\t\twhite-space: -pre-wrap; /* Opera 4-6 */\n\t\t\t\t\t\t\t\twhite-space: -o-pre-wrap; /* Opera 7 */\n\t\t\t\t\t\t\t\tword-wrap: break-word; /* Internet Explorer 5.5+ */\n\t\t\t\t\t\t\t\tfont-size: 12px;\n\t\t\t\t\t\t\t\tfont-family: 'Dejavu Serif'; \n\t\t\t\t\t\t\t}\n\t\t\t\t\t\t</style>\n\t\t\t\t\t\t<meta charset=\"UTF-8\">\n\t\t\t\t\t</head>\n\t\t\t\t\t<body>\n\t\t\t\t` + html.replace(new RegExp('flex-basis:', 'g'), '-webkit-flex-basis:').replace(new RegExp('flex:', 'g'), '-webkit-flex:') + '</body>';\n\n\t\t\t\tawait page.setContent(content, { waitUntil: ['domcontentloaded', 'load', 'networkidle0'] });\n\t\t\t\tawait page.evaluateHandle('document.fonts.ready');\n\t\t\t\t\n\t\t\t\tlet tmpFileName = objectIdHexString() + '.pdf';\t\n\t\t\t\n\t\t\t\tawait page.pdf({\n\t\t\t\t\tscale: 1,\n\t\t\t\t\tlandscape: orientation === 'portrait' ? false : true,\n\t\t\t\t\tformat: 'letter',\n\t\t\t\t\tmargin: {\n\t\t\t\t\t\ttop: '1cm',\n\t\t\t\t\t\tbottom: '1cm',\n\t\t\t\t\t\tleft: '1cm',\n\t\t\t\t\t\tright: '1cm'\n\t\t\t\t\t},\n\t\t\t\t\tprintBackground: true,\n\t\t\t\t\tdisplayHeaderFooter: true,\n\t\t\t\t\theaderTemplate: `\n\t\t\t\t\t\t<style>\n\t\t\t\t\t\t\t#header { \n\t\t\t\t\t\t\t\tpadding: 0 0 10px 10px !important; \n\t\t\t\t\t\t\t}\n\t\t\t\t\t\t</style>\n\t\t\t\t\t\t<span></span>\n\t\t\t\t\t`,\n\t\t\t\t\tfooterTemplate: `\n\t\t\t\t\t<style>\n\t\t\t\t\t\t#footer { \n\t\t\t\t\t\t\tpadding: 0 0 10px 10px !important;\n\t\t\t\t\t\t\tfont-size: 10px;\n\t\t\t\t\t\t\tfont-family: san-serif;\n\t\t\t\t\t\t}\n\t\t\t\t\t</style>\n\t\t\t\t\t<div style=\"padding-bottom: 2px; padding-right: 15px; text-align: right; width: 100%;\">\n\t\t\t\t\t\t\n\t\t\t\t\t</div>\n\t\t\t\t\t`,\n\t\t\t\t\tpath: path.join(__dirname, (tmpFileName)),\n\t\t\t\t\ttimeout: 0\n\t\t\t\t});\n\t\t\t\tawait browser.close();\n\t\t\t\t\n\t\t\t\tif (fs.existsSync(path.join(__dirname, (tmpFileName)))) {\n\t\t\t\t\ttry {\n\t\t\t\t\t\tlet data = fs.readFileSync(path.join(__dirname, (tmpFileName)))\n\t\t\t\t\t\tfs.unlinkSync(path.join(__dirname, (tmpFileName)));\n\t\t\t\t\t\tif (!upload) {\n\t\t\t\t\t\t\treturn 'data:application/pdf;base64,' + Buffer.from(data).toString('base64');\n\t\t\t\t\t\t}\n\t\t\t\t\t\telse {\n\t\t\t\t\t\t\tlet fileData = 'data:application/pdf;base64,' + Buffer.from(data).toString('base64');\n\t\t\t\t\t\t\treturn this.callMethod('uploadFileAndSave', fileName, fileData, (4 * Math.ceil(fileData.length / 3)), uploadFileOrder !== null ? uploadFileOrder : -1, uploadFileType, false);\n\t\t\t\t\t\t}\n\t\t\t\t\t}\n\t\t\t\t\tcatch (errRead) {\n\t\t\t\t\t\terrRead.message = 'Error in Generate PDF No Page Number: No file - ' + errRead.message;\n\t\t\t\t\t\tthrow errRead;\n\t\t\t\t\t}\n\t\t\t\t}\n\t\t\t\telse {\n\t\t\t\t\tconsole.log('No tmp file ', tmpFileName);\n\t\t\t\t\tthrow new Error('Error in Generate PDF No Page Number: No tmp file');\n\t\t\t\t}\n\t\t\t},\n\t\t\tworkerTaskWeight: 2\n\t\t},\n\t\tmergePDFResolve: {\n\t\t\tcheck: new SimpleSchema({\n\t\t\t\tfileKeys: {\n\t\t\t\t\ttype: Array\n\t\t\t\t},\n\t\t\t\t'fileKeys.$': {\n\t\t\t\t\ttype: String\n\t\t\t\t},\n\t\t\t\tfileName: {\n\t\t\t\t\ttype: String\n\t\t\t\t},\n\t\t\t\tfileType: {\n\t\t\t\t\ttype: String,\n\t\t\t\t\toptional: true\n\t\t\t\t}\n\t\t\t}),\n\t\t\tfunction: async function(fileKeys: string[], fileName: string, fileType?: string) {\n\t\t\t\ttry {\n\t\t\t\t\tlet resSigneds = await this.callMethod('getSignedUrls', fileKeys, 900);\n\n\t\t\t\t\tif (resSigneds && resSigneds.length) {\n\t\t\t\t\t\tlet promises = [];\n\t\n\t\t\t\t\t\tresSigneds.forEach((signedUrl) => {\n\t\t\t\t\t\t\tpromises.push(this.callMethod('getDataURIfromURL', signedUrl));\n\t\t\t\t\t\t});\n\t\t\t\t\t\t\n\t\t\t\t\t\tlet fileDatas = await Promise.all(promises);\n\t\t\t\t\t\tconst mergedPdf = await PDFDocument.create();\n\n\t\t\t\t\t\tfor (let i = 0; i < fileDatas.length; i++) {\n\t\t\t\t\t\t\tlet fileData = fileDatas[i];\n\n\t\t\t\t\t\t\tif (fileData) {\n\t\t\t\t\t\t\t\ttry {\n\t\t\t\t\t\t\t\t\tif (fileData.startsWith('data:application/pdf;base64,')) {\n\t\t\t\t\t\t\t\t\t\tconst pdf = await PDFDocument.load(fileData, { updateMetadata: false, parseSpeed: ParseSpeeds.Fastest, ignoreEncryption: true });\n\t\t\t\t\t\t\t\t\t\tconst copiedPages = await mergedPdf.copyPages(pdf, pdf.getPageIndices());\n\t\t\t\t\t\t\t\t\t\tcopiedPages.forEach((page) => {\n\t\t\t\t\t\t\t\t\t\t\tmergedPdf.addPage(page);\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\telse if (fileData.startsWith('data:image/jpeg;base64,/9j/') || fileData.startsWith('data:image/png;base64,/9j/')) {\n\t\t\t\t\t\t\t\t\t\tconst pdf = await PDFDocument.create();\n\t\t\t\t\t\t\t\t\t\tconst img = await pdf.embedJpg(fileData);\n\t\t\t\t\t\t\t\t\t\tconst page = pdf.addPage();\n\t\t\t\t\t\t\t\t\t\tlet imgDim = img.scaleToFit(page.getWidth() * 0.75, page.getHeight() * 0.75);\n\t\t\t\t\t\t\t\t\t\tpage.drawImage(img, {\n\t\t\t\t\t\t\t\t\t\t\tx: page.getWidth() / 2 - imgDim.width / 2,\n\t\t\t\t\t\t\t\t\t\t\ty: page.getHeight() / 2 - imgDim.height / 2,\n\t\t\t\t\t\t\t\t\t\t\twidth: imgDim.width,\n\t\t\t\t\t\t\t\t\t\t\theight: imgDim.height,\n\t\t\t\t\t\t\t\t\t\t});\n\t\t\t\t\t\t\t\t\t\tconst copiedPages = await mergedPdf.copyPages(pdf, pdf.getPageIndices());\n\t\t\t\t\t\t\t\t\t\tcopiedPages.forEach((page) => {\n\t\t\t\t\t\t\t\t\t\t\tmergedPdf.addPage(page);\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\telse if (fileData.startsWith('data:image/png;base64,iVBOR')) {\n\t\t\t\t\t\t\t\t\t\tconst pdf = await PDFDocument.create();\n\t\t\t\t\t\t\t\t\t\tconst img = await pdf.embedPng(fileData);\n\t\t\t\t\t\t\t\t\t\tconst page = pdf.addPage();\n\t\t\t\t\t\t\t\t\t\tlet imgDim = img.scaleToFit(page.getWidth() * 0.75, page.getHeight() * 0.75);\n\t\t\t\t\t\t\t\t\t\tpage.drawImage(img, {\n\t\t\t\t\t\t\t\t\t\t\tx: page.getWidth() / 2 - imgDim.width / 2,\n\t\t\t\t\t\t\t\t\t\t\ty: page.getHeight() / 2 - imgDim.height / 2,\n\t\t\t\t\t\t\t\t\t\t\twidth: imgDim.width,\n\t\t\t\t\t\t\t\t\t\t\theight: imgDim.height,\n\t\t\t\t\t\t\t\t\t\t});\n\t\t\t\t\t\t\t\t\t\tconst copiedPages = await mergedPdf.copyPages(pdf, pdf.getPageIndices());\n\t\t\t\t\t\t\t\t\t\tcopiedPages.forEach((page) => {\n\t\t\t\t\t\t\t\t\t\t\tmergedPdf.addPage(page);\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\telse {\n\t\t\t\t\t\t\t\t\t\tconsole.log('Error - unsupported!!', fileData.slice(0, 60));\n\t\t\t\t\t\t\t\t\t\tthrow new Error('Error in Merge PDF Resolve: Unsupported document type - ' + fileData.slice(0, 60));\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\tcatch (error) {\n\t\t\t\t\t\t\t\t\tconsole.log('Error processing fileData:', fileData.slice(0, 60), error.message);\n\t\t\t\t\t\t\t\t\terror.message = `Error in Merge PDF Resolve: Error processing fileData: ${fileData.slice(0, 60)} - ${error.message}`;\n\t\t\t\t\t\t\t\t\tthrow error;\n\t\t\t\t\t\t\t\t}\n\t\t\t\t\t\t\t}\n\t\t\t\t\t\t\telse {\n\t\t\t\t\t\t\t\tconsole.log('Error - no filedata!!', fileData);\n\t\t\t\t\t\t\t\tthrow new Error('Error in Merge PDF Resolve: No File Data');\n\t\t\t\t\t\t\t}\n\t\t\t\t\t\t}\n\n\t\t\t\t\t\tlet mergedPDFUint8 = await mergedPdf.save();\n\n\t\t\t\t\t\tconst b64PDF = 'data:application/pdf;base64,' + Buffer.from(mergedPDFUint8).toString('base64');\n\n\t\t\t\t\t\treturn this.callMethod('uploadFileAndSave', fileName, b64PDF, (4 * Math.ceil(b64PDF.length / 3)), -1, fileType, false);\n\t\t\t\t\t}\n\t\t\t\t\telse {\n\t\t\t\t\t\t\n\t\t\t\t\t}\n\t\t\t\t}\n\t\t\t\tcatch (err) {\n\t\t\t\t\terr.message = 'Error in Merge PDF Resolve: PDF Merge - Get Signed URLs - ' + err.message;\n\t\t\t\t\t\n\t\t\t\t\tthrow err;\n\t\t\t\t}\n\t\t\t},\n\t\t\tworkerTaskWeight: 2\n\t\t},\t\t\n\t\tmergePDFResolveNoSave: {\n\t\t\tcheck: new SimpleSchema({\n\t\t\t\tfileKeys: {\n\t\t\t\t\ttype: Array\n\t\t\t\t},\n\t\t\t\t'fileKeys.$': {\n\t\t\t\t\ttype: String\n\t\t\t\t}\n\t\t\t}),\n\t\t\tfunction: async function(fileKeys: string[]) {\n\t\t\t\ttry {\n\t\t\t\t\tlet resSigneds = await this.callMethod('getSignedUrls', fileKeys, 900);\n\t\t\t\t\tif (resSigneds && resSigneds.length) {\n\t\t\t\t\t\tlet promises = [];\n\n\t\t\t\t\t\tresSigneds.forEach((signedUrl) => {\n\t\t\t\t\t\t\tpromises.push(this.callMethod('getDataURIfromURL', signedUrl));\n\t\t\t\t\t\t});\n\t\t\t\t\t\t\n\t\t\t\t\t\tlet fileDatas = await Promise.all(promises);\n\t\t\t\t\t\tconst mergedPdf = await PDFDocument.create();\n\n\t\t\t\t\t\tfor (let i = 0; i < fileDatas.length; i++) {\n\t\t\t\t\t\t\tlet fileData = fileDatas[i];\n\n\t\t\t\t\t\t\tif (fileData) {\n\t\t\t\t\t\t\t\ttry {\n\t\t\t\t\t\t\t\t\tif (fileData.startsWith('data:application/pdf;base64,')) {\n\t\t\t\t\t\t\t\t\t\tconst pdf = await PDFDocument.load(fileData, { updateMetadata: false, parseSpeed: ParseSpeeds.Fastest, ignoreEncryption: true});\n\t\t\t\t\t\t\t\t\t\tconst copiedPages = await mergedPdf.copyPages(pdf, pdf.getPageIndices());\n\t\t\t\t\t\t\t\t\t\tcopiedPages.forEach((page) => {\n\t\t\t\t\t\t\t\t\t\t\tmergedPdf.addPage(page);\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\telse if (fileData.startsWith('data:image/jpeg;base64,/9j/') || fileData.startsWith('data:image/png;base64,/9j/')) {\n\t\t\t\t\t\t\t\t\t\tconst pdf = await PDFDocument.create();\n\t\t\t\t\t\t\t\t\t\tconst img = await pdf.embedJpg(fileData);\n\t\t\t\t\t\t\t\t\t\tconst page = pdf.addPage();\n\t\t\t\t\t\t\t\t\t\tlet imgDim = img.scaleToFit(page.getWidth() * 0.75, page.getHeight() * 0.75);\n\t\t\t\t\t\t\t\t\t\tpage.drawImage(img, {\n\t\t\t\t\t\t\t\t\t\t\tx: page.getWidth() / 2 - imgDim.width / 2,\n\t\t\t\t\t\t\t\t\t\t\ty: page.getHeight() / 2 - imgDim.height / 2,\n\t\t\t\t\t\t\t\t\t\t\twidth: imgDim.width,\n\t\t\t\t\t\t\t\t\t\t\theight: imgDim.height,\n\t\t\t\t\t\t\t\t\t\t});\n\t\t\t\t\t\t\t\t\t\tconst copiedPages = await mergedPdf.copyPages(pdf, pdf.getPageIndices());\n\t\t\t\t\t\t\t\t\t\tcopiedPages.forEach((page) => {\n\t\t\t\t\t\t\t\t\t\t\tmergedPdf.addPage(page);\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\telse if (fileData.startsWith('data:image/png;base64,iVBOR')) {\n\t\t\t\t\t\t\t\t\t\tconst pdf = await PDFDocument.create();\n\t\t\t\t\t\t\t\t\t\tconst img = await pdf.embedPng(fileData);\n\t\t\t\t\t\t\t\t\t\tconst page = pdf.addPage();\n\t\t\t\t\t\t\t\t\t\tlet imgDim = img.scaleToFit(page.getWidth() * 0.75, page.getHeight() * 0.75);\n\t\t\t\t\t\t\t\t\t\tpage.drawImage(img, {\n\t\t\t\t\t\t\t\t\t\t\tx: page.getWidth() / 2 - imgDim.width / 2,\n\t\t\t\t\t\t\t\t\t\t\ty: page.getHeight() / 2 - imgDim.height / 2,\n\t\t\t\t\t\t\t\t\t\t\twidth: imgDim.width,\n\t\t\t\t\t\t\t\t\t\t\theight: imgDim.height,\n\t\t\t\t\t\t\t\t\t\t});\n\t\t\t\t\t\t\t\t\t\tconst copiedPages = await mergedPdf.copyPages(pdf, pdf.getPageIndices());\n\t\t\t\t\t\t\t\t\t\tcopiedPages.forEach((page) => {\n\t\t\t\t\t\t\t\t\t\t\tmergedPdf.addPage(page);\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\telse {\n\t\t\t\t\t\t\t\t\t\tconsole.log('Error - unsupported!!', fileData.slice(0, 60));\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\tcatch (error) {\n\t\t\t\t\t\t\t\t\tconsole.log('Error processing fileData:', fileData.slice(0, 60), error);\n\t\t\t\t\t\t\t\t}\n\t\t\t\t\t\t\t}\n\t\t\t\t\t\t\telse {\n\t\t\t\t\t\t\t\tconsole.log('Error - no filedata!!', fileData);\n\t\t\t\t\t\t\t}\n\t\t\t\t\t\t}\n\n\t\t\t\t\t\tlet mergedPDFUint8 = await mergedPdf.save();\n\n\t\t\t\t\t\tconst b64PDF = 'data:application/pdf;base64,' + Buffer.from(mergedPDFUint8).toString('base64');\n\t\t\t\t\t\t\n\t\t\t\t\t\treturn b64PDF;\n\t\t\t\t\t}\n\t\t\t\t\telse {\n\t\t\t\t\t\tthrow new Error('Error in Merge PDF Resolve No Save: No signed urls');\n\t\t\t\t\t}\n\t\t\t\t}\n\t\t\t\tcatch (err) {\n\t\t\t\t\terr.message = `Error in Merge PDF Resolve: ${err.message}`;\n\t\t\t\t\tthrow err;\n\t\t\t\t}\n\t\t\t},\n\t\t\tworkerTaskWeight: 2\n\t\t},\n\t\tmergePDFResolveHtml: {\n\t\t\tcheck: new SimpleSchema({\n\t\t\t\thtmls: {\n\t\t\t\t\ttype: Array\n\t\t\t\t},\n\t\t\t\t'htmls.$': {\n\t\t\t\t\ttype: String\n\t\t\t\t},\n\t\t\t\tfileName: {\n\t\t\t\t\ttype: String\n\t\t\t\t},\n\t\t\t\tfileType: {\n\t\t\t\t\ttype: String,\n\t\t\t\t\toptional: true\n\t\t\t\t},\n\t\t\t\tsave: {\n\t\t\t\t\ttype: Boolean,\n\t\t\t\t\toptional: true\n\t\t\t\t}\n\t\t\t}),\n\t\t\tfunction: async function(htmls: string[], fileName: string, fileType?: string, save = true) {\n\t\t\t\tconst mergedPdf = await PDFDocument.create();\n\n\t\t\t\tfor (let i = 0; i < htmls.length; i++) {\n\t\t\t\t\tlet fileData = htmls[i];\n\n\t\t\t\t\tif (fileData) {\n\t\t\t\t\t\ttry {\n\t\t\t\t\t\t\tif (fileData.startsWith('data:application/pdf;base64,')) {\n\t\t\t\t\t\t\t\tconst pdf = await PDFDocument.load(fileData, { updateMetadata: false, parseSpeed: ParseSpeeds.Fastest, ignoreEncryption: true });\n\t\t\t\t\t\t\t\tconst copiedPages = await mergedPdf.copyPages(pdf, pdf.getPageIndices());\n\t\t\t\t\t\t\t\tcopiedPages.forEach((page) => {\n\t\t\t\t\t\t\t\t\tmergedPdf.addPage(page);\n\t\t\t\t\t\t\t\t});\n\t\t\t\t\t\t\t}\n\t\t\t\t\t\t\telse if (fileData.startsWith('data:image/jpeg;base64,/9j/') || fileData.startsWith('data:image/png;base64,/9j/')) {\n\t\t\t\t\t\t\t\tconst pdf = await PDFDocument.create();\n\t\t\t\t\t\t\t\tconst img = await pdf.embedJpg(fileData);\n\t\t\t\t\t\t\t\tconst page = pdf.addPage();\n\t\t\t\t\t\t\t\tlet imgDim = img.scaleToFit(page.getWidth() * 0.75, page.getHeight() * 0.75);\n\t\t\t\t\t\t\t\tpage.drawImage(img, {\n\t\t\t\t\t\t\t\t\tx: page.getWidth() / 2 - imgDim.width / 2,\n\t\t\t\t\t\t\t\t\ty: page.getHeight() / 2 - imgDim.height / 2,\n\t\t\t\t\t\t\t\t\twidth: imgDim.width,\n\t\t\t\t\t\t\t\t\theight: imgDim.height,\n\t\t\t\t\t\t\t\t});\n\t\t\t\t\t\t\t\tconst copiedPages = await mergedPdf.copyPages(pdf, pdf.getPageIndices());\n\t\t\t\t\t\t\t\tcopiedPages.forEach((page) => {\n\t\t\t\t\t\t\t\t\tmergedPdf.addPage(page);\n\t\t\t\t\t\t\t\t});\n\t\t\t\t\t\t\t}\n\t\t\t\t\t\t\telse if (fileData.startsWith('data:image/png;base64,iVBOR')) {\n\t\t\t\t\t\t\t\tconst pdf = await PDFDocument.create();\n\t\t\t\t\t\t\t\tconst img = await pdf.embedPng(fileData);\n\t\t\t\t\t\t\t\tconst page = pdf.addPage();\n\t\t\t\t\t\t\t\tlet imgDim = img.scaleToFit(page.getWidth() * 0.75, page.getHeight() * 0.75);\n\t\t\t\t\t\t\t\tpage.drawImage(img, {\n\t\t\t\t\t\t\t\t\tx: page.getWidth() / 2 - imgDim.width / 2,\n\t\t\t\t\t\t\t\t\ty: page.getHeight() / 2 - imgDim.height / 2,\n\t\t\t\t\t\t\t\t\twidth: imgDim.width,\n\t\t\t\t\t\t\t\t\theight: imgDim.height,\n\t\t\t\t\t\t\t\t});\n\t\t\t\t\t\t\t\tconst copiedPages = await mergedPdf.copyPages(pdf, pdf.getPageIndices());\n\t\t\t\t\t\t\t\tcopiedPages.forEach((page) => {\n\t\t\t\t\t\t\t\t\tmergedPdf.addPage(page);\n\t\t\t\t\t\t\t\t});\n\t\t\t\t\t\t\t}\n\t\t\t\t\t\t\telse {\n\t\t\t\t\t\t\t\tconsole.log('Error - unsupported!!', fileData.slice(0, 60));\n\t\t\t\t\t\t\t\tthrow new Error('Error in Merge PDF Resolve HTML: Unsupported file - ' + fileData.slice(0, 60));\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.log('Error processing fileData:', fileData.slice(0, 60), error);\n\t\t\t\t\t\t\terror.message = `Error in Merge PDF Resolve HTML: Error processing filedata - ${error.message}`;\n\t\t\t\t\t\t\tthrow error;\n\t\t\t\t\t\t}\n\t\t\t\t\t}\n\t\t\t\t\telse {\n\t\t\t\t\t\tconsole.log('Error - no filedata!!', fileData);\n\t\t\t\t\t\tthrow new Error('Error in Merge PDF Resolve HTML: No File data');\n\t\t\t\t\t}\n\t\t\t\t}\n\n\t\t\t\tlet mergedPDFUint8 = await mergedPdf.save();\n\n\t\t\t\tconst b64PDF = 'data:application/pdf;base64,' + Buffer.from(mergedPDFUint8).toString('base64');\n\n\t\t\t\tif (save) {\n\t\t\t\t\treturn this.callMethod('uploadFileAndSave', fileName, b64PDF, (4 * Math.ceil(b64PDF.length / 3)), -1, fileType, false);\n\t\t\t\t}\n\t\t\t\telse {\n\t\t\t\t\treturn b64PDF;\n\t\t\t\t}\n\t\t\t},\n\t\t\tworkerTaskWeight: 2\n\t\t}\n\t});\n}"]}
@@ -13,4 +13,5 @@ export interface MethodAllModel {
13
13
  skipValidation?: boolean;
14
14
  workerTaskWeight?: number;
15
15
  skipWorker?: boolean;
16
+ bypassSession?: boolean;
16
17
  }
package/package.json CHANGED
@@ -1,6 +1,6 @@
1
1
  {
2
2
  "name": "@resolveio/server-lib",
3
- "version": "20.7.93",
3
+ "version": "20.7.95",
4
4
  "description": "",
5
5
  "scripts": {
6
6
  "package": "./build_package.sh",