2021-06-19 09:56:35 -06:00
|
|
|
#!/usr/local/bin/python3
|
2020-06-03 12:38:11 -04:00
|
|
|
|
|
|
|
import sys
|
|
|
|
sys.path.append('/srv/newsblur')
|
|
|
|
|
|
|
|
import requests
|
2021-05-26 11:41:28 -04:00
|
|
|
from newsblur_web import settings
|
2020-06-03 12:38:11 -04:00
|
|
|
import socket
|
|
|
|
|
|
|
|
def main():
|
|
|
|
hostname = socket.gethostname()
|
|
|
|
admin_email = settings.ADMINS[0][1]
|
|
|
|
|
|
|
|
r = requests.get("https://api.mailgun.net/v3/newsletters.newsblur.com/stats/total",
|
|
|
|
auth=("api", settings.MAILGUN_ACCESS_KEY),
|
|
|
|
params={"event": ["accepted", "delivered", "failed"],
|
|
|
|
"duration": "2h"})
|
|
|
|
stats = r.json()['stats'][0]
|
|
|
|
delivered = stats['delivered']['total']
|
|
|
|
accepted = stats['delivered']['total']
|
|
|
|
bounced = stats['failed']['permanent']['total'] + stats['failed']['temporary']['total']
|
2021-07-14 11:11:44 -04:00
|
|
|
if bounced / float(delivered) > 0.5:
|
2020-06-03 12:38:11 -04:00
|
|
|
requests.post(
|
|
|
|
"https://api.mailgun.net/v2/%s/messages" % settings.MAILGUN_SERVER_NAME,
|
|
|
|
auth=("api", settings.MAILGUN_ACCESS_KEY),
|
2020-06-08 15:11:42 -04:00
|
|
|
data={"from": "NewsBlur Newsletter Monitor: %s <admin@%s.newsblur.com>" % (hostname, hostname),
|
2020-06-03 12:38:11 -04:00
|
|
|
"to": [admin_email],
|
2021-07-14 11:11:44 -04:00
|
|
|
"subject": "%s newsletters bounced (2h): %s/%s accepted/delivered -> %s bounced" % (hostname, accepted, delivered, bounced),
|
2020-06-03 12:44:47 -04:00
|
|
|
"text": "Newsletters are not being delivered! %s delivered, %s bounced" % (delivered, bounced)})
|
2020-06-19 02:27:48 -04:00
|
|
|
print(" ---> %s newsletters bounced: %s > %s > %s" % (hostname, accepted, delivered, bounced))
|
2020-06-03 12:38:11 -04:00
|
|
|
else:
|
2020-06-19 02:27:48 -04:00
|
|
|
print(" ---> %s newsletters OK: %s > %s > %s" % (hostname, accepted, delivered, bounced))
|
2020-06-03 12:38:11 -04:00
|
|
|
|
|
|
|
if __name__ == '__main__':
|
|
|
|
main()
|