2014-10-28 16:10:44 +00:00
|
|
|
import logging
|
|
|
|
import traceback
|
|
|
|
|
2013-09-27 23:29:01 +00:00
|
|
|
from flask.ext.mail import Message
|
|
|
|
|
2014-07-29 17:47:54 +00:00
|
|
|
from app import mail, app, get_app_url
|
2014-09-05 23:57:33 +00:00
|
|
|
from data import model
|
|
|
|
from util.gravatar import compute_hash
|
2014-10-22 23:01:56 +00:00
|
|
|
from util.jinjautil import get_template_env
|
2014-09-05 23:57:33 +00:00
|
|
|
|
2014-10-28 16:10:44 +00:00
|
|
|
logger = logging.getLogger(__name__)
|
2014-10-22 23:01:56 +00:00
|
|
|
template_env = get_template_env("emails")
|
2014-09-05 23:57:33 +00:00
|
|
|
|
2014-10-28 16:10:44 +00:00
|
|
|
class CannotSendEmailException(Exception):
|
|
|
|
pass
|
|
|
|
|
2014-09-05 23:57:33 +00:00
|
|
|
def send_email(recipient, subject, template_file, parameters):
|
|
|
|
app_title = app.config['REGISTRY_TITLE_SHORT']
|
|
|
|
app_url = get_app_url()
|
|
|
|
|
|
|
|
def app_link_handler(url=None, title=None):
|
|
|
|
real_url = app_url + '/' + url if url else app_url
|
|
|
|
if not title:
|
|
|
|
title = real_url if url else app_title
|
|
|
|
|
|
|
|
return '<a href="%s">%s</a>' % (real_url, title)
|
|
|
|
|
|
|
|
parameters.update({
|
|
|
|
'subject': subject,
|
|
|
|
'app_logo': 'https://quay.io/static/img/quay-logo.png', # TODO: make this pull from config
|
|
|
|
'app_url': app_url,
|
|
|
|
'app_title': app_title,
|
|
|
|
'app_link': app_link_handler
|
|
|
|
})
|
|
|
|
|
|
|
|
rendered_html = template_env.get_template(template_file + '.html').render(parameters)
|
|
|
|
|
2014-10-10 17:14:33 +00:00
|
|
|
msg = Message('[%s] %s' % (app_title, subject), recipients=[recipient])
|
2014-09-05 23:57:33 +00:00
|
|
|
msg.html = rendered_html
|
2013-09-27 23:29:01 +00:00
|
|
|
|
2014-10-28 16:10:44 +00:00
|
|
|
try:
|
|
|
|
mail.send(msg)
|
|
|
|
except Exception as ex:
|
2014-11-03 22:16:36 +00:00
|
|
|
logger.exception('Error while trying to send email to %s', recipient)
|
2014-10-28 16:10:44 +00:00
|
|
|
raise CannotSendEmailException(ex.message)
|
2013-09-27 23:29:01 +00:00
|
|
|
|
2014-09-05 23:57:33 +00:00
|
|
|
def send_password_changed(username, email):
|
|
|
|
send_email(email, 'Account password changed', 'passwordchanged', {
|
|
|
|
'username': username
|
|
|
|
})
|
2014-04-17 20:18:37 +00:00
|
|
|
|
2014-09-05 23:57:33 +00:00
|
|
|
def send_email_changed(username, old_email, new_email):
|
|
|
|
send_email(old_email, 'Account e-mail address changed', 'emailchanged', {
|
|
|
|
'username': username,
|
|
|
|
'new_email': new_email
|
|
|
|
})
|
2014-04-15 21:00:32 +00:00
|
|
|
|
2014-01-17 22:04:05 +00:00
|
|
|
def send_change_email(username, email, token):
|
2014-09-05 23:57:33 +00:00
|
|
|
send_email(email, 'E-mail address change requested', 'changeemail', {
|
|
|
|
'username': username,
|
|
|
|
'token': token
|
|
|
|
})
|
2014-01-17 22:04:05 +00:00
|
|
|
|
2013-09-27 23:29:01 +00:00
|
|
|
def send_confirmation_email(username, email, token):
|
2014-09-05 23:57:33 +00:00
|
|
|
send_email(email, 'Please confirm your e-mail address', 'confirmemail', {
|
|
|
|
'username': username,
|
|
|
|
'token': token
|
|
|
|
})
|
2013-10-14 21:50:07 +00:00
|
|
|
|
2014-07-28 18:58:12 +00:00
|
|
|
def send_repo_authorization_email(namespace, repository, email, token):
|
2014-09-05 23:57:33 +00:00
|
|
|
subject = 'Please verify your e-mail address for repository %s/%s' % (namespace, repository)
|
|
|
|
send_email(email, subject, 'repoauthorizeemail', {
|
|
|
|
'namespace': namespace,
|
|
|
|
'repository': repository,
|
|
|
|
'token': token
|
|
|
|
})
|
2014-07-28 18:58:12 +00:00
|
|
|
|
2013-10-14 21:50:07 +00:00
|
|
|
def send_recovery_email(email, token):
|
2014-09-05 23:57:33 +00:00
|
|
|
subject = 'Account recovery'
|
|
|
|
send_email(email, subject, 'recovery', {
|
|
|
|
'email': email,
|
|
|
|
'token': token
|
|
|
|
})
|
|
|
|
|
|
|
|
def send_payment_failed(email, username):
|
|
|
|
send_email(email, 'Subscription Payment Failure', 'paymentfailure', {
|
|
|
|
'username': username
|
|
|
|
})
|
2013-11-15 19:42:31 +00:00
|
|
|
|
2014-09-18 17:20:32 +00:00
|
|
|
def send_org_invite_email(member_name, member_email, orgname, team, adder, code):
|
|
|
|
send_email(member_email, 'Invitation to join team', 'teaminvite', {
|
|
|
|
'inviter': adder,
|
|
|
|
'token': code,
|
|
|
|
'organization': orgname,
|
|
|
|
'teamname': team
|
|
|
|
})
|
2013-11-15 19:42:31 +00:00
|
|
|
|
|
|
|
|
|
|
|
def send_invoice_email(email, contents):
|
2014-09-05 23:57:33 +00:00
|
|
|
# Note: This completely generates the contents of the email, so we don't use the
|
|
|
|
# normal template here.
|
2014-10-10 17:14:33 +00:00
|
|
|
msg = Message('Quay.io payment received - Thank you!', recipients=[email])
|
2013-11-15 19:42:31 +00:00
|
|
|
msg.html = contents
|
|
|
|
mail.send(msg)
|
2014-04-15 21:00:32 +00:00
|
|
|
|
|
|
|
|
2014-09-05 23:57:33 +00:00
|
|
|
# INTERNAL EMAILS BELOW
|
|
|
|
|
2014-04-17 20:18:37 +00:00
|
|
|
def send_subscription_change(change_description, customer_id, customer_email, quay_username):
|
2014-09-05 23:57:33 +00:00
|
|
|
SUBSCRIPTION_CHANGE_TITLE = 'Subscription Change - {0} {1}'
|
2014-09-23 20:28:06 +00:00
|
|
|
SUBSCRIPTION_CHANGE = """
|
|
|
|
Change: {0}<br>
|
|
|
|
Customer id: <a href="https://manage.stripe.com/customers/{1}">{1}</a><br>
|
|
|
|
Customer email: <a href="mailto:{2}">{2}</a><br>
|
|
|
|
Quay user or org name: {3}<br>
|
|
|
|
"""
|
|
|
|
|
2014-04-17 20:18:37 +00:00
|
|
|
title = SUBSCRIPTION_CHANGE_TITLE.format(quay_username, change_description)
|
2014-10-10 17:14:33 +00:00
|
|
|
msg = Message(title, recipients=['stripe@quay.io'])
|
2014-04-17 20:18:37 +00:00
|
|
|
msg.html = SUBSCRIPTION_CHANGE.format(change_description, customer_id, customer_email,
|
|
|
|
quay_username)
|
2014-04-15 21:00:32 +00:00
|
|
|
mail.send(msg)
|
2014-04-22 17:56:34 +00:00
|
|
|
|
|
|
|
|