Integración del Checkout Pro de Mercado Pago en Django
Definí en pasos los procesos requeridos para realizar una transacción y cómo están implementados.
-
Paso 1: Obtengo de la base de datos (o de donde se envíe) una lista con las cuotas o artículos que quiero que el cliente pague.
-
Paso 2: Defino: ¿Quiero que la persona pague cada cuota por separado o todos a la vez? Si debe ser todo en un pago utilizo la función "unaPreferenciaPorVariasCuotas", si cada uno se debe pagar aparte uso "unaPreferenciaPorCadaCuota".
-
Paso 3: La función elegida genera una/s preferencias (detalles sobre las preferencias debajo), que son enviadas a la API de MP mediante el SDK y se recibe como respuesta: el mismo objeto MÁS ciertos datos de mercado pago, incluido el init_point y la id de las preferencias enviadas en MP.
-
Paso 4: Se envía esta "id" al front end (+ el user token) y se pasa como argumento a una función del sdk, que genera un botón que redirecciona. Intenté utilizar el "init_point" para acceder al pago pero da error. Más detalles en: https://www.mercadopago.com.ar/developers/es/docs/checkout-pro/integrate-checkout-pro (En la sección donde se describe el HTML).
-
Paso 5: Una vez que el usuario paga lo que debe en MP, MP notifica a un punto (especificado en las preferencias) que se realizó una transacción. En esta request podemos encontrar el campo "resource", un link al recibo; accedemos a este y lo registramos en la base de datos. Todo esto se realiza en la función "recibirNotificacion", explicada debajo con más detalle.
-
Nota: el campo "status" tiene campos generales, mientras que "status_details" es más específico y que nos dá mas opciones. Documentación de estos campos en: https://www.mercadopago.com.ar/developers/es/reference/payments/_payments_id/get .
- Está programado utilizando el REST Framework de Django, pensado para que el frontend haga un get al framework y se le devuelva un objeto con todos los datos. Por privacidad de los datos, hay que elegir bien qué queremos que acceda el front end.
- Adapte cada campo a sus propias necesidades.
- En "enviarRequestAMP" cambie el argumento "ejemploPropio" de "unaPreferenciaPorVariasCuotas" por el propio dato que se desea tratar.
- En "recibirRequestDeMP" , dentro del if añada un sistema que registre en la base de datos cómo fué procesado el pago.
- "frontEndIntegration" y el archivo index.html pueden ser eliminados, ya que se utilizaron para pruebas.
- "preferencias" es un objeto con múltiples campos que podemos adaptar para nuestro uso específico. El objeto se encuentra en el archivo preferencias.py y ahí podemos ver cada campo con contexto. El campo más relevante es "items", una lista que contiene a su vez los objetos que se van a cobrar al usuario.
- El campo "items" es una lista de las diferentes cuotas o artículos que se desean pagar EN UN SOLO PAGO. Puede haber múltiples productos en el campo pero a la hora de pagar se suman los precios y no se pueden separar.
"payment_methods": {
"excluded_payment_methods": lista de diccionarios, ejemplo: "id": "master",
"excluded_payment_types": lista de diccionarios, ejemplo: "id": "ticket",
"installments": son las cuotas máximas aceptadas,
"porpouse": booleano, requeriría que se tenga una cuenta de mercado pago,
},
- El modo binario reduce las capacidades de pago de los usuarios, solo da approved o cancelled, no pending o etc.
- Se recomienda en la documentación dar 3 días por los pagos en efectivo, que impactan a las 48hs.
- Esos datos están como ejemplos, cada vez que se crea una preferencia se reemplazan por los actuales.
-
Requieren una devuelve UNA preferencia con el campo "items" como una lista de las cuotas.
-
unaPreferenciaPorCadaCuota devuelve un objeto de preferencias POR CADA cuota o artículo de la lista que se le dió.
-
unaPreferenciaPorVariasCuotas devuelve UN SOLO objeto de preferencias con una lista con los items dentro.
-
Las 2 funciones cumplen 2 funciones distintas dado que, si no tenemos manera de separar los productos y los queremos pagar a parte tenemos que enviarlos en requests separadas.
- La manera en la que se transforma la entrada debe adapatarse a la lista que se le dé, si no llegan elementos obligatorios como quantity se los puede asignar a 1.
- No sería ideal crear siempre nuevos links, podría ser buena idea anotar en la DB el link asociado al pago y el vencimiento. Si vence en las prox 48hs, se crea uno nuevo en caso de que el usuario pague en efectivo. O se puede excluir al efectivo y se reemplaza al anterior. Igualmente, puede ser una solución más complicada de implementarse que lo que parece por el uso de timedelta() .
- En esta función se recibe una notificación de MP, con diferentes objetos. El relevante es "resource", que es el link al recibo.
- Para acceder al recibo necesitamos usar el modulo "requests" con ese link y nuestra key privada en el header.
- Una vez recibidos los datos, buscamos el campo status_details. Como mencionado previamente, se lo usa en vez de "status" para ver exactamente por qué no se pasó el pago. Se podría implementar que si el pago se realizó con una tarjeta robada se inhabilite la cuenta o etc.
- Este recibo lo podemos registrar en una base de datos o como deseemos.
- Es necesario, primero que todo crear nuestra app en el dashboard. Donde nos pregunta sobre la integración, seleccionamos la opcion "Checkout Pro". Todavía no generamos las creedenciales "reales", solo nos interesa la key de prueba y la key pública.
- Dentro de la pestaña de "Tus integraciones" selecciono "Cuentas de prueba" y creo una nueva cuenta de prueba, le asigno los fondos que necesito para las pruebas.
- Accedemos a la ruta "http://127.0.0.1:8000/api/mp/", que llama a la función "enviarRequestAMP"; previamente introducimos un ejemplo para "unaPreferenciaPorCadaCuota" o "unaPreferenciaPorTodasLasCuotas". Copiamos el valor de "id" (o lo pasamos de alguna manera al front-end o template de Django) y el token de prueba. Un template de ejemplo está en index.html .
- Una vez en la página "http://127.0.0.1:8000/api/render/" hacemos click en el botón y accedemos a MP. Rellenamos los datos con nuestro usuario de prueba y las tarjetas de crédito de prueba (https://www.mercadopago.com.ar/developers/es/docs/checkout-api/integration-test/test-cards); ponemos nuestro documento y mail (el mail no debe ser el asociado a la cuenta). Una vez que se realiza la transacción recibimos la notificación y completamos el ciclo.
- Una vez que querramos pasar a producción, simplemente debemos ir al dashboard y a la pestaña de nuestra aplicación/implementación, y generar tokens de producción.
- Los reemplazamos en el ENV.
- Hacemos una comprobación y hacemos algún pago mínimo para testear si todo está funcional.