Skip to content

Commit

Permalink
Implement SMTP email service
Browse files Browse the repository at this point in the history
  • Loading branch information
hirunatan committed Jul 16, 2018
1 parent c075c56 commit b65caca
Show file tree
Hide file tree
Showing 4 changed files with 56 additions and 12 deletions.
17 changes: 14 additions & 3 deletions config/default.json
Original file line number Diff line number Diff line change
@@ -1,8 +1,10 @@
{
//"endpoint": "http://localhost:9000",
"team_name": "My Open Spacedeck",
"contact_email": "[email protected]",

"endpoint": "http://localhost:9666",
"storage_region": "eu-central-1",

"storage_region": "eu-central-1",
//"storage_bucket": "sdeck-development",
//"storage_cdn": "http://localhost:9123/sdeck-development",
//"storage_endpoint": "http://storage:9000",
Expand All @@ -18,5 +20,14 @@
"google_access" : "",
"google_secret" : "",
"admin_pass": "very_secret_admin_password",
"phantom_api_secret": "very_secret_phantom_password"
"phantom_api_secret": "very_secret_phantom_password",

// Choose "console" or "smtp"
"mail_provider": "smtp",
"mail_smtp_host": "your.smtp.host",
"mail_smtp_port": 465,
"mail_smtp_secure": true,
"mail_smtp_require_tls": true,
"mail_smtp_user": "your.smtp.user",
"mail_smtp_pass": "your.secret.smtp.password"
}
48 changes: 40 additions & 8 deletions helpers/mailer.js
Original file line number Diff line number Diff line change
@@ -1,18 +1,18 @@
'use strict';

var swig = require('swig');
const config = require('config');
const nodemailer = require('nodemailer');
const swig = require('swig');
//var AWS = require('aws-sdk');

module.exports = {
sendMail: (to_email, subject, body, options) => {

if (!options) {
options = {};
}

// FIXME
const teamname = options.teamname || "My Open Spacedeck"
const from = teamname + ' <[email protected]>';
const teamname = options.teamname || config.get('team_name');
const from = teamname + ' <' + config.get('contact_email') + '>';

let reply_to = [from];
if (options.reply_to) {
Expand All @@ -29,9 +29,40 @@ module.exports = {
options: options
});

//if (process.env.NODE_ENV === 'development') {
if (config.get('mail_provider') === 'console') {

console.log("Email: to " + to_email + " in production.\nreply_to: " + reply_to + "\nsubject: " + subject + "\nbody: \n" + htmlText + "\n\n plaintext:\n" + plaintext);
/*} else {

} else if (config.get('mail_provider') === 'smtp') {

const transporter = nodemailer.createTransport({
host: config.get('mail_smtp_host'),
port: config.get('mail_smtp_port'),
secure: config.get('mail_smtp_secure'),
requireTLS: config.get('mail_smtp_require_tls'),
auth: {
user: config.get('mail_smtp_user'),
pass: config.get('mail_smtp_pass'),
}
});

transporter.sendMail({
from: from,
replyTo: reply_to,
to: to_email,
subject: subject,
text: plaintext,
html: htmlText,
}, function(err, info) {
if (err) {
console.error("Error sending email:", err);
} else {
console.log("Email sent.");
}
});

} else if (config.get('mail_provider') === 'aws') {
/*
AWS.config.update({region: 'eu-west-1'});
var ses = new AWS.SES();
Expand All @@ -56,6 +87,7 @@ module.exports = {
if (err) console.error("Error sending email:", err);
else console.log("Email sent.");
});
}*/
*/
}
}
};
1 change: 1 addition & 0 deletions package.json
Original file line number Diff line number Diff line change
Expand Up @@ -30,6 +30,7 @@
"moment": "^2.19.3",
"morgan": "1.8.1",
"node-phantom-simple": "2.2.4",
"nodemailer": "^4.6.7",
"phantomjs-prebuilt": "2.1.14",
"read-chunk": "^2.1.0",
"request": "2.81.0",
Expand Down
2 changes: 1 addition & 1 deletion routes/api/users.js
Original file line number Diff line number Diff line change
Expand Up @@ -283,7 +283,7 @@ router.post('/password_reset_requests', (req, res, next) => {
router.post('/password_reset_requests/:confirm_token/confirm', function(req, res, next) {
var password = req.body.password;

User
db.User
.findOne({where: {"password_reset_token": req.params.confirm_token}})
.then((user) => {
if (user) {
Expand Down

0 comments on commit b65caca

Please sign in to comment.