@resolveio/server-lib 20.7.119 → 20.7.121
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/client-server-app.js +51 -1
- package/client-server-app.js.map +1 -1
- package/collections/app-status.collection.js +51 -1
- package/collections/app-status.collection.js.map +1 -1
- package/collections/counter.collection.js +55 -1
- package/collections/counter.collection.js.map +1 -1
- package/collections/cron-job-history.collection.js +136 -1
- package/collections/cron-job-history.collection.js.map +1 -1
- package/collections/cron-job.collection.js +87 -1
- package/collections/cron-job.collection.js.map +1 -1
- package/collections/email-history.collection.js +98 -1
- package/collections/email-history.collection.js.map +1 -1
- package/collections/email-verified.collection.js +60 -1
- package/collections/email-verified.collection.js.map +1 -1
- package/collections/file.collection.js +73 -1
- package/collections/file.collection.js.map +1 -1
- package/collections/flag-update.collection.js +56 -1
- package/collections/flag-update.collection.js.map +1 -1
- package/collections/flag.collection.js +56 -1
- package/collections/flag.collection.js.map +1 -1
- package/collections/log-method-latency.collection.js +72 -1
- package/collections/log-method-latency.collection.js.map +1 -1
- package/collections/log-subscription.collection.js +75 -1
- package/collections/log-subscription.collection.js.map +1 -1
- package/collections/log.collection.js +87 -1
- package/collections/log.collection.js.map +1 -1
- package/collections/logged-in-users.collection.js +66 -1
- package/collections/logged-in-users.collection.js.map +1 -1
- package/collections/monitor-cpu.collection.js +64 -1
- package/collections/monitor-cpu.collection.js.map +1 -1
- package/collections/monitor-function.collection.js +73 -1
- package/collections/monitor-function.collection.js.map +1 -1
- package/collections/monitor-memory.collection.js +76 -1
- package/collections/monitor-memory.collection.js.map +1 -1
- package/collections/monitor-mongo.collection.js +70 -1
- package/collections/monitor-mongo.collection.js.map +1 -1
- package/collections/notification.collection.js +56 -1
- package/collections/notification.collection.js.map +1 -1
- package/collections/report-builder-dashboard-builder.collection.js +108 -1
- package/collections/report-builder-dashboard-builder.collection.js.map +1 -1
- package/collections/report-builder-library.collection.js +86 -1
- package/collections/report-builder-library.collection.js.map +1 -1
- package/collections/report-builder-report.collection.js +148 -1
- package/collections/report-builder-report.collection.js.map +1 -1
- package/collections/user-group.collection.js +88 -1
- package/collections/user-group.collection.js.map +1 -1
- package/collections/user-guide.collection.js +56 -1
- package/collections/user-guide.collection.js.map +1 -1
- package/collections/user.collection.js +265 -1
- package/collections/user.collection.js.map +1 -1
- package/cron/cron.js +97 -1
- package/cron/cron.js.map +1 -1
- package/fixtures/cron-jobs.js +95 -1
- package/fixtures/cron-jobs.js.map +1 -1
- package/fixtures/init.js +78 -1
- package/fixtures/init.js.map +1 -1
- package/http/auth.js +869 -1
- package/http/auth.js.map +1 -1
- package/http/health.js +11 -1
- package/http/health.js.map +1 -1
- package/http/home.js +114 -1
- package/http/home.js.map +1 -1
- package/index.js +18 -1
- package/index.js.map +1 -1
- package/managers/cron.manager.js +461 -1
- package/managers/cron.manager.js.map +1 -1
- package/managers/local-log.manager.js +79 -1
- package/managers/local-log.manager.js.map +1 -1
- package/managers/method.manager.js +1023 -1
- package/managers/method.manager.js.map +1 -1
- package/managers/mongo.manager.js +4223 -1
- package/managers/mongo.manager.js.map +1 -1
- package/managers/monitor.manager.js +534 -1
- package/managers/monitor.manager.js.map +1 -1
- package/managers/subscription.manager.js +1292 -1
- package/managers/subscription.manager.js.map +1 -1
- package/managers/websocket.manager.js +165 -1
- package/managers/websocket.manager.js.map +1 -1
- package/managers/worker-dispatcher.manager.js +335 -1
- package/managers/worker-dispatcher.manager.js.map +1 -1
- package/managers/worker-server.manager.js +292 -1
- package/managers/worker-server.manager.js.map +1 -1
- package/methods/accounts.js +302 -1
- package/methods/accounts.js.map +1 -1
- package/methods/aws.js +748 -1
- package/methods/aws.js.map +1 -1
- package/methods/collections.js +542 -1
- package/methods/collections.js.map +1 -1
- package/methods/counters.js +111 -1
- package/methods/counters.js.map +1 -1
- package/methods/cron-jobs.js +1476 -1
- package/methods/cron-jobs.js.map +1 -1
- package/methods/flag-updates.js +8 -1
- package/methods/flag-updates.js.map +1 -1
- package/methods/flags.js +8 -1
- package/methods/flags.js.map +1 -1
- package/methods/logs.js +417 -1
- package/methods/logs.js.map +1 -1
- package/methods/monitor.js +543 -1
- package/methods/monitor.js.map +1 -1
- package/methods/pdf.js +742 -1
- package/methods/pdf.js.map +1 -1
- package/methods/report-builder.js +840 -1
- package/methods/report-builder.js.map +1 -1
- package/methods/support.js +232 -1
- package/methods/support.js.map +1 -1
- package/models/app-status.model.js +3 -1
- package/models/app-status.model.js.map +1 -1
- package/models/billing-logged-in-users.model.js +3 -1
- package/models/billing-logged-in-users.model.js.map +1 -1
- package/models/collection-document.model.js +3 -1
- package/models/collection-document.model.js.map +1 -1
- package/models/counter.model.js +3 -1
- package/models/counter.model.js.map +1 -1
- package/models/cron-job-history.model.js +3 -1
- package/models/cron-job-history.model.js.map +1 -1
- package/models/cron-job.model.js +3 -1
- package/models/cron-job.model.js.map +1 -1
- package/models/dialog.model.js +3 -1
- package/models/dialog.model.js.map +1 -1
- package/models/email-history.model.js +15 -1
- package/models/email-history.model.js.map +1 -1
- package/models/email-verified.model.js +3 -1
- package/models/email-verified.model.js.map +1 -1
- package/models/file.model.js +3 -1
- package/models/file.model.js.map +1 -1
- package/models/flag-update.model.js +3 -1
- package/models/flag-update.model.js.map +1 -1
- package/models/flag.model.js +3 -1
- package/models/flag.model.js.map +1 -1
- package/models/log-method-latency.model.js +3 -1
- package/models/log-method-latency.model.js.map +1 -1
- package/models/log-subscription.model.js +3 -1
- package/models/log-subscription.model.js.map +1 -1
- package/models/log.model.js +3 -1
- package/models/log.model.js.map +1 -1
- package/models/logged-in-users.model.js +3 -1
- package/models/logged-in-users.model.js.map +1 -1
- package/models/method-response.model.js +3 -1
- package/models/method-response.model.js.map +1 -1
- package/models/method.model.d.ts +0 -1
- package/models/method.model.js +3 -1
- package/models/method.model.js.map +1 -1
- package/models/monitor-cpu.model.js +3 -1
- package/models/monitor-cpu.model.js.map +1 -1
- package/models/monitor-function.model.js +3 -1
- package/models/monitor-function.model.js.map +1 -1
- package/models/monitor-memory.model.js +3 -1
- package/models/monitor-memory.model.js.map +1 -1
- package/models/monitor-mongo.model.js +3 -1
- package/models/monitor-mongo.model.js.map +1 -1
- package/models/notification.model.js +3 -1
- package/models/notification.model.js.map +1 -1
- package/models/pagination.model.js +23 -1
- package/models/pagination.model.js.map +1 -1
- package/models/permission.model.js +3 -1
- package/models/permission.model.js.map +1 -1
- package/models/report-builder-dashboard-builder.model.js +3 -1
- package/models/report-builder-dashboard-builder.model.js.map +1 -1
- package/models/report-builder-library.model.js +3 -1
- package/models/report-builder-library.model.js.map +1 -1
- package/models/report-builder-report.model.js +3 -1
- package/models/report-builder-report.model.js.map +1 -1
- package/models/report-builder.model.js +3 -1
- package/models/report-builder.model.js.map +1 -1
- package/models/select-data-label.model.js +3 -1
- package/models/select-data-label.model.js.map +1 -1
- package/models/server-message.model.js +3 -1
- package/models/server-message.model.js.map +1 -1
- package/models/subscription.model.js +3 -1
- package/models/subscription.model.js.map +1 -1
- package/models/support-ticket.model.js +3 -1
- package/models/support-ticket.model.js.map +1 -1
- package/models/user-group.model.js +3 -1
- package/models/user-group.model.js.map +1 -1
- package/models/user-guide.model.js +3 -1
- package/models/user-guide.model.js.map +1 -1
- package/models/user.model.js +3 -1
- package/models/user.model.js.map +1 -1
- package/package.json +1 -1
- package/public_api.js +77 -1
- package/public_api.js.map +1 -1
- package/publications/app-status.js +16 -1
- package/publications/app-status.js.map +1 -1
- package/publications/cron-jobs.js +32 -1
- package/publications/cron-jobs.js.map +1 -1
- package/publications/files.js +36 -1
- package/publications/files.js.map +1 -1
- package/publications/flags-update.js +22 -1
- package/publications/flags-update.js.map +1 -1
- package/publications/flags.js +22 -1
- package/publications/flags.js.map +1 -1
- package/publications/logs.js +164 -1
- package/publications/logs.js.map +1 -1
- package/publications/notifications.js +16 -1
- package/publications/notifications.js.map +1 -1
- package/publications/report-builder-dashboard-builders.js +42 -1
- package/publications/report-builder-dashboard-builders.js.map +1 -1
- package/publications/report-builder-libraries.js +90 -1
- package/publications/report-builder-libraries.js.map +1 -1
- package/publications/report-builder-reports.js +50 -1
- package/publications/report-builder-reports.js.map +1 -1
- package/publications/super-admin.js +16 -1
- package/publications/super-admin.js.map +1 -1
- package/publications/user-groups.js +16 -1
- package/publications/user-groups.js.map +1 -1
- package/publications/user-guides.js +16 -1
- package/publications/user-guides.js.map +1 -1
- package/resolveio-server-app.js +176 -1
- package/resolveio-server-app.js.map +1 -1
- package/server-app.js +1159 -1
- package/server-app.js.map +1 -1
- package/util/common.js +632 -1
- package/util/common.js.map +1 -1
- package/util/schema-report-builder.js +454 -1
- package/util/schema-report-builder.js.map +1 -1
package/methods/aws.js
CHANGED
|
@@ -1,2 +1,749 @@
|
|
|
1
|
-
"use strict";var __awaiter=this&&this.__awaiter||function(e,n,i,s){return new(i=i||Promise)(function(r,t){function fulfilled(e){try{step(s.next(e))}catch(e){t(e)}}function rejected(e){try{step(s.throw(e))}catch(e){t(e)}}function step(e){var t;e.done?r(e.value):((t=e.value)instanceof i?t:new i(function(e){e(t)})).then(fulfilled,rejected)}step((s=s.apply(e,n||[])).next())})},__generator=this&&this.__generator||function(n,i){var s,a,l,o={label:0,sent:function(){if(1&l[0])throw l[1];return l[1]},trys:[],ops:[]},c={next:verb(0),throw:verb(1),return:verb(2)};return"function"==typeof Symbol&&(c[Symbol.iterator]=function(){return this}),c;function verb(r){return function(e){var t=[r,e];if(s)throw new TypeError("Generator is already executing.");for(;o=c&&t[c=0]?0:o;)try{if(s=1,a&&(l=2&t[0]?a.return:t[0]?a.throw||((l=a.return)&&l.call(a),0):a.next)&&!(l=l.call(a,t[1])).done)return l;switch(a=0,(t=l?[2&t[0],l.value]:t)[0]){case 0:case 1:l=t;break;case 4:return o.label++,{value:t[1],done:!1};case 5:o.label++,a=t[1],t=[0];continue;case 7:t=o.ops.pop(),o.trys.pop();continue;default:if(!(l=0<(l=o.trys).length&&l[l.length-1])&&(6===t[0]||2===t[0])){o=0;continue}if(3===t[0]&&(!l||t[1]>l[0]&&t[1]<l[3]))o.label=t[1];else if(6===t[0]&&o.label<l[1])o.label=l[1],l=t;else{if(!(l&&o.label<l[2])){l[2]&&o.ops.pop(),o.trys.pop();continue}o.label=l[2],o.ops.push(t)}}t=i.call(n,o)}catch(e){t=[6,e],a=0}finally{s=l=0}if(5&t[0])throw t[1];return{value:t[0]?t[1]:void 0,done:!0}}}},__values=this&&this.__values||function(e){var t="function"==typeof Symbol&&Symbol.iterator,r=t&&e[t],n=0;if(r)return r.call(e);if(e&&"number"==typeof e.length)return{next:function(){return{value:(e=e&&n>=e.length?void 0:e)&&e[n++],done:!e}}};throw new TypeError(t?"Object is not iterable.":"Symbol.iterator is not defined.")},client_s3_1=(Object.defineProperty(exports,"__esModule",{value:!0}),exports.loadAWSMethods=void 0,require("@aws-sdk/client-s3")),s3_request_presigner_1=require("@aws-sdk/s3-request-presigner"),axios_1=require("axios"),simpl_schema_1=require("simpl-schema"),file_collection_1=require("../collections/file.collection"),resolveio_server_app_1=require("../resolveio-server-app"),common_1=require("../util/common"),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,o,c,u,_,e){return __awaiter(this,void 0,void 0,function(){var n,i,s,a,t,r;return __generator(this,function(e){switch(e.label){case 0:if(!l)throw new Error("Invalid File Name provided");n="uploads/"+Date.now()+"-"+pdfCnt+++"-"+l,i=this.getAWS().s3(),s=3,a=0,t=function(){var t,r;return __generator(this,function(e){switch(e.label){case 0:return e.trys.push([0,2,,6]),[4,i.putObject({Bucket:process.env.AWS_S3_BUCKET,Key:n,Body:Buffer.from(o.replace("data:"+o.split(",")[0].split(":")[1].split(";")[0]+";base64,",""),"base64"),ACL:"private",ContentType:o.split(",")[0].split(":")[1].split(";")[0],ContentDisposition:"inline"})];case 1:return e.sent()?[2,{value:file_collection_1.Files.create({_id:(0,common_1.objectIdHexString)(),__v:0,name:l,size:c,key:n,order:u,type:_})}]:[2,{value:null}];case 2:return(t=e.sent(),++a<=s)?(r=1e3*Math.pow(2,a),console.warn("Attempt ".concat(a," failed. Retrying in ").concat(r/1e3," seconds...")),[4,new Promise(function(e){return setTimeout(e,r)})]):[3,4];case 3:return e.sent(),[3,5];case 4:throw new Error("Error in AWS Upload File And Save: Failed to upload after ".concat(s," attempts: ").concat(t.message));case 5:return[3,6];case 6:return[2]}})},e.label=1;case 1:return a<=s?[5,t()]:[3,3];case 2:return"object"==typeof(r=e.sent())?[2,r.value]:[3,1];case 3:return[2,null]}})})}},uploadNonPDFFileAndSave:{check:new simpl_schema_1.default({fileName:{type:String},fileData:{type:String},fileSize:{type:Number},fileOrder:{type:Number},fileType:{type:String}}),function:function(i,s,a,l,o){return __awaiter(this,void 0,void 0,function(){var t,r,n;return __generator(this,function(e){switch(e.label){case 0:if(!i)throw new Error("Invalid File Name provided");t="uploads/"+Date.now()+"-"+i,r=this.getAWS().s3(),e.label=1;case 1:return e.trys.push([1,3,,4]),[4,r.putObject({Bucket:process.env.AWS_S3_BUCKET,Key:t,Body:Buffer.from(s),ACL:"private",ContentType:"application/gzip",ContentDisposition:"inline"})];case 2:return e.sent()?[2,file_collection_1.Files.create({_id:(0,common_1.objectIdHexString)(),__v:0,name:i,size:a,key:t,order:l,type:o})]:[2,null];case 3:throw(n=e.sent()).mesage="Error In AWS Upload Non PDF File And Save: "+n.mesage,n;case 4:return[2]}})})}},uploadNonPDFBufferAndSave:{check:new simpl_schema_1.default({fileName:{type:String},fileDataBuffer:{type:Buffer},fileSize:{type:Number},fileOrder:{type:Number},fileType:{type:String}}),function:function(i,s,a,l,o){return __awaiter(this,void 0,void 0,function(){var t,r,n;return __generator(this,function(e){switch(e.label){case 0:if(!i)throw new Error("Invalid File Name provided");t="uploads/"+Date.now()+"-"+i,r=this.getAWS().s3(),e.label=1;case 1:return e.trys.push([1,3,,4]),[4,r.putObject({Bucket:process.env.AWS_S3_BUCKET,Key:t,Body:s,ACL:"private",ContentType:"application/gzip",ContentDisposition:"inline"})];case 2:return e.sent()?[2,file_collection_1.Files.create({_id:(0,common_1.objectIdHexString)(),__v:0,name:i,size:a,key:t,order:l,type:o})]:[2,null];case 3:throw(n=e.sent()).mesage="Error In AWS Upload Non PDF Buffer And Save: "+n.mesage,n;case 4:return[2]}})})}},uploadNonPDFStreamAndSave:{check:new simpl_schema_1.default({fileName:{type:String},fileData:{type:String},fileOrder:{type:Number},fileType:{type:String}}),function:function(i,s,a,l){return __awaiter(this,void 0,void 0,function(){var t,r,n;return __generator(this,function(e){switch(e.label){case 0:if(!i)throw new Error("Invalid File Name provided");t="uploads/"+Date.now()+"-"+i,r=this.getAWS().s3(),e.label=1;case 1:return e.trys.push([1,3,,4]),[4,r.putObject({Bucket:process.env.AWS_S3_BUCKET,Key:t,Body:fs.createReadStream(s),ACL:"private",ContentType:"application/gzip",ContentDisposition:"inline"})];case 2:return e.sent()?[2,file_collection_1.Files.create({_id:(0,common_1.objectIdHexString)(),__v:0,name:i,size:1,key:t,order:a,type:l})]:[2,null];case 3:throw(n=e.sent()).mesage="Error In AWS Upload Non PDF Stream And Save: "+n.mesage,n;case 4:return[2]}})})}},deleteFiles:{check:new simpl_schema_1.default({keys:{type:Array},"keys.$":{type:String}}),function:function(u){return __awaiter(this,void 0,void 0,function(){var t,r,n,i,s,a,l,o,c;return __generator(this,function(e){switch(e.label){case 0:return[4,file_collection_1.Files.find({key:{$in:u}})];case 1:t=e.sent(),r=t.length,e.label=2;case 2:e.trys.push([2,10,11,12]),n=__values(t),i=n.next(),e.label=3;case 3:return i.done?[3,9]:(s=i.value,[4,file_collection_1.Files.deleteOne({_id:s._id})]);case 4:e.sent(),a=this.getAWS().s3(),e.label=5;case 5:return e.trys.push([5,7,,8]),[4,a.deleteObject({Bucket:process.env.AWS_S3_BUCKET,Key:s.key})];case 6:return e.sent()&&!--r?[2,t.length]:[3,8];case 7:throw(l=e.sent()).mesage="Error In AWS Delete Files: "+l.mesage,l;case 8:return i=n.next(),[3,3];case 9:return[3,12];case 10:return l=e.sent(),o={error:l},[3,12];case 11:try{i&&!i.done&&(c=n.return)&&c.call(n)}finally{if(o)throw o.error}return[7];case 12:return[2,0]}})})}},deleteFile:{check:new simpl_schema_1.default({key:{type:String}}),function:function(i){return __awaiter(this,void 0,void 0,function(){var t,r,n;return __generator(this,function(e){switch(e.label){case 0:return[4,file_collection_1.Files.findOne({key:i})];case 1:if(!(t=e.sent()))return[3,5];e.label=2;case 2:return e.trys.push([2,4,,5]),[4,file_collection_1.Files.deleteOne({_id:t._id})];case 3:return e.sent(),[3,5];case 4:throw(n=e.sent()).mesage="Error In AWS Delete File (Resolve Side): "+n.mesage,n;case 5:r=this.getAWS().s3(),e.label=6;case 6:return e.trys.push([6,8,,9]),[4,r.deleteObject({Bucket:process.env.AWS_S3_BUCKET,Key:i})];case 7:return[2,e.sent()];case 8:throw(n=e.sent()).mesage="Error In AWS Delete File (AWS Side): "+n.mesage,n;case 9:return[2]}})})}},deleteFileWithId:{check:new simpl_schema_1.default({id_file:{type:String}}),function:function(i){return __awaiter(this,void 0,void 0,function(){var t,r,n;return __generator(this,function(e){switch(e.label){case 0:return[4,file_collection_1.Files.findOne({_id:i})];case 1:if(!(t=e.sent()))throw new Error("Error in AWS Delete File With ID: Could not find file");e.label=2;case 2:return e.trys.push([2,4,,5]),[4,file_collection_1.Files.deleteOne({_id:t._id})];case 3:return e.sent(),[3,5];case 4:throw(n=e.sent()).mesage="Error In AWS Delete File With ID (Resolve Side): "+n.mesage,n;case 5:r=this.getAWS().s3(),e.label=6;case 6:return e.trys.push([6,8,,9]),[4,r.deleteObject({Bucket:process.env.AWS_S3_BUCKET,Key:t.key})];case 7:return[2,e.sent()];case 8:throw(n=e.sent()).mesage="Error In AWS Delete File With ID (AWS Side): "+n.mesage,n;case 9:return[2]}})})}},getSignedUrlsAndFilesWithId:{check:new simpl_schema_1.default({ids:{type:Array},"ids.$":{type:String},expires:{type:Number}}),function:function(o,c){return __awaiter(this,void 0,void 0,function(){var t,r,n,i,s,a,l;return __generator(this,function(e){switch(e.label){case 0:return t=[],[4,file_collection_1.Files.find({_id:{$in:o}})];case 1:r=e.sent(),n=0,e.label=2;case 2:return n<r.length?(s=r[n],i=this.getAWS().s3(),s=new client_s3_1.GetObjectCommand({Bucket:process.env.AWS_S3_BUCKET,Key:s.key}),l=(a=t).push,[4,(0,s3_request_presigner_1.getSignedUrl)(i,s,{expiresIn:c})]):[3,5];case 3:l.apply(a,[e.sent()]),e.label=4;case 4:return n++,[3,2];case 5:return[2,{res:t,fileArray:r.map(function(e){return e.name})}]}})})}},getSignedUrlWithId:{check:new simpl_schema_1.default({id_file:{type:String},expires:{type:Number}}),function:function(n,i){return __awaiter(this,void 0,void 0,function(){var t,r;return __generator(this,function(e){switch(e.label){case 0:return[4,file_collection_1.Files.findOne({_id:n})];case 1:return r=e.sent(),t=this.getAWS().s3(),r=new client_s3_1.GetObjectCommand({Bucket:process.env.AWS_S3_BUCKET,Key:r.key}),[2,(0,s3_request_presigner_1.getSignedUrl)(t,r,{expiresIn:i})]}})})}},getSignedUrlUSEast1BucketAndKey:{check:new simpl_schema_1.default({bucket:{type:String},key:{type:String},expires:{type:Number}}),function:function(e,t,r){var n=this.getAWS().s3USEast1(),e=new client_s3_1.GetObjectCommand({Bucket:e,Key:t});return(0,s3_request_presigner_1.getSignedUrl)(n,e,{expiresIn:r})}},getSignedUrl:{check:new simpl_schema_1.default({key:{type:String},expires:{type:Number}}),function:function(e,t){var r=this.getAWS().s3(),e=new client_s3_1.GetObjectCommand({Bucket:process.env.AWS_S3_BUCKET,Key:e});return(0,s3_request_presigner_1.getSignedUrl)(r,e,{expiresIn:t})}},getSignedUrls:{check:new simpl_schema_1.default({keys:{type:Array},"keys.$":{type:String},expires:{type:Number}}),function:function(l,o){return __awaiter(this,void 0,void 0,function(){var t,r,n,i,s,a;return __generator(this,function(e){switch(e.label){case 0:t=[],r=0,e.label=1;case 1:return r<l.length?(i=l[r],n=this.getAWS().s3(),i=new client_s3_1.GetObjectCommand({Bucket:process.env.AWS_S3_BUCKET,Key:i}),a=(s=t).push,[4,(0,s3_request_presigner_1.getSignedUrl)(n,i,{expiresIn:o})]):[3,4];case 2:a.apply(s,[e.sent()]),e.label=3;case 3:return r++,[3,1];case 4:return[2,t]}})})}},getDataURIfromURL:{check:new simpl_schema_1.default({url:{type:String}}),function:function(n){return __awaiter(this,void 0,void 0,function(){var t,r;return __generator(this,function(e){switch(e.label){case 0:return[4,axios_1.default.get(n,{responseType:"arraybuffer"})];case 1:if(200!==(r=e.sent()).status)throw new Error("Error in Get Data URI From URL: Failed to fetch URL, status: ".concat(r.status));return t=r.headers["content-type"],r=Buffer.from(r.data).toString("base64"),[2,"data:".concat(t,";base64,").concat(r)]}})})}},emailFile:{check:new simpl_schema_1.default({id_file:{type:String},email:{type:String},additional_message:{type:String}}),function:function(s,a,l){return __awaiter(this,void 0,void 0,function(){var t,r,n,i;return __generator(this,function(e){switch(e.label){case 0:return[4,file_collection_1.Files.findById(s)];case 1:if(!(t=e.sent()))throw new Error("Error in AWS Email File: Could not find file");e.label=2;case 2:return e.trys.push([2,10,,11]),[4,this.callMethod("getSignedUrl",t.key,259200)];case 3:return(r=e.sent())?t.size<5e6?(n="Attached is the file requested for email.\n"+(""!==l?"\nAdditional Message:\n"+l+"\n":""),[4,this.sendEmail(a,resolveio_server_app_1.ResolveIOServer.getClientName()+" File - "+t.name,n,"",[{filename:t.name,path:r}],null,"")]):[3,5]:[3,8];case 4:return e.sent(),[3,7];case 5:return n="Please click the link to the requested file.\n"+(""!==l?"\nAdditional Message:\n"+l+"\n":""),[4,this.sendEmail(a,resolveio_server_app_1.ResolveIOServer.getClientName()+" File - "+t.name,n+r,"",null,null,"")];case 6:e.sent(),e.label=7;case 7:return[2,!0];case 8:throw new Error("Error in AWS Email File: Could not get file URL");case 9:return[3,11];case 10:throw(i=e.sent()).mesage="Error In AWS Email File: "+i.mesage,i;case 11:return[2]}})})}}})}exports.loadAWSMethods=loadAWSMethods;
|
|
1
|
+
"use strict";
|
|
2
|
+
var __awaiter = (this && this.__awaiter) || function (thisArg, _arguments, P, generator) {
|
|
3
|
+
function adopt(value) { return value instanceof P ? value : new P(function (resolve) { resolve(value); }); }
|
|
4
|
+
return new (P || (P = Promise))(function (resolve, reject) {
|
|
5
|
+
function fulfilled(value) { try { step(generator.next(value)); } catch (e) { reject(e); } }
|
|
6
|
+
function rejected(value) { try { step(generator["throw"](value)); } catch (e) { reject(e); } }
|
|
7
|
+
function step(result) { result.done ? resolve(result.value) : adopt(result.value).then(fulfilled, rejected); }
|
|
8
|
+
step((generator = generator.apply(thisArg, _arguments || [])).next());
|
|
9
|
+
});
|
|
10
|
+
};
|
|
11
|
+
var __generator = (this && this.__generator) || function (thisArg, body) {
|
|
12
|
+
var _ = { label: 0, sent: function() { if (t[0] & 1) throw t[1]; return t[1]; }, trys: [], ops: [] }, f, y, t, g;
|
|
13
|
+
return g = { next: verb(0), "throw": verb(1), "return": verb(2) }, typeof Symbol === "function" && (g[Symbol.iterator] = function() { return this; }), g;
|
|
14
|
+
function verb(n) { return function (v) { return step([n, v]); }; }
|
|
15
|
+
function step(op) {
|
|
16
|
+
if (f) throw new TypeError("Generator is already executing.");
|
|
17
|
+
while (g && (g = 0, op[0] && (_ = 0)), _) try {
|
|
18
|
+
if (f = 1, y && (t = op[0] & 2 ? y["return"] : op[0] ? y["throw"] || ((t = y["return"]) && t.call(y), 0) : y.next) && !(t = t.call(y, op[1])).done) return t;
|
|
19
|
+
if (y = 0, t) op = [op[0] & 2, t.value];
|
|
20
|
+
switch (op[0]) {
|
|
21
|
+
case 0: case 1: t = op; break;
|
|
22
|
+
case 4: _.label++; return { value: op[1], done: false };
|
|
23
|
+
case 5: _.label++; y = op[1]; op = [0]; continue;
|
|
24
|
+
case 7: op = _.ops.pop(); _.trys.pop(); continue;
|
|
25
|
+
default:
|
|
26
|
+
if (!(t = _.trys, t = t.length > 0 && t[t.length - 1]) && (op[0] === 6 || op[0] === 2)) { _ = 0; continue; }
|
|
27
|
+
if (op[0] === 3 && (!t || (op[1] > t[0] && op[1] < t[3]))) { _.label = op[1]; break; }
|
|
28
|
+
if (op[0] === 6 && _.label < t[1]) { _.label = t[1]; t = op; break; }
|
|
29
|
+
if (t && _.label < t[2]) { _.label = t[2]; _.ops.push(op); break; }
|
|
30
|
+
if (t[2]) _.ops.pop();
|
|
31
|
+
_.trys.pop(); continue;
|
|
32
|
+
}
|
|
33
|
+
op = body.call(thisArg, _);
|
|
34
|
+
} catch (e) { op = [6, e]; y = 0; } finally { f = t = 0; }
|
|
35
|
+
if (op[0] & 5) throw op[1]; return { value: op[0] ? op[1] : void 0, done: true };
|
|
36
|
+
}
|
|
37
|
+
};
|
|
38
|
+
var __values = (this && this.__values) || function(o) {
|
|
39
|
+
var s = typeof Symbol === "function" && Symbol.iterator, m = s && o[s], i = 0;
|
|
40
|
+
if (m) return m.call(o);
|
|
41
|
+
if (o && typeof o.length === "number") return {
|
|
42
|
+
next: function () {
|
|
43
|
+
if (o && i >= o.length) o = void 0;
|
|
44
|
+
return { value: o && o[i++], done: !o };
|
|
45
|
+
}
|
|
46
|
+
};
|
|
47
|
+
throw new TypeError(s ? "Object is not iterable." : "Symbol.iterator is not defined.");
|
|
48
|
+
};
|
|
49
|
+
Object.defineProperty(exports, "__esModule", { value: true });
|
|
50
|
+
exports.loadAWSMethods = void 0;
|
|
51
|
+
var client_s3_1 = require("@aws-sdk/client-s3");
|
|
52
|
+
var s3_request_presigner_1 = require("@aws-sdk/s3-request-presigner");
|
|
53
|
+
var axios_1 = require("axios");
|
|
54
|
+
var simpl_schema_1 = require("simpl-schema");
|
|
55
|
+
var file_collection_1 = require("../collections/file.collection");
|
|
56
|
+
var resolveio_server_app_1 = require("../resolveio-server-app");
|
|
57
|
+
var common_1 = require("../util/common");
|
|
58
|
+
var fs = require('fs');
|
|
59
|
+
var pdfCnt = 1000000;
|
|
60
|
+
function loadAWSMethods(methodManager) {
|
|
61
|
+
methodManager.methods({
|
|
62
|
+
uploadFileAndSave: {
|
|
63
|
+
check: new simpl_schema_1.default({
|
|
64
|
+
fileName: {
|
|
65
|
+
type: String
|
|
66
|
+
},
|
|
67
|
+
fileData: {
|
|
68
|
+
type: String
|
|
69
|
+
},
|
|
70
|
+
fileSize: {
|
|
71
|
+
type: Number
|
|
72
|
+
},
|
|
73
|
+
fileOrder: {
|
|
74
|
+
type: Number
|
|
75
|
+
},
|
|
76
|
+
fileType: {
|
|
77
|
+
type: String
|
|
78
|
+
},
|
|
79
|
+
compress: {
|
|
80
|
+
type: Boolean
|
|
81
|
+
}
|
|
82
|
+
}),
|
|
83
|
+
// eslint-disable-next-line no-unused-vars
|
|
84
|
+
function: function (fileName, fileData, fileSize, fileOrder, fileType, compress) {
|
|
85
|
+
return __awaiter(this, void 0, void 0, function () {
|
|
86
|
+
var key, s3, maxRetries, attempt, _loop_1, state_1;
|
|
87
|
+
return __generator(this, function (_a) {
|
|
88
|
+
switch (_a.label) {
|
|
89
|
+
case 0:
|
|
90
|
+
if (!fileName) {
|
|
91
|
+
throw new Error("Invalid File Name provided");
|
|
92
|
+
}
|
|
93
|
+
key = 'uploads/' + Date.now() + '-' + (pdfCnt++) + '-' + fileName;
|
|
94
|
+
s3 = this.getAWS().s3();
|
|
95
|
+
maxRetries = 3;
|
|
96
|
+
attempt = 0;
|
|
97
|
+
_loop_1 = function () {
|
|
98
|
+
var res, err_1, backoff_1;
|
|
99
|
+
return __generator(this, function (_b) {
|
|
100
|
+
switch (_b.label) {
|
|
101
|
+
case 0:
|
|
102
|
+
_b.trys.push([0, 2, , 6]);
|
|
103
|
+
return [4 /*yield*/, s3.putObject({
|
|
104
|
+
Bucket: process.env.AWS_S3_BUCKET,
|
|
105
|
+
Key: key,
|
|
106
|
+
Body: Buffer.from(fileData.replace('data:' + fileData.split(',')[0].split(':')[1].split(';')[0] + ';base64,', ''), 'base64'),
|
|
107
|
+
ACL: 'private',
|
|
108
|
+
ContentType: fileData.split(',')[0].split(':')[1].split(';')[0],
|
|
109
|
+
ContentDisposition: 'inline'
|
|
110
|
+
})];
|
|
111
|
+
case 1:
|
|
112
|
+
res = _b.sent();
|
|
113
|
+
if (res) {
|
|
114
|
+
return [2 /*return*/, { value: file_collection_1.Files.create({
|
|
115
|
+
_id: (0, common_1.objectIdHexString)(), __v: 0, name: fileName, size: fileSize, key: key, order: fileOrder, type: fileType
|
|
116
|
+
}) }];
|
|
117
|
+
}
|
|
118
|
+
else {
|
|
119
|
+
return [2 /*return*/, { value: null }];
|
|
120
|
+
}
|
|
121
|
+
return [3 /*break*/, 6];
|
|
122
|
+
case 2:
|
|
123
|
+
err_1 = _b.sent();
|
|
124
|
+
attempt++;
|
|
125
|
+
if (!(attempt <= maxRetries)) return [3 /*break*/, 4];
|
|
126
|
+
backoff_1 = Math.pow(2, attempt) * 1000;
|
|
127
|
+
console.warn("Attempt ".concat(attempt, " failed. Retrying in ").concat(backoff_1 / 1000, " seconds..."));
|
|
128
|
+
// eslint-disable-next-line no-restricted-syntax
|
|
129
|
+
return [4 /*yield*/, new Promise(function (resolve) { return setTimeout(resolve, backoff_1); })];
|
|
130
|
+
case 3:
|
|
131
|
+
// eslint-disable-next-line no-restricted-syntax
|
|
132
|
+
_b.sent();
|
|
133
|
+
return [3 /*break*/, 5];
|
|
134
|
+
case 4: throw new Error("Error in AWS Upload File And Save: Failed to upload after ".concat(maxRetries, " attempts: ").concat(err_1.message));
|
|
135
|
+
case 5: return [3 /*break*/, 6];
|
|
136
|
+
case 6: return [2 /*return*/];
|
|
137
|
+
}
|
|
138
|
+
});
|
|
139
|
+
};
|
|
140
|
+
_a.label = 1;
|
|
141
|
+
case 1:
|
|
142
|
+
if (!(attempt <= maxRetries)) return [3 /*break*/, 3];
|
|
143
|
+
return [5 /*yield**/, _loop_1()];
|
|
144
|
+
case 2:
|
|
145
|
+
state_1 = _a.sent();
|
|
146
|
+
if (typeof state_1 === "object")
|
|
147
|
+
return [2 /*return*/, state_1.value];
|
|
148
|
+
return [3 /*break*/, 1];
|
|
149
|
+
case 3: return [2 /*return*/, null];
|
|
150
|
+
}
|
|
151
|
+
});
|
|
152
|
+
});
|
|
153
|
+
}
|
|
154
|
+
},
|
|
155
|
+
uploadNonPDFFileAndSave: {
|
|
156
|
+
check: new simpl_schema_1.default({
|
|
157
|
+
fileName: {
|
|
158
|
+
type: String
|
|
159
|
+
},
|
|
160
|
+
fileData: {
|
|
161
|
+
type: String
|
|
162
|
+
},
|
|
163
|
+
fileSize: {
|
|
164
|
+
type: Number
|
|
165
|
+
},
|
|
166
|
+
fileOrder: {
|
|
167
|
+
type: Number
|
|
168
|
+
},
|
|
169
|
+
fileType: {
|
|
170
|
+
type: String
|
|
171
|
+
}
|
|
172
|
+
}),
|
|
173
|
+
function: function (fileName, fileData, fileSize, fileOrder, fileType) {
|
|
174
|
+
return __awaiter(this, void 0, void 0, function () {
|
|
175
|
+
var key, s3, res, err_2;
|
|
176
|
+
return __generator(this, function (_a) {
|
|
177
|
+
switch (_a.label) {
|
|
178
|
+
case 0:
|
|
179
|
+
if (!fileName) {
|
|
180
|
+
throw new Error("Invalid File Name provided");
|
|
181
|
+
}
|
|
182
|
+
key = 'uploads/' + Date.now() + '-' + fileName;
|
|
183
|
+
s3 = this.getAWS().s3();
|
|
184
|
+
_a.label = 1;
|
|
185
|
+
case 1:
|
|
186
|
+
_a.trys.push([1, 3, , 4]);
|
|
187
|
+
return [4 /*yield*/, s3.putObject({
|
|
188
|
+
Bucket: process.env.AWS_S3_BUCKET,
|
|
189
|
+
Key: key,
|
|
190
|
+
Body: Buffer.from(fileData),
|
|
191
|
+
ACL: 'private',
|
|
192
|
+
ContentType: 'application/gzip',
|
|
193
|
+
ContentDisposition: 'inline'
|
|
194
|
+
})];
|
|
195
|
+
case 2:
|
|
196
|
+
res = _a.sent();
|
|
197
|
+
if (res) {
|
|
198
|
+
return [2 /*return*/, file_collection_1.Files.create({
|
|
199
|
+
_id: (0, common_1.objectIdHexString)(), __v: 0, name: fileName, size: fileSize, key: key, order: fileOrder, type: fileType
|
|
200
|
+
})];
|
|
201
|
+
}
|
|
202
|
+
else {
|
|
203
|
+
return [2 /*return*/, null];
|
|
204
|
+
}
|
|
205
|
+
return [3 /*break*/, 4];
|
|
206
|
+
case 3:
|
|
207
|
+
err_2 = _a.sent();
|
|
208
|
+
err_2.mesage = 'Error In AWS Upload Non PDF File And Save: ' + err_2.mesage;
|
|
209
|
+
throw err_2;
|
|
210
|
+
case 4: return [2 /*return*/];
|
|
211
|
+
}
|
|
212
|
+
});
|
|
213
|
+
});
|
|
214
|
+
}
|
|
215
|
+
},
|
|
216
|
+
uploadNonPDFBufferAndSave: {
|
|
217
|
+
check: new simpl_schema_1.default({
|
|
218
|
+
fileName: {
|
|
219
|
+
type: String
|
|
220
|
+
},
|
|
221
|
+
fileDataBuffer: {
|
|
222
|
+
type: Buffer
|
|
223
|
+
},
|
|
224
|
+
fileSize: {
|
|
225
|
+
type: Number
|
|
226
|
+
},
|
|
227
|
+
fileOrder: {
|
|
228
|
+
type: Number
|
|
229
|
+
},
|
|
230
|
+
fileType: {
|
|
231
|
+
type: String
|
|
232
|
+
}
|
|
233
|
+
}),
|
|
234
|
+
function: function (fileName, fileDataBuffer, fileSize, fileOrder, fileType) {
|
|
235
|
+
return __awaiter(this, void 0, void 0, function () {
|
|
236
|
+
var key, s3, res, err_3;
|
|
237
|
+
return __generator(this, function (_a) {
|
|
238
|
+
switch (_a.label) {
|
|
239
|
+
case 0:
|
|
240
|
+
if (!fileName) {
|
|
241
|
+
throw new Error("Invalid File Name provided");
|
|
242
|
+
}
|
|
243
|
+
key = 'uploads/' + Date.now() + '-' + fileName;
|
|
244
|
+
s3 = this.getAWS().s3();
|
|
245
|
+
_a.label = 1;
|
|
246
|
+
case 1:
|
|
247
|
+
_a.trys.push([1, 3, , 4]);
|
|
248
|
+
return [4 /*yield*/, s3.putObject({
|
|
249
|
+
Bucket: process.env.AWS_S3_BUCKET,
|
|
250
|
+
Key: key,
|
|
251
|
+
Body: fileDataBuffer,
|
|
252
|
+
ACL: 'private',
|
|
253
|
+
ContentType: 'application/gzip',
|
|
254
|
+
ContentDisposition: 'inline'
|
|
255
|
+
})];
|
|
256
|
+
case 2:
|
|
257
|
+
res = _a.sent();
|
|
258
|
+
if (res) {
|
|
259
|
+
return [2 /*return*/, file_collection_1.Files.create({
|
|
260
|
+
_id: (0, common_1.objectIdHexString)(), __v: 0, name: fileName, size: fileSize, key: key, order: fileOrder, type: fileType
|
|
261
|
+
})];
|
|
262
|
+
}
|
|
263
|
+
else {
|
|
264
|
+
return [2 /*return*/, null];
|
|
265
|
+
}
|
|
266
|
+
return [3 /*break*/, 4];
|
|
267
|
+
case 3:
|
|
268
|
+
err_3 = _a.sent();
|
|
269
|
+
err_3.mesage = 'Error In AWS Upload Non PDF Buffer And Save: ' + err_3.mesage;
|
|
270
|
+
throw err_3;
|
|
271
|
+
case 4: return [2 /*return*/];
|
|
272
|
+
}
|
|
273
|
+
});
|
|
274
|
+
});
|
|
275
|
+
}
|
|
276
|
+
},
|
|
277
|
+
uploadNonPDFStreamAndSave: {
|
|
278
|
+
check: new simpl_schema_1.default({
|
|
279
|
+
fileName: {
|
|
280
|
+
type: String
|
|
281
|
+
},
|
|
282
|
+
fileData: {
|
|
283
|
+
type: String
|
|
284
|
+
},
|
|
285
|
+
fileOrder: {
|
|
286
|
+
type: Number
|
|
287
|
+
},
|
|
288
|
+
fileType: {
|
|
289
|
+
type: String
|
|
290
|
+
}
|
|
291
|
+
}),
|
|
292
|
+
function: function (fileName, fileData, fileOrder, fileType) {
|
|
293
|
+
return __awaiter(this, void 0, void 0, function () {
|
|
294
|
+
var key, s3, res, err_4;
|
|
295
|
+
return __generator(this, function (_a) {
|
|
296
|
+
switch (_a.label) {
|
|
297
|
+
case 0:
|
|
298
|
+
if (!fileName) {
|
|
299
|
+
throw new Error("Invalid File Name provided");
|
|
300
|
+
}
|
|
301
|
+
key = 'uploads/' + Date.now() + '-' + fileName;
|
|
302
|
+
s3 = this.getAWS().s3();
|
|
303
|
+
_a.label = 1;
|
|
304
|
+
case 1:
|
|
305
|
+
_a.trys.push([1, 3, , 4]);
|
|
306
|
+
return [4 /*yield*/, s3.putObject({
|
|
307
|
+
Bucket: process.env.AWS_S3_BUCKET,
|
|
308
|
+
Key: key,
|
|
309
|
+
Body: fs.createReadStream(fileData),
|
|
310
|
+
ACL: 'private',
|
|
311
|
+
ContentType: 'application/gzip',
|
|
312
|
+
ContentDisposition: 'inline'
|
|
313
|
+
})];
|
|
314
|
+
case 2:
|
|
315
|
+
res = _a.sent();
|
|
316
|
+
if (res) {
|
|
317
|
+
return [2 /*return*/, file_collection_1.Files.create({
|
|
318
|
+
_id: (0, common_1.objectIdHexString)(), __v: 0, name: fileName, size: 1, key: key, order: fileOrder, type: fileType
|
|
319
|
+
})];
|
|
320
|
+
}
|
|
321
|
+
else {
|
|
322
|
+
return [2 /*return*/, null];
|
|
323
|
+
}
|
|
324
|
+
return [3 /*break*/, 4];
|
|
325
|
+
case 3:
|
|
326
|
+
err_4 = _a.sent();
|
|
327
|
+
err_4.mesage = 'Error In AWS Upload Non PDF Stream And Save: ' + err_4.mesage;
|
|
328
|
+
throw err_4;
|
|
329
|
+
case 4: return [2 /*return*/];
|
|
330
|
+
}
|
|
331
|
+
});
|
|
332
|
+
});
|
|
333
|
+
}
|
|
334
|
+
},
|
|
335
|
+
deleteFiles: {
|
|
336
|
+
check: new simpl_schema_1.default({
|
|
337
|
+
keys: {
|
|
338
|
+
type: Array
|
|
339
|
+
},
|
|
340
|
+
'keys.$': {
|
|
341
|
+
type: String
|
|
342
|
+
}
|
|
343
|
+
}),
|
|
344
|
+
function: function (keys) {
|
|
345
|
+
return __awaiter(this, void 0, void 0, function () {
|
|
346
|
+
var files, deleteCnt, files_1, files_1_1, file, s3, res, err_5, e_1_1;
|
|
347
|
+
var e_1, _a;
|
|
348
|
+
return __generator(this, function (_b) {
|
|
349
|
+
switch (_b.label) {
|
|
350
|
+
case 0: return [4 /*yield*/, file_collection_1.Files.find({ key: { $in: keys } })];
|
|
351
|
+
case 1:
|
|
352
|
+
files = _b.sent();
|
|
353
|
+
deleteCnt = files.length;
|
|
354
|
+
_b.label = 2;
|
|
355
|
+
case 2:
|
|
356
|
+
_b.trys.push([2, 10, 11, 12]);
|
|
357
|
+
files_1 = __values(files), files_1_1 = files_1.next();
|
|
358
|
+
_b.label = 3;
|
|
359
|
+
case 3:
|
|
360
|
+
if (!!files_1_1.done) return [3 /*break*/, 9];
|
|
361
|
+
file = files_1_1.value;
|
|
362
|
+
return [4 /*yield*/, file_collection_1.Files.deleteOne({ _id: file._id })];
|
|
363
|
+
case 4:
|
|
364
|
+
_b.sent();
|
|
365
|
+
s3 = this.getAWS().s3();
|
|
366
|
+
_b.label = 5;
|
|
367
|
+
case 5:
|
|
368
|
+
_b.trys.push([5, 7, , 8]);
|
|
369
|
+
return [4 /*yield*/, s3.deleteObject({
|
|
370
|
+
Bucket: process.env.AWS_S3_BUCKET,
|
|
371
|
+
Key: file.key
|
|
372
|
+
})];
|
|
373
|
+
case 6:
|
|
374
|
+
res = _b.sent();
|
|
375
|
+
if (res) {
|
|
376
|
+
deleteCnt--;
|
|
377
|
+
if (!deleteCnt) {
|
|
378
|
+
return [2 /*return*/, files.length];
|
|
379
|
+
}
|
|
380
|
+
}
|
|
381
|
+
return [3 /*break*/, 8];
|
|
382
|
+
case 7:
|
|
383
|
+
err_5 = _b.sent();
|
|
384
|
+
err_5.mesage = 'Error In AWS Delete Files: ' + err_5.mesage;
|
|
385
|
+
throw err_5;
|
|
386
|
+
case 8:
|
|
387
|
+
files_1_1 = files_1.next();
|
|
388
|
+
return [3 /*break*/, 3];
|
|
389
|
+
case 9: return [3 /*break*/, 12];
|
|
390
|
+
case 10:
|
|
391
|
+
e_1_1 = _b.sent();
|
|
392
|
+
e_1 = { error: e_1_1 };
|
|
393
|
+
return [3 /*break*/, 12];
|
|
394
|
+
case 11:
|
|
395
|
+
try {
|
|
396
|
+
if (files_1_1 && !files_1_1.done && (_a = files_1.return)) _a.call(files_1);
|
|
397
|
+
}
|
|
398
|
+
finally { if (e_1) throw e_1.error; }
|
|
399
|
+
return [7 /*endfinally*/];
|
|
400
|
+
case 12: return [2 /*return*/, 0];
|
|
401
|
+
}
|
|
402
|
+
});
|
|
403
|
+
});
|
|
404
|
+
}
|
|
405
|
+
},
|
|
406
|
+
deleteFile: {
|
|
407
|
+
check: new simpl_schema_1.default({
|
|
408
|
+
key: {
|
|
409
|
+
type: String
|
|
410
|
+
}
|
|
411
|
+
}),
|
|
412
|
+
function: function (key) {
|
|
413
|
+
return __awaiter(this, void 0, void 0, function () {
|
|
414
|
+
var file, err_6, s3, res, err_7;
|
|
415
|
+
return __generator(this, function (_a) {
|
|
416
|
+
switch (_a.label) {
|
|
417
|
+
case 0: return [4 /*yield*/, file_collection_1.Files.findOne({ key: key })];
|
|
418
|
+
case 1:
|
|
419
|
+
file = _a.sent();
|
|
420
|
+
if (!file) return [3 /*break*/, 5];
|
|
421
|
+
_a.label = 2;
|
|
422
|
+
case 2:
|
|
423
|
+
_a.trys.push([2, 4, , 5]);
|
|
424
|
+
return [4 /*yield*/, file_collection_1.Files.deleteOne({ _id: file._id })];
|
|
425
|
+
case 3:
|
|
426
|
+
_a.sent();
|
|
427
|
+
return [3 /*break*/, 5];
|
|
428
|
+
case 4:
|
|
429
|
+
err_6 = _a.sent();
|
|
430
|
+
err_6.mesage = 'Error In AWS Delete File (Resolve Side): ' + err_6.mesage;
|
|
431
|
+
throw err_6;
|
|
432
|
+
case 5:
|
|
433
|
+
s3 = this.getAWS().s3();
|
|
434
|
+
_a.label = 6;
|
|
435
|
+
case 6:
|
|
436
|
+
_a.trys.push([6, 8, , 9]);
|
|
437
|
+
return [4 /*yield*/, s3.deleteObject({
|
|
438
|
+
Bucket: process.env.AWS_S3_BUCKET,
|
|
439
|
+
Key: key
|
|
440
|
+
})];
|
|
441
|
+
case 7:
|
|
442
|
+
res = _a.sent();
|
|
443
|
+
return [2 /*return*/, res];
|
|
444
|
+
case 8:
|
|
445
|
+
err_7 = _a.sent();
|
|
446
|
+
err_7.mesage = 'Error In AWS Delete File (AWS Side): ' + err_7.mesage;
|
|
447
|
+
throw err_7;
|
|
448
|
+
case 9: return [2 /*return*/];
|
|
449
|
+
}
|
|
450
|
+
});
|
|
451
|
+
});
|
|
452
|
+
}
|
|
453
|
+
},
|
|
454
|
+
deleteFileWithId: {
|
|
455
|
+
check: new simpl_schema_1.default({
|
|
456
|
+
id_file: {
|
|
457
|
+
type: String
|
|
458
|
+
}
|
|
459
|
+
}),
|
|
460
|
+
function: function (id_file) {
|
|
461
|
+
return __awaiter(this, void 0, void 0, function () {
|
|
462
|
+
var file, err_8, s3, res, err_9;
|
|
463
|
+
return __generator(this, function (_a) {
|
|
464
|
+
switch (_a.label) {
|
|
465
|
+
case 0: return [4 /*yield*/, file_collection_1.Files.findOne({ _id: id_file })];
|
|
466
|
+
case 1:
|
|
467
|
+
file = _a.sent();
|
|
468
|
+
if (!file) {
|
|
469
|
+
throw new Error('Error in AWS Delete File With ID: Could not find file');
|
|
470
|
+
}
|
|
471
|
+
_a.label = 2;
|
|
472
|
+
case 2:
|
|
473
|
+
_a.trys.push([2, 4, , 5]);
|
|
474
|
+
return [4 /*yield*/, file_collection_1.Files.deleteOne({ _id: file._id })];
|
|
475
|
+
case 3:
|
|
476
|
+
_a.sent();
|
|
477
|
+
return [3 /*break*/, 5];
|
|
478
|
+
case 4:
|
|
479
|
+
err_8 = _a.sent();
|
|
480
|
+
err_8.mesage = 'Error In AWS Delete File With ID (Resolve Side): ' + err_8.mesage;
|
|
481
|
+
throw err_8;
|
|
482
|
+
case 5:
|
|
483
|
+
s3 = this.getAWS().s3();
|
|
484
|
+
_a.label = 6;
|
|
485
|
+
case 6:
|
|
486
|
+
_a.trys.push([6, 8, , 9]);
|
|
487
|
+
return [4 /*yield*/, s3.deleteObject({
|
|
488
|
+
Bucket: process.env.AWS_S3_BUCKET,
|
|
489
|
+
Key: file.key
|
|
490
|
+
})];
|
|
491
|
+
case 7:
|
|
492
|
+
res = _a.sent();
|
|
493
|
+
return [2 /*return*/, res];
|
|
494
|
+
case 8:
|
|
495
|
+
err_9 = _a.sent();
|
|
496
|
+
err_9.mesage = 'Error In AWS Delete File With ID (AWS Side): ' + err_9.mesage;
|
|
497
|
+
throw err_9;
|
|
498
|
+
case 9: return [2 /*return*/];
|
|
499
|
+
}
|
|
500
|
+
});
|
|
501
|
+
});
|
|
502
|
+
}
|
|
503
|
+
},
|
|
504
|
+
getSignedUrlsAndFilesWithId: {
|
|
505
|
+
check: new simpl_schema_1.default({
|
|
506
|
+
ids: {
|
|
507
|
+
type: Array
|
|
508
|
+
},
|
|
509
|
+
'ids.$': {
|
|
510
|
+
type: String
|
|
511
|
+
},
|
|
512
|
+
expires: {
|
|
513
|
+
type: Number
|
|
514
|
+
}
|
|
515
|
+
}),
|
|
516
|
+
function: function (ids, expires) {
|
|
517
|
+
return __awaiter(this, void 0, void 0, function () {
|
|
518
|
+
var res, files, i, file, s3, getCommand, _a, _b;
|
|
519
|
+
return __generator(this, function (_c) {
|
|
520
|
+
switch (_c.label) {
|
|
521
|
+
case 0:
|
|
522
|
+
res = [];
|
|
523
|
+
return [4 /*yield*/, file_collection_1.Files.find({ _id: { $in: ids } })];
|
|
524
|
+
case 1:
|
|
525
|
+
files = _c.sent();
|
|
526
|
+
i = 0;
|
|
527
|
+
_c.label = 2;
|
|
528
|
+
case 2:
|
|
529
|
+
if (!(i < files.length)) return [3 /*break*/, 5];
|
|
530
|
+
file = files[i];
|
|
531
|
+
s3 = this.getAWS().s3();
|
|
532
|
+
getCommand = new client_s3_1.GetObjectCommand({
|
|
533
|
+
Bucket: process.env.AWS_S3_BUCKET,
|
|
534
|
+
Key: file.key
|
|
535
|
+
});
|
|
536
|
+
_b = (_a = res).push;
|
|
537
|
+
return [4 /*yield*/, (0, s3_request_presigner_1.getSignedUrl)(s3, getCommand, { expiresIn: expires })];
|
|
538
|
+
case 3:
|
|
539
|
+
_b.apply(_a, [_c.sent()]);
|
|
540
|
+
_c.label = 4;
|
|
541
|
+
case 4:
|
|
542
|
+
i++;
|
|
543
|
+
return [3 /*break*/, 2];
|
|
544
|
+
case 5: return [2 /*return*/, { res: res, fileArray: files.map(function (a) { return a.name; }) }];
|
|
545
|
+
}
|
|
546
|
+
});
|
|
547
|
+
});
|
|
548
|
+
}
|
|
549
|
+
},
|
|
550
|
+
getSignedUrlWithId: {
|
|
551
|
+
check: new simpl_schema_1.default({
|
|
552
|
+
id_file: {
|
|
553
|
+
type: String
|
|
554
|
+
},
|
|
555
|
+
expires: {
|
|
556
|
+
type: Number
|
|
557
|
+
}
|
|
558
|
+
}),
|
|
559
|
+
function: function (id_file, expires) {
|
|
560
|
+
return __awaiter(this, void 0, void 0, function () {
|
|
561
|
+
var file, s3, getCommand;
|
|
562
|
+
return __generator(this, function (_a) {
|
|
563
|
+
switch (_a.label) {
|
|
564
|
+
case 0: return [4 /*yield*/, file_collection_1.Files.findOne({ _id: id_file })];
|
|
565
|
+
case 1:
|
|
566
|
+
file = _a.sent();
|
|
567
|
+
s3 = this.getAWS().s3();
|
|
568
|
+
getCommand = new client_s3_1.GetObjectCommand({
|
|
569
|
+
Bucket: process.env.AWS_S3_BUCKET,
|
|
570
|
+
Key: file.key
|
|
571
|
+
});
|
|
572
|
+
return [2 /*return*/, (0, s3_request_presigner_1.getSignedUrl)(s3, getCommand, { expiresIn: expires })];
|
|
573
|
+
}
|
|
574
|
+
});
|
|
575
|
+
});
|
|
576
|
+
}
|
|
577
|
+
},
|
|
578
|
+
getSignedUrlUSEast1BucketAndKey: {
|
|
579
|
+
check: new simpl_schema_1.default({
|
|
580
|
+
bucket: {
|
|
581
|
+
type: String
|
|
582
|
+
},
|
|
583
|
+
key: {
|
|
584
|
+
type: String
|
|
585
|
+
},
|
|
586
|
+
expires: {
|
|
587
|
+
type: Number
|
|
588
|
+
}
|
|
589
|
+
}),
|
|
590
|
+
function: function (bucket, key, expires) {
|
|
591
|
+
var s3 = this.getAWS().s3USEast1();
|
|
592
|
+
var getCommand = new client_s3_1.GetObjectCommand({
|
|
593
|
+
Bucket: bucket,
|
|
594
|
+
Key: key
|
|
595
|
+
});
|
|
596
|
+
return (0, s3_request_presigner_1.getSignedUrl)(s3, getCommand, { expiresIn: expires });
|
|
597
|
+
}
|
|
598
|
+
},
|
|
599
|
+
getSignedUrl: {
|
|
600
|
+
check: new simpl_schema_1.default({
|
|
601
|
+
key: {
|
|
602
|
+
type: String
|
|
603
|
+
},
|
|
604
|
+
expires: {
|
|
605
|
+
type: Number
|
|
606
|
+
}
|
|
607
|
+
}),
|
|
608
|
+
function: function (key, expires) {
|
|
609
|
+
var s3 = this.getAWS().s3();
|
|
610
|
+
var getCommand = new client_s3_1.GetObjectCommand({
|
|
611
|
+
Bucket: process.env.AWS_S3_BUCKET,
|
|
612
|
+
Key: key
|
|
613
|
+
});
|
|
614
|
+
return (0, s3_request_presigner_1.getSignedUrl)(s3, getCommand, { expiresIn: expires });
|
|
615
|
+
}
|
|
616
|
+
},
|
|
617
|
+
getSignedUrls: {
|
|
618
|
+
check: new simpl_schema_1.default({
|
|
619
|
+
keys: {
|
|
620
|
+
type: Array
|
|
621
|
+
},
|
|
622
|
+
'keys.$': {
|
|
623
|
+
type: String
|
|
624
|
+
},
|
|
625
|
+
expires: {
|
|
626
|
+
type: Number
|
|
627
|
+
}
|
|
628
|
+
}),
|
|
629
|
+
function: function (keys, expires) {
|
|
630
|
+
return __awaiter(this, void 0, void 0, function () {
|
|
631
|
+
var res, i, key, s3, getCommand, _a, _b;
|
|
632
|
+
return __generator(this, function (_c) {
|
|
633
|
+
switch (_c.label) {
|
|
634
|
+
case 0:
|
|
635
|
+
res = [];
|
|
636
|
+
i = 0;
|
|
637
|
+
_c.label = 1;
|
|
638
|
+
case 1:
|
|
639
|
+
if (!(i < keys.length)) return [3 /*break*/, 4];
|
|
640
|
+
key = keys[i];
|
|
641
|
+
s3 = this.getAWS().s3();
|
|
642
|
+
getCommand = new client_s3_1.GetObjectCommand({
|
|
643
|
+
Bucket: process.env.AWS_S3_BUCKET,
|
|
644
|
+
Key: key
|
|
645
|
+
});
|
|
646
|
+
_b = (_a = res).push;
|
|
647
|
+
return [4 /*yield*/, (0, s3_request_presigner_1.getSignedUrl)(s3, getCommand, { expiresIn: expires })];
|
|
648
|
+
case 2:
|
|
649
|
+
_b.apply(_a, [_c.sent()]);
|
|
650
|
+
_c.label = 3;
|
|
651
|
+
case 3:
|
|
652
|
+
i++;
|
|
653
|
+
return [3 /*break*/, 1];
|
|
654
|
+
case 4: return [2 /*return*/, res];
|
|
655
|
+
}
|
|
656
|
+
});
|
|
657
|
+
});
|
|
658
|
+
}
|
|
659
|
+
},
|
|
660
|
+
getDataURIfromURL: {
|
|
661
|
+
check: new simpl_schema_1.default({
|
|
662
|
+
url: {
|
|
663
|
+
type: String
|
|
664
|
+
}
|
|
665
|
+
}),
|
|
666
|
+
function: function (url) {
|
|
667
|
+
return __awaiter(this, void 0, void 0, function () {
|
|
668
|
+
var response, contentType, dataBase64;
|
|
669
|
+
return __generator(this, function (_a) {
|
|
670
|
+
switch (_a.label) {
|
|
671
|
+
case 0: return [4 /*yield*/, axios_1.default.get(url, {
|
|
672
|
+
responseType: 'arraybuffer'
|
|
673
|
+
})];
|
|
674
|
+
case 1:
|
|
675
|
+
response = _a.sent();
|
|
676
|
+
if (response.status !== 200) {
|
|
677
|
+
throw new Error("Error in Get Data URI From URL: Failed to fetch URL, status: ".concat(response.status));
|
|
678
|
+
}
|
|
679
|
+
contentType = response.headers['content-type'];
|
|
680
|
+
dataBase64 = Buffer.from(response.data).toString('base64');
|
|
681
|
+
return [2 /*return*/, "data:".concat(contentType, ";base64,").concat(dataBase64)];
|
|
682
|
+
}
|
|
683
|
+
});
|
|
684
|
+
});
|
|
685
|
+
}
|
|
686
|
+
},
|
|
687
|
+
emailFile: {
|
|
688
|
+
check: new simpl_schema_1.default({
|
|
689
|
+
id_file: {
|
|
690
|
+
type: String
|
|
691
|
+
},
|
|
692
|
+
email: {
|
|
693
|
+
type: String
|
|
694
|
+
},
|
|
695
|
+
additional_message: {
|
|
696
|
+
type: String
|
|
697
|
+
}
|
|
698
|
+
}),
|
|
699
|
+
function: function (id_file, email, additional_message) {
|
|
700
|
+
return __awaiter(this, void 0, void 0, function () {
|
|
701
|
+
var file, resPDF, emailMessage, emailMessage, err_10;
|
|
702
|
+
return __generator(this, function (_a) {
|
|
703
|
+
switch (_a.label) {
|
|
704
|
+
case 0: return [4 /*yield*/, file_collection_1.Files.findById(id_file)];
|
|
705
|
+
case 1:
|
|
706
|
+
file = _a.sent();
|
|
707
|
+
if (!file) {
|
|
708
|
+
throw new Error('Error in AWS Email File: Could not find file');
|
|
709
|
+
}
|
|
710
|
+
_a.label = 2;
|
|
711
|
+
case 2:
|
|
712
|
+
_a.trys.push([2, 10, , 11]);
|
|
713
|
+
return [4 /*yield*/, this.callMethod('getSignedUrl', file.key, 259200)];
|
|
714
|
+
case 3:
|
|
715
|
+
resPDF = _a.sent();
|
|
716
|
+
if (!resPDF) return [3 /*break*/, 8];
|
|
717
|
+
if (!(file.size < 5000000)) return [3 /*break*/, 5];
|
|
718
|
+
emailMessage = 'Attached is the file requested for email.\n' + (additional_message !== '' ? '\nAdditional Message:\n' + additional_message + '\n' : '');
|
|
719
|
+
return [4 /*yield*/, this.sendEmail(email, resolveio_server_app_1.ResolveIOServer.getClientName() + ' File - ' + file.name, emailMessage, '', [{
|
|
720
|
+
filename: file.name,
|
|
721
|
+
path: resPDF
|
|
722
|
+
}], null, '')];
|
|
723
|
+
case 4:
|
|
724
|
+
_a.sent();
|
|
725
|
+
return [3 /*break*/, 7];
|
|
726
|
+
case 5:
|
|
727
|
+
emailMessage = 'Please click the link to the requested file.\n' + (additional_message !== '' ? '\nAdditional Message:\n' + additional_message + '\n' : '');
|
|
728
|
+
return [4 /*yield*/, this.sendEmail(email, resolveio_server_app_1.ResolveIOServer.getClientName() + ' File - ' + file.name, emailMessage + resPDF, '', null, null, '')];
|
|
729
|
+
case 6:
|
|
730
|
+
_a.sent();
|
|
731
|
+
_a.label = 7;
|
|
732
|
+
case 7: return [2 /*return*/, true];
|
|
733
|
+
case 8: throw new Error('Error in AWS Email File: Could not get file URL');
|
|
734
|
+
case 9: return [3 /*break*/, 11];
|
|
735
|
+
case 10:
|
|
736
|
+
err_10 = _a.sent();
|
|
737
|
+
err_10.mesage = 'Error In AWS Email File: ' + err_10.mesage;
|
|
738
|
+
throw err_10;
|
|
739
|
+
case 11: return [2 /*return*/];
|
|
740
|
+
}
|
|
741
|
+
});
|
|
742
|
+
});
|
|
743
|
+
}
|
|
744
|
+
}
|
|
745
|
+
});
|
|
746
|
+
}
|
|
747
|
+
exports.loadAWSMethods = loadAWSMethods;
|
|
748
|
+
|
|
2
749
|
//# sourceMappingURL=aws.js.map
|