send individual mails to some members

v1-0-stable
Christian Merten 9 years ago
parent eb54915f16
commit 3c01f83517

@ -25,9 +25,9 @@ class MessageAdmin(admin.ModelAdmin):
inlines = [AttachmentInline] inlines = [AttachmentInline]
actions = ['send_message'] actions = ['send_message']
form = MessageForm form = MessageForm
filter_horizontal = ('to_members',)
def send_message(self, request, queryset): def send_message(self, request, queryset):
print("calling send_message")
if request.POST.get('confirmed'): if request.POST.get('confirmed'):
for msg in queryset: for msg in queryset:
submit_message(msg, request) submit_message(msg, request)

@ -2,6 +2,7 @@ from django.db import models
from django.core.exceptions import ValidationError from django.core.exceptions import ValidationError
from django import forms from django import forms
from django.utils.translation import ugettext_lazy as _ from django.utils.translation import ugettext_lazy as _
from django.utils.translation import ugettext
from .mailutils import send, get_content, SENT, PARTLY_SENT from .mailutils import send, get_content, SENT, PARTLY_SENT
import os import os
@ -42,10 +43,14 @@ class Message(models.Model):
verbose_name=_('to member list'), verbose_name=_('to member list'),
blank=True, blank=True,
null=True) null=True)
to_members = models.ManyToManyField('members.Member',
verbose_name=_('to member'),
blank=True)
reply_to = models.ForeignKey('members.Member', reply_to = models.ForeignKey('members.Member',
verbose_name=_('reply to'), verbose_name=_('reply to'),
blank=True, blank=True,
null=True) null=True,
related_name='reply_to')
sent = models.BooleanField(_('sent'), default=False) sent = models.BooleanField(_('sent'), default=False)
def __str__(self): def __str__(self):
@ -55,14 +60,23 @@ class Message(models.Model):
recipients = [g.name for g in self.to_groups.all()] recipients = [g.name for g in self.to_groups.all()]
if self.to_memberlist is not None: if self.to_memberlist is not None:
recipients.append(self.to_memberlist.name) recipients.append(self.to_memberlist.name)
if 3 > self.to_members.count() > 0:
recipients.extend([m.name for m in self.to_members.all()])
elif self.to_members.count() > 2:
recipients.append(ugettext('Some other members'))
return ", ".join(recipients) return ", ".join(recipients)
get_recipients.short_description = _('recipients') get_recipients.short_description = _('recipients')
def submit(self): def submit(self):
"""Sends the mail to the specified group of members""" """Sends the mail to the specified group of members"""
# recipients
members = set() members = set()
# get all the members of the selected groups
groups = [gr.member_set.all() for gr in self.to_groups.all()] groups = [gr.member_set.all() for gr in self.to_groups.all()]
members.update([m for gr in groups for m in gr]) members.update([m for gr in groups for m in gr])
# get all the individually picked members
members.update(self.to_members.all())
# get all the members of the selected member list
if self.to_memberlist is not None: if self.to_memberlist is not None:
members.update([mol.member for mol in members.update([mol.member for mol in
self.to_memberlist.memberonlist_set.all()]) self.to_memberlist.memberonlist_set.all()])
@ -102,16 +116,15 @@ class MessageForm(forms.ModelForm):
def clean(self): def clean(self):
group = self.cleaned_data.get('to_groups') group = self.cleaned_data.get('to_groups')
memberlist = self.cleaned_data.get('to_memberlist') memberlist = self.cleaned_data.get('to_memberlist')
print("group", group, "memberlist", memberlist) members = self.cleaned_data.get('to_members')
if not group and memberlist is None: if not group and memberlist is None and not members:
raise ValidationError(_('Either a group is required or a ' raise ValidationError(_('Either a group, a memberlist or at least'
'memberlist as recipient')) ' one member is required as recipient'))
class Attachment(models.Model): class Attachment(models.Model):
"""Represents an attachment to an email""" """Represents an attachment to an email"""
msg = models.ForeignKey(Message, on_delete=models.CASCADE) msg = models.ForeignKey(Message, on_delete=models.CASCADE)
print("attachment class")
# file (not naming it file because of builtin) # file (not naming it file because of builtin)
f = RestrictedFileField(_('file'), f = RestrictedFileField(_('file'),
upload_to='attachments', upload_to='attachments',

Loading…
Cancel
Save