Login

Simple class to organize email templates

Author:
jean
Posted:
April 13, 2015
Language:
Python
Version:
1.5
Score:
1 (after 1 ratings)

Provides pattern to organize and send your email messages.

  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
 45
 46
 47
 48
 49
 50
 51
 52
 53
 54
 55
 56
 57
 58
 59
 60
 61
 62
 63
 64
 65
 66
 67
 68
 69
 70
 71
 72
 73
 74
 75
 76
 77
 78
 79
 80
 81
 82
 83
 84
 85
 86
 87
 88
 89
 90
 91
 92
 93
 94
 95
 96
 97
 98
 99
100
101
102
103
104
105
106
107
108
109
110
111
112
113
114
115
116
117
118
119
120
121
122
123
124
125
126
127
128
129
130
131
# -*- coding: utf-8 -*-
from __future__ import unicode_literals
import os
import logging

from django.conf import settings
from django.core.mail import EmailMultiAlternatives
from django.template.base import TemplateDoesNotExist
from django.template.loader import render_to_string


logger = logging.getLogger(__name__)


class EmailTemplate(object):
    """Provide pattern to organize and send your common email messages.

    All Emails should be stored on these paths:
    <your_template_dir>/email/<template_name>/subject.txt
    <your_template_dir>/email/<template_name>/message.html
    <your_template_dir>/email/<template_name>/message.txt

    Examples:
    >>> email = EmailTemplate('<template_name>', {'date', datetime.now().date})
    >>> email.send(['[email protected]'], context={'name': 'Bill'})

    Only process your email templates:
    >>> user_data = {'name': 'Bill'}
    >>> subject = email.get_subject(user_data)
    >>> message = email.get_message_txt(user_data)
    >>> from django.core.mail import send_mail
    >>> send_mail(subject, message, settings.DEFAULT_FROM_EMAIL,
                  ['[email protected]'])


    Prevents method "send" to massive send.
    >>> email = EmailTemplate('<template_name>', {'date', datetime.now().date})
    >>> messages = []
    >>> messages.append(email.send(['[email protected]'], context={'name': 'Bill'},
                                   commit=False))
    >>> messages.append(email.send(['[email protected]'], context={'name': 'Jonh'},
                                   commit=False))
    >>> from django.core import mail
    >>> connection = mail.get_connection()
    >>> connection.send_messages(messages)
    """

    template_base_dir = 'email'
    template_subject = 'subject.txt'
    template_message_html = 'message.html'
    template_message_txt = 'message.txt'

    def __init__(self, name, default_context=None, **kwargs):
        self.name = name
        self.default_context = default_context or {}

    def __unicode__(self):
        return self.name

    @property
    def template_dir(self):
        return os.path.join(self.template_base_dir, self.name)

    @property
    def subject(self):
        """Template path of subject"""
        return os.path.join(self.template_dir, self.template_subject)

    @property
    def message_html(self):
        """Template path of html message"""
        return os.path.join(self.template_dir, self.template_message_html)

    @property
    def message_txt(self):
        """Template path of text message"""
        return os.path.join(self.template_dir, self.template_message_txt)

    def _get_template(self, template, context=None):
        _context = self.default_context.copy()
        if context:
            _context.update(context)

        try:
            return render_to_string(template, _context)
        except TemplateDoesNotExist:
            logger.debug("Email template {} doesn't exists.".format(template))
            return None

    def get_subject(self, context=None):
        return self._get_template(self.subject, context)

    def get_message_html(self, context=None):
        return self._get_template(self.message_html, context)

    def get_message_txt(self, context=None):
        return self._get_template(self.message_txt, context)

    def send(self, recipient_list, context=None, commit=True, **kwargs):
        """Send email message and return EmailMessage instance.

        Params:
            recipient_list -> List of emails to sent.
            context -> Contex data of template.
            commit -> If false, prevents to send message, only returning the
                      EmailMessage instance.
            kwargs -> Uses to pass other EmailMessage params like from_email,
                      bcc, cc and headers.
        """

        subject = self.get_subject(context)
        msg_html = self.get_message_html(context)
        msg_txt = self.get_message_txt(context)

        message = EmailMultiAlternatives(
            subject=subject,
            body=msg_txt,
            to=recipient_list,
            from_email=kwargs.get('from_email', settings.DEFAULT_FROM_EMAIL),
            bcc=kwargs.get('bcc'),
            cc=kwargs.get('cc'),
            headers=kwargs.get('headers'))

        if msg_html:
            message.attach_alternative(msg_html, 'text/html')

        if commit:
            sent = message.send(
                fail_silently=kwargs.get('fail_silently', False))

        return message

More like this

  1. Template tag - list punctuation for a list of items by shapiromatron 11 months, 3 weeks ago
  2. JSONRequestMiddleware adds a .json() method to your HttpRequests by cdcarter 12 months ago
  3. Serializer factory with Django Rest Framework by julio 1 year, 6 months ago
  4. Image compression before saving the new model / work with JPG, PNG by Schleidens 1 year, 7 months ago
  5. Help text hyperlinks by sa2812 1 year, 8 months ago

Comments

Please login first before commenting.