X-Git-Url: https://git.mdrn.pl/wolnelektury.git/blobdiff_plain/2caf7411aec24c9dda2a166d777010adb5130f9d..603df34c2176722c820cbe5ae193b3dcc755cd68:/src/newsletter/views.py diff --git a/src/newsletter/views.py b/src/newsletter/views.py index 78d64717e..71e0e3d97 100644 --- a/src/newsletter/views.py +++ b/src/newsletter/views.py @@ -1,64 +1,34 @@ -# -*- coding: utf-8 -*- -from django.core.urlresolvers import reverse -from django.http import Http404 +# This file is part of Wolne Lektury, licensed under GNU Affero GPLv3 or later. +# Copyright © Fundacja Wolne Lektury. See NOTICE for more information. +# from django.http.response import HttpResponseRedirect from django.shortcuts import render, get_object_or_404 -from django.utils.translation import ugettext_lazy as _ +from django.urls import reverse +from django.utils.translation import gettext as _ -from newsletter.forms import UnsubscribeForm, SubscribeForm -from newsletter.models import Subscription +from newsletter.forms import SubscribeForm, Newsletter -def subscribe_form(request): +def subscribe_form(request, slug=''): + newsletter = get_object_or_404(Newsletter, slug=slug) if request.POST: - form = SubscribeForm(request.POST) + form = SubscribeForm(newsletter, request.POST) if form.is_valid(): form.save() return HttpResponseRedirect(reverse('subscribed')) else: - form = SubscribeForm() - return render(request, 'newsletter/subscribe_form.html', { - 'page_title': _(u'Subscribe To Newsletter'), + form = SubscribeForm(newsletter) + + template_name = 'newsletter/subscribe_form.html' + return render(request, template_name, { + 'page_title': newsletter.page_title, 'form': form, }) def subscribed(request): - return render(request, 'newsletter/subscribed.html', { - 'page_title': _(u'Confirmation link sent'), - }) - - -def check_subscription(subscription, hashcode): - if hashcode != subscription.hashcode(): - raise Http404 - - -def confirm_subscription(request, subscription_id, hashcode): - subscription = get_object_or_404(Subscription, id=subscription_id) - check_subscription(subscription, hashcode) - subscription.active = True - subscription.save() - return render(request, 'newsletter/confirm_subscription.html', { - 'page_title': _(u'Subscription confirmed') - }) - - -def unsubscribe_form(request): - if request.POST: - form = UnsubscribeForm(request.POST) - if form.is_valid(): - form.save() - return HttpResponseRedirect(reverse('unsubscribed')) - else: - form = UnsubscribeForm() - return render(request, 'newsletter/unsubscribe_form.html', { - 'page_title': _(u'Unsubscribe'), - 'form': form, + template_name = 'newsletter/subscribed.html' + return render(request, template_name, { + 'page_title': _('Zapisano do newslettera'), }) - -def unsubscribed(request): - return render(request, 'newsletter/unsubscribed.html', { - 'page_title': _(u'Unsubscribed'), - })