Saltar al contenido principal

Aceptar Pagos

Con esta API, podrás integrar un sistema de cobros en tu plataforma, facilitando pagos únicos y devoluciones.


Funcionalidades

Autenticación y Seguridad

Para acceder a la API, es necesario autenticar cada petición mediante un token, consulta Autenticación.

📌 Generar cobro a un cliente.

  • URL base: https://api-sandbox.n1co.shop
  • Método: POST
  • Endpoint: /api/v3/Charges
  • Descripción: Crear cobro.
  • Cabeceras necesarias:
  • Content-Type: application/json
  • Authorization: Bearer {your_token}
  • Ejemplo:
{
"customer": {
"id": "customer114",
"name": "Carlos Dúran",
"email": "[email protected]",
"phoneNumber": "+50364331900"
},
"order": {
"id": "EPAY001",
"amount": 200.9,
"description": "Estufa eléctrica G.E modelo JJCBS631SFSS",
"name": "Compra de cocina"
},
"cardId": "69167196381d34f25eb22e9d",
"authenticationId": null,
"billingInfo": {
"countryCode": "US",
"stateCode": "CA",
"zipCode": "10002"
},
"locationCode": "N1C0CD001"
}
Crear métodos de pago

Necesitarás de datos de tarjetas de pruebas →, esta documentación te guía a través de escenarios de prueba válidas para el ambiente sandbox.

Antes de realizar un cobro, debes crear un método de pago →. Luego de crear el método de pago se debe usar el ID en el campo cardId (Requerido).

- Parámetros de la petición

ParámetroTipoRequeridoDescripción
customerobjectInformación del cliente
customer.idstringIdentificador único del cliente
customer.namestringNombre completo del cliente
customer.emailstringEmail del cliente
customer.phoneNumberstringNúmero de teléfono con código de país
orderobjectInformación de la orden
order.idstringIdentificador único de la orden
order.amountdecimalMonto a cobrar
order.descriptionstringDescripción de la orden
order.namestringNombre de la orden
cardIdstringID del token devuelto en la tokenización
authenticationIdstringID de autenticación 3DS (null en primera petición)
billingInfoobjectCondicional*Información de facturación, puede ser null
billingInfo.countryCodestringCondicional*Código del país
billingInfo.stateCodestringCondicional*Código del estado
billingInfo.zipCodestringCondicional*Código postal
locationCodestringCódigo de la sucursal, Se obtiene desde Portal → Configuración → Sucursales → Editar → abajo del campo Teléfono
Billing Info

El objeto billingInfo es requerido únicamente cuando el país emisor de la tarjeta es USA o CAN. Puedes determinarlo a partir del código de país del BIN del método de pago.

Location Code

El locationCode lo encuentras en el portal al editar tu sucursal, justo debajo del número de teléfono. No confundir con locationId.

- Parámetros de Respuesta

ParámetroTipoDescripción
statusstringEstado del cobro (FAILED, SUCCEEDED, AUTHENTICATION_REQUIRED)
messagestringDescripción del resultado
errorobjectCódigo y mensaje de error (cuando aplica)
authenticationobjectURL e ID de autenticación 3DS (cuando aplica)
orderobjectObjeto que contiene la información de la orden de compra
createdAtobjectFecha de creación del pago

- Estados

1. FAILED (Pago Fallido)

El proceso de pago ha fallado. El nodo error contendrá los detalles.

Details
Ver ejemplo de respuesta
{
"status": "FAILED",
"message": "El pago no se pudo procesar: Necesitamos más validaciones, por favor contacta a servicio al cliente al +50324086126. Id: 1b44231a-1cfc-424d-9573-0a3a3ff756bd",
"error": {
"code": "FRAUD_PREVENT",
"message": "Necesitamos más validaciones, por favor contacta a servicio al cliente al +50324086126",
"title": "Error en la transacción",
"detail": "Necesitamos más validaciones, por favor contacta a servicio al cliente al +50324086126"
},
"authentication": null,
"order": null,
"createdAt": "2025-12-04T17:51:59.1548011Z"
}

2. SUCCEEDED (Pago Exitoso)

El proceso de pago se completó correctamente.

Details
Ver ejemplo de respuesta
{
"status": "SUCCEEDED",
"message": "El pago fue realizado exitosamente",
"error": null,
"authentication": null,
"order": {
"id": "50582",
"reference": "EPAY001",
"amount": 200.9,
"captureAmount": 200.9,
"currency": "USD",
"authorizationCode": "217982"
},
"createdAt": "2025-12-04T17:51:59.1548011Z"
}

3. AUTHENTICATION_REQUIRED (Requiere Autenticación 3DS)

Si el estado es AUTHENTICATION_REQUIRED, la API te devolverá una URL de autenticación. Debes guiar al usuario a través de este flujo (en este caso es necesario el uso de un iframe).

Guía de Autenticación 3DS

Para una guía detallada sobre cómo implementar el iframe y manejar el flujo 3DS, consulta nuestra documentación de Autenticación 3D Secure.

Details
Ver ejemplo de respuesta
{
"status": "AUTHENTICATION_REQUIRED",
"message": "El pago requiere autenticación 3DS",
"error": null,
"authentication": {
"url": "https://front-3ds.h4b.dev/authentication/9b77e558-7d5d-4fdd-b84c-f295225ba2e1?showBranding=True&lang=es",
"id": "9b77e558-7d5d-4fdd-b84c-f295225ba2e1"
},
"order": null,
"createdAt": "2025-12-04T17:51:59.1548011Z"
}

📌 Generar devolución de un cobro

  • URL base: https://api-sandbox.n1co.shop
  • Método: POST
  • Endpoint: /api/v3/Refunds
  • Descripción: Crear devolución.
  • Cabeceras necesarias:
  • Content-Type: application/json
  • Authorization: Bearer {your_token}
  • Ejemplo de respuesta:
{
"orderId": "50634",
"cancellationReason": "Producto en mal estado fue devuelto por el cliente"
}