Merge remote-tracking branch 'zawadzki/new-design'
[wolnelektury.git] / src / newsletter / models.py
index 481cb85..af57d38 100644 (file)
@@ -1,10 +1,31 @@
-# -*- coding: utf-8 -*-
-from django.db.models import Model, EmailField, DateTimeField, BooleanField
+# This file is part of Wolnelektury, licensed under GNU Affero GPLv3 or later.
+# Copyright © Fundacja Nowoczesna Polska. See NOTICE for more information.
+#
+import hashlib
+
+from django.db import models
 from django.utils.translation import ugettext_lazy as _
 from django.utils.translation import ugettext_lazy as _
+from django.conf import settings
+
+
+class Subscription(models.Model):
+    email = models.EmailField(verbose_name=_('email address'), unique=True)
+    active = models.BooleanField(default=True, verbose_name=_('active'))
+    created_at = models.DateTimeField(auto_now_add=True)
+    last_modified = models.DateTimeField(auto_now=True)
+
+    class Meta:
+        verbose_name = _('subscription')
+        verbose_name_plural = _('subscriptions')
+
+    def __str__(self):
+        return self.email
+
+    def hashcode(self):
+        return hashlib.sha224(self.email + settings.SECRET_KEY).hexdigest()[:30]
 
 
 
 
-class Subscription(Model):
-    email = EmailField(verbose_name=_('email address'))
-    active = BooleanField(default=True)
-    created_at = DateTimeField(auto_now_add=True)
-    last_modified = DateTimeField(auto_now=True)
+class Newsletter(models.Model):
+    slug = models.SlugField(blank=True)
+    page_title = models.CharField(max_length=255, blank=True)
+    phplist_id = models.IntegerField()