src/hdalab/models/renkan.py
author ymh <ymh.work@gmail.com>
Sat, 28 Feb 2015 06:45:26 +0100
changeset 465 ddd669c54685
parent 462 df8b3b49e81c
child 466 b1b5bc392a45
permissions -rw-r--r--
Added tag V03.00-alpha.10 for changeset 209f6b75d9e5
Ignore whitespace changes - Everywhere: Within whitespace: At end of lines:
462
df8b3b49e81c correct bug and add email sending
ymh <ymh.work@gmail.com>
parents: 458
diff changeset
     1
# -*- coding: utf-8 -*-
295
af29252631ac renkan object with thumbnail
cavaliet
parents:
diff changeset
     2
'''
af29252631ac renkan object with thumbnail
cavaliet
parents:
diff changeset
     3
Created on Jul 17, 2014
af29252631ac renkan object with thumbnail
cavaliet
parents:
diff changeset
     4
af29252631ac renkan object with thumbnail
cavaliet
parents:
diff changeset
     5
@author: tc
af29252631ac renkan object with thumbnail
cavaliet
parents:
diff changeset
     6
'''
462
df8b3b49e81c correct bug and add email sending
ymh <ymh.work@gmail.com>
parents: 458
diff changeset
     7
import logging
458
604b887e70c3 add state history to renkan, correct get into post, generally prepare ground for mail management
ymh <ymh.work@gmail.com>
parents: 329
diff changeset
     8
from renkanmanager.models import Renkan
604b887e70c3 add state history to renkan, correct get into post, generally prepare ground for mail management
ymh <ymh.work@gmail.com>
parents: 329
diff changeset
     9
604b887e70c3 add state history to renkan, correct get into post, generally prepare ground for mail management
ymh <ymh.work@gmail.com>
parents: 329
diff changeset
    10
from django.conf import settings
462
df8b3b49e81c correct bug and add email sending
ymh <ymh.work@gmail.com>
parents: 458
diff changeset
    11
from django.core.mail import send_mail
295
af29252631ac renkan object with thumbnail
cavaliet
parents:
diff changeset
    12
from django.db import models
462
df8b3b49e81c correct bug and add email sending
ymh <ymh.work@gmail.com>
parents: 458
diff changeset
    13
from django.db.models.signals import post_save
df8b3b49e81c correct bug and add email sending
ymh <ymh.work@gmail.com>
parents: 458
diff changeset
    14
from django.template import loader
df8b3b49e81c correct bug and add email sending
ymh <ymh.work@gmail.com>
parents: 458
diff changeset
    15
from django.template.base import TemplateDoesNotExist
df8b3b49e81c correct bug and add email sending
ymh <ymh.work@gmail.com>
parents: 458
diff changeset
    16
from django.template.context import Context
329
ea6268cf8c83 renkan state management for staff members : publish, unpublish, reject.
cavaliet
parents: 299
diff changeset
    17
from django.utils.translation import ugettext as _
462
df8b3b49e81c correct bug and add email sending
ymh <ymh.work@gmail.com>
parents: 458
diff changeset
    18
from django.template.loader import render_to_string
df8b3b49e81c correct bug and add email sending
ymh <ymh.work@gmail.com>
parents: 458
diff changeset
    19
from django.core.mail.message import EmailMultiAlternatives
df8b3b49e81c correct bug and add email sending
ymh <ymh.work@gmail.com>
parents: 458
diff changeset
    20
from django.utils.html import strip_tags
295
af29252631ac renkan object with thumbnail
cavaliet
parents:
diff changeset
    21
af29252631ac renkan object with thumbnail
cavaliet
parents:
diff changeset
    22
462
df8b3b49e81c correct bug and add email sending
ymh <ymh.work@gmail.com>
parents: 458
diff changeset
    23
logger = logging.getLogger(__name__)
df8b3b49e81c correct bug and add email sending
ymh <ymh.work@gmail.com>
parents: 458
diff changeset
    24
299
8e00641076e7 remove renkan management to an other django app (see renkan hg repo)
cavaliet
parents: 295
diff changeset
    25
class HdalabRenkan(models.Model):
295
af29252631ac renkan object with thumbnail
cavaliet
parents:
diff changeset
    26
    
af29252631ac renkan object with thumbnail
cavaliet
parents:
diff changeset
    27
    EDITION = 1
329
ea6268cf8c83 renkan state management for staff members : publish, unpublish, reject.
cavaliet
parents: 299
diff changeset
    28
    MODERATED = 2
ea6268cf8c83 renkan state management for staff members : publish, unpublish, reject.
cavaliet
parents: 299
diff changeset
    29
    PUBLISHED = 3
