Huge News!Announcing our $40M Series B led by Abstract Ventures.Learn More
Socket
Sign inDemoInstall
Socket

nodemailer-sequelize-queue

Package Overview
Dependencies
Maintainers
1
Versions
23
Alerts
File Explorer

Advanced tools

Socket logo

Install Socket

Detect and block malicious and high-risk dependencies

Install

nodemailer-sequelize-queue - npm Package Compare versions

Comparing version 0.0.16 to 0.0.17

dist/utils/generateRandom.d.ts

3

dist/examples/index.js

@@ -38,2 +38,3 @@ "use strict";

maxAttempts: 2,
logging: true,
});

@@ -57,2 +58,2 @@ // Run cron schedule for sending mail (Only one time in root of the system)

});
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiaW5kZXguanMiLCJzb3VyY2VSb290IjoiIiwic291cmNlcyI6WyIuLi8uLi9zcmMvZXhhbXBsZXMvaW5kZXgudHMiXSwibmFtZXMiOltdLCJtYXBwaW5ncyI6Ijs7Ozs7QUFBQSxxREFBK0M7QUFDL0Msb0RBQTJCO0FBQzNCLGdCQUFNLENBQUMsTUFBTSxFQUFFLENBQUE7QUFFZixNQUFNLElBQUksR0FBRztJQUNYLElBQUksRUFBRSxPQUFPLENBQUMsR0FBRyxDQUFDLFNBQVM7SUFDM0IsSUFBSSxFQUFFLE9BQU8sQ0FBQyxHQUFHLENBQUMsU0FBUztDQUM1QixDQUFBO0FBRUQsZ0VBQWdFO0FBQ2hFLE1BQU0sU0FBUyxHQUFHO0lBQ2hCLElBQUksRUFBRSxPQUFPLENBQUMsR0FBRyxDQUFDLFNBQVM7SUFDM0IsSUFBSSxFQUFFLE9BQU8sQ0FBQyxHQUFHLENBQUMsU0FBUyxDQUFDLENBQUMsQ0FBQyxPQUFPLENBQUMsR0FBRyxDQUFDLFNBQVMsQ0FBQyxDQUFDLENBQUMsR0FBRztJQUN6RCxNQUFNLEVBQUUsSUFBSTtJQUNaLElBQUksRUFBRSxJQUFJO0NBQ1gsQ0FBQTtBQUVELE1BQU0sYUFBYSxHQUFHO0lBQ3BCLCtEQUErRDtJQUMvRCxNQUFNLEVBQUU7UUFDTixRQUFRLEVBQUUsT0FBTyxDQUFDLEdBQUcsQ0FBQyxXQUFXLElBQUksRUFBRTtRQUN2QyxRQUFRLEVBQUUsT0FBTyxDQUFDLEdBQUcsQ0FBQyxXQUFXLElBQUksRUFBRTtRQUN2QyxRQUFRLEVBQUUsT0FBTyxDQUFDLEdBQUcsQ0FBQyxXQUFXLElBQUksRUFBRTtRQUN2QyxJQUFJLEVBQUUsT0FBTyxDQUFDLEdBQUcsQ0FBQyxPQUFPLElBQUksRUFBRTtRQUMvQixPQUFPLEVBQUUsT0FBYztLQUN4QjtJQUNELHdEQUF3RDtJQUN4RCw4QkFBOEI7Q0FDL0IsQ0FBQTtBQUVELDJDQUEyQztBQUMzQyxNQUFNLEtBQUssR0FBRyxJQUFJLGVBQXdCLENBQUMsYUFBYSxFQUFFLFNBQVMsRUFBRTtJQUNuRSwyRUFBMkU7SUFDM0UsVUFBVSxFQUFFLGFBQWE7SUFDekIsaUNBQWlDO0lBQ2pDLFdBQVcsRUFBRSxDQUFDO0NBQ2YsQ0FBQyxDQUFBO0FBRUYsNEVBQTRFO0FBQzVFLEtBQUssQ0FBQyxhQUFhLEVBQUUsQ0FBQTtBQUVyQixvQkFBb0I7QUFDcEIsS0FBSyxDQUFDLFNBQVMsQ0FBQztJQUNkLFVBQVUsRUFBRSxnQkFBZ0I7SUFDNUIsUUFBUSxFQUFFLGdCQUFnQjtJQUMxQixPQUFPLEVBQUUsY0FBYztJQUN2QixJQUFJLEVBQUUsY0FBYztJQUVwQixXQUFXLEVBQUU7UUFDWDtZQUNFLDhDQUE4QztZQUM5QyxRQUFRLEVBQUUsVUFBVTtZQUNwQixpREFBaUQ7WUFDakQsSUFBSSxFQUFFLHNDQUFzQztTQUM3QztLQUNGO0NBQ0YsQ0FBQyxDQUFBIiwic291cmNlc0NvbnRlbnQiOlsiaW1wb3J0IE5vZGVtYWlsZXJTZXF1ZWxpemVRdWV1ZSBmcm9tICcuLi9pbmRleCdcbmltcG9ydCBkb3RlbnYgZnJvbSAnZG90ZW52J1xuZG90ZW52LmNvbmZpZygpXG5cbmNvbnN0IGF1dGggPSB7XG4gIHVzZXI6IHByb2Nlc3MuZW52LnNtdHBfdXNlcixcbiAgcGFzczogcHJvY2Vzcy5lbnYuc210cF9wYXNzLFxufVxuXG4vLyBTZWUgaHR0cHM6Ly93d3cubnBtanMuY29tL3BhY2thZ2Uvbm9kZW1haWxlciBmb3IgbW9yZSBvcHRpb25zXG5jb25zdCBzbXRwQ3JlZHMgPSB7XG4gIGhvc3Q6IHByb2Nlc3MuZW52LnNtdHBfaG9zdCxcbiAgcG9ydDogcHJvY2Vzcy5lbnYuc210cF9wb3J0ID8gcHJvY2Vzcy5lbnYuc210cF9wb3J0IDogNDY1LFxuICBzZWN1cmU6IHRydWUsXG4gIGF1dGg6IGF1dGgsXG59XG5cbmNvbnN0IGRiQ3JlZGVudGlhbHMgPSB7XG4gIC8vIFNlZSBodHRwczovL3d3dy5ucG1qcy5jb20vcGFja2FnZS9zZXF1ZWxpemUgZm9yIG1vcmUgb3B0aW9uc1xuICBjb25maWc6IHtcbiAgICB1c2VybmFtZTogcHJvY2Vzcy5lbnYuZGJfdXNlcm5hbWUgfHwgJycsXG4gICAgcGFzc3dvcmQ6IHByb2Nlc3MuZW52LmRiX3Bhc3N3b3JkIHx8ICcnLFxuICAgIGRhdGFiYXNlOiBwcm9jZXNzLmVudi5kYl9kYXRhYmFzZSB8fCAnJyxcbiAgICBob3N0OiBwcm9jZXNzLmVudi5kYl9ob3N0IHx8ICcnLFxuICAgIGRpYWxlY3Q6ICdteXNxbCcgYXMgYW55LFxuICB9LFxuICAvLyBBbHRlcm5hdGl2ZWx5IHlvdSBjYW4gdXNlIGV4aXN0aW5nIHNlcXVlbGl6ZSBpbnN0YW5jZVxuICAvLyBzZXF1ZWxpemU6IFNlcXVlbGl6ZUluc3RhbmVcbn1cblxuLy8gQ3JlYXRlIE5vZGVtYWlsZXJTZXF1ZWxpemVRdWV1ZSBpbnN0YW5jZVxuY29uc3QgcXVldWUgPSBuZXcgTm9kZW1haWxlclNlcXVlbGl6ZVF1ZXVlKGRiQ3JlZGVudGlhbHMsIHNtdHBDcmVkcywge1xuICAvLyBTZWUgaHR0cHM6Ly93d3cubnBtanMuY29tL3BhY2thZ2Uvbm9kZW1haWxlciBmb3IgbW9yZSBleHByZXNzaW9uIG9wdGlvbnNcbiAgZXhwcmVzc2lvbjogJyovMSAqICogKiAqJyxcbiAgLy8gSWYgLTEsIHdpbGwgdHJ5IGluZmluaXRlIHRpbWVzXG4gIG1heEF0dGVtcHRzOiAyLFxufSlcblxuLy8gIFJ1biBjcm9uIHNjaGVkdWxlIGZvciBzZW5kaW5nIG1haWwgKE9ubHkgb25lIHRpbWUgaW4gcm9vdCBvZiB0aGUgc3lzdGVtKVxucXVldWUuaW5pdFNjaGVkdWxlcigpXG5cbi8vIEFkZCBtYWlsIHRvIHF1ZXVlXG5xdWV1ZS5xdWV1ZU1haWwoe1xuICBlbWFpbF9mcm9tOiAndGVzdEBnbWFpbC5jb20nLFxuICBlbWFpbF90bzogJ3Rlc3RAZ21haWwuY29tJyxcbiAgc3ViamVjdDogJ3Rlc3Qgc3ViamVjdCcsXG4gIGh0bWw6ICd0ZXN0IG1lc3NhZ2UnLFxuXG4gIGF0dGFjaG1lbnRzOiBbXG4gICAge1xuICAgICAgLy8gTm90IHJlcXVpcmVkIChzZWUgTm9kZW1haWxlciBmaWxlbmFtZSBwcm9wKVxuICAgICAgZmlsZW5hbWU6ICdmaWxlLmpwZycsXG4gICAgICAvLyBMb2NhbCBvciByZW1vdGUgdXJsIChzZWUgTm9kZW1haWxlciBwYXRoIHByb3ApXG4gICAgICBwYXRoOiAnaHR0cHM6Ly9waWNzdW0ucGhvdG9zL2lkLzIzNy8yMDAvMzAwJyxcbiAgICB9LFxuICBdLFxufSlcbiJdfQ==
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiaW5kZXguanMiLCJzb3VyY2VSb290IjoiIiwic291cmNlcyI6WyIuLi8uLi9zcmMvZXhhbXBsZXMvaW5kZXgudHMiXSwibmFtZXMiOltdLCJtYXBwaW5ncyI6Ijs7Ozs7QUFBQSxxREFBK0M7QUFDL0Msb0RBQTJCO0FBQzNCLGdCQUFNLENBQUMsTUFBTSxFQUFFLENBQUE7QUFFZixNQUFNLElBQUksR0FBRztJQUNYLElBQUksRUFBRSxPQUFPLENBQUMsR0FBRyxDQUFDLFNBQVM7SUFDM0IsSUFBSSxFQUFFLE9BQU8sQ0FBQyxHQUFHLENBQUMsU0FBUztDQUM1QixDQUFBO0FBRUQsZ0VBQWdFO0FBQ2hFLE1BQU0sU0FBUyxHQUFHO0lBQ2hCLElBQUksRUFBRSxPQUFPLENBQUMsR0FBRyxDQUFDLFNBQVM7SUFDM0IsSUFBSSxFQUFFLE9BQU8sQ0FBQyxHQUFHLENBQUMsU0FBUyxDQUFDLENBQUMsQ0FBQyxPQUFPLENBQUMsR0FBRyxDQUFDLFNBQVMsQ0FBQyxDQUFDLENBQUMsR0FBRztJQUN6RCxNQUFNLEVBQUUsSUFBSTtJQUNaLElBQUksRUFBRSxJQUFJO0NBQ1gsQ0FBQTtBQUVELE1BQU0sYUFBYSxHQUFHO0lBQ3BCLCtEQUErRDtJQUMvRCxNQUFNLEVBQUU7UUFDTixRQUFRLEVBQUUsT0FBTyxDQUFDLEdBQUcsQ0FBQyxXQUFXLElBQUksRUFBRTtRQUN2QyxRQUFRLEVBQUUsT0FBTyxDQUFDLEdBQUcsQ0FBQyxXQUFXLElBQUksRUFBRTtRQUN2QyxRQUFRLEVBQUUsT0FBTyxDQUFDLEdBQUcsQ0FBQyxXQUFXLElBQUksRUFBRTtRQUN2QyxJQUFJLEVBQUUsT0FBTyxDQUFDLEdBQUcsQ0FBQyxPQUFPLElBQUksRUFBRTtRQUMvQixPQUFPLEVBQUUsT0FBYztLQUN4QjtJQUNELHdEQUF3RDtJQUN4RCw4QkFBOEI7Q0FDL0IsQ0FBQTtBQUVELDJDQUEyQztBQUMzQyxNQUFNLEtBQUssR0FBRyxJQUFJLGVBQXdCLENBQUMsYUFBYSxFQUFFLFNBQVMsRUFBRTtJQUNuRSwyRUFBMkU7SUFDM0UsVUFBVSxFQUFFLGFBQWE7SUFDekIsaUNBQWlDO0lBQ2pDLFdBQVcsRUFBRSxDQUFDO0lBQ2QsT0FBTyxFQUFFLElBQUk7Q0FDZCxDQUFDLENBQUE7QUFFRiw0RUFBNEU7QUFDNUUsS0FBSyxDQUFDLGFBQWEsRUFBRSxDQUFBO0FBRXJCLG9CQUFvQjtBQUNwQixLQUFLLENBQUMsU0FBUyxDQUFDO0lBQ2QsVUFBVSxFQUFFLGdCQUFnQjtJQUM1QixRQUFRLEVBQUUsZ0JBQWdCO0lBQzFCLE9BQU8sRUFBRSxjQUFjO0lBQ3ZCLElBQUksRUFBRSxjQUFjO0lBRXBCLFdBQVcsRUFBRTtRQUNYO1lBQ0UsOENBQThDO1lBQzlDLFFBQVEsRUFBRSxVQUFVO1lBQ3BCLGlEQUFpRDtZQUNqRCxJQUFJLEVBQUUsc0NBQXNDO1NBQzdDO0tBQ0Y7Q0FDRixDQUFDLENBQUEiLCJzb3VyY2VzQ29udGVudCI6WyJpbXBvcnQgTm9kZW1haWxlclNlcXVlbGl6ZVF1ZXVlIGZyb20gJy4uL2luZGV4J1xuaW1wb3J0IGRvdGVudiBmcm9tICdkb3RlbnYnXG5kb3RlbnYuY29uZmlnKClcblxuY29uc3QgYXV0aCA9IHtcbiAgdXNlcjogcHJvY2Vzcy5lbnYuc210cF91c2VyLFxuICBwYXNzOiBwcm9jZXNzLmVudi5zbXRwX3Bhc3MsXG59XG5cbi8vIFNlZSBodHRwczovL3d3dy5ucG1qcy5jb20vcGFja2FnZS9ub2RlbWFpbGVyIGZvciBtb3JlIG9wdGlvbnNcbmNvbnN0IHNtdHBDcmVkcyA9IHtcbiAgaG9zdDogcHJvY2Vzcy5lbnYuc210cF9ob3N0LFxuICBwb3J0OiBwcm9jZXNzLmVudi5zbXRwX3BvcnQgPyBwcm9jZXNzLmVudi5zbXRwX3BvcnQgOiA0NjUsXG4gIHNlY3VyZTogdHJ1ZSxcbiAgYXV0aDogYXV0aCxcbn1cblxuY29uc3QgZGJDcmVkZW50aWFscyA9IHtcbiAgLy8gU2VlIGh0dHBzOi8vd3d3Lm5wbWpzLmNvbS9wYWNrYWdlL3NlcXVlbGl6ZSBmb3IgbW9yZSBvcHRpb25zXG4gIGNvbmZpZzoge1xuICAgIHVzZXJuYW1lOiBwcm9jZXNzLmVudi5kYl91c2VybmFtZSB8fCAnJyxcbiAgICBwYXNzd29yZDogcHJvY2Vzcy5lbnYuZGJfcGFzc3dvcmQgfHwgJycsXG4gICAgZGF0YWJhc2U6IHByb2Nlc3MuZW52LmRiX2RhdGFiYXNlIHx8ICcnLFxuICAgIGhvc3Q6IHByb2Nlc3MuZW52LmRiX2hvc3QgfHwgJycsXG4gICAgZGlhbGVjdDogJ215c3FsJyBhcyBhbnksXG4gIH0sXG4gIC8vIEFsdGVybmF0aXZlbHkgeW91IGNhbiB1c2UgZXhpc3Rpbmcgc2VxdWVsaXplIGluc3RhbmNlXG4gIC8vIHNlcXVlbGl6ZTogU2VxdWVsaXplSW5zdGFuZVxufVxuXG4vLyBDcmVhdGUgTm9kZW1haWxlclNlcXVlbGl6ZVF1ZXVlIGluc3RhbmNlXG5jb25zdCBxdWV1ZSA9IG5ldyBOb2RlbWFpbGVyU2VxdWVsaXplUXVldWUoZGJDcmVkZW50aWFscywgc210cENyZWRzLCB7XG4gIC8vIFNlZSBodHRwczovL3d3dy5ucG1qcy5jb20vcGFja2FnZS9ub2RlbWFpbGVyIGZvciBtb3JlIGV4cHJlc3Npb24gb3B0aW9uc1xuICBleHByZXNzaW9uOiAnKi8xICogKiAqIConLFxuICAvLyBJZiAtMSwgd2lsbCB0cnkgaW5maW5pdGUgdGltZXNcbiAgbWF4QXR0ZW1wdHM6IDIsXG4gIGxvZ2dpbmc6IHRydWUsXG59KVxuXG4vLyAgUnVuIGNyb24gc2NoZWR1bGUgZm9yIHNlbmRpbmcgbWFpbCAoT25seSBvbmUgdGltZSBpbiByb290IG9mIHRoZSBzeXN0ZW0pXG5xdWV1ZS5pbml0U2NoZWR1bGVyKClcblxuLy8gQWRkIG1haWwgdG8gcXVldWVcbnF1ZXVlLnF1ZXVlTWFpbCh7XG4gIGVtYWlsX2Zyb206ICd0ZXN0QGdtYWlsLmNvbScsXG4gIGVtYWlsX3RvOiAndGVzdEBnbWFpbC5jb20nLFxuICBzdWJqZWN0OiAndGVzdCBzdWJqZWN0JyxcbiAgaHRtbDogJ3Rlc3QgbWVzc2FnZScsXG5cbiAgYXR0YWNobWVudHM6IFtcbiAgICB7XG4gICAgICAvLyBOb3QgcmVxdWlyZWQgKHNlZSBOb2RlbWFpbGVyIGZpbGVuYW1lIHByb3ApXG4gICAgICBmaWxlbmFtZTogJ2ZpbGUuanBnJyxcbiAgICAgIC8vIExvY2FsIG9yIHJlbW90ZSB1cmwgKHNlZSBOb2RlbWFpbGVyIHBhdGggcHJvcClcbiAgICAgIHBhdGg6ICdodHRwczovL3BpY3N1bS5waG90b3MvaWQvMjM3LzIwMC8zMDAnLFxuICAgIH0sXG4gIF0sXG59KVxuIl19

