|
1 |
from datetime import datetime
|
|
2 |
import logging
|
|
3 |
from html2text import HTML2Text
|
|
4 |
from emails.django import Message
|
|
5 |
from lxml.etree import HTML as HTMLTree
|
|
6 |
|
1 |
7 |
from django.utils import timezone
|
2 |
8 |
from django.conf import settings
|
3 |
9 |
from django.db import models
|
|
10 |
from django.core.files.storage import DefaultStorage
|
4 |
11 |
from django.utils.translation import ugettext_lazy as _
|
5 |
12 |
|
6 |
13 |
from ckeditor.fields import RichTextField
|
... | ... | |
10 |
17 |
('homepage', _('Homepage'))
|
11 |
18 |
)
|
12 |
19 |
|
|
20 |
logger = logging.getLogger(__name__)
|
|
21 |
|
13 |
22 |
class Category(models.Model):
|
14 |
23 |
name = models.CharField(max_length=64, blank=False, null=False)
|
15 |
24 |
ctime = models.DateTimeField(auto_now_add=True)
|
... | ... | |
62 |
71 |
id=self.announce.id, time=self.deliver_time)
|
63 |
72 |
return u'announce {id} to deliver'.format(id=self.announce.id)
|
64 |
73 |
|
|
74 |
def send(self):
|
|
75 |
subscriptions = self.announce.category.subscription_set.all()
|
|
76 |
total_sent = 0
|
|
77 |
handler = HTML2Text()
|
|
78 |
m = Message(html=self.announce.text, subject=self.announce.title,
|
|
79 |
text=handler.handle(self.announce.text),
|
|
80 |
mail_from=settings.DEFAULT_FROM_EMAIL)
|
|
81 |
html_tree = HTMLTree(self.announce.text)
|
|
82 |
storage = DefaultStorage()
|
|
83 |
for img in html_tree.xpath('//img/@src'):
|
|
84 |
img_path = img.lstrip(settings.MEDIA_URL)
|
|
85 |
m.attach(filename=img, data=storage.open(img_path))
|
|
86 |
m.attachments[img].is_inline = True
|
|
87 |
m.transformer.synchronize_inline_images()
|
|
88 |
m.transformer.save()
|
|
89 |
for s in subscriptions:
|
|
90 |
if not s.identifier:
|
|
91 |
continue
|
|
92 |
result = m.send(to=s.identifier)
|
|
93 |
if result.status_code == 250:
|
|
94 |
total_sent += 1
|
|
95 |
logger.info('Announce "%s" sent to %s', self.announce.title, s.identifier)
|
|
96 |
else:
|
|
97 |
logger.warning('Error occured while sending announce "%s" to %s: status code %s',
|
|
98 |
self.announce.title, s.identifier, result.status_code)
|
|
99 |
self.result = total_sent
|
|
100 |
self.deliver_time = timezone.now()
|
|
101 |
self.save()
|
|
102 |
|
65 |
103 |
class Meta:
|
66 |
104 |
verbose_name = _('sent')
|
67 |
105 |
ordering = ('-deliver_time',)
|