295
af29252631ac renkan object with thumbnail
cavaliet
parents:
diff changeset
    30
    REJECTED = 4
af29252631ac renkan object with thumbnail
cavaliet
parents:
diff changeset
    31
      
af29252631ac renkan object with thumbnail
cavaliet
parents:
diff changeset
    32
    STATE_CHOICES = (
af29252631ac renkan object with thumbnail
cavaliet
parents:
diff changeset
    33
    (EDITION, 'edition'),
329
ea6268cf8c83 renkan state management for staff members : publish, unpublish, reject.
cavaliet
parents: 299
diff changeset
    34
    (MODERATED, 'moderated'),
295
af29252631ac renkan object with thumbnail
cavaliet
parents:
diff changeset
    35
    (PUBLISHED, 'published'),
af29252631ac renkan object with thumbnail
cavaliet
parents:
diff changeset
    36
    (REJECTED, 'rejected'),
af29252631ac renkan object with thumbnail
cavaliet
parents:
diff changeset
    37
    )
af29252631ac renkan object with thumbnail
cavaliet
parents:
diff changeset
    38
    
329
ea6268cf8c83 renkan state management for staff members : publish, unpublish, reject.
cavaliet
parents: 299
diff changeset
    39
    STATE_CHOICES_DICT = {
ea6268cf8c83 renkan state management for staff members : publish, unpublish, reject.
cavaliet
parents: 299
diff changeset
    40
        EDITION: _('edition_state'),
ea6268cf8c83 renkan state management for staff members : publish, unpublish, reject.
cavaliet
parents: 299
diff changeset
    41
        MODERATED: _('moderated_state'),
ea6268cf8c83 renkan state management for staff members : publish, unpublish, reject.
cavaliet
parents: 299
diff changeset
    42
        PUBLISHED: _('published_state'),
ea6268cf8c83 renkan state management for staff members : publish, unpublish, reject.
cavaliet
parents: 299
diff changeset
    43
        REJECTED: _('rejected_state')
ea6268cf8c83 renkan state management for staff members : publish, unpublish, reject.
cavaliet
parents: 299
diff changeset
    44
    }
ea6268cf8c83 renkan state management for staff members : publish, unpublish, reject.
cavaliet
parents: 299
diff changeset
    45
    
299
8e00641076e7 remove renkan management to an other django app (see renkan hg repo)
cavaliet
parents: 295
diff changeset
    46
    renkan = models.ForeignKey(Renkan, blank=False, null=False)
295
af29252631ac renkan object with thumbnail
cavaliet
parents:
diff changeset
    47
    state = models.IntegerField(choices=STATE_CHOICES, default=1)
af29252631ac renkan object with thumbnail
cavaliet
parents:
diff changeset
    48
    
af29252631ac renkan object with thumbnail
cavaliet
parents:
diff changeset
    49
    class Meta:
af29252631ac renkan object with thumbnail
cavaliet
parents:
diff changeset
    50
        app_label = 'hdalab'
458
604b887e70c3 add state history to renkan, correct get into post, generally prepare ground for mail management
ymh <ymh.work@gmail.com>
parents: 329
diff changeset
    51
604b887e70c3 add state history to renkan, correct get into post, generally prepare ground for mail management
ymh <ymh.work@gmail.com>
parents: 329
diff changeset
    52
604b887e70c3 add state history to renkan, correct get into post, generally prepare ground for mail management
ymh <ymh.work@gmail.com>
parents: 329
diff changeset
    53
class HdalabRenkanStateTransition(models.Model):
604b887e70c3 add state history to renkan, correct get into post, generally prepare ground for mail management
ymh <ymh.work@gmail.com>
parents: 329
diff changeset
    54
604b887e70c3 add state history to renkan, correct get into post, generally prepare ground for mail management
ymh <ymh.work@gmail.com>
parents: 329
diff changeset
    55
    renkan = models.ForeignKey(HdalabRenkan, blank=False, null=False)
604b887e70c3 add state history to renkan, correct get into post, generally prepare ground for mail management
ymh <ymh.work@gmail.com>
parents: 329
diff changeset
    56
    from_state = models.IntegerField(choices=HdalabRenkan.STATE_CHOICES, default=1, blank=False, null=False)
604b887e70c3 add state history to renkan, correct get into post, generally prepare ground for mail management
ymh <ymh.work@gmail.com>
parents: 329
diff changeset
    57
    to_state = models.IntegerField(choices=HdalabRenkan.STATE_CHOICES, default=1, blank=False, null=False)
604b887e70c3 add state history to renkan, correct get into post, generally prepare ground for mail management
ymh <ymh.work@gmail.com>
parents: 329
diff changeset
    58
    ts = models.DateTimeField(auto_now_add=True, blank=False, null=False)