@@ -7,2 +7,3 @@ import { AddQueueModelAttributes, IQueueModel } from './QueueModel';

private dbInisializated;
private scheduled;
private smtpCredentials;

@@ -9,0 +10,0 @@ private options;

@@ -14,2 +14,3 @@ "use strict";

this.options = options;
this.scheduled = false;
}

@@ -29,2 +30,7 @@ async initDatabase(dbConfigInstance) {

}
console.log('initScheduler - - - --- - --', this.scheduled);
if (this.scheduled) {
return;
}
this.scheduled = true;
new Scheduler_1.default(this.smtpCredentials, this.queueModel, this.options.expression, this.options.maxAttempts, this.options.logging);

@@ -53,2 +59,2 @@ }

exports.default = NodemailerSequelizeQueue;
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiaW5kZXguanMiLCJzb3VyY2VSb290IjoiIiwic291cmNlcyI6WyIuLi9zcmMvaW5kZXgudHMiXSwibmFtZXMiOltdLCJtYXBwaW5ncyI6Ijs7Ozs7QUFBQSw4REFBa0c7QUFDbEcseUNBQXFEO0FBQ3JELDREQUFtQztBQUVuQyxNQUFxQix3QkFBd0I7SUFPM0MsWUFBWSxnQkFBa0MsRUFBRSxlQUFvQixFQUFFLE9BQWlCO1FBQ3JGLElBQUksQ0FBQyxZQUFZLENBQUMsZ0JBQWdCLENBQUMsQ0FBQTtRQUNuQyxJQUFJLENBQUMsZUFBZSxHQUFHLGVBQWUsQ0FBQTtRQUN0QyxJQUFJLENBQUMsT0FBTyxHQUFHLE9BQU8sQ0FBQTtJQUN4QixDQUFDO0lBRU8sS0FBSyxDQUFDLFlBQVksQ0FBQyxnQkFBa0M7UUFDM0QsSUFBSSxDQUFDLFNBQVMsR0FBRyxnQkFBZ0IsQ0FBQyxTQUFTO1lBQ3pDLENBQUMsQ0FBQyxnQkFBZ0IsQ0FBQyxTQUFTO1lBQzVCLENBQUMsQ0FBQyxJQUFJLHFCQUFTLENBQ1gsZ0JBQWdCLENBQUMsTUFBTSxDQUFDLFFBQVEsRUFDaEMsZ0JBQWdCLENBQUMsTUFBTSxDQUFDLFFBQVEsRUFDaEMsZ0JBQWdCLENBQUMsTUFBTSxDQUFDLFFBQVEsRUFDaEM7Z0JBQ0UsSUFBSSxFQUFFLGdCQUFnQixDQUFDLE1BQU0sQ0FBQyxJQUFJO2dCQUNsQyxPQUFPLEVBQUUsZ0JBQWdCLENBQUMsTUFBTSxDQUFDLE9BQU87Z0JBQ3hDLE9BQU8sRUFBRSxnQkFBZ0IsQ0FBQyxNQUFNLENBQUMsT0FBTzthQUN6QyxDQUNGLENBQUE7SUFDUCxDQUFDO0lBRU0sS0FBSyxDQUFDLGFBQWE7UUFDeEIsSUFBSSxDQUFDLElBQUksQ0FBQyxlQUFlLEVBQUU7WUFDekIsTUFBTSxJQUFJLENBQUMsVUFBVSxFQUFFLENBQUE7U0FDeEI7UUFDRCxJQUFJLG1CQUFTLENBQ1gsSUFBSSxDQUFDLGVBQWUsRUFDcEIsSUFBSSxDQUFDLFVBQVUsRUFDZixJQUFJLENBQUMsT0FBTyxDQUFDLFVBQVUsRUFDdkIsSUFBSSxDQUFDLE9BQU8sQ0FBQyxXQUFXLEVBQ3hCLElBQUksQ0FBQyxPQUFPLENBQUMsT0FBTyxDQUNyQixDQUFBO0lBQ0gsQ0FBQztJQUVPLEtBQUssQ0FBQyxVQUFVO1FBQ3RCLElBQUksQ0FBQyxVQUFVLEdBQUcsSUFBQSxvQkFBVSxFQUFDLElBQUksQ0FBQyxTQUFTLENBQUMsQ0FBQTtRQUU1Qyw2QkFBNkI7UUFDN0IsTUFBTSxJQUFJLENBQUMsVUFBVSxDQUFDLElBQUksQ0FBQztZQUN6QixPQUFPLEVBQUUsT0FBTyxDQUFDLEdBQUc7WUFDcEIsS0FBSyxFQUFFLEtBQUs7U0FDYixDQUFDLENBQUE7UUFDRixJQUFJLENBQUMsZUFBZSxHQUFHLElBQUksQ0FBQTtJQUM3QixDQUFDO0lBRUQsS0FBSyxDQUFDLFNBQVMsQ0FBQyxJQUE2QjtRQUMzQyxNQUFNLElBQUksQ0FBQyxVQUFVLEVBQUUsQ0FBQTtRQUV2QixNQUFNLFdBQVcsR0FBRyxNQUFNLElBQUksQ0FBQyxVQUFVLENBQUMsTUFBTSxDQUFDLElBQUksRUFBRTtZQUNyRCxTQUFTLEVBQUUsSUFBSTtTQUNoQixDQUFDLENBQUE7UUFDRixJQUFJLENBQUMsV0FBVyxDQUFDLEdBQUcsQ0FBQyxJQUFJLENBQUMsRUFBRTtZQUMxQixNQUFNLElBQUksS0FBSyxDQUFDLHNCQUFzQixDQUFDLENBQUE7U0FDeEM7UUFDRCxPQUFPLFdBQVcsQ0FBQTtJQUNwQixDQUFDO0NBQ0Y7QUEvREQsMkNBK0RDIiwic291cmNlc0NvbnRlbnQiOlsiaW1wb3J0IFF1ZXVlTW9kZWwsIHsgQWRkUXVldWVNb2RlbEF0dHJpYnV0ZXMsIElRdWV1ZU1vZGVsLCBJUXVldWVNb2RlbFN0YXRpYyB9IGZyb20gJy4vUXVldWVNb2RlbCdcbmltcG9ydCB7IFNlcXVlbGl6ZSwgTW9kZWwsIERpYWxlY3QgfSBmcm9tICdzZXF1ZWxpemUnXG5pbXBvcnQgU2NoZWR1bGVyIGZyb20gJy4vU2NoZWR1bGVyJ1xuXG5leHBvcnQgZGVmYXVsdCBjbGFzcyBOb2RlbWFpbGVyU2VxdWVsaXplUXVldWUgaW1wbGVtZW50cyBJTm9kZW1haWxlclNlcXVlbGl6ZVF1ZXVlIHtcbiAgcHJpdmF0ZSBxdWV1ZU1vZGVsOiBJUXVldWVNb2RlbFN0YXRpY1xuICBwcml2YXRlIHNlcXVlbGl6ZTogU2VxdWVsaXplXG4gIHByaXZhdGUgZGJJbmlzaWFsaXphdGVkOiBib29sZWFuXG4gIHByaXZhdGUgc210cENyZWRlbnRpYWxzOiBhbnlcbiAgcHJpdmF0ZSBvcHRpb25zOiBPcHRpb25zXG5cbiAgY29uc3RydWN0b3IoZGJDb25maWdJbnN0YW5jZTogRGJDb25naWZJbnN0YW5jZSwgc210cENyZWRlbnRpYWxzOiBhbnksIG9wdGlvbnM/OiBPcHRpb25zKSB7XG4gICAgdGhpcy5pbml0RGF0YWJhc2UoZGJDb25maWdJbnN0YW5jZSlcbiAgICB0aGlzLnNtdHBDcmVkZW50aWFscyA9IHNtdHBDcmVkZW50aWFsc1xuICAgIHRoaXMub3B0aW9ucyA9IG9wdGlvbnNcbiAgfVxuXG4gIHByaXZhdGUgYXN5bmMgaW5pdERhdGFiYXNlKGRiQ29uZmlnSW5zdGFuY2U6IERiQ29uZ2lmSW5zdGFuY2UpOiBQcm9taXNlPHZvaWQ+IHtcbiAgICB0aGlzLnNlcXVlbGl6ZSA9IGRiQ29uZmlnSW5zdGFuY2Uuc2VxdWVsaXplXG4gICAgICA/IGRiQ29uZmlnSW5zdGFuY2Uuc2VxdWVsaXplXG4gICAgICA6IG5ldyBTZXF1ZWxpemUoXG4gICAgICAgICAgZGJDb25maWdJbnN0YW5jZS5jb25maWcuZGF0YWJhc2UsXG4gICAgICAgICAgZGJDb25maWdJbnN0YW5jZS5jb25maWcudXNlcm5hbWUsXG4gICAgICAgICAgZGJDb25maWdJbnN0YW5jZS5jb25maWcucGFzc3dvcmQsXG4gICAgICAgICAge1xuICAgICAgICAgICAgaG9zdDogZGJDb25maWdJbnN0YW5jZS5jb25maWcuaG9zdCxcbiAgICAgICAgICAgIGRpYWxlY3Q6IGRiQ29uZmlnSW5zdGFuY2UuY29uZmlnLmRpYWxlY3QsXG4gICAgICAgICAgICBsb2dnaW5nOiBkYkNvbmZpZ0luc3RhbmNlLmNvbmZpZy5sb2dnaW5nLFxuICAgICAgICAgIH1cbiAgICAgICAgKVxuICB9XG5cbiAgcHVibGljIGFzeW5jIGluaXRTY2hlZHVsZXIoKTogUHJvbWlzZTx2b2lkPiB7XG4gICAgaWYgKCF0aGlzLmRiSW5pc2lhbGl6YXRlZCkge1xuICAgICAgYXdhaXQgdGhpcy5pbml0TW9kZWxzKClcbiAgICB9XG4gICAgbmV3IFNjaGVkdWxlcihcbiAgICAgIHRoaXMuc210cENyZWRlbnRpYWxzLFxuICAgICAgdGhpcy5xdWV1ZU1vZGVsLFxuICAgICAgdGhpcy5vcHRpb25zLmV4cHJlc3Npb24sXG4gICAgICB0aGlzLm9wdGlvbnMubWF4QXR0ZW1wdHMsXG4gICAgICB0aGlzLm9wdGlvbnMubG9nZ2luZ1xuICAgIClcbiAgfVxuXG4gIHByaXZhdGUgYXN5bmMgaW5pdE1vZGVscygpOiBQcm9taXNlPHZvaWQ+IHtcbiAgICB0aGlzLnF1ZXVlTW9kZWwgPSBRdWV1ZU1vZGVsKHRoaXMuc2VxdWVsaXplKVxuXG4gICAgLy8gQ3JlYXRlcyB0YWJsZSBpZiBub3QgZXhpc3RcbiAgICBhd2FpdCB0aGlzLnF1ZXVlTW9kZWwuc3luYyh7XG4gICAgICBsb2dnaW5nOiBjb25zb2xlLmxvZyxcbiAgICAgIGZvcmNlOiBmYWxzZSxcbiAgICB9KVxuICAgIHRoaXMuZGJJbmlzaWFsaXphdGVkID0gdHJ1ZVxuICB9XG5cbiAgYXN5bmMgcXVldWVNYWlsKGRhdGE6IEFkZFF1ZXVlTW9kZWxBdHRyaWJ1dGVzKTogUHJvbWlzZTxJUXVldWVNb2RlbD4ge1xuICAgIGF3YWl0IHRoaXMuaW5pdE1vZGVscygpXG5cbiAgICBjb25zdCBxdWV1ZUVudGl0eSA9IGF3YWl0IHRoaXMucXVldWVNb2RlbC5jcmVhdGUoZGF0YSwge1xuICAgICAgcmV0dXJuaW5nOiB0cnVlLFxuICAgIH0pXG4gICAgaWYgKCFxdWV1ZUVudGl0eS5nZXQoJ2lkJykpIHtcbiAgICAgIHRocm93IG5ldyBFcnJvcignRXJyb3IgcXVldWVpbmcgZW1haWwnKVxuICAgIH1cbiAgICByZXR1cm4gcXVldWVFbnRpdHlcbiAgfVxufVxuXG5leHBvcnQgaW50ZXJmYWNlIElOb2RlbWFpbGVyU2VxdWVsaXplUXVldWUge1xuICBxdWV1ZU1haWwoZGF0YTogQWRkUXVldWVNb2RlbEF0dHJpYnV0ZXMpOiBQcm9taXNlPE1vZGVsPGFueSwgYW55Pj5cbiAgaW5pdFNjaGVkdWxlcigpOiBQcm9taXNlPHZvaWQ+XG59XG5cbmV4cG9ydCB0eXBlIERiQ29uZmlnID0ge1xuICB1c2VybmFtZTogc3RyaW5nXG4gIHBhc3N3b3JkOiBzdHJpbmdcbiAgZGF0YWJhc2U6IHN0cmluZ1xuICBob3N0OiBzdHJpbmdcbiAgZGlhbGVjdDogRGlhbGVjdFxuICBsb2dnaW5nPzogYm9vbGVhbiB8ICgoc3FsOiBzdHJpbmcsIHRpbWluZz86IG51bWJlcikgPT4gdm9pZClcbn1cblxuZXhwb3J0IHR5cGUgRGJDb25naWZJbnN0YW5jZSA9IHtcbiAgY29uZmlnPzogRGJDb25maWdcbiAgc2VxdWVsaXplPzogU2VxdWVsaXplXG59XG5cbmV4cG9ydCB0eXBlIE9wdGlvbnMgPSB7XG4gIG1heEF0dGVtcHRzPzogbnVtYmVyXG4gIGV4cHJlc3Npb24/OiBzdHJpbmdcbiAgbG9nZ2luZz86IGJvb2xlYW5cbn1cbiJdfQ==
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiaW5kZXguanMiLCJzb3VyY2VSb290IjoiIiwic291cmNlcyI6WyIuLi9zcmMvaW5kZXgudHMiXSwibmFtZXMiOltdLCJtYXBwaW5ncyI6Ijs7Ozs7QUFBQSw4REFBa0c7QUFDbEcseUNBQXFEO0FBQ3JELDREQUFtQztBQUVuQyxNQUFxQix3QkFBd0I7SUFRM0MsWUFBWSxnQkFBa0MsRUFBRSxlQUFvQixFQUFFLE9BQWlCO1FBQ3JGLElBQUksQ0FBQyxZQUFZLENBQUMsZ0JBQWdCLENBQUMsQ0FBQTtRQUNuQyxJQUFJLENBQUMsZUFBZSxHQUFHLGVBQWUsQ0FBQTtRQUN0QyxJQUFJLENBQUMsT0FBTyxHQUFHLE9BQU8sQ0FBQTtRQUN0QixJQUFJLENBQUMsU0FBUyxHQUFHLEtBQUssQ0FBQTtJQUN4QixDQUFDO0lBRU8sS0FBSyxDQUFDLFlBQVksQ0FBQyxnQkFBa0M7UUFDM0QsSUFBSSxDQUFDLFNBQVMsR0FBRyxnQkFBZ0IsQ0FBQyxTQUFTO1lBQ3pDLENBQUMsQ0FBQyxnQkFBZ0IsQ0FBQyxTQUFTO1lBQzVCLENBQUMsQ0FBQyxJQUFJLHFCQUFTLENBQ1gsZ0JBQWdCLENBQUMsTUFBTSxDQUFDLFFBQVEsRUFDaEMsZ0JBQWdCLENBQUMsTUFBTSxDQUFDLFFBQVEsRUFDaEMsZ0JBQWdCLENBQUMsTUFBTSxDQUFDLFFBQVEsRUFDaEM7Z0JBQ0UsSUFBSSxFQUFFLGdCQUFnQixDQUFDLE1BQU0sQ0FBQyxJQUFJO2dCQUNsQyxPQUFPLEVBQUUsZ0JBQWdCLENBQUMsTUFBTSxDQUFDLE9BQU87Z0JBQ3hDLE9BQU8sRUFBRSxnQkFBZ0IsQ0FBQyxNQUFNLENBQUMsT0FBTzthQUN6QyxDQUNGLENBQUE7SUFDUCxDQUFDO0lBRU0sS0FBSyxDQUFDLGFBQWE7UUFDeEIsSUFBSSxDQUFDLElBQUksQ0FBQyxlQUFlLEVBQUU7WUFDekIsTUFBTSxJQUFJLENBQUMsVUFBVSxFQUFFLENBQUE7U0FDeEI7UUFFRCxPQUFPLENBQUMsR0FBRyxDQUFDLG9DQUFvQyxFQUFFLElBQUksQ0FBQyxTQUFTLENBQUMsQ0FBQTtRQUNqRSxJQUFJLElBQUksQ0FBQyxTQUFTLEVBQUU7WUFDbEIsT0FBTTtTQUNQO1FBRUQsSUFBSSxDQUFDLFNBQVMsR0FBRyxJQUFJLENBQUE7UUFDckIsSUFBSSxtQkFBUyxDQUNYLElBQUksQ0FBQyxlQUFlLEVBQ3BCLElBQUksQ0FBQyxVQUFVLEVBQ2YsSUFBSSxDQUFDLE9BQU8sQ0FBQyxVQUFVLEVBQ3ZCLElBQUksQ0FBQyxPQUFPLENBQUMsV0FBVyxFQUN4QixJQUFJLENBQUMsT0FBTyxDQUFDLE9BQU8sQ0FDckIsQ0FBQTtJQUNILENBQUM7SUFFTyxLQUFLLENBQUMsVUFBVTtRQUN0QixJQUFJLENBQUMsVUFBVSxHQUFHLElBQUEsb0JBQVUsRUFBQyxJQUFJLENBQUMsU0FBUyxDQUFDLENBQUE7UUFFNUMsNkJBQTZCO1FBQzdCLE1BQU0sSUFBSSxDQUFDLFVBQVUsQ0FBQyxJQUFJLENBQUM7WUFDekIsT0FBTyxFQUFFLE9BQU8sQ0FBQyxHQUFHO1lBQ3BCLEtBQUssRUFBRSxLQUFLO1NBQ2IsQ0FBQyxDQUFBO1FBQ0YsSUFBSSxDQUFDLGVBQWUsR0FBRyxJQUFJLENBQUE7SUFDN0IsQ0FBQztJQUVELEtBQUssQ0FBQyxTQUFTLENBQUMsSUFBNkI7UUFDM0MsTUFBTSxJQUFJLENBQUMsVUFBVSxFQUFFLENBQUE7UUFFdkIsTUFBTSxXQUFXLEdBQUcsTUFBTSxJQUFJLENBQUMsVUFBVSxDQUFDLE1BQU0sQ0FBQyxJQUFJLEVBQUU7WUFDckQsU0FBUyxFQUFFLElBQUk7U0FDaEIsQ0FBQyxDQUFBO1FBQ0YsSUFBSSxDQUFDLFdBQVcsQ0FBQyxHQUFHLENBQUMsSUFBSSxDQUFDLEVBQUU7WUFDMUIsTUFBTSxJQUFJLEtBQUssQ0FBQyxzQkFBc0IsQ0FBQyxDQUFBO1NBQ3hDO1FBQ0QsT0FBTyxXQUFXLENBQUE7SUFDcEIsQ0FBQztDQUNGO0FBeEVELDJDQXdFQyIsInNvdXJjZXNDb250ZW50IjpbImltcG9ydCBRdWV1ZU1vZGVsLCB7IEFkZFF1ZXVlTW9kZWxBdHRyaWJ1dGVzLCBJUXVldWVNb2RlbCwgSVF1ZXVlTW9kZWxTdGF0aWMgfSBmcm9tICcuL1F1ZXVlTW9kZWwnXG5pbXBvcnQgeyBTZXF1ZWxpemUsIE1vZGVsLCBEaWFsZWN0IH0gZnJvbSAnc2VxdWVsaXplJ1xuaW1wb3J0IFNjaGVkdWxlciBmcm9tICcuL1NjaGVkdWxlcidcblxuZXhwb3J0IGRlZmF1bHQgY2xhc3MgTm9kZW1haWxlclNlcXVlbGl6ZVF1ZXVlIGltcGxlbWVudHMgSU5vZGVtYWlsZXJTZXF1ZWxpemVRdWV1ZSB7XG4gIHByaXZhdGUgcXVldWVNb2RlbDogSVF1ZXVlTW9kZWxTdGF0aWNcbiAgcHJpdmF0ZSBzZXF1ZWxpemU6IFNlcXVlbGl6ZVxuICBwcml2YXRlIGRiSW5pc2lhbGl6YXRlZDogYm9vbGVhblxuICBwcml2YXRlIHNjaGVkdWxlZDogYm9vbGVhblxuICBwcml2YXRlIHNtdHBDcmVkZW50aWFsczogYW55XG4gIHByaXZhdGUgb3B0aW9uczogT3B0aW9uc1xuXG4gIGNvbnN0cnVjdG9yKGRiQ29uZmlnSW5zdGFuY2U6IERiQ29uZ2lmSW5zdGFuY2UsIHNtdHBDcmVkZW50aWFsczogYW55LCBvcHRpb25zPzogT3B0aW9ucykge1xuICAgIHRoaXMuaW5pdERhdGFiYXNlKGRiQ29uZmlnSW5zdGFuY2UpXG4gICAgdGhpcy5zbXRwQ3JlZGVudGlhbHMgPSBzbXRwQ3JlZGVudGlhbHNcbiAgICB0aGlzLm9wdGlvbnMgPSBvcHRpb25zXG4gICAgdGhpcy5zY2hlZHVsZWQgPSBmYWxzZVxuICB9XG5cbiAgcHJpdmF0ZSBhc3luYyBpbml0RGF0YWJhc2UoZGJDb25maWdJbnN0YW5jZTogRGJDb25naWZJbnN0YW5jZSk6IFByb21pc2U8dm9pZD4ge1xuICAgIHRoaXMuc2VxdWVsaXplID0gZGJDb25maWdJbnN0YW5jZS5zZXF1ZWxpemVcbiAgICAgID8gZGJDb25maWdJbnN0YW5jZS5zZXF1ZWxpemVcbiAgICAgIDogbmV3IFNlcXVlbGl6ZShcbiAgICAgICAgICBkYkNvbmZpZ0luc3RhbmNlLmNvbmZpZy5kYXRhYmFzZSxcbiAgICAgICAgICBkYkNvbmZpZ0luc3RhbmNlLmNvbmZpZy51c2VybmFtZSxcbiAgICAgICAgICBkYkNvbmZpZ0luc3RhbmNlLmNvbmZpZy5wYXNzd29yZCxcbiAgICAgICAgICB7XG4gICAgICAgICAgICBob3N0OiBkYkNvbmZpZ0luc3RhbmNlLmNvbmZpZy5ob3N0LFxuICAgICAgICAgICAgZGlhbGVjdDogZGJDb25maWdJbnN0YW5jZS5jb25maWcuZGlhbGVjdCxcbiAgICAgICAgICAgIGxvZ2dpbmc6IGRiQ29uZmlnSW5zdGFuY2UuY29uZmlnLmxvZ2dpbmcsXG4gICAgICAgICAgfVxuICAgICAgICApXG4gIH1cblxuICBwdWJsaWMgYXN5bmMgaW5pdFNjaGVkdWxlcigpOiBQcm9taXNlPHZvaWQ+IHtcbiAgICBpZiAoIXRoaXMuZGJJbmlzaWFsaXphdGVkKSB7XG4gICAgICBhd2FpdCB0aGlzLmluaXRNb2RlbHMoKVxuICAgIH1cblxuICAgIGNvbnNvbGUubG9nKCdpbml0U2NoZWR1bGVyIC0gLSAgICAgICAtIC0tLSAtIC0tJywgdGhpcy5zY2hlZHVsZWQpXG4gICAgaWYgKHRoaXMuc2NoZWR1bGVkKSB7XG4gICAgICByZXR1cm5cbiAgICB9XG5cbiAgICB0aGlzLnNjaGVkdWxlZCA9IHRydWVcbiAgICBuZXcgU2NoZWR1bGVyKFxuICAgICAgdGhpcy5zbXRwQ3JlZGVudGlhbHMsXG4gICAgICB0aGlzLnF1ZXVlTW9kZWwsXG4gICAgICB0aGlzLm9wdGlvbnMuZXhwcmVzc2lvbixcbiAgICAgIHRoaXMub3B0aW9ucy5tYXhBdHRlbXB0cyxcbiAgICAgIHRoaXMub3B0aW9ucy5sb2dnaW5nXG4gICAgKVxuICB9XG5cbiAgcHJpdmF0ZSBhc3luYyBpbml0TW9kZWxzKCk6IFByb21pc2U8dm9pZD4ge1xuICAgIHRoaXMucXVldWVNb2RlbCA9IFF1ZXVlTW9kZWwodGhpcy5zZXF1ZWxpemUpXG5cbiAgICAvLyBDcmVhdGVzIHRhYmxlIGlmIG5vdCBleGlzdFxuICAgIGF3YWl0IHRoaXMucXVldWVNb2RlbC5zeW5jKHtcbiAgICAgIGxvZ2dpbmc6IGNvbnNvbGUubG9nLFxuICAgICAgZm9yY2U6IGZhbHNlLFxuICAgIH0pXG4gICAgdGhpcy5kYkluaXNpYWxpemF0ZWQgPSB0cnVlXG4gIH1cblxuICBhc3luYyBxdWV1ZU1haWwoZGF0YTogQWRkUXVldWVNb2RlbEF0dHJpYnV0ZXMpOiBQcm9taXNlPElRdWV1ZU1vZGVsPiB7XG4gICAgYXdhaXQgdGhpcy5pbml0TW9kZWxzKClcblxuICAgIGNvbnN0IHF1ZXVlRW50aXR5ID0gYXdhaXQgdGhpcy5xdWV1ZU1vZGVsLmNyZWF0ZShkYXRhLCB7XG4gICAgICByZXR1cm5pbmc6IHRydWUsXG4gICAgfSlcbiAgICBpZiAoIXF1ZXVlRW50aXR5LmdldCgnaWQnKSkge1xuICAgICAgdGhyb3cgbmV3IEVycm9yKCdFcnJvciBxdWV1ZWluZyBlbWFpbCcpXG4gICAgfVxuICAgIHJldHVybiBxdWV1ZUVudGl0eVxuICB9XG59XG5cbmV4cG9ydCBpbnRlcmZhY2UgSU5vZGVtYWlsZXJTZXF1ZWxpemVRdWV1ZSB7XG4gIHF1ZXVlTWFpbChkYXRhOiBBZGRRdWV1ZU1vZGVsQXR0cmlidXRlcyk6IFByb21pc2U8TW9kZWw8YW55LCBhbnk+PlxuICBpbml0U2NoZWR1bGVyKCk6IFByb21pc2U8dm9pZD5cbn1cblxuZXhwb3J0IHR5cGUgRGJDb25maWcgPSB7XG4gIHVzZXJuYW1lOiBzdHJpbmdcbiAgcGFzc3dvcmQ6IHN0cmluZ1xuICBkYXRhYmFzZTogc3RyaW5nXG4gIGhvc3Q6IHN0cmluZ1xuICBkaWFsZWN0OiBEaWFsZWN0XG4gIGxvZ2dpbmc/OiBib29sZWFuIHwgKChzcWw6IHN0cmluZywgdGltaW5nPzogbnVtYmVyKSA9PiB2b2lkKVxufVxuXG5leHBvcnQgdHlwZSBEYkNvbmdpZkluc3RhbmNlID0ge1xuICBjb25maWc/OiBEYkNvbmZpZ1xuICBzZXF1ZWxpemU/OiBTZXF1ZWxpemVcbn1cblxuZXhwb3J0IHR5cGUgT3B0aW9ucyA9IHtcbiAgbWF4QXR0ZW1wdHM/OiBudW1iZXJcbiAgZXhwcmVzc2lvbj86IHN0cmluZ1xuICBsb2dnaW5nPzogYm9vbGVhblxufVxuIl19

