Cash

(payProduct=03)

Proceso de pago

1、El usuario realiza un pedido en el sitio web del comerciante y elige el pago en Cash.

2、El comerciante envía una solicitud de pago en Cash a Supefina.

3、Supefina devuelve la información del URL de pago en Cash.

4、El comerciante muestra ese URL de pago al usuario.

5、El usuario realiza el pago según las indicaciones de la página.

6、Pago exitoso.

7、Supefina notifica al comerciante que el pedido ha sido exitoso.

Dirección de solicitud

Entorno
URL

SandBox

POST https://api.supefina.tech/api/supefina/transactions/payin

Producción

POST https://api.supefina.net/api/supefina/transactions/payin

Parámetros de solicitud

Encabezado de solicitud

Key
Value

Content-Type

application/json

Cuerpo de solicitud

Nombre de variable
Tipo
Obligatorio
Descripción

countryId

String

Código del país Referencia:Tabla de diccionario-Código del país Ecuador,ECU

merId

String

ID del comerciante

Ruta para obtener el ID del comerciante: Panel de comerciante Supefina - Gestión de comerciantes - Información básica - ID del comerciante

payProduct

String

Tipo de pago Cash:03

currency

String

Moneda Referencia:Tabla de diccionario-Moneda Dólar estadounidense:USD

merOrderNo

String

Número de pedido del comerciante

orderAmount

String

Monto del pedido 0>= orderAmount <= 10,000

customerEmail

String

Correo electrónico del usuario

customerName

String

Nombre del usuario

lastName

String

Apellido del usuario

customerIdentificationType

String

No

Tipos de documentos de identificación del usuario:

07: Carnet de identidad (CI)

10: Número de pasaporte (PP) (solo para Cash)

03: Identificación de pasaporte (PAS) (solo para BankTransfer)

02: Registro Único del Contribuyente (RUC)

customerIdentification

String

Número de identificación del usuario

nonceStr

String

Cadena aleatoria

La longitud no puede exceder 32 caracteres

callbackUrl

String

No

Dirección de callback

Consultar la instrucción de notificación de callback

expireTimeL

Long

No

Tiempo de expiración:

Unidad: segundos; por defecto 1 día, se recomienda que el comerciante controle el tiempo

customerPhone

String

Teléfono del usuario

checkOut

Boolean

Pasarela de pago

true: Se necesita pasarela de pago

false: No se necesita pasarela de pago

Se recomienda enviar true.

Ejemplo de solicitud

{
    "countryId": "ECU",
    "merId": "8101499116984570",
    "payProduct": "03",
    "currency": "USD",
    "merOrderNo": "devtest0005",
    "orderAmount": "200",
    "customerEmail": "[email protected]",
    "customerName": "testName",
    "lastName": "test",
    "customerIdentificationType": "07",
    "customerIdentification": "87654321",
    "nonceStr": "123",
    "sign": "R9d1Enp0XUS5YMwv0EP$blm9mWTWwyoB"
}

Parámetros de respuesta

Nombre de variable
Tipo
Descripción

code

String

Código de respuesta Referencia específica: Códigos de estado de respuesta

msg

String

Mensaje de respuesta

data

Object

Datos de respuesta

merCode

String

ID de comerciante

merOrderNo

String

Número de pedido del comerciante

supefinaOrderId

String

Número del pedido de Supefina

amount

BigDecimal

Monto del pedido

fee

String

Comisión anticipada

identifier

String

Referencia de pago

transactionStatus

String

Estado del pedido. Este estado indica si la solicitud fue exitosa, sin relación con el estado real de la transacción.

00: Pedido exitoso;

04: Pedido fallido.

url

String

Enlace de la transacción

Ejemplo de respuesta

{
    "code": "string",
    "msg": "string",
    "data": {
        "merCode": "string",
        "merOrderNo": "string",
        "supefinaOrderNo": "string",
        "amount": 0,
        "fee": 0,
        "transactionStatus": "string",
        "url": "string",
        "identifier": "string"
    }
}

Notificación de callback

Método de envío: POST

Nombre de variable
Tipo
Descripción

amount

String

Monto del pedido

countryId

String

Código del país

fee

String

Comisión anticipada

identifier

String

Referencia de pago Clabe

merId

String

ID de comerciante

merOrderId

String

Número de pedido del comerciante

msg

String

Mensaje

nonceStr

String

Cadena aleatoria

La longitud no puede exceder 32 caracteres

realityAmount

String

Monto recibido

realityFee

String

Comisión recibida

reference

String

Identificador

sign

String

Firma

status

String

Estado de la transacción

Referencia específica: Tabla de diccionario - Estado del pedido de transacción

successTime

Date

Tiempo de éxito de la transacción

supefinaOrderId

String

Número del pedido de Supefina

transactionType

String

Tipo de transacción 01:Payin 02:Payout

Ejemplo de notificación de callback

{
    "amount": "230.00",
    "countryId": "ECU",
    "customerName": "Test Name",
    "fee": "6.90",
    "identifier": "90911988431",
    "merId": "8202980903390150",
    "merOrderId": "17922853818122896811753697281175369728",
    "nonceStr": "935111b9-968e-4b3d-9036-fd1acf",
    "realityAmount": "230",
    "realityFee": "6.90",
    "reference": "90911988431",
    "sign": "69DF96903B85CD1408BD6849C62254C0",
    "status": "01",
    "successTime": 1716149235000,
    "supefinaOrderId": "202405190101010696298b1ca1141",
    "transactionType": "01"
}

Respuesta de notificación de callback

Después de que el comerciante reciba correctamente la notificación de callback, debe devolver la cadena especificada: SUCCESS. Si no se devuelve o se devuelve otro contenido, se considerará que la notificación ha fallado. Por ejemplo:

public String test(){
	return "SUCCESS";
}

Última actualización