604b887e70c3 add state history to renkan, correct get into post, generally prepare ground for mail management
ymh <ymh.work@gmail.com>
parents: 329
diff changeset
    59
    message = models.TextField(blank=True, null=True)
604b887e70c3 add state history to renkan, correct get into post, generally prepare ground for mail management
ymh <ymh.work@gmail.com>
parents: 329
diff changeset
    60
    author = models.ForeignKey(settings.AUTH_USER_MODEL, blank=False, null=False)
604b887e70c3 add state history to renkan, correct get into post, generally prepare ground for mail management
ymh <ymh.work@gmail.com>
parents: 329
diff changeset
    61
    
604b887e70c3 add state history to renkan, correct get into post, generally prepare ground for mail management
ymh <ymh.work@gmail.com>
parents: 329
diff changeset
    62
    class Meta:
604b887e70c3 add state history to renkan, correct get into post, generally prepare ground for mail management
ymh <ymh.work@gmail.com>
parents: 329
diff changeset
    63
        app_label = 'hdalab'
462
df8b3b49e81c correct bug and add email sending
ymh <ymh.work@gmail.com>
parents: 458
diff changeset
    64
df8b3b49e81c correct bug and add email sending
ymh <ymh.work@gmail.com>
parents: 458
diff changeset
    65
MAIL_TEMPLATES = {
df8b3b49e81c correct bug and add email sending
ymh <ymh.work@gmail.com>
parents: 458
diff changeset
    66
    HdalabRenkan.PUBLISHED: ("mails/published_renkan", "Renkan publié"),
df8b3b49e81c correct bug and add email sending
ymh <ymh.work@gmail.com>
parents: 458
diff changeset
    67
    HdalabRenkan.REJECTED: ("mails/rejected_renkan", "Renkan rejeté")
df8b3b49e81c correct bug and add email sending
ymh <ymh.work@gmail.com>
parents: 458
diff changeset
    68
}
df8b3b49e81c correct bug and add email sending
ymh <ymh.work@gmail.com>
parents: 458
diff changeset
    69
df8b3b49e81c correct bug and add email sending
ymh <ymh.work@gmail.com>
parents: 458
diff changeset
    70
df8b3b49e81c correct bug and add email sending
ymh <ymh.work@gmail.com>
parents: 458
diff changeset
    71
#TODO put into queue
df8b3b49e81c correct bug and add email sending
ymh <ymh.work@gmail.com>
parents: 458
diff changeset
    72
def send_renkan_moderation_messages(sender, **kwargs):
df8b3b49e81c correct bug and add email sending
ymh <ymh.work@gmail.com>
parents: 458
diff changeset
    73
    renkan_state = kwargs.get('instance', None)
df8b3b49e81c correct bug and add email sending
ymh <ymh.work@gmail.com>
parents: 458
diff changeset
    74
    if not renkan_state or renkan_state.to_state not in MAIL_TEMPLATES:
df8b3b49e81c correct bug and add email sending
ymh <ymh.work@gmail.com>
parents: 458
diff changeset
    75
        return
df8b3b49e81c correct bug and add email sending
ymh <ymh.work@gmail.com>
parents: 458
diff changeset
    76
df8b3b49e81c correct bug and add email sending
ymh <ymh.work@gmail.com>
parents: 458
diff changeset
    77
    msg_txt = ""
df8b3b49e81c correct bug and add email sending
ymh <ymh.work@gmail.com>
parents: 458
diff changeset
    78
    msg_html = ""
df8b3b49e81c correct bug and add email sending
ymh <ymh.work@gmail.com>
parents: 458
diff changeset
    79
    subject = ""
df8b3b49e81c correct bug and add email sending
ymh <ymh.work@gmail.com>
parents: 458
diff changeset
    80
    try:
df8b3b49e81c correct bug and add email sending
ymh <ymh.work@gmail.com>
parents: 458
diff changeset
    81
        template_name, subject = MAIL_TEMPLATES[renkan_state.to_state]
df8b3b49e81c correct bug and add email sending
ymh <ymh.work@gmail.com>
parents: 458
diff changeset
    82
#        template = loader.get_template(template_name)
df8b3b49e81c correct bug and add email sending
ymh <ymh.work@gmail.com>
parents: 458
diff changeset
    83
        context = {'renkan_state': renkan_state, 'WEB_URL': settings.WEB_URL}
df8b3b49e81c correct bug and add email sending
ymh <ymh.work@gmail.com>
parents: 458
diff changeset
    84
        msg_html = render_to_string(template_name+".txt", context)
