quickfix
[wolnelektury.git] / src / newsletter / models.py
index 481cb85..a437ff4 100644 (file)
@@ -1,10 +1,31 @@
-# -*- coding: utf-8 -*-
-from django.db.models import Model, EmailField, DateTimeField, BooleanField
-from django.utils.translation import ugettext_lazy as _
+# This file is part of Wolne Lektury, licensed under GNU Affero GPLv3 or later.
+# Copyright © Fundacja Wolne Lektury. See NOTICE for more information.
+#
+import hashlib
 
+from django.db import models
+from django.conf import settings
 
-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 Subscription(models.Model):
+    email = models.EmailField(verbose_name='adres e-mail', unique=True)
+    active = models.BooleanField(default=True, verbose_name='aktywna')
+    created_at = models.DateTimeField(auto_now_add=True)
+    last_modified = models.DateTimeField(auto_now=True)
+
+    class Meta:
+        verbose_name = 'subskrypcja'
+        verbose_name_plural = 'subskrypcje'
+
+    def __str__(self):
+        return self.email
+
+    def hashcode(self):
+        return hashlib.sha224(self.email + settings.SECRET_KEY).hexdigest()[:30]
+
+
+class Newsletter(models.Model):
+    slug = models.SlugField(blank=True)
+    page_title = models.CharField(max_length=255, blank=True)
+    phplist_id = models.IntegerField(null=True, blank=True)
+    crm_id = models.IntegerField(null=True, blank=True)