2014-03-04 18:10:06 +00:00
|
|
|
logger = require('logger-sharelatex')
|
|
|
|
metrics = require('../../infrastructure/Metrics')
|
|
|
|
Settings = require('settings-sharelatex')
|
2014-03-06 15:37:25 +00:00
|
|
|
nodemailer = require("nodemailer")
|
2016-02-12 17:13:45 +00:00
|
|
|
sesTransport = require('nodemailer-ses-transport')
|
2016-03-29 13:15:33 +00:00
|
|
|
sgTransport = require('nodemailer-sendgrid-transport')
|
|
|
|
|
2016-02-12 17:13:45 +00:00
|
|
|
_ = require("underscore")
|
2014-03-04 18:10:06 +00:00
|
|
|
|
2014-03-05 22:37:55 +00:00
|
|
|
if Settings.email? and Settings.email.fromAddress?
|
|
|
|
defaultFromAddress = Settings.email.fromAddress
|
2014-03-06 15:37:25 +00:00
|
|
|
else
|
2014-03-05 22:57:28 +00:00
|
|
|
defaultFromAddress = ""
|
2014-03-05 11:57:57 +00:00
|
|
|
|
2014-03-06 15:37:25 +00:00
|
|
|
# provide dummy mailer unless we have a better one configured.
|
|
|
|
client =
|
|
|
|
sendMail: (options, callback = (err,status) ->) ->
|
|
|
|
logger.log options:options, "Would send email if enabled."
|
|
|
|
callback()
|
2014-03-04 18:10:06 +00:00
|
|
|
|
2016-02-12 17:13:45 +00:00
|
|
|
if Settings?.email?.parameters?.AWSAccessKeyID?
|
|
|
|
logger.log "using aws ses for email"
|
|
|
|
nm_client = nodemailer.createTransport(sesTransport(Settings.email.parameters))
|
2016-03-29 13:15:33 +00:00
|
|
|
else if Settings?.email?.parameters?.sendgridApiKey?
|
|
|
|
logger.log "using sendgrid for email"
|
|
|
|
nm_client = nodemailer.createTransport(sgTransport({auth:{api_key:Settings?.email?.parameters?.sendgridApiKey}}))
|
2016-02-12 17:13:45 +00:00
|
|
|
else if Settings?.email?.parameters?
|
|
|
|
smtp = _.pick(Settings?.email?.parameters, "host", "port", "secure", "auth")
|
|
|
|
|
|
|
|
|
|
|
|
logger.log "using smtp for email"
|
|
|
|
nm_client = nodemailer.createTransport(smtp)
|
|
|
|
else
|
|
|
|
nm_client = client
|
|
|
|
logger.warn "Email transport and/or parameters not defined. No emails will be sent."
|
|
|
|
|
|
|
|
if nm_client?
|
|
|
|
client = nm_client
|
|
|
|
else
|
|
|
|
logger.warn "Failed to create email transport. Please check your settings. No email will be sent."
|
|
|
|
|
2014-03-04 18:10:06 +00:00
|
|
|
|
2014-03-06 15:37:25 +00:00
|
|
|
module.exports =
|
2014-03-04 18:10:06 +00:00
|
|
|
sendEmail : (options, callback = (error) ->)->
|
2014-03-12 23:37:54 +00:00
|
|
|
logger.log receiver:options.to, subject:options.subject, "sending email"
|
2014-03-04 18:10:06 +00:00
|
|
|
metrics.inc "email"
|
2014-03-06 15:37:25 +00:00
|
|
|
options =
|
2014-03-04 18:10:06 +00:00
|
|
|
to: options.to
|
2014-03-05 22:37:55 +00:00
|
|
|
from: defaultFromAddress
|
2014-03-04 18:10:06 +00:00
|
|
|
subject: options.subject
|
2014-03-12 11:43:36 +00:00
|
|
|
html: options.html
|
2016-10-03 14:25:38 +00:00
|
|
|
text: options.text
|
2014-03-05 12:06:28 +00:00
|
|
|
replyTo: options.replyTo || Settings.email.replyToAddress
|
2014-06-17 17:18:45 +00:00
|
|
|
socketTimeout: 30 * 1000
|
2016-10-14 15:43:59 +00:00
|
|
|
if Settings.email.textEncoding?
|
2016-10-13 13:21:54 +00:00
|
|
|
opts.textEncoding = textEncoding
|
2014-03-06 15:37:25 +00:00
|
|
|
client.sendMail options, (err, res)->
|
2014-03-04 18:10:06 +00:00
|
|
|
if err?
|
|
|
|
logger.err err:err, "error sending message"
|
|
|
|
else
|
|
|
|
logger.log "Message sent to #{options.to}"
|
|
|
|
callback(err)
|