Skip to main content

Template for email

Project description

Django приложение шаблона письма email с поддержкой отправки через Celery task

Конфигурация

Подключение приложения

INSTALLED_APPS = [
    'mail_satvadev',
]

Использование базового класса шаблона письма

Для использования необходимо переопределить абстрактные свойства класса:

    @property
    @abc.abstractmethod
    def title(self):
        """Тема письма"""
        pass

    @property
    @abc.abstractmethod
    def template(self):
        """Шаблон письма"""
        pass

Для динамического формирования содержимого поддерживается подстановка значений в текстовый шаблон с требуемым форматированием.

Данные контекста в формате словаря передаются в конструктор при инициализации класса, и могут быть обработаны и преобразованы в переопределяемом методе

    _prepare_context(self, **kwargs)

по-умолчанию метод возвращает переданные kwargs без изменения.

Форматирование и подстановка контекста в текстовый шаблон может быть произведена в переопределяемом методе

    _generate_text(self, context)

по-умолчанию метод подставляет данные контекста в шаблон template.

Базовый класс поддерживает подстановку стандартного окончания в содержимое шаблона. Завершающий текст задается через свойство

    @property
    def footer(self):
        """Стандартное окончание письма"""

по-умолчанию - пустая строка.

Проверка формата электронной почты получателей письма

Поддерживается валидация списка получателей письма на корректность формата адресов электронной почты.

from mail_satvadev.filters import RecipientFilter


validator = RecipientFilter()
emails = validator.filter_emails(emails)  # Только корректные адреса email

Отправление письма получателем через Celery task

Для отправки письма через Celery task в файле настроек проекта settings.py должны быть прописаны

# Почта отправителя
EMAIL_HOST_USER=my.smtp.provider@.email.com
# Максимальное кол-во повторных попыток отправки
CELERY_MAX_RETRIES_COUNT=3

Отправление письма

  • subject - тема письма
  • emails_list - список электронных адресов получателей
  • text - содержимое письма в текстовом формате

опционально

  • параметр backoff - для повторных отправлений в случае неудачи (по алгоритму exponential backoff), по-умолчанию не задан.
from mail_satvadev.tasks import send_email

subject = `Тема письма`
emails_list = ['admin@example.com', 'user@example.com']
text = 'Содержимое письма'
send_email.delay(subject, emails_list, text, backoff)

Примеры использования

Письмо с проверочным кодом сброса пароля

from mail_satvadev.messages import BaseMail


class ResetPasswordMail(BaseMail):
    """Письмо с проверочным кодом сброса пароля"""
    subject = '<ERP SatvaSpace> Сброс пароля'
    template = r'Проверочный код: {code}'
    
<...>

from authentication.mail import ResetPasswordMail
from mail_satvadev.tasks import send_email


class ResetPasswordView(APIView):
    def post(self, request):
        <...>
        code = SystemRandom().randint(100000, 999999)
        mail = ResetPasswordMail(code=code)
        send_email.delay(mail.subject, ['user@example.com'], mail.text)

Письмо-напоминание

class BirthdayNotificationMail(BaseMail):
    """Письмо напоминание о днях рождения"""
    subject = 'Дни рождения'
    template = ''

    def __init__(self, birthdays: list[tuple[str, str]], **kwargs) -> None:
        self.template = self._get_template(birthdays)
        super().__init__(**kwargs)

    @staticmethod
    def _get_template(lines: list[str]) -> str:
        string = ''
        for line in lines:
            string += f'День рождения {line[0]} у сотрудника {line[1]} \n'
        return string.rstrip()
        
<...>       

from birthday_notification.mail import BirthdayNotificationMail
from mail_satvadev.tasks import send_email


def send_reminders():
    birthdate_list = []
    mail = BirthdayNotificationMail(birthdate_list)
    send_email.delay(mail.subject, ['user@example.com'], mail.text, 40)

Project details


Download files

Download the file for your platform. If you're not sure which to choose, learn more about installing packages.

Source Distribution

mail_satvadev-1.0.9.tar.gz (5.5 kB view details)

Uploaded Source

Built Distribution

mail_satvadev-1.0.9-py3-none-any.whl (7.0 kB view details)

Uploaded Python 3

File details

Details for the file mail_satvadev-1.0.9.tar.gz.

File metadata

  • Download URL: mail_satvadev-1.0.9.tar.gz
  • Upload date:
  • Size: 5.5 kB
  • Tags: Source
  • Uploaded using Trusted Publishing? No
  • Uploaded via: twine/4.0.2 CPython/3.8.9

File hashes

Hashes for mail_satvadev-1.0.9.tar.gz
Algorithm Hash digest
SHA256 25a454ea5cffedaf3eced7db0f1edcafccb9b079fe4467f6f1831da8fa4533a0
MD5 7afad0bf25301bcb9a5565879f2c5de1
BLAKE2b-256 9601ff762f4f5922b1ee215174d61e7d34d7b451958a6ff2a7550382bcee3261

See more details on using hashes here.

File details

Details for the file mail_satvadev-1.0.9-py3-none-any.whl.

File metadata

File hashes

Hashes for mail_satvadev-1.0.9-py3-none-any.whl
Algorithm Hash digest
SHA256 3352f8e37cb30814573b13e4c91c06dca06de888c3581ada3aef32b951d51fda
MD5 0979d7e53950bd999f803b603408cb76
BLAKE2b-256 fd072ad809754c88693864d994afb77f8ebeb806e74da6deb75b603dca24c355

See more details on using hashes here.

Supported by

AWS AWS Cloud computing and Security Sponsor Datadog Datadog Monitoring Fastly Fastly CDN Google Google Download Analytics Microsoft Microsoft PSF Sponsor Pingdom Pingdom Monitoring Sentry Sentry Error logging StatusPage StatusPage Status page