from django.contrib.auth.decorators import login_required
from django.http import Http404
-from django.http.response import HttpResponseRedirect
+from django.http.response import HttpResponseRedirect, HttpResponseForbidden
from django.shortcuts import render
+from api.piston_patch import HttpResponseAppRedirect
from paypal.forms import PaypalSubscriptionForm
from paypal.rest import execute_agreement, check_agreement, agreement_approval_url, PaypalError
from paypal.models import BillingAgreement as BillingAgreementModel, BillingPlan
-@login_required
-def paypal_form(request):
+def paypal_form(request, app=False):
if request.POST:
+ if not request.user.is_authenticated():
+ return HttpResponseForbidden()
form = PaypalSubscriptionForm(data=request.POST)
if form.is_valid():
amount = form.cleaned_data['amount']
try:
- approval_url = agreement_approval_url(amount)
+ approval_url = agreement_approval_url(amount, app=app)
except PaypalError as e:
return render(request, 'paypal/error_page.html', {'error': e.message})
return HttpResponseRedirect(approval_url)
@login_required
-def paypal_return(request):
+def paypal_return(request, app=False):
token = request.GET.get('token')
if not token:
raise Http404
active = check_agreement(resource.id)
BillingAgreementModel.objects.create(
agreement_id=resource.id, user=request.user, plan=plan, active=active, token=token)
- return render(request, 'paypal/return.html', {'resource': resource})
+ else:
+ resource = None
+ if app:
+ if getattr(resource, 'error'):
+ return HttpResponseAppRedirect('wolnelekturyapp://paypal_error')
+ else:
+ return HttpResponseAppRedirect('wolnelekturyapp://paypal_return')
+ else:
+ return render(request, 'paypal/return.html', {'resource': resource})
def paypal_cancel(request):