@@ -16,3 +16,4 @@ /// <reference types="node" />

/** path to a file or an URL (data uris are allowed as well) if you want to stream the file instead of including it (better for larger attachments) */
path: string | Url | undefined;
path?: string | Url;
url?: string | Url;
}

@@ -19,0 +20,0 @@ export declare type Message = {

@@ -14,3 +14,5 @@ "use strict";

async sendMail(message) {
console.log('Sending mail', message);
const mailResult = await this.transporter.sendMail(message);
console.log('mailResult', mailResult);
return mailResult;

@@ -20,2 +22,2 @@ }

exports.default = Mailer;
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiTWFpbGVyLmpzIiwic291cmNlUm9vdCI6IiIsInNvdXJjZXMiOlsiLi4vc3JjL01haWxlci50cyJdLCJuYW1lcyI6W10sIm1hcHBpbmdzIjoiOzs7OztBQUFBLDREQUFxRTtBQUdyRSxNQUFxQixNQUFNO0lBR3pCLFlBQVksUUFBYyxFQUFFLFNBQXVCO1FBQ2pELElBQUksQ0FBQyxXQUFXLEdBQUcsU0FBUztZQUMxQixDQUFDLENBQUMsb0JBQVUsQ0FBQyxlQUFlLENBQUMsU0FBUyxFQUFFLFFBQVEsQ0FBQztZQUNqRCxDQUFDLENBQUMsb0JBQVUsQ0FBQyxlQUFlLENBQUMsUUFBUSxDQUFDLENBQUE7SUFDMUMsQ0FBQztJQUVELEtBQUssQ0FBQyxRQUFRLENBQUMsT0FBZ0I7UUFDN0IsTUFBTSxVQUFVLEdBQW9CLE1BQU0sSUFBSSxDQUFDLFdBQVcsQ0FBQyxRQUFRLENBQUMsT0FBTyxDQUFDLENBQUE7UUFDNUUsT0FBTyxVQUFVLENBQUE7SUFDbkIsQ0FBQztDQUNGO0FBYkQseUJBYUMiLCJzb3VyY2VzQ29udGVudCI6WyJpbXBvcnQgbm9kZW1haWxlciwgeyBUcmFuc3BvcnRlciwgU2VudE1lc3NhZ2VJbmZvIH0gZnJvbSAnbm9kZW1haWxlcidcbmltcG9ydCB7IFVybCB9IGZyb20gJ3VybCdcblxuZXhwb3J0IGRlZmF1bHQgY2xhc3MgTWFpbGVyIGltcGxlbWVudHMgSU1haWxlciB7XG4gIHByaXZhdGUgdHJhbnNwb3J0ZXJcblxuICBjb25zdHJ1Y3RvcihkZWZhdWx0cz86IGFueSwgdHJhbnNwb3J0PzogVHJhbnNwb3J0ZXIpIHtcbiAgICB0aGlzLnRyYW5zcG9ydGVyID0gdHJhbnNwb3J0XG4gICAgICA/IG5vZGVtYWlsZXIuY3JlYXRlVHJhbnNwb3J0KHRyYW5zcG9ydCwgZGVmYXVsdHMpXG4gICAgICA6IG5vZGVtYWlsZXIuY3JlYXRlVHJhbnNwb3J0KGRlZmF1bHRzKVxuICB9XG5cbiAgYXN5bmMgc2VuZE1haWwobWVzc2FnZTogTWVzc2FnZSk6IFByb21pc2U8U2VudE1lc3NhZ2VJbmZvPiB7XG4gICAgY29uc3QgbWFpbFJlc3VsdDogU2VudE1lc3NhZ2VJbmZvID0gYXdhaXQgdGhpcy50cmFuc3BvcnRlci5zZW5kTWFpbChtZXNzYWdlKVxuICAgIHJldHVybiBtYWlsUmVzdWx0XG4gIH1cbn1cblxuZXhwb3J0IGludGVyZmFjZSBJTWFpbGVyIHtcbiAgc2VuZE1haWwobWVzc2FnZTogTWVzc2FnZSk6IFByb21pc2U8U2VudE1lc3NhZ2VJbmZvPlxufVxuXG5leHBvcnQgaW50ZXJmYWNlIEF0dGFjaG1lbnQge1xuICAvKiogZmlsZW5hbWUgdG8gYmUgcmVwb3J0ZWQgYXMgdGhlIG5hbWUgb2YgdGhlIGF0dGFjaGVkIGZpbGUsIHVzZSBvZiB1bmljb2RlIGlzIGFsbG93ZWQuIElmIHlvdSBkbyBub3Qgd2FudCB0byB1c2UgYSBmaWxlbmFtZSwgc2V0IHRoaXMgdmFsdWUgYXMgZmFsc2UsIG90aGVyd2lzZSBhIGZpbGVuYW1lIGlzIGdlbmVyYXRlZCBhdXRvbWF0aWNhbGx5ICovXG4gIGZpbGVuYW1lPzogc3RyaW5nIHwgZmFsc2VcbiAgLyoqIHBhdGggdG8gYSBmaWxlIG9yIGFuIFVSTCAoZGF0YSB1cmlzIGFyZSBhbGxvd2VkIGFzIHdlbGwpIGlmIHlvdSB3YW50IHRvIHN0cmVhbSB0aGUgZmlsZSBpbnN0ZWFkIG9mIGluY2x1ZGluZyBpdCAoYmV0dGVyIGZvciBsYXJnZXIgYXR0YWNobWVudHMpICovXG4gIHBhdGg6IHN0cmluZyB8IFVybCB8IHVuZGVmaW5lZFxufVxuXG5leHBvcnQgdHlwZSBNZXNzYWdlID0ge1xuICBmcm9tOiBzdHJpbmdcbiAgdG86IHN0cmluZ1xuICBzdWJqZWN0OiBzdHJpbmdcbiAgaHRtbDogc3RyaW5nXG4gIGF0dGFjaG1lbnRzPzogQXR0YWNobWVudFtdXG59XG4iXX0=
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiTWFpbGVyLmpzIiwic291cmNlUm9vdCI6IiIsInNvdXJjZXMiOlsiLi4vc3JjL01haWxlci50cyJdLCJuYW1lcyI6W10sIm1hcHBpbmdzIjoiOzs7OztBQUFBLDREQUFxRTtBQUdyRSxNQUFxQixNQUFNO0lBR3pCLFlBQVksUUFBYyxFQUFFLFNBQXVCO1FBQ2pELElBQUksQ0FBQyxXQUFXLEdBQUcsU0FBUztZQUMxQixDQUFDLENBQUMsb0JBQVUsQ0FBQyxlQUFlLENBQUMsU0FBUyxFQUFFLFFBQVEsQ0FBQztZQUNqRCxDQUFDLENBQUMsb0JBQVUsQ0FBQyxlQUFlLENBQUMsUUFBUSxDQUFDLENBQUE7SUFDMUMsQ0FBQztJQUVELEtBQUssQ0FBQyxRQUFRLENBQUMsT0FBZ0I7UUFDN0IsT0FBTyxDQUFDLEdBQUcsQ0FBQyxjQUFjLEVBQUUsT0FBTyxDQUFDLENBQUE7UUFDcEMsTUFBTSxVQUFVLEdBQW9CLE1BQU0sSUFBSSxDQUFDLFdBQVcsQ0FBQyxRQUFRLENBQUMsT0FBTyxDQUFDLENBQUE7UUFDNUUsT0FBTyxDQUFDLEdBQUcsQ0FBQyxZQUFZLEVBQUUsVUFBVSxDQUFDLENBQUE7UUFFckMsT0FBTyxVQUFVLENBQUE7SUFDbkIsQ0FBQztDQUNGO0FBaEJELHlCQWdCQyIsInNvdXJjZXNDb250ZW50IjpbImltcG9ydCBub2RlbWFpbGVyLCB7IFRyYW5zcG9ydGVyLCBTZW50TWVzc2FnZUluZm8gfSBmcm9tICdub2RlbWFpbGVyJ1xuaW1wb3J0IHsgVXJsIH0gZnJvbSAndXJsJ1xuXG5leHBvcnQgZGVmYXVsdCBjbGFzcyBNYWlsZXIgaW1wbGVtZW50cyBJTWFpbGVyIHtcbiAgcHJpdmF0ZSB0cmFuc3BvcnRlclxuXG4gIGNvbnN0cnVjdG9yKGRlZmF1bHRzPzogYW55LCB0cmFuc3BvcnQ/OiBUcmFuc3BvcnRlcikge1xuICAgIHRoaXMudHJhbnNwb3J0ZXIgPSB0cmFuc3BvcnRcbiAgICAgID8gbm9kZW1haWxlci5jcmVhdGVUcmFuc3BvcnQodHJhbnNwb3J0LCBkZWZhdWx0cylcbiAgICAgIDogbm9kZW1haWxlci5jcmVhdGVUcmFuc3BvcnQoZGVmYXVsdHMpXG4gIH1cblxuICBhc3luYyBzZW5kTWFpbChtZXNzYWdlOiBNZXNzYWdlKTogUHJvbWlzZTxTZW50TWVzc2FnZUluZm8+IHtcbiAgICBjb25zb2xlLmxvZygnU2VuZGluZyBtYWlsJywgbWVzc2FnZSlcbiAgICBjb25zdCBtYWlsUmVzdWx0OiBTZW50TWVzc2FnZUluZm8gPSBhd2FpdCB0aGlzLnRyYW5zcG9ydGVyLnNlbmRNYWlsKG1lc3NhZ2UpXG4gICAgY29uc29sZS5sb2coJ21haWxSZXN1bHQnLCBtYWlsUmVzdWx0KVxuXG4gICAgcmV0dXJuIG1haWxSZXN1bHRcbiAgfVxufVxuXG5leHBvcnQgaW50ZXJmYWNlIElNYWlsZXIge1xuICBzZW5kTWFpbChtZXNzYWdlOiBNZXNzYWdlKTogUHJvbWlzZTxTZW50TWVzc2FnZUluZm8+XG59XG5cbmV4cG9ydCBpbnRlcmZhY2UgQXR0YWNobWVudCB7XG4gIC8qKiBmaWxlbmFtZSB0byBiZSByZXBvcnRlZCBhcyB0aGUgbmFtZSBvZiB0aGUgYXR0YWNoZWQgZmlsZSwgdXNlIG9mIHVuaWNvZGUgaXMgYWxsb3dlZC4gSWYgeW91IGRvIG5vdCB3YW50IHRvIHVzZSBhIGZpbGVuYW1lLCBzZXQgdGhpcyB2YWx1ZSBhcyBmYWxzZSwgb3RoZXJ3aXNlIGEgZmlsZW5hbWUgaXMgZ2VuZXJhdGVkIGF1dG9tYXRpY2FsbHkgKi9cbiAgZmlsZW5hbWU/OiBzdHJpbmcgfCBmYWxzZVxuICAvKiogcGF0aCB0byBhIGZpbGUgb3IgYW4gVVJMIChkYXRhIHVyaXMgYXJlIGFsbG93ZWQgYXMgd2VsbCkgaWYgeW91IHdhbnQgdG8gc3RyZWFtIHRoZSBmaWxlIGluc3RlYWQgb2YgaW5jbHVkaW5nIGl0IChiZXR0ZXIgZm9yIGxhcmdlciBhdHRhY2htZW50cykgKi9cbiAgcGF0aD86IHN0cmluZyB8IFVybFxuICB1cmw/OiBzdHJpbmcgfCBVcmxcbn1cblxuZXhwb3J0IHR5cGUgTWVzc2FnZSA9IHtcbiAgZnJvbTogc3RyaW5nXG4gIHRvOiBzdHJpbmdcbiAgc3ViamVjdDogc3RyaW5nXG4gIGh0bWw6IHN0cmluZ1xuICBhdHRhY2htZW50cz86IEF0dGFjaG1lbnRbXVxufVxuIl19

@@ -8,5 +8,4 @@ import { IMailer } from './Mailer';

logging: boolean;
lockType?: LockType;
private queueModel;
constructor(smtpCredentials: any, queueModel: IQueueModelStatic, expression?: string, maxAttemps?: number, logging?: boolean, lockType?: LockType);
constructor(smtpCredentials: any, queueModel: IQueueModelStatic, expression?: string, maxAttemps?: number, logging?: boolean);
private runJobs;

@@ -13,0 +12,0 @@ private processQueueMails;

@@ -6,8 +6,10 @@ "use strict";

Object.defineProperty(exports, "__esModule", { value: true });
const node_cron_1 = __importDefault(require("node-cron"));
// import cron from 'node-cron'
const cron_1 = require("cron");
const sequelize_1 = require("sequelize");
const Mailer_1 = __importDefault(require("./Mailer"));
const logger_1 = __importDefault(require("./utils/logger"));
const generateRandom_1 = require("./utils/generateRandom");
class Scheduler {
constructor(smtpCredentials, queueModel, expression = '0 */1 * * *', maxAttemps = -1, logging = false, lockType) {
constructor(smtpCredentials, queueModel, expression = '0 */1 * * *', maxAttemps = -1, logging = false) {
if (!isCronValid(expression)) {

@@ -19,11 +21,14 @@ throw new Error('Cron expression is invalid');

this.logging = logging;
console.log('Scheduler - - - --- - --', this.expression);
this.runJobs();
this.queueModel = queueModel;
this.mailer = new Mailer_1.default(smtpCredentials);
this.lockType = lockType;
}
async runJobs() {
this.log(`Initialising cron schedule ${this.expression}`);
node_cron_1.default.schedule(this.expression, async () => {
this.processQueueMails().catch((e) => {
await new Promise((resolve) => setTimeout(resolve, (0, generateRandom_1.generateRandom)(500, 2500)));
// eslint-disable-next-line @typescript-eslint/no-this-alias
const self = this;
const job = new cron_1.CronJob(this.expression, function () {
self.processQueueMails().catch((e) => {
logger_1.default.error('Cron failed', {

@@ -35,6 +40,20 @@ message: e.message,

});
console.log('After job instantiation');
job.start();
// cron.schedule(this.expression, async () => {
// // if scheduler runing
// this.processQueueMails().catch((e) => {
// logger.error('Cron failed', {
// message: e.message,
// stack: e.stack,
// })
// })
// })
}
async processQueueMails() {
const options = {};
const transaction = await this.queueModel.sequelize.transaction();
const options = {
transaction: transaction,
lock: true,
};
try {

@@ -46,6 +65,5 @@ if (this.maxAttemps > 0) {

},
transaction,
lock: true,
};
}
console.log('processQueueMails - - - --- - --');
const mails = await this.queueModel.findAll(options);

@@ -59,12 +77,7 @@ // Remove from queue(prevents duplicate sends with multiple workers)

}
await Promise.all(models);
await transaction.commit();
const results = await Promise.all(models);
const ids = results.map((r) => r.id);
await this.queueModel.destroy({
where: {
id: ids,
},
});
}
catch (e) {
console.log(e);
await transaction.rollback();

@@ -81,7 +94,22 @@ throw e;

}
console.log(`Mail sent to ${model.email_to}`, 'debug');
// Remove from queue
await this.queueModel.destroy({
where: {
id: model.id,
},
});
this.log(`Deleted mail from queue ${model.id}`, 'debug');
return model;
}
catch (e) {
logger_1.default.error(`Error sending mail to ${model.email_to}`, model);
logger_1.default.error(`Error sending mail to ${model.email_to}`, { model, error: e });
model.update({
last_error: JSON.stringify(e),
attempts: model.attempts + 1,
}, {
where: {
id: model.id,
},
});
return model;

@@ -96,2 +124,3 @@ }

html: mail.html,
attachments: mail.attachments,
};

@@ -111,2 +140,2 @@ return message;

exports.default = Scheduler;
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"Scheduler.js","sourceRoot":"","sources":["../src/Scheduler.ts"],"names":[],"mappings":"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","sourcesContent":["import cron from 'node-cron'\nimport { Op } from 'sequelize'\nimport Mailer, { IMailer, Message } from './Mailer'\nimport { IQueueModelStatic, NsqMailQueue } from './QueueModel'\nimport logger from './utils/logger'\n\nclass Scheduler implements IScheduler {\n  expression: string\n  maxAttemps: number\n  mailer: IMailer\n  logging: boolean\n  lockType?: LockType\n\n  private queueModel: IQueueModelStatic\n\n  constructor(\n    smtpCredentials: any,\n    queueModel: IQueueModelStatic,\n    expression = '0 */1 * * *',\n    maxAttemps = -1,\n    logging = false,\n    lockType?: LockType\n  ) {\n    if (!isCronValid(expression)) {\n      throw new Error('Cron expression is invalid')\n    }\n    this.expression = expression\n    this.maxAttemps = maxAttemps\n    this.logging = logging\n    this.runJobs()\n\n    this.queueModel = queueModel\n\n    this.mailer = new Mailer(smtpCredentials)\n    this.lockType = lockType\n  }\n\n  private async runJobs() {\n    this.log(`Initialising cron schedule ${this.expression}`)\n\n    cron.schedule(this.expression, async () => {\n      this.processQueueMails().catch((e) => {\n        logger.error('Cron failed', {\n          message: e.message,\n          stack: e.stack,\n        })\n      })\n    })\n  }\n\n  private async processQueueMails(): Promise<void> {\n    const options: any = {}\n    const transaction = await this.queueModel.sequelize.transaction()\n    try {\n      if (this.maxAttemps > 0) {\n        options.where = {\n          attempts: {\n            [Op.lt]: this.maxAttemps,\n          },\n          transaction,\n          lock: true,\n        }\n      }\n      const mails = await this.queueModel.findAll(options)\n      // Remove from queue(prevents duplicate sends with multiple workers)\n      this.log(`Sending queued mail, number: ${mails?.length}`)\n\n      const models = []\n      for (const mail of mails) {\n        const model = this.sendQueuedMail(mail as NsqMailQueue)\n        models.push(model)\n      }\n      await transaction.commit()\n\n      const results = await Promise.all(models)\n      const ids = results.map((r) => r.id)\n      await this.queueModel.destroy({\n        where: {\n          id: ids,\n        },\n      })\n    } catch (e) {\n      await transaction.rollback()\n      throw e\n    }\n  }\n\n  private async sendQueuedMail(model: NsqMailQueue): Promise<NsqMailQueue> {\n    try {\n      const message = this.composeMailFromModel(model)\n      const result = await this.mailer.sendMail(message)\n      if (!result.accepted) {\n        throw new Error('Error sending mail')\n      }\n\n      // Remove from queue\n      return model\n    } catch (e) {\n      logger.error(`Error sending mail to ${model.email_to}`, model)\n      return model\n    }\n  }\n\n  private composeMailFromModel(mail: NsqMailQueue): Message {\n    const message: Message = {\n      from: mail.email_from,\n      to: mail.email_to,\n      subject: mail.subject,\n      html: mail.html,\n    }\n    return message\n  }\n\n  private log(message: string, level = 'info'): void {\n    if (this.logging) {\n      logger.log(level, message)\n    }\n  }\n}\n\nexport interface IScheduler {\n  expression: string\n  maxAttemps: number\n  mailer: IMailer\n  logging: boolean\n}\n\nfunction isCronValid(freq: string): boolean {\n  const cronregex = new RegExp(\n    /^(\\*|([0-9]|1[0-9]|2[0-9]|3[0-9]|4[0-9]|5[0-9])|\\*\\/([0-9]|1[0-9]|2[0-9]|3[0-9]|4[0-9]|5[0-9])) (\\*|([0-9]|1[0-9]|2[0-3])|\\*\\/([0-9]|1[0-9]|2[0-3])) (\\*|([1-9]|1[0-9]|2[0-9]|3[0-1])|\\*\\/([1-9]|1[0-9]|2[0-9]|3[0-1])) (\\*|([1-9]|1[0-2])|\\*\\/([1-9]|1[0-2])) (\\*|([0-6])|\\*\\/([0-6]))$/\n  )\n  return cronregex.test(freq)\n}\n\nexport type LockType = 'transaction'\n\nexport default Scheduler\n"]}
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"Scheduler.js","sourceRoot":"","sources":["../src/Scheduler.ts"],"names":[],"mappings":"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","sourcesContent":["// import cron from 'node-cron'\nimport { CronJob } from 'cron'\nimport { Op } from 'sequelize'\nimport Mailer, { IMailer, Message } from './Mailer'\nimport { IQueueModelStatic, NsqMailQueue } from './QueueModel'\nimport logger from './utils/logger'\nimport { generateRandom } from './utils/generateRandom'\n\nclass Scheduler implements IScheduler {\n  expression: string\n  maxAttemps: number\n  mailer: IMailer\n  logging: boolean\n\n  private queueModel: IQueueModelStatic\n\n  constructor(\n    smtpCredentials: any,\n    queueModel: IQueueModelStatic,\n    expression = '0 */1 * * *',\n    maxAttemps = -1,\n    logging = false\n  ) {\n    if (!isCronValid(expression)) {\n      throw new Error('Cron expression is invalid')\n    }\n    this.expression = expression\n    this.maxAttemps = maxAttemps\n    this.logging = logging\n\n    console.log('Scheduler - -       - --- - --', this.expression)\n    this.runJobs()\n\n    this.queueModel = queueModel\n\n    this.mailer = new Mailer(smtpCredentials)\n  }\n\n  private async runJobs() {\n    this.log(`Initialising cron schedule ${this.expression}`)\n\n    await new Promise((resolve) => setTimeout(resolve, generateRandom(500, 2500)))\n    // eslint-disable-next-line @typescript-eslint/no-this-alias\n    const self = this\n    const job = new CronJob(this.expression, function () {\n      self.processQueueMails().catch((e) => {\n        logger.error('Cron failed', {\n          message: e.message,\n          stack: e.stack,\n        })\n      })\n    })\n    console.log('After job instantiation')\n    job.start()\n    // cron.schedule(this.expression, async () => {\n    //   // if scheduler runing\n\n    //   this.processQueueMails().catch((e) => {\n    //     logger.error('Cron failed', {\n    //       message: e.message,\n    //       stack: e.stack,\n    //     })\n    //   })\n    // })\n  }\n\n  private async processQueueMails(): Promise<void> {\n    const transaction = await this.queueModel.sequelize.transaction()\n    const options: any = {\n      transaction: transaction,\n      lock: true,\n    }\n    try {\n      if (this.maxAttemps > 0) {\n        options.where = {\n          attempts: {\n            [Op.lt]: this.maxAttemps,\n          },\n        }\n      }\n      console.log('processQueueMails - -       - --- - --')\n      const mails = await this.queueModel.findAll(options)\n      // Remove from queue(prevents duplicate sends with multiple workers)\n      this.log(`Sending queued mail, number: ${mails?.length}`)\n\n      const models = []\n      for (const mail of mails) {\n        const model = this.sendQueuedMail(mail as NsqMailQueue)\n        models.push(model)\n      }\n\n      await Promise.all(models)\n      await transaction.commit()\n    } catch (e) {\n      console.log(e)\n      await transaction.rollback()\n      throw e\n    }\n  }\n\n  private async sendQueuedMail(model: NsqMailQueue): Promise<NsqMailQueue> {\n    try {\n      const message = this.composeMailFromModel(model)\n      const result = await this.mailer.sendMail(message)\n      if (!result.accepted) {\n        throw new Error('Error sending mail')\n      }\n\n      console.log(`Mail sent to ${model.email_to}`, 'debug')\n      // Remove from queue\n      await this.queueModel.destroy({\n        where: {\n          id: model.id,\n        },\n      })\n      this.log(`Deleted mail from queue ${model.id}`, 'debug')\n\n      return model\n    } catch (e) {\n      logger.error(`Error sending mail to ${model.email_to}`, { model, error: e })\n      model.update(\n        {\n          last_error: JSON.stringify(e),\n          attempts: model.attempts + 1,\n        },\n        {\n          where: {\n            id: model.id,\n          },\n        }\n      )\n      return model\n    }\n  }\n\n  private composeMailFromModel(mail: NsqMailQueue): Message {\n    const message: Message = {\n      from: mail.email_from,\n      to: mail.email_to,\n      subject: mail.subject,\n      html: mail.html,\n      attachments: mail.attachments,\n    }\n    return message\n  }\n\n  private log(message: string, level = 'info'): void {\n    if (this.logging) {\n      logger.log(level, message)\n    }\n  }\n}\n\nexport interface IScheduler {\n  expression: string\n  maxAttemps: number\n  mailer: IMailer\n  logging: boolean\n}\n\nfunction isCronValid(freq: string): boolean {\n  const cronregex = new RegExp(\n    /^(\\*|([0-9]|1[0-9]|2[0-9]|3[0-9]|4[0-9]|5[0-9])|\\*\\/([0-9]|1[0-9]|2[0-9]|3[0-9]|4[0-9]|5[0-9])) (\\*|([0-9]|1[0-9]|2[0-3])|\\*\\/([0-9]|1[0-9]|2[0-3])) (\\*|([1-9]|1[0-9]|2[0-9]|3[0-1])|\\*\\/([1-9]|1[0-9]|2[0-9]|3[0-1])) (\\*|([1-9]|1[0-2])|\\*\\/([1-9]|1[0-2])) (\\*|([0-6])|\\*\\/([0-6]))$/\n  )\n  return cronregex.test(freq)\n}\n\nexport type LockType = 'transaction'\n\nexport default Scheduler\n"]}
{
"name": "nodemailer-sequelize-queue",
"version": "0.0.16",
"version": "0.0.17",
"description": "Queue for mails with nodemailer and cron scheduler",

@@ -24,3 +24,3 @@ "main": "./dist/index.js",

"release": "npm run build && standard-version",
"release:publish": "git add . && npm run release && git push --follow-tags origin main && npm publish"
"release:publish": "git add . && npm run release && git push --follow-tags origin master && npm publish"
},

@@ -52,2 +52,3 @@ "repository": {

"devDependencies": {
"@types/cron": "^2.0.1",
"@types/node": "^10.17.60",

@@ -79,2 +80,3 @@ "@types/prettier": "2.6.0",

"@types/winston": "^2.4.4",
"cron": "^2.3.0",
"node-cron": "^3.0.2",

@@ -81,0 +83,0 @@ "nodemailer": "^6.7.8",

SocketSocket SOC 2 Logo

Product

  • Package Alerts
  • Integrations
  • Docs
  • Pricing
  • FAQ
  • Roadmap
  • Changelog

Packages

npm

Stay in touch

Get open source security insights delivered straight into your inbox.


  • Terms
  • Privacy
  • Security

Made with ⚡️ by Socket Inc