@resolveio/server-lib 20.5.14 → 20.5.15
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/collections/monitor-function.collection.d.ts +3 -0
- package/collections/monitor-function.collection.js +2 -0
- package/collections/monitor-function.collection.js.map +1 -0
- package/http/auth.js +1 -1
- package/http/auth.js.map +1 -1
- package/managers/local-log.manager.d.ts +1 -1
- package/managers/local-log.manager.js.map +1 -1
- package/managers/method.manager.d.ts +2 -4
- package/managers/method.manager.js +1 -1
- package/managers/method.manager.js.map +1 -1
- package/managers/mongo.manager.js +1 -1
- package/managers/mongo.manager.js.map +1 -1
- package/managers/monitor.manager.d.ts +7 -6
- package/managers/monitor.manager.js +1 -1
- package/managers/monitor.manager.js.map +1 -1
- package/managers/subscription.manager.js +1 -1
- package/managers/subscription.manager.js.map +1 -1
- package/methods/aws.js +1 -1
- package/methods/aws.js.map +1 -1
- package/methods/cron-jobs.js +1 -1
- package/methods/cron-jobs.js.map +1 -1
- package/methods/logs.js +1 -1
- package/methods/logs.js.map +1 -1
- package/methods/pdf.js +1 -1
- package/methods/pdf.js.map +1 -1
- package/methods.ts +0 -3
- package/models/log.model.d.ts +1 -1
- package/models/monitor-function.model.d.ts +14 -0
- package/models/{worker-task-request.model.js → monitor-function.model.js} +1 -1
- package/models/monitor-function.model.js.map +1 -0
- package/package.json +1 -1
- package/server-app.d.ts +33 -2
- package/server-app.js +1 -1
- package/server-app.js.map +1 -1
- package/collections/worker-task-request.collection.d.ts +0 -3
- package/collections/worker-task-request.collection.js +0 -2
- package/collections/worker-task-request.collection.js.map +0 -1
- package/collections/worker-task-response.collection.d.ts +0 -3
- package/collections/worker-task-response.collection.js +0 -2
- package/collections/worker-task-response.collection.js.map +0 -1
- package/models/worker-task-request.model.d.ts +0 -10
- package/models/worker-task-request.model.js.map +0 -1
- package/models/worker-task-response.model.d.ts +0 -9
- package/models/worker-task-response.model.js +0 -2
- package/models/worker-task-response.model.js.map +0 -1
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"sources":["../../src/managers/subscription.manager.ts"],"names":["logs_1","require","app_status_1","files_1","super_admin_1","logged_in_users_collection_1","cron_jobs_1","flags_1","method_responses_1","resolveio_server_app_1","notifications_1","report_builder_reports_1","report_builder_libraries_1","user_groups_1","user_guides_1","report_builder_dashboard_builders_1","common_1","NodeCache","flag_collection_1","os_1","flags_update_1","numCPUs","cpus","length","v8","SubscriptionManager","wss","serverConfig","monitorManagerFunction","_this","this","_publications","_subscriptions","_loggedInUsers","_mongoQueue","_mongoQueueId","_cacheId","_heapSize","getHeapStatistics","_enableDebug","_debugOplogCollections","_debugOplogHits","_debugSubCollections","_debugSubHits","_debugUnSubHits","_debugUnSubAllHits","_debugMongoQueueHits","_debugMongoQueueCollections","_debugSendQueueHits","_debugRemoveCacheHits","_oplogRetryCount","latencyBuffer","Map","LATENCY_UPDATE_INTERVAL","LATENCY_UPDATE_THRESHOLD_MS","_websocketManager","ResolveIOServer","getMainServer","getWebSocketManager","_monitorManagerFunction","_nodeCache","stdTTL","checkperiod","setInterval","flushThrottledLatencyUpdates","_wss","loadSuperAdminPublications","loadAppStatusPublications","loadLogPublications","loadFilePublications","loadCronJobPublications","loadFlagsUpdatePublications","loadFlagsPublications","loadMethodResponsePublications","loadNotificationPublications","loadReportBuilderReportPublications","loadReportBuilderLibraryPublications","loadUserGroupPublications","loadUserGuidePublications","loadReportBuilderDashboardBuilderPublications","tailOpLog","getEnableDebug","console","log","Date","JSON","stringify","sort","a","b","collection","localeCompare","publication","type","__awaiter","_a","LoggedInUsers","find","_b","sent","userCopy","deepCopy","i","loggedInUser","date","now","getTime","this_1","getWebSocket","id_ws","unsubscribeAll","forEach","sub","j","clients","id_socket","splice","deleteOne","_id","findIndex","client","this_2","some","Flags","findOne","then","flag","value","setCacheLimit","prototype","process","env","IS_WORKERS_ENABLED","_heapLimit","invalidatePubsCache","getMongoManager","invalidateQueryCache","collSubs","filter","collections","includes","this_3","running","runAgain","user_specific","Promise","all","map","ws","readyState","OPEN","sendDataToOneWithRetry","messageId","err","getMethodManager","sendEmail","id_user","sendDataToAllWithRetry","collSubs_1","__values","collSubs_1_1","next","done","delay","ms","resolve","setTimeout","sendDataToAll","sendDataToOne","publications","method","Object","assign","loggedInLatency","existingEntry","newLatency","get","lastUpdate","Math","abs","latency","set","size","updates","Array","from","entries","__read","_c","updateOne","update","$set","bulkWrite","clear","error","error_1","subscribe","messageRoute","messageDate","subscriptionData","pub","hits","push","check","_schema","valObj","rootKeys","keys","validate","errors","urlData","split","urlModule_1","urlNext","otherRouteSubs","startsWith","otherSub","unsubscribe","getPublicationCollections","cacheId","processSubscription","createLoggedInUser","reject","user","objectIdHexString","__v","insertOne","indexOf","userSubs","removeWebSocket","getActiveSubscriptions","resumeToken","_oplog$","closed","removeAllListeners","close","exit","pipeline","$match","$and","ns.coll","$nin","$not","lastResumeToken_1","getMainDB","watch","resumeAfter","errOp","on","doc","ns","coll","operationType","callMethodInternal","call","documentKey","NODE_APP_INSTANCE","IS_WORKER_INSTANCE","WORKER_INDEX","cacheData","parse","dateReviver","serverRes","hasError","data","sendWS","del","monitor","startMonitorFunction","function","apply","__spreadArray","res","finishMonitorFunction","err_1","subIndex","res_1","getBinarySize","endsWith","nodeCacheSize","getStats","vsize","deleteCount","subArr","zz","err_2","send","exports"],"mappings":"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","file":"subscription.manager.js","sourcesContent":["import { ServerResponseModel } from '../models/server-response.model';\nimport { ActiveSubscriptionModel, SubscriptionModel } from '../models/subscription.model';\nimport * as WebSocket from 'ws';\nimport { loadLogPublications } from '../publications/logs';\nimport { loadAppStatusPublications } from '../publications/app-status';\nimport { loadFilePublications } from '../publications/files';\nimport { loadSuperAdminPublications } from '../publications/super-admin';\nimport { LoggedInUsers } from '../collections/logged-in-users.collection';\nimport { loadCronJobPublications } from '../publications/cron-jobs';\nimport { loadFlagsPublications } from '../publications/flags';\nimport { loadMethodResponsePublications } from '../publications/method-responses';\nimport { ResolveIOServer } from '../resolveio-server-app';\nimport { loadNotificationPublications } from '../publications/notifications';\nimport { loadReportBuilderReportPublications } from '../publications/report-builder-reports';\nimport { LoggedInUserModel } from '../models/logged-in-users.model';\n\nimport { ChangeStream, ChangeStreamDeleteDocument, ChangeStreamInsertDocument, ChangeStreamReplaceDocument, ChangeStreamUpdateDocument, ResumeToken } from 'mongodb';\nimport { loadReportBuilderLibraryPublications } from '../publications/report-builder-libraries';\nimport { loadUserGroupPublications } from '../publications/user-groups';\nimport { loadUserGuidePublications } from '../publications/user-guides';\nimport { loadReportBuilderDashboardBuilderPublications } from '../publications/report-builder-dashboard-builders';\nimport { dateReviver, deepCopy, getBinarySize, objectIdHexString } from '../util/common';\nimport * as NodeCache from 'node-cache';\nimport { MonitorManagerFunction } from './monitor.manager';\nimport { Flags } from '../collections/flag.collection';\nimport { cpus } from 'os';\nimport { WebSocketManager } from './websocket.manager';\nimport { loadFlagsUpdatePublications } from '../publications/flags-update';\nconst numCPUs = cpus().length;\nconst v8 = require('v8');\n\n// Performance Dependencies\n// import * as path from 'path';\n// import { Worker } from 'worker_threads';\n\ninterface MongoQueueModel {\n\t_id: number,\n\ttype: string;\n\tcollection: string;\n\tsubscription: ActiveSubscriptionModel;\n\trunning: boolean;\n\trun_again: boolean;\n}\n\n// interface CurrentPerformanceMonitor {\n// \t_id: number;\n// \tfunction: string;\n// \tpublication: string;\n// \tsubscriptionData: any[];\n// \tdate_start: Date;\n// \tdate_end: Date;\n// \tduration: number;\n// \tresult: string;\n// }\n\nexport class SubscriptionManager {\n\tprivate _websocketManager: WebSocketManager;\n\tprivate _publications: SubscriptionModel = {};\n\tprivate _subscriptions: ActiveSubscriptionModel[] = [];\n\tprivate _wss: WebSocket.Server;\n\tprivate _loggedInUsers: LoggedInUserModel[] = [];\n\n\tprivate _mongoQueue: MongoQueueModel[] = [];\n\tprivate _mongoQueueId = 0;\n\t\n\tprivate _oplog$: ChangeStream;\n\n\tprivate _nodeCache;\n\tprivate _cacheId = 1;\n\n\tprivate _heapSize = v8.getHeapStatistics() / numCPUs;\n\tprivate _heapLimit: number;\n\n\tprivate serverConfig;\n\n\tprivate _monitorManagerFunction: MonitorManagerFunction;\n\n\tprivate _enableDebug = false;\n\tprivate _debugOplogCollections = [];\n\tprivate _debugOplogHits = 0;\n\tprivate _debugSubCollections = [];\n\tprivate _debugSubHits = 0;\n\tprivate _debugUnSubHits = 0;\n\tprivate _debugUnSubAllHits = 0;\n\tprivate _debugMongoQueueHits = 0;\n\tprivate _debugMongoQueueCollections = [];\n\tprivate _debugSendQueueHits = 0;\n\tprivate _debugRemoveCacheHits = 0;\n\n\tprivate _oplogRetryCount = 0;\n\n\t// Buffer to store throttled latency updates with timestamps\n\tprivate latencyBuffer = new Map<string, { latency: number, lastUpdate: Date }>();\n\n\t// Interval to flush latency updates in MongoDB\n\tprivate readonly LATENCY_UPDATE_INTERVAL = 60000;\n\n\t// Minimum time difference between two latency updates for the same user\n\tprivate readonly LATENCY_UPDATE_THRESHOLD_MS = 30000;\n\n\t// private currentPerfomanceMonitor: CurrentPerformanceMonitor[] = [];\n\t// private idPerformance: number = 0;\n\t// private performanceThread;\n\n\tconstructor(wss: WebSocket.Server, serverConfig, monitorManagerFunction: MonitorManagerFunction) {\n\t\tthis._websocketManager = ResolveIOServer.getMainServer().getWebSocketManager();\n\t\tthis._monitorManagerFunction = monitorManagerFunction;\n\n\t\tthis._nodeCache = new NodeCache( { stdTTL: 0, checkperiod: 0 } );\n\n\t\tsetInterval(() => this.flushThrottledLatencyUpdates(), this.LATENCY_UPDATE_INTERVAL);\n\n\t\t// setTimeout(() => {\n\t\t// \tconsole.log('Setting up performance thread');\n\n\t\t// \tthis.performanceThread = new Worker(path.join(__dirname, './subscription.performance.js'));\n\n\t\t// \tthis.performanceThread.on('exit', code => {\n\t\t// \t\tconsole.error(new Date(), 'THREAD EXITED!!!!!!!!!!!!!!!!!!', code);\n\t\t// \t});\n\n\t\t// \tthis.performanceThread.on('error', code => {\n\t\t// \t\tconsole.error(new Date(), 'THREAD RECV ERROR !!!!!!!!!!!!!!!!!!', code);\n\t\t// \t});\n\t\t// }, 5000);\n\n\t\t// setInterval(() => {\n\t\t// \tconsole.log('Post thread msg');\n\t\t// \tthis.performanceThread.postMessage(this.currentPerfomanceMonitor);\n\t\t// \tthis.currentPerfomanceMonitor = [];\n\t\t// }, 10000);\n\n\t\tthis.serverConfig = serverConfig;\n\t\tthis._wss = wss;\n\n\t\t// Publications\n\t\tloadSuperAdminPublications(this);\n\t\tloadAppStatusPublications(this);\n\t\tloadLogPublications(this);\n\t\tloadFilePublications(this);\n\t\tloadCronJobPublications(this);\n\t\tloadFlagsUpdatePublications(this);\n\t\tloadFlagsPublications(this);\n\t\tloadMethodResponsePublications(this);\n\t\tloadNotificationPublications(this);\n\t\tloadReportBuilderReportPublications(this);\n\t\tloadReportBuilderLibraryPublications(this);\n\t\tloadUserGroupPublications(this);\n\t\tloadUserGuidePublications(this);\n\t\tloadReportBuilderDashboardBuilderPublications(this);\n\n\t\tthis.tailOpLog();\n\n\t\tsetInterval(() => {\n\t\t\tthis._oplogRetryCount = 0;\n\t\t}, 15000);\n\n\t\tsetInterval(() => {\n\t\t\tif (this.getEnableDebug()) {\n\t\t\t\tconsole.log(new Date(), 'Sub Manager', 'Subs', this._subscriptions.length);\n\t\t\t\tconsole.log(new Date(), 'Sub Manager', 'Logged In Users', this._loggedInUsers.length);\n\t\t\t\tconsole.log(new Date(), 'Sub Manager', 'Mongo Queue', this._mongoQueue.length);\n\t\t\t\tconsole.log(new Date(), 'Sub Manager', 'Mongo Queue Hits', this._debugMongoQueueHits);\n\t\t\t\tconsole.log(new Date(), 'Sub Manager', 'Mongo Queue Collections', JSON.stringify(this._debugMongoQueueCollections.sort((a, b) => a.collection.localeCompare(b.collection) || a.publication.localeCompare(b.publication)), null, 2));\n\t\t\t\tconsole.log(new Date(), 'Sub Manager', 'Oplog Hits', this._debugOplogHits);\n\t\t\t\tconsole.log(new Date(), 'Sub Manager', 'Oplog Collections', JSON.stringify(this._debugOplogCollections.sort((a, b) => a.collection.localeCompare(b.collection) || a.type.localeCompare(b.type)), null, 2));\n\t\t\t\tconsole.log(new Date(), 'Sub Manager', 'Send Queue Hits', this._debugSendQueueHits);\n\t\t\t\tconsole.log(new Date(), 'Sub Manager', 'Sub Hits', this._debugSubHits);\n\t\t\t\tconsole.log(new Date(), 'Sub Manager', 'Sub Collections', JSON.stringify(this._debugSubCollections.sort((a, b) => a.publication.localeCompare(b.publication)), null, 2));\n\t\t\t\tconsole.log(new Date(), 'Sub Manager', 'Unsub Hits', this._debugUnSubHits);\n\t\t\t\tconsole.log(new Date(), 'Sub Manager', 'Unsub All Hits', this._debugUnSubAllHits);\n\t\t\t\tconsole.log(new Date(), 'Sub Manager', 'Cache Cleanup Hits', this._debugRemoveCacheHits);\n\t\t\t}\n\t\t\t\n\t\t\tthis._debugOplogHits = 0;\n\t\t\tthis._debugOplogCollections = [];\n\t\t\tthis._debugSubCollections = [];\n\t\t\tthis._debugMongoQueueHits = 0;\n\t\t\tthis._debugMongoQueueCollections = [];\n\t\t\tthis._debugSendQueueHits = 0;\n\t\t\tthis._debugSubHits = 0;\n\t\t\tthis._debugUnSubHits = 0;\n\t\t\tthis._debugUnSubAllHits = 0;\n\t\t\tthis._debugRemoveCacheHits = 0;\n\t\t}, 60000);\n\n\t\tsetInterval(async () => {\n\t\t\tthis._loggedInUsers = await LoggedInUsers.find();\n\t\n\t\t\tlet userCopy = deepCopy(this._loggedInUsers);\n\t\t\tfor (let i = this._loggedInUsers.length - 1; i >= 0; i--) {\n\t\t\t\tlet loggedInUser = userCopy[i];\n\n\t\t\t\tif (!loggedInUser.date || Date.now() - loggedInUser.date.getTime() > 120000) {\n\t\t\t\t\tif (this._websocketManager.getWebSocket(loggedInUser.id_ws)) {\n\t\t\t\t\t\tif (this.getEnableDebug()) {\n\t\t\t\t\t\t\tconsole.log(new Date(), 'Sub Manager', 'Unsub WS', this._websocketManager.getWebSocket(loggedInUser.id_ws)['user'], this._websocketManager.getWebSocket(loggedInUser.id_ws)['id_socket'], 2);\n\t\t\t\t\t\t}\n\t\t\t\t\t\tthis.unsubscribeAll(this._websocketManager.getWebSocket(loggedInUser.id_ws));\n\t\t\t\t\t}\n\t\t\t\t\telse {\n\t\t\t\t\t\tthis._subscriptions.forEach(sub => {\n\t\t\t\t\t\t\tfor (let j = sub.clients.length - 1; j >= 0; j--) {\n\t\t\t\t\t\t\t\tlet client = sub.clients[j];\n\n\t\t\t\t\t\t\t\tif (client.id_socket === loggedInUser.id_ws) {\n\t\t\t\t\t\t\t\t\tsub.clients.splice(j, 1);\n\t\t\t\t\t\t\t\t}\n\t\t\t\t\t\t\t}\n\t\t\t\t\t\t});\n\n\t\t\t\t\t\tLoggedInUsers.deleteOne({_id: loggedInUser._id});\n\n\t\t\t\t\t\tif (this._loggedInUsers.findIndex(a => a._id === loggedInUser._id) >= 0) {\n\t\t\t\t\t\t\tthis._loggedInUsers.splice(this._loggedInUsers.findIndex(a => a._id === loggedInUser._id), 1);\n\t\t\t\t\t\t}\n\t\t\t\t\t}\n\t\t\t\t}\n\t\t\t}\n\n\t\t\tfor (let i = 0; i < this._subscriptions.length; i++) {\n\t\t\t\tlet sub = this._subscriptions[i];\n\n\t\t\t\tfor (let j = sub.clients.length - 1; j >= 0; j--) {\n\t\t\t\t\tlet client = sub.clients[j];\n\n\t\t\t\t\tif (!this._loggedInUsers.some(a => a.id_ws === client.id_socket)) {\n\t\t\t\t\t\tsub.clients.splice(j, 1);\n\t\t\t\t\t}\n\t\t\t\t}\n\t\t\t}\n\t\t}, 30000);\n\n\t\tFlags.findOne({type: 'Enable Debug'}).then(flag => {\n\t\t\tif (flag && flag.value) {\n\t\t\t\tthis._enableDebug = true;\n\t\t\t}\n\t\t\telse {\n\t\t\t\tthis._enableDebug = false;\n\t\t\t}\n\t\t});\n\n\t\tthis.setCacheLimit();\n\t}\n\n\tprivate setCacheLimit() {\t\n\t\tif (process.env.IS_WORKERS_ENABLED === 'true') {\n\t\t\tthis._heapLimit = this._heapSize * 0.4;\n\t\t}\n\t\telse {\n\t\t\tthis._heapLimit = this._heapSize * 0.3; // Use 50% of total heap size\n\t\t}\n\t}\n\n\tpublic async invalidatePubsCache(collection: string, type: string) {\n\t\tResolveIOServer.getMongoManager().invalidateQueryCache(collection);\n\n\t\tlet collSubs = this._subscriptions.filter(a => a.collections.includes(collection));\n\n\t\tfor (let sub of collSubs) {\n\t\t\tif (this._enableDebug) {\n\t\t\t\tconsole.log(new Date(), 'Invalidate Sub', sub.publication, sub.running, sub.runAgain);\n\t\t\t}\n\n\t\t\tif (sub.running) {\n\t\t\t\tsub.runAgain = true;\n\t\t\t\tcontinue;\n\t\t\t}\n\n\t\t\tif (this._publications[sub.publication].user_specific) {\n\t\t\t\tPromise.all(\n\t\t\t\t\tsub.clients.map(async client => {\n\t\t\t\t\t\tlet ws = this._websocketManager.getWebSocket(client.id_socket);\n\t\t\t\t\t\tif (ws && ws.readyState === ws.OPEN) {\n\t\t\t\t\t\t\ttry {\n\t\t\t\t\t\t\t\tthis.sendDataToOneWithRetry(ws, client.messageId, sub, collection, type);\n\t\t\t\t\t\t\t} catch (err) {\n\t\t\t\t\t\t\t\t// Handle error\n\t\t\t\t\t\t\t\tResolveIOServer.getMainServer().getMethodManager().sendEmail('dev@resolveio.com', 'SERVER - Error Detected - ' + this.serverConfig['CLIENT_NAME'], 'Error Detected During sendDataToOne - User Specific - Socket: ' + client.id_socket + ', User: ' + client.id_user + ', MessageId: ' + client.messageId + ', Pub: ' + sub.publication + ', Err: ' + JSON.stringify(err, null, 2));\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\telse {\n\t\t\t\tthis.sendDataToAllWithRetry(sub, collection, type);\n\t\t\t}\n\t\t}\n\t}\n\n\tprivate async delay(ms: number) {\n\t\treturn new Promise(resolve => setTimeout(resolve, ms));\n\t}\n\n\tprivate async sendDataToAllWithRetry(sub: ActiveSubscriptionModel, collection: string, type: string) {\n\t\tsub.running = true;\n\n\t\tdo {\n\t\t\tif (this._enableDebug) {\n\t\t\t\tconsole.log(new Date(), 'Running sendDataToAll Sub', sub.publication);\n\t\t\t}\n\n\t\t\tsub.runAgain = false;\n\t\t\tawait this.sendDataToAll(sub, collection, type);\n\n\t\t\tif (this._enableDebug) {\n\t\t\t\tconsole.log(new Date(), 'Done sendDataToAll Sub', sub.publication, sub.runAgain);\n\t\t\t}\n\n\t\t\tif (sub.runAgain) {\n\t\t\t\tawait this.delay(500); // delay, adjust as needed\n\t\t\t}\n\t\t} while (sub.runAgain);\n\n\t\tsub.running = false;\n\t}\n\n\tprivate async sendDataToOneWithRetry(ws: WebSocket, messageId: number, sub: ActiveSubscriptionModel, collection: string, type: string) {\n\t\tsub.running = true;\n\n\t\tdo {\n\t\t\tif (this._enableDebug) {\n\t\t\t\tconsole.log(new Date(), 'Running sendDataToOne Sub', sub.publication);\n\t\t\t}\n\n\t\t\tsub.runAgain = false;\n\t\t\tawait this.sendDataToOne(ws, messageId, sub, collection, type);\n\n\t\t\tif (this._enableDebug) {\n\t\t\t\tconsole.log(new Date(), 'Done sendDataToOne Sub', sub.publication, sub.runAgain);\n\t\t\t}\n\n\t\t\tif (sub.runAgain) {\n\t\t\t\tawait this.delay(500); // delay, adjust as needed\n\t\t\t}\n\t\t} while (sub.runAgain);\n\t\tsub.running = false;\n\t}\n\n\t// Add all files to publications private object\n\tpublic publications(method: SubscriptionModel) {\n\t\tthis._publications = Object.assign(this._publications, method);\n\t}\n\n\t// Throttled `loggedInLatency` method\n\tpublic loggedInLatency(ws: WebSocket) {\n\t\tlet loggedInUser = this._loggedInUsers.find(a => a.id_ws === ws['id_socket']);\n\t\tif (!loggedInUser) return;\n\n\t\tconst now = new Date();\n\t\tconst existingEntry = this.latencyBuffer.get(ws['id_socket']);\n\t\tconst newLatency = ws['latency'];\n\n\t\t// Throttle updates: only update if time threshold has passed or latency has significantly changed\n\t\tif (\n\t\t\t!existingEntry || \n\t\t\t(now.getTime() - existingEntry.lastUpdate.getTime() >= this.LATENCY_UPDATE_THRESHOLD_MS) || \n\t\t\t(Math.abs(newLatency - existingEntry.latency) > 100) // Optional: log only significant changes\n\t\t) {\n\t\t\t// Update in-memory and buffer\n\t\t\tloggedInUser.date = now;\n\t\t\tthis.latencyBuffer.set(ws['id_socket'], { latency: newLatency, lastUpdate: now });\n\t\t}\n\t}\n\n\t// Method to flush buffered latency updates in bulk\n\tprivate async flushThrottledLatencyUpdates() {\n\t\tif (this.latencyBuffer.size === 0) return; // No updates to flush\n\n\t\tconst updates = Array.from(this.latencyBuffer.entries()).map(([id_ws, { latency, lastUpdate }]) => ({\n\t\t\tupdateOne: {\n\t\t\t\tfilter: { id_ws },\n\t\t\t\tupdate: { $set: { latency, date: lastUpdate } }\n\t\t\t}\n\t\t}));\n\n\t\ttry {\n\t\t\tawait LoggedInUsers.bulkWrite(updates);\n\t\t\tthis.latencyBuffer.clear(); // Clear buffer after successful update\n\n\t\t\tif (this.getEnableDebug()) {\n\t\t\t\tconsole.log(new Date(), 'Sub Manager', 'Throttled latency batch update successful', updates.length);\n\t\t\t}\n\t\t}\n\t\tcatch (error) {\n\t\t\tconsole.error(new Date(), 'Sub Manager', 'Throttled latency batch update failed', error);\n\t\t\t// Optional: implement retry logic or logging for failed updates\n\t\t}\n\t}\n\n\t// Subscribe to publication\n\tpublic subscribe(messageRoute: string, messageDate: Date, ws: WebSocket, messageId: number, publication: string, subscriptionData: any[]) {\n\t\tthis._debugSubHits += 1;\n\n\t\tif (!this._debugSubCollections.some(a => a.publication === publication)) {\n\t\t\tthis._debugSubCollections.push({\n\t\t\t\tpublication: publication,\n\t\t\t\thits: 1\n\t\t\t});\n\t\t}\n\t\telse {\n\t\t\tthis._debugSubCollections.find(a => a.publication === publication).hits += 1;\n\t\t}\n\n\t\tlet pub = this._publications[publication];\n\n\t\tif (!pub) {\n\t\t\tconsole.error(new Date(), 'No Publication: ' + publication);\n\t\t\treturn;\n\t\t}\n\t\telse {\n\t\t\tif (subscriptionData.length > 1 || subscriptionData[0]) {\n\t\t\t\tif (!pub.check) {\n\t\t\t\t\tconsole.error(new Date(), 'No Check Function For Pub ' + publication);\n\t\t\t\t\treturn;\n\t\t\t\t}\n\t\t\t\telse if (!pub.check._schema) {\n\t\t\t\t\tconsole.error(new Date(), 'No Check Schema For Pub ' + publication);\n\t\t\t\t\treturn;\n\t\t\t\t}\n\t\t\t\telse {\n\t\t\t\t\tlet valObj = {};\n\t\t\t\t\tlet valKeys = Object.keys(pub.check._schema);\n\n\t\t\t\t\tlet rootKeys = valKeys.filter(a => !a.includes('.'));\n\n\t\t\t\t\tfor (let i = 0; i < subscriptionData.length; i++) {\n\t\t\t\t\t\tvalObj[rootKeys[i]] = subscriptionData[i];\n\t\t\t\t\t}\n\n\t\t\t\t\ttry {\n\t\t\t\t\t\tpub.check.validate(valObj);\n\t\t\t\t\t}\n\t\t\t\t\tcatch (errors) {\n\t\t\t\t\t\tif (errors) {\n\t\t\t\t\t\t\tconsole.error(new Date(), 'Error in Pub Check (' + publication + ')', errors);\n\t\t\t\t\t\t\treturn;\n\t\t\t\t\t\t}\n\t\t\t\t\t}\n\t\t\t\t}\n\t\t\t}\n\n\t\t\tif (messageRoute !== 'Bypass') {\n\t\t\t\tlet urlData = messageRoute.split('/');\n\t\t\t\tlet urlModule = '';\n\t\t\t\tlet urlNext = urlData[0];\n\n\t\t\t\tif (urlData[0] === '') {\n\t\t\t\t\turlModule = '/';\n\t\t\t\t\turlNext = urlData[1];\n\t\t\t\t}\n\n\t\t\t\turlModule += urlNext;\n\n\t\t\t\tif (urlData.length > 1) {\n\t\t\t\t\turlModule += '/';\n\t\t\t\t}\n\n\t\t\t\tlet otherRouteSubs = this._subscriptions.filter(a => a.clients.some(b => b.id_socket === ws['id_socket'] && b.messageRoute !== 'Bypass' && b.messageRoute !== '/' && b.messageRoute !== messageRoute && !b.messageRoute.startsWith(urlModule)));\n\n\t\t\t\tif (otherRouteSubs.length) {\n\t\t\t\t\tResolveIOServer.getMainServer().getMethodManager().sendEmail('dev@resolveio.com', 'SERVER - Detected Undestroyed Subscription - ' + this.serverConfig['CLIENT_NAME'], 'USER: ' + ws['user'] + ' (Socket: ' + ws['id_socket'] + ') ' + ' is on route: ' + messageRoute + ' but has the following subscriptions on other routes:' + JSON.stringify(otherRouteSubs, null, 2));\n\n\t\t\t\t\totherRouteSubs.forEach(otherSub => {\n\t\t\t\t\t\totherSub.clients.filter(a => a.id_socket === ws['id_socket']).forEach(client => {\n\t\t\t\t\t\t\tthis.unsubscribe(client.messageRoute, new Date(), ws, client.messageId, otherSub.publication, otherSub.subscriptionData);\n\t\t\t\t\t\t});\n\t\t\t\t\t});\n\t\t\t\t}\n\t\t\t}\n\n\t\t\tlet sub = this._subscriptions.find(a => a.publication === publication && JSON.stringify(a.subscriptionData) === JSON.stringify(subscriptionData));\n\n\t\t\t// If sub found (another user watching same data), add client to same sub\n\t\t\tif (sub) {\n\t\t\t\tif (!sub.clients.some(a => a.id_socket === ws['id_socket'] && a.messageId === messageId)) {\n\t\t\t\t\tsub.clients.push({\n\t\t\t\t\t\tid_user: ws['id_user'],\n\t\t\t\t\t\tmessageId: messageId,\n\t\t\t\t\t\tid_socket: ws['id_socket'],\n\t\t\t\t\t\tmessageRoute: messageRoute\n\t\t\t\t\t});\n\t\t\t\t}\n\t\t\t}\n\t\t\t// If sub not found, create new sub\n\t\t\telse {\n\t\t\t\tthis._subscriptions.push({\n\t\t\t\t\tpublication: publication,\n\t\t\t\t\tsubscriptionData: subscriptionData,\n\t\t\t\t\tcollections: this.getPublicationCollections(publication),\n\t\t\t\t\tclients: [{\n\t\t\t\t\t\tid_user: ws['id_user'],\n\t\t\t\t\t\tmessageId: messageId,\n\t\t\t\t\t\tid_socket: ws['id_socket'],\n\t\t\t\t\t\tmessageRoute: messageRoute,\n\t\t\t\t\t}],\n\t\t\t\t\tcacheId: 0,\n\t\t\t\t\trunning: false,\n\t\t\t\t\trunAgain: false\n\t\t\t\t});\n\t\t\t}\n\n\t\t\tif (!sub) {\n\t\t\t\tsub = this._subscriptions.find(a => a.publication === publication && JSON.stringify(a.subscriptionData) === JSON.stringify(subscriptionData));\n\t\t\t}\n\n\t\t\tif (this._enableDebug) {\n\t\t\t\tconsole.log(new Date(), 'New Sub', sub.publication, sub.running, sub.runAgain, sub.clients.length);\n\t\t\t}\n\n\t\t\t// Immediately send data to the new client\n\t\t\tthis.processSubscription(sub, ws, messageId);\n\t\t}\n\t}\n\n\tpublic async createLoggedInUser(id_ws: string): Promise<LoggedInUserModel> {\n\t\treturn new Promise(async (resolve, reject) => {\n\t\t\tlet ws = this._websocketManager.getWebSocket(id_ws);\n\n\t\t\tif (ws) {\n\t\t\t\tlet user = {\n\t\t\t\t\t_id: objectIdHexString(),\n\t\t\t\t\t__v: 0,\n\t\t\t\t\tdate: new Date(),\n\t\t\t\t\tid_user: 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\t\n\t\t\t\tthis._loggedInUsers.push(user);\n\t\t\t\tLoggedInUsers.insertOne(user);\n\t\t\t\t\n\t\t\t\tresolve(user);\n\t\t\t}\n\t\t\telse {\n\t\t\t\tresolve(null);\n\t\t\t}\n\t\t});\n\t}\n\n\t// Unsubscribe from publication \n\tpublic unsubscribe(messageRoute: string, messageDate: Date, ws: WebSocket, messageId: number, publication: string, subscriptionData: any[]) {\n\t\tthis._debugUnSubHits += 1;\n\n\t\tif (!this._publications[publication]) {\n\t\t\tconsole.log('No Publication: ' + publication);\n\t\t\treturn;\n\t\t}\n\t\telse {\n\t\t\tlet sub = this._subscriptions.find(a => a.publication === publication && JSON.stringify(a.subscriptionData) === JSON.stringify(subscriptionData));\n\n\t\t\tif (sub) {\n\t\t\t\tfor (let i = sub.clients.length - 1; i >= 0; i--) {\n\t\t\t\t\tif (sub.clients[i].id_user === ws['id_user'] && sub.clients[i].messageId === messageId && sub.clients[i].id_socket === ws['id_socket']) {\n\t\t\t\t\t\tsub.clients.splice(i, 1);\n\t\t\t\t\t}\n\t\t\t\t}\n\n\t\t\t\tif (this._enableDebug) {\n\t\t\t\t\tconsole.log(new Date(), 'Unsub', sub.publication, sub.running, sub.runAgain, sub.clients.length);\n\t\t\t\t}\n\t\t\t}\n\t\t}\n\t}\n\n\n\t// Unsubscribe from publication\n\tpublic async unsubscribeAll(ws: WebSocket) {\n\t\tthis._debugUnSubAllHits += 1;\n\n\t\tif (ws) {\n\t\t\t// Check if WebSocket has already been unsubscribed\n\t\t\tif (ws['isUnsubscribed']) {\n\t\t\t\treturn; // Skip if already unsubscribed\n\t\t\t}\n\t\t\t\n\t\t\t// Mark the WebSocket as unsubscribed to prevent further calls\n\t\t\tws['isUnsubscribed'] = true;\n\t\t\t\n\t\t\tif (this._loggedInUsers.map(a => a.id_ws).indexOf(ws['id_socket']) >= 0) {\n\t\t\t\tthis._loggedInUsers.splice(this._loggedInUsers.map(a => a.id_ws).indexOf(ws['id_socket']), 1);\n\t\t\t}\n\t\t\tLoggedInUsers.deleteOne({ id_ws: ws['id_socket'] });\n\n\t\t\tlet userSubs = this._subscriptions.filter(a => a.clients.some(b => b.id_user === ws['id_user'] && b.id_socket === ws['id_socket']));\n\n\t\t\tfor (let i = userSubs.length - 1; i >= 0; i--) {\n\t\t\t\tlet sub = userSubs[i];\n\n\t\t\t\tfor (let j = sub.clients.length - 1; j >= 0; j--) {\n\t\t\t\t\tif (sub.clients[j].id_socket === ws['id_socket']) {\n\t\t\t\t\t\tsub.clients.splice(j, 1);\n\t\t\t\t\t}\n\t\t\t\t}\n\t\t\t}\n\n\t\t\tthis._websocketManager.removeWebSocket(ws);\n\t\t}\n\t}\n\n\tpublic getActiveSubscriptions() {\n\t\treturn this._subscriptions;\n\t}\n\n\t// Get publication collection\n\tprivate getPublicationCollections(publication: string) {\n\t\treturn this._publications[publication].collections;\n\t}\n\n\t// Watch (tail) Mongo's operation log on the entire database (all insert/modify/delete will trigger this function)\n\tprivate async tailOpLog(resumeToken?: ResumeToken) {\n\t\tif (this._oplog$ && !this._oplog$.closed) {\n\t\t\tthis._oplog$.removeAllListeners();\n\t\t\tthis._oplog$.close();\n\t\t\tthis._oplog$ = null;\n\t\t}\n\n\t\tawait new Promise(resolve => setTimeout(resolve, 1000));\n\n\t\tif (!this._oplog$ || this._oplog$.closed) {\n\t\t\tthis._oplogRetryCount += 1;\n\n\t\t\tif (this._oplogRetryCount > 5) {\n\t\t\t\tconsole.error('****************** TAIL OPLOG ERROR, RETRYING A BUNCH OF TIMES, KILLING PROCESS **************************');\n\t\t\t\tprocess.exit(1);\n\t\t\t}\n\n\t\t\tconst pipeline = [\n\t\t\t\t{\n\t\t\t\t\t$match: {\n\t\t\t\t\t\t$and: [\n\t\t\t\t\t\t\t{'ns.coll': { $nin: ['logs', 'log-method-latencies', 'log-subscriptions'] }},\n\t\t\t\t\t\t\t{'ns.coll': { $not: /.*\\.versions$/ }},\n\t\t\t\t\t\t\t{'ns.coll': { $not: /^monitor-/ }},\n\t\t\t\t\t\t]\n\t\t\t\t\t},\n\t\t\t\t},\n\t\t\t];\n\n\t\t\tlet lastResumeToken: ResumeToken;\n\n\t\t\tif (resumeToken) {\n\t\t\t\tlastResumeToken = resumeToken;\n\t\t\t\ttry {\n\t\t\t\t\tthis._oplog$ = ResolveIOServer.getMainDB().watch(pipeline, { resumeAfter: resumeToken });\n\t\t\t\t}\n\t\t\t\tcatch (errOp) {\n\t\t\t\t\tif (this._oplog$) {\n\t\t\t\t\t\tthis._oplog$.removeAllListeners();\n\t\t\t\t\t\tthis._oplog$.close();\n\t\t\t\t\t\tthis._oplog$ = null;\n\t\t\t\t\t}\n\t\t\t\t\tthis.tailOpLog(resumeToken);\n\t\t\t\t\treturn;\n\t\t\t\t}\n\t\t\t}\n\t\t\telse {\n\t\t\t\tthis._oplog$ = ResolveIOServer.getMainDB().watch(pipeline);\n\t\t\t}\n\n\t\t\tconsole.log(new Date(), 'oplog started');\n\n\t\t\tthis._oplog$.on('change', (doc: ChangeStreamInsertDocument | ChangeStreamUpdateDocument | ChangeStreamReplaceDocument | ChangeStreamDeleteDocument) => {\n\t\t\t\tif (doc.ns) {\n\t\t\t\t\tif (this._enableDebug) {\n\t\t\t\t\t\tconsole.log(new Date(), 'Oplog Hit', doc.ns);\n\t\t\t\t\t}\n\n\t\t\t\t\tlet collection = doc.ns.coll;\n\n\t\t\t\t\tif (!this._debugOplogCollections.some(a => a.collection === doc.ns.coll && a.type === doc.operationType)) {\n\t\t\t\t\t\tthis._debugOplogCollections.push({\n\t\t\t\t\t\t\tcollection: doc.ns.coll,\n\t\t\t\t\t\t\ttype: doc.operationType,\n\t\t\t\t\t\t\thits: 1\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\tthis._debugOplogCollections.find(a => a.collection === doc.ns.coll && a.type === doc.operationType).hits += 1;\n\t\t\t\t\t}\n\n\t\t\t\t\tif (collection) {\n\t\t\t\t\t\tthis._debugOplogHits += 1;\n\n\t\t\t\t\t\tif (doc.operationType === 'insert') {\n\t\t\t\t\t\t\tif (collection === 'support-tickets') {\n\t\t\t\t\t\t\t\tif (this.serverConfig['ROOT_URL'] === 'https://resolveio.com') {\n\t\t\t\t\t\t\t\t\tResolveIOServer.getMainServer().getMethodManager().callMethodInternal.call(ResolveIOServer.getMainServer().getMethodManager(), 'sendSupportTicketEmail', doc.documentKey['_id']);\n\t\t\t\t\t\t\t\t\tthis.invalidatePubsCache(collection, 'insert');\n\t\t\t\t\t\t\t\t}\n\t\t\t\t\t\t\t}\n\n\t\t\t\t\t\t\tif (collection !== 'method-responses') {\n\t\t\t\t\t\t\t\tthis.invalidatePubsCache(collection, 'insert');\n\t\t\t\t\t\t\t}\n\t\t\t\t\t\t}\n\t\t\t\t\t\telse if (doc.operationType === 'update' || doc.operationType === 'replace') {\n\t\t\t\t\t\t\tif (collection !== 'method-responses') {\n\t\t\t\t\t\t\t\tthis.invalidatePubsCache(collection, 'update');\n\t\t\t\t\t\t\t}\n\t\t\t\t\t\t}\n\t\t\t\t\t\telse if (doc.operationType === 'delete') {\n\t\t\t\t\t\t\tif (collection !== 'method-responses') {\n\t\t\t\t\t\t\t\tthis.invalidatePubsCache(collection, 'delete');\n\t\t\t\t\t\t\t}\n\t\t\t\t\t\t}\n\t\t\t\t\t}\n\n\t\t\t\t\tif (collection === 'flags') {\n\t\t\t\t\t\tFlags.findOne({ type: 'Enable Debug' }).then(flag => {\n\t\t\t\t\t\t\tif (flag && flag.value) {\n\t\t\t\t\t\t\t\tthis._enableDebug = true;\n\t\t\t\t\t\t\t}\n\t\t\t\t\t\t\telse {\n\t\t\t\t\t\t\t\tthis._enableDebug = false;\n\t\t\t\t\t\t\t}\n\t\t\t\t\t\t});\n\t\t\t\t\t}\n\n\t\t\t\t\tlastResumeToken = doc._id;\n\n\t\t\t\t\tif ((!process.env.NODE_APP_INSTANCE || process.env.NODE_APP_INSTANCE === '0') && (process.env.IS_WORKERS_ENABLED === 'false' || (process.env.IS_WORKER_INSTANCE === 'true' && process.env.WORKER_INDEX === '0'))) {\n\n\t\t\t\t\t}\n\t\t\t\t}\n\t\t\t});\n\n\t\t\tthis._oplog$.on('error', error => {\n\t\t\t\tconsole.log(new Date(), 'oplog error', error);\n\t\t\t\tthis._oplog$.removeAllListeners();\n\t\t\t\tthis._oplog$.close();\n\t\t\t\tthis._oplog$ = null;\n\t\t\t\tthis.tailOpLog(lastResumeToken);\n\t\t\t});\n\n\t\t\tthis._oplog$.on('end', () => {\n\t\t\t\tconsole.log(new Date(), 'oplog end');\n\t\t\t\tthis._oplog$.removeAllListeners();\n\t\t\t\tthis._oplog$.close();\n\t\t\t\tthis._oplog$ = null;\n\t\t\t\tthis.tailOpLog(lastResumeToken);\n\t\t\t});\n\n\t\t\tthis._oplog$.on('close', () => {\n\t\t\t\tconsole.log(new Date(), 'oplog close');\n\t\t\t\tthis._oplog$.removeAllListeners();\n\t\t\t\tthis._oplog$ = null;\n\t\t\t\tthis.tailOpLog(lastResumeToken);\n\t\t\t});\n\t\t}\n\t}\n\n\tprivate async processSubscription(sub: ActiveSubscriptionModel, ws: WebSocket, messageId: number) {\n\t\tif (!this._publications[sub.publication].user_specific) {\t\t\t\n\t\t\tif (sub.cacheId) {\n\t\t\t\ttry {\n\t\t\t\t\tlet cacheData = JSON.parse(this._nodeCache.get(sub.cacheId), dateReviver);\n\n\t\t\t\t\tlet serverRes: ServerResponseModel = {\n\t\t\t\t\t\tmessageId: messageId,\n\t\t\t\t\t\thasError: false,\n\t\t\t\t\t\tdata: cacheData\n\t\t\t\t\t};\n\n\t\t\t\t\tif (this._enableDebug) {\n\t\t\t\t\t\tconsole.log(new Date(), 'Process Sub, Cache', sub.publication);\n\t\t\t\t\t}\n\n\t\t\t\t\tthis.sendWS(ws, serverRes);\n\t\t\t\t}\n\t\t\t\tcatch (err) {\n\t\t\t\t\tthis._nodeCache.del(sub.cacheId);\n\t\t\t\t\tsub.cacheId = 0;\n\n\t\t\t\t\tthis.sendDataToAllWithRetry(sub, '', 'newSub');\n\t\t\t\t}\n\t\t\t}\n\t\t\telse {\n\t\t\t\tif (this._enableDebug) {\n\t\t\t\t\tconsole.log(new Date(), 'Process Sub, Non - Cache', sub.publication, sub.running);\n\t\t\t\t}\n\n\t\t\t\tif (sub.running) {\n\t\t\t\t\treturn;\n\t\t\t\t}\n\n\t\t\t\tthis.sendDataToAllWithRetry(sub, '', 'newSub');\n\t\t\t}\n\t\t}\n\t\telse {\n\t\t\tif (this._enableDebug) {\n\t\t\t\tconsole.log(new Date(), 'Process Sub Specific, Non - Cache', sub.publication, sub.running);\n\t\t\t}\n\n\t\t\tif (sub.running) {\n\t\t\t\treturn;\n\t\t\t}\n\t\t\t\n\t\t\tthis.sendDataToOneWithRetry(ws, messageId, sub, '', 'newSub');\n\t\t}\n\t}\n\n\tprivate async sendDataToOne(ws: WebSocket, messageId: number, sub: ActiveSubscriptionModel, collection: string, type: string) {\n\t\tlet monitor = this._monitorManagerFunction.startMonitorFunction('User Specific Publication', sub.publication, '', '', sub.subscriptionData);\n\t\ttry {\n\t\t\tResolveIOServer.getMainServer().getMethodManager().callMethodInternal.call(ResolveIOServer.getMainServer().getMethodManager(), 'insertSubscriptionLog', type, sub.publication, collection, JSON.stringify(sub.subscriptionData));\n\n\t\t\tlet res = await this._publications[sub.publication].function.call(Object.assign({}, this, SubscriptionManager.prototype), ws['id_user'], ...sub.subscriptionData);\n\t\t\tthis._monitorManagerFunction.finishMonitorFunction(monitor);\n\n\t\t\tlet serverRes: ServerResponseModel = {\n\t\t\t\tmessageId: messageId,\n\t\t\t\thasError: false,\n\t\t\t\tdata: res\n\t\t\t};\n\n\t\t\tthis.sendWS(ws, serverRes);\n\t\t}\n\t\tcatch (err) {\n\t\t\tthis._monitorManagerFunction.finishMonitorFunction(monitor);\n\n\t\t\tlet serverRes: ServerResponseModel = {\n\t\t\t\tmessageId: messageId,\n\t\t\t\thasError: true,\n\t\t\t\tdata: err\n\t\t\t};\n\n\t\t\tthis.sendWS(ws, serverRes);\n\n\t\t\tResolveIOServer.getMainServer().getMethodManager().sendEmail('dev@resolveio.com', 'SERVER - Error Detected - ' + this.serverConfig['CLIENT_NAME'], 'Error Detected During Subscription ' + sub.publication + ' - (sendDataToOne - WS)\\n\\nData \\n' + JSON.stringify(sub.subscriptionData, null, 2) + '\\n\\nErrors\\n' + JSON.stringify(err, null, 2));\n\t\t}\n\t}\n\n\t// Fetch pub once, send to all clients linked to this pub\n\tprivate async sendDataToAll(sub: ActiveSubscriptionModel, collection: string, type: string) {\n\t\tif (!sub.clients.length) {\n\t\t\tif (sub.cacheId) {\n\t\t\t\tthis._nodeCache.del(sub.cacheId);\n\t\t\t\tsub.cacheId = 0;\n\t\t\t}\n\n\t\t\tlet subIndex = this._subscriptions.findIndex(a => a.publication === sub.publication && JSON.stringify(a.subscriptionData) === JSON.stringify(sub.subscriptionData));\n\t\t\tif (subIndex >= 0) {\n\t\t\t\tthis._subscriptions.splice(subIndex, 1);\n\t\t\t}\n\n\t\t\treturn;\n\t\t}\n\t\telse {\n\t\t\tlet monitor = this._monitorManagerFunction.startMonitorFunction('Publication', sub.publication, '', '', sub.subscriptionData);\n\n\t\t\ttry {\n\t\t\t\tif (sub.publication !== 'superadminAPM' && sub.publication !== 'loggedInUsers') {\n\t\t\t\t\tResolveIOServer.getMainServer().getMethodManager().callMethodInternal.call(ResolveIOServer.getMainServer().getMethodManager(), 'insertSubscriptionLog', type, sub.publication, collection, JSON.stringify(sub.subscriptionData));\n\t\t\t\t}\n\n\t\t\t\tlet res = await this._publications[sub.publication].function.call(Object.assign({}, this, SubscriptionManager.prototype), ...sub.subscriptionData);\n\t\t\t\tthis._monitorManagerFunction.finishMonitorFunction(monitor);\n\n\t\t\t\tif (sub.cacheId) {\n\t\t\t\t\ttry {\n\t\t\t\t\t\tlet cacheData = JSON.parse(this._nodeCache.get(sub.cacheId), dateReviver);\n\t\n\t\t\t\t\t\tif (JSON.stringify(cacheData) !== JSON.stringify(res)) {\n\t\t\t\t\t\t\tPromise.all(\n\t\t\t\t\t\t\t\tsub.clients.map(async client => {\n\t\t\t\t\t\t\t\t\tlet ws = this._websocketManager.getWebSocket(client.id_socket);\n\t\t\t\t\t\t\t\t\tif (ws && ws.readyState === ws.OPEN) {\n\t\t\t\t\t\t\t\t\t\tlet serverRes: ServerResponseModel = {\n\t\t\t\t\t\t\t\t\t\t\tmessageId: client.messageId,\n\t\t\t\t\t\t\t\t\t\t\thasError: false,\n\t\t\t\t\t\t\t\t\t\t\tdata: res\n\t\t\t\t\t\t\t\t\t\t};\n\t\t\t\n\t\t\t\t\t\t\t\t\t\tthis.sendWS(ws, serverRes);\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\n\t\t\t\t\t\t\tthis._nodeCache.del(sub.cacheId);\n\n\t\t\t\t\t\t\tif (getBinarySize(JSON.stringify(res)) < 1000000 && \n\t\t\t\t\t\t\t\t!sub.collections.includes('logs') &&\n\t\t\t\t\t\t\t\t!sub.collections.includes('log-method-latencies') &&\n\t\t\t\t\t\t\t\t!sub.collections.includes('log-subscriptions') &&\n\t\t\t\t\t\t\t\t!sub.collections.find(a => a.endsWith('.versions')) &&\n\t\t\t\t\t\t\t\t!sub.collections.find(a => a.startsWith('monitor-'))\n\t\t\t\t\t\t\t) {\n\t\t\t\t\t\t\t\tthis._nodeCache.set(sub.cacheId, JSON.stringify(res));\n\t\t\t\t\t\t\t}\n\t\t\t\t\t\t\telse {\n\t\t\t\t\t\t\t\tsub.cacheId = 0;\n\t\t\t\t\t\t\t}\n\t\t\t\t\t\t}\n\t\t\t\t\t}\n\t\t\t\t\tcatch (err) {\n\t\t\t\t\t\tPromise.all(\n\t\t\t\t\t\t\tsub.clients.map(async client => {\n\t\t\t\t\t\t\t\tlet ws = this._websocketManager.getWebSocket(client.id_socket);\n\t\t\t\t\t\t\t\tif (ws && ws.readyState === ws.OPEN) {\n\t\t\t\t\t\t\t\t\tlet serverRes: ServerResponseModel = {\n\t\t\t\t\t\t\t\t\t\tmessageId: client.messageId,\n\t\t\t\t\t\t\t\t\t\thasError: false,\n\t\t\t\t\t\t\t\t\t\tdata: res\n\t\t\t\t\t\t\t\t\t};\n\t\t\n\t\t\t\t\t\t\t\t\tthis.sendWS(ws, serverRes);\n\t\t\t\t\t\t\t\t}\n\t\t\t\t\t\t\t})\n\t\t\t\t\t\t);\n\n\t\t\t\t\t\tthis._nodeCache.del(sub.cacheId);\n\n\t\t\t\t\t\tif (getBinarySize(JSON.stringify(res)) < 1000000 && \n\t\t\t\t\t\t\t!sub.collections.includes('logs') &&\n\t\t\t\t\t\t\t!sub.collections.includes('log-method-latencies') &&\n\t\t\t\t\t\t\t!sub.collections.includes('log-subscriptions') &&\n\t\t\t\t\t\t\t!sub.collections.find(a => a.endsWith('.versions')) &&\n\t\t\t\t\t\t\t!sub.collections.find(a => a.startsWith('monitor-'))\n\t\t\t\t\t\t) {\n\t\t\t\t\t\t\tthis._nodeCache.set(sub.cacheId, JSON.stringify(res));\n\t\t\t\t\t\t}\n\t\t\t\t\t\telse {\n\t\t\t\t\t\t\tsub.cacheId = 0;\n\t\t\t\t\t\t}\n\t\t\t\t\t}\n\t\t\t\t}\n\t\t\t\telse {\n\t\t\t\t\tPromise.all(\n\t\t\t\t\t\tsub.clients.map(async client => {\n\t\t\t\t\t\t\tlet ws = this._websocketManager.getWebSocket(client.id_socket);\n\t\t\t\t\t\t\tif (ws && ws.readyState === ws.OPEN) {\n\t\t\t\t\t\t\t\tlet serverRes: ServerResponseModel = {\n\t\t\t\t\t\t\t\t\tmessageId: client.messageId,\n\t\t\t\t\t\t\t\t\thasError: false,\n\t\t\t\t\t\t\t\t\tdata: res\n\t\t\t\t\t\t\t\t};\n\t\n\t\t\t\t\t\t\t\tthis.sendWS(ws, serverRes);\n\t\t\t\t\t\t\t}\n\t\t\t\t\t\t})\n\t\t\t\t\t);\n\t\t\t\t\t\n\t\t\t\t\tif (getBinarySize(JSON.stringify(res)) < 1000000 && \n\t\t\t\t\t\t!sub.collections.includes('logs') &&\n\t\t\t\t\t\t!sub.collections.includes('log-method-latencies') &&\n\t\t\t\t\t\t!sub.collections.includes('log-subscriptions') &&\n\t\t\t\t\t\t!sub.collections.find(a => a.endsWith('.versions')) &&\n\t\t\t\t\t\t!sub.collections.find(a => a.startsWith('monitor-'))\n\t\t\t\t\t) {\n\t\t\t\t\t\tsub.cacheId = this._cacheId++;\n\t\t\t\t\t\tthis._nodeCache.set(sub.cacheId, JSON.stringify(res));\n\n\t\t\t\t\t\tconst nodeCacheSize = this._nodeCache.getStats().vsize;\n\n\t\t\t\t\t\tif (nodeCacheSize > this._heapLimit) {\n\t\t\t\t\t\t\t// Evict cache entries as needed\n\t\t\t\t\t\t\tlet deleteCount = 0;\n\t\t\t\t\t\t\tconst subArr = this._subscriptions.filter(a => a.cacheId && !a.clients.length);\n\t\t\t\t\t\n\t\t\t\t\t\t\tfor (let zz = 0; zz < subArr.length; zz++) {\n\t\t\t\t\t\t\t\tthis._debugRemoveCacheHits += 1;\n\t\t\t\t\t\t\t\tthis._nodeCache.del(subArr[zz].cacheId);\n\t\t\t\t\t\t\t\tsubArr[zz].cacheId = 0;\n\t\t\t\t\t\t\t\tdeleteCount += 1;\n\t\t\t\t\t\t\t\tif (this._nodeCache.getStats().vsize < this._heapLimit * 0.75) {\n\t\t\t\t\t\t\t\t\tbreak;\n\t\t\t\t\t\t\t\t}\n\t\t\t\t\t\t\t}\n\n\t\t\t\t\t\t\tif (this._enableDebug) {\n\t\t\t\t\t\t\t\tconsole.log(\n\t\t\t\t\t\t\t\t\t'Sub Cache: ' +\n\t\t\t\t\t\t\t\t\t'Too Big - ' +\n\t\t\t\t\t\t\t\t\tsub.publication +\n\t\t\t\t\t\t\t\t\t' - Deleted: ' +\n\t\t\t\t\t\t\t\t\tdeleteCount +\n\t\t\t\t\t\t\t\t\t' - ' +\n\t\t\t\t\t\t\t\t\tnodeCacheSize\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\tsub.cacheId = 0;\n\t\t\t\t\t}\n\t\t\t\t}\n\t\t\t}\n\t\t\tcatch (err) {\n\t\t\t\tthis._monitorManagerFunction.finishMonitorFunction(monitor);\n\n\t\t\t\tPromise.all(\n\t\t\t\t\tsub.clients.map(async client => {\n\t\t\t\t\t\tlet ws = this._websocketManager.getWebSocket(client.id_socket);\n\t\t\t\t\t\tif (ws && ws.readyState === ws.OPEN) {\n\t\t\t\t\t\t\tlet serverRes: ServerResponseModel = {\n\t\t\t\t\t\t\t\tmessageId: client.messageId,\n\t\t\t\t\t\t\t\thasError: true,\n\t\t\t\t\t\t\t\tdata: err\n\t\t\t\t\t\t\t};\n\n\t\t\t\t\t\t\tthis.sendWS(ws, serverRes);\n\t\t\t\t\t\t}\n\t\t\t\t\t})\n\t\t\t\t);\n\n\t\t\t\tResolveIOServer.getMainServer().getMethodManager().sendEmail('dev@resolveio.com', 'SERVER - Error Detected - ' + this.serverConfig['CLIENT_NAME'], 'Error Detected During Subscription ' + sub.publication + ' - (sendPubData)\\n\\nData \\n' + JSON.stringify(sub.subscriptionData, null, 2) + '\\n\\nErrors\\n' + JSON.stringify(err, null, 2));\n\t\t\t}\n\t\t}\n\t}\n\n\tprivate sendWS(ws: WebSocket, data: ServerResponseModel) {\n\t\tthis._websocketManager.send(ws, data);\n\t}\n\n\tpublic getEnableDebug() {\n\t\treturn this._enableDebug;\n\t}\n}\n"]}
|
|
1
|
+
{"version":3,"sources":["../../src/managers/subscription.manager.ts"],"names":["logs_1","require","app_status_1","files_1","super_admin_1","logged_in_users_collection_1","cron_jobs_1","flags_1","method_responses_1","resolveio_server_app_1","notifications_1","report_builder_reports_1","report_builder_libraries_1","user_groups_1","user_guides_1","report_builder_dashboard_builders_1","common_1","NodeCache","flag_collection_1","os_1","flags_update_1","numCPUs","cpus","length","v8","SubscriptionManager","wss","serverConfig","monitorManagerFunction","_this","this","_publications","_subscriptions","_loggedInUsers","_mongoQueue","_mongoQueueId","_cacheId","_heapSize","getHeapStatistics","_enableDebug","_debugOplogCollections","_debugOplogHits","_debugSubCollections","_debugSubHits","_debugUnSubHits","_debugUnSubAllHits","_debugMongoQueueHits","_debugMongoQueueCollections","_debugSendQueueHits","_debugRemoveCacheHits","_oplogRetryCount","latencyBuffer","Map","LATENCY_UPDATE_INTERVAL","LATENCY_UPDATE_THRESHOLD_MS","_websocketManager","ResolveIOServer","getMainServer","getWebSocketManager","_monitorManagerFunction","_nodeCache","stdTTL","checkperiod","setInterval","flushThrottledLatencyUpdates","_wss","loadSuperAdminPublications","loadAppStatusPublications","loadLogPublications","loadFilePublications","loadCronJobPublications","loadFlagsUpdatePublications","loadFlagsPublications","loadMethodResponsePublications","loadNotificationPublications","loadReportBuilderReportPublications","loadReportBuilderLibraryPublications","loadUserGroupPublications","loadUserGuidePublications","loadReportBuilderDashboardBuilderPublications","tailOpLog","getEnableDebug","console","log","Date","JSON","stringify","sort","a","b","collection","localeCompare","publication","type","__awaiter","_a","LoggedInUsers","find","_b","sent","userCopy","deepCopy","i","loggedInUser","date","now","getTime","this_1","getWebSocket","id_ws","unsubscribeAll","forEach","sub","j","clients","id_socket","splice","deleteOne","_id","findIndex","client","this_2","some","Flags","findOne","then","flag","value","setCacheLimit","prototype","process","env","IS_WORKERS_ENABLED","_heapLimit","invalidatePubsCache","getMongoManager","invalidateQueryCache","collSubs","filter","collections","includes","this_3","running","runAgain","user_specific","Promise","all","map","ws","readyState","OPEN","sendDataToOneWithRetry","messageId","err","getMethodManager","sendEmail","id_user","sendDataToAllWithRetry","collSubs_1","__values","collSubs_1_1","next","done","delay","ms","resolve","setTimeout","sendDataToAll","sendDataToOne","publications","method","Object","assign","loggedInLatency","existingEntry","newLatency","get","lastUpdate","Math","abs","latency","set","size","updates","Array","from","entries","__read","_c","updateOne","update","$set","bulkWrite","clear","error","error_1","subscribe","messageRoute","messageDate","subscriptionData","pub","hits","push","check","_schema","valObj","rootKeys","keys","validate","errors","urlData","split","urlModule_1","urlNext","otherRouteSubs","startsWith","otherSub","unsubscribe","getPublicationCollections","cacheId","processSubscription","createLoggedInUser","reject","user","objectIdHexString","__v","insertOne","indexOf","userSubs","removeWebSocket","getActiveSubscriptions","resumeToken","_oplog$","closed","removeAllListeners","close","exit","pipeline","$match","$and","ns.coll","$nin","$not","lastResumeToken_1","getMainDB","watch","resumeAfter","errOp","on","doc","ns","coll","operationType","callMethod","call","documentKey","NODE_APP_INSTANCE","IS_WORKER_INSTANCE","WORKER_INDEX","cacheData","parse","dateReviver","serverRes","hasError","data","sendWS","del","monitor","startMonitorFunction","function","apply","__spreadArray","res","finishMonitorFunction","err_1","subIndex","res_1","getBinarySize","endsWith","nodeCacheSize","getStats","vsize","deleteCount","subArr","zz","err_2","send","exports"],"mappings":"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","file":"subscription.manager.js","sourcesContent":["import { ServerResponseModel } from '../models/server-response.model';\nimport { ActiveSubscriptionModel, SubscriptionModel } from '../models/subscription.model';\nimport * as WebSocket from 'ws';\nimport { loadLogPublications } from '../publications/logs';\nimport { loadAppStatusPublications } from '../publications/app-status';\nimport { loadFilePublications } from '../publications/files';\nimport { loadSuperAdminPublications } from '../publications/super-admin';\nimport { LoggedInUsers } from '../collections/logged-in-users.collection';\nimport { loadCronJobPublications } from '../publications/cron-jobs';\nimport { loadFlagsPublications } from '../publications/flags';\nimport { loadMethodResponsePublications } from '../publications/method-responses';\nimport { ResolveIOServer } from '../resolveio-server-app';\nimport { loadNotificationPublications } from '../publications/notifications';\nimport { loadReportBuilderReportPublications } from '../publications/report-builder-reports';\nimport { LoggedInUserModel } from '../models/logged-in-users.model';\n\nimport { ChangeStream, ChangeStreamDeleteDocument, ChangeStreamInsertDocument, ChangeStreamReplaceDocument, ChangeStreamUpdateDocument, ResumeToken } from 'mongodb';\nimport { loadReportBuilderLibraryPublications } from '../publications/report-builder-libraries';\nimport { loadUserGroupPublications } from '../publications/user-groups';\nimport { loadUserGuidePublications } from '../publications/user-guides';\nimport { loadReportBuilderDashboardBuilderPublications } from '../publications/report-builder-dashboard-builders';\nimport { dateReviver, deepCopy, getBinarySize, objectIdHexString } from '../util/common';\nimport * as NodeCache from 'node-cache';\nimport { MonitorManagerFunction } from './monitor.manager';\nimport { Flags } from '../collections/flag.collection';\nimport { cpus } from 'os';\nimport { WebSocketManager } from './websocket.manager';\nimport { loadFlagsUpdatePublications } from '../publications/flags-update';\nconst numCPUs = cpus().length;\nconst v8 = require('v8');\n\n// Performance Dependencies\n// import * as path from 'path';\n// import { Worker } from 'worker_threads';\n\ninterface MongoQueueModel {\n\t_id: number,\n\ttype: string;\n\tcollection: string;\n\tsubscription: ActiveSubscriptionModel;\n\trunning: boolean;\n\trun_again: boolean;\n}\n\n// interface CurrentPerformanceMonitor {\n// \t_id: number;\n// \tfunction: string;\n// \tpublication: string;\n// \tsubscriptionData: any[];\n// \tdate_start: Date;\n// \tdate_end: Date;\n// \tduration: number;\n// \tresult: string;\n// }\n\nexport class SubscriptionManager {\n\tprivate _websocketManager: WebSocketManager;\n\tprivate _publications: SubscriptionModel = {};\n\tprivate _subscriptions: ActiveSubscriptionModel[] = [];\n\tprivate _wss: WebSocket.Server;\n\tprivate _loggedInUsers: LoggedInUserModel[] = [];\n\n\tprivate _mongoQueue: MongoQueueModel[] = [];\n\tprivate _mongoQueueId = 0;\n\t\n\tprivate _oplog$: ChangeStream;\n\n\tprivate _nodeCache;\n\tprivate _cacheId = 1;\n\n\tprivate _heapSize = v8.getHeapStatistics() / numCPUs;\n\tprivate _heapLimit: number;\n\n\tprivate serverConfig;\n\n\tprivate _monitorManagerFunction: MonitorManagerFunction;\n\n\tprivate _enableDebug = false;\n\tprivate _debugOplogCollections = [];\n\tprivate _debugOplogHits = 0;\n\tprivate _debugSubCollections = [];\n\tprivate _debugSubHits = 0;\n\tprivate _debugUnSubHits = 0;\n\tprivate _debugUnSubAllHits = 0;\n\tprivate _debugMongoQueueHits = 0;\n\tprivate _debugMongoQueueCollections = [];\n\tprivate _debugSendQueueHits = 0;\n\tprivate _debugRemoveCacheHits = 0;\n\n\tprivate _oplogRetryCount = 0;\n\n\t// Buffer to store throttled latency updates with timestamps\n\tprivate latencyBuffer = new Map<string, { latency: number, lastUpdate: Date }>();\n\n\t// Interval to flush latency updates in MongoDB\n\tprivate readonly LATENCY_UPDATE_INTERVAL = 60000;\n\n\t// Minimum time difference between two latency updates for the same user\n\tprivate readonly LATENCY_UPDATE_THRESHOLD_MS = 30000;\n\n\t// private currentPerfomanceMonitor: CurrentPerformanceMonitor[] = [];\n\t// private idPerformance: number = 0;\n\t// private performanceThread;\n\n\tconstructor(wss: WebSocket.Server, serverConfig, monitorManagerFunction: MonitorManagerFunction) {\n\t\tthis._websocketManager = ResolveIOServer.getMainServer().getWebSocketManager();\n\t\tthis._monitorManagerFunction = monitorManagerFunction;\n\n\t\tthis._nodeCache = new NodeCache( { stdTTL: 0, checkperiod: 0 } );\n\n\t\tsetInterval(() => this.flushThrottledLatencyUpdates(), this.LATENCY_UPDATE_INTERVAL);\n\n\t\t// setTimeout(() => {\n\t\t// \tconsole.log('Setting up performance thread');\n\n\t\t// \tthis.performanceThread = new Worker(path.join(__dirname, './subscription.performance.js'));\n\n\t\t// \tthis.performanceThread.on('exit', code => {\n\t\t// \t\tconsole.error(new Date(), 'THREAD EXITED!!!!!!!!!!!!!!!!!!', code);\n\t\t// \t});\n\n\t\t// \tthis.performanceThread.on('error', code => {\n\t\t// \t\tconsole.error(new Date(), 'THREAD RECV ERROR !!!!!!!!!!!!!!!!!!', code);\n\t\t// \t});\n\t\t// }, 5000);\n\n\t\t// setInterval(() => {\n\t\t// \tconsole.log('Post thread msg');\n\t\t// \tthis.performanceThread.postMessage(this.currentPerfomanceMonitor);\n\t\t// \tthis.currentPerfomanceMonitor = [];\n\t\t// }, 10000);\n\n\t\tthis.serverConfig = serverConfig;\n\t\tthis._wss = wss;\n\n\t\t// Publications\n\t\tloadSuperAdminPublications(this);\n\t\tloadAppStatusPublications(this);\n\t\tloadLogPublications(this);\n\t\tloadFilePublications(this);\n\t\tloadCronJobPublications(this);\n\t\tloadFlagsUpdatePublications(this);\n\t\tloadFlagsPublications(this);\n\t\tloadMethodResponsePublications(this);\n\t\tloadNotificationPublications(this);\n\t\tloadReportBuilderReportPublications(this);\n\t\tloadReportBuilderLibraryPublications(this);\n\t\tloadUserGroupPublications(this);\n\t\tloadUserGuidePublications(this);\n\t\tloadReportBuilderDashboardBuilderPublications(this);\n\n\t\tthis.tailOpLog();\n\n\t\tsetInterval(() => {\n\t\t\tthis._oplogRetryCount = 0;\n\t\t}, 15000);\n\n\t\tsetInterval(() => {\n\t\t\tif (this.getEnableDebug()) {\n\t\t\t\tconsole.log(new Date(), 'Sub Manager', 'Subs', this._subscriptions.length);\n\t\t\t\tconsole.log(new Date(), 'Sub Manager', 'Logged In Users', this._loggedInUsers.length);\n\t\t\t\tconsole.log(new Date(), 'Sub Manager', 'Mongo Queue', this._mongoQueue.length);\n\t\t\t\tconsole.log(new Date(), 'Sub Manager', 'Mongo Queue Hits', this._debugMongoQueueHits);\n\t\t\t\tconsole.log(new Date(), 'Sub Manager', 'Mongo Queue Collections', JSON.stringify(this._debugMongoQueueCollections.sort((a, b) => a.collection.localeCompare(b.collection) || a.publication.localeCompare(b.publication)), null, 2));\n\t\t\t\tconsole.log(new Date(), 'Sub Manager', 'Oplog Hits', this._debugOplogHits);\n\t\t\t\tconsole.log(new Date(), 'Sub Manager', 'Oplog Collections', JSON.stringify(this._debugOplogCollections.sort((a, b) => a.collection.localeCompare(b.collection) || a.type.localeCompare(b.type)), null, 2));\n\t\t\t\tconsole.log(new Date(), 'Sub Manager', 'Send Queue Hits', this._debugSendQueueHits);\n\t\t\t\tconsole.log(new Date(), 'Sub Manager', 'Sub Hits', this._debugSubHits);\n\t\t\t\tconsole.log(new Date(), 'Sub Manager', 'Sub Collections', JSON.stringify(this._debugSubCollections.sort((a, b) => a.publication.localeCompare(b.publication)), null, 2));\n\t\t\t\tconsole.log(new Date(), 'Sub Manager', 'Unsub Hits', this._debugUnSubHits);\n\t\t\t\tconsole.log(new Date(), 'Sub Manager', 'Unsub All Hits', this._debugUnSubAllHits);\n\t\t\t\tconsole.log(new Date(), 'Sub Manager', 'Cache Cleanup Hits', this._debugRemoveCacheHits);\n\t\t\t}\n\t\t\t\n\t\t\tthis._debugOplogHits = 0;\n\t\t\tthis._debugOplogCollections = [];\n\t\t\tthis._debugSubCollections = [];\n\t\t\tthis._debugMongoQueueHits = 0;\n\t\t\tthis._debugMongoQueueCollections = [];\n\t\t\tthis._debugSendQueueHits = 0;\n\t\t\tthis._debugSubHits = 0;\n\t\t\tthis._debugUnSubHits = 0;\n\t\t\tthis._debugUnSubAllHits = 0;\n\t\t\tthis._debugRemoveCacheHits = 0;\n\t\t}, 60000);\n\n\t\tsetInterval(async () => {\n\t\t\tthis._loggedInUsers = await LoggedInUsers.find();\n\t\n\t\t\tlet userCopy = deepCopy(this._loggedInUsers);\n\t\t\tfor (let i = this._loggedInUsers.length - 1; i >= 0; i--) {\n\t\t\t\tlet loggedInUser = userCopy[i];\n\n\t\t\t\tif (!loggedInUser.date || Date.now() - loggedInUser.date.getTime() > 120000) {\n\t\t\t\t\tif (this._websocketManager.getWebSocket(loggedInUser.id_ws)) {\n\t\t\t\t\t\tif (this.getEnableDebug()) {\n\t\t\t\t\t\t\tconsole.log(new Date(), 'Sub Manager', 'Unsub WS', this._websocketManager.getWebSocket(loggedInUser.id_ws)['user'], this._websocketManager.getWebSocket(loggedInUser.id_ws)['id_socket'], 2);\n\t\t\t\t\t\t}\n\t\t\t\t\t\tthis.unsubscribeAll(this._websocketManager.getWebSocket(loggedInUser.id_ws));\n\t\t\t\t\t}\n\t\t\t\t\telse {\n\t\t\t\t\t\tthis._subscriptions.forEach(sub => {\n\t\t\t\t\t\t\tfor (let j = sub.clients.length - 1; j >= 0; j--) {\n\t\t\t\t\t\t\t\tlet client = sub.clients[j];\n\n\t\t\t\t\t\t\t\tif (client.id_socket === loggedInUser.id_ws) {\n\t\t\t\t\t\t\t\t\tsub.clients.splice(j, 1);\n\t\t\t\t\t\t\t\t}\n\t\t\t\t\t\t\t}\n\t\t\t\t\t\t});\n\n\t\t\t\t\t\tLoggedInUsers.deleteOne({_id: loggedInUser._id});\n\n\t\t\t\t\t\tif (this._loggedInUsers.findIndex(a => a._id === loggedInUser._id) >= 0) {\n\t\t\t\t\t\t\tthis._loggedInUsers.splice(this._loggedInUsers.findIndex(a => a._id === loggedInUser._id), 1);\n\t\t\t\t\t\t}\n\t\t\t\t\t}\n\t\t\t\t}\n\t\t\t}\n\n\t\t\tfor (let i = 0; i < this._subscriptions.length; i++) {\n\t\t\t\tlet sub = this._subscriptions[i];\n\n\t\t\t\tfor (let j = sub.clients.length - 1; j >= 0; j--) {\n\t\t\t\t\tlet client = sub.clients[j];\n\n\t\t\t\t\tif (!this._loggedInUsers.some(a => a.id_ws === client.id_socket)) {\n\t\t\t\t\t\tsub.clients.splice(j, 1);\n\t\t\t\t\t}\n\t\t\t\t}\n\t\t\t}\n\t\t}, 30000);\n\n\t\tFlags.findOne({type: 'Enable Debug'}).then(flag => {\n\t\t\tif (flag && flag.value) {\n\t\t\t\tthis._enableDebug = true;\n\t\t\t}\n\t\t\telse {\n\t\t\t\tthis._enableDebug = false;\n\t\t\t}\n\t\t});\n\n\t\tthis.setCacheLimit();\n\t}\n\n\tprivate setCacheLimit() {\t\n\t\tif (process.env.IS_WORKERS_ENABLED === 'true') {\n\t\t\tthis._heapLimit = this._heapSize * 0.4;\n\t\t}\n\t\telse {\n\t\t\tthis._heapLimit = this._heapSize * 0.3; // Use 50% of total heap size\n\t\t}\n\t}\n\n\tpublic async invalidatePubsCache(collection: string, type: string) {\n\t\tResolveIOServer.getMongoManager().invalidateQueryCache(collection);\n\n\t\tlet collSubs = this._subscriptions.filter(a => a.collections.includes(collection));\n\n\t\tfor (let sub of collSubs) {\n\t\t\tif (this._enableDebug) {\n\t\t\t\tconsole.log(new Date(), 'Invalidate Sub', sub.publication, sub.running, sub.runAgain);\n\t\t\t}\n\n\t\t\tif (sub.running) {\n\t\t\t\tsub.runAgain = true;\n\t\t\t\tcontinue;\n\t\t\t}\n\n\t\t\tif (this._publications[sub.publication].user_specific) {\n\t\t\t\tPromise.all(\n\t\t\t\t\tsub.clients.map(async client => {\n\t\t\t\t\t\tlet ws = this._websocketManager.getWebSocket(client.id_socket);\n\t\t\t\t\t\tif (ws && ws.readyState === ws.OPEN) {\n\t\t\t\t\t\t\ttry {\n\t\t\t\t\t\t\t\tthis.sendDataToOneWithRetry(ws, client.messageId, sub, collection, type);\n\t\t\t\t\t\t\t} catch (err) {\n\t\t\t\t\t\t\t\t// Handle error\n\t\t\t\t\t\t\t\tResolveIOServer.getMainServer().getMethodManager().sendEmail('dev@resolveio.com', 'SERVER - Error Detected - ' + this.serverConfig['CLIENT_NAME'], 'Error Detected During sendDataToOne - User Specific - Socket: ' + client.id_socket + ', User: ' + client.id_user + ', MessageId: ' + client.messageId + ', Pub: ' + sub.publication + ', Err: ' + JSON.stringify(err, null, 2));\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\telse {\n\t\t\t\tthis.sendDataToAllWithRetry(sub, collection, type);\n\t\t\t}\n\t\t}\n\t}\n\n\tprivate async delay(ms: number) {\n\t\treturn new Promise(resolve => setTimeout(resolve, ms));\n\t}\n\n\tprivate async sendDataToAllWithRetry(sub: ActiveSubscriptionModel, collection: string, type: string) {\n\t\tsub.running = true;\n\n\t\tdo {\n\t\t\tif (this._enableDebug) {\n\t\t\t\tconsole.log(new Date(), 'Running sendDataToAll Sub', sub.publication);\n\t\t\t}\n\n\t\t\tsub.runAgain = false;\n\t\t\tawait this.sendDataToAll(sub, collection, type);\n\n\t\t\tif (this._enableDebug) {\n\t\t\t\tconsole.log(new Date(), 'Done sendDataToAll Sub', sub.publication, sub.runAgain);\n\t\t\t}\n\n\t\t\tif (sub.runAgain) {\n\t\t\t\tawait this.delay(500); // delay, adjust as needed\n\t\t\t}\n\t\t} while (sub.runAgain);\n\n\t\tsub.running = false;\n\t}\n\n\tprivate async sendDataToOneWithRetry(ws: WebSocket, messageId: number, sub: ActiveSubscriptionModel, collection: string, type: string) {\n\t\tsub.running = true;\n\n\t\tdo {\n\t\t\tif (this._enableDebug) {\n\t\t\t\tconsole.log(new Date(), 'Running sendDataToOne Sub', sub.publication);\n\t\t\t}\n\n\t\t\tsub.runAgain = false;\n\t\t\tawait this.sendDataToOne(ws, messageId, sub, collection, type);\n\n\t\t\tif (this._enableDebug) {\n\t\t\t\tconsole.log(new Date(), 'Done sendDataToOne Sub', sub.publication, sub.runAgain);\n\t\t\t}\n\n\t\t\tif (sub.runAgain) {\n\t\t\t\tawait this.delay(500); // delay, adjust as needed\n\t\t\t}\n\t\t} while (sub.runAgain);\n\t\tsub.running = false;\n\t}\n\n\t// Add all files to publications private object\n\tpublic publications(method: SubscriptionModel) {\n\t\tthis._publications = Object.assign(this._publications, method);\n\t}\n\n\t// Throttled `loggedInLatency` method\n\tpublic loggedInLatency(ws: WebSocket) {\n\t\tlet loggedInUser = this._loggedInUsers.find(a => a.id_ws === ws['id_socket']);\n\t\tif (!loggedInUser) return;\n\n\t\tconst now = new Date();\n\t\tconst existingEntry = this.latencyBuffer.get(ws['id_socket']);\n\t\tconst newLatency = ws['latency'];\n\n\t\t// Throttle updates: only update if time threshold has passed or latency has significantly changed\n\t\tif (\n\t\t\t!existingEntry || \n\t\t\t(now.getTime() - existingEntry.lastUpdate.getTime() >= this.LATENCY_UPDATE_THRESHOLD_MS) || \n\t\t\t(Math.abs(newLatency - existingEntry.latency) > 100) // Optional: log only significant changes\n\t\t) {\n\t\t\t// Update in-memory and buffer\n\t\t\tloggedInUser.date = now;\n\t\t\tthis.latencyBuffer.set(ws['id_socket'], { latency: newLatency, lastUpdate: now });\n\t\t}\n\t}\n\n\t// Method to flush buffered latency updates in bulk\n\tprivate async flushThrottledLatencyUpdates() {\n\t\tif (this.latencyBuffer.size === 0) return; // No updates to flush\n\n\t\tconst updates = Array.from(this.latencyBuffer.entries()).map(([id_ws, { latency, lastUpdate }]) => ({\n\t\t\tupdateOne: {\n\t\t\t\tfilter: { id_ws },\n\t\t\t\tupdate: { $set: { latency, date: lastUpdate } }\n\t\t\t}\n\t\t}));\n\n\t\ttry {\n\t\t\tawait LoggedInUsers.bulkWrite(updates);\n\t\t\tthis.latencyBuffer.clear(); // Clear buffer after successful update\n\n\t\t\tif (this.getEnableDebug()) {\n\t\t\t\tconsole.log(new Date(), 'Sub Manager', 'Throttled latency batch update successful', updates.length);\n\t\t\t}\n\t\t}\n\t\tcatch (error) {\n\t\t\tconsole.error(new Date(), 'Sub Manager', 'Throttled latency batch update failed', error);\n\t\t\t// Optional: implement retry logic or logging for failed updates\n\t\t}\n\t}\n\n\t// Subscribe to publication\n\tpublic subscribe(messageRoute: string, messageDate: Date, ws: WebSocket, messageId: number, publication: string, subscriptionData: any[]) {\n\t\tthis._debugSubHits += 1;\n\n\t\tif (!this._debugSubCollections.some(a => a.publication === publication)) {\n\t\t\tthis._debugSubCollections.push({\n\t\t\t\tpublication: publication,\n\t\t\t\thits: 1\n\t\t\t});\n\t\t}\n\t\telse {\n\t\t\tthis._debugSubCollections.find(a => a.publication === publication).hits += 1;\n\t\t}\n\n\t\tlet pub = this._publications[publication];\n\n\t\tif (!pub) {\n\t\t\tconsole.error(new Date(), 'No Publication: ' + publication);\n\t\t\treturn;\n\t\t}\n\t\telse {\n\t\t\tif (subscriptionData.length > 1 || subscriptionData[0]) {\n\t\t\t\tif (!pub.check) {\n\t\t\t\t\tconsole.error(new Date(), 'No Check Function For Pub ' + publication);\n\t\t\t\t\treturn;\n\t\t\t\t}\n\t\t\t\telse if (!pub.check._schema) {\n\t\t\t\t\tconsole.error(new Date(), 'No Check Schema For Pub ' + publication);\n\t\t\t\t\treturn;\n\t\t\t\t}\n\t\t\t\telse {\n\t\t\t\t\tlet valObj = {};\n\t\t\t\t\tlet valKeys = Object.keys(pub.check._schema);\n\n\t\t\t\t\tlet rootKeys = valKeys.filter(a => !a.includes('.'));\n\n\t\t\t\t\tfor (let i = 0; i < subscriptionData.length; i++) {\n\t\t\t\t\t\tvalObj[rootKeys[i]] = subscriptionData[i];\n\t\t\t\t\t}\n\n\t\t\t\t\ttry {\n\t\t\t\t\t\tpub.check.validate(valObj);\n\t\t\t\t\t}\n\t\t\t\t\tcatch (errors) {\n\t\t\t\t\t\tif (errors) {\n\t\t\t\t\t\t\tconsole.error(new Date(), 'Error in Pub Check (' + publication + ')', errors);\n\t\t\t\t\t\t\treturn;\n\t\t\t\t\t\t}\n\t\t\t\t\t}\n\t\t\t\t}\n\t\t\t}\n\n\t\t\tif (messageRoute !== 'Bypass') {\n\t\t\t\tlet urlData = messageRoute.split('/');\n\t\t\t\tlet urlModule = '';\n\t\t\t\tlet urlNext = urlData[0];\n\n\t\t\t\tif (urlData[0] === '') {\n\t\t\t\t\turlModule = '/';\n\t\t\t\t\turlNext = urlData[1];\n\t\t\t\t}\n\n\t\t\t\turlModule += urlNext;\n\n\t\t\t\tif (urlData.length > 1) {\n\t\t\t\t\turlModule += '/';\n\t\t\t\t}\n\n\t\t\t\tlet otherRouteSubs = this._subscriptions.filter(a => a.clients.some(b => b.id_socket === ws['id_socket'] && b.messageRoute !== 'Bypass' && b.messageRoute !== '/' && b.messageRoute !== messageRoute && !b.messageRoute.startsWith(urlModule)));\n\n\t\t\t\tif (otherRouteSubs.length) {\n\t\t\t\t\tResolveIOServer.getMainServer().getMethodManager().sendEmail('dev@resolveio.com', 'SERVER - Detected Undestroyed Subscription - ' + this.serverConfig['CLIENT_NAME'], 'USER: ' + ws['user'] + ' (Socket: ' + ws['id_socket'] + ') ' + ' is on route: ' + messageRoute + ' but has the following subscriptions on other routes:' + JSON.stringify(otherRouteSubs, null, 2));\n\n\t\t\t\t\totherRouteSubs.forEach(otherSub => {\n\t\t\t\t\t\totherSub.clients.filter(a => a.id_socket === ws['id_socket']).forEach(client => {\n\t\t\t\t\t\t\tthis.unsubscribe(client.messageRoute, new Date(), ws, client.messageId, otherSub.publication, otherSub.subscriptionData);\n\t\t\t\t\t\t});\n\t\t\t\t\t});\n\t\t\t\t}\n\t\t\t}\n\n\t\t\tlet sub = this._subscriptions.find(a => a.publication === publication && JSON.stringify(a.subscriptionData) === JSON.stringify(subscriptionData));\n\n\t\t\t// If sub found (another user watching same data), add client to same sub\n\t\t\tif (sub) {\n\t\t\t\tif (!sub.clients.some(a => a.id_socket === ws['id_socket'] && a.messageId === messageId)) {\n\t\t\t\t\tsub.clients.push({\n\t\t\t\t\t\tid_user: ws['id_user'],\n\t\t\t\t\t\tmessageId: messageId,\n\t\t\t\t\t\tid_socket: ws['id_socket'],\n\t\t\t\t\t\tmessageRoute: messageRoute\n\t\t\t\t\t});\n\t\t\t\t}\n\t\t\t}\n\t\t\t// If sub not found, create new sub\n\t\t\telse {\n\t\t\t\tthis._subscriptions.push({\n\t\t\t\t\tpublication: publication,\n\t\t\t\t\tsubscriptionData: subscriptionData,\n\t\t\t\t\tcollections: this.getPublicationCollections(publication),\n\t\t\t\t\tclients: [{\n\t\t\t\t\t\tid_user: ws['id_user'],\n\t\t\t\t\t\tmessageId: messageId,\n\t\t\t\t\t\tid_socket: ws['id_socket'],\n\t\t\t\t\t\tmessageRoute: messageRoute,\n\t\t\t\t\t}],\n\t\t\t\t\tcacheId: 0,\n\t\t\t\t\trunning: false,\n\t\t\t\t\trunAgain: false\n\t\t\t\t});\n\t\t\t}\n\n\t\t\tif (!sub) {\n\t\t\t\tsub = this._subscriptions.find(a => a.publication === publication && JSON.stringify(a.subscriptionData) === JSON.stringify(subscriptionData));\n\t\t\t}\n\n\t\t\tif (this._enableDebug) {\n\t\t\t\tconsole.log(new Date(), 'New Sub', sub.publication, sub.running, sub.runAgain, sub.clients.length);\n\t\t\t}\n\n\t\t\t// Immediately send data to the new client\n\t\t\tthis.processSubscription(sub, ws, messageId);\n\t\t}\n\t}\n\n\tpublic async createLoggedInUser(id_ws: string): Promise<LoggedInUserModel> {\n\t\treturn new Promise(async (resolve, reject) => {\n\t\t\tlet ws = this._websocketManager.getWebSocket(id_ws);\n\n\t\t\tif (ws) {\n\t\t\t\tlet user = {\n\t\t\t\t\t_id: objectIdHexString(),\n\t\t\t\t\t__v: 0,\n\t\t\t\t\tdate: new Date(),\n\t\t\t\t\tid_user: 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\t\n\t\t\t\tthis._loggedInUsers.push(user);\n\t\t\t\tLoggedInUsers.insertOne(user);\n\t\t\t\t\n\t\t\t\tresolve(user);\n\t\t\t}\n\t\t\telse {\n\t\t\t\tresolve(null);\n\t\t\t}\n\t\t});\n\t}\n\n\t// Unsubscribe from publication \n\tpublic unsubscribe(messageRoute: string, messageDate: Date, ws: WebSocket, messageId: number, publication: string, subscriptionData: any[]) {\n\t\tthis._debugUnSubHits += 1;\n\n\t\tif (!this._publications[publication]) {\n\t\t\tconsole.log('No Publication: ' + publication);\n\t\t\treturn;\n\t\t}\n\t\telse {\n\t\t\tlet sub = this._subscriptions.find(a => a.publication === publication && JSON.stringify(a.subscriptionData) === JSON.stringify(subscriptionData));\n\n\t\t\tif (sub) {\n\t\t\t\tfor (let i = sub.clients.length - 1; i >= 0; i--) {\n\t\t\t\t\tif (sub.clients[i].id_user === ws['id_user'] && sub.clients[i].messageId === messageId && sub.clients[i].id_socket === ws['id_socket']) {\n\t\t\t\t\t\tsub.clients.splice(i, 1);\n\t\t\t\t\t}\n\t\t\t\t}\n\n\t\t\t\tif (this._enableDebug) {\n\t\t\t\t\tconsole.log(new Date(), 'Unsub', sub.publication, sub.running, sub.runAgain, sub.clients.length);\n\t\t\t\t}\n\t\t\t}\n\t\t}\n\t}\n\n\n\t// Unsubscribe from publication\n\tpublic async unsubscribeAll(ws: WebSocket) {\n\t\tthis._debugUnSubAllHits += 1;\n\n\t\tif (ws) {\n\t\t\t// Check if WebSocket has already been unsubscribed\n\t\t\tif (ws['isUnsubscribed']) {\n\t\t\t\treturn; // Skip if already unsubscribed\n\t\t\t}\n\t\t\t\n\t\t\t// Mark the WebSocket as unsubscribed to prevent further calls\n\t\t\tws['isUnsubscribed'] = true;\n\t\t\t\n\t\t\tif (this._loggedInUsers.map(a => a.id_ws).indexOf(ws['id_socket']) >= 0) {\n\t\t\t\tthis._loggedInUsers.splice(this._loggedInUsers.map(a => a.id_ws).indexOf(ws['id_socket']), 1);\n\t\t\t}\n\t\t\tLoggedInUsers.deleteOne({ id_ws: ws['id_socket'] });\n\n\t\t\tlet userSubs = this._subscriptions.filter(a => a.clients.some(b => b.id_user === ws['id_user'] && b.id_socket === ws['id_socket']));\n\n\t\t\tfor (let i = userSubs.length - 1; i >= 0; i--) {\n\t\t\t\tlet sub = userSubs[i];\n\n\t\t\t\tfor (let j = sub.clients.length - 1; j >= 0; j--) {\n\t\t\t\t\tif (sub.clients[j].id_socket === ws['id_socket']) {\n\t\t\t\t\t\tsub.clients.splice(j, 1);\n\t\t\t\t\t}\n\t\t\t\t}\n\t\t\t}\n\n\t\t\tthis._websocketManager.removeWebSocket(ws);\n\t\t}\n\t}\n\n\tpublic getActiveSubscriptions() {\n\t\treturn this._subscriptions;\n\t}\n\n\t// Get publication collection\n\tprivate getPublicationCollections(publication: string) {\n\t\treturn this._publications[publication].collections;\n\t}\n\n\t// Watch (tail) Mongo's operation log on the entire database (all insert/modify/delete will trigger this function)\n\tprivate async tailOpLog(resumeToken?: ResumeToken) {\n\t\tif (this._oplog$ && !this._oplog$.closed) {\n\t\t\tthis._oplog$.removeAllListeners();\n\t\t\tthis._oplog$.close();\n\t\t\tthis._oplog$ = null;\n\t\t}\n\n\t\tawait new Promise(resolve => setTimeout(resolve, 1000));\n\n\t\tif (!this._oplog$ || this._oplog$.closed) {\n\t\t\tthis._oplogRetryCount += 1;\n\n\t\t\tif (this._oplogRetryCount > 5) {\n\t\t\t\tconsole.error('****************** TAIL OPLOG ERROR, RETRYING A BUNCH OF TIMES, KILLING PROCESS **************************');\n\t\t\t\tprocess.exit(1);\n\t\t\t}\n\n\t\t\tconst pipeline = [\n\t\t\t\t{\n\t\t\t\t\t$match: {\n\t\t\t\t\t\t$and: [\n\t\t\t\t\t\t\t{'ns.coll': { $nin: ['logs'] }},\n\t\t\t\t\t\t\t{'ns.coll': { $not: /.*\\.versions$/ }},\n\t\t\t\t\t\t\t{'ns.coll': { $not: /^monitor-/ }},\n\t\t\t\t\t\t]\n\t\t\t\t\t},\n\t\t\t\t},\n\t\t\t];\n\n\t\t\tlet lastResumeToken: ResumeToken;\n\n\t\t\tif (resumeToken) {\n\t\t\t\tlastResumeToken = resumeToken;\n\t\t\t\ttry {\n\t\t\t\t\tthis._oplog$ = ResolveIOServer.getMainDB().watch(pipeline, { resumeAfter: resumeToken });\n\t\t\t\t}\n\t\t\t\tcatch (errOp) {\n\t\t\t\t\tif (this._oplog$) {\n\t\t\t\t\t\tthis._oplog$.removeAllListeners();\n\t\t\t\t\t\tthis._oplog$.close();\n\t\t\t\t\t\tthis._oplog$ = null;\n\t\t\t\t\t}\n\t\t\t\t\tthis.tailOpLog(resumeToken);\n\t\t\t\t\treturn;\n\t\t\t\t}\n\t\t\t}\n\t\t\telse {\n\t\t\t\tthis._oplog$ = ResolveIOServer.getMainDB().watch(pipeline);\n\t\t\t}\n\n\t\t\tconsole.log(new Date(), 'oplog started');\n\n\t\t\tthis._oplog$.on('change', (doc: ChangeStreamInsertDocument | ChangeStreamUpdateDocument | ChangeStreamReplaceDocument | ChangeStreamDeleteDocument) => {\n\t\t\t\tif (doc.ns) {\n\t\t\t\t\tif (this._enableDebug) {\n\t\t\t\t\t\tconsole.log(new Date(), 'Oplog Hit', doc.ns);\n\t\t\t\t\t}\n\n\t\t\t\t\tlet collection = doc.ns.coll;\n\n\t\t\t\t\tif (!this._debugOplogCollections.some(a => a.collection === doc.ns.coll && a.type === doc.operationType)) {\n\t\t\t\t\t\tthis._debugOplogCollections.push({\n\t\t\t\t\t\t\tcollection: doc.ns.coll,\n\t\t\t\t\t\t\ttype: doc.operationType,\n\t\t\t\t\t\t\thits: 1\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\tthis._debugOplogCollections.find(a => a.collection === doc.ns.coll && a.type === doc.operationType).hits += 1;\n\t\t\t\t\t}\n\n\t\t\t\t\tif (collection) {\n\t\t\t\t\t\tthis._debugOplogHits += 1;\n\n\t\t\t\t\t\tif (doc.operationType === 'insert') {\n\t\t\t\t\t\t\tif (collection === 'support-tickets') {\n\t\t\t\t\t\t\t\tif (this.serverConfig['ROOT_URL'] === 'https://resolveio.com') {\n\t\t\t\t\t\t\t\t\tResolveIOServer.getMainServer().getMethodManager().callMethod.call(ResolveIOServer.getMainServer().getMethodManager(), 'sendSupportTicketEmail', doc.documentKey['_id']);\n\t\t\t\t\t\t\t\t\tthis.invalidatePubsCache(collection, 'insert');\n\t\t\t\t\t\t\t\t}\n\t\t\t\t\t\t\t}\n\n\t\t\t\t\t\t\tif (collection !== 'method-responses') {\n\t\t\t\t\t\t\t\tthis.invalidatePubsCache(collection, 'insert');\n\t\t\t\t\t\t\t}\n\t\t\t\t\t\t}\n\t\t\t\t\t\telse if (doc.operationType === 'update' || doc.operationType === 'replace') {\n\t\t\t\t\t\t\tif (collection !== 'method-responses') {\n\t\t\t\t\t\t\t\tthis.invalidatePubsCache(collection, 'update');\n\t\t\t\t\t\t\t}\n\t\t\t\t\t\t}\n\t\t\t\t\t\telse if (doc.operationType === 'delete') {\n\t\t\t\t\t\t\tif (collection !== 'method-responses') {\n\t\t\t\t\t\t\t\tthis.invalidatePubsCache(collection, 'delete');\n\t\t\t\t\t\t\t}\n\t\t\t\t\t\t}\n\t\t\t\t\t}\n\n\t\t\t\t\tif (collection === 'flags') {\n\t\t\t\t\t\tFlags.findOne({ type: 'Enable Debug' }).then(flag => {\n\t\t\t\t\t\t\tif (flag && flag.value) {\n\t\t\t\t\t\t\t\tthis._enableDebug = true;\n\t\t\t\t\t\t\t}\n\t\t\t\t\t\t\telse {\n\t\t\t\t\t\t\t\tthis._enableDebug = false;\n\t\t\t\t\t\t\t}\n\t\t\t\t\t\t});\n\t\t\t\t\t}\n\n\t\t\t\t\tlastResumeToken = doc._id;\n\n\t\t\t\t\tif ((!process.env.NODE_APP_INSTANCE || process.env.NODE_APP_INSTANCE === '0') && (process.env.IS_WORKERS_ENABLED === 'false' || (process.env.IS_WORKER_INSTANCE === 'true' && process.env.WORKER_INDEX === '0'))) {\n\n\t\t\t\t\t}\n\t\t\t\t}\n\t\t\t});\n\n\t\t\tthis._oplog$.on('error', error => {\n\t\t\t\tconsole.log(new Date(), 'oplog error', error);\n\t\t\t\tthis._oplog$.removeAllListeners();\n\t\t\t\tthis._oplog$.close();\n\t\t\t\tthis._oplog$ = null;\n\t\t\t\tthis.tailOpLog(lastResumeToken);\n\t\t\t});\n\n\t\t\tthis._oplog$.on('end', () => {\n\t\t\t\tconsole.log(new Date(), 'oplog end');\n\t\t\t\tthis._oplog$.removeAllListeners();\n\t\t\t\tthis._oplog$.close();\n\t\t\t\tthis._oplog$ = null;\n\t\t\t\tthis.tailOpLog(lastResumeToken);\n\t\t\t});\n\n\t\t\tthis._oplog$.on('close', () => {\n\t\t\t\tconsole.log(new Date(), 'oplog close');\n\t\t\t\tthis._oplog$.removeAllListeners();\n\t\t\t\tthis._oplog$ = null;\n\t\t\t\tthis.tailOpLog(lastResumeToken);\n\t\t\t});\n\t\t}\n\t}\n\n\tprivate async processSubscription(sub: ActiveSubscriptionModel, ws: WebSocket, messageId: number) {\n\t\tif (!this._publications[sub.publication].user_specific) {\t\t\t\n\t\t\tif (sub.cacheId) {\n\t\t\t\ttry {\n\t\t\t\t\tlet cacheData = JSON.parse(this._nodeCache.get(sub.cacheId), dateReviver);\n\n\t\t\t\t\tlet serverRes: ServerResponseModel = {\n\t\t\t\t\t\tmessageId: messageId,\n\t\t\t\t\t\thasError: false,\n\t\t\t\t\t\tdata: cacheData\n\t\t\t\t\t};\n\n\t\t\t\t\tif (this._enableDebug) {\n\t\t\t\t\t\tconsole.log(new Date(), 'Process Sub, Cache', sub.publication);\n\t\t\t\t\t}\n\n\t\t\t\t\tthis.sendWS(ws, serverRes);\n\t\t\t\t}\n\t\t\t\tcatch (err) {\n\t\t\t\t\tthis._nodeCache.del(sub.cacheId);\n\t\t\t\t\tsub.cacheId = 0;\n\n\t\t\t\t\tthis.sendDataToAllWithRetry(sub, '', 'newSub');\n\t\t\t\t}\n\t\t\t}\n\t\t\telse {\n\t\t\t\tif (this._enableDebug) {\n\t\t\t\t\tconsole.log(new Date(), 'Process Sub, Non - Cache', sub.publication, sub.running);\n\t\t\t\t}\n\n\t\t\t\tif (sub.running) {\n\t\t\t\t\treturn;\n\t\t\t\t}\n\n\t\t\t\tthis.sendDataToAllWithRetry(sub, '', 'newSub');\n\t\t\t}\n\t\t}\n\t\telse {\n\t\t\tif (this._enableDebug) {\n\t\t\t\tconsole.log(new Date(), 'Process Sub Specific, Non - Cache', sub.publication, sub.running);\n\t\t\t}\n\n\t\t\tif (sub.running) {\n\t\t\t\treturn;\n\t\t\t}\n\t\t\t\n\t\t\tthis.sendDataToOneWithRetry(ws, messageId, sub, '', 'newSub');\n\t\t}\n\t}\n\n\tprivate async sendDataToOne(ws: WebSocket, messageId: number, sub: ActiveSubscriptionModel, collection: string, type: string) {\n\t\tlet monitor = this._monitorManagerFunction.startMonitorFunction('User Specific Publication', sub.publication, '', '', sub.subscriptionData);\n\t\ttry {\n\t\t\tResolveIOServer.getMainServer().getMethodManager().callMethod.call(ResolveIOServer.getMainServer().getMethodManager(), 'insertSubscriptionLog', type, sub.publication, collection, JSON.stringify(sub.subscriptionData));\n\n\t\t\tlet res = await this._publications[sub.publication].function.call(Object.assign({}, this, SubscriptionManager.prototype), ws['id_user'], ...sub.subscriptionData);\n\t\t\tthis._monitorManagerFunction.finishMonitorFunction(monitor);\n\n\t\t\tlet serverRes: ServerResponseModel = {\n\t\t\t\tmessageId: messageId,\n\t\t\t\thasError: false,\n\t\t\t\tdata: res\n\t\t\t};\n\n\t\t\tthis.sendWS(ws, serverRes);\n\t\t}\n\t\tcatch (err) {\n\t\t\tthis._monitorManagerFunction.finishMonitorFunction(monitor);\n\n\t\t\tlet serverRes: ServerResponseModel = {\n\t\t\t\tmessageId: messageId,\n\t\t\t\thasError: true,\n\t\t\t\tdata: err\n\t\t\t};\n\n\t\t\tthis.sendWS(ws, serverRes);\n\n\t\t\tResolveIOServer.getMainServer().getMethodManager().sendEmail('dev@resolveio.com', 'SERVER - Error Detected - ' + this.serverConfig['CLIENT_NAME'], 'Error Detected During Subscription ' + sub.publication + ' - (sendDataToOne - WS)\\n\\nData \\n' + JSON.stringify(sub.subscriptionData, null, 2) + '\\n\\nErrors\\n' + JSON.stringify(err, null, 2));\n\t\t}\n\t}\n\n\t// Fetch pub once, send to all clients linked to this pub\n\tprivate async sendDataToAll(sub: ActiveSubscriptionModel, collection: string, type: string) {\n\t\tif (!sub.clients.length) {\n\t\t\tif (sub.cacheId) {\n\t\t\t\tthis._nodeCache.del(sub.cacheId);\n\t\t\t\tsub.cacheId = 0;\n\t\t\t}\n\n\t\t\tlet subIndex = this._subscriptions.findIndex(a => a.publication === sub.publication && JSON.stringify(a.subscriptionData) === JSON.stringify(sub.subscriptionData));\n\t\t\tif (subIndex >= 0) {\n\t\t\t\tthis._subscriptions.splice(subIndex, 1);\n\t\t\t}\n\n\t\t\treturn;\n\t\t}\n\t\telse {\n\t\t\tlet monitor = this._monitorManagerFunction.startMonitorFunction('Publication', sub.publication, '', '', sub.subscriptionData);\n\n\t\t\ttry {\n\t\t\t\tif (sub.publication !== 'superadminAPM' && sub.publication !== 'loggedInUsers') {\n\t\t\t\t\tResolveIOServer.getMainServer().getMethodManager().callMethod.call(ResolveIOServer.getMainServer().getMethodManager(), 'insertSubscriptionLog', type, sub.publication, collection, JSON.stringify(sub.subscriptionData));\n\t\t\t\t}\n\n\t\t\t\tlet res = await this._publications[sub.publication].function.call(Object.assign({}, this, SubscriptionManager.prototype), ...sub.subscriptionData);\n\t\t\t\tthis._monitorManagerFunction.finishMonitorFunction(monitor);\n\n\t\t\t\tif (sub.cacheId) {\n\t\t\t\t\ttry {\n\t\t\t\t\t\tlet cacheData = JSON.parse(this._nodeCache.get(sub.cacheId), dateReviver);\n\t\n\t\t\t\t\t\tif (JSON.stringify(cacheData) !== JSON.stringify(res)) {\n\t\t\t\t\t\t\tPromise.all(\n\t\t\t\t\t\t\t\tsub.clients.map(async client => {\n\t\t\t\t\t\t\t\t\tlet ws = this._websocketManager.getWebSocket(client.id_socket);\n\t\t\t\t\t\t\t\t\tif (ws && ws.readyState === ws.OPEN) {\n\t\t\t\t\t\t\t\t\t\tlet serverRes: ServerResponseModel = {\n\t\t\t\t\t\t\t\t\t\t\tmessageId: client.messageId,\n\t\t\t\t\t\t\t\t\t\t\thasError: false,\n\t\t\t\t\t\t\t\t\t\t\tdata: res\n\t\t\t\t\t\t\t\t\t\t};\n\t\t\t\n\t\t\t\t\t\t\t\t\t\tthis.sendWS(ws, serverRes);\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\n\t\t\t\t\t\t\tthis._nodeCache.del(sub.cacheId);\n\n\t\t\t\t\t\t\tif (getBinarySize(JSON.stringify(res)) < 1000000 && \n\t\t\t\t\t\t\t\t!sub.collections.includes('logs') &&\n\t\t\t\t\t\t\t\t!sub.collections.find(a => a.endsWith('.versions')) &&\n\t\t\t\t\t\t\t\t!sub.collections.find(a => a.startsWith('monitor-'))\n\t\t\t\t\t\t\t) {\n\t\t\t\t\t\t\t\tthis._nodeCache.set(sub.cacheId, JSON.stringify(res));\n\t\t\t\t\t\t\t}\n\t\t\t\t\t\t\telse {\n\t\t\t\t\t\t\t\tsub.cacheId = 0;\n\t\t\t\t\t\t\t}\n\t\t\t\t\t\t}\n\t\t\t\t\t}\n\t\t\t\t\tcatch (err) {\n\t\t\t\t\t\tPromise.all(\n\t\t\t\t\t\t\tsub.clients.map(async client => {\n\t\t\t\t\t\t\t\tlet ws = this._websocketManager.getWebSocket(client.id_socket);\n\t\t\t\t\t\t\t\tif (ws && ws.readyState === ws.OPEN) {\n\t\t\t\t\t\t\t\t\tlet serverRes: ServerResponseModel = {\n\t\t\t\t\t\t\t\t\t\tmessageId: client.messageId,\n\t\t\t\t\t\t\t\t\t\thasError: false,\n\t\t\t\t\t\t\t\t\t\tdata: res\n\t\t\t\t\t\t\t\t\t};\n\t\t\n\t\t\t\t\t\t\t\t\tthis.sendWS(ws, serverRes);\n\t\t\t\t\t\t\t\t}\n\t\t\t\t\t\t\t})\n\t\t\t\t\t\t);\n\n\t\t\t\t\t\tthis._nodeCache.del(sub.cacheId);\n\n\t\t\t\t\t\tif (getBinarySize(JSON.stringify(res)) < 1000000 && \n\t\t\t\t\t\t\t!sub.collections.includes('logs') &&\n\t\t\t\t\t\t\t!sub.collections.find(a => a.endsWith('.versions')) &&\n\t\t\t\t\t\t\t!sub.collections.find(a => a.startsWith('monitor-'))\n\t\t\t\t\t\t) {\n\t\t\t\t\t\t\tthis._nodeCache.set(sub.cacheId, JSON.stringify(res));\n\t\t\t\t\t\t}\n\t\t\t\t\t\telse {\n\t\t\t\t\t\t\tsub.cacheId = 0;\n\t\t\t\t\t\t}\n\t\t\t\t\t}\n\t\t\t\t}\n\t\t\t\telse {\n\t\t\t\t\tPromise.all(\n\t\t\t\t\t\tsub.clients.map(async client => {\n\t\t\t\t\t\t\tlet ws = this._websocketManager.getWebSocket(client.id_socket);\n\t\t\t\t\t\t\tif (ws && ws.readyState === ws.OPEN) {\n\t\t\t\t\t\t\t\tlet serverRes: ServerResponseModel = {\n\t\t\t\t\t\t\t\t\tmessageId: client.messageId,\n\t\t\t\t\t\t\t\t\thasError: false,\n\t\t\t\t\t\t\t\t\tdata: res\n\t\t\t\t\t\t\t\t};\n\t\n\t\t\t\t\t\t\t\tthis.sendWS(ws, serverRes);\n\t\t\t\t\t\t\t}\n\t\t\t\t\t\t})\n\t\t\t\t\t);\n\t\t\t\t\t\n\t\t\t\t\tif (getBinarySize(JSON.stringify(res)) < 1000000 && \n\t\t\t\t\t\t!sub.collections.includes('logs') &&\n\t\t\t\t\t\t!sub.collections.find(a => a.endsWith('.versions')) &&\n\t\t\t\t\t\t!sub.collections.find(a => a.startsWith('monitor-'))\n\t\t\t\t\t) {\n\t\t\t\t\t\tsub.cacheId = this._cacheId++;\n\t\t\t\t\t\tthis._nodeCache.set(sub.cacheId, JSON.stringify(res));\n\n\t\t\t\t\t\tconst nodeCacheSize = this._nodeCache.getStats().vsize;\n\n\t\t\t\t\t\tif (nodeCacheSize > this._heapLimit) {\n\t\t\t\t\t\t\t// Evict cache entries as needed\n\t\t\t\t\t\t\tlet deleteCount = 0;\n\t\t\t\t\t\t\tconst subArr = this._subscriptions.filter(a => a.cacheId && !a.clients.length);\n\t\t\t\t\t\n\t\t\t\t\t\t\tfor (let zz = 0; zz < subArr.length; zz++) {\n\t\t\t\t\t\t\t\tthis._debugRemoveCacheHits += 1;\n\t\t\t\t\t\t\t\tthis._nodeCache.del(subArr[zz].cacheId);\n\t\t\t\t\t\t\t\tsubArr[zz].cacheId = 0;\n\t\t\t\t\t\t\t\tdeleteCount += 1;\n\t\t\t\t\t\t\t\tif (this._nodeCache.getStats().vsize < this._heapLimit * 0.75) {\n\t\t\t\t\t\t\t\t\tbreak;\n\t\t\t\t\t\t\t\t}\n\t\t\t\t\t\t\t}\n\n\t\t\t\t\t\t\tif (this._enableDebug) {\n\t\t\t\t\t\t\t\tconsole.log(\n\t\t\t\t\t\t\t\t\t'Sub Cache: ' +\n\t\t\t\t\t\t\t\t\t'Too Big - ' +\n\t\t\t\t\t\t\t\t\tsub.publication +\n\t\t\t\t\t\t\t\t\t' - Deleted: ' +\n\t\t\t\t\t\t\t\t\tdeleteCount +\n\t\t\t\t\t\t\t\t\t' - ' +\n\t\t\t\t\t\t\t\t\tnodeCacheSize\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\tsub.cacheId = 0;\n\t\t\t\t\t}\n\t\t\t\t}\n\t\t\t}\n\t\t\tcatch (err) {\n\t\t\t\tthis._monitorManagerFunction.finishMonitorFunction(monitor);\n\n\t\t\t\tPromise.all(\n\t\t\t\t\tsub.clients.map(async client => {\n\t\t\t\t\t\tlet ws = this._websocketManager.getWebSocket(client.id_socket);\n\t\t\t\t\t\tif (ws && ws.readyState === ws.OPEN) {\n\t\t\t\t\t\t\tlet serverRes: ServerResponseModel = {\n\t\t\t\t\t\t\t\tmessageId: client.messageId,\n\t\t\t\t\t\t\t\thasError: true,\n\t\t\t\t\t\t\t\tdata: err\n\t\t\t\t\t\t\t};\n\n\t\t\t\t\t\t\tthis.sendWS(ws, serverRes);\n\t\t\t\t\t\t}\n\t\t\t\t\t})\n\t\t\t\t);\n\n\t\t\t\tResolveIOServer.getMainServer().getMethodManager().sendEmail('dev@resolveio.com', 'SERVER - Error Detected - ' + this.serverConfig['CLIENT_NAME'], 'Error Detected During Subscription ' + sub.publication + ' - (sendPubData)\\n\\nData \\n' + JSON.stringify(sub.subscriptionData, null, 2) + '\\n\\nErrors\\n' + JSON.stringify(err, null, 2));\n\t\t\t}\n\t\t}\n\t}\n\n\tprivate sendWS(ws: WebSocket, data: ServerResponseModel) {\n\t\tthis._websocketManager.send(ws, data);\n\t}\n\n\tpublic getEnableDebug() {\n\t\treturn this._enableDebug;\n\t}\n}\n"]}
|
package/methods/aws.js
CHANGED
|
@@ -1,2 +1,2 @@
|
|
|
1
|
-
"use strict";var __awaiter=this&&this.__awaiter||function(e,i,r,o){return new(r=r||Promise)(function(n,t){function fulfilled(e){try{step(o.next(e))}catch(e){t(e)}}function rejected(e){try{step(o.throw(e))}catch(e){t(e)}}function step(e){var t;e.done?n(e.value):((t=e.value)instanceof r?t:new r(function(e){e(t)})).then(fulfilled,rejected)}step((o=o.apply(e,i||[])).next())})},__generator=this&&this.__generator||function(i,r){var o,s,c,l={label:0,sent:function(){if(1&c[0])throw c[1];return c[1]},trys:[],ops:[]},a={next:verb(0),throw:verb(1),return:verb(2)};return"function"==typeof Symbol&&(a[Symbol.iterator]=function(){return this}),a;function verb(n){return function(e){var t=[n,e];if(o)throw new TypeError("Generator is already executing.");for(;l=a&&t[a=0]?0:l;)try{if(o=1,s&&(c=2&t[0]?s.return:t[0]?s.throw||((c=s.return)&&c.call(s),0):s.next)&&!(c=c.call(s,t[1])).done)return c;switch(s=0,(t=c?[2&t[0],c.value]:t)[0]){case 0:case 1:c=t;break;case 4:return l.label++,{value:t[1],done:!1};case 5:l.label++,s=t[1],t=[0];continue;case 7:t=l.ops.pop(),l.trys.pop();continue;default:if(!(c=0<(c=l.trys).length&&c[c.length-1])&&(6===t[0]||2===t[0])){l=0;continue}if(3===t[0]&&(!c||t[1]>c[0]&&t[1]<c[3]))l.label=t[1];else if(6===t[0]&&l.label<c[1])l.label=c[1],c=t;else{if(!(c&&l.label<c[2])){c[2]&&l.ops.pop(),l.trys.pop();continue}l.label=c[2],l.ops.push(t)}}t=r.call(i,l)}catch(e){t=[6,e],s=0}finally{o=c=0}if(5&t[0])throw t[1];return{value:t[0]?t[1]:void 0,done:!0}}}},file_collection_1=(Object.defineProperty(exports,"__esModule",{value:!0}),exports.loadAWSMethods=void 0,require("../collections/file.collection")),simpl_schema_1=require("simpl-schema"),resolveio_server_app_1=require("../resolveio-server-app"),client_s3_1=require("@aws-sdk/client-s3"),s3_request_presigner_1=require("@aws-sdk/s3-request-presigner"),common_1=require("../util/common"),request=require("request").defaults({encoding:null}),fs=require("fs"),pdfCnt=1e6;function loadAWSMethods(e){e.methods({uploadFileAndSave:{check:new simpl_schema_1.default({fileName:{type:String},fileData:{type:String},fileSize:{type:Number},fileOrder:{type:Number},fileType:{type:String},compress:{type:Boolean}}),function:function(l,a,u,f,_,e){var t=this;return new Promise(function(s,c){return __awaiter(t,void 0,void 0,function(){var t,n,i,r,o;return __generator(this,function(e){return l?(t="uploads/"+Date.now()+"-"+pdfCnt+++"-"+l,n=this.getAWS().s3(),i=3,r=0,(o=function(){n.putObject({Bucket:process.env.AWS_S3_BUCKET,Key:t,Body:Buffer.from(a.replace("data:"+a.split(",")[0].split(":")[1].split(";")[0]+";base64,",""),"base64"),ACL:"private",ContentType:a.split(",")[0].split(":")[1].split(";")[0],ContentDisposition:"inline"}).then(function(e){e?file_collection_1.Files.create({_id:(0,common_1.objectIdHexString)(),__v:0,name:l,size:u,key:t,order:f,type:_}).then(function(e){s(e)}).catch(function(e){c(e)}):s(null)}).catch(function(e){var t;++r<=i?(t=1e3*Math.pow(2,r),console.warn("Attempt ".concat(r," failed. Retrying in ").concat(t/1e3," seconds...")),setTimeout(o,t)):c(new Error("Failed to upload after ".concat(i," attempts: ").concat(e.message)))})})()):c(new Error("Invalid fileName provided")),[2]})})})}},uploadNonPDFFileAndSave:{check:new simpl_schema_1.default({fileName:{type:String},fileData:{type:String},fileSize:{type:Number},fileOrder:{type:Number},fileType:{type:String}}),function:function(r,e,o,s,c){var l=this;return new Promise(function(t,n){var i;r&&(i="uploads/"+Date.now()+"-"+r,l.getAWS().s3().putObject({Bucket:process.env.AWS_S3_BUCKET,Key:i,Body:Buffer.from(e),ACL:"private",ContentType:"application/gzip",ContentDisposition:"inline"}).then(function(e){e?file_collection_1.Files.create({_id:(0,common_1.objectIdHexString)(),__v:0,name:r,size:o,key:i,order:s,type:c}).then(function(e){t(e)},function(e){return n(e)}):t(null)},function(e){n(e)}))})}},uploadNonPDFBufferAndSave:{check:new simpl_schema_1.default({fileName:{type:String},fileDataBuffer:{type:Buffer},fileSize:{type:Number},fileOrder:{type:Number},fileType:{type:String}}),function:function(r,e,o,s,c){var l=this;return new Promise(function(t,n){var i;r&&(i="uploads/"+Date.now()+"-"+r,l.getAWS().s3().putObject({Bucket:process.env.AWS_S3_BUCKET,Key:i,Body:e,ACL:"private",ContentType:"application/gzip",ContentDisposition:"inline"}).then(function(e){e?file_collection_1.Files.create({_id:(0,common_1.objectIdHexString)(),__v:0,name:r,size:o,key:i,order:s,type:c}).then(function(e){t(e)},function(e){return n(e)}):t(null)},function(e){n(e)}))})}},uploadNonPDFStreamAndSave:{check:new simpl_schema_1.default({fileName:{type:String},fileData:{type:String},fileOrder:{type:Number},fileType:{type:String}}),function:function(r,e,o,s){var c=this;return new Promise(function(t,n){var i;r&&(i="uploads/"+Date.now()+"-"+r,c.getAWS().s3().putObject({Bucket:process.env.AWS_S3_BUCKET,Key:i,Body:fs.createReadStream(e),ACL:"private",ContentType:"application/gzip",ContentDisposition:"inline"}).then(function(e){e?file_collection_1.Files.create({_id:(0,common_1.objectIdHexString)(),__v:0,name:r,size:1,key:i,order:o,type:s}).then(function(e){t(e)},function(e){return n(e)}):t(null)},function(e){n(e)}))})}},deleteFiles:{check:new simpl_schema_1.default({keys:{type:Array},"keys.$":{type:String}}),function:function(s){var e=this;return new Promise(function(r,o){return __awaiter(e,void 0,void 0,function(){var t,n,i=this;return __generator(this,function(e){switch(e.label){case 0:return[4,file_collection_1.Files.find({key:{$in:s}})];case 1:return t=e.sent(),n=t.length,t.forEach(function(e){file_collection_1.Files.deleteOne({_id:e._id}),i.getAWS().s3().deleteObject({Bucket:process.env.AWS_S3_BUCKET,Key:e.key}).then(function(e){e&&!--n&&r(t.length),r(!0)},function(e){return o(e)})}),[2]}})})})}},deleteFile:{check:new simpl_schema_1.default({key:{type:String}}),function:function(r){var e=this;return new Promise(function(n,i){return __awaiter(e,void 0,void 0,function(){var t;return __generator(this,function(e){switch(e.label){case 0:return[4,file_collection_1.Files.findOne({key:r})];case 1:return(t=e.sent())&&file_collection_1.Files.deleteOne({_id:t._id}),this.getAWS().s3().deleteObject({Bucket:process.env.AWS_S3_BUCKET,Key:r}).then(function(e){n(e)},function(e){i(e)}),[2]}})})})}},deleteFileWithId:{check:new simpl_schema_1.default({id_file:{type:String}}),function:function(r){var e=this;return new Promise(function(n,i){return __awaiter(e,void 0,void 0,function(){var t;return __generator(this,function(e){switch(e.label){case 0:return[4,file_collection_1.Files.findOne({_id:r})];case 1:return(t=e.sent())||i("Could not find file"),this.getAWS().s3().deleteObject({Bucket:process.env.AWS_S3_BUCKET,Key:t.key}).then(function(e){n(e)},function(e){i(e)}),file_collection_1.Files.deleteOne({_id:t._id}),[2]}})})})}},getSignedUrlsAndFilesWithId:{check:new simpl_schema_1.default({ids:{type:Array},"ids.$":{type:String},expires:{type:Number}}),function:function(a,u){var t=this;return new Promise(function(l,e){return __awaiter(t,void 0,void 0,function(){var t,n,i,r,o,s,c;return __generator(this,function(e){switch(e.label){case 0:return t=[],[4,file_collection_1.Files.find({_id:{$in:a}})];case 1:n=e.sent(),i=0,e.label=2;case 2:return i<n.length?(o=n[i],r=this.getAWS().s3(),o=new client_s3_1.GetObjectCommand({Bucket:process.env.AWS_S3_BUCKET,Key:o.key}),c=(s=t).push,[4,(0,s3_request_presigner_1.getSignedUrl)(r,o,{expiresIn:u})]):[3,5];case 3:c.apply(s,[e.sent()]),e.label=4;case 4:return i++,[3,2];case 5:return l({res:t,fileArray:n.map(function(e){return e.name})}),[2]}})})})}},getSignedUrlWithId:{check:new simpl_schema_1.default({id_file:{type:String},expires:{type:Number}}),function:function(o,s){var e=this;return new Promise(function(i,r){return __awaiter(e,void 0,void 0,function(){var t,n;return __generator(this,function(e){switch(e.label){case 0:return[4,file_collection_1.Files.findOne({_id:o})];case 1:return n=e.sent(),t=this.getAWS().s3(),n=new client_s3_1.GetObjectCommand({Bucket:process.env.AWS_S3_BUCKET,Key:n.key}),(0,s3_request_presigner_1.getSignedUrl)(t,n,{expiresIn:s}).then(function(e){i(e)},function(e){r(e)}),[2]}})})})}},getSignedUrlUSEast1BucketAndKey:{check:new simpl_schema_1.default({bucket:{type:String},key:{type:String},expires:{type:Number}}),function:function(r,o,s){var c=this;return new Promise(function(t,n){var e=c.getAWS().s3USEast1(),i=new client_s3_1.GetObjectCommand({Bucket:r,Key:o});(0,s3_request_presigner_1.getSignedUrl)(e,i,{expiresIn:s}).then(function(e){t(e)},function(e){n(e)})})}},getSignedUrl:{check:new simpl_schema_1.default({key:{type:String},expires:{type:Number}}),function:function(r,o){var s=this;return new Promise(function(t,n){var e=s.getAWS().s3(),i=new client_s3_1.GetObjectCommand({Bucket:process.env.AWS_S3_BUCKET,Key:r});(0,s3_request_presigner_1.getSignedUrl)(e,i,{expiresIn:o}).then(function(e){t(e)},function(e){n(e)})})}},getSignedUrls:{check:new simpl_schema_1.default({keys:{type:Array},"keys.$":{type:String},expires:{type:Number}}),function:function(l,a){var t=this;return new Promise(function(c,e){return __awaiter(t,void 0,void 0,function(){var t,n,i,r,o,s;return __generator(this,function(e){switch(e.label){case 0:t=[],n=0,e.label=1;case 1:return n<l.length?(r=l[n],i=this.getAWS().s3(),r=new client_s3_1.GetObjectCommand({Bucket:process.env.AWS_S3_BUCKET,Key:r}),s=(o=t).push,[4,(0,s3_request_presigner_1.getSignedUrl)(i,r,{expiresIn:a})]):[3,4];case 2:s.apply(o,[e.sent()]),e.label=3;case 3:return n++,[3,1];case 4:return c(t),[2]}})})})}},getDataURIfromURL:{check:new simpl_schema_1.default({url:{type:String}}),function:function(e){return new Promise(function(i,r){request.get(e,function(e,t,n){e||200!==t.statusCode?r(e):(e="data:"+t.headers["content-type"]+";base64,"+new Buffer(n).toString("base64"),i(e))})})}},emailFile:{check:new simpl_schema_1.default({id_file:{type:String},email:{type:String},additional_message:{type:String}}),function:function(t,c,l){var e=this;return new Promise(function(o,s){return __awaiter(e,void 0,void 0,function(){var i,r=this;return __generator(this,function(e){switch(e.label){case 0:return[4,file_collection_1.Files.findById(t)];case 1:return(i=e.sent())?this.callMethodInternal("getSignedUrl",i.key,259200,function(e,t){var n;t?(i.size<5e6?(n="Attached is the file requested for email.\n"+(""!==l?"\nAdditional Message:\n"+l+"\n":""),r.sendEmail(c,resolveio_server_app_1.ResolveIOServer.getClientName()+" File - "+i.name,n,"",[{filename:i.name,path:t}],null,"")):(n="Please click the link to the requested file.\n"+(""!==l?"\nAdditional Message:\n"+l+"\n":""),r.sendEmail(c,resolveio_server_app_1.ResolveIOServer.getClientName()+" File - "+i.name,n+t,"",null,null,"")),o(!0)):s("Could not get file URL")}):s("Could not find file"),[2]}})})})}}})}exports.loadAWSMethods=loadAWSMethods;
|
|
1
|
+
"use strict";var __awaiter=this&&this.__awaiter||function(e,i,r,o){return new(r=r||Promise)(function(n,t){function fulfilled(e){try{step(o.next(e))}catch(e){t(e)}}function rejected(e){try{step(o.throw(e))}catch(e){t(e)}}function step(e){var t;e.done?n(e.value):((t=e.value)instanceof r?t:new r(function(e){e(t)})).then(fulfilled,rejected)}step((o=o.apply(e,i||[])).next())})},__generator=this&&this.__generator||function(i,r){var o,s,c,l={label:0,sent:function(){if(1&c[0])throw c[1];return c[1]},trys:[],ops:[]},a={next:verb(0),throw:verb(1),return:verb(2)};return"function"==typeof Symbol&&(a[Symbol.iterator]=function(){return this}),a;function verb(n){return function(e){var t=[n,e];if(o)throw new TypeError("Generator is already executing.");for(;l=a&&t[a=0]?0:l;)try{if(o=1,s&&(c=2&t[0]?s.return:t[0]?s.throw||((c=s.return)&&c.call(s),0):s.next)&&!(c=c.call(s,t[1])).done)return c;switch(s=0,(t=c?[2&t[0],c.value]:t)[0]){case 0:case 1:c=t;break;case 4:return l.label++,{value:t[1],done:!1};case 5:l.label++,s=t[1],t=[0];continue;case 7:t=l.ops.pop(),l.trys.pop();continue;default:if(!(c=0<(c=l.trys).length&&c[c.length-1])&&(6===t[0]||2===t[0])){l=0;continue}if(3===t[0]&&(!c||t[1]>c[0]&&t[1]<c[3]))l.label=t[1];else if(6===t[0]&&l.label<c[1])l.label=c[1],c=t;else{if(!(c&&l.label<c[2])){c[2]&&l.ops.pop(),l.trys.pop();continue}l.label=c[2],l.ops.push(t)}}t=r.call(i,l)}catch(e){t=[6,e],s=0}finally{o=c=0}if(5&t[0])throw t[1];return{value:t[0]?t[1]:void 0,done:!0}}}},file_collection_1=(Object.defineProperty(exports,"__esModule",{value:!0}),exports.loadAWSMethods=void 0,require("../collections/file.collection")),simpl_schema_1=require("simpl-schema"),resolveio_server_app_1=require("../resolveio-server-app"),client_s3_1=require("@aws-sdk/client-s3"),s3_request_presigner_1=require("@aws-sdk/s3-request-presigner"),common_1=require("../util/common"),request=require("request").defaults({encoding:null}),fs=require("fs"),pdfCnt=1e6;function loadAWSMethods(e){e.methods({uploadFileAndSave:{check:new simpl_schema_1.default({fileName:{type:String},fileData:{type:String},fileSize:{type:Number},fileOrder:{type:Number},fileType:{type:String},compress:{type:Boolean}}),function:function(l,a,u,f,_,e){var t=this;return new Promise(function(s,c){return __awaiter(t,void 0,void 0,function(){var t,n,i,r,o;return __generator(this,function(e){return l?(t="uploads/"+Date.now()+"-"+pdfCnt+++"-"+l,n=this.getAWS().s3(),i=3,r=0,(o=function(){n.putObject({Bucket:process.env.AWS_S3_BUCKET,Key:t,Body:Buffer.from(a.replace("data:"+a.split(",")[0].split(":")[1].split(";")[0]+";base64,",""),"base64"),ACL:"private",ContentType:a.split(",")[0].split(":")[1].split(";")[0],ContentDisposition:"inline"}).then(function(e){e?file_collection_1.Files.create({_id:(0,common_1.objectIdHexString)(),__v:0,name:l,size:u,key:t,order:f,type:_}).then(function(e){s(e)}).catch(function(e){c(e)}):s(null)}).catch(function(e){var t;++r<=i?(t=1e3*Math.pow(2,r),console.warn("Attempt ".concat(r," failed. Retrying in ").concat(t/1e3," seconds...")),setTimeout(o,t)):c(new Error("Failed to upload after ".concat(i," attempts: ").concat(e.message)))})})()):c(new Error("Invalid fileName provided")),[2]})})})}},uploadNonPDFFileAndSave:{check:new simpl_schema_1.default({fileName:{type:String},fileData:{type:String},fileSize:{type:Number},fileOrder:{type:Number},fileType:{type:String}}),function:function(r,e,o,s,c){var l=this;return new Promise(function(t,n){var i;r&&(i="uploads/"+Date.now()+"-"+r,l.getAWS().s3().putObject({Bucket:process.env.AWS_S3_BUCKET,Key:i,Body:Buffer.from(e),ACL:"private",ContentType:"application/gzip",ContentDisposition:"inline"}).then(function(e){e?file_collection_1.Files.create({_id:(0,common_1.objectIdHexString)(),__v:0,name:r,size:o,key:i,order:s,type:c}).then(function(e){t(e)},function(e){return n(e)}):t(null)},function(e){n(e)}))})}},uploadNonPDFBufferAndSave:{check:new simpl_schema_1.default({fileName:{type:String},fileDataBuffer:{type:Buffer},fileSize:{type:Number},fileOrder:{type:Number},fileType:{type:String}}),function:function(r,e,o,s,c){var l=this;return new Promise(function(t,n){var i;r&&(i="uploads/"+Date.now()+"-"+r,l.getAWS().s3().putObject({Bucket:process.env.AWS_S3_BUCKET,Key:i,Body:e,ACL:"private",ContentType:"application/gzip",ContentDisposition:"inline"}).then(function(e){e?file_collection_1.Files.create({_id:(0,common_1.objectIdHexString)(),__v:0,name:r,size:o,key:i,order:s,type:c}).then(function(e){t(e)},function(e){return n(e)}):t(null)},function(e){n(e)}))})}},uploadNonPDFStreamAndSave:{check:new simpl_schema_1.default({fileName:{type:String},fileData:{type:String},fileOrder:{type:Number},fileType:{type:String}}),function:function(r,e,o,s){var c=this;return new Promise(function(t,n){var i;r&&(i="uploads/"+Date.now()+"-"+r,c.getAWS().s3().putObject({Bucket:process.env.AWS_S3_BUCKET,Key:i,Body:fs.createReadStream(e),ACL:"private",ContentType:"application/gzip",ContentDisposition:"inline"}).then(function(e){e?file_collection_1.Files.create({_id:(0,common_1.objectIdHexString)(),__v:0,name:r,size:1,key:i,order:o,type:s}).then(function(e){t(e)},function(e){return n(e)}):t(null)},function(e){n(e)}))})}},deleteFiles:{check:new simpl_schema_1.default({keys:{type:Array},"keys.$":{type:String}}),function:function(s){var e=this;return new Promise(function(r,o){return __awaiter(e,void 0,void 0,function(){var t,n,i=this;return __generator(this,function(e){switch(e.label){case 0:return[4,file_collection_1.Files.find({key:{$in:s}})];case 1:return t=e.sent(),n=t.length,t.forEach(function(e){file_collection_1.Files.deleteOne({_id:e._id}),i.getAWS().s3().deleteObject({Bucket:process.env.AWS_S3_BUCKET,Key:e.key}).then(function(e){e&&!--n&&r(t.length),r(!0)},function(e){return o(e)})}),[2]}})})})}},deleteFile:{check:new simpl_schema_1.default({key:{type:String}}),function:function(r){var e=this;return new Promise(function(n,i){return __awaiter(e,void 0,void 0,function(){var t;return __generator(this,function(e){switch(e.label){case 0:return[4,file_collection_1.Files.findOne({key:r})];case 1:return(t=e.sent())&&file_collection_1.Files.deleteOne({_id:t._id}),this.getAWS().s3().deleteObject({Bucket:process.env.AWS_S3_BUCKET,Key:r}).then(function(e){n(e)},function(e){i(e)}),[2]}})})})}},deleteFileWithId:{check:new simpl_schema_1.default({id_file:{type:String}}),function:function(r){var e=this;return new Promise(function(n,i){return __awaiter(e,void 0,void 0,function(){var t;return __generator(this,function(e){switch(e.label){case 0:return[4,file_collection_1.Files.findOne({_id:r})];case 1:return(t=e.sent())||i("Could not find file"),this.getAWS().s3().deleteObject({Bucket:process.env.AWS_S3_BUCKET,Key:t.key}).then(function(e){n(e)},function(e){i(e)}),file_collection_1.Files.deleteOne({_id:t._id}),[2]}})})})}},getSignedUrlsAndFilesWithId:{check:new simpl_schema_1.default({ids:{type:Array},"ids.$":{type:String},expires:{type:Number}}),function:function(a,u){var t=this;return new Promise(function(l,e){return __awaiter(t,void 0,void 0,function(){var t,n,i,r,o,s,c;return __generator(this,function(e){switch(e.label){case 0:return t=[],[4,file_collection_1.Files.find({_id:{$in:a}})];case 1:n=e.sent(),i=0,e.label=2;case 2:return i<n.length?(o=n[i],r=this.getAWS().s3(),o=new client_s3_1.GetObjectCommand({Bucket:process.env.AWS_S3_BUCKET,Key:o.key}),c=(s=t).push,[4,(0,s3_request_presigner_1.getSignedUrl)(r,o,{expiresIn:u})]):[3,5];case 3:c.apply(s,[e.sent()]),e.label=4;case 4:return i++,[3,2];case 5:return l({res:t,fileArray:n.map(function(e){return e.name})}),[2]}})})})}},getSignedUrlWithId:{check:new simpl_schema_1.default({id_file:{type:String},expires:{type:Number}}),function:function(o,s){var e=this;return new Promise(function(i,r){return __awaiter(e,void 0,void 0,function(){var t,n;return __generator(this,function(e){switch(e.label){case 0:return[4,file_collection_1.Files.findOne({_id:o})];case 1:return n=e.sent(),t=this.getAWS().s3(),n=new client_s3_1.GetObjectCommand({Bucket:process.env.AWS_S3_BUCKET,Key:n.key}),(0,s3_request_presigner_1.getSignedUrl)(t,n,{expiresIn:s}).then(function(e){i(e)},function(e){r(e)}),[2]}})})})}},getSignedUrlUSEast1BucketAndKey:{check:new simpl_schema_1.default({bucket:{type:String},key:{type:String},expires:{type:Number}}),function:function(r,o,s){var c=this;return new Promise(function(t,n){var e=c.getAWS().s3USEast1(),i=new client_s3_1.GetObjectCommand({Bucket:r,Key:o});(0,s3_request_presigner_1.getSignedUrl)(e,i,{expiresIn:s}).then(function(e){t(e)},function(e){n(e)})})}},getSignedUrl:{check:new simpl_schema_1.default({key:{type:String},expires:{type:Number}}),function:function(r,o){var s=this;return new Promise(function(t,n){var e=s.getAWS().s3(),i=new client_s3_1.GetObjectCommand({Bucket:process.env.AWS_S3_BUCKET,Key:r});(0,s3_request_presigner_1.getSignedUrl)(e,i,{expiresIn:o}).then(function(e){t(e)},function(e){n(e)})})}},getSignedUrls:{check:new simpl_schema_1.default({keys:{type:Array},"keys.$":{type:String},expires:{type:Number}}),function:function(l,a){var t=this;return new Promise(function(c,e){return __awaiter(t,void 0,void 0,function(){var t,n,i,r,o,s;return __generator(this,function(e){switch(e.label){case 0:t=[],n=0,e.label=1;case 1:return n<l.length?(r=l[n],i=this.getAWS().s3(),r=new client_s3_1.GetObjectCommand({Bucket:process.env.AWS_S3_BUCKET,Key:r}),s=(o=t).push,[4,(0,s3_request_presigner_1.getSignedUrl)(i,r,{expiresIn:a})]):[3,4];case 2:s.apply(o,[e.sent()]),e.label=3;case 3:return n++,[3,1];case 4:return c(t),[2]}})})})}},getDataURIfromURL:{check:new simpl_schema_1.default({url:{type:String}}),function:function(e){return new Promise(function(i,r){request.get(e,function(e,t,n){e||200!==t.statusCode?r(e):(e="data:"+t.headers["content-type"]+";base64,"+new Buffer(n).toString("base64"),i(e))})})}},emailFile:{check:new simpl_schema_1.default({id_file:{type:String},email:{type:String},additional_message:{type:String}}),function:function(t,c,l){var e=this;return new Promise(function(o,s){return __awaiter(e,void 0,void 0,function(){var i,r=this;return __generator(this,function(e){switch(e.label){case 0:return[4,file_collection_1.Files.findById(t)];case 1:return(i=e.sent())?this.callMethod("getSignedUrl",i.key,259200,function(e,t){var n;t?(i.size<5e6?(n="Attached is the file requested for email.\n"+(""!==l?"\nAdditional Message:\n"+l+"\n":""),r.sendEmail(c,resolveio_server_app_1.ResolveIOServer.getClientName()+" File - "+i.name,n,"",[{filename:i.name,path:t}],null,"")):(n="Please click the link to the requested file.\n"+(""!==l?"\nAdditional Message:\n"+l+"\n":""),r.sendEmail(c,resolveio_server_app_1.ResolveIOServer.getClientName()+" File - "+i.name,n+t,"",null,null,"")),o(!0)):s("Could not get file URL")}):s("Could not find file"),[2]}})})})}}})}exports.loadAWSMethods=loadAWSMethods;
|
|
2
2
|
//# sourceMappingURL=aws.js.map
|
package/methods/aws.js.map
CHANGED
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"sources":["../../src/methods/aws.ts"],"names":["file_collection_1","require","simpl_schema_1","resolveio_server_app_1","client_s3_1","s3_request_presigner_1","common_1","request","defaults","encoding","fs","pdfCnt","loadAWSMethods","methodManager","methods","uploadFileAndSave","check","default","fileName","type","String","fileData","fileSize","Number","fileOrder","fileType","compress","Boolean","function","_this","this","Promise","resolve","reject","__awaiter","key_1","Date","now","s3_1","getAWS","s3","maxRetries_1","attempt_1","uploadFile_1","putObject","Bucket","process","env","AWS_S3_BUCKET","Key","Body","Buffer","from","replace","split","ACL","ContentType","ContentDisposition","then","res","Files","create","_id","objectIdHexString","__v","name","size","key","order","resFile","catch","errFile","err","backoff","Math","pow","console","warn","concat","setTimeout","Error","message","uploadNonPDFFileAndSave","key_2","uploadNonPDFBufferAndSave","fileDataBuffer","key_3","uploadNonPDFStreamAndSave","key_4","createReadStream","deleteFiles","keys","Array","keys.$","find","$in","files","_a","sent","deleteCnt","length","forEach","file","deleteOne","deleteObject","e","deleteFile","findOne","deleteFileWithId","id_file","getSignedUrlsAndFilesWithId","ids","ids.$","expires","_c","i","getCommand","GetObjectCommand","_b","push","getSignedUrl","expiresIn","apply","fileArray","map","a","getSignedUrlWithId","getSignedUrlUSEast1BucketAndKey","bucket","s3USEast1","getSignedUrls","getDataURIfromURL","url","get","error","response","body","statusCode","data","headers","toString","emailFile","email","additional_message","findById","callMethodInternal","errPDF","resPDF","emailMessage","sendEmail","ResolveIOServer","getClientName","filename","path","exports"],"mappings":"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","file":"aws.js","sourcesContent":["import { AWS, MethodManager } from '../managers/method.manager';\nimport { Files } from '../collections/file.collection';\nimport SimpleSchema from 'simpl-schema';\nimport { ResolveIOServer } from '../resolveio-server-app';\nimport { GetObjectCommand } from '@aws-sdk/client-s3';\nimport { getSignedUrl } from '@aws-sdk/s3-request-presigner';\nimport { objectIdHexString } from '../util/common';\n\nlet request = require('request').defaults({ encoding: null });\nlet fs = require('fs');\nlet pdfCnt = 1000000;\n\nexport function loadAWSMethods(methodManager: MethodManager) {\n\tmethodManager.methods({\n\t\tuploadFileAndSave: {\n\t\t\tcheck: new SimpleSchema({\n\t\t\t\tfileName: {\n\t\t\t\t\ttype: String\n\t\t\t\t},\n\t\t\t\tfileData: {\n\t\t\t\t\ttype: String\n\t\t\t\t},\n\t\t\t\tfileSize: {\n\t\t\t\t\ttype: Number\n\t\t\t\t},\n\t\t\t\tfileOrder: {\n\t\t\t\t\ttype: Number\n\t\t\t\t},\n\t\t\t\tfileType: {\n\t\t\t\t\ttype: String\n\t\t\t\t},\n\t\t\t\tcompress: {\n\t\t\t\t\ttype: Boolean\n\t\t\t\t}\n\t\t\t}),\n\t\t\tfunction: function(fileName: string, fileData: string, fileSize: number, fileOrder: number, fileType: string, compress: Boolean) {\n\t\t\t\treturn new Promise(async (resolve, reject) => {\n\t\t\t\t\tif (fileName) {\n\t\t\t\t\t\tlet key = 'uploads/' + Date.now() + '-' + (pdfCnt++) + '-' + fileName;\n\t\t\t\t\t\tlet s3 = (<AWS>this.getAWS()).s3();\n\t\t\t\t\t\tconst maxRetries = 3;\n\t\t\t\t\t\tlet attempt = 0;\n\n\t\t\t\t\t\tconst uploadFile = () => {\n\t\t\t\t\t\t\ts3.putObject({\n\t\t\t\t\t\t\t\tBucket: process.env.AWS_S3_BUCKET,\n\t\t\t\t\t\t\t\tKey: key,\n\t\t\t\t\t\t\t\tBody: Buffer.from(fileData.replace('data:' + fileData.split(',')[0].split(':')[1].split(';')[0] + ';base64,', ''), 'base64'), \n\t\t\t\t\t\t\t\tACL: 'private', \n\t\t\t\t\t\t\t\tContentType: fileData.split(',')[0].split(':')[1].split(';')[0], \n\t\t\t\t\t\t\t\tContentDisposition: 'inline'\n\t\t\t\t\t\t\t}).then(res => {\n\t\t\t\t\t\t\t\tif (res) {\n\t\t\t\t\t\t\t\t\tFiles.create({\n\t\t\t\t\t\t\t\t\t\t_id: objectIdHexString(), __v: 0, name: fileName, size: fileSize, key: key, order: fileOrder, type: fileType\n\t\t\t\t\t\t\t\t\t}).then(resFile => {\n\t\t\t\t\t\t\t\t\t\tresolve(resFile);\n\t\t\t\t\t\t\t\t\t}).catch(errFile => {\n\t\t\t\t\t\t\t\t\t\treject(errFile);\n\t\t\t\t\t\t\t\t\t});\n\t\t\t\t\t\t\t\t} else {\n\t\t\t\t\t\t\t\t\tresolve(null);\n\t\t\t\t\t\t\t\t}\n\t\t\t\t\t\t\t}).catch(err => {\n\t\t\t\t\t\t\t\tattempt++;\n\t\t\t\t\t\t\t\tif (attempt <= maxRetries) {\n\t\t\t\t\t\t\t\t\tconst backoff = Math.pow(2, attempt) * 1000; // Exponential backoff\n\t\t\t\t\t\t\t\t\tconsole.warn(`Attempt ${attempt} failed. Retrying in ${backoff / 1000} seconds...`);\n\t\t\t\t\t\t\t\t\tsetTimeout(uploadFile, backoff);\n\t\t\t\t\t\t\t\t} else {\n\t\t\t\t\t\t\t\t\treject(new Error(`Failed to upload after ${maxRetries} attempts: ${err.message}`));\n\t\t\t\t\t\t\t\t}\n\t\t\t\t\t\t\t});\n\t\t\t\t\t\t};\n\n\t\t\t\t\t\tuploadFile(); // Start the upload process\n\t\t\t\t\t} else {\n\t\t\t\t\t\treject(new Error(\"Invalid fileName provided\"));\n\t\t\t\t\t}\n\t\t\t\t});\n\t\t\t}\n\t\t},\n\t\tuploadNonPDFFileAndSave: {\n\t\t\tcheck: new SimpleSchema({\t\n\t\t\t\tfileName: {\t\n\t\t\t\t\ttype: String\t\n\t\t\t\t},\t\n\t\t\t\tfileData: {\t\n\t\t\t\t\ttype: String\t\n\t\t\t\t},\t\n\t\t\t\tfileSize: {\t\n\t\t\t\t\ttype: Number\t\n\t\t\t\t},\t\n\t\t\t\tfileOrder: {\t\n\t\t\t\t\ttype: Number\t\n\t\t\t\t},\t\n\t\t\t\tfileType: {\t\n\t\t\t\t\ttype: String\t\n\t\t\t\t}\t\n\t\t\t}),\t\n\t\t\tfunction: function(fileName: string, fileData: string, fileSize: number, fileOrder: number, fileType: string) {\t\n\t\t\t\treturn new Promise((resolve, reject) => {\t\n\t\t\t\t\tif (fileName) {\t\n\t\t\t\t\t\tlet key = 'uploads/' + Date.now() + '-' + fileName;\t\n\n\t\t\t\t\t\tlet s3 = (<AWS>this.getAWS()).s3();\n\t\t\t\t\t\ts3.putObject({\n\t\t\t\t\t\t\tBucket: process.env.AWS_S3_BUCKET, \n\t\t\t\t\t\t\tKey: key, \n\t\t\t\t\t\t\tBody: Buffer.from(fileData), \n\t\t\t\t\t\t\tACL: 'private', \n\t\t\t\t\t\t\tContentType: 'application/gzip', \n\t\t\t\t\t\t\tContentDisposition: 'inline'\n\t\t\t\t\t\t}).then(res => {\n\t\t\t\t\t\t\tif (res) {\n\t\t\t\t\t\t\t\tFiles.create({\t\n\t\t\t\t\t\t\t\t\t_id: objectIdHexString(), __v: 0, name: fileName, size: fileSize, key: key, order: fileOrder, type: fileType\n\t\t\t\t\t\t\t\t}).then(resFile => {\t\n\t\t\t\t\t\t\t\t\tresolve(resFile);\t\n\t\t\t\t\t\t\t\t}, errFile => reject(errFile));\t\n\t\t\t\t\t\t\t}\n\t\t\t\t\t\t\telse {\n\t\t\t\t\t\t\t\tresolve(null);\n\t\t\t\t\t\t\t}\n\t\t\t\t\t\t}, err => {\n\t\t\t\t\t\t\treject(err);\n\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},\n\t\tuploadNonPDFBufferAndSave: {\n\t\t\tcheck: new SimpleSchema({\t\n\t\t\t\tfileName: {\t\n\t\t\t\t\ttype: String\t\n\t\t\t\t},\t\n\t\t\t\tfileDataBuffer: {\t\n\t\t\t\t\ttype: Buffer\n\t\t\t\t},\t\n\t\t\t\tfileSize: {\t\n\t\t\t\t\ttype: Number\t\n\t\t\t\t},\t\n\t\t\t\tfileOrder: {\t\n\t\t\t\t\ttype: Number\t\n\t\t\t\t},\t\n\t\t\t\tfileType: {\t\n\t\t\t\t\ttype: String\t\n\t\t\t\t}\t\n\t\t\t}),\t\n\t\t\tfunction: function(fileName: string, fileDataBuffer, fileSize: number, fileOrder: number, fileType: string) {\t\n\t\t\t\treturn new Promise((resolve, reject) => {\t\n\t\t\t\t\tif (fileName) {\t\n\t\t\t\t\t\tlet key = 'uploads/' + Date.now() + '-' + fileName;\t\n\t\t\t\t\t\t\n\t\t\t\t\t\tlet s3 = (<AWS>this.getAWS()).s3();\n\t\t\t\t\t\ts3.putObject({\n\t\t\t\t\t\t\tBucket: process.env.AWS_S3_BUCKET, \n\t\t\t\t\t\t\tKey: key, \n\t\t\t\t\t\t\tBody: fileDataBuffer, \n\t\t\t\t\t\t\tACL: 'private', \n\t\t\t\t\t\t\tContentType: 'application/gzip', \n\t\t\t\t\t\t\tContentDisposition: 'inline'\n\t\t\t\t\t\t}).then(res => {\t\n\t\t\t\t\t\t\tif (res) {\n\t\t\t\t\t\t\t\tFiles.create({\t\n\t\t\t\t\t\t\t\t\t_id: objectIdHexString(), __v: 0, name: fileName, size: fileSize, key: key, order: fileOrder, type: fileType\n\t\t\t\t\t\t\t\t}).then(resFile => {\t\n\t\t\t\t\t\t\t\t\tresolve(resFile);\t\n\t\t\t\t\t\t\t\t}, errFile => reject(errFile));\t\n\t\t\t\t\t\t\t}\t\n\t\t\t\t\t\t\telse {\n\t\t\t\t\t\t\t\tresolve(null);\n\t\t\t\t\t\t\t}\n\t\t\t\t\t\t}, err => {\n\t\t\t\t\t\t\treject(err);\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},\n\t\tuploadNonPDFStreamAndSave: {\n\t\t\tcheck: new SimpleSchema({\t\n\t\t\t\tfileName: {\t\n\t\t\t\t\ttype: String\t\n\t\t\t\t},\t\n\t\t\t\tfileData: {\t\n\t\t\t\t\ttype: String\t\n\t\t\t\t},\t\n\t\t\t\tfileOrder: {\t\n\t\t\t\t\ttype: Number\t\n\t\t\t\t},\t\n\t\t\t\tfileType: {\t\n\t\t\t\t\ttype: String\t\n\t\t\t\t}\t\n\t\t\t}),\t\n\t\t\tfunction: function(fileName: string, fileData: string, fileOrder: number, fileType: string) {\t\n\t\t\t\treturn new Promise((resolve, reject) => {\t\n\t\t\t\t\tif (fileName) {\t\n\t\t\t\t\t\tlet key = 'uploads/' + Date.now() + '-' + fileName;\t\n\t\t\t\t\t\t\n\t\t\t\t\t\tlet s3 = (<AWS>this.getAWS()).s3();\n\t\t\t\t\t\ts3.putObject({\n\t\t\t\t\t\t\tBucket: process.env.AWS_S3_BUCKET, \n\t\t\t\t\t\t\tKey: key, \n\t\t\t\t\t\t\tBody: fs.createReadStream(fileData), \n\t\t\t\t\t\t\tACL: 'private', \n\t\t\t\t\t\t\tContentType: 'application/gzip', \n\t\t\t\t\t\t\tContentDisposition: 'inline'\n\t\t\t\t\t\t}).then(res => {\n\t\t\t\t\t\t\tif (res) {\n\t\t\t\t\t\t\t\tFiles.create({\t\n\t\t\t\t\t\t\t\t\t_id: objectIdHexString(), __v: 0, name: fileName, size: 1, key: key, order: fileOrder, type: fileType\n\t\t\t\t\t\t\t\t}).then(resFile => {\t\n\t\t\t\t\t\t\t\t\tresolve(resFile);\t\n\t\t\t\t\t\t\t\t}, errFile => reject(errFile));\n\t\t\t\t\t\t\t}\n\t\t\t\t\t\t\telse {\n\t\t\t\t\t\t\t\tresolve(null);\n\t\t\t\t\t\t\t}\n\t\t\t\t\t\t}, err => {\n\t\t\t\t\t\t\treject(err);\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},\n\t\tdeleteFiles: {\n\t\t\tcheck: new SimpleSchema({\n\t\t\t\tkeys: {\n\t\t\t\t\ttype: Array\n\t\t\t\t},\n\t\t\t\t'keys.$': {\n\t\t\t\t\ttype: String\n\t\t\t\t}\n\t\t\t}),\n\t\t\tfunction: function(keys: string[]) {\t\n\t\t\t\treturn new Promise(async (resolve, reject) => {\n\t\t\t\t\tlet files = await Files.find({key: {$in: keys}});\n\t\t\n\t\t\t\t\tlet deleteCnt = files.length;\n\t\t\n\t\t\t\t\tfiles.forEach(file => {\n\t\t\t\t\t\tFiles.deleteOne({_id: file._id});\n\t\t\t\t\t\t\n\t\t\t\t\t\tlet s3 = (<AWS>this.getAWS()).s3();\n\t\t\t\t\t\ts3.deleteObject({\n\t\t\t\t\t\t\tBucket: process.env.AWS_S3_BUCKET, \n\t\t\t\t\t\t\tKey: file.key\n\t\t\t\t\t\t}).then(res => {\n\t\t\t\t\t\t\tif (res) {\n\t\t\t\t\t\t\t\tdeleteCnt--;\n\t\t\t\t\t\t\t\tif (!deleteCnt) {\n\t\t\t\t\t\t\t\t\tresolve(files.length);\n\t\t\t\t\t\t\t\t}\n\t\t\t\t\t\t\t}\n\n\t\t\t\t\t\t\tresolve(true);\n\t\t\t\t\t\t}, (e) => reject(e));\n\t\t\t\t\t});\n\t\t\t\t});\n\t\t\t}\n\t\t},\n\t\tdeleteFile: {\n\t\t\tcheck: new SimpleSchema({\n\t\t\t\tkey: {\n\t\t\t\t\ttype: String\n\t\t\t\t}\n\t\t\t}),\n\t\t\tfunction: function(key: string) {\n\t\t\t\treturn new Promise(async (resolve, reject) => {\n\t\t\n\t\t\t\t\tlet file = await Files.findOne({key: key});\n\t\t\n\t\t\t\t\tif (file) {\n\t\t\t\t\t\tFiles.deleteOne({_id: file._id});\n\t\t\t\t\t}\n\n\t\t\t\t\tlet s3 = (<AWS>this.getAWS()).s3();\n\t\t\t\t\ts3.deleteObject({\n\t\t\t\t\t\tBucket: process.env.AWS_S3_BUCKET,\n\t\t\t\t\t\tKey: key\n\t\t\t\t\t}).then(res => {\n\t\t\t\t\t\tresolve(res);\n\t\t\t\t\t}, err => {\n\t\t\t\t\t\treject(err);\n\t\t\t\t\t});\n\t\t\t\t});\n\t\t\t}\n\t\t},\n\t\tdeleteFileWithId: {\n\t\t\tcheck: new SimpleSchema({\n\t\t\t\tid_file: {\n\t\t\t\t\ttype: String\n\t\t\t\t}\n\t\t\t}),\n\t\t\tfunction: function(id_file: string) {\n\t\t\t\treturn new Promise(async (resolve, reject) => {\n\t\t\n\t\t\t\t\tlet file = await Files.findOne({_id: id_file});\n\t\t\n\t\t\t\t\tif (!file) {\n\t\t\t\t\t\treject('Could not find file');\n\t\t\t\t\t}\n\t\t\n\t\t\t\t\tlet s3 = (<AWS>this.getAWS()).s3();\n\t\t\t\t\ts3.deleteObject({\n\t\t\t\t\t\tBucket: process.env.AWS_S3_BUCKET,\n\t\t\t\t\t\tKey: file.key\n\t\t\t\t\t}).then(res => {\n\t\t\t\t\t\tresolve(res);\n\t\t\t\t\t}, err => {\n\t\t\t\t\t\treject(err);\n\t\t\t\t\t});\n\n\t\t\t\t\tFiles.deleteOne({_id: file._id});\n\t\t\t\t});\n\t\t\t}\n\t\t},\n\t\tgetSignedUrlsAndFilesWithId: {\n\t\t\tcheck: new SimpleSchema({\n\t\t\t\tids: {\n\t\t\t\t\ttype: Array\n\t\t\t\t},\n\t\t\t\t'ids.$': {\n\t\t\t\t\ttype: String\n\t\t\t\t},\n\t\t\t\texpires: {\n\t\t\t\t\ttype: Number\n\t\t\t\t}\n\t\t\t}),\n\t\t\tfunction: function(ids: string[], expires: number) {\n\t\t\t\treturn new Promise(async (resolve, reject) => {\n\t\t\t\t\tlet res = [];\n\t\t\t\t\tlet fileArray = [];\n\n\t\t\t\t\tlet files = await Files.find({_id: {$in: ids}});\n\t\t\t\t\t\n\t\t\t\t\tfor (let i = 0; i < files.length; i++) {\n\t\t\t\t\t\tlet file = files[i];\n\t\t\t\t\t\tlet s3 = (<AWS>this.getAWS()).s3();\n\t\t\t\t\t\tlet getCommand = new GetObjectCommand({\n\t\t\t\t\t\t\tBucket: process.env.AWS_S3_BUCKET, \n\t\t\t\t\t\t\tKey: file.key\n\t\t\t\t\t\t});\n\t\t\t\t\t\tres.push(await getSignedUrl(s3, getCommand, {expiresIn: expires}));\n\t\t\t\t\t}\n\t\t\t\t\t\n\t\t\t\t\tresolve({res: res, fileArray: files.map(a => a.name)});\n\t\t\t\t});\n\t\t\t}\n\t\t},\n\t\tgetSignedUrlWithId: {\n\t\t\tcheck: new SimpleSchema({\n\t\t\t\tid_file: {\n\t\t\t\t\ttype: String\n\t\t\t\t},\n\t\t\t\texpires: {\n\t\t\t\t\ttype: Number\n\t\t\t\t}\n\t\t\t}),\n\t\t\tfunction: function(id_file: string, expires: number) {\n\t\t\t\treturn new Promise(async (resolve, reject) => {\n\t\t\t\t\tlet file = await Files.findOne({_id: id_file});\n\n\t\t\t\t\tlet s3 = (<AWS>this.getAWS()).s3();\n\t\t\t\t\tlet getCommand = new GetObjectCommand({\n\t\t\t\t\t\tBucket: process.env.AWS_S3_BUCKET, \n\t\t\t\t\t\tKey: file.key\n\t\t\t\t\t});\n\t\t\t\t\tgetSignedUrl(s3, getCommand, {expiresIn: expires}).then(res => {\n\t\t\t\t\t\tresolve(res);\n\t\t\t\t\t}, err => {\n\t\t\t\t\t\treject(err);\n\t\t\t\t\t});\n\t\t\t\t});\n\t\t\t}\n\t\t},\n\t\tgetSignedUrlUSEast1BucketAndKey: {\n\t\t\tcheck: new SimpleSchema({\n\t\t\t\tbucket: {\n\t\t\t\t\ttype: String\n\t\t\t\t},\n\t\t\t\tkey: {\n\t\t\t\t\ttype: String\n\t\t\t\t},\n\t\t\t\texpires: {\n\t\t\t\t\ttype: Number\n\t\t\t\t}\n\t\t\t}),\n\t\t\tfunction: function(bucket: string, key: string, expires: number) {\n\t\t\t\treturn new Promise((resolve, reject) => {\n\t\t\t\t\tlet s3 = (<AWS>this.getAWS()).s3USEast1();\n\t\t\t\t\tlet getCommand = new GetObjectCommand({\n\t\t\t\t\t\tBucket: bucket, \n\t\t\t\t\t\tKey: key\n\t\t\t\t\t});\n\t\t\t\t\tgetSignedUrl(s3, getCommand, {expiresIn: expires}).then(res => {\n\t\t\t\t\t\tresolve(res);\n\t\t\t\t\t}, err => {\n\t\t\t\t\t\treject(err);\n\t\t\t\t\t});\n\t\t\t\t});\n\t\t\t}\n\t\t},\n\t\tgetSignedUrl: {\n\t\t\tcheck: new SimpleSchema({\n\t\t\t\tkey: {\n\t\t\t\t\ttype: String\n\t\t\t\t},\n\t\t\t\texpires: {\n\t\t\t\t\ttype: Number\n\t\t\t\t}\n\t\t\t}),\n\t\t\tfunction: function(key: string, expires: number) {\n\t\t\t\treturn new Promise((resolve, reject) => {\n\t\t\t\t\tlet s3 = (<AWS>this.getAWS()).s3();\n\t\t\t\t\tlet getCommand = new GetObjectCommand({\n\t\t\t\t\t\tBucket: process.env.AWS_S3_BUCKET, \n\t\t\t\t\t\tKey: key\n\t\t\t\t\t});\n\t\t\t\t\tgetSignedUrl(s3, getCommand, {expiresIn: expires}).then(res => {\n\t\t\t\t\t\tresolve(res);\n\t\t\t\t\t}, err => {\n\t\t\t\t\t\treject(err);\n\t\t\t\t\t});\n\t\t\t\t});\n\t\t\t}\n\t\t},\n\t\tgetSignedUrls: {\n\t\t\tcheck: new SimpleSchema({\n\t\t\t\tkeys: {\n\t\t\t\t\ttype: Array\n\t\t\t\t},\n\t\t\t\t'keys.$': {\n\t\t\t\t\ttype: String\n\t\t\t\t},\n\t\t\t\texpires: {\n\t\t\t\t\ttype: Number\n\t\t\t\t}\n\t\t\t}),\n\t\t\tfunction: function(keys: string[], expires: number) {\n\t\t\t\treturn new Promise(async (resolve, reject) => {\n\t\t\t\t\tlet res = [];\n\n\t\t\t\t\tfor (let i = 0; i < keys.length; i++) {\n\t\t\t\t\t\tlet key = keys[i];\n\t\t\t\t\t\tlet s3 = (<AWS>this.getAWS()).s3();\n\t\t\t\t\t\tlet getCommand = new GetObjectCommand({\n\t\t\t\t\t\t\tBucket: process.env.AWS_S3_BUCKET, \n\t\t\t\t\t\t\tKey: key\n\t\t\t\t\t\t});\n\t\t\t\t\t\tres.push(await getSignedUrl(s3, getCommand, {expiresIn: expires}));\n\t\t\t\t\t}\n\n\t\t\t\t\tresolve(res);\n\t\t\t\t});\n\t\t\t}\n\t\t},\n\t\tgetDataURIfromURL: {\n\t\t\tcheck: new SimpleSchema({\n\t\t\t\turl: {\n\t\t\t\t\ttype: String\n\t\t\t\t}\n\t\t\t}),\n\t\t\tfunction: function(url: string) {\n\t\t\t\treturn new Promise((resolve, reject) => {\n\t\t\t\t\trequest.get(url, function (error, response, body) {\n\t\t\t\t\t\tif (!error && response.statusCode === 200) {\n\t\t\t\t\t\t\tlet data = 'data:' + response.headers['content-type'] + ';base64,' + new Buffer(body).toString('base64');\n\t\t\t\t\t\t\tresolve(data);\n\t\t\t\t\t\t}\n\t\t\t\t\t\telse {\n\t\t\t\t\t\t\treject(error);\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\temailFile: {\n\t\t\tcheck: new SimpleSchema({\n\t\t\t\tid_file: {\n\t\t\t\t\ttype: String\n\t\t\t\t},\n\t\t\t\temail: {\n\t\t\t\t\ttype: String\n\t\t\t\t},\n additional_message: {\n type: String\n }\n\t\t\t}),\n\t\t\tfunction: function(id_file: string, email: string, additional_message) {\n\t\t\t\treturn new Promise(async (resolve, reject) => {\n\t\t\t\t\tlet file = await Files.findById(id_file);\n\n\t\t\t\t\tif (!file) {\n\t\t\t\t\t\treject('Could not find file');\n\t\t\t\t\t\treturn;\n\t\t\t\t\t}\n\n\t\t\t\t\tthis.callMethodInternal('getSignedUrl', file.key, 259200, (errPDF, resPDF) => {\n\t\t\t\t\t\tif (resPDF) {\n\t\t\t\t\t\t\tif (file.size < 5000000) {\n\t\t\t\t\t\t\t\tlet emailMessage = 'Attached is the file requested for email.\\n' + (additional_message !== '' ? '\\nAdditional Message:\\n' + additional_message + '\\n' : '') ;\n\n\t\t\t\t\t\t\t\tthis.sendEmail(email, ResolveIOServer.getClientName() + ' File - ' + file.name, emailMessage, '', [{\n\t\t\t\t\t\t\t\t\tfilename: file.name,\n\t\t\t\t\t\t\t\t\tpath: resPDF\n\t\t\t\t\t\t\t\t}], null, '');\n\t\t\t\t\t\t\t}\n\t\t\t\t\t\t\telse {\n\t\t\t\t\t\t\t\tlet emailMessage = 'Please click the link to the requested file.\\n' + (additional_message !== '' ? '\\nAdditional Message:\\n' + additional_message + '\\n' : '') ;\n\t\t\t\t\t\t\t\t\n\t\t\t\t\t\t\t\tthis.sendEmail(email, ResolveIOServer.getClientName() + ' File - ' + file.name, emailMessage + resPDF, '', null, null, '');\n\t\t\t\t\t\t\t}\n\n\t\t\t\t\t\t\tresolve(true);\n\t\t\t\t\t\t}\n\t\t\t\t\t\telse {\n\t\t\t\t\t\t\treject('Could not get file URL');\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}"]}
|
|
1
|
+
{"version":3,"sources":["../../src/methods/aws.ts"],"names":["file_collection_1","require","simpl_schema_1","resolveio_server_app_1","client_s3_1","s3_request_presigner_1","common_1","request","defaults","encoding","fs","pdfCnt","loadAWSMethods","methodManager","methods","uploadFileAndSave","check","default","fileName","type","String","fileData","fileSize","Number","fileOrder","fileType","compress","Boolean","function","_this","this","Promise","resolve","reject","__awaiter","key_1","Date","now","s3_1","getAWS","s3","maxRetries_1","attempt_1","uploadFile_1","putObject","Bucket","process","env","AWS_S3_BUCKET","Key","Body","Buffer","from","replace","split","ACL","ContentType","ContentDisposition","then","res","Files","create","_id","objectIdHexString","__v","name","size","key","order","resFile","catch","errFile","err","backoff","Math","pow","console","warn","concat","setTimeout","Error","message","uploadNonPDFFileAndSave","key_2","uploadNonPDFBufferAndSave","fileDataBuffer","key_3","uploadNonPDFStreamAndSave","key_4","createReadStream","deleteFiles","keys","Array","keys.$","find","$in","files","_a","sent","deleteCnt","length","forEach","file","deleteOne","deleteObject","e","deleteFile","findOne","deleteFileWithId","id_file","getSignedUrlsAndFilesWithId","ids","ids.$","expires","_c","i","getCommand","GetObjectCommand","_b","push","getSignedUrl","expiresIn","apply","fileArray","map","a","getSignedUrlWithId","getSignedUrlUSEast1BucketAndKey","bucket","s3USEast1","getSignedUrls","getDataURIfromURL","url","get","error","response","body","statusCode","data","headers","toString","emailFile","email","additional_message","findById","callMethod","errPDF","resPDF","emailMessage","sendEmail","ResolveIOServer","getClientName","filename","path","exports"],"mappings":"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","file":"aws.js","sourcesContent":["import { AWS, MethodManager } from '../managers/method.manager';\nimport { Files } from '../collections/file.collection';\nimport SimpleSchema from 'simpl-schema';\nimport { ResolveIOServer } from '../resolveio-server-app';\nimport { GetObjectCommand } from '@aws-sdk/client-s3';\nimport { getSignedUrl } from '@aws-sdk/s3-request-presigner';\nimport { objectIdHexString } from '../util/common';\n\nlet request = require('request').defaults({ encoding: null });\nlet fs = require('fs');\nlet pdfCnt = 1000000;\n\nexport function loadAWSMethods(methodManager: MethodManager) {\n\tmethodManager.methods({\n\t\tuploadFileAndSave: {\n\t\t\tcheck: new SimpleSchema({\n\t\t\t\tfileName: {\n\t\t\t\t\ttype: String\n\t\t\t\t},\n\t\t\t\tfileData: {\n\t\t\t\t\ttype: String\n\t\t\t\t},\n\t\t\t\tfileSize: {\n\t\t\t\t\ttype: Number\n\t\t\t\t},\n\t\t\t\tfileOrder: {\n\t\t\t\t\ttype: Number\n\t\t\t\t},\n\t\t\t\tfileType: {\n\t\t\t\t\ttype: String\n\t\t\t\t},\n\t\t\t\tcompress: {\n\t\t\t\t\ttype: Boolean\n\t\t\t\t}\n\t\t\t}),\n\t\t\tfunction: function(fileName: string, fileData: string, fileSize: number, fileOrder: number, fileType: string, compress: Boolean) {\n\t\t\t\treturn new Promise(async (resolve, reject) => {\n\t\t\t\t\tif (fileName) {\n\t\t\t\t\t\tlet key = 'uploads/' + Date.now() + '-' + (pdfCnt++) + '-' + fileName;\n\t\t\t\t\t\tlet s3 = (<AWS>this.getAWS()).s3();\n\t\t\t\t\t\tconst maxRetries = 3;\n\t\t\t\t\t\tlet attempt = 0;\n\n\t\t\t\t\t\tconst uploadFile = () => {\n\t\t\t\t\t\t\ts3.putObject({\n\t\t\t\t\t\t\t\tBucket: process.env.AWS_S3_BUCKET,\n\t\t\t\t\t\t\t\tKey: key,\n\t\t\t\t\t\t\t\tBody: Buffer.from(fileData.replace('data:' + fileData.split(',')[0].split(':')[1].split(';')[0] + ';base64,', ''), 'base64'), \n\t\t\t\t\t\t\t\tACL: 'private', \n\t\t\t\t\t\t\t\tContentType: fileData.split(',')[0].split(':')[1].split(';')[0], \n\t\t\t\t\t\t\t\tContentDisposition: 'inline'\n\t\t\t\t\t\t\t}).then(res => {\n\t\t\t\t\t\t\t\tif (res) {\n\t\t\t\t\t\t\t\t\tFiles.create({\n\t\t\t\t\t\t\t\t\t\t_id: objectIdHexString(), __v: 0, name: fileName, size: fileSize, key: key, order: fileOrder, type: fileType\n\t\t\t\t\t\t\t\t\t}).then(resFile => {\n\t\t\t\t\t\t\t\t\t\tresolve(resFile);\n\t\t\t\t\t\t\t\t\t}).catch(errFile => {\n\t\t\t\t\t\t\t\t\t\treject(errFile);\n\t\t\t\t\t\t\t\t\t});\n\t\t\t\t\t\t\t\t} else {\n\t\t\t\t\t\t\t\t\tresolve(null);\n\t\t\t\t\t\t\t\t}\n\t\t\t\t\t\t\t}).catch(err => {\n\t\t\t\t\t\t\t\tattempt++;\n\t\t\t\t\t\t\t\tif (attempt <= maxRetries) {\n\t\t\t\t\t\t\t\t\tconst backoff = Math.pow(2, attempt) * 1000; // Exponential backoff\n\t\t\t\t\t\t\t\t\tconsole.warn(`Attempt ${attempt} failed. Retrying in ${backoff / 1000} seconds...`);\n\t\t\t\t\t\t\t\t\tsetTimeout(uploadFile, backoff);\n\t\t\t\t\t\t\t\t} else {\n\t\t\t\t\t\t\t\t\treject(new Error(`Failed to upload after ${maxRetries} attempts: ${err.message}`));\n\t\t\t\t\t\t\t\t}\n\t\t\t\t\t\t\t});\n\t\t\t\t\t\t};\n\n\t\t\t\t\t\tuploadFile(); // Start the upload process\n\t\t\t\t\t} else {\n\t\t\t\t\t\treject(new Error(\"Invalid fileName provided\"));\n\t\t\t\t\t}\n\t\t\t\t});\n\t\t\t}\n\t\t},\n\t\tuploadNonPDFFileAndSave: {\n\t\t\tcheck: new SimpleSchema({\t\n\t\t\t\tfileName: {\t\n\t\t\t\t\ttype: String\t\n\t\t\t\t},\t\n\t\t\t\tfileData: {\t\n\t\t\t\t\ttype: String\t\n\t\t\t\t},\t\n\t\t\t\tfileSize: {\t\n\t\t\t\t\ttype: Number\t\n\t\t\t\t},\t\n\t\t\t\tfileOrder: {\t\n\t\t\t\t\ttype: Number\t\n\t\t\t\t},\t\n\t\t\t\tfileType: {\t\n\t\t\t\t\ttype: String\t\n\t\t\t\t}\t\n\t\t\t}),\t\n\t\t\tfunction: function(fileName: string, fileData: string, fileSize: number, fileOrder: number, fileType: string) {\t\n\t\t\t\treturn new Promise((resolve, reject) => {\t\n\t\t\t\t\tif (fileName) {\t\n\t\t\t\t\t\tlet key = 'uploads/' + Date.now() + '-' + fileName;\t\n\n\t\t\t\t\t\tlet s3 = (<AWS>this.getAWS()).s3();\n\t\t\t\t\t\ts3.putObject({\n\t\t\t\t\t\t\tBucket: process.env.AWS_S3_BUCKET, \n\t\t\t\t\t\t\tKey: key, \n\t\t\t\t\t\t\tBody: Buffer.from(fileData), \n\t\t\t\t\t\t\tACL: 'private', \n\t\t\t\t\t\t\tContentType: 'application/gzip', \n\t\t\t\t\t\t\tContentDisposition: 'inline'\n\t\t\t\t\t\t}).then(res => {\n\t\t\t\t\t\t\tif (res) {\n\t\t\t\t\t\t\t\tFiles.create({\t\n\t\t\t\t\t\t\t\t\t_id: objectIdHexString(), __v: 0, name: fileName, size: fileSize, key: key, order: fileOrder, type: fileType\n\t\t\t\t\t\t\t\t}).then(resFile => {\t\n\t\t\t\t\t\t\t\t\tresolve(resFile);\t\n\t\t\t\t\t\t\t\t}, errFile => reject(errFile));\t\n\t\t\t\t\t\t\t}\n\t\t\t\t\t\t\telse {\n\t\t\t\t\t\t\t\tresolve(null);\n\t\t\t\t\t\t\t}\n\t\t\t\t\t\t}, err => {\n\t\t\t\t\t\t\treject(err);\n\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},\n\t\tuploadNonPDFBufferAndSave: {\n\t\t\tcheck: new SimpleSchema({\t\n\t\t\t\tfileName: {\t\n\t\t\t\t\ttype: String\t\n\t\t\t\t},\t\n\t\t\t\tfileDataBuffer: {\t\n\t\t\t\t\ttype: Buffer\n\t\t\t\t},\t\n\t\t\t\tfileSize: {\t\n\t\t\t\t\ttype: Number\t\n\t\t\t\t},\t\n\t\t\t\tfileOrder: {\t\n\t\t\t\t\ttype: Number\t\n\t\t\t\t},\t\n\t\t\t\tfileType: {\t\n\t\t\t\t\ttype: String\t\n\t\t\t\t}\t\n\t\t\t}),\t\n\t\t\tfunction: function(fileName: string, fileDataBuffer, fileSize: number, fileOrder: number, fileType: string) {\t\n\t\t\t\treturn new Promise((resolve, reject) => {\t\n\t\t\t\t\tif (fileName) {\t\n\t\t\t\t\t\tlet key = 'uploads/' + Date.now() + '-' + fileName;\t\n\t\t\t\t\t\t\n\t\t\t\t\t\tlet s3 = (<AWS>this.getAWS()).s3();\n\t\t\t\t\t\ts3.putObject({\n\t\t\t\t\t\t\tBucket: process.env.AWS_S3_BUCKET, \n\t\t\t\t\t\t\tKey: key, \n\t\t\t\t\t\t\tBody: fileDataBuffer, \n\t\t\t\t\t\t\tACL: 'private', \n\t\t\t\t\t\t\tContentType: 'application/gzip', \n\t\t\t\t\t\t\tContentDisposition: 'inline'\n\t\t\t\t\t\t}).then(res => {\t\n\t\t\t\t\t\t\tif (res) {\n\t\t\t\t\t\t\t\tFiles.create({\t\n\t\t\t\t\t\t\t\t\t_id: objectIdHexString(), __v: 0, name: fileName, size: fileSize, key: key, order: fileOrder, type: fileType\n\t\t\t\t\t\t\t\t}).then(resFile => {\t\n\t\t\t\t\t\t\t\t\tresolve(resFile);\t\n\t\t\t\t\t\t\t\t}, errFile => reject(errFile));\t\n\t\t\t\t\t\t\t}\t\n\t\t\t\t\t\t\telse {\n\t\t\t\t\t\t\t\tresolve(null);\n\t\t\t\t\t\t\t}\n\t\t\t\t\t\t}, err => {\n\t\t\t\t\t\t\treject(err);\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},\n\t\tuploadNonPDFStreamAndSave: {\n\t\t\tcheck: new SimpleSchema({\t\n\t\t\t\tfileName: {\t\n\t\t\t\t\ttype: String\t\n\t\t\t\t},\t\n\t\t\t\tfileData: {\t\n\t\t\t\t\ttype: String\t\n\t\t\t\t},\t\n\t\t\t\tfileOrder: {\t\n\t\t\t\t\ttype: Number\t\n\t\t\t\t},\t\n\t\t\t\tfileType: {\t\n\t\t\t\t\ttype: String\t\n\t\t\t\t}\t\n\t\t\t}),\t\n\t\t\tfunction: function(fileName: string, fileData: string, fileOrder: number, fileType: string) {\t\n\t\t\t\treturn new Promise((resolve, reject) => {\t\n\t\t\t\t\tif (fileName) {\t\n\t\t\t\t\t\tlet key = 'uploads/' + Date.now() + '-' + fileName;\t\n\t\t\t\t\t\t\n\t\t\t\t\t\tlet s3 = (<AWS>this.getAWS()).s3();\n\t\t\t\t\t\ts3.putObject({\n\t\t\t\t\t\t\tBucket: process.env.AWS_S3_BUCKET, \n\t\t\t\t\t\t\tKey: key, \n\t\t\t\t\t\t\tBody: fs.createReadStream(fileData), \n\t\t\t\t\t\t\tACL: 'private', \n\t\t\t\t\t\t\tContentType: 'application/gzip', \n\t\t\t\t\t\t\tContentDisposition: 'inline'\n\t\t\t\t\t\t}).then(res => {\n\t\t\t\t\t\t\tif (res) {\n\t\t\t\t\t\t\t\tFiles.create({\t\n\t\t\t\t\t\t\t\t\t_id: objectIdHexString(), __v: 0, name: fileName, size: 1, key: key, order: fileOrder, type: fileType\n\t\t\t\t\t\t\t\t}).then(resFile => {\t\n\t\t\t\t\t\t\t\t\tresolve(resFile);\t\n\t\t\t\t\t\t\t\t}, errFile => reject(errFile));\n\t\t\t\t\t\t\t}\n\t\t\t\t\t\t\telse {\n\t\t\t\t\t\t\t\tresolve(null);\n\t\t\t\t\t\t\t}\n\t\t\t\t\t\t}, err => {\n\t\t\t\t\t\t\treject(err);\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},\n\t\tdeleteFiles: {\n\t\t\tcheck: new SimpleSchema({\n\t\t\t\tkeys: {\n\t\t\t\t\ttype: Array\n\t\t\t\t},\n\t\t\t\t'keys.$': {\n\t\t\t\t\ttype: String\n\t\t\t\t}\n\t\t\t}),\n\t\t\tfunction: function(keys: string[]) {\t\n\t\t\t\treturn new Promise(async (resolve, reject) => {\n\t\t\t\t\tlet files = await Files.find({key: {$in: keys}});\n\t\t\n\t\t\t\t\tlet deleteCnt = files.length;\n\t\t\n\t\t\t\t\tfiles.forEach(file => {\n\t\t\t\t\t\tFiles.deleteOne({_id: file._id});\n\t\t\t\t\t\t\n\t\t\t\t\t\tlet s3 = (<AWS>this.getAWS()).s3();\n\t\t\t\t\t\ts3.deleteObject({\n\t\t\t\t\t\t\tBucket: process.env.AWS_S3_BUCKET, \n\t\t\t\t\t\t\tKey: file.key\n\t\t\t\t\t\t}).then(res => {\n\t\t\t\t\t\t\tif (res) {\n\t\t\t\t\t\t\t\tdeleteCnt--;\n\t\t\t\t\t\t\t\tif (!deleteCnt) {\n\t\t\t\t\t\t\t\t\tresolve(files.length);\n\t\t\t\t\t\t\t\t}\n\t\t\t\t\t\t\t}\n\n\t\t\t\t\t\t\tresolve(true);\n\t\t\t\t\t\t}, (e) => reject(e));\n\t\t\t\t\t});\n\t\t\t\t});\n\t\t\t}\n\t\t},\n\t\tdeleteFile: {\n\t\t\tcheck: new SimpleSchema({\n\t\t\t\tkey: {\n\t\t\t\t\ttype: String\n\t\t\t\t}\n\t\t\t}),\n\t\t\tfunction: function(key: string) {\n\t\t\t\treturn new Promise(async (resolve, reject) => {\n\t\t\n\t\t\t\t\tlet file = await Files.findOne({key: key});\n\t\t\n\t\t\t\t\tif (file) {\n\t\t\t\t\t\tFiles.deleteOne({_id: file._id});\n\t\t\t\t\t}\n\n\t\t\t\t\tlet s3 = (<AWS>this.getAWS()).s3();\n\t\t\t\t\ts3.deleteObject({\n\t\t\t\t\t\tBucket: process.env.AWS_S3_BUCKET,\n\t\t\t\t\t\tKey: key\n\t\t\t\t\t}).then(res => {\n\t\t\t\t\t\tresolve(res);\n\t\t\t\t\t}, err => {\n\t\t\t\t\t\treject(err);\n\t\t\t\t\t});\n\t\t\t\t});\n\t\t\t}\n\t\t},\n\t\tdeleteFileWithId: {\n\t\t\tcheck: new SimpleSchema({\n\t\t\t\tid_file: {\n\t\t\t\t\ttype: String\n\t\t\t\t}\n\t\t\t}),\n\t\t\tfunction: function(id_file: string) {\n\t\t\t\treturn new Promise(async (resolve, reject) => {\n\t\t\n\t\t\t\t\tlet file = await Files.findOne({_id: id_file});\n\t\t\n\t\t\t\t\tif (!file) {\n\t\t\t\t\t\treject('Could not find file');\n\t\t\t\t\t}\n\t\t\n\t\t\t\t\tlet s3 = (<AWS>this.getAWS()).s3();\n\t\t\t\t\ts3.deleteObject({\n\t\t\t\t\t\tBucket: process.env.AWS_S3_BUCKET,\n\t\t\t\t\t\tKey: file.key\n\t\t\t\t\t}).then(res => {\n\t\t\t\t\t\tresolve(res);\n\t\t\t\t\t}, err => {\n\t\t\t\t\t\treject(err);\n\t\t\t\t\t});\n\n\t\t\t\t\tFiles.deleteOne({_id: file._id});\n\t\t\t\t});\n\t\t\t}\n\t\t},\n\t\tgetSignedUrlsAndFilesWithId: {\n\t\t\tcheck: new SimpleSchema({\n\t\t\t\tids: {\n\t\t\t\t\ttype: Array\n\t\t\t\t},\n\t\t\t\t'ids.$': {\n\t\t\t\t\ttype: String\n\t\t\t\t},\n\t\t\t\texpires: {\n\t\t\t\t\ttype: Number\n\t\t\t\t}\n\t\t\t}),\n\t\t\tfunction: function(ids: string[], expires: number) {\n\t\t\t\treturn new Promise(async (resolve, reject) => {\n\t\t\t\t\tlet res = [];\n\t\t\t\t\tlet fileArray = [];\n\n\t\t\t\t\tlet files = await Files.find({_id: {$in: ids}});\n\t\t\t\t\t\n\t\t\t\t\tfor (let i = 0; i < files.length; i++) {\n\t\t\t\t\t\tlet file = files[i];\n\t\t\t\t\t\tlet s3 = (<AWS>this.getAWS()).s3();\n\t\t\t\t\t\tlet getCommand = new GetObjectCommand({\n\t\t\t\t\t\t\tBucket: process.env.AWS_S3_BUCKET, \n\t\t\t\t\t\t\tKey: file.key\n\t\t\t\t\t\t});\n\t\t\t\t\t\tres.push(await getSignedUrl(s3, getCommand, {expiresIn: expires}));\n\t\t\t\t\t}\n\t\t\t\t\t\n\t\t\t\t\tresolve({res: res, fileArray: files.map(a => a.name)});\n\t\t\t\t});\n\t\t\t}\n\t\t},\n\t\tgetSignedUrlWithId: {\n\t\t\tcheck: new SimpleSchema({\n\t\t\t\tid_file: {\n\t\t\t\t\ttype: String\n\t\t\t\t},\n\t\t\t\texpires: {\n\t\t\t\t\ttype: Number\n\t\t\t\t}\n\t\t\t}),\n\t\t\tfunction: function(id_file: string, expires: number) {\n\t\t\t\treturn new Promise(async (resolve, reject) => {\n\t\t\t\t\tlet file = await Files.findOne({_id: id_file});\n\n\t\t\t\t\tlet s3 = (<AWS>this.getAWS()).s3();\n\t\t\t\t\tlet getCommand = new GetObjectCommand({\n\t\t\t\t\t\tBucket: process.env.AWS_S3_BUCKET, \n\t\t\t\t\t\tKey: file.key\n\t\t\t\t\t});\n\t\t\t\t\tgetSignedUrl(s3, getCommand, {expiresIn: expires}).then(res => {\n\t\t\t\t\t\tresolve(res);\n\t\t\t\t\t}, err => {\n\t\t\t\t\t\treject(err);\n\t\t\t\t\t});\n\t\t\t\t});\n\t\t\t}\n\t\t},\n\t\tgetSignedUrlUSEast1BucketAndKey: {\n\t\t\tcheck: new SimpleSchema({\n\t\t\t\tbucket: {\n\t\t\t\t\ttype: String\n\t\t\t\t},\n\t\t\t\tkey: {\n\t\t\t\t\ttype: String\n\t\t\t\t},\n\t\t\t\texpires: {\n\t\t\t\t\ttype: Number\n\t\t\t\t}\n\t\t\t}),\n\t\t\tfunction: function(bucket: string, key: string, expires: number) {\n\t\t\t\treturn new Promise((resolve, reject) => {\n\t\t\t\t\tlet s3 = (<AWS>this.getAWS()).s3USEast1();\n\t\t\t\t\tlet getCommand = new GetObjectCommand({\n\t\t\t\t\t\tBucket: bucket, \n\t\t\t\t\t\tKey: key\n\t\t\t\t\t});\n\t\t\t\t\tgetSignedUrl(s3, getCommand, {expiresIn: expires}).then(res => {\n\t\t\t\t\t\tresolve(res);\n\t\t\t\t\t}, err => {\n\t\t\t\t\t\treject(err);\n\t\t\t\t\t});\n\t\t\t\t});\n\t\t\t}\n\t\t},\n\t\tgetSignedUrl: {\n\t\t\tcheck: new SimpleSchema({\n\t\t\t\tkey: {\n\t\t\t\t\ttype: String\n\t\t\t\t},\n\t\t\t\texpires: {\n\t\t\t\t\ttype: Number\n\t\t\t\t}\n\t\t\t}),\n\t\t\tfunction: function(key: string, expires: number) {\n\t\t\t\treturn new Promise((resolve, reject) => {\n\t\t\t\t\tlet s3 = (<AWS>this.getAWS()).s3();\n\t\t\t\t\tlet getCommand = new GetObjectCommand({\n\t\t\t\t\t\tBucket: process.env.AWS_S3_BUCKET, \n\t\t\t\t\t\tKey: key\n\t\t\t\t\t});\n\t\t\t\t\tgetSignedUrl(s3, getCommand, {expiresIn: expires}).then(res => {\n\t\t\t\t\t\tresolve(res);\n\t\t\t\t\t}, err => {\n\t\t\t\t\t\treject(err);\n\t\t\t\t\t});\n\t\t\t\t});\n\t\t\t}\n\t\t},\n\t\tgetSignedUrls: {\n\t\t\tcheck: new SimpleSchema({\n\t\t\t\tkeys: {\n\t\t\t\t\ttype: Array\n\t\t\t\t},\n\t\t\t\t'keys.$': {\n\t\t\t\t\ttype: String\n\t\t\t\t},\n\t\t\t\texpires: {\n\t\t\t\t\ttype: Number\n\t\t\t\t}\n\t\t\t}),\n\t\t\tfunction: function(keys: string[], expires: number) {\n\t\t\t\treturn new Promise(async (resolve, reject) => {\n\t\t\t\t\tlet res = [];\n\n\t\t\t\t\tfor (let i = 0; i < keys.length; i++) {\n\t\t\t\t\t\tlet key = keys[i];\n\t\t\t\t\t\tlet s3 = (<AWS>this.getAWS()).s3();\n\t\t\t\t\t\tlet getCommand = new GetObjectCommand({\n\t\t\t\t\t\t\tBucket: process.env.AWS_S3_BUCKET, \n\t\t\t\t\t\t\tKey: key\n\t\t\t\t\t\t});\n\t\t\t\t\t\tres.push(await getSignedUrl(s3, getCommand, {expiresIn: expires}));\n\t\t\t\t\t}\n\n\t\t\t\t\tresolve(res);\n\t\t\t\t});\n\t\t\t}\n\t\t},\n\t\tgetDataURIfromURL: {\n\t\t\tcheck: new SimpleSchema({\n\t\t\t\turl: {\n\t\t\t\t\ttype: String\n\t\t\t\t}\n\t\t\t}),\n\t\t\tfunction: function(url: string) {\n\t\t\t\treturn new Promise((resolve, reject) => {\n\t\t\t\t\trequest.get(url, function (error, response, body) {\n\t\t\t\t\t\tif (!error && response.statusCode === 200) {\n\t\t\t\t\t\t\tlet data = 'data:' + response.headers['content-type'] + ';base64,' + new Buffer(body).toString('base64');\n\t\t\t\t\t\t\tresolve(data);\n\t\t\t\t\t\t}\n\t\t\t\t\t\telse {\n\t\t\t\t\t\t\treject(error);\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\temailFile: {\n\t\t\tcheck: new SimpleSchema({\n\t\t\t\tid_file: {\n\t\t\t\t\ttype: String\n\t\t\t\t},\n\t\t\t\temail: {\n\t\t\t\t\ttype: String\n\t\t\t\t},\n additional_message: {\n type: String\n }\n\t\t\t}),\n\t\t\tfunction: function(id_file: string, email: string, additional_message) {\n\t\t\t\treturn new Promise(async (resolve, reject) => {\n\t\t\t\t\tlet file = await Files.findById(id_file);\n\n\t\t\t\t\tif (!file) {\n\t\t\t\t\t\treject('Could not find file');\n\t\t\t\t\t\treturn;\n\t\t\t\t\t}\n\n\t\t\t\t\tthis.callMethod('getSignedUrl', file.key, 259200, (errPDF, resPDF) => {\n\t\t\t\t\t\tif (resPDF) {\n\t\t\t\t\t\t\tif (file.size < 5000000) {\n\t\t\t\t\t\t\t\tlet emailMessage = 'Attached is the file requested for email.\\n' + (additional_message !== '' ? '\\nAdditional Message:\\n' + additional_message + '\\n' : '') ;\n\n\t\t\t\t\t\t\t\tthis.sendEmail(email, ResolveIOServer.getClientName() + ' File - ' + file.name, emailMessage, '', [{\n\t\t\t\t\t\t\t\t\tfilename: file.name,\n\t\t\t\t\t\t\t\t\tpath: resPDF\n\t\t\t\t\t\t\t\t}], null, '');\n\t\t\t\t\t\t\t}\n\t\t\t\t\t\t\telse {\n\t\t\t\t\t\t\t\tlet emailMessage = 'Please click the link to the requested file.\\n' + (additional_message !== '' ? '\\nAdditional Message:\\n' + additional_message + '\\n' : '') ;\n\t\t\t\t\t\t\t\t\n\t\t\t\t\t\t\t\tthis.sendEmail(email, ResolveIOServer.getClientName() + ' File - ' + file.name, emailMessage + resPDF, '', null, null, '');\n\t\t\t\t\t\t\t}\n\n\t\t\t\t\t\t\tresolve(true);\n\t\t\t\t\t\t}\n\t\t\t\t\t\telse {\n\t\t\t\t\t\t\treject('Could not get file URL');\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}"]}
|