Configuración de la integración
La integración de Money Out se realiza mediante la ejecución de un solo llamado a la API v1/transaction-intents. Así, la transacción se crea y procesa en un solo request y, si la ejecución es exitosa, el dinero estará disponible para ser retirado en la cuenta de destino, sin necesidad de llevar adelante etapas adicionales.
Para integrar Money Out con destino a cuentas bancarias, deberás enviar un POST con tu Access Token en el header Authorization
y tu clave de idempotencia en el header X-Idempotency-Key
al endpoint /v1/transaction-intents/process. Deberás enviar los parámetros correspondientes siguiendo las indicaciones de la tabla debajo.
curl
curl --request POST \
--url https://api.mercadopago.com/v1/transaction-intents/process \
--header 'Authorization: Bearer TEST-4613*********761-11121*********92cd39015*********7bbc3cb-1*********' \
--header 'content-type: application/json' \
--header 'x-enforce-signature: false' \
--data '{
"external_reference": "external_ref_1234",
"point_of_interaction": {
"type": "PSP_TRANSFER"
},
"seller_configuration": {
"notification_info": {
"notification_url": "http://example.com.ar/notification"
}
},
"transaction": {
"from": {
"accounts": [
{
"amount": 25
}
]
},
"to": {
"total_amount": 25,
"accounts": [
{
"amount": 25,
"bank_id": "015",
"number": "0150533701000132688355",
"holder": "Victor Hugo",
"owner": {
"identification": {
"number": "20209642647",
"type": "CUIT"
}
},
"type": "savings_account",
"description": "envio de 25"
}
]
},
"total_amount": 25
}
}'
Campo | Descripción | Requerido/Opcional | Ejemplo |
x-signature | Header. Firma de la solicitud con el cuerpo cifrado en base 64 con las claves pública y privada del integrador. Accede a la sección Cifrado punta a punta si necesitas más información. | Requerido sólo en el ambiente de producción. | - |
x-enforce-signature | Header. Booleano para indicar si el integrador enviará o no la firma. | No requerido en ambiente de pruebas, y requerido en ambiente productivo, que es cuando es obligatorio enviar la firma. | - |
external_reference | Body. String con una referencia para identificar la transacción. Es generada por el integrador y puede ser cualquier valor que permita hacer un seguimiento de las transacciones siempre que no tenga caracteres especiales (“”, [ ], (), @) y no exceda los 64 caracteres. Sí están permitidos números (1234), letras (abcde) y guiones medios y bajos (-; _). Su valor no puede ser duplicado con otras transacciones. | Opcional | MP0001 |
point_of_interaction.type | Body. Valor fijo. Siempre debe ser {"type":"PSP_TRANSFER"} | Requerido | {"type":"PSP_TRANSFER"} |
seller_configuration.notification_info.notification_url | Body. URL en la que se recibirán las notificaciones de los eventos relacionados a la transacción, como sus cambios de estado. Este campo tiene un límite de 500 caracteres. | Opcional | http://ejemplo.cl/notification |
transaction.from.accounts.amount | Body. Valor de la transacción, que será retirado de la cuenta de origen from . El valor mínimo es 0, y el máximo, 10000000000. | Requerido | 100,00 |
transaction.to.accounts.amount | Body. Monto a enviar a la cuenta destino indicada en el to . Debe ser el mismo valor indicado para from.accounts.amount . | Requerido | 100,00 |
transaction.to.accounts.bank_id | Body. Número identificador del banco al que pertenece la cuenta de destino. | Requerido | 99999004 |
transaction.to.accounts.type | Body. Tipo de cuenta de destino. Los valores posibles son current , para cuentas bancarias, y mercadopago , para cuentas Mercado Pago. | Requerido | current / mercadopago |
transaction.to.accounts.number | Body. Número único que representa la cuenta bancaria de destino. | Requerido | 10266732 |
transaction.to.accounts.owner.identification.type | Body. Tipo de identificación del titular de la cuenta de destino. | Requerido | “RUT” |
transaction.to.accounts[n].owner.identification.number | Body. Número de identificación del titular de la cuenta de destino. | Requerido | 1234567890 |
transaction.total_amount | Body. Monto total de la transacción. Debe ser el mismo valor indicado para from.accounts.amount y to.accounts.amount | Requerido | 100,00 |
Si la ejecución fue exitosa, recibirás una respuesta con status code 200
, que indica que la transacción fue aceptada, como en el ejemplo a continuación.
curl
{
"created_date": "2024-11-13T15:04:25.699+00:00",
"external_reference": "external_ref_1234",
"id": "22dvqmseu9m",
"last_updated_date": "2024-11-13T15:04:31.256+00:00",
"point_of_interaction": {
"type": "PSP_TRANSFER"
},
"seller_configuration": {
"notification_info": {
"notification_url": "http://example.ar/notification"
}
},
"status": "processed",
"transaction": {
"from": {
"accounts": [
{
"amount": 25,
"status_details": []
}
]
},
"paid_amount": 25,
"payer": {
"id": 1992483656
},
"refunded_amount": 0,
"to": {
"accounts": [
{
"amount": 25,
"description": "envio de 25",
"origin_id": "01JCK0VSV3TBSAADAGJQKG4GTY",
"status_details": [
"approved"
]
}
]
},
"total_amount": 25,
"statement_descriptor": "",
"binary_mode": false
}
}
Atributo | Descripción |
created_date | Fecha de creación de la transacción. Será devuelto en formato AAAA-MM-DDTHH:MM:SS.SSSZ. |
external_reference | Referencia externa de la transacción, que fue generada por el integrador al momento de crearla. |
id | Identificador único de la transacción, generado automáticamente. |
last_updated_date | Última actualización del estado de la transacción. Será devuelto en formato AAAA-MM-DDTHH:MM:SS.SSSZ. |
point_of_interaction.type | Punto de interacción. Es un valor fijo, siempre {"type":"PSP_TRANSFER"} . |
seller_configuration.notification_info.notification_url | URL en la que se recibirán las notificaciones de los eventos relacionados a la transacción, como sus cambios de estado. |
status | Estado de la transacción. Para conocer los posibles estados, dirígete a Posibles estados de una transacción. |
transaction.from.accounts.amount | Monto debitado de la cuenta Mercado Pago de origen. |
transaction.paid_amount | Monto total cobrado al titular de la cuenta de origen. Será igual a from.accounts.amount , salvo que haya habido un reembolso total o parcial, indicado en refunded_amount . |
transaction.payer.id | Identificador del integrador titular de la cuenta de origen. |
transaction.refunded_amount | En caso de un reembolso, indicará el monto total reembolsado al titular de la cuenta de origen. Si no hubo ningún reembolso, su valor será 0. |
transaction.to.accounts.amount | Monto transferido a la cuenta de destino. Su valor será igual a from.accounts.amount , salvo que haya habido un reembolso total o parcial, indicado este último en el campo transaction.refunded_amount . |
transaction.to.accounts.origin_id | Identificador que permite rastrear la transacción dentro del sistema bancario. |
transaction.to.accounts.amount.status_detail | Información detallada del estado de la transacción. Para conocer los posibles status_detail , dirígete a Posibles estados de una transacción. |
transaction.to.accounts.owner.identification.number | Número identificador del titular de la cuenta de destino. |
transaction.to.accounts.owner.identification.type | Tipo de identificación del titular de la cuenta. |
transaction.to.accounts.bank_id | Número identificador del banco al que pertence la cuenta de destino. |
transaction.to.accounts.type | Tipo de cuenta de destino. |
transaction.to.accounts.number | Número único que representa la cuenta de destino. |
transaction.total_amount | Monto total de la transacción. |
transaction.statement_descriptor | Mensaje adicional a la transacción. |
Configurar notificaciones
Para poder mantenerte al tanto de los estados de tus transacciones, debes configurar las notificaciones Webhooks. Se trata de mensajes enviados por el servidor de Mercado Pago ante eventos que suceden en tu aplicación. Específicamente para el caso de Money Out, estos eventos pueden ser, o bien la creación de una transacción, o las actualizaciones de estado que la misma atraviese durante su procesamiento.
Puedes configurar tus notificaciones Webhooks al realizar el llamado para crear una transacción, a través del campo notification_url
. Sólo debes completarlo con aquella URL en la cual quieras recibir tus actualizaciones.
Puedes ver ejemplos de los mensajes que recibirás al registrarse un evento a continuación.
- Mensaje ante la creación de una transacción
json
{
"action": "transaction_intent.created",
"api_version": "v1",
"data": {
"id": "1108917506-01GGTH198RP0K71H133EK9BJAT" // ID del transaction intent
},
"date_created": "2022-11-01T17:19:53.915-04:00",
"id": "103686924004", // ID de la notificacion
"last_updated": "0001-01-01T00:00:00Z",
"status": "new",
"type": "transaction_intent"
}
- Mensaje ante una actualización de una transacción
json
{
"action": "transaction_intent.updated",
"api_version": "v1",
"data": {
"id": "1108917506-01GGTH198RP0K71H133EK9BJAT" // ID del transaction intent
},
"date_created": "2022-11-01T17:19:53.915-04:00",
"id": "103686918006", // ID de la notificacion
"last_updated": "2022-11-01T17:19:55.001-04:00",
"status": "partially_processed",
"type": "transaction_intent"
}
El atributo data.id
corresponde al ID de la transacción sobre la que se te está notificando, el parámetro id
será el identificador de la notificación, y status
te informará, o bien la creación de la transacción, o bien la actualización del estado de la misma.
Acciones necesarias después de recibir la notificación
Cuando recibes una notificación en tu plataforma debes, primero, validar la información del recurso notificado. Para eso, ejecuta el request para Obtener información sobre una transacción utilizando el ID de la transacción que te fue notificada.
Una vez contrastados y validados los datos de la transacción, Mercado Pago espera una respuesta para asegurarse que la notificación fue recibida correctamente. Para eso, debes devolver un HTTP STATUS 200 (OK)
o 201 (CREATED)
a la URL enviada en el campo notification_url
. Si no se envía esta respuesta, se entenderá que no has recibido la notificación y se realizará un nuevo intento de envío hasta que se reciba la respuesta.
En la siguiente tabla puedes encontrar los principales eventos, plazos y tiempo de espera para recibir nuevos intentos de notificación.
Evento | Plazo después del primer envío | Tiempo de espera de confirmación |
Envío | - | 22 segundos |
Primer intento | 15 minutos | 5 segundos |
Segundo intento | 30 minutos | 5 segundos |
Tercer intento | 6 horas | 5 segundos |
Cuarto intento | 48 horas | 5 segundos |
Quinto intento | 96 horas | 5 segundos |
Obtener información sobre una transacción
Si lo deseas, puedes obtener información sobre una transacción. Esto puede ser útil para corroborar que la misma fue creada correctamente, para consultar su status
, o para verificar la información recibida en tus notificaciones.
Para hacerlo, envía un GET con tu Access Token al endpoint /v1/transaction-intents//{{transaction_intent_id}}, reemplazando transaction_intent_id
por el ID obtenido en la respuesta al momento de crear la transacción.
curl
curl --location --request GET 'https://api.mercadopago.com/v1/transaction-intents/{{transaction_intent_id}}' \
--header 'Authorization: Bearer {{access_token}}'
Si los datos enviados en el llamado son correctos, recibirás una respuesta como la siguiente:
json
{
"created_date": "2024-11-13T15:04:25.699+00:00",
"external_reference": "external_ref_1234",
"id": "22dvqmseu9m",
"last_updated_date": "2024-11-13T15:04:31.256+00:00",
"point_of_interaction": {
"type": "PSP_TRANSFER"
},
"seller_configuration": {
"notification_info": {
"notification_url": "http://example.ar/notification"
}
},
"status": "processed",
"transaction": {
"from": {
"accounts": [
{
"amount": 25,
"status_details": []
}
]
},
"paid_amount": 25,
"payer": {
"id": 1992483656
},
"refunded_amount": 0,
"to": {
"accounts": [
{
"amount": 25,
"description": "envio de 25",
"origin_id": "01JCK0VSV3TBSAADAGJQKG4GTY",
"status_details": [
"approved"
]
}
]
},
"total_amount": 25,
"statement_descriptor": "",
"binary_mode": false
}
}
Para conocer los detalles de cada atributo devuelto, consulta la respuesta a Configurar retiros.
Posibles estados de una transacción
Cuando creas una transacción, o bien cuando consultas información relativa a ella, las respuestas te devolverán dos campos que te permitirán conocer el estado en el que se encuentra.
Por un lado, el campo status
te brindará información respecto al estado actual del procesamiento. Por otro, el campo status_detail
, que encontrarás como atributo de transaction.to.accounts
, te permitirá conocer los motivos o detalles que dieron como resultado ese estado.
A continuación puedes ver todos los estados por los que puede pasar una transacción durante su procesamiento.
status | status_detail | Descripción |
processed | approved | El procesamiento de la transacción se realizó de manera exitosa. |
approved | partially_refunded | La transacción fue reembolsada parcialmente por el banco de destino. |
transaction_in_process | pending_authorized | La transacción está en proceso, pendiente de estado final, y aguarda autorización. |
transaction_in_process | pending_bank | El banco destino no dio respuesta, por lo que la transacción está pendiente de estado final. |
refunded | refunded | La transacción fue reembolsada por el banco de destino. |
rejected | by_bank | El banco de destino rechazó la transferencia. Realiza nuevamente el llamado. |
rejected | by_provider | El proveedor rechazó la transferencia. Realiza nuevamente el llamado. |
rejected | high_risk | La transacción es rechazada por riesgo de fraude. Realiza nuevamente el llamado. |
rejected | insufficient_funds | Transacción rechazada por fondos insuficientes en la cuenta de origen. Realiza nuevamente el llamado. |
rejected | other_reason | Transacción rechazada por defecto debido a problemas internos durante su procesamiento. Realiza nuevamente el llamado. |
rejected | review_manual | La transacción es rechazada y encaminada a prevención al fraude para análisis. Realiza nuevamente el llamado. |