X-Git-Url: https://git.mdrn.pl/wolnelektury.git/blobdiff_plain/6d7b11e4a01b2314c0527d94d91f3159c0bd34ce..2a8b16aa45fb2b17f92068016ec72f93ccdef776:/apps/funding/views.py diff --git a/apps/funding/views.py b/apps/funding/views.py index c14cee3ee..66c34a28f 100644 --- a/apps/funding/views.py +++ b/apps/funding/views.py @@ -2,12 +2,17 @@ # This file is part of Wolnelektury, licensed under GNU Affero GPLv3 or later. # Copyright © Fundacja Nowoczesna Polska. See NOTICE for more information. # +from django.views.decorators.cache import never_cache from django.conf import settings from django.core.urlresolvers import reverse +from django.http import Http404 from django.shortcuts import redirect, get_object_or_404 -from django.views.generic import TemplateView, FormView, DetailView -from .forms import DummyForm -from .models import Offer, Spent +from django.utils.decorators import method_decorator +from django.views.generic import TemplateView, FormView, DetailView, ListView +import getpaid.backends.payu +from getpaid.models import Payment +from .forms import FundingForm +from .models import Offer, Spent, Funding def mix(*streams): @@ -67,11 +72,17 @@ class WLFundView(TemplateView): class OfferDetailView(FormView): - form_class = DummyForm + form_class = FundingForm template_name = "funding/offer_detail.html" + backend = 'getpaid.backends.payu' - def dispatch(self, request, slug): - self.object = get_object_or_404(Offer.public(), slug=slug) + def dispatch(self, request, slug=None): + if slug: + self.object = get_object_or_404(Offer.public(), slug=slug) + else: + self.object = Offer.current() + if self.object is None: + raise Http404 return super(OfferDetailView, self).dispatch(request, slug) def get_form(self, form_class): @@ -83,11 +94,26 @@ class OfferDetailView(FormView): def get_context_data(self, *args, **kwargs): ctx = super(OfferDetailView, self).get_context_data(*args, **kwargs) ctx['object'] = self.object + if self.object.is_current(): + ctx['funding_no_show_current'] = True return ctx def form_valid(self, form): - form.save() - return redirect(reverse("funding_thanks")) + funding = form.save() + # Skip getpaid.forms.PaymentMethodForm, go directly to the broker. + payment = Payment.create(funding, self.backend) + gateway_url = payment.get_processor()(payment).get_gateway_url(self.request) + payment.change_status('in_progress') + return redirect(gateway_url) + + +class OfferListView(ListView): + queryset = Offer.public() + + def get_context_data(self, *args, **kwargs): + ctx = super(OfferListView, self).get_context_data(*args, **kwargs) + ctx['funding_no_show_current'] = True + return ctx class ThanksView(TemplateView): @@ -95,5 +121,9 @@ class ThanksView(TemplateView): def get_context_data(self, *args, **kwargs): ctx = super(ThanksView, self).get_context_data(*args, **kwargs) - ctx['object'] = Offer.current() + ctx['offer'] = Offer.current() + ctx['funding_no_show_current'] = True return ctx + +class NoThanksView(TemplateView): + template_name = "funding/no_thanks.html"