Skip to content

valdergallo/django-email-manager

 
 

Repository files navigation

Django Email Manager

Continuous Integration Status

A simple application to manage emails sent by a Django application.

Installation

pip install django-email-manager

or

  # Download zip file
  # Extract it
  # Execute in the extracted directory: python setup.py install

Upgrade

pip install django-email-manager --upgrade --no-deps

Motivation

  • http://djangopackages.com/grids/g/email

  • Problem: Bad control of what and how many e-mails have being sent to users.

  • Solution: A simple table that log a summary of each e-mail had been sent. A daily routine avoid this table grows uncontrolled and use the data to generate statistics.

  • Problem: Important e-mails are deleted from the database when a user change his e-mail.

  • Solution: A simple table that store all e-mails independently.

  • Usually, good systems do not send attachments by e-mail because this a open door to attacks.

Configuration

  • settings.py:
INSTALLED_APPS = (
    'django.contrib.auth',
    'django.contrib.admin',
    'email_manager',
)

# This attribute activates a listener to store all e-mails independently of auth_user database.
EMAIL_DATABASE_ACTIVATED = True

# If you want to use celery for sending e-mails, you can customize the task name, example:
EMAIL_MANAGER_USING_CELERY = True # default = False
EMAIL_MANAGER_TASK = 'email-manager-task' # default = None
  • urls.py
from django.contrib import admin
admin.autodiscover()

urlpatterns = patterns('',
     url(r'^admin/', include(admin.site.urls)),
     (r'^email-manager/', include('email_manager.urls', namespace='email_manager', app_name='email_manager')),
)
  • Templates:
{% url email_manager:define_email_preferences user.id %}
{% if user.is_superuser %}
    {% url email_manager:send_email_to_groups %}
    {% url email_manager:send_email_to_users %}
    {% url email_manager:update_statistics %}
{% endif %}

Usage

  • Manual Test:
/email-manager/send-email-to-groups/
/email-manager/send-email-to-users/
/email-manager/update-statistics/
/email-manager/define_email_preferences/USER_ID
  • Send e-mails directly in source code:
from email_manager.feature_send_email import EmailSender
EmailSender().send_email(emails, subject, text_content, html_content, main_content)
EmailSender().send_email_to_users(users, additional_emails, subject, content, html_content, email_type)
EmailSender().send_email_to_groups(groups, additional_emails, subject, content, html_content, email_type)
  • Manual updating statistics:
python manage.py update_email_statistics

Change Log

Version 0.2.1

Version 0.2.0

Version 0.1.0

TODO:

  • Auto update statistics
  • Simple graphs and reports

About

A simple application to manage emails sent by a Django application.

Resources

Stars

Watchers

Forks

Releases

No releases published

Packages

No packages published