overleaf/services/web/app/coffee/Features/Email/EmailSender.coffee

80 lines
3.1 KiB
CoffeeScript
Raw Normal View History

logger = require('logger-sharelatex')
metrics = require('metrics-sharelatex')
Settings = require('settings-sharelatex')
2014-03-06 15:37:25 +00:00
nodemailer = require("nodemailer")
sesTransport = require('nodemailer-ses-transport')
2016-03-29 13:15:33 +00:00
sgTransport = require('nodemailer-sendgrid-transport')
2017-12-11 11:05:04 +00:00
mandrillTransport = require('nodemailer-mandrill-transport')
rateLimiter = require('../../infrastructure/RateLimiter')
_ = require("underscore")
if Settings.email? and Settings.email.fromAddress?
defaultFromAddress = Settings.email.fromAddress
2014-03-06 15:37:25 +00:00
else
defaultFromAddress = ""
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()
if Settings?.email?.parameters?.AWSAccessKeyID? or Settings?.email?.driver == 'ses'
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}}))
2017-12-11 11:48:31 +00:00
else if Settings?.email?.parameters?.MandrillApiKey?
2017-12-11 11:05:04 +00:00
logger.log "using mandril for email"
2017-12-11 11:48:31 +00:00
nm_client = nodemailer.createTransport(mandrillTransport({auth:{apiKey:Settings?.email?.parameters?.MandrillApiKey}}))
else if Settings?.email?.parameters?
logger.log "using smtp for email"
2017-12-11 11:05:04 +00:00
smtp = _.pick(Settings?.email?.parameters, "host", "port", "secure", "auth", "ignoreTLS")
nm_client = nodemailer.createTransport(smtp)
else
logger.warn "Email transport and/or parameters not defined. No emails will be sent."
2017-12-11 11:05:04 +00:00
nm_client = client
if nm_client?
client = nm_client
else
logger.warn "Failed to create email transport. Please check your settings. No email will be sent."
checkCanSendEmail = (options, callback)->
if !options.sendingUser_id? #email not sent from user, not rate limited
2017-01-17 16:25:18 +00:00
return callback(null, true)
opts =
endpointName: "send_email"
timeInterval: 60 * 60 * 3
subjectName: options.sendingUser_id
throttle: 100
rateLimiter.addCount opts, callback
2014-03-06 15:37:25 +00:00
module.exports =
sendEmail : (options, callback = (error) ->)->
2014-03-12 23:37:54 +00:00
logger.log receiver:options.to, subject:options.subject, "sending email"
checkCanSendEmail options, (err, canContinue)->
if err?
return callback(err)
if !canContinue
logger.log sendingUser_id:options.sendingUser_id, to:options.to, subject:options.subject, canContinue:canContinue, "rate limit hit for sending email, not sending"
return callback("rate limit hit sending email")
metrics.inc "email"
options =
to: options.to
from: defaultFromAddress
subject: options.subject
html: options.html
text: options.text
replyTo: options.replyTo || Settings.email.replyToAddress
socketTimeout: 30 * 1000
if Settings.email.textEncoding?
opts.textEncoding = textEncoding
client.sendMail options, (err, res)->
if err?
logger.err err:err, "error sending message"
2017-03-27 16:45:19 +00:00
err = new Error('Cannot send email')
else
logger.log "Message sent to #{options.to}"
2017-03-27 16:45:19 +00:00
callback(err)