# Parámetros de URL de Redirect

Además de poder saber el resultado de una transacción por medio de los [Webhook](https://docs.wompi.sv/webhook), también es posible saberlo por medio de la URL de Redirect.&#x20;

La URL de Redirect es donde el pagador se redirecciona después de hacer un pago, la URL de redirect se puede especificar tanto al crear un [enlace de pago](https://docs.wompi.sv/metodos-api/enlace-de-pago) como al iniciar una transacción de compra por medio de [API](https://docs.wompi.sv/metodos-api/crear-transaccion-compra-3ds).&#x20;

{% hint style="warning" %}
Aunque se puede saber el resultado de una transacción por medio de la URL de redirect se recomienda usar siempre los Webhook en conjunto con la URL de Redirect, debido a que la entrega de la URL de Redirect depende del navegador del pagador, y el flujo podría fallar por problemas con internet, problemas con el explorador, etc.&#x20;

Ya que los Webhook se entregan de servidor a servidor y se tiene una lógica de reintentos de entrega es mucho más confiable que la URL de Redirect
{% endhint %}

Un ejemplo de uso de la URL de Redirect es la página donde el usuario se redirecciona después de hacer el pago, en la que se confirma su pago y se muestra el detalle de su compra.

## Parámetros de la URL de Redirect

A continuación se detallan los parámetros que se agregan a la URL de Redirect. Estos parámetros pueden utilizarse para determinar si la transacción fue exitosa o fallida.

Es importante notar que los parámetros varían si la transacción viene de un [enlace de pago](https://docs.wompi.sv/metodos-api/enlace-de-pago) o de una transacción por [API](https://docs.wompi.sv/metodos-api/crear-transaccion-compra-3ds).

<table><thead><tr><th>Parametro</th><th width="142">Tipo Dato</th><th>Aplica para</th><th>Descripción</th></tr></thead><tbody><tr><td>idTransaccion</td><td>Cadena de 36 caracteres </td><td><ul><li>Enlace de Pago</li><li>API</li></ul></td><td>Es el identificador único de la tracción</td></tr><tr><td>monto</td><td>Decimal</td><td><p></p><ul><li>Enlace de Pago</li><li>API</li></ul></td><td>En formato #####.## (sin separador de miles y con punto para separar los decimales)</td></tr><tr><td>esReal</td><td>bool</td><td><p></p><ul><li>API</li></ul></td><td><p>Viene el texto "true" cuando la transacción es real.</p><p></p><p>Viene el texto "false" si es una transacción en un ambiente de prueba, es decir que el aplicativo asociado no es productivo y que no se hizo un cobro real.</p></td></tr><tr><td>codigoAutorizacion</td><td>Cadena de caracteres</td><td><p></p><ul><li>API</li></ul></td><td>El código de autorización de la transacción. No debería tener más de 10 caracteres.</td></tr><tr><td>mensaje</td><td>Cadena de Caracteres</td><td><p></p><ul><li>API</li></ul></td><td>Es de utilidad cuando la transacción fallo ya que allí se explica la razon del fallo, como máximo tendrá 50 caracteres.</td></tr><tr><td>formaPago</td><td>enum</td><td><ul><li>API</li></ul></td><td>Pude ser uno de los siguiente valores:<br>* PagoNormal<br>* Puntos<br>* Cuotas<br>* Bitcoin<br></td></tr><tr><td>esAprobada</td><td>bool</td><td><ul><li>API</li></ul></td><td>"true" si la transacción es exitosa.<br><br>"false" si es fallida</td></tr><tr><td>identificadorEnlaceComercio</td><td>cadena</td><td><ul><li>Enlace Pago</li></ul></td><td>Es la cadena de caracteres que se envió en el parámetro  "identificadorEnlaceComercio" al <a href="../metodos-api/enlace-de-pago">crear el enlace de pago</a></td></tr><tr><td>idEnlace</td><td>entero</td><td><ul><li>Enlace Pago</li></ul></td><td>El identificador único del enlace de pago generado internamente por Wompi</td></tr><tr><td>hash</td><td>cadena caracteres</td><td><ul><li>Enlace pago</li><li>API</li></ul></td><td>Hash HMAC para validar que ninguno de los parámetros haya sido modificado en transito.</td></tr></tbody></table>

## Como Determinar si Una Transacción es Exitosa

### Opción 1: Consultando datos de Transacción

Es posible invocar el end point del [API ](https://api.wompi.sv/index.html)"**/TransaccionCompra/{id}**" con el valor del paramero idTransaccion en el "id" de la url del end point del API.

Del objeto retornado por el API validar:

* esReal sea "true"
* esAprobada sea "true"
* Opcionalmente que la propiedad "monto" coincida con lo que se deseaba cobrar

Para la definición completa del API referirse al [Swagger](https://api.wompi.sv/).  Para entender como autenticarse en el API referirse a la [sección de autenticación](https://docs.wompi.sv/autenticacion/autenticacion).

### Opción 2: Usar solo los parámetros del URL de Redirect

En el caso de las URL Redirect de API basta con usar los parámetros de redirect para saber si la transacción es exitosa, esto es posible ya que los tres parámetros vienen en la URL:

* esReal sea "true"
* esAprobada sea "true"
* Opcionalmente que la propiedad "monto: coincida con lo que se deseaba cobrar

{% hint style="danger" %}
**Importante:** Si se usa solo los parámetros de la URL de Redirect, sin consultar el API,  para ver si la transacción es exitosa; es indispensable validar que el HASH este correcto. Si esto no se hace es posible que el usuario pagador modifique los parámetros en transito. Por ejemplo , el parámetro "esAprobada" cambiarse  de "false" a "true", generando un falso positivo.

Para ver como generar el hash y validarlo referirse  a  "[Validar Parámetros de URL Redirect](https://docs.wompi.sv/redirect-url/validar-parametros-url-redirect)"
{% endhint %}

### Ejemplos URLs de Redirect

* URL API:  <https://wompi.sv/?idTransaccion=0abac760-e642-46e0-b658-0f526957b88a&monto=10&esReal=True&formaPago=PagoNormal&esAprobada=True&codigoAutorizacion=270015&mensaje=AUTORIZADO&hash=986d4c7667bd0a9ef446dbbbb5939618c7a51f6a4860d34259a1c76f2a8f0d03>
* URL Enlace Pago: <https://wompi.sv/?identificadorEnlaceComercio=test-link&idTransaccion=d0efabed-12e0-4915-abc1-0d3689906700&idEnlace=1384854&monto=10&hash=1a658786ae50a582587183ee462c8fc63674636d82a688d4fe8c2b744fd27641>
