ticketfrei3/kibicara/platforms/email/bot.py
2020-07-17 15:51:14 +02:00

57 lines
1.9 KiB
Python

# Copyright (C) 2020 by Maike <maike@systemli.org>
#
# SPDX-License-Identifier: 0BSD
from kibicara.platforms.email.model import EmailSubscribers, Email
from kibicara.platformapi import Censor, Spawner
from kibicara.email import send_email
from kibicara.config import config
from kibicara.webapi.admin import to_token
from smtplib import SMTPException
from logging import getLogger
logger = getLogger(__name__)
class EmailBot(Censor):
def __init__(self, email_model):
super().__init__(email_model.hood)
self.model = email_model
self.messages = []
async def run(self):
""" Loop which waits for new messages and sends emails to all subscribers. """
while True:
message = await self.receive()
for subscriber in EmailSubscribers(hood=self.hood.id):
payload = {
'email': subscriber.email,
'hood': self.hood.id,
}
token = to_token(email=subscriber.email, hood=self.hood.id)
unsubscribe_link = (
config['root_url']
+ 'api/'
+ self.model.id
+ '/email/unsubscribe/'
+ token
)
message.text += (
"\n\n--\nIf you want to stop receiving these mails, "
"follow this link: " + unsubscribe_link
)
try:
send_email(
subscriber.email,
"Kibicara " + self.hood.name,
body=message.text,
)
except (ConnectionRefusedError, SMTPException):
logger.error(
"Sending subscription confirmation email failed.", exc_info=True
)
spawner = Spawner(Email, EmailBot)