X-Git-Url: https://git.mdrn.pl/wolnelektury.git/blobdiff_plain/97c8c6d7c7961976172bece182832d01c9c0fc4b..91eb62bdcc6b891f12d20b1d8d5d70cbd7b12325:/src/club/models.py?ds=sidebyside diff --git a/src/club/models.py b/src/club/models.py index 8c26d03a1..6fd58e0b3 100644 --- a/src/club/models.py +++ b/src/club/models.py @@ -2,6 +2,7 @@ # Copyright © Fundacja Nowoczesna Polska. See NOTICE for more information. # from datetime import datetime, timedelta +from django.apps import apps from django.conf import settings from django.contrib.sites.models import Site from django.core.mail import send_mail @@ -11,6 +12,7 @@ from django import template from django.utils.timezone import now from django.utils.translation import ugettext_lazy as _, ungettext, ugettext, get_language from catalogue.utils import get_random_hash +from messaging.states import Level from .payment_methods import recurring_payment_method, single_payment_method from .payu import models as payu_models from . import utils @@ -63,7 +65,8 @@ class Schedule(models.Model): def save(self, *args, **kwargs): if not self.key: self.key = get_random_hash(self.email) - return super(Schedule, self).save(*args, **kwargs) + super(Schedule, self).save(*args, **kwargs) + self.update_contact() def initiate_payment(self, request): return self.get_payment_method().initiate(request, self) @@ -108,6 +111,19 @@ class Schedule(models.Model): self.email_sent = True self.save() + def update_contact(self): + Contact = apps.get_model('messaging', 'Contact') + if not self.payed_at: + level = Level.TRIED + since = self.started_at + else: + since = self.payed_at + if self.is_recurring(): + level = Level.RECURRING + else: + level = Level.SINGLE + Contact.update(self.email, level, since, self.expires_at) + class Membership(models.Model): """ Represents a user being recognized as a member of the club. """