2018-07-08 00:01:06 +02:00
|
|
|
# -*- mode: python; coding: utf-8 -*-
|
2020-11-23 17:06:37 +01:00
|
|
|
# Re2o est un logiciel d'administration développé initiallement au Rézo Metz. Il
|
2018-07-08 00:01:06 +02:00
|
|
|
# se veut agnostique au réseau considéré, de manière à être installable en
|
|
|
|
# quelques clics.
|
|
|
|
#
|
|
|
|
# Copyright © 2018 Hugo Levy-Falk
|
|
|
|
#
|
|
|
|
# This program is free software; you can redistribute it and/or modify
|
|
|
|
# it under the terms of the GNU General Public License as published by
|
|
|
|
# the Free Software Foundation; either version 2 of the License, or
|
|
|
|
# (at your option) any later version.
|
|
|
|
#
|
|
|
|
# This program is distributed in the hope that it will be useful,
|
|
|
|
# but WITHOUT ANY WARRANTY; without even the implied warranty of
|
|
|
|
# MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
|
|
|
|
# GNU General Public License for more details.
|
|
|
|
#
|
|
|
|
# You should have received a copy of the GNU General Public License along
|
|
|
|
# with this program; if not, write to the Free Software Foundation, Inc.,
|
|
|
|
# 51 Franklin Street, Fifth Floor, Boston, MA 02110-1301 USA.
|
2018-01-12 01:07:25 +01:00
|
|
|
"""Payment
|
|
|
|
|
2018-07-08 00:01:06 +02:00
|
|
|
Here are the views needed by comnpay
|
2018-01-12 01:07:25 +01:00
|
|
|
"""
|
2018-04-14 13:39:51 +00:00
|
|
|
|
|
|
|
from collections import OrderedDict
|
|
|
|
|
2018-01-12 01:07:25 +01:00
|
|
|
from django.contrib import messages
|
2021-02-10 11:06:09 +01:00
|
|
|
from django.contrib.auth.decorators import login_required
|
|
|
|
from django.http import HttpResponse, HttpResponseBadRequest
|
|
|
|
from django.shortcuts import get_object_or_404, redirect
|
|
|
|
from django.urls import reverse
|
2018-01-12 01:07:25 +01:00
|
|
|
from django.utils.datastructures import MultiValueDictKeyError
|
2018-03-31 13:43:46 +00:00
|
|
|
from django.utils.translation import ugettext as _
|
2021-02-10 11:06:09 +01:00
|
|
|
from django.views.decorators.csrf import csrf_exempt
|
2018-01-12 01:07:25 +01:00
|
|
|
|
2018-06-21 20:03:46 +02:00
|
|
|
from cotisations.models import Facture
|
2021-02-10 11:06:09 +01:00
|
|
|
|
2018-06-21 20:03:46 +02:00
|
|
|
from .comnpay import Transaction
|
2018-07-03 14:49:13 +02:00
|
|
|
from .models import ComnpayPayment
|
2018-01-12 01:07:25 +01:00
|
|
|
|
2018-04-13 18:58:29 +00:00
|
|
|
|
2018-01-12 01:07:25 +01:00
|
|
|
@csrf_exempt
|
|
|
|
@login_required
|
|
|
|
def accept_payment(request, factureid):
|
2018-04-09 17:40:46 +00:00
|
|
|
"""
|
2018-07-08 00:01:06 +02:00
|
|
|
The view where the user is redirected when a comnpay payment has been
|
|
|
|
accepted.
|
2018-04-09 17:40:46 +00:00
|
|
|
"""
|
2018-06-17 16:31:47 +02:00
|
|
|
invoice = get_object_or_404(Facture, id=factureid)
|
2018-06-17 23:09:55 +02:00
|
|
|
if invoice.valid:
|
2018-06-17 16:31:47 +02:00
|
|
|
messages.success(
|
|
|
|
request,
|
2019-11-04 17:55:03 +01:00
|
|
|
_("The payment of %(amount)s € was accepted.")
|
|
|
|
% {"amount": invoice.prix_total()},
|
2018-06-17 16:31:47 +02:00
|
|
|
)
|
2018-06-17 23:09:55 +02:00
|
|
|
# In case a cotisation was bought, inform the user, the
|
|
|
|
# cotisation time has been extended too
|
2021-02-10 11:06:09 +01:00
|
|
|
if any(
|
|
|
|
purchase.test_membership_or_connection()
|
|
|
|
for purchase in invoice.vente_set.all()
|
|
|
|
):
|
2018-06-17 23:09:55 +02:00
|
|
|
messages.success(
|
|
|
|
request,
|
2019-11-04 17:55:03 +01:00
|
|
|
_(
|
|
|
|
"The subscription of %(member_name)s was extended to"
|
|
|
|
" %(end_date)s."
|
|
|
|
)
|
|
|
|
% {
|
|
|
|
"member_name": invoice.user.pseudo,
|
|
|
|
"end_date": invoice.user.end_adhesion(),
|
|
|
|
},
|
2018-06-17 23:09:55 +02:00
|
|
|
)
|
2019-11-04 17:55:03 +01:00
|
|
|
return redirect(reverse("users:profil", kwargs={"userid": invoice.user.id}))
|
2018-01-12 01:07:25 +01:00
|
|
|
|
|
|
|
|
|
|
|
@csrf_exempt
|
|
|
|
@login_required
|
|
|
|
def refuse_payment(request):
|
2018-04-09 17:40:46 +00:00
|
|
|
"""
|
2018-07-08 00:01:06 +02:00
|
|
|
The view where the user is redirected when a comnpay payment has been
|
|
|
|
refused.
|
2018-04-09 17:40:46 +00:00
|
|
|
"""
|
2019-11-04 17:55:03 +01:00
|
|
|
messages.error(request, _("The payment was refused."))
|
|
|
|
return redirect(reverse("users:profil", kwargs={"userid": request.user.id}))
|
2018-04-13 18:58:29 +00:00
|
|
|
|
2018-01-12 01:07:25 +01:00
|
|
|
|
|
|
|
@csrf_exempt
|
|
|
|
def ipn(request):
|
2018-04-09 17:40:46 +00:00
|
|
|
"""
|
|
|
|
The view called by Comnpay server to validate the transaction.
|
|
|
|
Verify that we can firmly save the user's action and notify
|
2018-07-08 00:01:06 +02:00
|
|
|
Comnpay with 400 response if not or with a 200 response if yes.
|
2018-04-09 17:40:46 +00:00
|
|
|
"""
|
2018-06-21 20:03:46 +02:00
|
|
|
p = Transaction()
|
2019-11-04 17:55:03 +01:00
|
|
|
order = ("idTpe", "idTransaction", "montant", "result", "sec")
|
2018-01-12 01:07:25 +01:00
|
|
|
try:
|
|
|
|
data = OrderedDict([(f, request.POST[f]) for f in order])
|
|
|
|
except MultiValueDictKeyError:
|
|
|
|
return HttpResponseBadRequest("HTTP/1.1 400 Bad Request")
|
|
|
|
|
2019-11-04 17:55:03 +01:00
|
|
|
idTransaction = request.POST["idTransaction"]
|
2018-01-12 01:07:25 +01:00
|
|
|
try:
|
|
|
|
factureid = int(idTransaction)
|
|
|
|
except ValueError:
|
|
|
|
return HttpResponseBadRequest("HTTP/1.1 400 Bad Request")
|
|
|
|
|
|
|
|
facture = get_object_or_404(Facture, id=factureid)
|
2019-11-04 17:55:03 +01:00
|
|
|
payment_method = get_object_or_404(ComnpayPayment, payment=facture.paiement)
|
2018-07-03 14:49:13 +02:00
|
|
|
|
|
|
|
if not p.validSec(data, payment_method.payment_pass):
|
|
|
|
return HttpResponseBadRequest("HTTP/1.1 400 Bad Request")
|
|
|
|
|
2019-11-04 17:55:03 +01:00
|
|
|
result = True if (request.POST["result"] == "OK") else False
|
|
|
|
idTpe = request.POST["idTpe"]
|
2018-07-03 14:49:13 +02:00
|
|
|
|
|
|
|
# Checking that the payment is actually for us.
|
|
|
|
if not idTpe == payment_method.payment_credential:
|
|
|
|
return HttpResponseBadRequest("HTTP/1.1 400 Bad Request")
|
2018-01-12 01:07:25 +01:00
|
|
|
|
2018-07-03 14:49:13 +02:00
|
|
|
# Checking that the payment is valid
|
2018-01-12 01:07:25 +01:00
|
|
|
if not result:
|
2018-04-09 17:40:46 +00:00
|
|
|
# Payment failed: Cancelling the invoice operation
|
|
|
|
# And send the response to Comnpay indicating we have well
|
|
|
|
# received the failure information.
|
2018-01-12 01:07:25 +01:00
|
|
|
return HttpResponse("HTTP/1.1 200 OK")
|
|
|
|
|
|
|
|
facture.valid = True
|
|
|
|
facture.save()
|
|
|
|
|
2018-04-09 17:40:46 +00:00
|
|
|
# Everything worked we send a reponse to Comnpay indicating that
|
|
|
|
# it's ok for them to proceed
|
2018-01-12 01:07:25 +01:00
|
|
|
return HttpResponse("HTTP/1.0 200 OK")
|