-
Notifications
You must be signed in to change notification settings - Fork 7
/
Copy pathmailer.py
44 lines (36 loc) · 1.79 KB
/
mailer.py
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
import os
import requests
import logging
from tornado import template
import verifier
logger = logging.getLogger(__name__)
DOMAIN_NAME = 'torweather.org'
API_KEY = os.environ.get('MAILGUN_KEY')
EMAIL_DOWN_SUBJECT = '[Tor Weather] Node Down!'
EMAIL_DOWN_BODY = '''
It appears that the Tor node {{nickname}} (fingerprint: {{fingerprint}}) has been uncontactable through the Tor network for at least 48 hours. You may wish to look at it to see why.
You can find more information about the Tor node at:
https://metrics.torproject.org/rs.html#details/{{fingerprint}}
You can unsubscribe from these reports at any time by visiting the following url:
https://www.torweather.org/unsubscribe?hmac={{hmac}}&fingerprint={{fingerprint}}
The original Tor Weather was decommissioned by the Tor project and this replacement is now maintained independently. You can learn more here:
https://github.com/thingless/torweather/blob/master/README.md
'''
email_down_template = template.Template(EMAIL_DOWN_BODY)
def alert_down(node):
parms = dict(node)
parms['hmac'] = verifier.generate(parms['fingerprint'])
logger.info('Emailing node_down %r', parms)
if os.environ.get('PROD'):
assert API_KEY
try:
return requests.post("https://api.mailgun.net/v3/{}/messages".format(DOMAIN_NAME),
auth=("api", API_KEY),
data={
"from": "Tor Weather <noreply@{}>".format(DOMAIN_NAME),
"to": [parms['email']],
"subject": EMAIL_DOWN_SUBJECT,
"text": email_down_template.generate(**parms)
})
except Exception as e:
logger.exception("Failed to send email :(")