@resolveio/server-lib 20.7.98 → 20.7.100
This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
- package/package.json +1 -1
- package/server-app.js +1 -1
- package/server-app.js.map +1 -1
- package/util/common.js +1 -1
- package/util/common.js.map +1 -1
package/package.json
CHANGED
package/server-app.js
CHANGED
|
@@ -1,2 +1,2 @@
|
|
|
1
|
-
"use strict";var __awaiter=this&&this.__awaiter||function(e,n,s,o){return new(s=s||Promise)(function(t,r){function fulfilled(e){try{step(o.next(e))}catch(e){r(e)}}function rejected(e){try{step(o.throw(e))}catch(e){r(e)}}function step(e){var r;e.done?t(e.value):((r=e.value)instanceof s?r:new s(function(e){e(r)})).then(fulfilled,rejected)}step((o=o.apply(e,n||[])).next())})},__generator=this&&this.__generator||function(n,s){var o,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(t){return function(e){var r=[t,e];if(o)throw new TypeError("Generator is already executing.");for(;c=l&&r[l=0]?0:c;)try{if(o=1,i&&(a=2&r[0]?i.return:r[0]?i.throw||((a=i.return)&&a.call(i),0):i.next)&&!(a=a.call(i,r[1])).done)return a;switch(i=0,(r=a?[2&r[0],a.value]:r)[0]){case 0:case 1:a=r;break;case 4:return c.label++,{value:r[1],done:!1};case 5:c.label++,i=r[1],r=[0];continue;case 7:r=c.ops.pop(),c.trys.pop();continue;default:if(!(a=0<(a=c.trys).length&&a[a.length-1])&&(6===r[0]||2===r[0])){c=0;continue}if(3===r[0]&&(!a||r[1]>a[0]&&r[1]<a[3]))c.label=r[1];else if(6===r[0]&&c.label<a[1])c.label=a[1],a=r;else{if(!(a&&c.label<a[2])){a[2]&&c.ops.pop(),c.trys.pop();continue}c.label=a[2],c.ops.push(r)}}r=s.call(n,c)}catch(e){r=[6,e],i=0}finally{o=a=0}if(5&r[0])throw r[1];return{value:r[0]?r[1]:void 0,done:!0}}}},__values=this&&this.__values||function(e){var r="function"==typeof Symbol&&Symbol.iterator,t=r&&e[r],n=0;if(t)return t.call(e);if(e&&"number"==typeof e.length)return{next:function(){return{value:(e=e&&n>=e.length?void 0:e)&&e[n++],done:!e}}};throw new TypeError(r?"Object is not iterable.":"Symbol.iterator is not defined.")},__read=this&&this.__read||function(e,r){var t="function"==typeof Symbol&&e[Symbol.iterator];if(!t)return e;var n,s,o=t.call(e),i=[];try{for(;(void 0===r||0<r--)&&!(n=o.next()).done;)i.push(n.value)}catch(e){s={error:e}}finally{try{n&&!n.done&&(t=o.return)&&t.call(o)}finally{if(s)throw s.error}}return i},__spreadArray=this&&this.__spreadArray||function(e,r,t){if(t||2===arguments.length)for(var n,s=0,o=r.length;s<o;s++)!n&&s in r||((n=n||Array.prototype.slice.call(r,0,s))[s]=r[s]);return e.concat(n||Array.prototype.slice.call(r))},bodyParser=(Object.defineProperty(exports,"__esModule",{value:!0}),exports.ResolveIOMainServer=void 0,require("body-parser")),express=require("express"),xmlParser=require("express-xml-bodyparser"),http_1=require("http"),jwt=require("jsonwebtoken"),moment=require("moment-timezone"),WebSocket=require("ws"),log_collection_1=require("./collections/log.collection"),user_collection_1=require("./collections/user.collection"),cron_manager_1=require("./managers/cron.manager"),method_manager_1=require("./managers/method.manager"),monitor_manager_1=require("./managers/monitor.manager"),subscription_manager_1=require("./managers/subscription.manager"),common_1=require("./util/common"),mongodb_1=require("mongodb"),auth_1=require("./http/auth"),health_1=require("./http/health"),home_1=require("./http/home"),websocket_manager_1=require("./managers/websocket.manager"),worker_dispatcher_manager_1=require("./managers/worker-dispatcher.manager"),worker_server_manager_1=require("./managers/worker-server.manager"),resolveio_server_app_1=require("./resolveio-server-app"),ResolveIOMainServer=function(){function ResolveIOMainServer(){this._offlineUpdates=[],this.sesMail=!1,this.standardProgram=!1,this.publicProgram=!1,this._rebootFlag=!1,this.LOGGER="ERROR",this._clientRoutes=[],this._lastErrorMsg=null,this._debugMsgRecv=0,this._debugMsgQueue=0,this._isWorkersEnabled=!1,this._isWorkerInstance=!1,this._safeShutdown=!1}return ResolveIOMainServer.create=function(){return __awaiter(this,void 0,void 0,function(){var r;return __generator(this,function(e){switch(e.label){case 0:return[4,(r=new ResolveIOMainServer).initialize()];case 1:return e.sent(),[2,r]}})})},ResolveIOMainServer.prototype.initialize=function(){return __awaiter(this,void 0,void 0,function(){var r,o,i=this;return __generator(this,function(e){switch(e.label){case 0:return this._serverStartTime=new Date,this._lastErrorMsg=null,r=this,[4,monitor_manager_1.MonitorManager.create()];case 1:return r._monitorManager=e.sent(),this._monitorManagerFunction=new monitor_manager_1.MonitorManagerFunction,this._isWorkersEnabled="true"===process.env.IS_WORKERS_ENABLED,this._isWorkerInstance="true"===process.env.IS_WORKER_INSTANCE,setInterval(function(){i._subscriptionManager&&i._subscriptionManager.getEnableDebug()&&(console.log(new Date,"Server App","Msg Recv Hits",i._debugMsgRecv),console.log(new Date,"Server App","Msg Queue Hits",i._debugMsgQueue)),i._debugMsgQueue=0,i._debugMsgRecv=0},6e4),o=!1,setTimeout(function(){o=!0},5e3),process.removeAllListeners("unhandledRejection"),process.on("unhandledRejection",function(n,s){return __awaiter(i,void 0,void 0,function(){var r,t=this;return __generator(this,function(e){switch(e.label){case 0:return!n||"MongoError"!==n.name||48!==n.code&&26!==n.code&&11e3!==n.code?!n||"MongoServerError"!==n.name||o&&26!==n.code&&11e3!==n.code&&86!==n.code?(console.error(new Date,"Unhandled Rejection at Promise",[n,s]),r=moment().diff(this._serverStartTime,"seconds"),n&&("MongoNetworkTimeoutError"===n.name||n instanceof mongodb_1.MongoNetworkTimeoutError)?60<r&&!this._lastErrorMsg?(this._lastErrorMsg=new Date,setTimeout(function(){t._lastErrorMsg=null},6e4),[4,this._methodManager.sendEmail("dev@resolveio.com","SERVER - MongoNetworkTimeoutError - Quitting NodeJS - "+resolveio_server_app_1.ResolveIOServer.getServerConfig().CLIENT_NAME,JSON.stringify({name:n.name,message:n.message,stack:n.stack},null,2))]):[3,2]:[3,3]):[2]:[2];case 1:e.sent(),process.exit(1),e.label=2;case 2:return[3,11];case 3:return n&&"MongoError"===n.name&&"not master"===n.message?60<r&&!this._lastErrorMsg?(this._lastErrorMsg=new Date,setTimeout(function(){t._lastErrorMsg=null},6e4),[4,this._methodManager.sendEmail("dev@resolveio.com","SERVER - Unhandled Rejection - Quitting NodeJS - "+resolveio_server_app_1.ResolveIOServer.getServerConfig().CLIENT_NAME,JSON.stringify([n.name,n.message,n.stack],null,2))]):[3,5]:[3,6];case 4:e.sent(),e.label=5;case 5:return process.exit(1),[3,11];case 6:return n&&"MongoError"===n.name&&"not master and slaveOk=false"===n.message?60<r&&!this._lastErrorMsg?(this._lastErrorMsg=new Date,setTimeout(function(){t._lastErrorMsg=null},6e4),[4,this._methodManager.sendEmail("dev@resolveio.com","SERVER - Unhandled Rejection - Quitting NodeJS - "+resolveio_server_app_1.ResolveIOServer.getServerConfig().CLIENT_NAME,JSON.stringify([n.name,n.message,n.stack],null,2))]):[3,8]:[3,9];case 7:e.sent(),e.label=8;case 8:return process.exit(1),[3,11];case 9:return n?"StatusError"!==n.name&&""!==n.message&&60<r&&!this._lastErrorMsg?(this._lastErrorMsg=new Date,setTimeout(function(){t._lastErrorMsg=null},6e4),[4,this._methodManager.sendEmail("dev@resolveio.com","SERVER - Unhandled Rejection - "+resolveio_server_app_1.ResolveIOServer.getServerConfig().CLIENT_NAME,JSON.stringify([n.name,n.message,n.stack],null,2))]):[3,11]:[3,11];case 10:e.sent(),e.label=11;case 11:return[2]}})})}),process.on("uncaughtException",function(t){return __awaiter(i,void 0,void 0,function(){var r=this;return __generator(this,function(e){switch(e.label){case 0:return(console.error(t,"Uncaught Exception thrown"),60<moment().diff(this._serverStartTime,"seconds")&&!this._lastErrorMsg)?(this._lastErrorMsg=new Date,setTimeout(function(){r._lastErrorMsg=null},6e4),[4,this._methodManager.sendEmail("dev@resolveio.com","SERVER - Unhandled Exception - "+resolveio_server_app_1.ResolveIOServer.getServerConfig().CLIENT_NAME,JSON.stringify([t.name,t.message,t.stack],null,2))]):[3,2];case 1:e.sent(),e.label=2;case 2:return[2]}})})}),process.on("SIGINT",function(){return __awaiter(i,void 0,void 0,function(){return __generator(this,function(e){switch(e.label){case 0:return this._rebootFlag=!0,this._serverHTTP&&this._serverHTTP.close(),[4,this.safeShutdown()];case 1:return e.sent(),[2]}})})}),process.on("SIGTERM",function(){return __awaiter(i,void 0,void 0,function(){return __generator(this,function(e){switch(e.label){case 0:return this._rebootFlag=!0,this._serverHTTP&&this._serverHTTP.close(),[4,this.safeShutdown()];case 1:return e.sent(),[2]}})})}),process.on("SIGQUIT",function(){return __awaiter(i,void 0,void 0,function(){return __generator(this,function(e){switch(e.label){case 0:return this._rebootFlag=!0,this._serverHTTP&&this._serverHTTP.close(),[4,this.safeShutdown()];case 1:return e.sent(),[2]}})})}),"DEBUG"===this.LOGGER&&console.log("Starting ResolveIO Server"),this._isWorkersEnabled?this._isWorkerInstance?(console.log("Running as a Worker instance",process.env.NODE_APP_INSTANCE),this._methodManager=method_manager_1.MethodManager.create(null,this._monitorManagerFunction,this._isWorkersEnabled,this._isWorkerInstance),this._workerServerManager=worker_server_manager_1.WorkerServerManager.create(this._methodManager,this.getServerConfig()),"0"===process.env.WORKER_INDEX&&(this._cronManager=cron_manager_1.CronManager.create())):(console.log("Running as a Server instance",process.env.NODE_APP_INSTANCE),this._websocketManager=websocket_manager_1.WebSocketManager.create(this),this._methodManager=method_manager_1.MethodManager.create(this._websocketManager,this._monitorManagerFunction,this._isWorkersEnabled,this._isWorkerInstance),this._workerDispatcherManager=worker_dispatcher_manager_1.WorkerDispatcherManager.create(this._websocketManager,this._methodManager),this._subscriptionManager=subscription_manager_1.SubscriptionManager.create(this._serverWSS,resolveio_server_app_1.ResolveIOServer.getServerConfig(),this._monitorManagerFunction),this.startServerInstance(),this.listen()):(console.log("Running with Workers Disabled",process.env.NODE_APP_INSTANCE),this._websocketManager=websocket_manager_1.WebSocketManager.create(this),this._methodManager=method_manager_1.MethodManager.create(this._websocketManager,this._monitorManagerFunction,this._isWorkersEnabled,this._isWorkerInstance),this._subscriptionManager=subscription_manager_1.SubscriptionManager.create(this._serverWSS,resolveio_server_app_1.ResolveIOServer.getServerConfig(),this._monitorManagerFunction),this._cronManager=cron_manager_1.CronManager.create(),this.startServerInstance(),this.listen()),[2]}})})},ResolveIOMainServer.prototype.startServerInstance=function(){this._app=express(),this._app.use(bodyParser.json({limit:"50mb",reviver:common_1.dateReviver})),this._app.use(bodyParser.urlencoded({limit:"50mb",extended:!0,parameterLimit:1e6})),this._app.use(xmlParser()),this._portHTTP=process.env.NODE_APP_INSTANCE?parseInt("808"+process.env.NODE_APP_INSTANCE):8080,"DEBUG"===this.LOGGER&&console.log("Setup ports"),this.createServer(),"DEBUG"===this.LOGGER&&console.log("Create server"),this._app.use(function(e,r,t){r.setHeader("Access-Control-Allow-Origin","*"),r.setHeader("Access-Control-Allow-Methods","GET, POST"),r.setHeader("Access-Control-Allow-Headers","X-Requested-With,content-type"),r.setHeader("Access-Control-Allow-Credentials","false"),t()}),"DEBUG"===this.LOGGER&&console.log("Setup cors"),(0,auth_1.setupAuthRoutes)(this,this._app,resolveio_server_app_1.ResolveIOServer.getServerConfig()),(0,health_1.setupHealthRoutes)(this._app),"ResolveIO"!==resolveio_server_app_1.ResolveIOServer.getServerConfig().CLIENT_NAME&&!this.standardProgram||(0,home_1.setupHomeRoutes)(this,this._app,resolveio_server_app_1.ResolveIOServer.getServerConfig()),"DEBUG"===this.LOGGER&&console.log("Setup express routes")},ResolveIOMainServer.prototype.safeShutdown=function(){return __awaiter(this,void 0,void 0,function(){var r=this;return __generator(this,function(e){switch(e.label){case 0:if(this._safeShutdown||console.log(new Date,"Safe Shutdown Command Received"),this._monitorManagerFunction.getActiveMonitorFunctions().length||this._offlineUpdates.length||this._workerDispatcherManager&&!this._workerDispatcherManager.isSafeShutdown())return[3,7];if(!resolveio_server_app_1.ResolveIOServer.getMongoConnection())return[3,5];e.label=1;case 1:return e.trys.push([1,3,,4]),[4,resolveio_server_app_1.ResolveIOServer.getMongoConnection().close(!1)];case 2:return e.sent(),console.log(new Date,"Safe Exit Complete, Process Exit"),process.exit(0),[3,4];case 3:return e.sent(),process.exit(1),[3,4];case 4:return[3,6];case 5:process.exit(0),e.label=6;case 6:return[3,8];case 7:this._safeShutdown||(this._safeShutdown=!0,setTimeout(function(){r._safeShutdown=!1},1e3),console.log(new Date,"Safe Exit In Progress",this._monitorManagerFunction.getActiveMonitorFunctions().length,this._offlineUpdates.length)),setImmediate(function(){return __awaiter(r,void 0,void 0,function(){return __generator(this,function(e){switch(e.label){case 0:return[4,this.safeShutdown()];case 1:return e.sent(),[2]}})})}),e.label=8;case 8:return[2]}})})},ResolveIOMainServer.prototype.getIsWorkersEnabled=function(){return this._isWorkersEnabled},ResolveIOMainServer.prototype.getIsWorkerInstance=function(){return this._isWorkerInstance},ResolveIOMainServer.prototype.getWSList=function(){var r=[];return this._serverWSS.clients.forEach(function(e){r.push(e.id_socket)}),r},ResolveIOMainServer.prototype.getWSUserList=function(){var r=[];return this._serverWSS.clients.forEach(function(e){r.push(e.id_user)}),r},ResolveIOMainServer.prototype.getHTTPServer=function(){return this._serverHTTP},ResolveIOMainServer.prototype.getCronManager=function(){return this._cronManager},ResolveIOMainServer.prototype.getMethodManager=function(){return this._methodManager},ResolveIOMainServer.prototype.getSubscriptionManager=function(){return this._subscriptionManager},ResolveIOMainServer.prototype.getMonitorManager=function(){return this._monitorManager},ResolveIOMainServer.prototype.getRebootFlag=function(){return this._rebootFlag},ResolveIOMainServer.prototype.getWebSocketManager=function(){return this._websocketManager},ResolveIOMainServer.prototype.createServer=function(){var r=this;this._serverHTTP=(0,http_1.createServer)(this._app),this._serverHTTP.keepAliveTimeout=65e3,this._serverHTTP.headersTimeout=66e3,this._serverWSS=new WebSocket.Server({server:this._serverHTTP,verifyClient:this.publicProgram?null:function(s,o){var e;r._rebootFlag?o(!1,409,"Unable To Process"):("DEBUG"===r.LOGGER&&console.log("Verify Client",s,o),s.req.url&&s.req.url.includes("workerToken=")?(s.req.url.split("workerToken=")[1]||"")===resolveio_server_app_1.ResolveIOServer.getServerConfig().WORKER_TOKEN?o(!0):o(!1,401,"Unauthorized"):(e=s.req.headers["sec-websocket-protocol"].split(/,/),(s.origin===resolveio_server_app_1.ResolveIOServer.getServerConfig().ROOT_URL||s.origin===resolveio_server_app_1.ResolveIOServer.getServerConfig().SEC_ROOT_URL||s.origin===resolveio_server_app_1.ResolveIOServer.getServerConfig().RESOLVEIO_URL||s.origin===resolveio_server_app_1.ResolveIOServer.getServerConfig().RESOLVEIO_SECONDARY_URL)&&(e=e[0])?jwt.verify(e,resolveio_server_app_1.ResolveIOServer.getServerConfig().JWT_SECRET,function(t,n){return __awaiter(r,void 0,void 0,function(){var r;return __generator(this,function(e){switch(e.label){case 0:return t?(o(!1,401,"Unauthorized"),[3,5]):[3,1];case 1:s.req.id_user=n.id_user,e.label=2;case 2:return e.trys.push([2,4,,5]),[4,user_collection_1.Users.findById(n.id_user)];case 3:return(r=e.sent())?(s.req.user=r.fullname,s.req.user_readonly=r.readonly||!1,s.req.doc_user=r,o(!0)):o(!1),[3,5];case 4:return e.sent(),o(!1),[3,5];case 5:return[2]}})})}):o(!1,401,"Unauthorized")))}})},ResolveIOMainServer.prototype.listen=function(){var e=this;this._serverHTTP.listen(this._portHTTP,function(){console.log("Running HTTP/WS server on port %s",e._portHTTP)}),this._serverWSS.on("connection",function(o,i){return __awaiter(e,void 0,void 0,function(){var r,t,n,s=this;return __generator(this,function(e){switch(e.label){case 0:return i.url&&i.url.includes("workerToken=")?(r=(0,common_1.objectIdHexString)(),o.id_worker=r,console.log(new Date,process.env.NODE_APP_INSTANCE,"Worker Connected",process.env.NODE_APP_INSTANCE),this._workerDispatcherManager.addWorker(o),n=null,this._workerDispatcherManager.sendWorkerPayload(o,"ping"),t=setInterval(function(){n?(n=null,s._workerDispatcherManager.sendWorkerPayload(o,"ping")):(s._workerDispatcherManager.disconnectWorker(o.id_worker),o.close())},3e4),o.on("message",function(e){"ping"===(e="string"!=typeof e?e.toString():e)?s._workerDispatcherManager.sendWorkerPayload(o,"pong"):"pong"===e?n=new Date:s._workerDispatcherManager.handleWorkerMessage(o.id_worker,e)}),o.on("close",function(){s._workerDispatcherManager.disconnectWorker(o.id_worker),console.log(new Date,"Worker disconnected:",r),t&&clearInterval(t)}),o.on("error",function(e){s._workerDispatcherManager.disconnectWorker(o.id_worker),console.error("Error on WS Worker",e),o.close()}),[3,3]):[3,1];case 1:return o.id_socket=(0,common_1.objectIdHexString)(),o.id_user=i.id_user,o.user=i.user,o.user_readonly=i.user_readonly,o.doc_user=i.doc_user,this._websocketManager.addWebSocket(o),[4,this._subscriptionManager.createLoggedInUser(o.id_socket)];case 2:e.sent(),setTimeout(function(){o.pingTime=new Date,o.send("ping",function(r){return __awaiter(s,void 0,void 0,function(){return __generator(this,function(e){switch(e.label){case 0:return r?(this._subscriptionManager.getEnableDebug()&&console.log(new Date,"Server App","Error WS Ping"),[4,this.unsubscribeWS(o)]):[3,2];case 1:e.sent(),e.label=2;case 2:return[2]}})})})},5e3),"DEBUG"===this.LOGGER&&console.log("Connection from user: "+i.user),o.isAlive=!0,o.retryCnt=0,o.on("message",function(n){return __awaiter(s,void 0,void 0,function(){var r,t;return __generator(this,function(e){switch(e.label){case 0:this._debugMsgRecv+=1,r=[],e.label=1;case 1:return e.trys.push([1,2,,4]),r=JSON.parse(n,common_1.dateReviver),[3,4];case 2:return t=e.sent(),console.log("Error - JSON.parse",n),[4,this._methodManager.sendEmail("dev@resolveio.com","SERVER - JSON Parse Error - "+resolveio_server_app_1.ResolveIOServer.getServerConfig().CLIENT_NAME,JSON.stringify([n,t]))];case 3:return e.sent(),[2];case 4:return[4,this.processSocketMessage(o,r)];case 5:return e.sent(),[2]}})})}).on("end",function(){o.close()}).on("error",function(){o.close()}).on("close",function(){return __awaiter(s,void 0,void 0,function(){return __generator(this,function(e){switch(e.label){case 0:return[4,this.unsubscribeWS(o)];case 1:return e.sent(),[2]}})})}),e.label=3;case 3:return[2]}})})}),setInterval(function(){return __awaiter(e,void 0,void 0,function(){var r,n,t,s,o,i,a,c=this;return __generator(this,function(e){switch(e.label){case 0:r=function(t){return __generator(this,function(e){switch(e.label){case 0:return t.pingTime&&2e4<=Date.now()-t.pingTime.getTime()?!1!==t.isAlive?[3,4]:(t.retryCnt++,3<=t.retryCnt?[4,n.unsubscribeWS(t)]:[3,2]):[3,5];case 1:return e.sent(),[3,3];case 2:t.pingTime=new Date,t.send("ping",function(r){return __awaiter(c,void 0,void 0,function(){return __generator(this,function(e){switch(e.label){case 0:return r?(this._subscriptionManager.getEnableDebug()&&console.log(new Date,"Server App","Error WS Ping"),[4,this.unsubscribeWS(t)]):[3,2];case 1:e.sent(),e.label=2;case 2:return[2]}})})}),e.label=3;case 3:return[3,5];case 4:t.retryCnt=0,t.isAlive=!1,t.pingTime=new Date,t.send("ping",function(r){return __awaiter(c,void 0,void 0,function(){return __generator(this,function(e){switch(e.label){case 0:return r?(this._subscriptionManager.getEnableDebug()&&console.log(new Date,"Server App","Error WS Ping"),[4,this.unsubscribeWS(t)]):[3,2];case 1:e.sent(),e.label=2;case 2:return[2]}})})}),e.label=5;case 5:return[2]}})},n=this,e.label=1;case 1:e.trys.push([1,6,7,8]),t=__values(this._serverWSS.clients),s=t.next(),e.label=2;case 2:return s.done?[3,5]:(o=s.value,[5,r(o)]);case 3:e.sent(),e.label=4;case 4:return s=t.next(),[3,2];case 5:return[3,8];case 6:return o=e.sent(),i={error:o},[3,8];case 7:try{s&&!s.done&&(a=t.return)&&a.call(t)}finally{if(i)throw i.error}return[7];case 8:return[2]}})})},2e4)},ResolveIOMainServer.prototype.processSocketMessage=function(i,a){return __awaiter(this,void 0,void 0,function(){var r,t,n,s,o;return __generator(this,function(e){switch(e.label){case 0:if("string"==typeof a&&"ping"===a)return i&&i.readyState===i.OPEN&&i.send("pong"),[2];if("string"==typeof a&&"pong"===a)return i.isAlive=!0,i.pongTime=new Date,i.latency=moment.duration(moment(i.pongTime).diff(i.pingTime)).asMilliseconds(),this._subscriptionManager.loggedInLatency(i),[2];if(!Array.isArray(a[0]))return console.log("Invalid message format (expected array of arrays)",a),[2];e.label=1;case 1:e.trys.push([1,6,7,8]),r=__values(a),t=r.next(),e.label=2;case 2:return t.done?[3,5]:(n=t.value,[4,this.handleClientMessage(i,n)]);case 3:e.sent(),e.label=4;case 4:return t=r.next(),[3,2];case 5:return[3,8];case 6:return n=e.sent(),s={error:n},[3,8];case 7:try{t&&!t.done&&(o=r.return)&&o.call(r)}finally{if(s)throw s.error}return[7];case 8:return[2]}})})},ResolveIOMainServer.prototype.handleClientMessage=function(p,f){return __awaiter(this,void 0,void 0,function(){var r,t,n,s,o,i,a,c,l,u,_,g,h,d,v;return __generator(this,function(e){switch(e.label){case 0:return(r=f[0],t=f[1],n=f[2],s=f[3],this.publicProgram||!this._clientRoutes.some(function(e){return r.includes(e)})||p.doc_user.roles.groups.some(function(e){return e.views.some(function(e){return r.includes(e)||e.includes(r)})})||p.doc_user.roles.super_admin)?"subscription"!==s?[3,4]:(i=f[4],o=f[5],"sub"!==i?[3,2]:[4,this._subscriptionManager.subscribe(r,t,p,n,o,f.slice(6))]):[2];case 1:return e.sent(),[3,3];case 2:this._subscriptionManager.unsubscribe(r,t,p,n,o,f.slice(6)),e.label=3;case 3:return[3,22];case 4:if(this.publicProgram||"offline"!==s)return[3,16];i={messageId:n,hasError:!1,data:"ACK"},p&&p.readyState===p.OPEN&&this._websocketManager.send(p,i),this._offlineUpdates.push(p),a=f[4],c=0,e.label=5;case 5:if(!(c<a.length))return[3,15];if(l=a[c],l=l.data,l.shift(),l.shift(),v=l.shift(),l.shift(),d=l.shift(),v={messageId:v,hasError:!1,data:"ACK"},p&&p.readyState===p.OPEN&&this._websocketManager.send(p,v),"insertDocument"===d&&"driver-gps"===l[0])return[3,14];if("reportBuilderGetResults"!==d&&"reportBuilderGetDistinctValue"!==d&&"reportBuilderBuildTree"!==d&&"generatePDF"!==d&&"getWOOfflineData"!==d&&"countQuery"!==d&&"countWithQuery"!==d&&"countCollectionWithQuery"!==d&&"find"!==d&&"findOne"!==d&&"findWithOptions"!==d&&"getDrivers"!==d&&"processAirdropDistribution"!==d&&"qbHandleResponse"!==d){if("https://resolveio.com"===resolveio_server_app_1.ResolveIOServer.getServerConfig().ROOT_URL||"http://localhost:4200"===resolveio_server_app_1.ResolveIOServer.getServerConfig().ROOT_URL)return[3,6];resolveio_server_app_1.ResolveIOServer.getLocalLogManager().writeLog({type:"log",data:{_id:(0,common_1.objectIdHexString)(),createdAt:new Date,type:"client-request",collection:"",id_document:"",payload:(0,common_1.getBinarySize)(JSON.stringify([l]))<1e6?JSON.stringify([l],null,2):"Too Big",method:d,id_user:p.id_user||"",user:p.user||"",messageId:n,route:r}})}return[3,8];case 6:return[4,log_collection_1.Logs.insertOne({_id:(0,common_1.objectIdHexString)(),type:"client-request",collection:"",id_document:"",payload:(0,common_1.getBinarySize)(JSON.stringify([l]))<1e6?JSON.stringify([l],null,2):"Too Big",method:d,id_user:p.id_user||"",user:p.user||"",messageId:n,route:r,client:"ResolveIO",instance:"backend.resolveio.com",instance_index:process.env.NODE_APP_INSTANCE||""})];case 7:e.sent(),e.label=8;case 8:if(!this._methodManager._methods[d])return[3,13];e.label=9;case 9:return e.trys.push([9,11,,12]),[4,(v=this._methodManager.callMethod).call.apply(v,__spreadArray([Object.assign({},this._methodManager,method_manager_1.MethodManager.prototype,{id_user:p.id_user,user:p.user,id_ws:p.id_socket}),d],__read(l),!1))];case 10:return e.sent(),[3,12];case 11:return h=e.sent(),console.log(new Date,"Offline Error",JSON.stringify(h,null,2)),[3,12];case 12:return"updateDocumentOffline"!==d&&"updateDocumentPropsOffline"!==d||resolveio_server_app_1.ResolveIOServer.getMongoManager().invalidateQueryCache(l[0]),[3,14];case 13:console.log("Offline - Could not find method: "+d),e.label=14;case 14:return c++,[3,5];case 15:return this._offlineUpdates.splice(this._offlineUpdates.map(function(e){return e.id_socket}).indexOf(p.id_socket),1),[3,22];case 16:if(u=__spreadArray([],__read(f),!1),u.shift(),u.shift(),_=u.shift(),"method"!==u.shift())return[3,22];if(g=u.shift(),p.user_readonly)return[2];if("reportBuilderGetResults"!==g&&"reportBuilderGetDistinctValue"!==g&&"reportBuilderBuildTree"!==g&&"generatePDF"!==g&&"getWOOfflineData"!==g&&"countQuery"!==g&&"countWithQuery"!==g&&"countCollectionWithQuery"!==g&&"find"!==g&&"findOne"!==g&&"findWithOptions"!==g&&"getDrivers"!==g&&"processAirdropDistribution"!==g){if("https://resolveio.com"===resolveio_server_app_1.ResolveIOServer.getServerConfig().ROOT_URL||"http://localhost:4200"===resolveio_server_app_1.ResolveIOServer.getServerConfig().ROOT_URL)return[3,17];resolveio_server_app_1.ResolveIOServer.getLocalLogManager().writeLog({type:"log",data:{_id:(0,common_1.objectIdHexString)(),createdAt:new Date,type:"client-request",collection:"",id_document:"",payload:(0,common_1.getBinarySize)(JSON.stringify([u]))<1e6?JSON.stringify([u],null,2):"Too Big",method:g,id_user:p.id_user||"",user:p.user||"",messageId:n,route:r}})}return[3,19];case 17:return[4,log_collection_1.Logs.insertOne({_id:(0,common_1.objectIdHexString)(),type:"client-request",collection:"",id_document:"",payload:(0,common_1.getBinarySize)(JSON.stringify([u]))<1e6?JSON.stringify([u],null,2):"Too Big",method:g,id_user:p.id_user||"",user:p.user||"",messageId:n,route:r,client:"ResolveIO",instance:"backend.resolveio.com",instance_index:process.env.NODE_APP_INSTANCE||""})];case 18:e.sent(),e.label=19;case 19:return(h={messageId:_,hasError:!1,data:"ACK"},p&&p.readyState===p.OPEN&&this._websocketManager.send(p,h),(d=this._methodManager.getMethod(g))&&!d.skipWorker&&this._isWorkersEnabled&&"find"!==g&&"insertDocument"!==g&&"countWithQuery"!==g&&"findOne"!==g&&"updateDocumentProps"!==g&&"findWithOptions"!==g&&"updateDocument"!==g&&"insertErrorLog"!==g&&"removeDocument"!==g&&"supportCreateBillingUser"!==g&&"getSignedUrl"!==g&&"getSignedUrls"!==g&&"getSignedUrlWithId"!==g&&"incorrectUser"!==g&&"reloadWS"!==g&&"reconnectWS"!==g&&"disconnectWS"!==g)?(this._workerDispatcherManager.sendClientTask(_,g,u,{id_user:p.id_user,user:p.user,id_ws:p.id_socket}),[3,22]):[3,20];case 20:return[4,this.callMethodLocally(p,_,g,u)];case 21:e.sent(),e.label=22;case 22:return[2]}})})},ResolveIOMainServer.prototype.callMethodLocally=function(s,o,i,a){return __awaiter(this,void 0,void 0,function(){var r,t,n;return __generator(this,function(e){switch(e.label){case 0:r={messageId:o,hasError:!1,data:null},e.label=1;case 1:return e.trys.push([1,3,,4]),[4,(n=this._methodManager.callMethod).call.apply(n,__spreadArray([Object.assign({},this._methodManager,method_manager_1.MethodManager.prototype,{id_user:s.id_user,user:s.user,id_ws:s.id_socket}),i],__read(a),!1))];case 2:return n=e.sent(),r.data=n,[3,4];case 3:return t=e.sent(),r.hasError=!0,r.data=t||"Unknown error",[3,4];case 4:return s&&s.readyState===s.OPEN&&this._websocketManager.send(s,r),[2]}})})},ResolveIOMainServer.prototype.unsubscribeWS=function(r){return __awaiter(this,void 0,void 0,function(){return __generator(this,function(e){switch(e.label){case 0:return this._subscriptionManager&&this._subscriptionManager.getEnableDebug()&&console.log(new Date,"Server App","Unsub WS",r.user,r.id_socket),[4,this._subscriptionManager.unsubscribeAll(r)];case 1:return e.sent(),r.removeAllListeners(),r=null,[2]}})})},ResolveIOMainServer.prototype.getApp=function(){return this._app},ResolveIOMainServer.prototype.getServerConfig=function(){return resolveio_server_app_1.ResolveIOServer.getServerConfig()},ResolveIOMainServer.prototype.getWorkerDispatcherManager=function(){return this._workerDispatcherManager},ResolveIOMainServer.prototype.getWorkerServerManager=function(){return this._workerServerManager},ResolveIOMainServer}();exports.ResolveIOMainServer=ResolveIOMainServer;
|
|
1
|
+
"use strict";var __awaiter=this&&this.__awaiter||function(e,n,s,o){return new(s=s||Promise)(function(t,r){function fulfilled(e){try{step(o.next(e))}catch(e){r(e)}}function rejected(e){try{step(o.throw(e))}catch(e){r(e)}}function step(e){var r;e.done?t(e.value):((r=e.value)instanceof s?r:new s(function(e){e(r)})).then(fulfilled,rejected)}step((o=o.apply(e,n||[])).next())})},__generator=this&&this.__generator||function(n,s){var o,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(t){return function(e){var r=[t,e];if(o)throw new TypeError("Generator is already executing.");for(;c=l&&r[l=0]?0:c;)try{if(o=1,i&&(a=2&r[0]?i.return:r[0]?i.throw||((a=i.return)&&a.call(i),0):i.next)&&!(a=a.call(i,r[1])).done)return a;switch(i=0,(r=a?[2&r[0],a.value]:r)[0]){case 0:case 1:a=r;break;case 4:return c.label++,{value:r[1],done:!1};case 5:c.label++,i=r[1],r=[0];continue;case 7:r=c.ops.pop(),c.trys.pop();continue;default:if(!(a=0<(a=c.trys).length&&a[a.length-1])&&(6===r[0]||2===r[0])){c=0;continue}if(3===r[0]&&(!a||r[1]>a[0]&&r[1]<a[3]))c.label=r[1];else if(6===r[0]&&c.label<a[1])c.label=a[1],a=r;else{if(!(a&&c.label<a[2])){a[2]&&c.ops.pop(),c.trys.pop();continue}c.label=a[2],c.ops.push(r)}}r=s.call(n,c)}catch(e){r=[6,e],i=0}finally{o=a=0}if(5&r[0])throw r[1];return{value:r[0]?r[1]:void 0,done:!0}}}},__values=this&&this.__values||function(e){var r="function"==typeof Symbol&&Symbol.iterator,t=r&&e[r],n=0;if(t)return t.call(e);if(e&&"number"==typeof e.length)return{next:function(){return{value:(e=e&&n>=e.length?void 0:e)&&e[n++],done:!e}}};throw new TypeError(r?"Object is not iterable.":"Symbol.iterator is not defined.")},__read=this&&this.__read||function(e,r){var t="function"==typeof Symbol&&e[Symbol.iterator];if(!t)return e;var n,s,o=t.call(e),i=[];try{for(;(void 0===r||0<r--)&&!(n=o.next()).done;)i.push(n.value)}catch(e){s={error:e}}finally{try{n&&!n.done&&(t=o.return)&&t.call(o)}finally{if(s)throw s.error}}return i},__spreadArray=this&&this.__spreadArray||function(e,r,t){if(t||2===arguments.length)for(var n,s=0,o=r.length;s<o;s++)!n&&s in r||((n=n||Array.prototype.slice.call(r,0,s))[s]=r[s]);return e.concat(n||Array.prototype.slice.call(r))},bodyParser=(Object.defineProperty(exports,"__esModule",{value:!0}),exports.ResolveIOMainServer=void 0,require("body-parser")),express=require("express"),xmlParser=require("express-xml-bodyparser"),http_1=require("http"),jwt=require("jsonwebtoken"),moment=require("moment-timezone"),WebSocket=require("ws"),log_collection_1=require("./collections/log.collection"),user_collection_1=require("./collections/user.collection"),cron_manager_1=require("./managers/cron.manager"),method_manager_1=require("./managers/method.manager"),monitor_manager_1=require("./managers/monitor.manager"),subscription_manager_1=require("./managers/subscription.manager"),common_1=require("./util/common"),mongodb_1=require("mongodb"),auth_1=require("./http/auth"),health_1=require("./http/health"),home_1=require("./http/home"),websocket_manager_1=require("./managers/websocket.manager"),worker_dispatcher_manager_1=require("./managers/worker-dispatcher.manager"),worker_server_manager_1=require("./managers/worker-server.manager"),resolveio_server_app_1=require("./resolveio-server-app"),ResolveIOMainServer=function(){function ResolveIOMainServer(){this._offlineUpdates=[],this.sesMail=!1,this.standardProgram=!1,this.publicProgram=!1,this._rebootFlag=!1,this.LOGGER="ERROR",this._clientRoutes=[],this._lastErrorMsg=null,this._debugMsgRecv=0,this._debugMsgQueue=0,this._isWorkersEnabled=!1,this._isWorkerInstance=!1,this._safeShutdown=!1}return ResolveIOMainServer.create=function(){return __awaiter(this,void 0,void 0,function(){var r;return __generator(this,function(e){switch(e.label){case 0:return[4,(r=new ResolveIOMainServer).initialize()];case 1:return e.sent(),[2,r]}})})},ResolveIOMainServer.prototype.initialize=function(){return __awaiter(this,void 0,void 0,function(){var r,o,i=this;return __generator(this,function(e){switch(e.label){case 0:return this._serverStartTime=new Date,this._lastErrorMsg=null,r=this,[4,monitor_manager_1.MonitorManager.create()];case 1:return r._monitorManager=e.sent(),this._monitorManagerFunction=new monitor_manager_1.MonitorManagerFunction,this._isWorkersEnabled="true"===process.env.IS_WORKERS_ENABLED,this._isWorkerInstance="true"===process.env.IS_WORKER_INSTANCE,setInterval(function(){i._subscriptionManager&&i._subscriptionManager.getEnableDebug()&&(console.log(new Date,"Server App","Msg Recv Hits",i._debugMsgRecv),console.log(new Date,"Server App","Msg Queue Hits",i._debugMsgQueue)),i._debugMsgQueue=0,i._debugMsgRecv=0},6e4),o=!1,setTimeout(function(){o=!0},5e3),process.removeAllListeners("unhandledRejection"),process.on("unhandledRejection",function(n,s){return __awaiter(i,void 0,void 0,function(){var r,t=this;return __generator(this,function(e){switch(e.label){case 0:return!n||"MongoError"!==n.name||48!==n.code&&26!==n.code&&11e3!==n.code&&251!==n.code?!n||"MongoServerError"!==n.name||o&&26!==n.code&&11e3!==n.code&&86!==n.code&&251!==n.code?(console.error(new Date,"Unhandled Rejection at Promise",[n,s]),r=moment().diff(this._serverStartTime,"seconds"),n&&("MongoNetworkTimeoutError"===n.name||n instanceof mongodb_1.MongoNetworkTimeoutError)?60<r&&!this._lastErrorMsg?(this._lastErrorMsg=new Date,setTimeout(function(){t._lastErrorMsg=null},6e4),[4,this._methodManager.sendEmail("dev@resolveio.com","SERVER - MongoNetworkTimeoutError - Quitting NodeJS - "+resolveio_server_app_1.ResolveIOServer.getServerConfig().CLIENT_NAME,JSON.stringify({name:n.name,message:n.message,stack:n.stack},null,2))]):[3,2]:[3,3]):[2]:[2];case 1:e.sent(),process.exit(1),e.label=2;case 2:return[3,11];case 3:return n&&"MongoError"===n.name&&"not master"===n.message?60<r&&!this._lastErrorMsg?(this._lastErrorMsg=new Date,setTimeout(function(){t._lastErrorMsg=null},6e4),[4,this._methodManager.sendEmail("dev@resolveio.com","SERVER - Unhandled Rejection - Quitting NodeJS - "+resolveio_server_app_1.ResolveIOServer.getServerConfig().CLIENT_NAME,JSON.stringify([n.name,n.message,n.stack],null,2))]):[3,5]:[3,6];case 4:e.sent(),e.label=5;case 5:return process.exit(1),[3,11];case 6:return n&&"MongoError"===n.name&&"not master and slaveOk=false"===n.message?60<r&&!this._lastErrorMsg?(this._lastErrorMsg=new Date,setTimeout(function(){t._lastErrorMsg=null},6e4),[4,this._methodManager.sendEmail("dev@resolveio.com","SERVER - Unhandled Rejection - Quitting NodeJS - "+resolveio_server_app_1.ResolveIOServer.getServerConfig().CLIENT_NAME,JSON.stringify([n.name,n.message,n.stack],null,2))]):[3,8]:[3,9];case 7:e.sent(),e.label=8;case 8:return process.exit(1),[3,11];case 9:return n?"StatusError"!==n.name&&""!==n.message&&60<r&&!this._lastErrorMsg?(this._lastErrorMsg=new Date,setTimeout(function(){t._lastErrorMsg=null},6e4),[4,this._methodManager.sendEmail("dev@resolveio.com","SERVER - Unhandled Rejection - "+resolveio_server_app_1.ResolveIOServer.getServerConfig().CLIENT_NAME,JSON.stringify([n.name,n.message,n.stack],null,2))]):[3,11]:[3,11];case 10:e.sent(),e.label=11;case 11:return[2]}})})}),process.on("uncaughtException",function(t){return __awaiter(i,void 0,void 0,function(){var r=this;return __generator(this,function(e){switch(e.label){case 0:return(console.error(t,"Uncaught Exception thrown"),60<moment().diff(this._serverStartTime,"seconds")&&!this._lastErrorMsg)?(this._lastErrorMsg=new Date,setTimeout(function(){r._lastErrorMsg=null},6e4),[4,this._methodManager.sendEmail("dev@resolveio.com","SERVER - Unhandled Exception - "+resolveio_server_app_1.ResolveIOServer.getServerConfig().CLIENT_NAME,JSON.stringify([t.name,t.message,t.stack],null,2))]):[3,2];case 1:e.sent(),e.label=2;case 2:return[2]}})})}),process.on("SIGINT",function(){return __awaiter(i,void 0,void 0,function(){return __generator(this,function(e){switch(e.label){case 0:return this._rebootFlag=!0,this._serverHTTP&&this._serverHTTP.close(),[4,this.safeShutdown()];case 1:return e.sent(),[2]}})})}),process.on("SIGTERM",function(){return __awaiter(i,void 0,void 0,function(){return __generator(this,function(e){switch(e.label){case 0:return this._rebootFlag=!0,this._serverHTTP&&this._serverHTTP.close(),[4,this.safeShutdown()];case 1:return e.sent(),[2]}})})}),process.on("SIGQUIT",function(){return __awaiter(i,void 0,void 0,function(){return __generator(this,function(e){switch(e.label){case 0:return this._rebootFlag=!0,this._serverHTTP&&this._serverHTTP.close(),[4,this.safeShutdown()];case 1:return e.sent(),[2]}})})}),"DEBUG"===this.LOGGER&&console.log("Starting ResolveIO Server"),this._isWorkersEnabled?this._isWorkerInstance?(console.log("Running as a Worker instance",process.env.NODE_APP_INSTANCE),this._methodManager=method_manager_1.MethodManager.create(null,this._monitorManagerFunction,this._isWorkersEnabled,this._isWorkerInstance),this._workerServerManager=worker_server_manager_1.WorkerServerManager.create(this._methodManager,this.getServerConfig()),"0"===process.env.WORKER_INDEX&&(this._cronManager=cron_manager_1.CronManager.create())):(console.log("Running as a Server instance",process.env.NODE_APP_INSTANCE),this._websocketManager=websocket_manager_1.WebSocketManager.create(this),this._methodManager=method_manager_1.MethodManager.create(this._websocketManager,this._monitorManagerFunction,this._isWorkersEnabled,this._isWorkerInstance),this._workerDispatcherManager=worker_dispatcher_manager_1.WorkerDispatcherManager.create(this._websocketManager,this._methodManager),this._subscriptionManager=subscription_manager_1.SubscriptionManager.create(this._serverWSS,resolveio_server_app_1.ResolveIOServer.getServerConfig(),this._monitorManagerFunction),this.startServerInstance(),this.listen()):(console.log("Running with Workers Disabled",process.env.NODE_APP_INSTANCE),this._websocketManager=websocket_manager_1.WebSocketManager.create(this),this._methodManager=method_manager_1.MethodManager.create(this._websocketManager,this._monitorManagerFunction,this._isWorkersEnabled,this._isWorkerInstance),this._subscriptionManager=subscription_manager_1.SubscriptionManager.create(this._serverWSS,resolveio_server_app_1.ResolveIOServer.getServerConfig(),this._monitorManagerFunction),this._cronManager=cron_manager_1.CronManager.create(),this.startServerInstance(),this.listen()),[2]}})})},ResolveIOMainServer.prototype.startServerInstance=function(){this._app=express(),this._app.use(bodyParser.json({limit:"50mb",reviver:common_1.dateReviver})),this._app.use(bodyParser.urlencoded({limit:"50mb",extended:!0,parameterLimit:1e6})),this._app.use(xmlParser()),this._portHTTP=process.env.NODE_APP_INSTANCE?parseInt("808"+process.env.NODE_APP_INSTANCE):8080,"DEBUG"===this.LOGGER&&console.log("Setup ports"),this.createServer(),"DEBUG"===this.LOGGER&&console.log("Create server"),this._app.use(function(e,r,t){r.setHeader("Access-Control-Allow-Origin","*"),r.setHeader("Access-Control-Allow-Methods","GET, POST"),r.setHeader("Access-Control-Allow-Headers","X-Requested-With,content-type"),r.setHeader("Access-Control-Allow-Credentials","false"),t()}),"DEBUG"===this.LOGGER&&console.log("Setup cors"),(0,auth_1.setupAuthRoutes)(this,this._app,resolveio_server_app_1.ResolveIOServer.getServerConfig()),(0,health_1.setupHealthRoutes)(this._app),"ResolveIO"!==resolveio_server_app_1.ResolveIOServer.getServerConfig().CLIENT_NAME&&!this.standardProgram||(0,home_1.setupHomeRoutes)(this,this._app,resolveio_server_app_1.ResolveIOServer.getServerConfig()),"DEBUG"===this.LOGGER&&console.log("Setup express routes")},ResolveIOMainServer.prototype.safeShutdown=function(){return __awaiter(this,void 0,void 0,function(){var r=this;return __generator(this,function(e){switch(e.label){case 0:if(this._safeShutdown||console.log(new Date,"Safe Shutdown Command Received"),this._monitorManagerFunction.getActiveMonitorFunctions().length||this._offlineUpdates.length||this._workerDispatcherManager&&!this._workerDispatcherManager.isSafeShutdown())return[3,7];if(!resolveio_server_app_1.ResolveIOServer.getMongoConnection())return[3,5];e.label=1;case 1:return e.trys.push([1,3,,4]),[4,resolveio_server_app_1.ResolveIOServer.getMongoConnection().close(!1)];case 2:return e.sent(),console.log(new Date,"Safe Exit Complete, Process Exit"),process.exit(0),[3,4];case 3:return e.sent(),process.exit(1),[3,4];case 4:return[3,6];case 5:process.exit(0),e.label=6;case 6:return[3,8];case 7:this._safeShutdown||(this._safeShutdown=!0,setTimeout(function(){r._safeShutdown=!1},1e3),console.log(new Date,"Safe Exit In Progress",this._monitorManagerFunction.getActiveMonitorFunctions().length,this._offlineUpdates.length)),setImmediate(function(){return __awaiter(r,void 0,void 0,function(){return __generator(this,function(e){switch(e.label){case 0:return[4,this.safeShutdown()];case 1:return e.sent(),[2]}})})}),e.label=8;case 8:return[2]}})})},ResolveIOMainServer.prototype.getIsWorkersEnabled=function(){return this._isWorkersEnabled},ResolveIOMainServer.prototype.getIsWorkerInstance=function(){return this._isWorkerInstance},ResolveIOMainServer.prototype.getWSList=function(){var r=[];return this._serverWSS.clients.forEach(function(e){r.push(e.id_socket)}),r},ResolveIOMainServer.prototype.getWSUserList=function(){var r=[];return this._serverWSS.clients.forEach(function(e){r.push(e.id_user)}),r},ResolveIOMainServer.prototype.getHTTPServer=function(){return this._serverHTTP},ResolveIOMainServer.prototype.getCronManager=function(){return this._cronManager},ResolveIOMainServer.prototype.getMethodManager=function(){return this._methodManager},ResolveIOMainServer.prototype.getSubscriptionManager=function(){return this._subscriptionManager},ResolveIOMainServer.prototype.getMonitorManager=function(){return this._monitorManager},ResolveIOMainServer.prototype.getRebootFlag=function(){return this._rebootFlag},ResolveIOMainServer.prototype.getWebSocketManager=function(){return this._websocketManager},ResolveIOMainServer.prototype.createServer=function(){var r=this;this._serverHTTP=(0,http_1.createServer)(this._app),this._serverHTTP.keepAliveTimeout=65e3,this._serverHTTP.headersTimeout=66e3,this._serverWSS=new WebSocket.Server({server:this._serverHTTP,verifyClient:this.publicProgram?null:function(s,o){var e;r._rebootFlag?o(!1,409,"Unable To Process"):("DEBUG"===r.LOGGER&&console.log("Verify Client",s,o),s.req.url&&s.req.url.includes("workerToken=")?(s.req.url.split("workerToken=")[1]||"")===resolveio_server_app_1.ResolveIOServer.getServerConfig().WORKER_TOKEN?o(!0):o(!1,401,"Unauthorized"):(e=s.req.headers["sec-websocket-protocol"].split(/,/),(s.origin===resolveio_server_app_1.ResolveIOServer.getServerConfig().ROOT_URL||s.origin===resolveio_server_app_1.ResolveIOServer.getServerConfig().SEC_ROOT_URL||s.origin===resolveio_server_app_1.ResolveIOServer.getServerConfig().RESOLVEIO_URL||s.origin===resolveio_server_app_1.ResolveIOServer.getServerConfig().RESOLVEIO_SECONDARY_URL)&&(e=e[0])?jwt.verify(e,resolveio_server_app_1.ResolveIOServer.getServerConfig().JWT_SECRET,function(t,n){return __awaiter(r,void 0,void 0,function(){var r;return __generator(this,function(e){switch(e.label){case 0:return t?(o(!1,401,"Unauthorized"),[3,5]):[3,1];case 1:s.req.id_user=n.id_user,e.label=2;case 2:return e.trys.push([2,4,,5]),[4,user_collection_1.Users.findById(n.id_user)];case 3:return(r=e.sent())?(s.req.user=r.fullname,s.req.user_readonly=r.readonly||!1,s.req.doc_user=r,o(!0)):o(!1),[3,5];case 4:return e.sent(),o(!1),[3,5];case 5:return[2]}})})}):o(!1,401,"Unauthorized")))}})},ResolveIOMainServer.prototype.listen=function(){var e=this;this._serverHTTP.listen(this._portHTTP,function(){console.log("Running HTTP/WS server on port %s",e._portHTTP)}),this._serverWSS.on("connection",function(o,i){return __awaiter(e,void 0,void 0,function(){var r,t,n,s=this;return __generator(this,function(e){switch(e.label){case 0:return i.url&&i.url.includes("workerToken=")?(r=(0,common_1.objectIdHexString)(),o.id_worker=r,console.log(new Date,process.env.NODE_APP_INSTANCE,"Worker Connected",process.env.NODE_APP_INSTANCE),this._workerDispatcherManager.addWorker(o),n=null,this._workerDispatcherManager.sendWorkerPayload(o,"ping"),t=setInterval(function(){n?(n=null,s._workerDispatcherManager.sendWorkerPayload(o,"ping")):(s._workerDispatcherManager.disconnectWorker(o.id_worker),o.close())},3e4),o.on("message",function(e){"ping"===(e="string"!=typeof e?e.toString():e)?s._workerDispatcherManager.sendWorkerPayload(o,"pong"):"pong"===e?n=new Date:s._workerDispatcherManager.handleWorkerMessage(o.id_worker,e)}),o.on("close",function(){s._workerDispatcherManager.disconnectWorker(o.id_worker),console.log(new Date,"Worker disconnected:",r),t&&clearInterval(t)}),o.on("error",function(e){s._workerDispatcherManager.disconnectWorker(o.id_worker),console.error("Error on WS Worker",e),o.close()}),[3,3]):[3,1];case 1:return o.id_socket=(0,common_1.objectIdHexString)(),o.id_user=i.id_user,o.user=i.user,o.user_readonly=i.user_readonly,o.doc_user=i.doc_user,this._websocketManager.addWebSocket(o),[4,this._subscriptionManager.createLoggedInUser(o.id_socket)];case 2:e.sent(),setTimeout(function(){o.pingTime=new Date,o.send("ping",function(r){return __awaiter(s,void 0,void 0,function(){return __generator(this,function(e){switch(e.label){case 0:return r?(this._subscriptionManager.getEnableDebug()&&console.log(new Date,"Server App","Error WS Ping"),[4,this.unsubscribeWS(o)]):[3,2];case 1:e.sent(),e.label=2;case 2:return[2]}})})})},5e3),"DEBUG"===this.LOGGER&&console.log("Connection from user: "+i.user),o.isAlive=!0,o.retryCnt=0,o.on("message",function(n){return __awaiter(s,void 0,void 0,function(){var r,t;return __generator(this,function(e){switch(e.label){case 0:this._debugMsgRecv+=1,r=[],e.label=1;case 1:return e.trys.push([1,2,,4]),r=JSON.parse(n,common_1.dateReviver),[3,4];case 2:return t=e.sent(),console.log("Error - JSON.parse",n),[4,this._methodManager.sendEmail("dev@resolveio.com","SERVER - JSON Parse Error - "+resolveio_server_app_1.ResolveIOServer.getServerConfig().CLIENT_NAME,JSON.stringify([n,t]))];case 3:return e.sent(),[2];case 4:return[4,this.processSocketMessage(o,r)];case 5:return e.sent(),[2]}})})}).on("end",function(){o.close()}).on("error",function(){o.close()}).on("close",function(){return __awaiter(s,void 0,void 0,function(){return __generator(this,function(e){switch(e.label){case 0:return[4,this.unsubscribeWS(o)];case 1:return e.sent(),[2]}})})}),e.label=3;case 3:return[2]}})})}),setInterval(function(){return __awaiter(e,void 0,void 0,function(){var r,n,t,s,o,i,a,c=this;return __generator(this,function(e){switch(e.label){case 0:r=function(t){return __generator(this,function(e){switch(e.label){case 0:return t.pingTime&&2e4<=Date.now()-t.pingTime.getTime()?!1!==t.isAlive?[3,4]:(t.retryCnt++,3<=t.retryCnt?[4,n.unsubscribeWS(t)]:[3,2]):[3,5];case 1:return e.sent(),[3,3];case 2:t.pingTime=new Date,t.send("ping",function(r){return __awaiter(c,void 0,void 0,function(){return __generator(this,function(e){switch(e.label){case 0:return r?(this._subscriptionManager.getEnableDebug()&&console.log(new Date,"Server App","Error WS Ping"),[4,this.unsubscribeWS(t)]):[3,2];case 1:e.sent(),e.label=2;case 2:return[2]}})})}),e.label=3;case 3:return[3,5];case 4:t.retryCnt=0,t.isAlive=!1,t.pingTime=new Date,t.send("ping",function(r){return __awaiter(c,void 0,void 0,function(){return __generator(this,function(e){switch(e.label){case 0:return r?(this._subscriptionManager.getEnableDebug()&&console.log(new Date,"Server App","Error WS Ping"),[4,this.unsubscribeWS(t)]):[3,2];case 1:e.sent(),e.label=2;case 2:return[2]}})})}),e.label=5;case 5:return[2]}})},n=this,e.label=1;case 1:e.trys.push([1,6,7,8]),t=__values(this._serverWSS.clients),s=t.next(),e.label=2;case 2:return s.done?[3,5]:(o=s.value,[5,r(o)]);case 3:e.sent(),e.label=4;case 4:return s=t.next(),[3,2];case 5:return[3,8];case 6:return o=e.sent(),i={error:o},[3,8];case 7:try{s&&!s.done&&(a=t.return)&&a.call(t)}finally{if(i)throw i.error}return[7];case 8:return[2]}})})},2e4)},ResolveIOMainServer.prototype.processSocketMessage=function(i,a){return __awaiter(this,void 0,void 0,function(){var r,t,n,s,o;return __generator(this,function(e){switch(e.label){case 0:if("string"==typeof a&&"ping"===a)return i&&i.readyState===i.OPEN&&i.send("pong"),[2];if("string"==typeof a&&"pong"===a)return i.isAlive=!0,i.pongTime=new Date,i.latency=moment.duration(moment(i.pongTime).diff(i.pingTime)).asMilliseconds(),this._subscriptionManager.loggedInLatency(i),[2];if(!Array.isArray(a[0]))return console.log("Invalid message format (expected array of arrays)",a),[2];e.label=1;case 1:e.trys.push([1,6,7,8]),r=__values(a),t=r.next(),e.label=2;case 2:return t.done?[3,5]:(n=t.value,[4,this.handleClientMessage(i,n)]);case 3:e.sent(),e.label=4;case 4:return t=r.next(),[3,2];case 5:return[3,8];case 6:return n=e.sent(),s={error:n},[3,8];case 7:try{t&&!t.done&&(o=r.return)&&o.call(r)}finally{if(s)throw s.error}return[7];case 8:return[2]}})})},ResolveIOMainServer.prototype.handleClientMessage=function(p,f){return __awaiter(this,void 0,void 0,function(){var r,t,n,s,o,i,a,c,l,u,_,g,h,d,v;return __generator(this,function(e){switch(e.label){case 0:return(r=f[0],t=f[1],n=f[2],s=f[3],this.publicProgram||!this._clientRoutes.some(function(e){return r.includes(e)})||p.doc_user.roles.groups.some(function(e){return e.views.some(function(e){return r.includes(e)||e.includes(r)})})||p.doc_user.roles.super_admin)?"subscription"!==s?[3,4]:(i=f[4],o=f[5],"sub"!==i?[3,2]:[4,this._subscriptionManager.subscribe(r,t,p,n,o,f.slice(6))]):[2];case 1:return e.sent(),[3,3];case 2:this._subscriptionManager.unsubscribe(r,t,p,n,o,f.slice(6)),e.label=3;case 3:return[3,22];case 4:if(this.publicProgram||"offline"!==s)return[3,16];i={messageId:n,hasError:!1,data:"ACK"},p&&p.readyState===p.OPEN&&this._websocketManager.send(p,i),this._offlineUpdates.push(p),a=f[4],c=0,e.label=5;case 5:if(!(c<a.length))return[3,15];if(l=a[c],l=l.data,l.shift(),l.shift(),v=l.shift(),l.shift(),d=l.shift(),v={messageId:v,hasError:!1,data:"ACK"},p&&p.readyState===p.OPEN&&this._websocketManager.send(p,v),"insertDocument"===d&&"driver-gps"===l[0])return[3,14];if("reportBuilderGetResults"!==d&&"reportBuilderGetDistinctValue"!==d&&"reportBuilderBuildTree"!==d&&"generatePDF"!==d&&"getWOOfflineData"!==d&&"countQuery"!==d&&"countWithQuery"!==d&&"countCollectionWithQuery"!==d&&"find"!==d&&"findOne"!==d&&"findWithOptions"!==d&&"getDrivers"!==d&&"processAirdropDistribution"!==d&&"qbHandleResponse"!==d){if("https://resolveio.com"===resolveio_server_app_1.ResolveIOServer.getServerConfig().ROOT_URL||"http://localhost:4200"===resolveio_server_app_1.ResolveIOServer.getServerConfig().ROOT_URL)return[3,6];resolveio_server_app_1.ResolveIOServer.getLocalLogManager().writeLog({type:"log",data:{_id:(0,common_1.objectIdHexString)(),createdAt:new Date,type:"client-request",collection:"",id_document:"",payload:(0,common_1.getBinarySize)(JSON.stringify([l]))<1e6?JSON.stringify([l],null,2):"Too Big",method:d,id_user:p.id_user||"",user:p.user||"",messageId:n,route:r}})}return[3,8];case 6:return[4,log_collection_1.Logs.insertOne({_id:(0,common_1.objectIdHexString)(),type:"client-request",collection:"",id_document:"",payload:(0,common_1.getBinarySize)(JSON.stringify([l]))<1e6?JSON.stringify([l],null,2):"Too Big",method:d,id_user:p.id_user||"",user:p.user||"",messageId:n,route:r,client:"ResolveIO",instance:"backend.resolveio.com",instance_index:process.env.NODE_APP_INSTANCE||""})];case 7:e.sent(),e.label=8;case 8:if(!this._methodManager._methods[d])return[3,13];e.label=9;case 9:return e.trys.push([9,11,,12]),[4,(v=this._methodManager.callMethod).call.apply(v,__spreadArray([Object.assign({},this._methodManager,method_manager_1.MethodManager.prototype,{id_user:p.id_user,user:p.user,id_ws:p.id_socket}),d],__read(l),!1))];case 10:return e.sent(),[3,12];case 11:return h=e.sent(),console.log(new Date,"Offline Error",JSON.stringify(h,null,2)),[3,12];case 12:return"updateDocumentOffline"!==d&&"updateDocumentPropsOffline"!==d||resolveio_server_app_1.ResolveIOServer.getMongoManager().invalidateQueryCache(l[0]),[3,14];case 13:console.log("Offline - Could not find method: "+d),e.label=14;case 14:return c++,[3,5];case 15:return this._offlineUpdates.splice(this._offlineUpdates.map(function(e){return e.id_socket}).indexOf(p.id_socket),1),[3,22];case 16:if(u=__spreadArray([],__read(f),!1),u.shift(),u.shift(),_=u.shift(),"method"!==u.shift())return[3,22];if(g=u.shift(),p.user_readonly)return[2];if("reportBuilderGetResults"!==g&&"reportBuilderGetDistinctValue"!==g&&"reportBuilderBuildTree"!==g&&"generatePDF"!==g&&"getWOOfflineData"!==g&&"countQuery"!==g&&"countWithQuery"!==g&&"countCollectionWithQuery"!==g&&"find"!==g&&"findOne"!==g&&"findWithOptions"!==g&&"getDrivers"!==g&&"processAirdropDistribution"!==g){if("https://resolveio.com"===resolveio_server_app_1.ResolveIOServer.getServerConfig().ROOT_URL||"http://localhost:4200"===resolveio_server_app_1.ResolveIOServer.getServerConfig().ROOT_URL)return[3,17];resolveio_server_app_1.ResolveIOServer.getLocalLogManager().writeLog({type:"log",data:{_id:(0,common_1.objectIdHexString)(),createdAt:new Date,type:"client-request",collection:"",id_document:"",payload:(0,common_1.getBinarySize)(JSON.stringify([u]))<1e6?JSON.stringify([u],null,2):"Too Big",method:g,id_user:p.id_user||"",user:p.user||"",messageId:n,route:r}})}return[3,19];case 17:return[4,log_collection_1.Logs.insertOne({_id:(0,common_1.objectIdHexString)(),type:"client-request",collection:"",id_document:"",payload:(0,common_1.getBinarySize)(JSON.stringify([u]))<1e6?JSON.stringify([u],null,2):"Too Big",method:g,id_user:p.id_user||"",user:p.user||"",messageId:n,route:r,client:"ResolveIO",instance:"backend.resolveio.com",instance_index:process.env.NODE_APP_INSTANCE||""})];case 18:e.sent(),e.label=19;case 19:return(h={messageId:_,hasError:!1,data:"ACK"},p&&p.readyState===p.OPEN&&this._websocketManager.send(p,h),(d=this._methodManager.getMethod(g))&&!d.skipWorker&&this._isWorkersEnabled&&"find"!==g&&"insertDocument"!==g&&"countWithQuery"!==g&&"findOne"!==g&&"updateDocumentProps"!==g&&"findWithOptions"!==g&&"updateDocument"!==g&&"insertErrorLog"!==g&&"removeDocument"!==g&&"supportCreateBillingUser"!==g&&"getSignedUrl"!==g&&"getSignedUrls"!==g&&"getSignedUrlWithId"!==g&&"incorrectUser"!==g&&"reloadWS"!==g&&"reconnectWS"!==g&&"disconnectWS"!==g)?(this._workerDispatcherManager.sendClientTask(_,g,u,{id_user:p.id_user,user:p.user,id_ws:p.id_socket}),[3,22]):[3,20];case 20:return[4,this.callMethodLocally(p,_,g,u)];case 21:e.sent(),e.label=22;case 22:return[2]}})})},ResolveIOMainServer.prototype.callMethodLocally=function(s,o,i,a){return __awaiter(this,void 0,void 0,function(){var r,t,n;return __generator(this,function(e){switch(e.label){case 0:r={messageId:o,hasError:!1,data:null},e.label=1;case 1:return e.trys.push([1,3,,4]),[4,(n=this._methodManager.callMethod).call.apply(n,__spreadArray([Object.assign({},this._methodManager,method_manager_1.MethodManager.prototype,{id_user:s.id_user,user:s.user,id_ws:s.id_socket}),i],__read(a),!1))];case 2:return n=e.sent(),r.data=n,[3,4];case 3:return t=e.sent(),r.hasError=!0,r.data=t||"Unknown error",[3,4];case 4:return s&&s.readyState===s.OPEN&&this._websocketManager.send(s,r),[2]}})})},ResolveIOMainServer.prototype.unsubscribeWS=function(r){return __awaiter(this,void 0,void 0,function(){return __generator(this,function(e){switch(e.label){case 0:return this._subscriptionManager&&this._subscriptionManager.getEnableDebug()&&console.log(new Date,"Server App","Unsub WS",r.user,r.id_socket),[4,this._subscriptionManager.unsubscribeAll(r)];case 1:return e.sent(),r.removeAllListeners(),r=null,[2]}})})},ResolveIOMainServer.prototype.getApp=function(){return this._app},ResolveIOMainServer.prototype.getServerConfig=function(){return resolveio_server_app_1.ResolveIOServer.getServerConfig()},ResolveIOMainServer.prototype.getWorkerDispatcherManager=function(){return this._workerDispatcherManager},ResolveIOMainServer.prototype.getWorkerServerManager=function(){return this._workerServerManager},ResolveIOMainServer}();exports.ResolveIOMainServer=ResolveIOMainServer;
|
|
2
2
|
//# sourceMappingURL=server-app.js.map
|
package/server-app.js.map
CHANGED
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"sources":["../../src/server-app.ts"],"names":["bodyParser","require","express","xmlParser","http_1","jwt","moment","WebSocket","log_collection_1","user_collection_1","cron_manager_1","method_manager_1","monitor_manager_1","subscription_manager_1","common_1","mongodb_1","auth_1","health_1","home_1","websocket_manager_1","worker_dispatcher_manager_1","worker_server_manager_1","resolveio_server_app_1","ResolveIOMainServer","this","_offlineUpdates","sesMail","standardProgram","publicProgram","_rebootFlag","LOGGER","_clientRoutes","_lastErrorMsg","_debugMsgRecv","_debugMsgQueue","_isWorkersEnabled","_isWorkerInstance","_safeShutdown","create","resolveioMainServer","initialize","_a","sent","prototype","_serverStartTime","Date","MonitorManager","_monitorManager","_b","_monitorManagerFunction","MonitorManagerFunction","process","env","IS_WORKERS_ENABLED","IS_WORKER_INSTANCE","setInterval","_this","_subscriptionManager","getEnableDebug","console","log","initServerFlag","setTimeout","removeAllListeners","on","error","rej","__awaiter","diffTimeSec","diff","MongoNetworkTimeoutError","_methodManager","sendEmail","ResolveIOServer","getServerConfig","JSON","stringify","name","message","stack","exit","_serverHTTP","close","safeShutdown","NODE_APP_INSTANCE","MethodManager","_workerServerManager","WorkerServerManager","WORKER_INDEX","_cronManager","CronManager","_websocketManager","WebSocketManager","_workerDispatcherManager","WorkerDispatcherManager","SubscriptionManager","_serverWSS","startServerInstance","listen","_app","use","json","limit","reviver","dateReviver","urlencoded","extended","parameterLimit","_portHTTP","parseInt","createServer","req","res","next","setHeader","setupAuthRoutes","setupHealthRoutes","setupHomeRoutes","getActiveMonitorFunctions","length","isSafeShutdown","getMongoConnection","setImmediate","getIsWorkersEnabled","getIsWorkerInstance","getWSList","clients","forEach","ws","push","getWSUserList","getHTTPServer","getCronManager","getMethodManager","getSubscriptionManager","getMonitorManager","getRebootFlag","getWebSocketManager","keepAliveTimeout","headersTimeout","Server","server","verifyClient","info","cb","token","url","includes","split","infoData","headers","origin","verify","err","decoded","Users","findById","user","fullname","readonly","workerId_1","objectIdHexString","addWorker","lastComm_1","sendWorkerPayload","interval_1","disconnectWorker","toString","handleWorkerMessage","clearInterval","addWebSocket","createLoggedInUser","send","unsubscribeWS","socketData","parse","e_1","processSocketMessage","now","getTime","this_1","_e","__values","value","readyState","OPEN","duration","asMilliseconds","loggedInLatency","Array","isArray","socketData_1","socketData_1_1","handleClientMessage","msg","messageRoute","messageDate","messageId","type","some","a","roles","groups","views","b","super_admin","subType","pub","subscribe","slice","unsubscribe","serverRes","hasError","data","offlineUpdates","i","update","shift","updateMessageId","method","serverResMethod","getLocalLogManager","writeLog","_id","createdAt","collection","id_document","payload","getBinarySize","id_user","route","Logs","insertOne","client","instance","instance_index","_methods","callMethod","call","apply","__spreadArray","Object","assign","id_ws","__read","err_1","getMongoManager","invalidateQueryCache","splice","map","indexOf","dataCopy","msgId","methodName","ack","getMethod","skipWorker","sendClientTask","callMethodLocally","params","result","err_2","unsubscribeAll","getApp","getWorkerDispatcherManager","getWorkerServerManager","exports"],"mappings":"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","file":"server-app.js","sourcesContent":["import * as bodyParser from 'body-parser';\nimport * as express from 'express';\nimport * as xmlParser from 'express-xml-bodyparser';\nimport { createServer, Server } from 'http';\nimport * as jwt from 'jsonwebtoken';\nimport * as moment from 'moment-timezone';\nimport * as WebSocket from 'ws';\n\nimport { Logs } from './collections/log.collection';\nimport { Users } from './collections/user.collection';\nimport { CronManager } from './managers/cron.manager';\nimport { MethodManager } from './managers/method.manager';\nimport { MonitorManager, MonitorManagerFunction } from './managers/monitor.manager';\nimport { SubscriptionManager } from './managers/subscription.manager';\nimport { ServerResponseModel } from './models/server-message.model';\nimport { dateReviver, getBinarySize, objectIdHexString } from './util/common';\n\nimport { MongoNetworkTimeoutError } from 'mongodb';\nimport { setupAuthRoutes } from './http/auth';\nimport { setupHealthRoutes } from './http/health';\nimport { setupHomeRoutes } from './http/home';\n\nimport { WebSocketManager } from './managers/websocket.manager';\nimport { WorkerDispatcherManager } from './managers/worker-dispatcher.manager';\nimport { WorkerServerManager } from './managers/worker-server.manager';\nimport { ResolveIOServer } from './resolveio-server-app';\n\nexport class ResolveIOMainServer {\n\tprivate _app: express.Application;\n\tprivate _serverHTTP: Server;\n\tprivate _portHTTP: string | number;\n\tprivate _serverWSS: WebSocket.Server;\n\tprivate _offlineUpdates = [];\n\tpublic sesMail = false;\n\tprivate standardProgram = false;\n\tprivate publicProgram = false;\n\tprivate _rebootFlag = false;\n\n\tprivate LOGGER = 'ERROR'; //ERROR / DEBUG\n\n\tprivate _websocketManager: WebSocketManager;\n\tprivate _monitorManager: MonitorManager;\n\tprivate _monitorManagerFunction: MonitorManagerFunction;\n\tprivate _subscriptionManager: SubscriptionManager;\n\tprivate _methodManager: MethodManager;\n\tprivate _cronManager: CronManager;\n\tprivate _clientRoutes: string[] = [];\n\tprivate _workerDispatcherManager: WorkerDispatcherManager;\n\tprivate _workerServerManager: WorkerServerManager;\n\n\tprivate _serverStartTime: Date;\n\tprivate _lastErrorMsg: Date = null;\n\n\tprivate _debugMsgRecv = 0;\n\tprivate _debugMsgQueue = 0;\n\n\tprivate _isWorkersEnabled = false;\n\tprivate _isWorkerInstance = false;\n\n\tprivate _safeShutdown = false;\n\n\tconstructor() {}\n\n\tstatic async create() {\n\t\tconst resolveioMainServer = new ResolveIOMainServer();\n\t\tawait resolveioMainServer.initialize();\n\t\treturn resolveioMainServer;\n\t}\n\n\tprivate async initialize() {\n\t\tthis._serverStartTime = new Date();\n\t\tthis._lastErrorMsg = null;\n\t\tthis._monitorManager = await MonitorManager.create();\n\t\tthis._monitorManagerFunction = new MonitorManagerFunction();\n\n\t\t// Check for workers and decide what to start\n\t\tthis._isWorkersEnabled = process.env.IS_WORKERS_ENABLED === 'true';\n\t\tthis._isWorkerInstance = process.env.IS_WORKER_INSTANCE === 'true';\n\n\t\tsetInterval(() => {\n\t\t\tif (this._subscriptionManager && this._subscriptionManager.getEnableDebug()) {\n\t\t\t\tconsole.log(new Date(), 'Server App', 'Msg Recv Hits', this._debugMsgRecv);\n\t\t\t\tconsole.log(new Date(), 'Server App', 'Msg Queue Hits', this._debugMsgQueue);\n\t\t\t}\n\n\t\t\tthis._debugMsgQueue = 0;\n\t\t\tthis._debugMsgRecv = 0;\n\t\t}, 60000);\n\n\t\tlet initServerFlag = false;\n\n\t\tsetTimeout(() => {\n\t\t\tinitServerFlag = true;\n\t\t}, 5000);\n\n\t\tprocess.removeAllListeners('unhandledRejection');\n\n\t\tprocess.on('unhandledRejection', async (error, rej) => {\n\t\t\t// Condition to filter out the MongoError with code 48 (NamespaceExists)\n\t\t\tif (error && error['name'] === 'MongoError' && (error['code'] === 48 || error['code'] === 26 || error['code'] === 11000)) {\n\t\t\t\treturn; // Simply return without doing anything further\n\t\t\t}\n\n\t\t\tif (error && error['name'] === 'MongoServerError' && (!initServerFlag || error['code'] === 26 || error['code'] === 11000 || error['code'] === 86)) {\n\t\t\t\treturn; // Simply return without doing anything further\n\t\t\t}\n\n\t\t\tconsole.error(new Date(), 'Unhandled Rejection at Promise', [error, rej]);\n\t\t\t\n\t\t\tlet diffTimeSec = moment().diff(this._serverStartTime, 'seconds');\n\n\t\t\t// If this is a MongoNetworkTimeoutError, handle it specifically\n\t\t\tif (error && (error['name'] === 'MongoNetworkTimeoutError' || error instanceof MongoNetworkTimeoutError)) {\n\t\t\t\tif (diffTimeSec > 60 && !this._lastErrorMsg) {\n\t\t\t\t\tthis._lastErrorMsg = new Date();\n\t\t\t\t\tsetTimeout(() => {\n\t\t\t\t\t\tthis._lastErrorMsg = null;\n\t\t\t\t\t}, 60000);\n\n\t\t\t\t\t// Sending email notification (using your existing method)\n\t\t\t\t\tawait this._methodManager.sendEmail('dev@resolveio.com', 'SERVER - MongoNetworkTimeoutError - Quitting NodeJS - ' + ResolveIOServer.getServerConfig()['CLIENT_NAME'], JSON.stringify({\n\t\t\t\t\t\tname: error['name'],\n\t\t\t\t\t\tmessage: error['message'],\n\t\t\t\t\t\tstack: error['stack']\n\t\t\t\t\t}, null, 2));\n\n\t\t\t\t\t// Exiting the process\n\t\t\t\t\tprocess.exit(1);\n\t\t\t\t}\n\t\t\t}\n\t\t\telse if (error && error['name'] === 'MongoError' && error['message'] === 'not master') {\n\t\t\t\tif (diffTimeSec > 60 && !this._lastErrorMsg) {\n\t\t\t\t\tthis._lastErrorMsg = new Date();\n\n\t\t\t\t\tsetTimeout(() => {\n\t\t\t\t\t\tthis._lastErrorMsg = null;\n\t\t\t\t\t}, 60000);\n\n\t\t\t\t\tawait this._methodManager.sendEmail('dev@resolveio.com', 'SERVER - Unhandled Rejection - Quitting NodeJS - ' + ResolveIOServer.getServerConfig()['CLIENT_NAME'], JSON.stringify([error['name'], error['message'], error['stack']], null, 2));\n\t\t\t\t}\n\n\t\t\t\tprocess.exit(1);\n\t\t\t}\n\t\t\telse if (error && error['name'] === 'MongoError' && error['message'] === 'not master and slaveOk=false') {\n\t\t\t\tif (diffTimeSec > 60 && !this._lastErrorMsg) {\n\t\t\t\t\tthis._lastErrorMsg = new Date();\n\n\t\t\t\t\tsetTimeout(() => {\n\t\t\t\t\t\tthis._lastErrorMsg = null;\n\t\t\t\t\t}, 60000);\n\n\t\t\t\t\tawait this._methodManager.sendEmail('dev@resolveio.com', 'SERVER - Unhandled Rejection - Quitting NodeJS - ' + ResolveIOServer.getServerConfig()['CLIENT_NAME'], JSON.stringify([error['name'], error['message'], error['stack']], null, 2));\n\t\t\t\t}\n\n\t\t\t\tprocess.exit(1);\n\t\t\t}\n\t\t\telse if (error) {\n\t\t\t\tif (error['name'] !== 'StatusError' && error['message'] !== '') {\n\t\t\t\t\tif (diffTimeSec > 60 && !this._lastErrorMsg) {\n\t\t\t\t\t\tthis._lastErrorMsg = new Date();\n\n\t\t\t\t\t\tsetTimeout(() => {\n\t\t\t\t\t\t\tthis._lastErrorMsg = null;\n\t\t\t\t\t\t}, 60000);\n\n\t\t\t\t\t\tawait this._methodManager.sendEmail('dev@resolveio.com', 'SERVER - Unhandled Rejection - ' + ResolveIOServer.getServerConfig()['CLIENT_NAME'], JSON.stringify([error['name'], error['message'], error['stack']], null, 2));\n\t\t\t\t\t}\n\t\t\t\t}\n\t\t\t}\n\t\t});\n\n\t\tprocess.on('uncaughtException', async error => {\n\t\t\tconsole.error(error, 'Uncaught Exception thrown');\n\n\t\t\tlet diffTimeSec = moment().diff(this._serverStartTime, 'seconds');\n\n\t\t\tif (diffTimeSec > 60 && !this._lastErrorMsg) {\n\t\t\t\tthis._lastErrorMsg = new Date();\n\n\t\t\t\tsetTimeout(() => {\n\t\t\t\t\tthis._lastErrorMsg = null;\n\t\t\t\t}, 60000);\n\t\t\t\t\n\t\t\t\tawait this._methodManager.sendEmail('dev@resolveio.com', 'SERVER - Unhandled Exception - ' + ResolveIOServer.getServerConfig()['CLIENT_NAME'], JSON.stringify([error['name'], error['message'], error['stack']], null, 2));\n\t\t\t}\n\t\t});\n\n\t\t//PM2 wants to reboot/restart\n\t\tprocess.on('SIGINT', async () => {\n\t\t\tthis._rebootFlag = true;\n\t\t\tif (this._serverHTTP) {\n\t\t\t\tthis._serverHTTP.close();\n\t\t\t}\n\t\t\tawait this.safeShutdown();\n\t\t});\n\n\t\tprocess.on('SIGTERM', async () => {\n\t\t\tthis._rebootFlag = true;\n\t\t\tif (this._serverHTTP) {\n\t\t\t\tthis._serverHTTP.close();\n\t\t\t}\n\t\t\tawait this.safeShutdown();\n\t\t});\n\n\t\tprocess.on('SIGQUIT', async () => {\n\t\t\tthis._rebootFlag = true;\n\t\t\tif (this._serverHTTP) {\n\t\t\t\tthis._serverHTTP.close();\n\t\t\t}\n\t\t\tawait this.safeShutdown();\n\t\t});\n\n\t\tif (this.LOGGER === 'DEBUG') {\n\t\t\tconsole.log('Starting ResolveIO Server');\n\t\t}\n\n\t\tif (this._isWorkersEnabled) {\n\t\t\tif (this._isWorkerInstance) {\n\t\t\t\tconsole.log('Running as a Worker instance', process.env.NODE_APP_INSTANCE);\n\t\t\t\tthis._methodManager = MethodManager.create(null, this._monitorManagerFunction, this._isWorkersEnabled, this._isWorkerInstance);\n\t\t\t\tthis._workerServerManager = WorkerServerManager.create(this._methodManager, this.getServerConfig());\n\n\t\t\t\tif (process.env.WORKER_INDEX === '0') {\n\t\t\t\t\tthis._cronManager = CronManager.create();\n\t\t\t\t}\n\t\t\t}\n\t\t\telse {\n\t\t\t\tconsole.log('Running as a Server instance', process.env.NODE_APP_INSTANCE);\n\t\t\t\tthis._websocketManager = WebSocketManager.create(this);\n\t\t\t\tthis._methodManager = MethodManager.create(this._websocketManager, this._monitorManagerFunction, this._isWorkersEnabled, this._isWorkerInstance);\n\t\t\t\tthis._workerDispatcherManager = WorkerDispatcherManager.create(this._websocketManager, this._methodManager);\n\t\t\t\tthis._subscriptionManager = SubscriptionManager.create(this._serverWSS, ResolveIOServer.getServerConfig(), this._monitorManagerFunction);\n\t\t\t\tthis.startServerInstance();\n\t\t\t\tthis.listen();\n\t\t\t}\n\t\t}\n\t\telse {\n\t\t\tconsole.log('Running with Workers Disabled', process.env.NODE_APP_INSTANCE);\n\t\t\tthis._websocketManager = WebSocketManager.create(this);\n\t\t\tthis._methodManager = MethodManager.create(this._websocketManager, this._monitorManagerFunction, this._isWorkersEnabled, this._isWorkerInstance);\n\t\t\tthis._subscriptionManager = SubscriptionManager.create(this._serverWSS, ResolveIOServer.getServerConfig(), this._monitorManagerFunction);\n\t\t\tthis._cronManager = CronManager.create();\n\t\t\tthis.startServerInstance();\n\t\t\tthis.listen();\n\t\t}\n\t}\n\n\tprivate startServerInstance() {\n\t\t// Start express app\n\t\tthis._app = express();\n\n\t\tthis._app.use(bodyParser.json({limit: '50mb', reviver: dateReviver}));\n\t\tthis._app.use(bodyParser.urlencoded({limit: '50mb', extended: true, parameterLimit: 1000000 }));\n\t\tthis._app.use(xmlParser());\n\t\t\n\t\t// Set port\n\t\tthis._portHTTP = process.env.NODE_APP_INSTANCE ? parseInt('808' + process.env.NODE_APP_INSTANCE) : 8080;\n\n\t\tif (this.LOGGER === 'DEBUG') {\n\t\t\tconsole.log('Setup ports');\n\t\t}\n\n\t\t// Create http server and websock server\n\t\tthis.createServer();\n\n\t\tif (this.LOGGER === 'DEBUG') {\n\t\t\tconsole.log('Create server');\n\t\t}\n\n\t\t// Set CORS\n\t\tthis._app.use(function (req, res, next) {\n\t\t\tres.setHeader('Access-Control-Allow-Origin', '*');\n\t\t\tres.setHeader('Access-Control-Allow-Methods', 'GET, POST');\n\t\t\tres.setHeader('Access-Control-Allow-Headers', 'X-Requested-With,content-type');\n\t\t\tres.setHeader('Access-Control-Allow-Credentials', 'false');\n\t\t\tnext();\n\t\t});\n\n\t\tif (this.LOGGER === 'DEBUG') {\n\t\t\tconsole.log('Setup cors');\n\t\t}\n\n\t\t// Set up http login route\n\t\tsetupAuthRoutes(this, this._app, ResolveIOServer.getServerConfig());\n\t\tsetupHealthRoutes(this._app);\n\n\t\tif (ResolveIOServer.getServerConfig()['CLIENT_NAME'] === 'ResolveIO' || this.standardProgram) {\n\t\t\tsetupHomeRoutes(this, this._app, ResolveIOServer.getServerConfig());\n\t\t}\n\n\t\tif (this.LOGGER === 'DEBUG') {\n\t\t\tconsole.log('Setup express routes');\n\t\t}\n\t}\n\n\tprivate async safeShutdown() {\n\t\tif (!this._safeShutdown) {\n\t\t\tconsole.log(new Date(), 'Safe Shutdown Command Received');\n\t\t}\n\n\t\tif (\n\t\t\t!this._monitorManagerFunction.getActiveMonitorFunctions().length\n\t\t\t&& !this._offlineUpdates.length && (!this._workerDispatcherManager || this._workerDispatcherManager.isSafeShutdown())\n\t\t) {\n\t\t\tif (ResolveIOServer.getMongoConnection()) {\n\t\t\t\ttry {\n\t\t\t\t\tawait ResolveIOServer.getMongoConnection().close(false);\n\t\t\t\t\tconsole.log(new Date(), 'Safe Exit Complete, Process Exit');\n\t\t\t\t\tprocess.exit(0);\n\t\t\t\t}\n\t\t\t\tcatch { \n\t\t\t\t\tprocess.exit(1); \n\t\t\t\t};\n\t\t\t}\n\t\t\telse {\n\t\t\t\tprocess.exit(0);\n\t\t\t}\n\t\t}\n\t\telse {\n\t\t\tif (!this._safeShutdown) {\n\t\t\t\tthis._safeShutdown = true;\n\n\t\t\t\tsetTimeout(() => {\n\t\t\t\t\tthis._safeShutdown = false;\n\t\t\t\t}, 1000);\n\n\t\t\t\tconsole.log(new Date(), 'Safe Exit In Progress', \n\t\t\t\t\tthis._monitorManagerFunction.getActiveMonitorFunctions().length,\n\t\t\t\t\tthis._offlineUpdates.length\n\t\t\t\t);\n\t\t\t}\n\n\t\t\tsetImmediate(async () => {\n\t\t\t\tawait this.safeShutdown();\n\t\t\t});\n\t\t}\n\t}\n\n\tgetIsWorkersEnabled() {\n\t\treturn this._isWorkersEnabled;\n\t}\n\n\tgetIsWorkerInstance() {\n\t\treturn this._isWorkerInstance;\n\t}\n\n\tpublic getWSList() {\n\t\tlet res = [];\n\t\tthis._serverWSS.clients.forEach((ws: WebSocket) => {\n\t\t\tres.push(ws['id_socket']);\n\t\t});\n\t\treturn res;\n\t}\n\n\tpublic getWSUserList() {\n\t\tlet res = [];\n\t\tthis._serverWSS.clients.forEach((ws: WebSocket) => {\n\t\t\tres.push(ws['id_user']);\n\t\t});\n\t\treturn res;\n\t}\n\n\tpublic getHTTPServer() {\n\t\treturn this._serverHTTP;\n\t}\n\n\tpublic getCronManager() {\n\t\treturn this._cronManager;\n\t}\n\n\tpublic getMethodManager() {\n\t\treturn this._methodManager;\n\t}\n\n\tpublic getSubscriptionManager() {\n\t\treturn this._subscriptionManager;\n\t}\n\n\tpublic getMonitorManager() {\n\t\treturn this._monitorManager;\n\t}\n\n\tpublic getRebootFlag() {\n\t\treturn this._rebootFlag;\n\t}\n\n\tpublic getWebSocketManager(): WebSocketManager {\n\t\treturn this._websocketManager;\n\t}\n\n\tprivate createServer(): void {\n\t\tthis._serverHTTP = createServer(this._app);\n\t\tthis._serverHTTP.keepAliveTimeout = 65000;\n\t\tthis._serverHTTP.headersTimeout = 66000;\n\n\t\tthis._serverWSS = new WebSocket.Server({\n\t\t\tserver: this._serverHTTP,\n\t\t\tverifyClient: this.publicProgram ? null : (info, cb) => {\n\t\t\t\tif (this._rebootFlag) {\n\t\t\t\t\tcb(false, 409, 'Unable To Process');\n\t\t\t\t}\n\t\t\t\telse {\n\t\t\t\t\tif (this.LOGGER === 'DEBUG') {\n\t\t\t\t\t\tconsole.log('Verify Client', info, cb);\n\t\t\t\t\t}\n\n\t\t\t\t\t// If it's a worker, we might skip token checks or do a simple check:\n\t\t\t\t\tif (info.req.url && info.req.url.includes('workerToken=')) {\n\t\t\t\t\t\tlet urlParts = info.req.url.split('workerToken='); \n\t\t\t\t\t\tlet workerToken = urlParts[1] || '';\n\n\t\t\t\t\t\tif (workerToken === ResolveIOServer.getServerConfig()['WORKER_TOKEN']) {\n\t\t\t\t\t\t\tcb(true);\n\t\t\t\t\t\t}\n\t\t\t\t\t\telse {\n\t\t\t\t\t\t\tcb(false, 401, 'Unauthorized');\n\t\t\t\t\t\t}\n\n\t\t\t\t\t\treturn;\n\t\t\t\t\t}\n\n\t\t\t\t\tlet infoData = (<string>info.req.headers['sec-websocket-protocol']).split(/,/);\n\n\t\t\t\t\tif (\n\t\t\t\t\t\tinfo.origin !== ResolveIOServer.getServerConfig()['ROOT_URL']\n\t\t\t\t\t\t&& info.origin !== ResolveIOServer.getServerConfig()['SEC_ROOT_URL']\n\t\t\t\t\t\t&& info.origin !== ResolveIOServer.getServerConfig()['RESOLVEIO_URL']\n\t\t\t\t\t\t&& info.origin !== ResolveIOServer.getServerConfig()['RESOLVEIO_SECONDARY_URL']\n\t\t\t\t\t) {\n\t\t\t\t\t\tcb(false, 401, 'Unauthorized');\n\t\t\t\t\t}\n\t\t\t\t\telse {\n\t\t\t\t\t\tlet token = infoData[0];\n\t\t\t\t\t\tif (!token) {\n\t\t\t\t\t\t\tcb(false, 401, 'Unauthorized');\n\t\t\t\t\t\t}\n\t\t\t\t\t\telse {\n\t\t\t\t\t\t\tjwt.verify(token, ResolveIOServer.getServerConfig()['JWT_SECRET'], async (err, decoded) => {\n\t\t\t\t\t\t\t\tif (err) {\n\t\t\t\t\t\t\t\t\tcb(false, 401, 'Unauthorized');\n\t\t\t\t\t\t\t\t}\n\t\t\t\t\t\t\t\telse {\n\t\t\t\t\t\t\t\t\tinfo.req['id_user'] = decoded['id_user'];\n\t\t\t\t\t\t\t\t\ttry {\n\t\t\t\t\t\t\t\t\t\tlet user = await Users.findById(decoded['id_user']);\n\t\t\t\t\t\t\t\t\t\tif (user) {\n\t\t\t\t\t\t\t\t\t\t\tinfo.req['user'] = user.fullname;\n\t\t\t\t\t\t\t\t\t\t\tinfo.req['user_readonly'] = user.readonly || false;\n\t\t\t\t\t\t\t\t\t\t\tinfo.req['doc_user'] = user;\n\t\t\t\t\t\t\t\t\t\t\tcb(true);\n\t\t\t\t\t\t\t\t\t\t}\n\t\t\t\t\t\t\t\t\t\telse {\n\t\t\t\t\t\t\t\t\t\t\tcb(false);\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\tcatch {\n\t\t\t\t\t\t\t\t\t\tcb(false);\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}\n\t\t\t}\n\t\t});\n\t}\n\n\t/**\n\t * Listen for connections from clients or workers.\n\t */\n\tprivate listen(): void {\n\t\tthis._serverHTTP.listen(this._portHTTP, () => {\n\t\t\tconsole.log('Running HTTP/WS server on port %s', this._portHTTP);\n\t\t});\n\n\t\tthis._serverWSS.on('connection', async (ws, req) => {\n\t\t\tif (req.url && req.url.includes('workerToken=')) {\n\t\t\t\t// It's a WORKER\n\t\t\t\tlet workerId = objectIdHexString();\n\t\t\t\tws['id_worker'] = workerId;\n\n\t\t\t\tconsole.log(new Date(), process.env.NODE_APP_INSTANCE, 'Worker Connected', process.env.NODE_APP_INSTANCE);\n\n\t\t\t\tthis._workerDispatcherManager.addWorker(ws);\n\n\t\t\t\tlet interval = null;\n\t\t\t\tlet lastComm = null;\n\n\t\t\t\tthis._workerDispatcherManager.sendWorkerPayload(ws, 'ping');\n\t\n\t\t\t\tinterval = setInterval(() => {\n\t\t\t\t\tif (!lastComm) {\n\t\t\t\t\t\tthis._workerDispatcherManager.disconnectWorker(ws['id_worker']);\n\t\t\t\t\t\tws.close();\n\t\t\t\t\t}\n\t\t\t\t\telse {\n\t\t\t\t\t\tlastComm = null;\n\t\t\t\t\t\tthis._workerDispatcherManager.sendWorkerPayload(ws, 'ping');\n\t\t\t\t\t}\n\t\t\t\t}, 30000);\n\n\t\t\t\tws.on('message', (message: any) => {\n\t\t\t\t\t// console.log(new Date(), 'Message Recv', message);\n\n\t\t\t\t\tif (typeof message !== 'string') {\n\t\t\t\t\t\tmessage = message.toString();\n\t\t\t\t\t}\n\n\t\t\t\t\t// console.log(new Date(), 'String Message Recv', message);\n\n\t\t\t\t\tif (message === 'ping') {\n\t\t\t\t\t\t// console.log(new Date(), 'Recv Ping, Sending Pong');\n\t\t\t\t\t\tthis._workerDispatcherManager.sendWorkerPayload(ws, 'pong');\n\t\t\t\t\t}\n\t\t\t\t\telse if (message === 'pong') {\n\t\t\t\t\t\t// console.log(new Date(), 'Recv Ping, Sending Pong');\n\t\t\t\t\t\tlastComm = new Date();\n\t\t\t\t\t}\n\t\t\t\t\telse {\n\t\t\t\t\t\tthis._workerDispatcherManager.handleWorkerMessage(ws['id_worker'], message);\n\t\t\t\t\t}\n\t\t\t\t});\n\n\t\t\t\tws.on('close', () => {\n\t\t\t\t\tthis._workerDispatcherManager.disconnectWorker(ws['id_worker']);\n\n\t\t\t\t\tconsole.log(new Date(), 'Worker disconnected:', workerId);\n\t\t\t\t\t\n\t\t\t\t\tif (interval) {\n\t\t\t\t\t\tclearInterval(interval);\n\t\t\t\t\t}\n\t\t\t\t});\n\n\t\t\t\tws.on('error', (error) => {\n\t\t\t\t\tthis._workerDispatcherManager.disconnectWorker(ws['id_worker']);\n\n\t\t\t\t\tconsole.error('Error on WS Worker', error);\n\t\t\t\t\tws.close();\n\t\t\t\t});\n\t\t\t}\n\t\t\telse {\n\t\t\t\t// Normal client\n\t\t\t\tws['id_socket'] = objectIdHexString();\n\t\t\t\tws['id_user'] = req['id_user'];\n\t\t\t\tws['user'] = req['user'];\n\t\t\t\tws['user_readonly'] = req['user_readonly'];\n\t\t\t\tws['doc_user'] = req['doc_user'];\n\n\t\t\t\tthis._websocketManager.addWebSocket(ws);\n\n\t\t\t\tawait this._subscriptionManager.createLoggedInUser(ws['id_socket']);\n\t\t\t\t\n\t\t\t\tsetTimeout(() => {\n\t\t\t\t\tws['pingTime'] = new Date();\n\t\t\t\t\tws.send('ping', async (error) => {\n\t\t\t\t\t\tif (error) {\n\t\t\t\t\t\t\tif (this._subscriptionManager.getEnableDebug()) {\n\t\t\t\t\t\t\t\tconsole.log(new Date(), 'Server App', 'Error WS Ping');\n\t\t\t\t\t\t\t}\n\t\t\t\t\t\t\tawait this.unsubscribeWS(ws);\n\t\t\t\t\t\t}\n\t\t\t\t\t});\n\t\t\t\t}, 5000);\n\n\t\t\t\tif (this.LOGGER === 'DEBUG') {\n\t\t\t\t\tconsole.log('Connection from user: ' + req['user']);\n\t\t\t\t}\n\t\t\t\n\t\t\t\tws['isAlive'] = true;\n\t\t\t\tws['retryCnt'] = 0;\n\n\t\t\t\tws.on('message', async (message: string) => {\n\t\t\t\t\tthis._debugMsgRecv += 1;\n\t\t\t\t\tlet socketData = [];\n\t\t\t\t\n\t\t\t\t\ttry {\n\t\t\t\t\t\tsocketData = JSON.parse(message, dateReviver);\n\t\t\t\t\t}\n\t\t\t\t\tcatch (e) {\n\t\t\t\t\t\tconsole.log('Error - JSON.parse', message);\n\t\t\t\t\t\tawait this._methodManager.sendEmail(\n\t\t\t\t\t\t\t'dev@resolveio.com', \n\t\t\t\t\t\t\t'SERVER - JSON Parse Error - ' + ResolveIOServer.getServerConfig()['CLIENT_NAME'], \n\t\t\t\t\t\t\tJSON.stringify([message, e])\n\t\t\t\t\t\t);\n\t\t\t\t\t\treturn;\n\t\t\t\t\t}\n\n\t\t\t\t\t// call our existing processSocketMessage\n\t\t\t\t\tawait this.processSocketMessage(ws, socketData);\n\t\t\t\t})\n\t\t\t\t.on('end', () => {\n\t\t\t\t\tws.close();\n\t\t\t\t})\n\t\t\t\t.on('error', () => {\n\t\t\t\t\tws.close()\n\t\t\t\t})\n\t\t\t\t.on('close', async () => {\n\t\t\t\t\tawait this.unsubscribeWS(ws);\n\t\t\t\t});\n\t\t\t}\n\t\t});\n\n\t\t// Keep alive timer\n\t\tsetInterval(async () => {\n\t\t\tfor (let ws of this._serverWSS.clients) {\n\t\t\t\tif (ws['pingTime'] && Date.now() - ws['pingTime'].getTime() >= 20000) {\n\t\t\t\t\tif (ws['isAlive'] === false) {\n\t\t\t\t\t\tws['retryCnt']++;\n\t\t\t\t\t\tif (ws['retryCnt'] >= 3) {\n\t\t\t\t\t\t\tawait this.unsubscribeWS(ws);\n\t\t\t\t\t\t}\n\t\t\t\t\t\telse {\n\t\t\t\t\t\t\tws['pingTime'] = new Date();\n\t\t\t\t\t\t\tws.send('ping', async (error) => {\n\t\t\t\t\t\t\t\tif (error) {\n\t\t\t\t\t\t\t\t\tif (this._subscriptionManager.getEnableDebug()) {\n\t\t\t\t\t\t\t\t\t\tconsole.log(new Date(), 'Server App', 'Error WS Ping');\n\t\t\t\t\t\t\t\t\t}\n\t\t\t\t\t\t\t\t\tawait this.unsubscribeWS(ws);\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\telse {\n\t\t\t\t\t\tws['retryCnt'] = 0;\n\t\t\t\t\t\tws['isAlive'] = false;\n\t\t\t\t\t\tws['pingTime'] = new Date();\n\t\t\t\t\t\tws.send('ping', async (error) => {\n\t\t\t\t\t\t\tif (error) {\n\t\t\t\t\t\t\t\tif (this._subscriptionManager.getEnableDebug()) {\n\t\t\t\t\t\t\t\t\tconsole.log(new Date(), 'Server App', 'Error WS Ping');\n\t\t\t\t\t\t\t\t}\n\t\t\t\t\t\t\t\tawait this.unsubscribeWS(ws);\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\t\t}\n\t\t}, 20000);\n\t}\n\n\tprivate async processSocketMessage(ws: WebSocket, socketData: any) {\n\t\tif (typeof socketData === 'string' && socketData === 'ping') {\n\t\t\tif (ws && ws.readyState === ws.OPEN) {\n\t\t\t\tws.send('pong');\n\t\t\t}\n\t\t\treturn;\n\t\t}\n\t\telse if (typeof socketData === 'string' && socketData === 'pong') {\n\t\t\tws['isAlive'] = true;\n\t\t\tws['pongTime'] = new Date();\n\t\t\tws['latency'] = moment.duration(moment(ws['pongTime']).diff(ws['pingTime'])).asMilliseconds();\n\t\t\tthis._subscriptionManager.loggedInLatency(ws);\n\t\t\treturn;\n\t\t}\n\n\t\t// If the top level is not an array, let's skip\n\t\tif (!Array.isArray(socketData[0])) {\n\t\t\tconsole.log('Invalid message format (expected array of arrays)', socketData);\n\t\t\treturn;\n\t\t}\n\n\t\t// Handle each sub-message\n\t\tfor (let message of socketData) {\n\t\t\tawait this.handleClientMessage(ws, message);\n\t\t}\n\t}\n\n\tprivate async handleClientMessage(ws: WebSocket, msg: any[]): Promise<void> {\n\t\t// This is basically your old logic from processSocketMessage,\n\t\t// but we'll insert our worker-queue logic for \"method\" calls.\n\n\t\tlet messageRoute = msg[0];\n\t\tlet messageDate = msg[1];\n\t\tlet messageId = msg[2];\n\t\tlet type = msg[3];\n\n\t\tif (!this.publicProgram && this._clientRoutes.some(a => messageRoute.includes(a)) && !ws['doc_user'].roles.groups.some(a => a.views.some(b => messageRoute.includes(b) || b.includes(messageRoute))) && !ws['doc_user'].roles.super_admin) {\n\t\t\treturn;\n\t\t}\n\n\t\tif (type === 'subscription') {\n\t\t\tlet subType = msg[4];\n\t\t\tlet pub = msg[5];\n\n\t\t\tif (subType === 'sub') {\n\t\t\t\tawait this._subscriptionManager.subscribe(messageRoute, messageDate, ws, messageId, pub, msg.slice(6));\n\t\t\t}\n\t\t\telse {\n\t\t\t\tthis._subscriptionManager.unsubscribe(messageRoute, messageDate, ws, messageId, pub, msg.slice(6));\n\t\t\t}\n\t\t}\n\t\telse if (!this.publicProgram && type === 'offline') {\n\t\t\tlet serverRes: ServerResponseModel = {\n\t\t\t\tmessageId: messageId,\n\t\t\t\thasError: false,\n\t\t\t\tdata: 'ACK'\n\t\t\t};\n\n\t\t\tif (ws && ws.readyState === ws.OPEN) {\n\t\t\t\tthis._websocketManager.send(ws, serverRes);\n\t\t\t}\n\n\t\t\tthis._offlineUpdates.push(ws);\n\t\t\tlet offlineUpdates = msg[4];\n\n\t\t\tfor (let i = 0; i < offlineUpdates.length; i++) {\n\t\t\t\tlet update = offlineUpdates[i];\n\n\t\t\t\tlet data = update.data;\n\n\t\t\t\t// eslint-disable-next-line no-unused-vars\n\t\t\t\tlet updateRoute = data.shift();\n\t\t\t\t// eslint-disable-next-line no-unused-vars\n\t\t\t\tlet updateDate = data.shift();\n\t\t\t\tlet updateMessageId = data.shift();\n\t\t\t\t// eslint-disable-next-line no-unused-vars\n\t\t\t\tlet updateType = data.shift();\n\t\t\t\tlet method = data.shift();\n\n\t\t\t\tlet serverResMethod: ServerResponseModel = {\n\t\t\t\t\tmessageId: updateMessageId,\n\t\t\t\t\thasError: false,\n\t\t\t\t\tdata: 'ACK'\n\t\t\t\t};\n\n\t\t\t\tif (ws && ws.readyState === ws.OPEN) {\n\t\t\t\t\tthis._websocketManager.send(ws, serverResMethod);\n\t\t\t\t}\n\n\t\t\t\tif (method === 'insertDocument' && data[0] === 'driver-gps') {\n\t\t\t\t\tcontinue;\n\t\t\t\t}\n\t\t\t\t\n\t\t\t\tif (method !== 'reportBuilderGetResults' && method !== 'reportBuilderGetDistinctValue' && method !== 'reportBuilderBuildTree' && method !== 'generatePDF' && method !== 'getWOOfflineData' && method !== 'countQuery' && method !== 'countWithQuery' && method !== 'countCollectionWithQuery' && method !== 'find' && method !== 'findOne' && method !== 'findWithOptions' && method !== 'getDrivers' && method !== 'processAirdropDistribution' && method !== 'qbHandleResponse') {\n\t\t\t\t\tif (\n\t\t\t\t\t\tResolveIOServer.getServerConfig()['ROOT_URL'] !== 'https://resolveio.com'\n\t\t\t\t\t&& ResolveIOServer.getServerConfig()['ROOT_URL'] !== 'http://localhost:4200'\n\t\t\t\t\t) {\n\t\t\t\t\t\tResolveIOServer.getLocalLogManager().writeLog({\n\t\t\t\t\t\t\ttype: 'log',\n\t\t\t\t\t\t\tdata: {\n\t\t\t\t\t\t\t\t_id: objectIdHexString(),\n\t\t\t\t\t\t\t\tcreatedAt: new Date(),\n\t\t\t\t\t\t\t\ttype: 'client-request',\n\t\t\t\t\t\t\t\tcollection: '',\n\t\t\t\t\t\t\t\tid_document: '',\n\t\t\t\t\t\t\t\tpayload: getBinarySize(JSON.stringify([data])) < 1000000 ? JSON.stringify([data], null, 2) : 'Too Big',\n\t\t\t\t\t\t\t\tmethod: method,\n\t\t\t\t\t\t\t\tid_user: ws['id_user'] || '',\n\t\t\t\t\t\t\t\tuser: ws['user'] || '',\n\t\t\t\t\t\t\t\tmessageId: messageId,\n\t\t\t\t\t\t\t\troute: messageRoute\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\telse {\n\t\t\t\t\t\tawait Logs.insertOne({\n\t\t\t\t\t\t\t_id: objectIdHexString(),\n\t\t\t\t\t\t\ttype: 'client-request',\n\t\t\t\t\t\t\tcollection: '',\n\t\t\t\t\t\t\tid_document: '',\n\t\t\t\t\t\t\tpayload: getBinarySize(JSON.stringify([data])) < 1000000 ? JSON.stringify([data], null, 2) : 'Too Big',\n\t\t\t\t\t\t\tmethod: method,\n\t\t\t\t\t\t\tid_user: ws['id_user'] || '',\n\t\t\t\t\t\t\tuser: ws['user'] || '',\n\t\t\t\t\t\t\tmessageId: messageId,\n\t\t\t\t\t\t\troute: messageRoute,\n\t\t\t\t\t\t\tclient: 'ResolveIO',\n\t\t\t\t\t\t\tinstance: 'backend.resolveio.com',\n\t\t\t\t\t\t\tinstance_index: process.env.NODE_APP_INSTANCE || ''\n\t\t\t\t\t\t});\n\t\t\t\t\t}\n\t\t\t\t}\n\n\t\t\t\tif (this._methodManager._methods[method]) {\n\t\t\t\t\ttry {\n\t\t\t\t\t\tawait this._methodManager.callMethod.call(Object.assign({}, this._methodManager, MethodManager.prototype, {id_user: ws['id_user'], user: ws['user'], id_ws: ws['id_socket']}), method, ...data);\n\t\t\t\t\t}\n\t\t\t\t\tcatch (err) {\n\t\t\t\t\t\tconsole.log(new Date(), 'Offline Error', JSON.stringify(err, null, 2));\n\t\t\t\t\t}\n\n\t\t\t\t\tif (method === 'updateDocumentOffline' || method === 'updateDocumentPropsOffline') {\n\t\t\t\t\t\tResolveIOServer.getMongoManager().invalidateQueryCache(data[0]);\n\t\t\t\t\t}\n\t\t\t\t}\n\t\t\t\telse {\n\t\t\t\t\tconsole.log('Offline - Could not find method: ' + method);\n\t\t\t\t}\n\t\t\t}\n\n\t\t\tthis._offlineUpdates.splice(this._offlineUpdates.map(a => a['id_socket']).indexOf(ws['id_socket']), 1);\n\t\t}\n\t\telse {\n\t\t\t// It's presumably a 'method' or something else\n\t\t\tlet dataCopy = [...msg];\n\n\t\t\t// eslint-disable-next-line no-unused-vars\n\t\t\tlet route = dataCopy.shift();\n\t\t\t// eslint-disable-next-line no-unused-vars\n\t\t\tlet date = dataCopy.shift();\n\t\t\tlet msgId = dataCopy.shift();\n\t\t\tlet msgType = dataCopy.shift();\n\t\t\t\n\t\t\tif (msgType === 'method') {\n\t\t\t\tlet methodName = dataCopy.shift();\n\n\t\t\t\tif (ws['user_readonly']) {\n\t\t\t\t\treturn;\n\t\t\t\t}\n\n\t\t\t\tif (methodName !== 'reportBuilderGetResults' && methodName !== 'reportBuilderGetDistinctValue' && methodName !== 'reportBuilderBuildTree' && methodName !== 'generatePDF' && methodName !== 'getWOOfflineData' && methodName !== 'countQuery' && methodName !== 'countWithQuery' && methodName !== 'countCollectionWithQuery' && methodName !== 'find' && methodName !== 'findOne' && methodName !== 'findWithOptions' && methodName !== 'getDrivers' && methodName !== 'processAirdropDistribution') {\n\t\t\t\t\tif (\n\t\t\t\t\t\tResolveIOServer.getServerConfig()['ROOT_URL'] !== 'https://resolveio.com'\n\t\t\t\t\t&& ResolveIOServer.getServerConfig()['ROOT_URL'] !== 'http://localhost:4200'\n\t\t\t\t\t) {\n\t\t\t\t\t\tResolveIOServer.getLocalLogManager().writeLog({\n\t\t\t\t\t\t\ttype: 'log',\n\t\t\t\t\t\t\tdata: {\n\t\t\t\t\t\t\t\t_id: objectIdHexString(),\n\t\t\t\t\t\t\t\tcreatedAt: new Date(),\n\t\t\t\t\t\t\t\ttype: 'client-request',\n\t\t\t\t\t\t\t\tcollection: '',\n\t\t\t\t\t\t\t\tid_document: '',\n\t\t\t\t\t\t\t\tpayload: getBinarySize(JSON.stringify([dataCopy])) < 1000000 ? JSON.stringify([dataCopy], null, 2) : 'Too Big',\n\t\t\t\t\t\t\t\tmethod: methodName,\n\t\t\t\t\t\t\t\tid_user: ws['id_user'] || '',\n\t\t\t\t\t\t\t\tuser: ws['user'] || '',\n\t\t\t\t\t\t\t\tmessageId: messageId,\n\t\t\t\t\t\t\t\troute: messageRoute\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\telse {\n\t\t\t\t\t\tawait Logs.insertOne({\n\t\t\t\t\t\t\t_id: objectIdHexString(),\n\t\t\t\t\t\t\ttype: 'client-request',\n\t\t\t\t\t\t\tcollection: '',\n\t\t\t\t\t\t\tid_document: '',\n\t\t\t\t\t\t\tpayload: getBinarySize(JSON.stringify([dataCopy])) < 1000000 ? JSON.stringify([dataCopy], null, 2) : 'Too Big',\n\t\t\t\t\t\t\tmethod: methodName,\n\t\t\t\t\t\t\tid_user: ws['id_user'] || '',\n\t\t\t\t\t\t\tuser: ws['user'] || '',\n\t\t\t\t\t\t\tmessageId: messageId,\n\t\t\t\t\t\t\troute: messageRoute,\n\t\t\t\t\t\t\tclient: 'ResolveIO',\n\t\t\t\t\t\t\tinstance: 'backend.resolveio.com',\n\t\t\t\t\t\t\tinstance_index: process.env.NODE_APP_INSTANCE || ''\n\t\t\t\t\t\t});\n\t\t\t\t\t}\n\t\t\t\t}\n\n\t\t\t\t// Immediately ACK\n\t\t\t\tlet ack: ServerResponseModel = {\n\t\t\t\t\tmessageId: msgId,\n\t\t\t\t\thasError: false,\n\t\t\t\t\tdata: 'ACK'\n\t\t\t\t};\n\n\t\t\t\tif (ws && ws.readyState === ws.OPEN) {\n\t\t\t\t\tthis._websocketManager.send(ws, ack);\n\t\t\t\t}\n\n\t\t\t\tlet method = this._methodManager.getMethod(methodName);\n\n\t\t\t\tif (method && \n\t\t\t\t\t!method.skipWorker &&\n\t\t\t\t\tthis._isWorkersEnabled && \n\t\t\t\t\tmethodName !== 'find' &&\n\t\t\t\t\tmethodName !== 'insertDocument' &&\n\t\t\t\t\tmethodName !== 'countWithQuery' &&\n\t\t\t\t\tmethodName !== 'findOne' &&\n\t\t\t\t\tmethodName !== 'updateDocumentProps' &&\n\t\t\t\t\tmethodName !== 'findWithOptions' &&\n\t\t\t\t\tmethodName !== 'updateDocument' &&\n\t\t\t\t\tmethodName !== 'insertErrorLog' &&\n\t\t\t\t\tmethodName !== 'removeDocument' &&\n\t\t\t\t\tmethodName !== 'supportCreateBillingUser' &&\n\t\t\t\t\tmethodName !== 'getSignedUrl' &&\n\t\t\t\t\tmethodName !== 'getSignedUrls' &&\n\t\t\t\t\tmethodName !== 'getSignedUrlWithId' &&\n\t\t\t\t\tmethodName !== 'incorrectUser' &&\n\t\t\t\t\tmethodName !== 'reloadWS' &&\n\t\t\t\t\tmethodName !== 'reconnectWS' &&\n\t\t\t\t\tmethodName !== 'disconnectWS'\n\t\t\t\t) {\t\t\t\t\t\n\t\t\t\t\tthis._workerDispatcherManager.sendClientTask(msgId, methodName, dataCopy, {\n\t\t\t\t\t\tid_user: ws['id_user'],\n\t\t\t\t\t\tuser: ws['user'],\n\t\t\t\t\t\tid_ws: ws['id_socket']\n\t\t\t\t\t});\n\t\t\t\t}\n\t\t\t\telse {\n\t\t\t\t\t// No worker available: do method locally\n\t\t\t\t\tawait this.callMethodLocally(ws, msgId, methodName, dataCopy);\n\t\t\t\t}\n\t\t\t}\n\t\t}\n\t}\n\n\t/**\n\t * callMethodLocally is your old approach for invoking the method in-process.\n\t */\n\tprivate async callMethodLocally(ws: WebSocket, messageId: number, method: string, params: any[]) {\n\t\tlet serverRes: ServerResponseModel = {\n\t\t\tmessageId: messageId,\n\t\t\thasError: false,\n\t\t\tdata: null\n\t\t};\n\n\t\ttry {\n\t\t\t// You can keep your logging code (LogMethodLatencies, Logs.insertOne, etc.)\n\t\t\tlet result = await this._methodManager.callMethod.call(\n\t\t\t\tObject.assign({}, this._methodManager, MethodManager.prototype, {\n\t\t\t\t\tid_user: ws['id_user'],\n\t\t\t\t\tuser: ws['user'],\n\t\t\t\t\tid_ws: ws['id_socket']\n\t\t\t\t}),\n\t\t\t\tmethod,\n\t\t\t\t...params\n\t\t\t);\n\n\t\t\tserverRes.data = result;\n\t\t}\n\t\tcatch (err) {\n\t\t\tserverRes.hasError = true;\n\t\t\tserverRes.data = err || 'Unknown error';\n\t\t}\n\n\t\tif (ws && ws.readyState === ws.OPEN) {\n\t\t\tthis._websocketManager.send(ws, serverRes);\n\t\t}\n\t}\n\n\t\n\n\t/**\n\t * Cleanly remove a client from the subscription manager, etc.\n\t */\n\tpublic async unsubscribeWS(ws: WebSocket) {\n\t\tif (this._subscriptionManager && this._subscriptionManager.getEnableDebug()) {\n\t\t\tconsole.log(new Date(), 'Server App', 'Unsub WS', ws['user'], ws['id_socket']);\n\t\t}\n\t\tawait this._subscriptionManager.unsubscribeAll(ws);\n\t\tws.removeAllListeners();\n\t\tws = null;\n\t}\n\n\tpublic getApp() {\n\t\treturn this._app;\n\t}\n\n\tpublic getServerConfig() {\n\t\treturn ResolveIOServer.getServerConfig();\n\t}\n\n\tpublic getWorkerDispatcherManager() {\n\t\treturn this._workerDispatcherManager;\n\t}\n\n\tpublic getWorkerServerManager() {\n\t\treturn this._workerServerManager;\n\t}\n}"]}
|
|
1
|
+
{"version":3,"sources":["../../src/server-app.ts"],"names":["bodyParser","require","express","xmlParser","http_1","jwt","moment","WebSocket","log_collection_1","user_collection_1","cron_manager_1","method_manager_1","monitor_manager_1","subscription_manager_1","common_1","mongodb_1","auth_1","health_1","home_1","websocket_manager_1","worker_dispatcher_manager_1","worker_server_manager_1","resolveio_server_app_1","ResolveIOMainServer","this","_offlineUpdates","sesMail","standardProgram","publicProgram","_rebootFlag","LOGGER","_clientRoutes","_lastErrorMsg","_debugMsgRecv","_debugMsgQueue","_isWorkersEnabled","_isWorkerInstance","_safeShutdown","create","resolveioMainServer","initialize","_a","sent","prototype","_serverStartTime","Date","MonitorManager","_monitorManager","_b","_monitorManagerFunction","MonitorManagerFunction","process","env","IS_WORKERS_ENABLED","IS_WORKER_INSTANCE","setInterval","_this","_subscriptionManager","getEnableDebug","console","log","initServerFlag","setTimeout","removeAllListeners","on","error","rej","__awaiter","diffTimeSec","diff","MongoNetworkTimeoutError","_methodManager","sendEmail","ResolveIOServer","getServerConfig","JSON","stringify","name","message","stack","exit","_serverHTTP","close","safeShutdown","NODE_APP_INSTANCE","MethodManager","_workerServerManager","WorkerServerManager","WORKER_INDEX","_cronManager","CronManager","_websocketManager","WebSocketManager","_workerDispatcherManager","WorkerDispatcherManager","SubscriptionManager","_serverWSS","startServerInstance","listen","_app","use","json","limit","reviver","dateReviver","urlencoded","extended","parameterLimit","_portHTTP","parseInt","createServer","req","res","next","setHeader","setupAuthRoutes","setupHealthRoutes","setupHomeRoutes","getActiveMonitorFunctions","length","isSafeShutdown","getMongoConnection","setImmediate","getIsWorkersEnabled","getIsWorkerInstance","getWSList","clients","forEach","ws","push","getWSUserList","getHTTPServer","getCronManager","getMethodManager","getSubscriptionManager","getMonitorManager","getRebootFlag","getWebSocketManager","keepAliveTimeout","headersTimeout","Server","server","verifyClient","info","cb","token","url","includes","split","infoData","headers","origin","verify","err","decoded","Users","findById","user","fullname","readonly","workerId_1","objectIdHexString","addWorker","lastComm_1","sendWorkerPayload","interval_1","disconnectWorker","toString","handleWorkerMessage","clearInterval","addWebSocket","createLoggedInUser","send","unsubscribeWS","socketData","parse","e_1","processSocketMessage","now","getTime","this_1","_e","__values","value","readyState","OPEN","duration","asMilliseconds","loggedInLatency","Array","isArray","socketData_1","socketData_1_1","handleClientMessage","msg","messageRoute","messageDate","messageId","type","some","a","roles","groups","views","b","super_admin","subType","pub","subscribe","slice","unsubscribe","serverRes","hasError","data","offlineUpdates","i","update","shift","updateMessageId","method","serverResMethod","getLocalLogManager","writeLog","_id","createdAt","collection","id_document","payload","getBinarySize","id_user","route","Logs","insertOne","client","instance","instance_index","_methods","callMethod","call","apply","__spreadArray","Object","assign","id_ws","__read","err_1","getMongoManager","invalidateQueryCache","splice","map","indexOf","dataCopy","msgId","methodName","ack","getMethod","skipWorker","sendClientTask","callMethodLocally","params","result","err_2","unsubscribeAll","getApp","getWorkerDispatcherManager","getWorkerServerManager","exports"],"mappings":"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","file":"server-app.js","sourcesContent":["import * as bodyParser from 'body-parser';\nimport * as express from 'express';\nimport * as xmlParser from 'express-xml-bodyparser';\nimport { createServer, Server } from 'http';\nimport * as jwt from 'jsonwebtoken';\nimport * as moment from 'moment-timezone';\nimport * as WebSocket from 'ws';\n\nimport { Logs } from './collections/log.collection';\nimport { Users } from './collections/user.collection';\nimport { CronManager } from './managers/cron.manager';\nimport { MethodManager } from './managers/method.manager';\nimport { MonitorManager, MonitorManagerFunction } from './managers/monitor.manager';\nimport { SubscriptionManager } from './managers/subscription.manager';\nimport { ServerResponseModel } from './models/server-message.model';\nimport { dateReviver, getBinarySize, objectIdHexString } from './util/common';\n\nimport { MongoNetworkTimeoutError } from 'mongodb';\nimport { setupAuthRoutes } from './http/auth';\nimport { setupHealthRoutes } from './http/health';\nimport { setupHomeRoutes } from './http/home';\n\nimport { WebSocketManager } from './managers/websocket.manager';\nimport { WorkerDispatcherManager } from './managers/worker-dispatcher.manager';\nimport { WorkerServerManager } from './managers/worker-server.manager';\nimport { ResolveIOServer } from './resolveio-server-app';\n\nexport class ResolveIOMainServer {\n\tprivate _app: express.Application;\n\tprivate _serverHTTP: Server;\n\tprivate _portHTTP: string | number;\n\tprivate _serverWSS: WebSocket.Server;\n\tprivate _offlineUpdates = [];\n\tpublic sesMail = false;\n\tprivate standardProgram = false;\n\tprivate publicProgram = false;\n\tprivate _rebootFlag = false;\n\n\tprivate LOGGER = 'ERROR'; //ERROR / DEBUG\n\n\tprivate _websocketManager: WebSocketManager;\n\tprivate _monitorManager: MonitorManager;\n\tprivate _monitorManagerFunction: MonitorManagerFunction;\n\tprivate _subscriptionManager: SubscriptionManager;\n\tprivate _methodManager: MethodManager;\n\tprivate _cronManager: CronManager;\n\tprivate _clientRoutes: string[] = [];\n\tprivate _workerDispatcherManager: WorkerDispatcherManager;\n\tprivate _workerServerManager: WorkerServerManager;\n\n\tprivate _serverStartTime: Date;\n\tprivate _lastErrorMsg: Date = null;\n\n\tprivate _debugMsgRecv = 0;\n\tprivate _debugMsgQueue = 0;\n\n\tprivate _isWorkersEnabled = false;\n\tprivate _isWorkerInstance = false;\n\n\tprivate _safeShutdown = false;\n\n\tconstructor() {}\n\n\tstatic async create() {\n\t\tconst resolveioMainServer = new ResolveIOMainServer();\n\t\tawait resolveioMainServer.initialize();\n\t\treturn resolveioMainServer;\n\t}\n\n\tprivate async initialize() {\n\t\tthis._serverStartTime = new Date();\n\t\tthis._lastErrorMsg = null;\n\t\tthis._monitorManager = await MonitorManager.create();\n\t\tthis._monitorManagerFunction = new MonitorManagerFunction();\n\n\t\t// Check for workers and decide what to start\n\t\tthis._isWorkersEnabled = process.env.IS_WORKERS_ENABLED === 'true';\n\t\tthis._isWorkerInstance = process.env.IS_WORKER_INSTANCE === 'true';\n\n\t\tsetInterval(() => {\n\t\t\tif (this._subscriptionManager && this._subscriptionManager.getEnableDebug()) {\n\t\t\t\tconsole.log(new Date(), 'Server App', 'Msg Recv Hits', this._debugMsgRecv);\n\t\t\t\tconsole.log(new Date(), 'Server App', 'Msg Queue Hits', this._debugMsgQueue);\n\t\t\t}\n\n\t\t\tthis._debugMsgQueue = 0;\n\t\t\tthis._debugMsgRecv = 0;\n\t\t}, 60000);\n\n\t\tlet initServerFlag = false;\n\n\t\tsetTimeout(() => {\n\t\t\tinitServerFlag = true;\n\t\t}, 5000);\n\n\t\tprocess.removeAllListeners('unhandledRejection');\n\n\t\tprocess.on('unhandledRejection', async (error, rej) => {\n\t\t\t// Condition to filter out the MongoError with code 48 (NamespaceExists)\n\t\t\tif (error && error['name'] === 'MongoError' && (error['code'] === 48 || error['code'] === 26 || error['code'] === 11000 || error['code'] === 251)) {\n\t\t\t\treturn; // Simply return without doing anything further\n\t\t\t}\n\n\t\t\tif (error && error['name'] === 'MongoServerError' && (!initServerFlag || error['code'] === 26 || error['code'] === 11000 || error['code'] === 86 || error['code'] === 251)) {\n\t\t\t\treturn; // Simply return without doing anything further\n\t\t\t}\n\n\t\t\tconsole.error(new Date(), 'Unhandled Rejection at Promise', [error, rej]);\n\t\t\t\n\t\t\tlet diffTimeSec = moment().diff(this._serverStartTime, 'seconds');\n\n\t\t\t// If this is a MongoNetworkTimeoutError, handle it specifically\n\t\t\tif (error && (error['name'] === 'MongoNetworkTimeoutError' || error instanceof MongoNetworkTimeoutError)) {\n\t\t\t\tif (diffTimeSec > 60 && !this._lastErrorMsg) {\n\t\t\t\t\tthis._lastErrorMsg = new Date();\n\t\t\t\t\tsetTimeout(() => {\n\t\t\t\t\t\tthis._lastErrorMsg = null;\n\t\t\t\t\t}, 60000);\n\n\t\t\t\t\t// Sending email notification (using your existing method)\n\t\t\t\t\tawait this._methodManager.sendEmail('dev@resolveio.com', 'SERVER - MongoNetworkTimeoutError - Quitting NodeJS - ' + ResolveIOServer.getServerConfig()['CLIENT_NAME'], JSON.stringify({\n\t\t\t\t\t\tname: error['name'],\n\t\t\t\t\t\tmessage: error['message'],\n\t\t\t\t\t\tstack: error['stack']\n\t\t\t\t\t}, null, 2));\n\n\t\t\t\t\t// Exiting the process\n\t\t\t\t\tprocess.exit(1);\n\t\t\t\t}\n\t\t\t}\n\t\t\telse if (error && error['name'] === 'MongoError' && error['message'] === 'not master') {\n\t\t\t\tif (diffTimeSec > 60 && !this._lastErrorMsg) {\n\t\t\t\t\tthis._lastErrorMsg = new Date();\n\n\t\t\t\t\tsetTimeout(() => {\n\t\t\t\t\t\tthis._lastErrorMsg = null;\n\t\t\t\t\t}, 60000);\n\n\t\t\t\t\tawait this._methodManager.sendEmail('dev@resolveio.com', 'SERVER - Unhandled Rejection - Quitting NodeJS - ' + ResolveIOServer.getServerConfig()['CLIENT_NAME'], JSON.stringify([error['name'], error['message'], error['stack']], null, 2));\n\t\t\t\t}\n\n\t\t\t\tprocess.exit(1);\n\t\t\t}\n\t\t\telse if (error && error['name'] === 'MongoError' && error['message'] === 'not master and slaveOk=false') {\n\t\t\t\tif (diffTimeSec > 60 && !this._lastErrorMsg) {\n\t\t\t\t\tthis._lastErrorMsg = new Date();\n\n\t\t\t\t\tsetTimeout(() => {\n\t\t\t\t\t\tthis._lastErrorMsg = null;\n\t\t\t\t\t}, 60000);\n\n\t\t\t\t\tawait this._methodManager.sendEmail('dev@resolveio.com', 'SERVER - Unhandled Rejection - Quitting NodeJS - ' + ResolveIOServer.getServerConfig()['CLIENT_NAME'], JSON.stringify([error['name'], error['message'], error['stack']], null, 2));\n\t\t\t\t}\n\n\t\t\t\tprocess.exit(1);\n\t\t\t}\n\t\t\telse if (error) {\n\t\t\t\tif (error['name'] !== 'StatusError' && error['message'] !== '') {\n\t\t\t\t\tif (diffTimeSec > 60 && !this._lastErrorMsg) {\n\t\t\t\t\t\tthis._lastErrorMsg = new Date();\n\n\t\t\t\t\t\tsetTimeout(() => {\n\t\t\t\t\t\t\tthis._lastErrorMsg = null;\n\t\t\t\t\t\t}, 60000);\n\n\t\t\t\t\t\tawait this._methodManager.sendEmail('dev@resolveio.com', 'SERVER - Unhandled Rejection - ' + ResolveIOServer.getServerConfig()['CLIENT_NAME'], JSON.stringify([error['name'], error['message'], error['stack']], null, 2));\n\t\t\t\t\t}\n\t\t\t\t}\n\t\t\t}\n\t\t});\n\n\t\tprocess.on('uncaughtException', async error => {\n\t\t\tconsole.error(error, 'Uncaught Exception thrown');\n\n\t\t\tlet diffTimeSec = moment().diff(this._serverStartTime, 'seconds');\n\n\t\t\tif (diffTimeSec > 60 && !this._lastErrorMsg) {\n\t\t\t\tthis._lastErrorMsg = new Date();\n\n\t\t\t\tsetTimeout(() => {\n\t\t\t\t\tthis._lastErrorMsg = null;\n\t\t\t\t}, 60000);\n\t\t\t\t\n\t\t\t\tawait this._methodManager.sendEmail('dev@resolveio.com', 'SERVER - Unhandled Exception - ' + ResolveIOServer.getServerConfig()['CLIENT_NAME'], JSON.stringify([error['name'], error['message'], error['stack']], null, 2));\n\t\t\t}\n\t\t});\n\n\t\t//PM2 wants to reboot/restart\n\t\tprocess.on('SIGINT', async () => {\n\t\t\tthis._rebootFlag = true;\n\t\t\tif (this._serverHTTP) {\n\t\t\t\tthis._serverHTTP.close();\n\t\t\t}\n\t\t\tawait this.safeShutdown();\n\t\t});\n\n\t\tprocess.on('SIGTERM', async () => {\n\t\t\tthis._rebootFlag = true;\n\t\t\tif (this._serverHTTP) {\n\t\t\t\tthis._serverHTTP.close();\n\t\t\t}\n\t\t\tawait this.safeShutdown();\n\t\t});\n\n\t\tprocess.on('SIGQUIT', async () => {\n\t\t\tthis._rebootFlag = true;\n\t\t\tif (this._serverHTTP) {\n\t\t\t\tthis._serverHTTP.close();\n\t\t\t}\n\t\t\tawait this.safeShutdown();\n\t\t});\n\n\t\tif (this.LOGGER === 'DEBUG') {\n\t\t\tconsole.log('Starting ResolveIO Server');\n\t\t}\n\n\t\tif (this._isWorkersEnabled) {\n\t\t\tif (this._isWorkerInstance) {\n\t\t\t\tconsole.log('Running as a Worker instance', process.env.NODE_APP_INSTANCE);\n\t\t\t\tthis._methodManager = MethodManager.create(null, this._monitorManagerFunction, this._isWorkersEnabled, this._isWorkerInstance);\n\t\t\t\tthis._workerServerManager = WorkerServerManager.create(this._methodManager, this.getServerConfig());\n\n\t\t\t\tif (process.env.WORKER_INDEX === '0') {\n\t\t\t\t\tthis._cronManager = CronManager.create();\n\t\t\t\t}\n\t\t\t}\n\t\t\telse {\n\t\t\t\tconsole.log('Running as a Server instance', process.env.NODE_APP_INSTANCE);\n\t\t\t\tthis._websocketManager = WebSocketManager.create(this);\n\t\t\t\tthis._methodManager = MethodManager.create(this._websocketManager, this._monitorManagerFunction, this._isWorkersEnabled, this._isWorkerInstance);\n\t\t\t\tthis._workerDispatcherManager = WorkerDispatcherManager.create(this._websocketManager, this._methodManager);\n\t\t\t\tthis._subscriptionManager = SubscriptionManager.create(this._serverWSS, ResolveIOServer.getServerConfig(), this._monitorManagerFunction);\n\t\t\t\tthis.startServerInstance();\n\t\t\t\tthis.listen();\n\t\t\t}\n\t\t}\n\t\telse {\n\t\t\tconsole.log('Running with Workers Disabled', process.env.NODE_APP_INSTANCE);\n\t\t\tthis._websocketManager = WebSocketManager.create(this);\n\t\t\tthis._methodManager = MethodManager.create(this._websocketManager, this._monitorManagerFunction, this._isWorkersEnabled, this._isWorkerInstance);\n\t\t\tthis._subscriptionManager = SubscriptionManager.create(this._serverWSS, ResolveIOServer.getServerConfig(), this._monitorManagerFunction);\n\t\t\tthis._cronManager = CronManager.create();\n\t\t\tthis.startServerInstance();\n\t\t\tthis.listen();\n\t\t}\n\t}\n\n\tprivate startServerInstance() {\n\t\t// Start express app\n\t\tthis._app = express();\n\n\t\tthis._app.use(bodyParser.json({limit: '50mb', reviver: dateReviver}));\n\t\tthis._app.use(bodyParser.urlencoded({limit: '50mb', extended: true, parameterLimit: 1000000 }));\n\t\tthis._app.use(xmlParser());\n\t\t\n\t\t// Set port\n\t\tthis._portHTTP = process.env.NODE_APP_INSTANCE ? parseInt('808' + process.env.NODE_APP_INSTANCE) : 8080;\n\n\t\tif (this.LOGGER === 'DEBUG') {\n\t\t\tconsole.log('Setup ports');\n\t\t}\n\n\t\t// Create http server and websock server\n\t\tthis.createServer();\n\n\t\tif (this.LOGGER === 'DEBUG') {\n\t\t\tconsole.log('Create server');\n\t\t}\n\n\t\t// Set CORS\n\t\tthis._app.use(function (req, res, next) {\n\t\t\tres.setHeader('Access-Control-Allow-Origin', '*');\n\t\t\tres.setHeader('Access-Control-Allow-Methods', 'GET, POST');\n\t\t\tres.setHeader('Access-Control-Allow-Headers', 'X-Requested-With,content-type');\n\t\t\tres.setHeader('Access-Control-Allow-Credentials', 'false');\n\t\t\tnext();\n\t\t});\n\n\t\tif (this.LOGGER === 'DEBUG') {\n\t\t\tconsole.log('Setup cors');\n\t\t}\n\n\t\t// Set up http login route\n\t\tsetupAuthRoutes(this, this._app, ResolveIOServer.getServerConfig());\n\t\tsetupHealthRoutes(this._app);\n\n\t\tif (ResolveIOServer.getServerConfig()['CLIENT_NAME'] === 'ResolveIO' || this.standardProgram) {\n\t\t\tsetupHomeRoutes(this, this._app, ResolveIOServer.getServerConfig());\n\t\t}\n\n\t\tif (this.LOGGER === 'DEBUG') {\n\t\t\tconsole.log('Setup express routes');\n\t\t}\n\t}\n\n\tprivate async safeShutdown() {\n\t\tif (!this._safeShutdown) {\n\t\t\tconsole.log(new Date(), 'Safe Shutdown Command Received');\n\t\t}\n\n\t\tif (\n\t\t\t!this._monitorManagerFunction.getActiveMonitorFunctions().length\n\t\t\t&& !this._offlineUpdates.length && (!this._workerDispatcherManager || this._workerDispatcherManager.isSafeShutdown())\n\t\t) {\n\t\t\tif (ResolveIOServer.getMongoConnection()) {\n\t\t\t\ttry {\n\t\t\t\t\tawait ResolveIOServer.getMongoConnection().close(false);\n\t\t\t\t\tconsole.log(new Date(), 'Safe Exit Complete, Process Exit');\n\t\t\t\t\tprocess.exit(0);\n\t\t\t\t}\n\t\t\t\tcatch { \n\t\t\t\t\tprocess.exit(1); \n\t\t\t\t};\n\t\t\t}\n\t\t\telse {\n\t\t\t\tprocess.exit(0);\n\t\t\t}\n\t\t}\n\t\telse {\n\t\t\tif (!this._safeShutdown) {\n\t\t\t\tthis._safeShutdown = true;\n\n\t\t\t\tsetTimeout(() => {\n\t\t\t\t\tthis._safeShutdown = false;\n\t\t\t\t}, 1000);\n\n\t\t\t\tconsole.log(new Date(), 'Safe Exit In Progress', \n\t\t\t\t\tthis._monitorManagerFunction.getActiveMonitorFunctions().length,\n\t\t\t\t\tthis._offlineUpdates.length\n\t\t\t\t);\n\t\t\t}\n\n\t\t\tsetImmediate(async () => {\n\t\t\t\tawait this.safeShutdown();\n\t\t\t});\n\t\t}\n\t}\n\n\tgetIsWorkersEnabled() {\n\t\treturn this._isWorkersEnabled;\n\t}\n\n\tgetIsWorkerInstance() {\n\t\treturn this._isWorkerInstance;\n\t}\n\n\tpublic getWSList() {\n\t\tlet res = [];\n\t\tthis._serverWSS.clients.forEach((ws: WebSocket) => {\n\t\t\tres.push(ws['id_socket']);\n\t\t});\n\t\treturn res;\n\t}\n\n\tpublic getWSUserList() {\n\t\tlet res = [];\n\t\tthis._serverWSS.clients.forEach((ws: WebSocket) => {\n\t\t\tres.push(ws['id_user']);\n\t\t});\n\t\treturn res;\n\t}\n\n\tpublic getHTTPServer() {\n\t\treturn this._serverHTTP;\n\t}\n\n\tpublic getCronManager() {\n\t\treturn this._cronManager;\n\t}\n\n\tpublic getMethodManager() {\n\t\treturn this._methodManager;\n\t}\n\n\tpublic getSubscriptionManager() {\n\t\treturn this._subscriptionManager;\n\t}\n\n\tpublic getMonitorManager() {\n\t\treturn this._monitorManager;\n\t}\n\n\tpublic getRebootFlag() {\n\t\treturn this._rebootFlag;\n\t}\n\n\tpublic getWebSocketManager(): WebSocketManager {\n\t\treturn this._websocketManager;\n\t}\n\n\tprivate createServer(): void {\n\t\tthis._serverHTTP = createServer(this._app);\n\t\tthis._serverHTTP.keepAliveTimeout = 65000;\n\t\tthis._serverHTTP.headersTimeout = 66000;\n\n\t\tthis._serverWSS = new WebSocket.Server({\n\t\t\tserver: this._serverHTTP,\n\t\t\tverifyClient: this.publicProgram ? null : (info, cb) => {\n\t\t\t\tif (this._rebootFlag) {\n\t\t\t\t\tcb(false, 409, 'Unable To Process');\n\t\t\t\t}\n\t\t\t\telse {\n\t\t\t\t\tif (this.LOGGER === 'DEBUG') {\n\t\t\t\t\t\tconsole.log('Verify Client', info, cb);\n\t\t\t\t\t}\n\n\t\t\t\t\t// If it's a worker, we might skip token checks or do a simple check:\n\t\t\t\t\tif (info.req.url && info.req.url.includes('workerToken=')) {\n\t\t\t\t\t\tlet urlParts = info.req.url.split('workerToken='); \n\t\t\t\t\t\tlet workerToken = urlParts[1] || '';\n\n\t\t\t\t\t\tif (workerToken === ResolveIOServer.getServerConfig()['WORKER_TOKEN']) {\n\t\t\t\t\t\t\tcb(true);\n\t\t\t\t\t\t}\n\t\t\t\t\t\telse {\n\t\t\t\t\t\t\tcb(false, 401, 'Unauthorized');\n\t\t\t\t\t\t}\n\n\t\t\t\t\t\treturn;\n\t\t\t\t\t}\n\n\t\t\t\t\tlet infoData = (<string>info.req.headers['sec-websocket-protocol']).split(/,/);\n\n\t\t\t\t\tif (\n\t\t\t\t\t\tinfo.origin !== ResolveIOServer.getServerConfig()['ROOT_URL']\n\t\t\t\t\t\t&& info.origin !== ResolveIOServer.getServerConfig()['SEC_ROOT_URL']\n\t\t\t\t\t\t&& info.origin !== ResolveIOServer.getServerConfig()['RESOLVEIO_URL']\n\t\t\t\t\t\t&& info.origin !== ResolveIOServer.getServerConfig()['RESOLVEIO_SECONDARY_URL']\n\t\t\t\t\t) {\n\t\t\t\t\t\tcb(false, 401, 'Unauthorized');\n\t\t\t\t\t}\n\t\t\t\t\telse {\n\t\t\t\t\t\tlet token = infoData[0];\n\t\t\t\t\t\tif (!token) {\n\t\t\t\t\t\t\tcb(false, 401, 'Unauthorized');\n\t\t\t\t\t\t}\n\t\t\t\t\t\telse {\n\t\t\t\t\t\t\tjwt.verify(token, ResolveIOServer.getServerConfig()['JWT_SECRET'], async (err, decoded) => {\n\t\t\t\t\t\t\t\tif (err) {\n\t\t\t\t\t\t\t\t\tcb(false, 401, 'Unauthorized');\n\t\t\t\t\t\t\t\t}\n\t\t\t\t\t\t\t\telse {\n\t\t\t\t\t\t\t\t\tinfo.req['id_user'] = decoded['id_user'];\n\t\t\t\t\t\t\t\t\ttry {\n\t\t\t\t\t\t\t\t\t\tlet user = await Users.findById(decoded['id_user']);\n\t\t\t\t\t\t\t\t\t\tif (user) {\n\t\t\t\t\t\t\t\t\t\t\tinfo.req['user'] = user.fullname;\n\t\t\t\t\t\t\t\t\t\t\tinfo.req['user_readonly'] = user.readonly || false;\n\t\t\t\t\t\t\t\t\t\t\tinfo.req['doc_user'] = user;\n\t\t\t\t\t\t\t\t\t\t\tcb(true);\n\t\t\t\t\t\t\t\t\t\t}\n\t\t\t\t\t\t\t\t\t\telse {\n\t\t\t\t\t\t\t\t\t\t\tcb(false);\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\tcatch {\n\t\t\t\t\t\t\t\t\t\tcb(false);\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}\n\t\t\t}\n\t\t});\n\t}\n\n\t/**\n\t * Listen for connections from clients or workers.\n\t */\n\tprivate listen(): void {\n\t\tthis._serverHTTP.listen(this._portHTTP, () => {\n\t\t\tconsole.log('Running HTTP/WS server on port %s', this._portHTTP);\n\t\t});\n\n\t\tthis._serverWSS.on('connection', async (ws, req) => {\n\t\t\tif (req.url && req.url.includes('workerToken=')) {\n\t\t\t\t// It's a WORKER\n\t\t\t\tlet workerId = objectIdHexString();\n\t\t\t\tws['id_worker'] = workerId;\n\n\t\t\t\tconsole.log(new Date(), process.env.NODE_APP_INSTANCE, 'Worker Connected', process.env.NODE_APP_INSTANCE);\n\n\t\t\t\tthis._workerDispatcherManager.addWorker(ws);\n\n\t\t\t\tlet interval = null;\n\t\t\t\tlet lastComm = null;\n\n\t\t\t\tthis._workerDispatcherManager.sendWorkerPayload(ws, 'ping');\n\t\n\t\t\t\tinterval = setInterval(() => {\n\t\t\t\t\tif (!lastComm) {\n\t\t\t\t\t\tthis._workerDispatcherManager.disconnectWorker(ws['id_worker']);\n\t\t\t\t\t\tws.close();\n\t\t\t\t\t}\n\t\t\t\t\telse {\n\t\t\t\t\t\tlastComm = null;\n\t\t\t\t\t\tthis._workerDispatcherManager.sendWorkerPayload(ws, 'ping');\n\t\t\t\t\t}\n\t\t\t\t}, 30000);\n\n\t\t\t\tws.on('message', (message: any) => {\n\t\t\t\t\t// console.log(new Date(), 'Message Recv', message);\n\n\t\t\t\t\tif (typeof message !== 'string') {\n\t\t\t\t\t\tmessage = message.toString();\n\t\t\t\t\t}\n\n\t\t\t\t\t// console.log(new Date(), 'String Message Recv', message);\n\n\t\t\t\t\tif (message === 'ping') {\n\t\t\t\t\t\t// console.log(new Date(), 'Recv Ping, Sending Pong');\n\t\t\t\t\t\tthis._workerDispatcherManager.sendWorkerPayload(ws, 'pong');\n\t\t\t\t\t}\n\t\t\t\t\telse if (message === 'pong') {\n\t\t\t\t\t\t// console.log(new Date(), 'Recv Ping, Sending Pong');\n\t\t\t\t\t\tlastComm = new Date();\n\t\t\t\t\t}\n\t\t\t\t\telse {\n\t\t\t\t\t\tthis._workerDispatcherManager.handleWorkerMessage(ws['id_worker'], message);\n\t\t\t\t\t}\n\t\t\t\t});\n\n\t\t\t\tws.on('close', () => {\n\t\t\t\t\tthis._workerDispatcherManager.disconnectWorker(ws['id_worker']);\n\n\t\t\t\t\tconsole.log(new Date(), 'Worker disconnected:', workerId);\n\t\t\t\t\t\n\t\t\t\t\tif (interval) {\n\t\t\t\t\t\tclearInterval(interval);\n\t\t\t\t\t}\n\t\t\t\t});\n\n\t\t\t\tws.on('error', (error) => {\n\t\t\t\t\tthis._workerDispatcherManager.disconnectWorker(ws['id_worker']);\n\n\t\t\t\t\tconsole.error('Error on WS Worker', error);\n\t\t\t\t\tws.close();\n\t\t\t\t});\n\t\t\t}\n\t\t\telse {\n\t\t\t\t// Normal client\n\t\t\t\tws['id_socket'] = objectIdHexString();\n\t\t\t\tws['id_user'] = req['id_user'];\n\t\t\t\tws['user'] = req['user'];\n\t\t\t\tws['user_readonly'] = req['user_readonly'];\n\t\t\t\tws['doc_user'] = req['doc_user'];\n\n\t\t\t\tthis._websocketManager.addWebSocket(ws);\n\n\t\t\t\tawait this._subscriptionManager.createLoggedInUser(ws['id_socket']);\n\t\t\t\t\n\t\t\t\tsetTimeout(() => {\n\t\t\t\t\tws['pingTime'] = new Date();\n\t\t\t\t\tws.send('ping', async (error) => {\n\t\t\t\t\t\tif (error) {\n\t\t\t\t\t\t\tif (this._subscriptionManager.getEnableDebug()) {\n\t\t\t\t\t\t\t\tconsole.log(new Date(), 'Server App', 'Error WS Ping');\n\t\t\t\t\t\t\t}\n\t\t\t\t\t\t\tawait this.unsubscribeWS(ws);\n\t\t\t\t\t\t}\n\t\t\t\t\t});\n\t\t\t\t}, 5000);\n\n\t\t\t\tif (this.LOGGER === 'DEBUG') {\n\t\t\t\t\tconsole.log('Connection from user: ' + req['user']);\n\t\t\t\t}\n\t\t\t\n\t\t\t\tws['isAlive'] = true;\n\t\t\t\tws['retryCnt'] = 0;\n\n\t\t\t\tws.on('message', async (message: string) => {\n\t\t\t\t\tthis._debugMsgRecv += 1;\n\t\t\t\t\tlet socketData = [];\n\t\t\t\t\n\t\t\t\t\ttry {\n\t\t\t\t\t\tsocketData = JSON.parse(message, dateReviver);\n\t\t\t\t\t}\n\t\t\t\t\tcatch (e) {\n\t\t\t\t\t\tconsole.log('Error - JSON.parse', message);\n\t\t\t\t\t\tawait this._methodManager.sendEmail(\n\t\t\t\t\t\t\t'dev@resolveio.com', \n\t\t\t\t\t\t\t'SERVER - JSON Parse Error - ' + ResolveIOServer.getServerConfig()['CLIENT_NAME'], \n\t\t\t\t\t\t\tJSON.stringify([message, e])\n\t\t\t\t\t\t);\n\t\t\t\t\t\treturn;\n\t\t\t\t\t}\n\n\t\t\t\t\t// call our existing processSocketMessage\n\t\t\t\t\tawait this.processSocketMessage(ws, socketData);\n\t\t\t\t})\n\t\t\t\t.on('end', () => {\n\t\t\t\t\tws.close();\n\t\t\t\t})\n\t\t\t\t.on('error', () => {\n\t\t\t\t\tws.close()\n\t\t\t\t})\n\t\t\t\t.on('close', async () => {\n\t\t\t\t\tawait this.unsubscribeWS(ws);\n\t\t\t\t});\n\t\t\t}\n\t\t});\n\n\t\t// Keep alive timer\n\t\tsetInterval(async () => {\n\t\t\tfor (let ws of this._serverWSS.clients) {\n\t\t\t\tif (ws['pingTime'] && Date.now() - ws['pingTime'].getTime() >= 20000) {\n\t\t\t\t\tif (ws['isAlive'] === false) {\n\t\t\t\t\t\tws['retryCnt']++;\n\t\t\t\t\t\tif (ws['retryCnt'] >= 3) {\n\t\t\t\t\t\t\tawait this.unsubscribeWS(ws);\n\t\t\t\t\t\t}\n\t\t\t\t\t\telse {\n\t\t\t\t\t\t\tws['pingTime'] = new Date();\n\t\t\t\t\t\t\tws.send('ping', async (error) => {\n\t\t\t\t\t\t\t\tif (error) {\n\t\t\t\t\t\t\t\t\tif (this._subscriptionManager.getEnableDebug()) {\n\t\t\t\t\t\t\t\t\t\tconsole.log(new Date(), 'Server App', 'Error WS Ping');\n\t\t\t\t\t\t\t\t\t}\n\t\t\t\t\t\t\t\t\tawait this.unsubscribeWS(ws);\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\telse {\n\t\t\t\t\t\tws['retryCnt'] = 0;\n\t\t\t\t\t\tws['isAlive'] = false;\n\t\t\t\t\t\tws['pingTime'] = new Date();\n\t\t\t\t\t\tws.send('ping', async (error) => {\n\t\t\t\t\t\t\tif (error) {\n\t\t\t\t\t\t\t\tif (this._subscriptionManager.getEnableDebug()) {\n\t\t\t\t\t\t\t\t\tconsole.log(new Date(), 'Server App', 'Error WS Ping');\n\t\t\t\t\t\t\t\t}\n\t\t\t\t\t\t\t\tawait this.unsubscribeWS(ws);\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\t\t}\n\t\t}, 20000);\n\t}\n\n\tprivate async processSocketMessage(ws: WebSocket, socketData: any) {\n\t\tif (typeof socketData === 'string' && socketData === 'ping') {\n\t\t\tif (ws && ws.readyState === ws.OPEN) {\n\t\t\t\tws.send('pong');\n\t\t\t}\n\t\t\treturn;\n\t\t}\n\t\telse if (typeof socketData === 'string' && socketData === 'pong') {\n\t\t\tws['isAlive'] = true;\n\t\t\tws['pongTime'] = new Date();\n\t\t\tws['latency'] = moment.duration(moment(ws['pongTime']).diff(ws['pingTime'])).asMilliseconds();\n\t\t\tthis._subscriptionManager.loggedInLatency(ws);\n\t\t\treturn;\n\t\t}\n\n\t\t// If the top level is not an array, let's skip\n\t\tif (!Array.isArray(socketData[0])) {\n\t\t\tconsole.log('Invalid message format (expected array of arrays)', socketData);\n\t\t\treturn;\n\t\t}\n\n\t\t// Handle each sub-message\n\t\tfor (let message of socketData) {\n\t\t\tawait this.handleClientMessage(ws, message);\n\t\t}\n\t}\n\n\tprivate async handleClientMessage(ws: WebSocket, msg: any[]): Promise<void> {\n\t\t// This is basically your old logic from processSocketMessage,\n\t\t// but we'll insert our worker-queue logic for \"method\" calls.\n\n\t\tlet messageRoute = msg[0];\n\t\tlet messageDate = msg[1];\n\t\tlet messageId = msg[2];\n\t\tlet type = msg[3];\n\n\t\tif (!this.publicProgram && this._clientRoutes.some(a => messageRoute.includes(a)) && !ws['doc_user'].roles.groups.some(a => a.views.some(b => messageRoute.includes(b) || b.includes(messageRoute))) && !ws['doc_user'].roles.super_admin) {\n\t\t\treturn;\n\t\t}\n\n\t\tif (type === 'subscription') {\n\t\t\tlet subType = msg[4];\n\t\t\tlet pub = msg[5];\n\n\t\t\tif (subType === 'sub') {\n\t\t\t\tawait this._subscriptionManager.subscribe(messageRoute, messageDate, ws, messageId, pub, msg.slice(6));\n\t\t\t}\n\t\t\telse {\n\t\t\t\tthis._subscriptionManager.unsubscribe(messageRoute, messageDate, ws, messageId, pub, msg.slice(6));\n\t\t\t}\n\t\t}\n\t\telse if (!this.publicProgram && type === 'offline') {\n\t\t\tlet serverRes: ServerResponseModel = {\n\t\t\t\tmessageId: messageId,\n\t\t\t\thasError: false,\n\t\t\t\tdata: 'ACK'\n\t\t\t};\n\n\t\t\tif (ws && ws.readyState === ws.OPEN) {\n\t\t\t\tthis._websocketManager.send(ws, serverRes);\n\t\t\t}\n\n\t\t\tthis._offlineUpdates.push(ws);\n\t\t\tlet offlineUpdates = msg[4];\n\n\t\t\tfor (let i = 0; i < offlineUpdates.length; i++) {\n\t\t\t\tlet update = offlineUpdates[i];\n\n\t\t\t\tlet data = update.data;\n\n\t\t\t\t// eslint-disable-next-line no-unused-vars\n\t\t\t\tlet updateRoute = data.shift();\n\t\t\t\t// eslint-disable-next-line no-unused-vars\n\t\t\t\tlet updateDate = data.shift();\n\t\t\t\tlet updateMessageId = data.shift();\n\t\t\t\t// eslint-disable-next-line no-unused-vars\n\t\t\t\tlet updateType = data.shift();\n\t\t\t\tlet method = data.shift();\n\n\t\t\t\tlet serverResMethod: ServerResponseModel = {\n\t\t\t\t\tmessageId: updateMessageId,\n\t\t\t\t\thasError: false,\n\t\t\t\t\tdata: 'ACK'\n\t\t\t\t};\n\n\t\t\t\tif (ws && ws.readyState === ws.OPEN) {\n\t\t\t\t\tthis._websocketManager.send(ws, serverResMethod);\n\t\t\t\t}\n\n\t\t\t\tif (method === 'insertDocument' && data[0] === 'driver-gps') {\n\t\t\t\t\tcontinue;\n\t\t\t\t}\n\t\t\t\t\n\t\t\t\tif (method !== 'reportBuilderGetResults' && method !== 'reportBuilderGetDistinctValue' && method !== 'reportBuilderBuildTree' && method !== 'generatePDF' && method !== 'getWOOfflineData' && method !== 'countQuery' && method !== 'countWithQuery' && method !== 'countCollectionWithQuery' && method !== 'find' && method !== 'findOne' && method !== 'findWithOptions' && method !== 'getDrivers' && method !== 'processAirdropDistribution' && method !== 'qbHandleResponse') {\n\t\t\t\t\tif (\n\t\t\t\t\t\tResolveIOServer.getServerConfig()['ROOT_URL'] !== 'https://resolveio.com'\n\t\t\t\t\t&& ResolveIOServer.getServerConfig()['ROOT_URL'] !== 'http://localhost:4200'\n\t\t\t\t\t) {\n\t\t\t\t\t\tResolveIOServer.getLocalLogManager().writeLog({\n\t\t\t\t\t\t\ttype: 'log',\n\t\t\t\t\t\t\tdata: {\n\t\t\t\t\t\t\t\t_id: objectIdHexString(),\n\t\t\t\t\t\t\t\tcreatedAt: new Date(),\n\t\t\t\t\t\t\t\ttype: 'client-request',\n\t\t\t\t\t\t\t\tcollection: '',\n\t\t\t\t\t\t\t\tid_document: '',\n\t\t\t\t\t\t\t\tpayload: getBinarySize(JSON.stringify([data])) < 1000000 ? JSON.stringify([data], null, 2) : 'Too Big',\n\t\t\t\t\t\t\t\tmethod: method,\n\t\t\t\t\t\t\t\tid_user: ws['id_user'] || '',\n\t\t\t\t\t\t\t\tuser: ws['user'] || '',\n\t\t\t\t\t\t\t\tmessageId: messageId,\n\t\t\t\t\t\t\t\troute: messageRoute\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\telse {\n\t\t\t\t\t\tawait Logs.insertOne({\n\t\t\t\t\t\t\t_id: objectIdHexString(),\n\t\t\t\t\t\t\ttype: 'client-request',\n\t\t\t\t\t\t\tcollection: '',\n\t\t\t\t\t\t\tid_document: '',\n\t\t\t\t\t\t\tpayload: getBinarySize(JSON.stringify([data])) < 1000000 ? JSON.stringify([data], null, 2) : 'Too Big',\n\t\t\t\t\t\t\tmethod: method,\n\t\t\t\t\t\t\tid_user: ws['id_user'] || '',\n\t\t\t\t\t\t\tuser: ws['user'] || '',\n\t\t\t\t\t\t\tmessageId: messageId,\n\t\t\t\t\t\t\troute: messageRoute,\n\t\t\t\t\t\t\tclient: 'ResolveIO',\n\t\t\t\t\t\t\tinstance: 'backend.resolveio.com',\n\t\t\t\t\t\t\tinstance_index: process.env.NODE_APP_INSTANCE || ''\n\t\t\t\t\t\t});\n\t\t\t\t\t}\n\t\t\t\t}\n\n\t\t\t\tif (this._methodManager._methods[method]) {\n\t\t\t\t\ttry {\n\t\t\t\t\t\tawait this._methodManager.callMethod.call(Object.assign({}, this._methodManager, MethodManager.prototype, {id_user: ws['id_user'], user: ws['user'], id_ws: ws['id_socket']}), method, ...data);\n\t\t\t\t\t}\n\t\t\t\t\tcatch (err) {\n\t\t\t\t\t\tconsole.log(new Date(), 'Offline Error', JSON.stringify(err, null, 2));\n\t\t\t\t\t}\n\n\t\t\t\t\tif (method === 'updateDocumentOffline' || method === 'updateDocumentPropsOffline') {\n\t\t\t\t\t\tResolveIOServer.getMongoManager().invalidateQueryCache(data[0]);\n\t\t\t\t\t}\n\t\t\t\t}\n\t\t\t\telse {\n\t\t\t\t\tconsole.log('Offline - Could not find method: ' + method);\n\t\t\t\t}\n\t\t\t}\n\n\t\t\tthis._offlineUpdates.splice(this._offlineUpdates.map(a => a['id_socket']).indexOf(ws['id_socket']), 1);\n\t\t}\n\t\telse {\n\t\t\t// It's presumably a 'method' or something else\n\t\t\tlet dataCopy = [...msg];\n\n\t\t\t// eslint-disable-next-line no-unused-vars\n\t\t\tlet route = dataCopy.shift();\n\t\t\t// eslint-disable-next-line no-unused-vars\n\t\t\tlet date = dataCopy.shift();\n\t\t\tlet msgId = dataCopy.shift();\n\t\t\tlet msgType = dataCopy.shift();\n\t\t\t\n\t\t\tif (msgType === 'method') {\n\t\t\t\tlet methodName = dataCopy.shift();\n\n\t\t\t\tif (ws['user_readonly']) {\n\t\t\t\t\treturn;\n\t\t\t\t}\n\n\t\t\t\tif (methodName !== 'reportBuilderGetResults' && methodName !== 'reportBuilderGetDistinctValue' && methodName !== 'reportBuilderBuildTree' && methodName !== 'generatePDF' && methodName !== 'getWOOfflineData' && methodName !== 'countQuery' && methodName !== 'countWithQuery' && methodName !== 'countCollectionWithQuery' && methodName !== 'find' && methodName !== 'findOne' && methodName !== 'findWithOptions' && methodName !== 'getDrivers' && methodName !== 'processAirdropDistribution') {\n\t\t\t\t\tif (\n\t\t\t\t\t\tResolveIOServer.getServerConfig()['ROOT_URL'] !== 'https://resolveio.com'\n\t\t\t\t\t&& ResolveIOServer.getServerConfig()['ROOT_URL'] !== 'http://localhost:4200'\n\t\t\t\t\t) {\n\t\t\t\t\t\tResolveIOServer.getLocalLogManager().writeLog({\n\t\t\t\t\t\t\ttype: 'log',\n\t\t\t\t\t\t\tdata: {\n\t\t\t\t\t\t\t\t_id: objectIdHexString(),\n\t\t\t\t\t\t\t\tcreatedAt: new Date(),\n\t\t\t\t\t\t\t\ttype: 'client-request',\n\t\t\t\t\t\t\t\tcollection: '',\n\t\t\t\t\t\t\t\tid_document: '',\n\t\t\t\t\t\t\t\tpayload: getBinarySize(JSON.stringify([dataCopy])) < 1000000 ? JSON.stringify([dataCopy], null, 2) : 'Too Big',\n\t\t\t\t\t\t\t\tmethod: methodName,\n\t\t\t\t\t\t\t\tid_user: ws['id_user'] || '',\n\t\t\t\t\t\t\t\tuser: ws['user'] || '',\n\t\t\t\t\t\t\t\tmessageId: messageId,\n\t\t\t\t\t\t\t\troute: messageRoute\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\telse {\n\t\t\t\t\t\tawait Logs.insertOne({\n\t\t\t\t\t\t\t_id: objectIdHexString(),\n\t\t\t\t\t\t\ttype: 'client-request',\n\t\t\t\t\t\t\tcollection: '',\n\t\t\t\t\t\t\tid_document: '',\n\t\t\t\t\t\t\tpayload: getBinarySize(JSON.stringify([dataCopy])) < 1000000 ? JSON.stringify([dataCopy], null, 2) : 'Too Big',\n\t\t\t\t\t\t\tmethod: methodName,\n\t\t\t\t\t\t\tid_user: ws['id_user'] || '',\n\t\t\t\t\t\t\tuser: ws['user'] || '',\n\t\t\t\t\t\t\tmessageId: messageId,\n\t\t\t\t\t\t\troute: messageRoute,\n\t\t\t\t\t\t\tclient: 'ResolveIO',\n\t\t\t\t\t\t\tinstance: 'backend.resolveio.com',\n\t\t\t\t\t\t\tinstance_index: process.env.NODE_APP_INSTANCE || ''\n\t\t\t\t\t\t});\n\t\t\t\t\t}\n\t\t\t\t}\n\n\t\t\t\t// Immediately ACK\n\t\t\t\tlet ack: ServerResponseModel = {\n\t\t\t\t\tmessageId: msgId,\n\t\t\t\t\thasError: false,\n\t\t\t\t\tdata: 'ACK'\n\t\t\t\t};\n\n\t\t\t\tif (ws && ws.readyState === ws.OPEN) {\n\t\t\t\t\tthis._websocketManager.send(ws, ack);\n\t\t\t\t}\n\n\t\t\t\tlet method = this._methodManager.getMethod(methodName);\n\n\t\t\t\tif (method && \n\t\t\t\t\t!method.skipWorker &&\n\t\t\t\t\tthis._isWorkersEnabled && \n\t\t\t\t\tmethodName !== 'find' &&\n\t\t\t\t\tmethodName !== 'insertDocument' &&\n\t\t\t\t\tmethodName !== 'countWithQuery' &&\n\t\t\t\t\tmethodName !== 'findOne' &&\n\t\t\t\t\tmethodName !== 'updateDocumentProps' &&\n\t\t\t\t\tmethodName !== 'findWithOptions' &&\n\t\t\t\t\tmethodName !== 'updateDocument' &&\n\t\t\t\t\tmethodName !== 'insertErrorLog' &&\n\t\t\t\t\tmethodName !== 'removeDocument' &&\n\t\t\t\t\tmethodName !== 'supportCreateBillingUser' &&\n\t\t\t\t\tmethodName !== 'getSignedUrl' &&\n\t\t\t\t\tmethodName !== 'getSignedUrls' &&\n\t\t\t\t\tmethodName !== 'getSignedUrlWithId' &&\n\t\t\t\t\tmethodName !== 'incorrectUser' &&\n\t\t\t\t\tmethodName !== 'reloadWS' &&\n\t\t\t\t\tmethodName !== 'reconnectWS' &&\n\t\t\t\t\tmethodName !== 'disconnectWS'\n\t\t\t\t) {\t\t\t\t\t\n\t\t\t\t\tthis._workerDispatcherManager.sendClientTask(msgId, methodName, dataCopy, {\n\t\t\t\t\t\tid_user: ws['id_user'],\n\t\t\t\t\t\tuser: ws['user'],\n\t\t\t\t\t\tid_ws: ws['id_socket']\n\t\t\t\t\t});\n\t\t\t\t}\n\t\t\t\telse {\n\t\t\t\t\t// No worker available: do method locally\n\t\t\t\t\tawait this.callMethodLocally(ws, msgId, methodName, dataCopy);\n\t\t\t\t}\n\t\t\t}\n\t\t}\n\t}\n\n\t/**\n\t * callMethodLocally is your old approach for invoking the method in-process.\n\t */\n\tprivate async callMethodLocally(ws: WebSocket, messageId: number, method: string, params: any[]) {\n\t\tlet serverRes: ServerResponseModel = {\n\t\t\tmessageId: messageId,\n\t\t\thasError: false,\n\t\t\tdata: null\n\t\t};\n\n\t\ttry {\n\t\t\t// You can keep your logging code (LogMethodLatencies, Logs.insertOne, etc.)\n\t\t\tlet result = await this._methodManager.callMethod.call(\n\t\t\t\tObject.assign({}, this._methodManager, MethodManager.prototype, {\n\t\t\t\t\tid_user: ws['id_user'],\n\t\t\t\t\tuser: ws['user'],\n\t\t\t\t\tid_ws: ws['id_socket']\n\t\t\t\t}),\n\t\t\t\tmethod,\n\t\t\t\t...params\n\t\t\t);\n\n\t\t\tserverRes.data = result;\n\t\t}\n\t\tcatch (err) {\n\t\t\tserverRes.hasError = true;\n\t\t\tserverRes.data = err || 'Unknown error';\n\t\t}\n\n\t\tif (ws && ws.readyState === ws.OPEN) {\n\t\t\tthis._websocketManager.send(ws, serverRes);\n\t\t}\n\t}\n\n\t\n\n\t/**\n\t * Cleanly remove a client from the subscription manager, etc.\n\t */\n\tpublic async unsubscribeWS(ws: WebSocket) {\n\t\tif (this._subscriptionManager && this._subscriptionManager.getEnableDebug()) {\n\t\t\tconsole.log(new Date(), 'Server App', 'Unsub WS', ws['user'], ws['id_socket']);\n\t\t}\n\t\tawait this._subscriptionManager.unsubscribeAll(ws);\n\t\tws.removeAllListeners();\n\t\tws = null;\n\t}\n\n\tpublic getApp() {\n\t\treturn this._app;\n\t}\n\n\tpublic getServerConfig() {\n\t\treturn ResolveIOServer.getServerConfig();\n\t}\n\n\tpublic getWorkerDispatcherManager() {\n\t\treturn this._workerDispatcherManager;\n\t}\n\n\tpublic getWorkerServerManager() {\n\t\treturn this._workerServerManager;\n\t}\n}"]}
|
package/util/common.js
CHANGED
|
@@ -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)},__read=this&&this.__read||function(e,t){var r="function"==typeof Symbol&&e[Symbol.iterator];if(!r)return e;var o,n,i=r.call(e),a=[];try{for(;(void 0===t||0<t--)&&!(o=i.next()).done;)a.push(o.value)}catch(e){n={error:e}}finally{try{o&&!o.done&&(r=i.return)&&r.call(i)}finally{if(n)throw n.error}}return a},__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.")},__spreadArray=this&&this.__spreadArray||function(e,t,r){if(r||2===arguments.length)for(var o,n=0,i=t.length;n<i;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))},rusDiff=(Object.defineProperty(exports,"__esModule",{value:!0}),exports.mergeDeep=exports.isObject=exports.toTitleCase=exports.randomString=exports.pad=exports.getBinarySize=exports.deepDiffDetails=exports.applyMongoUpdate=exports.getDeepDiff=exports.mergeUpdates=exports.getMongoMergeUpdatedDoc=exports.getMongoUpdates=exports.dateReviver=exports.deepCopy=exports.floorPrecision=exports.round=exports.roundPrecision=exports.throwErr=exports.buildRbLookups=exports.buildRbSchema=exports.objectIdHexString=void 0,require("rus-diff")),deepDiff=require("deep-diff").diff,deep_object_diff_1=require("deep-object-diff"),clone=require("clone"),moment=require("moment-timezone"),mongodb_1=require("mongodb");function objectIdHexString(){return(new mongodb_1.ObjectId).toHexString()}function buildRbSchema(t){return Object.keys(t).forEach(function(e){t[e].type===Object?(t[e].type="Object",t[e].rbType="Object"):t[e].type===Array?(t[e].type="Array",t[e].rbType="Array"):t[e].type===String?(t[e].type="String",t[e].rbType="String"):t[e].type===Date?(t[e].type="Date",t[e].rbType="Date"):t[e].type===Number?(t[e].type="Number",t[e].rbType="Number"):t[e].type===Boolean&&(t[e].rbType="Boolean",t[e].type="Boolean")}),Object.keys(t).forEach(function(e){delete t[e].type}),t}function buildRbLookups(e,a,t){void 0===t&&(t=[]),e.forEach(function(e){var t,r="",o="",n="",i=toTitleCase(e.lookup.replace(/\_/g," "))+" ("+toTitleCase(e.local_key.replace("id_","").replace(/\_/g," ").replace(/\.\$\./g," -> ").replace(/\./g," -> "))+") (Lookup)",i=(e.local_key.match(/\./)?(t=e.local_key.replace(/\.\$/g,""),o=(n=e.local_key.replace(/^(.+\.).*$/,"$1")).replace(/\.$/,"")):t=e.local_key,n=n+i,a[e.local_key]?a[e.local_key].type!==String&&(r+="--local_key: '"+e.local_key+"' MUST be a String! "):r+="--local_key: '"+e.local_key+"' MUST be a valid schema path! ",{lookup_collection:e.lookup,lookup_collection_alias:i,local_key:t,field_path:o,lookup_as:n,lookup_key:"_id",type:"Object"});a[n]=i,r&&throwErr(r,e,i,n)});for(var r=0;r<t.length;r++)a[t[r]]={},a[t[r]].default_checked=!0,Object.assign(a[t[r]],a.tree[t[r]]);return a}function throwErr(e,t,r,o){void 0===o&&(o=""),console.log("------- ERROR thrown by rbLookups: "),console.log(e),console.log("---item: "),console.log(t),console.log("---Attempted to create rbSchema['"+o+"']: "),console.log(r),process.exit(1)}function roundPrecision(e,t){void 0===t&&(t=0);e=e.toString(),e.includes(".")&&("0"===e[0]&&(t+=1),t-=e.indexOf(".")),t=Math.pow(10,t);return Math.round(parseFloat(e)*t)/t}function round(e,t){void 0===t&&(t=0);t=Math.pow(10,t);return Math.round(e*t+1e-6)/t}function floorPrecision(e,t){void 0===t&&(t=0);e=e.toString(),e.includes(".")&&("0"===e[0]&&(t+=1),t-=e.indexOf(".")),t=Math.pow(10,t);return Math.floor(parseFloat(e)*t)/t}function deepCopy(e){return clone(e)}function dateReviver(e,t){if("string"==typeof t){var r=/^(\d{4})-(\d{2})-(\d{2})T(\d{2}):(\d{2}):(\d{2}(?:\.\d*)?)Z$/.exec(t);if(r)return new Date(Date.UTC(+r[1],+r[2]-1,+r[3],+r[4],+r[5],+r[6].split(".")[0],+r[6].split(".")[1]))}return t}function getMongoUpdates(e,t,r){e.createdAt&&(t.createdAt=e.createdAt),e.updatedAt&&(t.updatedAt=e.updatedAt);e=rusDiff.diff(e,t);return e?(e.$set&&!Object.keys(e.$set).length&&delete e.$set,r&&(e.$inc={__v:1})):r&&(e={$inc:{__v:1}}),e}function getMongoMergeUpdatedDoc(e,t,r){var o=deepCopy(r),t=(o.__v=t.__v,getDeepDiff(r,t));return applyMongoUpdate(o,mergeUpdates(getDeepDiff(r,e),t)),o}function mergeUpdates(){for(var e=[],t=0;t<arguments.length;t++)e[t]=arguments[t];var r={$set:{},$unset:{},$inc:{},$push:{},$pull:{}};return e.filter(Boolean).forEach(function(e){e.forEach(function(e){var t=e.path.join(".");switch(e.kind){case"E":handleEditedChange(r,t,e);break;case"A":handleArrayChange(r,t,e)}})}),r}function handleEditedChange(e,t,r){"number"==typeof r.rhs&&(t.includes("quantity")||t.includes("qty"))?e.$inc[t]=(e.$inc[t]||0)+r.rhs-r.lhs:e.$set[t]=r.rhs}function handleArrayChange(e,t,r){"N"===r.item.kind?(e.$push[t]=e.$push[t]||[],e.$push[t].some(function(e){return JSON.stringify(e)===JSON.stringify(r.item.rhs)})||e.$push[t].push(r.item.rhs)):"D"===r.item.kind&&(e.$pull[t]=e.$pull[t]||[],e.$pull[t].some(function(e){return JSON.stringify(e)===JSON.stringify(r.item.lhs)})||e.$pull[t].push(r.item.lhs))}function getDeepDiff(e,t){return delete e._id,delete e.__v,e.updatedAt&&delete e.updatedAt,e.createdAt&&delete e.createdAt,delete t._id,delete t.__v,t.updatedAt&&delete t.updatedAt,t.createdAt&&delete t.createdAt,deepDiff(e,t)}function applyMongoUpdate(e,t){var r=deepCopy(e);return t&&(t.$rename&&handleRename(e,t.$rename),t.$set&&handleSet(e,t.$set),t.$inc&&handleInc(e,t.$inc),t.$unset&&handleUnset(e,t.$unset),t.$pull&&handlePull(e,r,t.$pull),t.$push)&&handlePush(e,t.$push),e}function handleRename(e,t){for(var r in t){var o=t[r],n=__read(resolve(e,r),2),i=n[0],n=n[1],a=__read(resolve(e,o),2),l=a[0],a=a[1];i&&1===n.length?l&&1===a.length?(l[a[0]]=i[n[0]],delete i[n[0]]):logError(l,a,e,o):logError(i,n,e,r)}}function handleSet(e,t){for(var r in t){var o=t[r],n=__read(resolve(e,r,{force:!0}),2),i=n[0],n=n[1];i&&1===n.length?i[n[0]]=o:logError(i,n,e,r)}}function handleInc(e,t){for(var r in t){var o=t[r],n=__read(resolve(e,r,{force:!0}),2),i=n[0],n=n[1];i&&1===n.length?i[n[0]]=(i[n[0]]||0)+o:logError(i,n,e,r)}}function handleUnset(e,t){for(var r in t){var o=__read(resolve(e,r),2),n=o[0],o=o[1];n&&1===o.length?delete n[o[0]]:logError(n,o,e,r)}}function handlePull(i,a,e){var t,r,l;for(l in e){var o=e[l];try{t=void 0;for(var n=__values(o),s=n.next();!s.done;s=n.next())!function(t){var e=__read(resolve(i,l),2),r=e[0],e=e[1],o=__read(resolve(a,l),2),n=o[0],o=o[1];r&&1===e.length?r[e[0]].splice(n[o[0]].findIndex(function(e){return JSON.stringify(e)===JSON.stringify(t)}),1):logError(r,e,i,l)}(s.value)}catch(e){t={error:e}}finally{try{s&&!s.done&&(r=n.return)&&r.call(n)}finally{if(t)throw t.error}}}}function handlePush(e,t){var r,o,n;for(n in t){var i=t[n];try{r=void 0;for(var a=__values(i),l=a.next();!l.done;l=a.next()){var s=l.value,d=__read(resolve(e,n),2),c=d[0],p=d[1];c&&1===p.length?c[p[0]].push(s):logError(c,p,e,n)}}catch(e){r={error:e}}finally{try{l&&!l.done&&(o=a.return)&&o.call(a)}finally{if(r)throw r.error}}}}function logError(e,t,r,o){console.log("Error",e+"/"+t+" - couldn't resolve for "+JSON.stringify(r)+" "+o)}function resolve(e,t,r){void 0===r&&(r={});for(var o=arrize(t),n=[],i=(0<o.length&&n.unshift(o.pop()),e);0<o.length;){var a=o.shift();if(void 0===i[a]){if(!r.force){n.unshift(a),n=o.concat(n);break}var l="number"==typeof o[0],s=0===o.length&&"number"==typeof n[0];i[a]=l||s?[]:{}}i=i[a]}return[i,n]}function arrize(e,t){return void 0===t&&(t="."),Array.isArray(e)?e.slice():null==e||!1===e||""===e?[]:e.toString().split(t).map(function(e){return[void 0,null,!1,""].includes(e)?null:e.toString()}).filter(function(e){return null!==e})}function deepDiffDetails(e,t){var r=deepCopy(e),o=deepCopy(t),n=(0,deep_object_diff_1.detailedDiff)(r,o),i="",l=function(t){return t instanceof Date?moment(t).format("llll"):"object"==typeof t&&null!==t?(Object.keys(t).filter(function(e){return e.startsWith("_id")||e.startsWith("id_")}).forEach(function(e){delete t[e]}),JSON.stringify(t)):"string"==typeof t?'"'.concat(t,'"'):String(t)},s=function(o,n){if(null===o||null===n||"object"!=typeof o||"object"!=typeof n)return"from: ".concat(l(o)," to: ").concat(l(n));if(Array.isArray(o)||Array.isArray(n)){for(var e=Array.isArray(o)?o:[],t=Array.isArray(n)?n:[],r=[],i=Math.max(e.length,t.length),a=0;a<i;a++)e[a]&&!t[a]?r.push("Removed at index ".concat(a,": ").concat(l(e[a]))):!e[a]&&t[a]?r.push("Added at index ".concat(a,": ").concat(l(t[a]))):e[a]&&t[a]&&JSON.stringify(e[a])!==JSON.stringify(t[a])&&r.push("Changed at index ".concat(a,": {").concat(s(e[a],t[a]),"}"));return r.join(", ")}return Object.keys(__assign(__assign({},o),n)).filter(function(e){return!e.startsWith("_id")&&!e.startsWith("id_")}).map(function(e){var t=o?o[e]:void 0,r=n?n[e]:void 0;return"".concat(toTitleCase(e),": ").concat(s(t,r))}).join(", ")};return["added","deleted","updated"].forEach(function(t){var e;0<Object.keys(n[t]).length&&(e=Object.keys(n[t]).filter(function(e){return"added"===t||("deleted"===t?!n.added[e]:!n.added[e]&&!n.deleted[e])}).filter(function(e){return!e.startsWith("_id")&&!e.startsWith("id_")}).map(function(e){return"\n".concat(toTitleCase(e),": ").concat(s(r[e],o[e]))}).join(","),i+=e?"".concat(e):"")}),i}function getBinarySize(e){return e?Buffer.byteLength(e,"utf8"):0}function pad(e,t){for(var r=e+"";r.length<t;)r="0"+r;return r}function randomString(e,t){for(var r="",o=e;0<o;--o)r+=t[Math.floor(Math.random()*t.length)];return r}function toTitleCase(e){return e.replace(/\w\S*/g,function(e){return e.charAt(0).toUpperCase()+e.substr(1).toLowerCase()})}function isObject(e){return e&&"object"==typeof e&&!Array.isArray(e)}function mergeDeep(e){for(var t,r=[],o=1;o<arguments.length;o++)r[o-1]=arguments[o];if(!r.length)return e;var n=r.shift();if(isObject(e)&&isObject(n))for(var i in n)isObject(n[i])?(e[i]||Object.assign(e,((t={})[i]={},t)),mergeDeep(e[i],n[i])):Object.assign(e,((t={})[i]=n[i],t));return mergeDeep.apply(void 0,__spreadArray([e],__read(r),!1))}exports.objectIdHexString=objectIdHexString,exports.buildRbSchema=buildRbSchema,exports.buildRbLookups=buildRbLookups,exports.throwErr=throwErr,exports.roundPrecision=roundPrecision,exports.round=round,exports.floorPrecision=floorPrecision,exports.deepCopy=deepCopy,exports.dateReviver=dateReviver,exports.getMongoUpdates=getMongoUpdates,exports.getMongoMergeUpdatedDoc=getMongoMergeUpdatedDoc,exports.mergeUpdates=mergeUpdates,exports.getDeepDiff=getDeepDiff,exports.applyMongoUpdate=applyMongoUpdate,exports.deepDiffDetails=deepDiffDetails,exports.getBinarySize=getBinarySize,exports.pad=pad,exports.randomString=randomString,exports.toTitleCase=toTitleCase,exports.isObject=isObject,exports.mergeDeep=mergeDeep;
|
|
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)},__read=this&&this.__read||function(e,t){var r="function"==typeof Symbol&&e[Symbol.iterator];if(!r)return e;var o,n,i=r.call(e),a=[];try{for(;(void 0===t||0<t--)&&!(o=i.next()).done;)a.push(o.value)}catch(e){n={error:e}}finally{try{o&&!o.done&&(r=i.return)&&r.call(i)}finally{if(n)throw n.error}}return a},__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.")},__spreadArray=this&&this.__spreadArray||function(e,t,r){if(r||2===arguments.length)for(var o,n=0,i=t.length;n<i;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))},rusDiff=(Object.defineProperty(exports,"__esModule",{value:!0}),exports.mergeDeep=exports.isObject=exports.toTitleCase=exports.randomString=exports.pad=exports.getBinarySize=exports.deepDiffDetails=exports.applyMongoUpdate=exports.getDeepDiff=exports.mergeUpdates=exports.getMongoMergeUpdatedDoc=exports.getMongoUpdates=exports.dateReviver=exports.deepCopy=exports.floorPrecision=exports.round=exports.roundPrecision=exports.throwErr=exports.buildRbLookups=exports.buildRbSchema=exports.objectIdHexString=void 0,require("rus-diff")),deepDiff=require("deep-diff").diff,deep_object_diff_1=require("deep-object-diff"),moment=require("moment-timezone"),mongodb_1=require("mongodb"),clone=require("clone");function objectIdHexString(){return(new mongodb_1.ObjectId).toHexString()}function buildRbSchema(t){return Object.keys(t).forEach(function(e){t[e].type===Object?(t[e].type="Object",t[e].rbType="Object"):t[e].type===Array?(t[e].type="Array",t[e].rbType="Array"):t[e].type===String?(t[e].type="String",t[e].rbType="String"):t[e].type===Date?(t[e].type="Date",t[e].rbType="Date"):t[e].type===Number?(t[e].type="Number",t[e].rbType="Number"):t[e].type===Boolean&&(t[e].rbType="Boolean",t[e].type="Boolean")}),Object.keys(t).forEach(function(e){delete t[e].type}),t}function buildRbLookups(e,a,t){void 0===t&&(t=[]),e.forEach(function(e){var t,r="",o="",n="",i=toTitleCase(e.lookup.replace(/\_/g," "))+" ("+toTitleCase(e.local_key.replace("id_","").replace(/\_/g," ").replace(/\.\$\./g," -> ").replace(/\./g," -> "))+") (Lookup)",i=(e.local_key.match(/\./)?(t=e.local_key.replace(/\.\$/g,""),o=(n=e.local_key.replace(/^(.+\.).*$/,"$1")).replace(/\.$/,"")):t=e.local_key,n=n+i,a[e.local_key]?a[e.local_key].type!==String&&(r+="--local_key: '"+e.local_key+"' MUST be a String! "):r+="--local_key: '"+e.local_key+"' MUST be a valid schema path! ",{lookup_collection:e.lookup,lookup_collection_alias:i,local_key:t,field_path:o,lookup_as:n,lookup_key:"_id",type:"Object"});a[n]=i,r&&throwErr(r,e,i,n)});for(var r=0;r<t.length;r++)a[t[r]]={},a[t[r]].default_checked=!0,Object.assign(a[t[r]],a.tree[t[r]]);return a}function throwErr(e,t,r,o){void 0===o&&(o=""),console.log("------- ERROR thrown by rbLookups: "),console.log(e),console.log("---item: "),console.log(t),console.log("---Attempted to create rbSchema['"+o+"']: "),console.log(r),process.exit(1)}function roundPrecision(e,t){void 0===t&&(t=0);e=e.toString(),e.includes(".")&&("0"===e[0]&&(t+=1),t-=e.indexOf(".")),t=Math.pow(10,t);return Math.round(parseFloat(e)*t)/t}function round(e,t){void 0===t&&(t=0);t=Math.pow(10,t);return Math.round(e*t+1e-6)/t}function floorPrecision(e,t){void 0===t&&(t=0);e=e.toString(),e.includes(".")&&("0"===e[0]&&(t+=1),t-=e.indexOf(".")),t=Math.pow(10,t);return Math.floor(parseFloat(e)*t)/t}function deepCopy(e){return clone(e)}function dateReviver(e,t){if("string"==typeof t){var r=/^(\d{4})-(\d{2})-(\d{2})T(\d{2}):(\d{2}):(\d{2}(?:\.\d*)?)Z$/.exec(t);if(r)return new Date(Date.UTC(+r[1],+r[2]-1,+r[3],+r[4],+r[5],+r[6].split(".")[0],+r[6].split(".")[1]))}return t}function getMongoUpdates(e,t,r){e.createdAt&&(t.createdAt=e.createdAt),e.updatedAt&&(t.updatedAt=e.updatedAt);e=rusDiff.diff(e,t);return e?(e.$set&&!Object.keys(e.$set).length&&delete e.$set,r&&(e.$inc={__v:1})):r&&(e={$inc:{__v:1}}),e}function getMongoMergeUpdatedDoc(e,t,r){var o=deepCopy(t),t=(o.__v=t.__v,getDeepDiff(r,t));return applyMongoUpdate(o,mergeUpdates(getDeepDiff(r,e),t)),o}function mergeUpdates(){for(var e=[],t=0;t<arguments.length;t++)e[t]=arguments[t];var r={$set:{},$unset:{},$inc:{},$push:{},$pull:{}};return e.filter(Boolean).forEach(function(e){e.forEach(function(e){var t=e.path.join(".");switch(e.kind){case"E":handleEditedChange(r,t,e);break;case"A":handleArrayChange(r,t,e)}})}),r}function handleEditedChange(e,t,r){"number"==typeof r.rhs&&(t.includes("quantity")||t.includes("qty"))?e.$inc[t]=(e.$inc[t]||0)+r.rhs-r.lhs:e.$set[t]=r.rhs}function handleArrayChange(e,t,r){"N"===r.item.kind?(e.$push[t]||(e.$push[t]={$each:[]}),e.$push[t].$each.some(function(e){return JSON.stringify(e)===JSON.stringify(r.item.rhs)})||e.$push[t].$each.push(r.item.rhs)):"D"===r.item.kind&&(e.$pull[t]||(e.$pull[t]=[]),e.$pull[t].some(function(e){return JSON.stringify(e)===JSON.stringify(r.item.lhs)})||e.$pull[t].push(r.item.lhs))}function getDeepDiff(e,t){return delete e._id,delete e.__v,e.updatedAt&&delete e.updatedAt,e.createdAt&&delete e.createdAt,delete t._id,delete t.__v,t.updatedAt&&delete t.updatedAt,t.createdAt&&delete t.createdAt,deepDiff(e,t)}function applyMongoUpdate(e,t){var r=deepCopy(e);return t&&(t.$rename&&handleRename(e,t.$rename),t.$set&&handleSet(e,t.$set),t.$inc&&handleInc(e,t.$inc),t.$unset&&handleUnset(e,t.$unset),t.$pull&&handlePull(e,r,t.$pull),t.$push)&&handlePush(e,t.$push),e}function handleRename(e,t){for(var r in t){var o=t[r],n=__read(resolve(e,r),2),i=n[0],n=n[1],a=__read(resolve(e,o),2),l=a[0],a=a[1];i&&1===n.length?l&&1===a.length?(l[a[0]]=i[n[0]],delete i[n[0]]):logError(l,a,e,o):logError(i,n,e,r)}}function handleSet(e,t){for(var r in t){var o=t[r],n=__read(resolve(e,r,{force:!0}),2),i=n[0],n=n[1];i&&1===n.length?i[n[0]]=o:logError(i,n,e,r)}}function handleInc(e,t){for(var r in t){var o=t[r],n=__read(resolve(e,r,{force:!0}),2),i=n[0],n=n[1];i&&1===n.length?("number"!=typeof i[n[0]]&&(i[n[0]]=0),i[n[0]]+=o):logError(i,n,e,r)}}function handleUnset(e,t){for(var r in t){var o=__read(resolve(e,r),2),n=o[0],o=o[1];n&&1===o.length?delete n[o[0]]:logError(n,o,e,r)}}function handlePull(i,a,e){var t,r,l;for(l in e){var o=e[l];try{t=void 0;for(var n=__values(o),s=n.next();!s.done;s=n.next())!function(t){var e=__read(resolve(i,l),2),r=e[0],e=e[1],o=__read(resolve(a,l),2),n=o[0],o=o[1];r&&1===e.length?-1!==(n=n[o[0]].findIndex(function(e){return JSON.stringify(e)===JSON.stringify(t)}))&&r[e[0]].splice(n,1):logError(r,e,i,l)}(s.value)}catch(e){t={error:e}}finally{try{s&&!s.done&&(r=n.return)&&r.call(n)}finally{if(t)throw t.error}}}}function handlePush(e,t){var r,o,n;for(n in t){var i=t[n];try{r=void 0;for(var a=__values(i),l=a.next();!l.done;l=a.next()){var s=l.value,c=__read(resolve(e,n),2),d=c[0],p=c[1];d&&1===p.length?d[p[0]].push(s):logError(d,p,e,n)}}catch(e){r={error:e}}finally{try{l&&!l.done&&(o=a.return)&&o.call(a)}finally{if(r)throw r.error}}}}function logError(e,t,r,o){console.log("Error",e+"/"+t+" - couldn't resolve for "+JSON.stringify(r)+" "+o)}function resolve(e,t,r){void 0===r&&(r={});for(var o=arrize(t),n=[],i=(0<o.length&&n.unshift(o.pop()),e);0<o.length;){var a=o.shift();if(void 0===i[a]){if(!r.force){n.unshift(a),n=o.concat(n);break}var l="number"==typeof o[0],s=0===o.length&&"number"==typeof n[0];i[a]=l||s?[]:{}}i=i[a]}return[i,n]}function arrize(e,t){return void 0===t&&(t="."),Array.isArray(e)?e.slice():null==e||!1===e||""===e?[]:e.toString().split(t).map(function(e){return[void 0,null,!1,""].includes(e)?null:e.toString()}).filter(function(e){return null!==e})}function deepDiffDetails(e,t){var r=deepCopy(e),o=deepCopy(t),n=(0,deep_object_diff_1.detailedDiff)(r,o),i="",l=function(t){return t instanceof Date?moment(t).format("llll"):"object"==typeof t&&null!==t?(Object.keys(t).filter(function(e){return e.startsWith("_id")||e.startsWith("id_")}).forEach(function(e){delete t[e]}),JSON.stringify(t)):"string"==typeof t?'"'.concat(t,'"'):String(t)},s=function(o,n){if(null===o||null===n||"object"!=typeof o||"object"!=typeof n)return"from: ".concat(l(o)," to: ").concat(l(n));if(Array.isArray(o)||Array.isArray(n)){for(var e=Array.isArray(o)?o:[],t=Array.isArray(n)?n:[],r=[],i=Math.max(e.length,t.length),a=0;a<i;a++)e[a]&&!t[a]?r.push("Removed at index ".concat(a,": ").concat(l(e[a]))):!e[a]&&t[a]?r.push("Added at index ".concat(a,": ").concat(l(t[a]))):e[a]&&t[a]&&JSON.stringify(e[a])!==JSON.stringify(t[a])&&r.push("Changed at index ".concat(a,": {").concat(s(e[a],t[a]),"}"));return r.join(", ")}return Object.keys(__assign(__assign({},o),n)).filter(function(e){return!e.startsWith("_id")&&!e.startsWith("id_")}).map(function(e){var t=o?o[e]:void 0,r=n?n[e]:void 0;return"".concat(toTitleCase(e),": ").concat(s(t,r))}).join(", ")};return["added","deleted","updated"].forEach(function(t){var e;0<Object.keys(n[t]).length&&(e=Object.keys(n[t]).filter(function(e){return"added"===t||("deleted"===t?!n.added[e]:!n.added[e]&&!n.deleted[e])}).filter(function(e){return!e.startsWith("_id")&&!e.startsWith("id_")}).map(function(e){return"\n".concat(toTitleCase(e),": ").concat(s(r[e],o[e]))}).join(","),i+=e?"".concat(e):"")}),i}function getBinarySize(e){return e?Buffer.byteLength(e,"utf8"):0}function pad(e,t){for(var r=e+"";r.length<t;)r="0"+r;return r}function randomString(e,t){for(var r="",o=e;0<o;--o)r+=t[Math.floor(Math.random()*t.length)];return r}function toTitleCase(e){return e.replace(/\w\S*/g,function(e){return e.charAt(0).toUpperCase()+e.substr(1).toLowerCase()})}function isObject(e){return e&&"object"==typeof e&&!Array.isArray(e)}function mergeDeep(e){for(var t,r=[],o=1;o<arguments.length;o++)r[o-1]=arguments[o];if(!r.length)return e;var n=r.shift();if(isObject(e)&&isObject(n))for(var i in n)isObject(n[i])?(e[i]||Object.assign(e,((t={})[i]={},t)),mergeDeep(e[i],n[i])):Object.assign(e,((t={})[i]=n[i],t));return mergeDeep.apply(void 0,__spreadArray([e],__read(r),!1))}exports.objectIdHexString=objectIdHexString,exports.buildRbSchema=buildRbSchema,exports.buildRbLookups=buildRbLookups,exports.throwErr=throwErr,exports.roundPrecision=roundPrecision,exports.round=round,exports.floorPrecision=floorPrecision,exports.deepCopy=deepCopy,exports.dateReviver=dateReviver,exports.getMongoUpdates=getMongoUpdates,exports.getMongoMergeUpdatedDoc=getMongoMergeUpdatedDoc,exports.mergeUpdates=mergeUpdates,exports.getDeepDiff=getDeepDiff,exports.applyMongoUpdate=applyMongoUpdate,exports.deepDiffDetails=deepDiffDetails,exports.getBinarySize=getBinarySize,exports.pad=pad,exports.randomString=randomString,exports.toTitleCase=toTitleCase,exports.isObject=isObject,exports.mergeDeep=mergeDeep;
|
|
2
2
|
//# sourceMappingURL=common.js.map
|
package/util/common.js.map
CHANGED
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"sources":["../../src/util/common.ts"],"names":["rusDiff","require","deepDiff","diff","deep_object_diff_1","clone","moment","mongodb_1","objectIdHexString","ObjectId","toHexString","buildRbSchema","rbSchema","Object","keys","forEach","key","type","rbType","Array","String","Date","Number","Boolean","buildRbLookups","rbLookups","defaultSchema","default_checked_array","lkp","localKey","errString","localKeyDir","localKeyDirDot","collectionAlias","toTitleCase","lookup","replace","local_key","lookupNode","match","newPropertyName","lookup_collection","lookup_collection_alias","field_path","lookup_as","lookup_key","throwErr","ii","length","assign","err","console","log","process","exit","roundPrecision","value","precision","stringValue","toString","includes","indexOf","exponent","Math","pow","round","parseFloat","power","floorPrecision","floor","deepCopy","dateReviver","a","exec","UTC","split","getMongoUpdates","currDoc","modifiedDoc","incVersion","createdAt","updatedAt","updates","$set","$inc","__v","getMongoMergeUpdatedDoc","f_doc","currentDoc","oldDoc","upDoc","diff_1","getDeepDiff","applyMongoUpdate","mergeUpdates","updatesToMerge","_i","arguments","merged","$unset","$push","$pull","filter","anUpdate","change","path","join","kind","handleEditedChange","handleArrayChange","rhs","lhs","item","some","JSON","stringify","push","doc1","doc2","_id","uDoc","delta","orig","$rename","handleRename","handleSet","handleInc","handleUnset","handlePull","handlePush","renameMap","k","v","_a","__read","resolve","o1","n1","_b","o2","n2","logError","setMap","force","o","n","incMap","unsetMap","pullMap","pathk","pullValues","e_1","pullValues_1","__values","pullValues_1_1","next","done","vk","_c","splice","findIndex","z","pushMap","pushValues","e_2","pushValues_1","pushValues_1_1","options","stack","arrize","last","e","unshift","pop","shift","concat","isNextNum","isLastNum","glue","isArray","slice","map","deepDiffDetails","object1","object2","obj1","obj2","detailedDiff","diffString","formatValue","format","startsWith","formatObjectDiff","customArrayDiff","arr1","arr2","arrayDiffResults","maxLength","max","i","__assign","obj1Val","undefined","obj2Val","diffType","getBinarySize","string","Buffer","byteLength","pad","num","size","s","randomString","chars","result","random","str","txt","charAt","toUpperCase","substr","toLowerCase","isObject","mergeDeep","target","sources","source","apply","__spreadArray","exports"],"mappings":"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","file":"common.js","sourcesContent":["/* eslint-disable no-restricted-properties */\nlet rusDiff = require('rus-diff');\nlet deepDiff = require('deep-diff').diff;\nimport { detailedDiff } from 'deep-object-diff';\nimport { LookupTables } from '../models/report-builder.model';\nlet clone = require('clone');\nimport * as moment from 'moment-timezone';\nimport { ObjectId } from 'mongodb';\n\nexport function objectIdHexString() {\n\tlet objectId = new ObjectId();\n\treturn objectId.toHexString();\n}\n\nexport function buildRbSchema(rbSchema: any) {\n\tObject.keys(rbSchema).forEach(key => {\n\t\tif (rbSchema[key].type === Object) {\n\t\t\trbSchema[key].type = 'Object';\n\t\t\trbSchema[key].rbType = 'Object';\n\t\t}\n\t\telse if (rbSchema[key].type === Array) {\n\t\t\trbSchema[key].type = 'Array';\n\t\t\trbSchema[key].rbType = 'Array';\n\t\t}\n\t\telse if (rbSchema[key].type === String) {\n\t\t\trbSchema[key].type = 'String';\n\t\t\trbSchema[key].rbType = 'String';\n\t\t}\n\t\telse if (rbSchema[key].type === Date) {\n\t\t\trbSchema[key].type = 'Date';\n\t\t\trbSchema[key].rbType = 'Date';\n\t\t}\n\t\telse if (rbSchema[key].type === Number) {\n\t\t\trbSchema[key].type = 'Number';\n\t\t\trbSchema[key].rbType = 'Number';\n\t\t}\n\t\telse if (rbSchema[key].type === Boolean) {\n\t\t\trbSchema[key].rbType = 'Boolean';\n\t\t\trbSchema[key].type = 'Boolean';\n\t\t}\n\t});\n\n\tObject.keys(rbSchema).forEach(key => {\n\t\tdelete rbSchema[key].type;\n\t});\n\n\treturn rbSchema;\n}\n\nexport function buildRbLookups(rbLookups: LookupTables[], defaultSchema: object, default_checked_array: string[] = []) {\n\t// Remember: lkp.local_key will be removed later on, because it has 'id_'\n\t\n\trbLookups.forEach(lkp => {\n\t\tlet errString = '';\n\t\tlet localKey, newPropertyName;\n\t\tlet localKeyDir = '';\n\t\tlet localKeyDirDot = '';\n\t\tlet collectionAlias = toTitleCase(lkp.lookup.replace(/\\_/g, ' ')) + ' (' + toTitleCase(lkp.local_key.replace('id_', '').replace(/\\_/g, ' ').replace(/\\.\\$\\./g, ' -> ').replace(/\\./g, ' -> ')) + ') (Lookup)';\n\n\t\tif (lkp.local_key.match(/\\./)) {\n\t\t\tlocalKey = lkp.local_key.replace(/\\.\\$/g, '');\n\t\t\tlocalKeyDirDot = lkp.local_key.replace(/^(.+\\.).*$/, '$1');\n\t\t\tlocalKeyDir = localKeyDirDot.replace(/\\.$/, '');\n\t\t}\n\t\telse {\n\t\t\t// local_key is a root leaf node.\n\t\t\tlocalKey = lkp.local_key;\n\t\t}\n\t\tnewPropertyName = localKeyDirDot + collectionAlias;\n\t\t\n\t\tif (!defaultSchema[lkp.local_key]) {\n\t\t\terrString += '--local_key: \\'' + lkp.local_key + '\\' MUST be a valid schema path! ';\n\t\t}\n\t\telse if (defaultSchema[lkp.local_key].type !== String) {\n\t\t\terrString += '--local_key: \\'' + lkp.local_key + '\\' MUST be a String! ';\n\t\t}\n\t\tlet lookupNode = {\n\t\t\tlookup_collection: lkp.lookup,\n\t\t\tlookup_collection_alias: collectionAlias,\n\t\t\tlocal_key: localKey,\n\t\t\tfield_path: localKeyDir,\n\t\t\tlookup_as: newPropertyName,\n\t\t\tlookup_key: '_id',\n\t\t\ttype: 'Object',\n\t\t};\n\n\t\tdefaultSchema[newPropertyName] = lookupNode;\n\n\t\tif (errString) {\n\t\t\tthrowErr(errString, lkp, lookupNode, newPropertyName);\n\t\t}\n\t});\n\n\tfor (let ii = 0; ii < default_checked_array.length; ii++) {\n\t\tdefaultSchema[default_checked_array[ii]] = {};\n\t\tdefaultSchema[default_checked_array[ii]]['default_checked'] = true;\n\t\tObject.assign(defaultSchema[default_checked_array[ii]], defaultSchema['tree'][default_checked_array[ii]]);\n\t}\n\n\treturn defaultSchema;\n}\n\nexport function throwErr(err: any, lkp, lookupNode, newPropertyName = '') {\n\t// err could be from a try/throw/catch\n\tconsole.log('------- ERROR thrown by rbLookups: ');\n\tconsole.log(err);\n\tconsole.log('---item: ');\n\tconsole.log(lkp);\n\tconsole.log('---Attempted to create rbSchema[\\'' + newPropertyName + '\\']: ');\n\tconsole.log(lookupNode);\n\tprocess.exit(1);\n}\n\nexport function roundPrecision(value: number, precision = 0) {\n\tlet stringValue = value.toString();\n\t\n\tif (stringValue.includes('.')) {\n\t\tif (stringValue[0] === '0') {\n\t\t\tprecision += 1;\n\t\t}\n\t\t\n\t\tprecision -= stringValue.indexOf('.');\n\t}\n\n\tconst exponent = Math.pow(10, precision);\n\treturn Math.round(parseFloat(stringValue) * exponent) / exponent;\n}\n\nexport function round(value, precision = 0) {\n\tconst power = Math.pow(10, precision);\n\tconst adjustment = 1e-6;\n\treturn Math.round( (value * power) + adjustment) / power;\n}\n\nexport function floorPrecision(value: number, precision = 0) {\n\tlet stringValue = value.toString();\n\t\n\tif (stringValue.includes('.')) {\n\t\tif (stringValue[0] === '0') {\n\t\t\tprecision += 1;\n\t\t}\n\t\t\n\t\tprecision -= stringValue.indexOf('.');\n\t}\n\n\tconst exponent = Math.pow(10, precision);\n\treturn Math.floor(parseFloat(stringValue) * exponent) / exponent;\n}\n\nexport function deepCopy(value) {\n\treturn clone(value);\n}\n\nexport function dateReviver(key, value) {\n\tif (typeof value === 'string') {\n\t\tlet a = /^(\\d{4})-(\\d{2})-(\\d{2})T(\\d{2}):(\\d{2}):(\\d{2}(?:\\.\\d*)?)Z$/.exec(value);\n\t\tif (a) {\n\t\t\treturn new Date(Date.UTC(+a[1], +a[2] - 1, +a[3], +a[4], +a[5], +a[6].split('.')[0], +a[6].split('.')[1]));\n\t\t}\n\t}\n\treturn value;\n}\n\nexport function getMongoUpdates(currDoc, modifiedDoc, incVersion) {\n\tif (currDoc.createdAt) {\n\t\tmodifiedDoc.createdAt = currDoc.createdAt;\n\t}\n\n\tif (currDoc.updatedAt) {\n\t\tmodifiedDoc.updatedAt = currDoc.updatedAt;\n\t}\n\n\tlet updates = rusDiff.diff(currDoc, modifiedDoc);\n\n\tif (updates) {\n\t\tif (updates.$set && !Object.keys(updates.$set).length) {\n\t\t\tdelete updates.$set;\n\t\t}\n\n\t\tif (incVersion) {\n\t\t\tupdates.$inc = {__v: 1};\n\t\t}\n\t}\n\telse {\n\t\tif (incVersion) {\n\t\t\tupdates = {\n\t\t\t\t$inc: {__v: 1}\n\t\t\t};\n\t\t}\n\t}\n\n\treturn updates;\n}\n\nexport function getMongoMergeUpdatedDoc(f_doc, currentDoc, oldDoc) {\n\tlet upDoc = deepCopy(oldDoc);\n\tupDoc.__v = currentDoc.__v;\n\tlet diff_1 = getDeepDiff(oldDoc, currentDoc);\n\tlet diff_2 = getDeepDiff(oldDoc, f_doc);\n\tlet updates = mergeUpdates(diff_2, diff_1);\n\tapplyMongoUpdate(upDoc, updates);\n\treturn upDoc;\n}\n\nexport function mergeUpdates(...updatesToMerge) {\n const merged = {\n $set: {},\n $unset: {},\n $inc: {},\n $push: {},\n $pull: {}\n };\n\n updatesToMerge.filter(Boolean).forEach(anUpdate => {\n anUpdate.forEach(change => {\n const path = change.path.join('.');\n\n switch (change.kind) {\n case 'E':\n handleEditedChange(merged, path, change);\n break;\n case 'A':\n handleArrayChange(merged, path, change);\n break;\n default:\n break;\n }\n });\n });\n\n return merged;\n}\n\nfunction handleEditedChange(merged, path, change) {\n if (typeof(change.rhs) === 'number' && (path.includes('quantity') || path.includes('qty'))) {\n merged.$inc[path] = (merged.$inc[path] || 0) + change.rhs - change.lhs;\n } else {\n merged.$set[path] = change.rhs;\n }\n}\n\nfunction handleArrayChange(merged, path, change) {\n if (change.item.kind === 'N') {\n merged.$push[path] = merged.$push[path] || [];\n if (!merged.$push[path].some(a => JSON.stringify(a) === JSON.stringify(change.item.rhs))) {\n merged.$push[path].push(change.item.rhs);\n }\n } else if (change.item.kind === 'D') {\n merged.$pull[path] = merged.$pull[path] || [];\n if (!merged.$pull[path].some(a => JSON.stringify(a) === JSON.stringify(change.item.lhs))) {\n merged.$pull[path].push(change.item.lhs);\n }\n }\n}\n\nexport function getDeepDiff(doc1, doc2) {\n\tdelete doc1._id;\n\tdelete doc1.__v;\n\n\tif (doc1.updatedAt) {\n\t\tdelete doc1.updatedAt;\n\t}\n\n\tif (doc1.createdAt) {\n\t\tdelete doc1.createdAt;\n\t}\n\n\tdelete doc2._id;\n\tdelete doc2.__v;\n\n\tif (doc2.updatedAt) {\n\t\tdelete doc2.updatedAt;\n\t}\n\n\tif (doc2.createdAt) {\n\t\tdelete doc2.createdAt;\n\t}\n\n\treturn deepDiff(doc1, doc2);\n}\n\nexport function applyMongoUpdate(uDoc: any, delta: any): any {\n const orig = deepCopy(uDoc);\n\n if (delta) {\n if (delta.$rename) handleRename(uDoc, delta.$rename);\n if (delta.$set) handleSet(uDoc, delta.$set);\n if (delta.$inc) handleInc(uDoc, delta.$inc);\n if (delta.$unset) handleUnset(uDoc, delta.$unset);\n if (delta.$pull) handlePull(uDoc, orig, delta.$pull);\n if (delta.$push) handlePush(uDoc, delta.$push);\n }\n\n return uDoc;\n}\n\nfunction handleRename(uDoc: any, renameMap: any) {\n for (const k in renameMap) {\n const v = renameMap[k];\n const [o1, n1] = resolve(uDoc, k);\n const [o2, n2] = resolve(uDoc, v);\n if (o1 && n1.length === 1) {\n if (o2 && n2.length === 1) {\n o2[n2[0]] = o1[n1[0]];\n delete o1[n1[0]];\n } else {\n logError(o2, n2, uDoc, v);\n }\n } else {\n logError(o1, n1, uDoc, k);\n }\n }\n}\n\nfunction handleSet(uDoc: any, setMap: any) {\n for (const k in setMap) {\n const v = setMap[k];\n const [o, n] = resolve(uDoc, k, { force: true });\n if (o && n.length === 1) {\n o[n[0]] = v;\n } else {\n logError(o, n, uDoc, k);\n }\n }\n}\n\nfunction handleInc(uDoc: any, incMap: any) {\n for (const k in incMap) {\n const v = incMap[k];\n const [o, n] = resolve(uDoc, k, { force: true });\n if (o && n.length === 1) {\n o[n[0]] = (o[n[0]] || 0) + v;\n } else {\n logError(o, n, uDoc, k);\n }\n }\n}\n\nfunction handleUnset(uDoc: any, unsetMap: any) {\n for (const k in unsetMap) {\n const [o, n] = resolve(uDoc, k);\n if (o && n.length === 1) {\n delete o[n[0]];\n } else {\n logError(o, n, uDoc, k);\n }\n }\n}\n\nfunction handlePull(uDoc: any, orig: any, pullMap: any) {\n for (const pathk in pullMap) {\n const pullValues = pullMap[pathk];\n for (let vk of pullValues) {\n const [o, n] = resolve(uDoc, pathk);\n const [o2, n2] = resolve(orig, pathk);\n if (o && n.length === 1) {\n o[n[0]].splice((<Array<any>>o2[n2[0]]).findIndex(z => JSON.stringify(z) === JSON.stringify(vk)), 1);\n } else {\n logError(o, n, uDoc, pathk);\n }\n }\n }\n}\n\nfunction handlePush(uDoc: any, pushMap: any) {\n for (const pathk in pushMap) {\n const pushValues = pushMap[pathk];\n for (let vk of pushValues) {\n const [o, n] = resolve(uDoc, pathk);\n if (o && n.length === 1) {\n o[n[0]].push(vk);\n } else {\n logError(o, n, uDoc, pathk);\n }\n }\n }\n}\n\nfunction logError(o: any, n: any, uDoc: any, key: any) {\n console.log('Error', o + '/' + n + ' - couldn\\'t resolve for ' + JSON.stringify(uDoc) + ' ' + key);\n}\n\nfunction resolve(a: any, path: string, options: any = {}): [any, any] {\n const stack = arrize(path);\n let last = [];\n\n if (stack.length > 0) {\n last.unshift(stack.pop());\n }\n\n let e = a;\n while (stack.length > 0) {\n const k = stack.shift();\n if (e[k] !== void 0) {\n e = e[k];\n } else {\n if (!options.force) {\n last.unshift(k);\n last = stack.concat(last);\n break;\n }\n const isNextNum = typeof stack[0] === 'number';\n const isLastNum = stack.length === 0 && typeof last[0] === 'number';\n e[k] = isNextNum || isLastNum ? [] : {};\n e = e[k];\n }\n }\n\n return [e, last];\n}\n\nfunction arrize(path: any, glue: string = '.'): string[] {\n if (Array.isArray(path)) {\n return path.slice();\n }\n\n if (path === void 0 || path === null || path === false || path === '') {\n return [];\n }\n\n return path.toString().split(glue)\n .map(e => {\n if ([void 0, null, false, ''].includes(e)) {\n return null;\n }\n return e.toString();\n })\n .filter(e => e !== null);\n}\n\nexport function deepDiffDetails(object1: Object, object2: Object): string {\n let obj1 = deepCopy(object1);\n\tlet obj2 = deepCopy(object2);\n\n\tlet diff = detailedDiff(obj1, obj2);\n\tlet diffString = '';\n\n\tconst formatValue = (value: any): string => {\n\t\tif (value instanceof Date) {\n\t\t\treturn moment(value).format('llll');\n\t\t} \n\t\telse if (typeof value === 'object' && value !== null) {\n\t\t\tObject.keys(value).filter(a => a.startsWith('_id') || a.startsWith('id_')).forEach(key => {\n\t\t\t\tdelete value[key];\n\t\t\t});\n\t\t\treturn JSON.stringify(value); // Pretty print objects\n\t\t} \n\t\telse {\n\t\t\treturn typeof value === 'string' ? `\"${value}\"` : String(value);\n\t\t}\n\t};\n\n\tconst customArrayDiff = (arr1: any[], arr2: any[]): string => {\n let arrayDiffResults = [];\n const maxLength = Math.max(arr1.length, arr2.length);\n\n for (let i = 0; i < maxLength; i++) {\n if (arr1[i] && !arr2[i]) {\n arrayDiffResults.push(`Removed at index ${i}: ${formatValue(arr1[i])}`);\n } \n\t\t\telse if (!arr1[i] && arr2[i]) {\n arrayDiffResults.push(`Added at index ${i}: ${formatValue(arr2[i])}`);\n } \n\t\t\telse if (arr1[i] && arr2[i] && JSON.stringify(arr1[i]) !== JSON.stringify(arr2[i])) {\n arrayDiffResults.push(`Changed at index ${i}: {${formatObjectDiff(arr1[i], arr2[i])}}`);\n }\n }\n\n return arrayDiffResults.join(', ');\n };\n\n\tconst formatObjectDiff = (obj1: any, obj2: any): string => {\n\t\tif (obj1 === null || obj2 === null || typeof obj1 !== 'object' || typeof obj2 !== 'object') {\n\t\t\treturn `from: ${formatValue(obj1)} to: ${formatValue(obj2)}`;\n\t\t}\n\n\t\tif (Array.isArray(obj1) || Array.isArray(obj2)) {\n\t\t\treturn customArrayDiff(Array.isArray(obj1) ? obj1 : [], Array.isArray(obj2) ? obj2 : []);\n\t\t}\n\n\t\treturn Object.keys({...obj1, ...obj2}).filter(a => !a.startsWith('_id') && !a.startsWith('id_')).map(key => {\n\t\t\tconst obj1Val = obj1 ? obj1[key] : undefined;\n\t\t\tconst obj2Val = obj2 ? obj2[key] : undefined;\n\t\t\treturn `${toTitleCase(key)}: ${formatObjectDiff(obj1Val, obj2Val)}`;\n\t\t}).join(', ');\n\t};\n\n\t// Handle each diff type\n\t['added', 'deleted', 'updated'].forEach(diffType => {\n\t\tif (Object.keys(diff[diffType]).length > 0) {\n\t\t\tconst updates = Object.keys(diff[diffType])\n\t\t\t\t.filter(key => diffType === 'added' ? true : (diffType === 'deleted' ? !diff['added'][key] : !diff['added'][key] && !diff['deleted'][key]))\n\t\t\t\t.filter(key => !key.startsWith('_id') && !key.startsWith('id_'))\n\t\t\t\t.map(key => `\\n${toTitleCase(key)}: ${formatObjectDiff(obj1[key], obj2[key])}`)\n\t\t\t\t.join(',');\n\n\t\t\tdiffString += updates ? `${updates}` : '';\n\t\t}\n\t});\n\n\treturn diffString;\n}\n\nexport function getBinarySize(string) {\n\tif (string) {\n\t\treturn Buffer.byteLength(string, 'utf8');\n\t}\n\telse {\n\t\treturn 0;\n\t}\n}\n\nexport function pad(num, size) {\n\tlet s = num + '';\n\twhile (s.length < size) { s = '0' + s; }\n\treturn s;\n}\n\nexport function randomString(length, chars) {\n\tlet result = '';\n\tfor (let i = length; i > 0; --i) { result += chars[Math.floor(Math.random() * chars.length)]; }\n\treturn result;\n}\n\nexport function toTitleCase(str) {\n\treturn str.replace(/\\w\\S*/g, function(txt){\n\t\treturn txt.charAt(0).toUpperCase() + txt.substr(1).toLowerCase();\n\t});\n}\n\nexport function isObject(item) {\n\treturn (item && typeof item === 'object' && !Array.isArray(item));\n}\n\nexport function mergeDeep(target, ...sources) {\n\tif (!sources.length) {\n\t\treturn target;\n\t}\n\tconst source = sources.shift();\n\n\tif (isObject(target) && isObject(source)) {\n\t\tfor (const key in source) {\n\t\t\tif (isObject(source[key])) {\n\t\t\t\tif (!target[key]) {\n\t\t\t\t\tObject.assign(target, { [key]: {} });\n\t\t\t\t}\n\t\t\t\tmergeDeep(target[key], source[key]);\n\t\t\t} \n\t\t\telse {\n\t\t\t\tObject.assign(target, { [key]: source[key] });\n\t\t\t}\n\t\t}\n\t}\n\n\treturn mergeDeep(target, ...sources);\n}"]}
|
|
1
|
+
{"version":3,"sources":["../../src/util/common.ts"],"names":["rusDiff","require","deepDiff","diff","deep_object_diff_1","moment","mongodb_1","clone","objectIdHexString","ObjectId","toHexString","buildRbSchema","rbSchema","Object","keys","forEach","key","type","rbType","Array","String","Date","Number","Boolean","buildRbLookups","rbLookups","defaultSchema","default_checked_array","lkp","localKey","errString","localKeyDir","localKeyDirDot","collectionAlias","toTitleCase","lookup","replace","local_key","lookupNode","match","newPropertyName","lookup_collection","lookup_collection_alias","field_path","lookup_as","lookup_key","throwErr","ii","length","assign","err","console","log","process","exit","roundPrecision","value","precision","stringValue","toString","includes","indexOf","exponent","Math","pow","round","parseFloat","power","floorPrecision","floor","deepCopy","dateReviver","a","exec","UTC","split","getMongoUpdates","currDoc","modifiedDoc","incVersion","createdAt","updatedAt","updates","$set","$inc","__v","getMongoMergeUpdatedDoc","f_doc","currentDoc","oldDoc","upDoc","diff_1","getDeepDiff","applyMongoUpdate","mergeUpdates","updatesToMerge","_i","arguments","merged","$unset","$push","$pull","filter","anUpdate","change","path","join","kind","handleEditedChange","handleArrayChange","rhs","lhs","item","$each","some","JSON","stringify","push","doc1","doc2","_id","uDoc","delta","orig","$rename","handleRename","handleSet","handleInc","handleUnset","handlePull","handlePush","renameMap","k","v","_a","__read","resolve","o1","n1","_b","o2","n2","logError","setMap","force","o","n","incMap","unsetMap","pullMap","pathk","pullValues","e_1","pullValues_1","__values","pullValues_1_1","next","done","vk","_c","index","findIndex","z","splice","pushMap","pushValues","e_2","pushValues_1","pushValues_1_1","options","stack","arrize","last","e","unshift","pop","shift","concat","isNextNum","isLastNum","glue","isArray","slice","map","deepDiffDetails","object1","object2","obj1","obj2","detailedDiff","diffString","formatValue","format","startsWith","formatObjectDiff","customArrayDiff","arr1","arr2","arrayDiffResults","maxLength","max","i","__assign","obj1Val","undefined","obj2Val","diffType","getBinarySize","string","Buffer","byteLength","pad","num","size","s","randomString","chars","result","random","str","txt","charAt","toUpperCase","substr","toLowerCase","isObject","mergeDeep","target","sources","source","apply","__spreadArray","exports"],"mappings":"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","file":"common.js","sourcesContent":["/* eslint-disable no-restricted-properties */\nlet rusDiff = require('rus-diff');\nlet deepDiff = require('deep-diff').diff;\nimport { detailedDiff } from 'deep-object-diff';\nimport * as moment from 'moment-timezone';\nimport { ObjectId } from 'mongodb';\nimport { LookupTables } from '../models/report-builder.model';\nlet clone = require('clone');\n\nexport function objectIdHexString() {\n\tlet objectId = new ObjectId();\n\treturn objectId.toHexString();\n}\n\nexport function buildRbSchema(rbSchema: any) {\n\tObject.keys(rbSchema).forEach(key => {\n\t\tif (rbSchema[key].type === Object) {\n\t\t\trbSchema[key].type = 'Object';\n\t\t\trbSchema[key].rbType = 'Object';\n\t\t}\n\t\telse if (rbSchema[key].type === Array) {\n\t\t\trbSchema[key].type = 'Array';\n\t\t\trbSchema[key].rbType = 'Array';\n\t\t}\n\t\telse if (rbSchema[key].type === String) {\n\t\t\trbSchema[key].type = 'String';\n\t\t\trbSchema[key].rbType = 'String';\n\t\t}\n\t\telse if (rbSchema[key].type === Date) {\n\t\t\trbSchema[key].type = 'Date';\n\t\t\trbSchema[key].rbType = 'Date';\n\t\t}\n\t\telse if (rbSchema[key].type === Number) {\n\t\t\trbSchema[key].type = 'Number';\n\t\t\trbSchema[key].rbType = 'Number';\n\t\t}\n\t\telse if (rbSchema[key].type === Boolean) {\n\t\t\trbSchema[key].rbType = 'Boolean';\n\t\t\trbSchema[key].type = 'Boolean';\n\t\t}\n\t});\n\n\tObject.keys(rbSchema).forEach(key => {\n\t\tdelete rbSchema[key].type;\n\t});\n\n\treturn rbSchema;\n}\n\nexport function buildRbLookups(rbLookups: LookupTables[], defaultSchema: object, default_checked_array: string[] = []) {\n\t// Remember: lkp.local_key will be removed later on, because it has 'id_'\n\t\n\trbLookups.forEach(lkp => {\n\t\tlet errString = '';\n\t\tlet localKey, newPropertyName;\n\t\tlet localKeyDir = '';\n\t\tlet localKeyDirDot = '';\n\t\tlet collectionAlias = toTitleCase(lkp.lookup.replace(/\\_/g, ' ')) + ' (' + toTitleCase(lkp.local_key.replace('id_', '').replace(/\\_/g, ' ').replace(/\\.\\$\\./g, ' -> ').replace(/\\./g, ' -> ')) + ') (Lookup)';\n\n\t\tif (lkp.local_key.match(/\\./)) {\n\t\t\tlocalKey = lkp.local_key.replace(/\\.\\$/g, '');\n\t\t\tlocalKeyDirDot = lkp.local_key.replace(/^(.+\\.).*$/, '$1');\n\t\t\tlocalKeyDir = localKeyDirDot.replace(/\\.$/, '');\n\t\t}\n\t\telse {\n\t\t\t// local_key is a root leaf node.\n\t\t\tlocalKey = lkp.local_key;\n\t\t}\n\t\tnewPropertyName = localKeyDirDot + collectionAlias;\n\t\t\n\t\tif (!defaultSchema[lkp.local_key]) {\n\t\t\terrString += '--local_key: \\'' + lkp.local_key + '\\' MUST be a valid schema path! ';\n\t\t}\n\t\telse if (defaultSchema[lkp.local_key].type !== String) {\n\t\t\terrString += '--local_key: \\'' + lkp.local_key + '\\' MUST be a String! ';\n\t\t}\n\t\tlet lookupNode = {\n\t\t\tlookup_collection: lkp.lookup,\n\t\t\tlookup_collection_alias: collectionAlias,\n\t\t\tlocal_key: localKey,\n\t\t\tfield_path: localKeyDir,\n\t\t\tlookup_as: newPropertyName,\n\t\t\tlookup_key: '_id',\n\t\t\ttype: 'Object',\n\t\t};\n\n\t\tdefaultSchema[newPropertyName] = lookupNode;\n\n\t\tif (errString) {\n\t\t\tthrowErr(errString, lkp, lookupNode, newPropertyName);\n\t\t}\n\t});\n\n\tfor (let ii = 0; ii < default_checked_array.length; ii++) {\n\t\tdefaultSchema[default_checked_array[ii]] = {};\n\t\tdefaultSchema[default_checked_array[ii]]['default_checked'] = true;\n\t\tObject.assign(defaultSchema[default_checked_array[ii]], defaultSchema['tree'][default_checked_array[ii]]);\n\t}\n\n\treturn defaultSchema;\n}\n\nexport function throwErr(err: any, lkp, lookupNode, newPropertyName = '') {\n\t// err could be from a try/throw/catch\n\tconsole.log('------- ERROR thrown by rbLookups: ');\n\tconsole.log(err);\n\tconsole.log('---item: ');\n\tconsole.log(lkp);\n\tconsole.log('---Attempted to create rbSchema[\\'' + newPropertyName + '\\']: ');\n\tconsole.log(lookupNode);\n\tprocess.exit(1);\n}\n\nexport function roundPrecision(value: number, precision = 0) {\n\tlet stringValue = value.toString();\n\t\n\tif (stringValue.includes('.')) {\n\t\tif (stringValue[0] === '0') {\n\t\t\tprecision += 1;\n\t\t}\n\t\t\n\t\tprecision -= stringValue.indexOf('.');\n\t}\n\n\tconst exponent = Math.pow(10, precision);\n\treturn Math.round(parseFloat(stringValue) * exponent) / exponent;\n}\n\nexport function round(value, precision = 0) {\n\tconst power = Math.pow(10, precision);\n\tconst adjustment = 1e-6;\n\treturn Math.round( (value * power) + adjustment) / power;\n}\n\nexport function floorPrecision(value: number, precision = 0) {\n\tlet stringValue = value.toString();\n\t\n\tif (stringValue.includes('.')) {\n\t\tif (stringValue[0] === '0') {\n\t\t\tprecision += 1;\n\t\t}\n\t\t\n\t\tprecision -= stringValue.indexOf('.');\n\t}\n\n\tconst exponent = Math.pow(10, precision);\n\treturn Math.floor(parseFloat(stringValue) * exponent) / exponent;\n}\n\nexport function deepCopy(value) {\n\treturn clone(value);\n}\n\nexport function dateReviver(key, value) {\n\tif (typeof value === 'string') {\n\t\tlet a = /^(\\d{4})-(\\d{2})-(\\d{2})T(\\d{2}):(\\d{2}):(\\d{2}(?:\\.\\d*)?)Z$/.exec(value);\n\t\tif (a) {\n\t\t\treturn new Date(Date.UTC(+a[1], +a[2] - 1, +a[3], +a[4], +a[5], +a[6].split('.')[0], +a[6].split('.')[1]));\n\t\t}\n\t}\n\treturn value;\n}\n\nexport function getMongoUpdates(currDoc, modifiedDoc, incVersion) {\n\tif (currDoc.createdAt) {\n\t\tmodifiedDoc.createdAt = currDoc.createdAt;\n\t}\n\n\tif (currDoc.updatedAt) {\n\t\tmodifiedDoc.updatedAt = currDoc.updatedAt;\n\t}\n\n\tlet updates = rusDiff.diff(currDoc, modifiedDoc);\n\n\tif (updates) {\n\t\tif (updates.$set && !Object.keys(updates.$set).length) {\n\t\t\tdelete updates.$set;\n\t\t}\n\n\t\tif (incVersion) {\n\t\t\tupdates.$inc = {__v: 1};\n\t\t}\n\t}\n\telse {\n\t\tif (incVersion) {\n\t\t\tupdates = {\n\t\t\t\t$inc: {__v: 1}\n\t\t\t};\n\t\t}\n\t}\n\n\treturn updates;\n}\n\nexport function getMongoMergeUpdatedDoc(f_doc, currentDoc, oldDoc) {\n\tlet upDoc = deepCopy(currentDoc); // was oldDoc\n\tupDoc.__v = currentDoc.__v;\n\n\tlet diff_1 = getDeepDiff(oldDoc, currentDoc);\n\tlet diff_2 = getDeepDiff(oldDoc, f_doc);\n\n\tlet updates = mergeUpdates(diff_2, diff_1);\n\tapplyMongoUpdate(upDoc, updates);\n\treturn upDoc;\n}\n\n\nexport function mergeUpdates(...updatesToMerge) {\n const merged = {\n $set: {},\n $unset: {},\n $inc: {},\n $push: {},\n $pull: {}\n };\n\n updatesToMerge.filter(Boolean).forEach(anUpdate => {\n anUpdate.forEach(change => {\n const path = change.path.join('.');\n\n switch (change.kind) {\n case 'E':\n handleEditedChange(merged, path, change);\n break;\n case 'A':\n handleArrayChange(merged, path, change);\n break;\n default:\n break;\n }\n });\n });\n\n return merged;\n}\n\nfunction handleEditedChange(merged, path, change) {\n\t// Later diffs override earlier ones\n\tif (typeof(change.rhs) === 'number' && (path.includes('quantity') || path.includes('qty'))) {\n\t\tmerged.$inc[path] = (merged.$inc[path] || 0) + change.rhs - change.lhs;\n\t}\n\telse {\n\t\tmerged.$set[path] = change.rhs;\n\t}\n}\n\n\nfunction handleArrayChange(merged, path, change) {\n\tif (change.item.kind === 'N') {\n\t\tif (!merged.$push[path]) merged.$push[path] = { $each: [] };\n\n\t\tif (!merged.$push[path].$each.some(a => JSON.stringify(a) === JSON.stringify(change.item.rhs))) {\n\t\t\tmerged.$push[path].$each.push(change.item.rhs);\n\t\t}\n\t}\n\telse if (change.item.kind === 'D') {\n\t\tif (!merged.$pull[path]) merged.$pull[path] = [];\n\n\t\tif (!merged.$pull[path].some(a => JSON.stringify(a) === JSON.stringify(change.item.lhs))) {\n\t\t\tmerged.$pull[path].push(change.item.lhs);\n\t\t}\n\t}\n}\n\nexport function getDeepDiff(doc1, doc2) {\n\tdelete doc1._id;\n\tdelete doc1.__v;\n\n\tif (doc1.updatedAt) {\n\t\tdelete doc1.updatedAt;\n\t}\n\n\tif (doc1.createdAt) {\n\t\tdelete doc1.createdAt;\n\t}\n\n\tdelete doc2._id;\n\tdelete doc2.__v;\n\n\tif (doc2.updatedAt) {\n\t\tdelete doc2.updatedAt;\n\t}\n\n\tif (doc2.createdAt) {\n\t\tdelete doc2.createdAt;\n\t}\n\n\treturn deepDiff(doc1, doc2);\n}\n\nexport function applyMongoUpdate(uDoc: any, delta: any): any {\n const orig = deepCopy(uDoc);\n\n if (delta) {\n if (delta.$rename) handleRename(uDoc, delta.$rename);\n if (delta.$set) handleSet(uDoc, delta.$set);\n if (delta.$inc) handleInc(uDoc, delta.$inc);\n if (delta.$unset) handleUnset(uDoc, delta.$unset);\n if (delta.$pull) handlePull(uDoc, orig, delta.$pull);\n if (delta.$push) handlePush(uDoc, delta.$push);\n }\n\n return uDoc;\n}\n\nfunction handleRename(uDoc: any, renameMap: any) {\n for (const k in renameMap) {\n const v = renameMap[k];\n const [o1, n1] = resolve(uDoc, k);\n const [o2, n2] = resolve(uDoc, v);\n if (o1 && n1.length === 1) {\n if (o2 && n2.length === 1) {\n o2[n2[0]] = o1[n1[0]];\n delete o1[n1[0]];\n } else {\n logError(o2, n2, uDoc, v);\n }\n } else {\n logError(o1, n1, uDoc, k);\n }\n }\n}\n\nfunction handleSet(uDoc: any, setMap: any) {\n for (const k in setMap) {\n const v = setMap[k];\n const [o, n] = resolve(uDoc, k, { force: true });\n if (o && n.length === 1) {\n o[n[0]] = v;\n } else {\n logError(o, n, uDoc, k);\n }\n }\n}\n\nfunction handleInc(uDoc: any, incMap: any) {\n for (const k in incMap) {\n const v = incMap[k];\n const [o, n] = resolve(uDoc, k, { force: true });\n if (o && n.length === 1) {\n\t\t\tif (typeof o[n[0]] !== 'number') {\n\t\t\t\to[n[0]] = 0;\n\t\t\t}\n\t\t\to[n[0]] += v;\n } else {\n logError(o, n, uDoc, k);\n }\n }\n}\n\nfunction handleUnset(uDoc: any, unsetMap: any) {\n for (const k in unsetMap) {\n const [o, n] = resolve(uDoc, k);\n if (o && n.length === 1) {\n delete o[n[0]];\n } else {\n logError(o, n, uDoc, k);\n }\n }\n}\n\nfunction handlePull(uDoc: any, orig: any, pullMap: any) {\n for (const pathk in pullMap) {\n const pullValues = pullMap[pathk];\n for (let vk of pullValues) {\n const [o, n] = resolve(uDoc, pathk);\n const [o2, n2] = resolve(orig, pathk);\n if (o && n.length === 1) {\n\t\t\t\tconst index = (<Array<any>>o2[n2[0]]).findIndex(z => JSON.stringify(z) === JSON.stringify(vk));\n\t\t\t\tif (index !== -1) {\n\t\t\t\t\to[n[0]].splice(index, 1);\n\t\t\t\t}\n } else {\n logError(o, n, uDoc, pathk);\n }\n }\n }\n}\n\nfunction handlePush(uDoc: any, pushMap: any) {\n for (const pathk in pushMap) {\n const pushValues = pushMap[pathk];\n for (let vk of pushValues) {\n const [o, n] = resolve(uDoc, pathk);\n if (o && n.length === 1) {\n o[n[0]].push(vk);\n } else {\n logError(o, n, uDoc, pathk);\n }\n }\n }\n}\n\nfunction logError(o: any, n: any, uDoc: any, key: any) {\n console.log('Error', o + '/' + n + ' - couldn\\'t resolve for ' + JSON.stringify(uDoc) + ' ' + key);\n}\n\nfunction resolve(a: any, path: string, options: any = {}): [any, any] {\n const stack = arrize(path);\n let last = [];\n\n if (stack.length > 0) {\n last.unshift(stack.pop());\n }\n\n let e = a;\n while (stack.length > 0) {\n const k = stack.shift();\n if (e[k] !== void 0) {\n e = e[k];\n } else {\n if (!options.force) {\n last.unshift(k);\n last = stack.concat(last);\n break;\n }\n const isNextNum = typeof stack[0] === 'number';\n const isLastNum = stack.length === 0 && typeof last[0] === 'number';\n e[k] = isNextNum || isLastNum ? [] : {};\n e = e[k];\n }\n }\n\n return [e, last];\n}\n\nfunction arrize(path: any, glue: string = '.'): string[] {\n if (Array.isArray(path)) {\n return path.slice();\n }\n\n if (path === void 0 || path === null || path === false || path === '') {\n return [];\n }\n\n return path.toString().split(glue)\n .map(e => {\n if ([void 0, null, false, ''].includes(e)) {\n return null;\n }\n return e.toString();\n })\n .filter(e => e !== null);\n}\n\nexport function deepDiffDetails(object1: Object, object2: Object): string {\n let obj1 = deepCopy(object1);\n\tlet obj2 = deepCopy(object2);\n\n\tlet diff = detailedDiff(obj1, obj2);\n\tlet diffString = '';\n\n\tconst formatValue = (value: any): string => {\n\t\tif (value instanceof Date) {\n\t\t\treturn moment(value).format('llll');\n\t\t} \n\t\telse if (typeof value === 'object' && value !== null) {\n\t\t\tObject.keys(value).filter(a => a.startsWith('_id') || a.startsWith('id_')).forEach(key => {\n\t\t\t\tdelete value[key];\n\t\t\t});\n\t\t\treturn JSON.stringify(value); // Pretty print objects\n\t\t} \n\t\telse {\n\t\t\treturn typeof value === 'string' ? `\"${value}\"` : String(value);\n\t\t}\n\t};\n\n\tconst customArrayDiff = (arr1: any[], arr2: any[]): string => {\n let arrayDiffResults = [];\n const maxLength = Math.max(arr1.length, arr2.length);\n\n for (let i = 0; i < maxLength; i++) {\n if (arr1[i] && !arr2[i]) {\n arrayDiffResults.push(`Removed at index ${i}: ${formatValue(arr1[i])}`);\n } \n\t\t\telse if (!arr1[i] && arr2[i]) {\n arrayDiffResults.push(`Added at index ${i}: ${formatValue(arr2[i])}`);\n } \n\t\t\telse if (arr1[i] && arr2[i] && JSON.stringify(arr1[i]) !== JSON.stringify(arr2[i])) {\n arrayDiffResults.push(`Changed at index ${i}: {${formatObjectDiff(arr1[i], arr2[i])}}`);\n }\n }\n\n return arrayDiffResults.join(', ');\n };\n\n\tconst formatObjectDiff = (obj1: any, obj2: any): string => {\n\t\tif (obj1 === null || obj2 === null || typeof obj1 !== 'object' || typeof obj2 !== 'object') {\n\t\t\treturn `from: ${formatValue(obj1)} to: ${formatValue(obj2)}`;\n\t\t}\n\n\t\tif (Array.isArray(obj1) || Array.isArray(obj2)) {\n\t\t\treturn customArrayDiff(Array.isArray(obj1) ? obj1 : [], Array.isArray(obj2) ? obj2 : []);\n\t\t}\n\n\t\treturn Object.keys({...obj1, ...obj2}).filter(a => !a.startsWith('_id') && !a.startsWith('id_')).map(key => {\n\t\t\tconst obj1Val = obj1 ? obj1[key] : undefined;\n\t\t\tconst obj2Val = obj2 ? obj2[key] : undefined;\n\t\t\treturn `${toTitleCase(key)}: ${formatObjectDiff(obj1Val, obj2Val)}`;\n\t\t}).join(', ');\n\t};\n\n\t// Handle each diff type\n\t['added', 'deleted', 'updated'].forEach(diffType => {\n\t\tif (Object.keys(diff[diffType]).length > 0) {\n\t\t\tconst updates = Object.keys(diff[diffType])\n\t\t\t\t.filter(key => diffType === 'added' ? true : (diffType === 'deleted' ? !diff['added'][key] : !diff['added'][key] && !diff['deleted'][key]))\n\t\t\t\t.filter(key => !key.startsWith('_id') && !key.startsWith('id_'))\n\t\t\t\t.map(key => `\\n${toTitleCase(key)}: ${formatObjectDiff(obj1[key], obj2[key])}`)\n\t\t\t\t.join(',');\n\n\t\t\tdiffString += updates ? `${updates}` : '';\n\t\t}\n\t});\n\n\treturn diffString;\n}\n\nexport function getBinarySize(string) {\n\tif (string) {\n\t\treturn Buffer.byteLength(string, 'utf8');\n\t}\n\telse {\n\t\treturn 0;\n\t}\n}\n\nexport function pad(num, size) {\n\tlet s = num + '';\n\twhile (s.length < size) { s = '0' + s; }\n\treturn s;\n}\n\nexport function randomString(length, chars) {\n\tlet result = '';\n\tfor (let i = length; i > 0; --i) { result += chars[Math.floor(Math.random() * chars.length)]; }\n\treturn result;\n}\n\nexport function toTitleCase(str) {\n\treturn str.replace(/\\w\\S*/g, function(txt){\n\t\treturn txt.charAt(0).toUpperCase() + txt.substr(1).toLowerCase();\n\t});\n}\n\nexport function isObject(item) {\n\treturn (item && typeof item === 'object' && !Array.isArray(item));\n}\n\nexport function mergeDeep(target, ...sources) {\n\tif (!sources.length) {\n\t\treturn target;\n\t}\n\tconst source = sources.shift();\n\n\tif (isObject(target) && isObject(source)) {\n\t\tfor (const key in source) {\n\t\t\tif (isObject(source[key])) {\n\t\t\t\tif (!target[key]) {\n\t\t\t\t\tObject.assign(target, { [key]: {} });\n\t\t\t\t}\n\t\t\t\tmergeDeep(target[key], source[key]);\n\t\t\t} \n\t\t\telse {\n\t\t\t\tObject.assign(target, { [key]: source[key] });\n\t\t\t}\n\t\t}\n\t}\n\n\treturn mergeDeep(target, ...sources);\n}"]}
|