df8b3b49e81c correct bug and add email sending
ymh <ymh.work@gmail.com>
parents: 458
diff changeset
    85
        msg_txt = render_to_string(template_name+".html", context)
df8b3b49e81c correct bug and add email sending
ymh <ymh.work@gmail.com>
parents: 458
diff changeset
    86
    except TemplateDoesNotExist:
df8b3b49e81c correct bug and add email sending
ymh <ymh.work@gmail.com>
parents: 458
diff changeset
    87
        logger.error("Mail template %s for state %s not found", MAIL_TEMPLATES[renkan_state.to_state], HdalabRenkan.STATE_CHOICES_DICT[renkan_state.to_state])
df8b3b49e81c correct bug and add email sending
ymh <ymh.work@gmail.com>
parents: 458
diff changeset
    88
        return
df8b3b49e81c correct bug and add email sending
ymh <ymh.work@gmail.com>
parents: 458
diff changeset
    89
    except Exception as e:
df8b3b49e81c correct bug and add email sending
ymh <ymh.work@gmail.com>
parents: 458
diff changeset
    90
        logger.error("Error rendering template %s for state %s : %r", MAIL_TEMPLATES[renkan_state.to_state], HdalabRenkan.STATE_CHOICES_DICT[renkan_state.to_state], e)
df8b3b49e81c correct bug and add email sending
ymh <ymh.work@gmail.com>
parents: 458
diff changeset
    91
    
df8b3b49e81c correct bug and add email sending
ymh <ymh.work@gmail.com>
parents: 458
diff changeset
    92
    if msg_txt and msg_html and renkan_state.renkan and renkan_state.renkan.renkan and renkan_state.renkan.renkan.owner and renkan_state.renkan.renkan.owner.email:
df8b3b49e81c correct bug and add email sending
ymh <ymh.work@gmail.com>
parents: 458
diff changeset
    93
        logger.debug("Sending following mail to %s : %s", renkan_state.renkan.renkan.owner.email, msg_txt)
df8b3b49e81c correct bug and add email sending
ymh <ymh.work@gmail.com>
parents: 458
diff changeset
    94
        emsg = EmailMultiAlternatives(subject, strip_tags(msg_txt), settings.ADMINS[0][1], [renkan_state.renkan.renkan.owner.email])
df8b3b49e81c correct bug and add email sending
ymh <ymh.work@gmail.com>
parents: 458
diff changeset
    95
        emsg.attach_alternative(msg_html, "text/html")
df8b3b49e81c correct bug and add email sending
ymh <ymh.work@gmail.com>
parents: 458
diff changeset
    96
        emsg.send(fail_silently=True)
df8b3b49e81c correct bug and add email sending
ymh <ymh.work@gmail.com>
parents: 458
diff changeset
    97
df8b3b49e81c correct bug and add email sending
ymh <ymh.work@gmail.com>
parents: 458
diff changeset
    98
df8b3b49e81c correct bug and add email sending
ymh <ymh.work@gmail.com>
parents: 458
diff changeset
    99
def queue_renkan_rendering(sender, **kwargs):
df8b3b49e81c correct bug and add email sending
ymh <ymh.work@gmail.com>
parents: 458
diff changeset
   100
    pass
df8b3b49e81c correct bug and add email sending
ymh <ymh.work@gmail.com>
parents: 458
diff changeset
   101
    #check state
df8b3b49e81c correct bug and add email sending
ymh <ymh.work@gmail.com>
parents: 458
diff changeset
   102
    #queue renkan for endering
df8b3b49e81c correct bug and add email sending
ymh <ymh.work@gmail.com>
parents: 458
diff changeset
   103
    
df8b3b49e81c correct bug and add email sending
ymh <ymh.work@gmail.com>
parents: 458
diff changeset
   104
    
df8b3b49e81c correct bug and add email sending
ymh <ymh.work@gmail.com>
parents: 458
diff changeset
   105
RENKAN_MODERATION_UUID = "e2f84503-609b-4efa-819d-908e2efe7b1b"
df8b3b49e81c correct bug and add email sending
ymh <ymh.work@gmail.com>
parents: 458
diff changeset
   106
RENKAN_RENDERING_UUID = "b8830748-be2b-479a-8aef-c8d952437b2f"
df8b3b49e81c correct bug and add email sending
ymh <ymh.work@gmail.com>
parents: 458
diff changeset
   107
df8b3b49e81c correct bug and add email sending
ymh <ymh.work@gmail.com>
parents: 458
diff changeset
   108
post_save.connect(send_renkan_moderation_messages, sender=HdalabRenkanStateTransition, dispatch_uid=RENKAN_MODERATION_UUID)