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…
Nuevo en la versión 1.1.2: ¡Compatible con python 2.7 y 3.x!
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-sermepa1.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
INSTALLED_APPS += ('sermepa',)
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.Ds_AuthorisationCode = sender.Ds_AuthorisationCode #Guardar este valor en caso # de poder hacer devoluciones, es necesario. 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
Ds_AuthorisationCode: Código de la operación autorizada, para poder hacer una devolución posterior.
Prueba el formulario de compra puntual en http://localhost:8000/ o http://localhost:8000/L/ …
Project details
Download files
Download the file for your platform. If you're not sure which to choose, learn more about installing packages.