A django app to emit and listen Redsys/sermepa payments
Project description
Django sermepa es una aplicación muy al estilo de django-paypal para usar el TPV Virtual de Redsys/Sermepa, el TPV más usado en España.
Permite generar cobros puntuales, recurrentes por fichero o por referencia, y devoluciones.
La app tiene una vista que escucha las notificaciones del TPV (se debe pedir su activación a tu banco) y lanza signals para que sean procesadas por tu aplicación de cobros, para cambiar de estado el pedido, enviar emails de notificación…
Para utilizarlo sigue los siguientes pasos
Instala el proyecto usando pip o bájate las fuentes de github:
1.1 Intalación con pip:
pip install django-sermepa
1.2 Usando las fuentes, bájate el proyecto y copia la carpeta sermepa en tu entorno o proyecto.
Añadelo a INSTALLED_APPS del settings.py
Ojo, hay nuevos modelos: syncdb o migrations (no incluídas, depende de tu versiòn de django)
Añade los siguientes settings:
SERMEPA_URL_PRO = 'https://sis.redsys.es/sis/realizarPago' SERMEPA_URL_TEST = 'https://sis-t.redsys.es:25443/sis/realizarPago' SERMEPA_MERCHANT_CODE = '327234688' #comercio de test SERMEPA_TERMINAL = '002' SERMEPA_SECRET_KEY = 'qwertyasdf0123456789' SERMEPA_BUTTON_IMG = '/site_media/_img/targets.jpg' SERMEPA_CURRENCY = '978' #Euros
Deberás modificar SERMEPA_MERCHANT_CODE, SERMEPA_SECRET_KEY, SERMEPA_BUTTON_IMG, SERMEPA_TERMINAL
Añade la ruta de la respuesta de Sermepa a tus urls:
(r'^sermepa/', include('sermepa.urls')),
Programa los listeners de las signals de OK, KO y si quieres de error:
6.1 El listener recibe un objecto de tipo SermepaResponse con toda la información de la operación del TPV. Puedes usar un listener que procese todas los casos, o uno por cada caso (OK y KO)
def payment_ok(sender, **kwargs): '''sender es un objecto de clase SermepaResponse. Utiliza el campo Ds_MerchantData para asociarlo a tu Pedido o Carrito''' pedido = Pedido.objects.get(id=sender.Ds_MerchantData) pedido.estado = 'cobrado' pedido.save() send_email_success(pedido) def payment_ko(sender, **kwargs): '''sender es un objecto de clase SermepaResponse. Utiliza el campo Ds_MerchantData para asociarlo a tu Pedido o Carrito'' pass def sermepa_ipn_error(sender, **kwargs): '''Esta señal salta cuando el POST data recibido está mal firmado. Solo pasa en caso de intentos de cracking. sender es un objecto de clase SermepaResponse. Utiliza el campo Ds_MerchantData para asociarlo a tu Pedido o Carrito'' pass
6.2 Asocia el listener a las señales, en algún punto que se cargue al iniciar el proyecto, por ejemplo en el models.py
from sermepa.signals import payment_was_successful from sermepa.signals import payment_was_error from sermepa.signals import signature_error payment_was_successful.connect(payment_ok) payment_was_error.connect(payment_ko) signature_error.connect(sermepa_ipn_error)
Utiliza el form de SermepaPaymentForm para inicializar el botón de pago.
El botón de pago será un formulario POST a la url del TPV, firmado con tu clave secreta, que deberá pasar toda la información de la operación: modalidad de pago, importe (en céntimos), URLs de notificación, OK y KO, descripción, datos del comercio, identificador de tu pedido, identificador de la operación…
Existen diferentes modalidades de pago:
Las compras puntuales, el Ds_Merchant_TransactionType=’0’ y el Ds_Merchant_Order debe ser un string siempre único y de 10 caracteres.
Las suscripciones o pagos recurrentes. Existen 2 tipos, por fichero o por referencia.
2.1 Por fichero, tienen un límite de 12 meses o 12 cobros.
2.1.1 El primer cobro el Ds_Merchant_TransactionType=’L’ y el Ds_Merchant_Order debe ser siempre único.
El tpv responde con el mismo valor pasado en la variable Ds_Order más 2 dígitos adicionales indicando el número de transacción (la primera es 00)
2.1.2 Los cobros sucesivos se debe pasar el Ds_Merchant_TransactionType=’M’ y el primer Ds_Merchant_Order
2.2 Por referencia, no tiene límite de tiempo ni de cobros. Este sistema soporta cobros de 0€ para activaciones y cambios de tarjetas.
2.2.1 El primer cobro el Ds_Merchant_TransactionType=’0’ y el Ds_Merchant_Order=’REQUIRED’
El tpv responde con un nuevo parámetro Ds_Merchant_Identifier, que hay que almacenar (idreferencia)
2.2.2 Los cobros sucesivos son Ds_Merchant_TransactionType=’0’ y el Ds_Merchant_Order=idreferencia (el valor que nos han pasado en el primero cobro)
Mira el código del ejemplo (sermepa_test/views.py) para más info:
El TPV enviará una respuesta (SermepaResponse) con la información que se le ha enviado más nuevos datos relacionados con el pago. A destacar:
Ds_MerchantData es el mismo valor enviado en el formulario en el campo Ds_Merchant_MerchantData. Debería contener el identificador de tu Pedido o Carrito
Ds_Merchant_Identifier: la referencia para cobros recurrentes sucesivos si se utiliza el pago por referencia.
Ds_ExpiryDate: Fecha de expiración de la tarjeta
Ds_Card_Number: Número asteriscado de la tarjeta
Prueba el formulario de compra puntual en http://localhost:8000/
Project details
Download files
Download the file for your platform. If you're not sure which to choose, learn more about installing packages.
Source Distribution
File details
Details for the file django-sermepa-1.1.1.tar.gz
.
File metadata
- Download URL: django-sermepa-1.1.1.tar.gz
- Upload date:
- Size: 7.9 kB
- Tags: Source
- Uploaded using Trusted Publishing? No
File hashes
Algorithm | Hash digest | |
---|---|---|
SHA256 | e079a2ecfe0c3aa96f853a7b4bdb8a31b8322ba8267c7b6b387c89a0888383bd |
|
MD5 | 52c49b7301abbe27960e4d4803ae1c63 |
|
BLAKE2b-256 | 596fbb3c3c9d9f548d2b5de4b8d112fcd264f428fb5205c404ca0c418661fcc0 |