NAV

python php javascript

API PayCode

Introducción

Bienvenido a PayCode! Podras usar los endpoints de la API de PayCode para poder generar cobros de manera rápida y sencilla.

¡Tenemos enlaces de lenguaje en Python, PHP y JavaScript! Puede ver ejemplos de código en el área oscura a la derecha y puede cambiar el lenguaje de programación de los ejemplos con las pestañas en la parte superior derecha.

Base URL

URL base
https://plataforma.paycode.com.mx

V1

Autenticación

El módulo de autenticación de la API de PayCode nos permite obtener un token el cual nos permite autenticar cada una de las peticiones futuras

La API de PayCode utiliza una autenticación basada en token para aceptar peticiones.

Si se raliza un peteción sin el token asignado simplemente fallara.

Login

import requests

url = "https://plataforma.paycode.com.mx/Api/v1/auth/loginApi"

payload = "" headers = { 'Authorization': '[API Key]' }

response = requests.request("GET", url, headers=headers, data=payload)

print(response.text)

<?php

$curl = curl_init();

curl_setopt_array($curl, array( CURLOPT_URL => 'https://plataforma.paycode.com.mx/Api/v1/auth/loginApi', CURLOPT_RETURNTRANSFER => true, CURLOPT_ENCODING => '', CURLOPT_MAXREDIRS => 10, CURLOPT_TIMEOUT => 0, CURLOPT_FOLLOWLOCATION => true, CURLOPT_HTTP_VERSION => CURL_HTTP_VERSION_1_1, CURLOPT_CUSTOMREQUEST => 'GET', CURLOPT_HTTPHEADER => array( 'Authorization: [API Key]' ), ));

$response = curl_exec($curl);

curl_close($curl); echo $response;


var axios = require('axios');
var data = '';

var config = { method: 'get', url: 'https://plataforma.paycode.com.mx/Api/v1/auth/loginApi', headers: { 'Authorization': '[API Key]' }, data : data };

axios(config) .then(function (response) { console.log(JSON.stringify(response.data)); }) .catch(function (error) { console.log(error); });

Este es un ejemplo de respuesta satisfactoria del endpoint, La respuesta del mismo esta en formato JSON.

{
    "access_token": "[token]",
    "token_type": "bearer",
    "expires_in": 300
}

Este es un ejemplo de respuesta rechazada del endpoint, La respuesta del mismo esta en formato JSON.

{
    "error": -80
}

Recupera un token tipo bearer, que permite autenticar una petición

Información de petición
Categoria Valor
Método HTTP GET
EndPoint /Api/v1/auth/loginApi
Headers
Tipo Valor
Authorization [API Key]
Esquema de entrada de la petición

El contenido del esquema debe de estar en formato JSON.

No requiere ningún esquema de entrada

Esquema de salida de una petición satisfactoria
Campo Tipo de dato Definición
access_token String Token de autenticación
token_type String Tipo de token
expires_in Int Tiempo de vida del token (Segundos)
Esquema de salida de una petición no satisfatoria
Campo Tipo de dato Definición
error String Identificador de error

Actualizar token

import requests

url = "https://plataforma.paycode.com.mx/Api/v1/token/actualizar_token"

payload = {} headers = { 'Authorization': 'Bearer [token]' }

response = requests.request("POST", url, headers=headers, data = payload)

print(response.text.encode('utf8'))

<?php

$curl = curl_init();

curl_setopt_array($curl, array( CURLOPT_URL => "https://plataforma.paycode.com.mx/Api/v1/token/actualizar_token", CURLOPT_RETURNTRANSFER => true, CURLOPT_ENCODING => "", CURLOPT_MAXREDIRS => 10, CURLOPT_TIMEOUT => 0, CURLOPT_FOLLOWLOCATION => true, CURLOPT_HTTP_VERSION => CURL_HTTP_VERSION_1_1, CURLOPT_CUSTOMREQUEST => "POST", CURLOPT_HTTPHEADER => array( "Authorization: Bearer [token]" ), ));

$response = curl_exec($curl);

curl_close($curl); echo $response;


var axios = require('axios');
var data = '';

var config = { method: 'post', url: 'https://plataforma.paycode.com.mx/Api/v1/token/actualizar_token', headers: { 'Authorization': 'Bearer [token]' }, data : data };

axios(config) .then(function (response) { console.log(JSON.stringify(response.data)); }) .catch(function (error) { console.log(error); });

Este es un ejemplo de respuesta satisfactoria del endpoint, La respuesta del mismo esta en formato JSON.

{
    "access_token": "[token]",
    "token_type": "bearer",
    "expires_in": 300
}

Este es un ejemplo de respuesta rechazada del endpoint, La respuesta del mismo esta en formato JSON.

{
    "error": -80
}

Recupera un token nuevo usando el token actual, siempre y cuando no haya expirado.

Información de petición
Categoria Valor
Método HTTP POST
EndPoint Api/v1/token/actualizar_token
Headers
Tipo Valor
Authorization Bearer [token]
Content-Type application/json
Esquema de entrada de la petición

No requiere ningún esquema de entrada

Esquema de salida de una petición satisfactoria
Campo Tipo de dato Definición
access_token String Token de autenticación
token_type String Tipo de token
expires_in Int Tiempo de vida del token (Segundos)
Esquema de salida de una petición no satisfatoria
Campo Tipo de dato Definición
error String Identificador de error

Logout

import requests

url = "https://plataforma.paycode.com.mx/Api/v1/auth/logoutApi"

payload = {} headers = { 'Authorization': 'Bearer [token]' }

response = requests.request("POST", url, headers=headers, data = payload)

print(response.text.encode('utf8'))

<?php

$curl = curl_init();

curl_setopt_array($curl, array( CURLOPT_URL => "https://plataforma.paycode.com.mx/Api/v1/auth/logoutApi", CURLOPT_RETURNTRANSFER => true, CURLOPT_ENCODING => "", CURLOPT_MAXREDIRS => 10, CURLOPT_TIMEOUT => 0, CURLOPT_FOLLOWLOCATION => true, CURLOPT_HTTP_VERSION => CURL_HTTP_VERSION_1_1, CURLOPT_CUSTOMREQUEST => "POST", CURLOPT_HTTPHEADER => array( "Authorization: Bearer [token]" ), ));

$response = curl_exec($curl);

curl_close($curl); echo $response;


var axios = require('axios');
var data = '';

var config = { method: 'post', url: 'https://plataforma.paycode.com.mx/Api/v1/auth/logoutApi', headers: { 'Authorization': 'Bearer [token]' }, data : data };

axios(config) .then(function (response) { console.log(JSON.stringify(response.data)); }) .catch(function (error) { console.log(error); });

Este es un ejemplo de respuesta satisfactoria del endpoint, La respuesta del mismo esta en formato JSON.

{
    "message": "Successfully logged out"
}

Este es un ejemplo de respuesta rechazada del endpoint, La respuesta del mismo esta en formato JSON.

{
    "error": -80
}

El token recuperado es mandado a un lista negra imposibilitándolo para generar nuevas peticiones.

Información de petición
Categoria Valor
Método HTTP POST
EndPoint Api/v1/auth/logoutApi
Headers
Tipo Valor
Authorization Bearer [token]
Content-Type application/json
Esquema de entrada de la petición

No requiere ningún esquema de entrada

Esquema de salida de una petición satisfactoria
Campo Tipo de dato Definición
message String Mensaje de salida
Esquema de salida de una petición no satisfatoria
Campo Tipo de dato Definición
error String Identificador de error

Cobros

Las siguientes URL nos permiten hacer cobros de manera única, recurrente y masiva de manera rápida y sencilla

Pago único

import requests
import json

url = "https://plataforma.paycode.com.mx/Api/v1/pagos/pago_unico"

payload = json.dumps({ "numero_tel": 5555555555, "name": "XXXXXXX", "lastname_pa": "XXXXX", "lastname_mo": "XXXXXX", "mont": 1, "concept": "XXXXXX", "limit_da": "2021-10-21 16:10:10" }) headers = { 'Authorization': 'Bearer [token]', 'Content-Type': 'application/json' }

response = requests.request("POST", url, headers=headers, data=payload)

print(response.text)

<?php

$curl = curl_init();

curl_setopt_array($curl, array( CURLOPT_URL => 'https://plataforma.paycode.com.mx/Api/v1/pagos/pago_unico', CURLOPT_RETURNTRANSFER => true, CURLOPT_ENCODING => '', CURLOPT_MAXREDIRS => 10, CURLOPT_TIMEOUT => 0, CURLOPT_FOLLOWLOCATION => true, CURLOPT_HTTP_VERSION => CURL_HTTP_VERSION_1_1, CURLOPT_CUSTOMREQUEST => 'POST', CURLOPT_POSTFIELDS =>'{ "numero_tel": 5555555555, "name": "XXXXXXX", "lastname_pa": "XXXXX", "lastname_mo": "XXXXXX", "mont": 1, "concept" : "XXXXXX", "limit_da": "2021-10-21 16:10:10" } ', CURLOPT_HTTPHEADER => array( 'Authorization: Bearer [token]', 'Content-Type: application/json' ), ));

$response = curl_exec($curl);

curl_close($curl); echo $response;

var axios = require('axios');
var data = JSON.Stringify({
  "numero_tel": 5555555555,
  "name": "XXXXXXX",
  "lastname_pa": "XXXXX",
  "lastname_mo": "XXXXXX",
  "mont": 1,
  "concept": "XXXXXX",
  "limit_da": "2021-10-21 16:10:10"
});

var config = { method: 'post', url: 'https://plataforma.paycode.com.mx/Api/v1/pagos/pago_unico', headers: { 'Authorization': 'Bearer [token]', 'Content-Type': 'application/json' }, data : data };

axios(config) .then(function (response) { console.log(JSON.Stringify(response.data)); }) .catch(function (error) { console.log(error); });

Este es un ejemplo de respuesta satisfactoria del endpoint, La respuesta del mismo esta en formato JSON.

{ 
  "success": true,
    "data": {
        "telefono": "XXXXXXXXXX",
        "concepto": "XXXXXX",
        "codigo_rastreo": "XXXXXXXX"
    }
}

Este es un ejemplo de respuesta rechazada del endpoint, La respuesta del mismo esta en formato JSON.

{
    "error": "-80", 
}

Cree un pago con un cargo único con el cual el cliente podrá aceptar, posponer o rechazar a través de CoDi, El número telefónico debe estar previamente registrado ante CoDi.

Informacion de peticion
Categoria Valor
Método HTTP POST
EndPoint /Api/v1/pagos/pago_unico
Headers
Tipo Valor
Authorization Bearer [token]
Content-Type application/json
Esquema de entrada de la petición

El contenido del esquema debe estar en formato JSON.

Campo Tipo de dato Requerido Definición
numero_tel Integer True Número telefónico del cliente (debe de estar dado de alta en CoDi)
name String True Nombre del cliente
lastname_pa String True Apellido paterno del cliente
lastname_mo String True Apellido materno del cliente
mont Float True Monto del cargo
concept String True Concepto del cobro menor a 40 caracteres
limit_da String True Fecha límite del pago, minimo 3 minutos, maximo 30 días
Esquema de salida de una petición satisfactoria
Campo Tipo de dato Definición
success Boolean Respuesta de la petición
data Object Objeto con Información del cobro
data.telefono String Telefóno al que se genero el cobro
data.concepto String Concepto por el que se realizó el cobro
data.codigo_rastreo String Identificador del cobro, el cual no servira para rastrear el estatus del mismo
Esquema de salida de una petición no satisfatoria
Campo Tipo de dato Definición
error String Identificador de error

Pago recurrente

import requests
import json

url = "https://plataforma.paycode.com.mx/Api/v1/pagos/pago_recurrente"

payload = json.dumps({ "numero_tel": 5555555555, "name": "XXXXXXXXX", "lastname_pa": "XXXXXXXXX", "lastname_mo": "XXXXXXXXX", "mont": 1, "concept": "XXXXXXXXX", "limit_da": "2021-10-16 16:10:10", "date_pay": "Mensual" }) headers = { 'Authorization': 'Bearer [token]', 'Content-Type': 'application/json' }

response = requests.request("POST", url, headers=headers, data=payload)

print(response.text)

<?php

$curl = curl_init();

curl_setopt_array($curl, array( CURLOPT_URL => 'https://plataforma.paycode.com.mx/Api/v1/pagos/pago_recurrente', CURLOPT_RETURNTRANSFER => true, CURLOPT_ENCODING => '', CURLOPT_MAXREDIRS => 10, CURLOPT_TIMEOUT => 0, CURLOPT_FOLLOWLOCATION => true, CURLOPT_HTTP_VERSION => CURL_HTTP_VERSION_1_1, CURLOPT_CUSTOMREQUEST => 'POST', CURLOPT_POSTFIELDS =>'{ "numero_tel": 5555555555, "name": "XXXXXXXXX", "lastname_pa": "XXXXXXXXX", "lastname_mo": "XXXXXXXXX", "mont": 1, "concept" : "XXXXXXXXX", "limit_da": "2021-10-16 16:10:10", "date_pay": "Mensual" }

', CURLOPT_HTTPHEADER => array( 'Authorization: Bearer [token]', 'Content-Type: application/json' ), ));

$response = curl_exec($curl);

curl_close($curl); echo $response;

var axios = require('axios');
var data = JSON.Stringify({
  "numero_tel": 5555555555,
  "name": "XXXXXXXXX",
  "lastname_pa": "XXXXXXXXX",
  "lastname_mo": "XXXXXXXXX",
  "mont": 1,
  "concept": "XXXXXXXXX",
  "limit_da": "2021-10-16 16:10:10",
  "date_pay": "Mensual"
});

var config = { method: 'post', url: 'https://plataforma.paycode.com.mx/Api/v1/pagos/pago_recurrente', headers: { 'Authorization': 'Bearer [token]', 'Content-Type': 'application/json' }, data : data };

axios(config) .then(function (response) { console.log(JSON.Stringify(response.data)); }) .catch(function (error) { console.log(error); });

Este es un ejemplo de respuesta satisfactoria del endpoint, La respuesta del mismo esta en formato JSON.

{
    "status": "exitoso"
}

Este es un ejemplo de respuesta rechazada del endpoint, La respuesta del mismo esta en formato JSON.

{
    "error": "-80", 
}

Cree un pago con un cargo recurrente con el cual el cliente podra aceptar, posponer o rechazar a traves de CoDi.

Informacion de peticion
Categoria Valor
Método HTTP POST
EndPoint Api/v1/pagos/pago_recurrente
Headers
Tipo Valor
Authorization Bearer [token]
Content-Type application/json
Esquema de entrada de la petición

El contenido del esquema debe estar en formato JSON.

Campo Tipo de dato Requerido Definición
numero_tel Integer True Número telefónico del cliente (debe de estar dado de alta en CoDi)
name String True Nombre del cliente
lastname_pa String True Apellido paterno del cliente
lastname_mo String True Apellido materno del cliente
mont Float True Monto del cargo
concept String True Concepto del cobro menor a 40 caracteres
limit_da String True Fecha límite del pago, minimo 3 minutos, maximo 30 días
date_pay String True Recurrencia del pago [Anual,Bimestral,Cuatrimestral,Horas,Mensual,Quincenal,Semanal,Semestral,Trimestral,Unico]
Esquema de salida de una petición satisfactoria
Campo Tipo de dato Definición
success Boolean Respuesta de la petición
Esquema de salida de una petición no satisfatoria
Campo Tipo de dato Definición
error String Identificador de error

Pagos masivos

import requests
import json

url = "https://plataforma.paycode.com.mx/Api/v1/pagos/pagos_masivos"

payload = json.dumps({ "data": [ { "numero_tel": 5555555555, "name": "XXXXXXXXXXXXXXX", "lastname_pa": "XXXXXXXXXXXXXXX ", "lastname_mo": "XXXXXXXXXXXXXXX", "mont": 1, "concept": "XXXXXXXXXXXXXXX ", "limit_da": "2022-10-20 16:10:10" }, { "numero_tel": 5555555555, "name": "XXXXXXXXXXXXXXX", "lastname_pa": "XXXXXXXXXXXXXXX ", "lastname_mo": "XXXXXXXXXXXXXXX", "mont": 1, "concept": "XXXXXXXXXXXXXXX ", "limit_da": "2022-10-20 16:10:10" } ] }) headers = { 'Authorization': 'Bearer [token]', 'Content-Type': 'application/json' }

response = requests.request("POST", url, headers=headers, data=payload)

print(response.text)

<?php

$curl = curl_init();

curl_setopt_array($curl, array( CURLOPT_URL => 'https://plataforma.paycode.com.mx/Api/v1/pagos/pagos_masivos', CURLOPT_RETURNTRANSFER => true, CURLOPT_ENCODING => '', CURLOPT_MAXREDIRS => 10, CURLOPT_TIMEOUT => 0, CURLOPT_FOLLOWLOCATION => true, CURLOPT_HTTP_VERSION => CURL_HTTP_VERSION_1_1, CURLOPT_CUSTOMREQUEST => 'POST', CURLOPT_POSTFIELDS =>'{ "data":[ { "numero_tel": 5555555555, "name": "XXXXXXXXXXXXXXX", "lastname_pa": "XXXXXXXXXXXXXXX ", "lastname_mo": "XXXXXXXXXXXXXXX", "mont": 1, "concept" : "XXXXXXXXXXXXXXX ", "limit_da": "2022-10-20 16:10:10" }, { "numero_tel": 5555555555, "name": "XXXXXXXXXXXXXXX", "lastname_pa": "XXXXXXXXXXXXXXX ", "lastname_mo": "XXXXXXXXXXXXXXX", "mont": 1, "concept" : "XXXXXXXXXXXXXXX ", "limit_da": "2022-10-20 16:10:10" }
] } '
, CURLOPT_HTTPHEADER => array( 'Authorization: Bearer [token]', 'Content-Type: application/json' ), ));

$response = curl_exec($curl);

curl_close($curl); echo $response;

var axios = require('axios');
var data = JSON.Stringify({
  "data": [
    {
      "numero_tel": 5555555555,
      "name": "XXXXXXXXXXXXXXX",
      "lastname_pa": "XXXXXXXXXXXXXXX ",
      "lastname_mo": "XXXXXXXXXXXXXXX",
      "mont": 1,
      "concept": "XXXXXXXXXXXXXXX ",
      "limit_da": "2022-10-20 16:10:10"
    },
    {
      "numero_tel": 5555555555,
      "name": "XXXXXXXXXXXXXXX",
      "lastname_pa": "XXXXXXXXXXXXXXX ",
      "lastname_mo": "XXXXXXXXXXXXXXX",
      "mont": 1,
      "concept": "XXXXXXXXXXXXXXX ",
      "limit_da": "2022-10-20 16:10:10"
    }
  ]
});

var config = { method: 'post', url: 'https://plataforma.paycode.com.mx/Api/v1/pagos/pagos_masivos', headers: { 'Authorization': 'Bearer [token]', 'Content-Type': 'application/json' }, data : data };

axios(config) .then(function (response) { console.log(JSON.Stringify(response.data)); }) .catch(function (error) { console.log(error); });

Este es un ejemplo de respuesta satisfactoria del endpoint, La respuesta del mismo esta en formato JSON.

{
    "success": true,
    "estatus": [
        {
            "success": true,
            "data": [
                {
                    "success": true,
                    "data": {
                        "telefono": "5555555555",
                        "concepto": "XXXXXXXXX",
                        "codigo_rastreo": "XXXXXXXXX"
                    }
                }
            ]
        },
        {
            "success": true,
            "data": [
                {
                    "success": true,
                    "data": {
                        "telefono": "5555555555",
                        "concepto": "XXXXXXXXX",
                        "codigo_rastreo": "XXXXXXXXX"
                    }
                }
            ]
        }
    ]
}

Este es un ejemplo de respuesta rechazada del endpoint, La respuesta del mismo esta en formato JSON.

{
    "error": "-80", 
}

Cree un objeto de cobros para generar múltiples cobros, los clientes podrán aceptar, posponer o rechazar a través de CoDi.

Informacion de peticion
Categoria Valor
Método HTTP POST
EndPoint /Api/v1/pagos/pagos_masivos
Headers
Tipo Valor
Authorization Bearer [token]
Content-Type application/json
Esquema de entrada de la petición

El contenido del esquema debe estar en formato JSON.

Campo Tipo de dato Requerido Definición
data Array True Arreglo que contendra la infromación de los clientes a los que se genera el cobro
data.x.numero_tel Integer True Número telefónico del cliente (debe de estar dado de alta en CoDi)
data.x.name String True Nombre del cliente
data.x.lastname_pa String True Apellido paterno del cliente
data.x.lastname_mo String True Apellido materno del cliente
data.x.mont Float True Monto del cargo
data.x.concept Integer True Concepto del cobro menor a 40 caracteres
data.x.limit_da Integer True Fecha límite del pago, minimo 3 minutos, maximo 30 días
Esquema de salida de una petición satisfactoria
Campo Tipo de dato Definición
success Boolean Respuesta de la peteción
estatus Array Arreglo con las respuestas de cada cobro
estatus.x.success Boolean Respuesta del cobro
estatus.x.data.success Boolean Respuesta del cobro
estatus.x.data.data Boolean Respuesta del cobro
estatus.x.data.data.telefono String Telefóno al que se genero el cobro
estatus.x.data.data.concepto String Concepto por el que se realizó el cobro
estatus.x.data.data.codigo_rastreo String Identificador del cobro, el cual no servira para rastrear el estatus del mismo
Esquema de salida de una petición no satisfatoria
Campo Tipo de dato Definición
error String Identificador de error

Consulta de estatus de cobro

import requests
import json

url = "https://plataforma.paycode.com.mx/Api/v1/pagos/consultar_estatus"

payload = json.dumps({ "codigoRastreo": 'XXXXXXXX' }) headers = { 'Authorization': 'Bearer [token]', 'Content-Type': 'application/json' }

response = requests.request("POST", url, headers=headers, data=payload)

print(response.text)

$curl = curl_init();

curl_setopt_array($curl, array( CURLOPT_URL => 'https://plataforma.paycode.com.mx/Api/v1/pagos/consultar_estatus', CURLOPT_RETURNTRANSFER => true, CURLOPT_ENCODING => '', CURLOPT_MAXREDIRS => 10, CURLOPT_TIMEOUT => 0, CURLOPT_FOLLOWLOCATION => true, CURLOPT_HTTP_VERSION => CURL_HTTP_VERSION_1_1, CURLOPT_CUSTOMREQUEST => 'POST', CURLOPT_POSTFIELDS =>'{ "codigoRastreo":'XXXXXXXX' }', CURLOPT_HTTPHEADER => array( 'Authorization: Bearer [token]', 'Content-Type: application/json' ), ));

$response = curl_exec($curl);

curl_close($curl); echo $response;


var axios = require('axios');
var data = JSON.Stringify({
  "codigoRastreo": 'XXXXXXXX'
});

var config = { method: 'post', url: 'https://plataforma.paycode.com.mx/Api/v1/pagos/consultar_estatus', headers: { 'Authorization': '[token]', 'Content-Type': 'application/json' }, data : data };

axios(config) .then(function (response) { console.log(JSON.Stringify(response.data)); }) .catch(function (error) { console.log(error); });

Este es un ejemplo de respuesta satisfactoria del endpoint, La respuesta del mismo esta en formato JSON.

{
    "success": true,
    "data": {
        "estatus": "Rechazado",
        "ultima_actualizacion": "2021-02-12 09:52:35"
    }
}

Este es un ejemplo de respuesta rechazada del endpoint, La respuesta del mismo esta en formato JSON.

{
    "error": "-80", 
}

Cree un objeto de rastreo para generar un consulta de estatus de cobro, los clientes podrán consultar el estatus del cobro enviado a traves de un código de rastreo.

Información de petición
Categoria Valor
Método HTTP POST
EndPoint /Api/v1/pagos/consultar_estatus
Headers
Tipo Valor
Authorization Bearer [token]
Content-Type application/json
Esquema de entrada de la petición
Campo Tipo de dato Requerido Definición
clave_rastreo String True Identificador de hasta 20 posiciones alfanuméricas que la institución le proporciona al usuario al momento en que se instruye el pago.
Esquema de salida de una petición satisfactoria
Campo Tipo de dato Definición
status String Estatus de la petición
data Object Objeto con que contiene el estatus actual del objeto y su ultima fecha de actulización
data.estatus Strig Estado actual del del cobro push
data.ultima_actualizacion Strig Fecha con de la ultima transacción del cobro push
Esquema de salida de una petición no satisfatoria
Campo Tipo de dato Definición
error String Identificador de error

Cobros por codigo QR

El módulo de códigos QR nos permite integrar códigos QR de manera sencilla.

Crear codigo QR

import requests
import json

url = "https://plataforma.paycode.com.mx/Api/v1/qr/crear_qr"

payload = json.dumps({ "mont": 1, "concept": "XXXXXXX", "limit_da": "2021-06-19 11:44:22", "type": 0, "reference": 7000003 }) headers = { 'Authorization': 'Bearer [token]', 'Content-Type': 'application/json' }

response = requests.request("POST", url, headers=headers, data=payload)

print(response.text)


<?php

$curl = curl_init();

curl_setopt_array($curl, array( CURLOPT_URL => 'https://plataforma.paycode.com.mx/Api/v1/qr/crear_qr', CURLOPT_RETURNTRANSFER => true, CURLOPT_ENCODING => '', CURLOPT_MAXREDIRS => 10, CURLOPT_TIMEOUT => 0, CURLOPT_FOLLOWLOCATION => true, CURLOPT_HTTP_VERSION => CURL_HTTP_VERSION_1_1, CURLOPT_CUSTOMREQUEST => 'POST', CURLOPT_POSTFIELDS =>'{ "mont": 1, "concept": "XXXXXXX", "limit_da": "2021-06-19 11:44:22", "type": 0, "reference": 7000003 }', CURLOPT_HTTPHEADER => array( 'Authorization: Bearer [token]', 'Content-Type: application/json' ), ));

$response = curl_exec($curl);

curl_close($curl); echo $response;


var axios = require('axios');
var data = JSON.stringify({
  "mont": 1,
  "concept": "XXXXXXX",
  "limit_da": "2021-06-19 11:44:22",
  "type": 0,
  "reference": 7000003
});

var config = { method: 'post', url: 'https://plataforma.paycode.com.mx/Api/v1/qr/crear_qr', headers: { 'Authorization': 'Bearer [token]', 'Content-Type': 'application/json' }, data : data };

axios(config) .then(function (response) { console.log(JSON.stringify(response.data)); }) .catch(function (error) { console.log(error); });

Este es un ejemplo de respuesta satisfactoria del endpoint, La respuesta del mismo esta en formato JSON.

{
    "status": "exitoso",
    "json_pago": "",
    "clave_rastreo": "XXXXXXX",
    "ref_pago": "XXXXXXX",
    "empresa_cobra": "XXXXXX"
}

Este es un ejemplo de respuesta rechazada del endpoint, La respuesta del mismo esta en formato JSON.

{
    "error": "-80", 
}

Recupera un objeto QR el cual nos permitirá poder hacer el renderizado de un código QR de manera sencilla usando base64, los códigos QR cuentan con una vida util de 3 minutos como minimo y como maximo de 30 días, si el código QR no se encuentra en este rango sera ilegible.

Ejemplo:

<img alt="" src="data:image/png;base64, infromación del QR">

Es recomendable almacenar el valor clave_rastreo al momento de enviar el estatus de cada código QR.

Información de petición
Categoria Valor
Método HTTP POST
EndPoint /Api/v1/qr/crear_qr
Headers
Tipo Valor
Authorization Bearer [token]
Content-Type application/json
Esquema de entrada de la petición
Campo Tipo de dato Requerido Definición
mont float True Monto del cargo
concept String True Concepto del cobro menor a 40 caracteres
concept String True Motivo del cargo
limit_da String True Fecha límite del pago, minimo 3 minutos, maximo 30 días
reference Int True Número de identificación de hasta siete posiciones que el usuario selecciona al momento de instruir su pago
type Int True Tipo de cobro [1=>Unico, 2=>Recurrente]
Esquema de salida de una petición satisfactoria
Campo Tipo de dato Definición
status String Estatus de la petición
json_pago String Cadena con el contenido para poder hacer el render de una imagen base64
clave_rastreo Strig Identificador de hasta 20 posiciones alfanuméricas que la institución le proporciona al usuario al momento en que se instruye el pago
ref_pago Strig Identificador del pago
empresa_cobra Strig Razón social de la empresa que cobra
Esquema de salida de una petición no satisfatoria
Campo Tipo de dato Definición
error String identificador de error

Actualizar código QR

import requests
import json

url = "https://plataforma.paycode.com.mx/Api/v1/qr/refrescar_qr"

payload = json.dumps({ "clave_rastro": "XXXXXXXXX", "ref_pag": "XXXXXXXXX" }) headers = { 'Authorization': 'Bearer [token]', 'Content-Type': 'application/json' }

response = requests.request("POST", url, headers=headers, data=payload)

print(response.text)

<?php

$curl = curl_init();

curl_setopt_array($curl, array( CURLOPT_URL => 'https://plataforma.paycode.com.mx/Api/v1/qr/refrescar_qr', CURLOPT_RETURNTRANSFER => true, CURLOPT_ENCODING => '', CURLOPT_MAXREDIRS => 10, CURLOPT_TIMEOUT => 0, CURLOPT_FOLLOWLOCATION => true, CURLOPT_HTTP_VERSION => CURL_HTTP_VERSION_1_1, CURLOPT_CUSTOMREQUEST => 'POST', CURLOPT_POSTFIELDS =>' {"clave_rastro":"XXXXXX","ref_pag":"XXXXXX" }', CURLOPT_HTTPHEADER => array( 'Authorization: Bearer [token]', 'Content-Type: application/json' ), ));

$response = curl_exec($curl);

curl_close($curl); echo $response;


var axios = require('axios');
var data = JSON.stringify({
  "clave_rastro": "XXXXXXX",
  "ref_pag": "XXXXXXX"
});

var config = { method: 'post', url: 'https://plataforma.paycode.com.mx/Api/v1/qr/refrescar_qr', headers: { 'Authorization': 'Bearer [token]', 'Content-Type': 'application/json' }, data : data };

axios(config) .then(function (response) { console.log(JSON.stringify(response.data)); }) .catch(function (error) { console.log(error); });

Este es un ejemplo de respuesta satisfactoria del endpoint, La respuesta del mismo esta en formato JSON.

{
    "status": "exitoso",
    "json_pago": "",
    "clave_rastreo": "XXXXXXX",
    "ref_pago": "XXXXXXX",
    "empresa_cobra": "XXXXXX"
}

Este es un ejemplo de respuesta rechazada del endpoint, La respuesta del mismo esta en formato JSON.

{
    "error": "-80", 
}

Recupera objeto refrescar QR, el cual nos va a permitir generar un nuevo codigo QR pasando como parametros la clave de rastreo y la referencia de pago.

Información de petición
Categoria Valor
Método HTTP POST
EndPoint Api/v1/qr/refrescar_qr
Headers
Tipo Valor
Authorization Bearer [token]
Content-Type application/json
Esquema de entrada de la petición
Campo Tipo de dato Definición
clave_rastreo String Identificador de hasta 20 posiciones alfanuméricas que la institución le proporciona al usuario al momento en que se instruye el pago.
ref_pago String Identificador del pago
Esquema de salida de una petición satisfactoria
Campo Tipo de dato Definición
status String Estatus de la petición
json_pago String Cadena con el contenido para poder hacer el render de una imagen base64
clave_rastreo Strig Identificador de hasta 20 posiciones alfanuméricas que la institución le proporciona al usuario al momento en que se instruye el pago
ref_pago Strig Identificador del pago
empresa_cobra Strig Razón social de la empresa que cobra
Esquema de salida de una petición no satisfatoria
Campo Tipo de dato Definición
error String identificador de error

Obtener estatus de código QR

import requests
import json

url = "https://plataforma.paycode.com.mx/Api/v1/qr/consultar_estatus"

payload = json.dumps({ "claveRastreo": "XXXXXXXXX" }) headers = { 'Authorization': 'Bearer [token]', 'Content-Type': 'application/json' }

response = requests.request("POST", url, headers=headers, data=payload)

print(response.text)

<?php

$curl = curl_init();

curl_setopt_array($curl, array( CURLOPT_URL => 'https://plataforma.paycode.com.mx/Api/v1/qr/consultar_estatus', CURLOPT_RETURNTRANSFER => true, CURLOPT_ENCODING => '', CURLOPT_MAXREDIRS => 10, CURLOPT_TIMEOUT => 0, CURLOPT_FOLLOWLOCATION => true, CURLOPT_HTTP_VERSION => CURL_HTTP_VERSION_1_1, CURLOPT_CUSTOMREQUEST => 'POST', CURLOPT_POSTFIELDS =>'{ "claveRastreo":"XXXXXXXXX" }', CURLOPT_HTTPHEADER => array( 'Authorization: Bearer [token]', 'Content-Type: application/json' ), ));

$response = curl_exec($curl);

curl_close($curl); echo $response;


var axios = require('axios');
var data = JSON.stringify({
  "claveRastreo": "XXXXXXXX"
});

var config = { method: 'post', url: 'https://plataforma.paycode.com.mx/Api/v1/qr/consultar_estatus', headers: { 'Authorization': 'Bearer [token]', 'Content-Type': 'application/json' }, data : data };

axios(config) .then(function (response) { console.log(JSON.stringify(response.data)); }) .catch(function (error) { console.log(error); });

Este es un ejemplo de respuesta satisfactoria del endpoint, La respuesta del mismo esta en formato JSON.

{
    "success": true,
    "data": {
        "estatus": "Rechazado",
        "ultima_actualizacion": "2021-02-12 09:52:35"
    }
}

Este es un ejemplo de respuesta rechazada del endpoint, La respuesta del mismo esta en formato JSON.

{
    "error": "-80", 
}

Recupera objeto refrescar QR, el cual nos va a permitir generar un nuevo codigo QR pasando como parametros la clave de rastreo y la referencia de pago.

Información de petición
Categoria Valor
Método HTTP POST
EndPoint Api/v1/qr/consultar_estatus
Headers
Tipo Valor
Authorization Bearer [token]
Content-Type application/json
Esquema de entrada de la petición

El contenido del esquema debe de estar en formato JSON.

Campo Tipo de dato Requerido Definición
clave_rastreo String True Identificador de hasta 20 posiciones alfanuméricas que la institución le proporciona al usuario al momento en que se instruye el pago.
Esquema de salida de una petición satisfactoria
Campo Tipo de dato Definición
status String Estatus de la petición
data Object Objeto con que contiene el estatus actual del objeto y su ultima fecha de actulización
data.estatus Strig Estado actual del último escaneo del código QR
data.ultima_actualizacion Strig Fecha con de la ultima transacción del código QR
Esquema de salida de una petición no satisfatoria
Campo Tipo de dato Definición
error String identificador de error

V2

Autenticación versión 2

El módulo de autenticación de la API de PayCode nos permite obtener un token el cual nos permite autenticar cada una de las peticiones futuras

La API de PayCode utiliza una autenticación basada en token para aceptar peticiones.

Si se raliza un peteción sin el token asignado simplemente fallara.

Login v2

import requests

url = "https://plataforma.paycode.com.mx/Api/v2/auth/login"

payload = ""
headers = {
  'Authorization': '[API Key]'
}

response = requests.request("GET", url, headers=headers, data=payload)

print(response.text)

<?php
$curl = curl_init();

curl_setopt_array($curl, array(
  CURLOPT_URL => 'https://plataforma.paycode.com.mx/Api/v2/auth/login',
  CURLOPT_RETURNTRANSFER => true,
  CURLOPT_ENCODING => '',
  CURLOPT_MAXREDIRS => 10,
  CURLOPT_TIMEOUT => 0,
  CURLOPT_FOLLOWLOCATION => true,
  CURLOPT_HTTP_VERSION => CURL_HTTP_VERSION_1_1,
  CURLOPT_CUSTOMREQUEST => 'GET',
  CURLOPT_HTTPHEADER => array(
    'Authorization: [API Key]'
  ),
));

$response = curl_exec($curl);

curl_close($curl);
echo $response;



var axios = require('axios');
var data = '';

var config = {
  method: 'get',
  url: 'https://plataforma.paycode.com.mx/Api/v2/auth/login',
  headers: { 
    'Authorization': '[API Key]'
  },
  data : data
};

axios(config)
.then(function (response) {
  console.log(JSON.stringify(response.data));
})
.catch(function (error) {
  console.log(error);
});


Este es un ejemplo de respuesta satisfactoria del endpoint, La respuesta del mismo esta en formato JSON.

{
    "access_token": "[token]",
    "token_type": "bearer",
    "expires_in": 300
}

Este es un ejemplo de respuesta rechazada del endpoint, La respuesta del mismo esta en formato JSON.

{
    "error": -80
}

Recupera un token tipo bearer, que permite autenticar una petición

Información de petición
Categoria Valor
Método HTTP GET
EndPoint /Api/v2/auth/login
Headers
Tipo Valor
Authorization [API Key]
Esquema de entrada de la petición

El contenido del esquema debe de estar en formato JSON.

No requiere ningún esquema de entrada

Esquema de salida de una petición satisfactoria
Campo Tipo de dato Definición
access_token String Token de autenticación
token_type String Tipo de token
expires_in Int Tiempo de vida del token
Esquema de salida de una petición no satisfatoria
Campo Tipo de dato Definición
error String Identificador de error

Actualizar token v2

import requests

url = "https://plataforma.paycode.com.mx/Api/v2/token/actualizar_token"

payload  = {}
headers = {
  'Authorization': 'Bearer [token]'
}

response = requests.request("POST", url, headers=headers, data = payload)

print(response.text.encode('utf8'))


<?php

$curl = curl_init();

curl_setopt_array($curl, array(
  CURLOPT_URL => "https://plataforma.paycode.com.mx/Api/v2/token/actualizar_token",
  CURLOPT_RETURNTRANSFER => true,
  CURLOPT_ENCODING => "",
  CURLOPT_MAXREDIRS => 10,
  CURLOPT_TIMEOUT => 0,
  CURLOPT_FOLLOWLOCATION => true,
  CURLOPT_HTTP_VERSION => CURL_HTTP_VERSION_1_1,
  CURLOPT_CUSTOMREQUEST => "POST",
  CURLOPT_HTTPHEADER => array(
    "Authorization: Bearer [token]"
  ),
));

$response = curl_exec($curl);

curl_close($curl);
echo $response;


var axios = require('axios');
var data = '';

var config = {
  method: 'post',
  url: 'https://plataforma.paycode.com.mx/Api/v2/token/actualizar_token',
  headers: { 
    'Authorization': 'Bearer [token]'
  },
  data : data
};

axios(config)
.then(function (response) {
  console.log(JSON.stringify(response.data));
})
.catch(function (error) {
  console.log(error);
});



Este es un ejemplo de respuesta satisfactoria del endpoint, La respuesta del mismo esta en formato JSON.

{
    "access_token": "[token]",
    "token_type": "bearer",
    "expires_in": 300
}

Este es un ejemplo de respuesta rechazada del endpoint, La respuesta del mismo esta en formato JSON.

{
    "error": -80
}

Recupera un token nuevo usando el token actual, siempre y cuando no se halla expirado.

Información de petición
Categoria Valor
Método HTTP POST
EndPoint Api/v2/token/actualizar_token
Headers
Tipo Valor
Authorization Bearer [token]
Content-Type application/json
Esquema de entrada de la petición

No requiere ningún esquema de entrada

Esquema de salida de una petición satisfactoria
Campo Tipo de dato Definición
access_token String Token de autenticación
token_type String Tipo de token
expires_in Int Tiempo de vida del token (Segundos)
Esquema de salida de una petición no satisfatoria
Campo Tipo de dato Definición
error String Identificador de error

Logout v2

import requests

url = "https://plataforma.paycode.com.mx/Api/v2/auth/logout"

payload = ""
headers = {
  'Authorization': 'Bearer  [token]'
}

response = requests.request("GET", url, headers=headers, data=payload)

print(response.text)

<?php

<?php

$curl = curl_init();

curl_setopt_array($curl, array(
  CURLOPT_URL => 'https://plataforma.paycode.com.mx/Api/v2/auth/logout',
  CURLOPT_RETURNTRANSFER => true,
  CURLOPT_ENCODING => '',
  CURLOPT_MAXREDIRS => 10,
  CURLOPT_TIMEOUT => 0,
  CURLOPT_FOLLOWLOCATION => true,
  CURLOPT_HTTP_VERSION => CURL_HTTP_VERSION_1_1,
  CURLOPT_CUSTOMREQUEST => 'GET',
  CURLOPT_HTTPHEADER => array(
    'Authorization: Bearer [token]'
  ),
));

$response = curl_exec($curl);

curl_close($curl);
echo $response;




var axios = require('axios');
var data = '';

var config = {
  method: 'get',
  url: 'https://plataforma.paycode.com.mx/Api/v2/auth/logout',
  headers: { 
    'Authorization': 'Bearer [token]'
  },
  data : data
};

axios(config)
.then(function (response) {
  console.log(JSON.stringify(response.data));
})
.catch(function (error) {
  console.log(error);
});



Este es un ejemplo de respuesta satisfactoria del endpoint, La respuesta del mismo esta en formato JSON.

{
    "message": "Successfully logged out"
}

Este es un ejemplo de respuesta rechazada del endpoint, La respuesta del mismo esta en formato JSON.

{
    "error": -80
}

El token recuperado es mandado a un lista negra imposibilitándolo para generar nuevas peticiones.

Información de petición
Categoria Valor
Método HTTP GET
EndPoint Api/v2/auth/logout
Headers
Tipo Valor
Authorization Bearer [token]
Content-Type application/json
Esquema de entrada de la petición

No requiere ningún esquema de entrada

Esquema de salida de una petición satisfactoria
Campo Tipo de dato Definición
message String Mensaje de salida
Esquema de salida de una petición no satisfatoria
Campo Tipo de dato Definición
error String Identificador de error

Cobros v2

Las siguientes URL nos permiten hacer cobros de manera única, recurrente y masiva de manera rápida y sencilla

Pago único v2

import requests
import json

url = "https://plataforma.paycode.com.mx/Api/v2/cobros/cobro_unico"

payload = json.dumps({
  "phone": 5555555555,
  "amount": 10.5,
  "name": "XXXXXX",
  "lastname_pa": "XXXXXX",
  "lastname_mo": "XXXXXX",
  "birth_date": "1995-02-16",
  "email": "mail@mail.com",
  "concept": "XXXXXX",
  "limit_date": "2021-06-19 11:44:22",
  "branch_code": "",
  "product_code": "",
  "zone_code": "",
  "period_code": "",
  "date_pay": "unico",
  "if_error": 1
})
headers = {
  'Authorization': 'Bearer [token]',
  'Content-Type': 'application/json'
}

response = requests.request("POST", url, headers=headers, data=payload)

print(response.text)

<?php

$curl = curl_init();

curl_setopt_array($curl, array(
  CURLOPT_URL => 'https://plataforma.paycode.com.mx/Api/v2/cobros/cobro_unico',
  CURLOPT_RETURNTRANSFER => true,
  CURLOPT_ENCODING => '',
  CURLOPT_MAXREDIRS => 10,
  CURLOPT_TIMEOUT => 0,
  CURLOPT_FOLLOWLOCATION => true,
  CURLOPT_HTTP_VERSION => CURL_HTTP_VERSION_1_1,
  CURLOPT_CUSTOMREQUEST => 'POST',
  CURLOPT_POSTFIELDS =>'{
    "phone":5555555555,
    "amount":10.5,
    "name":"XXXXXX",
    "lastname_pa":"XXXXXX",
    "lastname_mo":"XXXXXX",
    "birth_date": "1995-02-16",
    "email" :"mail@mail.com",
    "concept":"XXXXXX",
    "limit_date":"2021-06-19 11:44:22",
    "branch_code":"",
    "product_code":"",
    "zone_code":"",
    "period_code":"",
    "date_pay":"unico",
    "if_error":1
}',
  CURLOPT_HTTPHEADER => array(
    'Authorization: Bearer [token]',
    'Content-Type: application/json'
  ),
));

$response = curl_exec($curl);

curl_close($curl);
echo $response;


var axios = require('axios');
var data = JSON.Stringify({
  "phone": 5555555555,
  "amount": 10.5,
  "name": "XXXXXX",
  "lastname_pa": "XXXXXX",
  "lastname_mo": "XXXXXX",
  "birth_date": "1995-02-16",
  "email": "mail@mail.com",
  "concept": "XXXXXX",
  "limit_date": "2021-06-19 11:44:22",
  "branch_code": "",
  "product_code": "",
  "zone_code": "",
  "period_code": "",
  "date_pay": "unico",
  "if_error": 1
});

var config = {
  method: 'post',
  url: 'https://plataforma.paycode.com.mx/Api/v2/cobros/cobro_unico',
  headers: { 
    'Authorization': 'Bearer [token]', 
    'Content-Type': 'application/json'
  },
  data : data
};

axios(config)
.then(function (response) {
  console.log(JSON.Stringify(response.data));
})
.catch(function (error) {
  console.log(error);
});


Este es un ejemplo de respuesta satisfactoria del endpoint, La respuesta del mismo esta en formato JSON.

{ 
  "success": true,
    "data": {
        "telefono": "XXXXXXXXXX",
        "concepto": "XXXXXX",
        "codigo_rastreo": "XXXXXXXX",
        "errors": [
            "Código de zona no ingresado",
            "Código de sucursal no ingresado",
            "Código de producto no ingresado",
            "Código de periodo no ingresado"
        ]
    }
}

Este es un ejemplo de respuesta rechazada del endpoint, La respuesta del mismo esta en formato JSON.

{
    "error": "-80", 
}

Cree un pago con un cargo único con el cual el cliente podrá aceptar, posponer o rechazar a través de CoDi, El número telefónico debe estar previamente registrado ante CoDi.

Informacion de peticion
Categoria Valor
Método HTTP POST
EndPoint /Api/v2/cobros/cobro_unico
Headers
Tipo Valor
Authorization Bearer [token]
Content-Type application/json
Esquema de entrada de la petición

El contenido del esquema debe estar en formato JSON.

Campo Tipo de dato Requerido Definición
phone Integer True Número telefónico del cliente (debe de estar dado de alta en CoDi)
amount Float True Monto del cargo
name String True Nombre del cliente
lastname_pa String True Apellido paterno del cliente
lastname_mo String True Apellido materno del cliente
birth_date String True Fecha de nacimiento del cliente
email String True Correo electrónico del cliente
concept String True Concepto del cobro menor a 40 caracteres
limit_date String True Fecha límite del pago, minimo 3 minutos, maximo 30 días
branch_code String True Código de la sucursal asociada al producto
product_code String True Código del producto
zone_code String True Código del región
period_code String True Código del periodo
date_pay String True Periodicidad del pago
if_error String True Condición para generar un envío de pago unico sencillo, donde 1 le permite no colocar los valores de branch_code, product_code, zone_code, period_zone en dado caso de que se coloquen y esten mal se enviara el cobro y mostrara los errores, si no se colocan estos valores y esta el valor if_error en 1 se asignaran valores por defecto en estos campos, si el valor esta en 0 los campos branch_code, period_code product_code y zone_code deben ser validos de lo contrario no saldra el envio de cobro
Esquema de salida de una petición satisfactoria
Campo Tipo de dato Definición
success Boolean Respuesta de la petición
data Object Objeto con Información del cobro
data.telefono String Telefóno al que se genero el cobro
data.concepto String Concepto por el que se realizó el cobro
data.codigo_rastreo String Identificador del cobro, el cual no servira para rastrear el estatus del mismo
data.errors Array Arreglo donde se listaran los errores
Esquema de salida de una petición no satisfatoria
Campo Tipo de dato Definición
error String Identificador de error

Consulta de estatus de cobro v2

import requests
import json

url = "https://plataforma.paycode.com.mx/Api/v2/pagos/consultar_estatus"

payload = json.dumps({
  "codigoRastreo": 'XXXXXXXX'
})
headers = {
  'Authorization': 'Bearer [token]',
  'Content-Type': 'application/json'
}

response = requests.request("POST", url, headers=headers, data=payload)

print(response.text)


$curl = curl_init();

curl_setopt_array($curl, array(
  CURLOPT_URL => 'https://plataforma.paycode.com.mx/Api/v1/pagos/consultar_estatus',
  CURLOPT_RETURNTRANSFER => true,
  CURLOPT_ENCODING => '',
  CURLOPT_MAXREDIRS => 10,
  CURLOPT_TIMEOUT => 0,
  CURLOPT_FOLLOWLOCATION => true,
  CURLOPT_HTTP_VERSION => CURL_HTTP_VERSION_1_1,
  CURLOPT_CUSTOMREQUEST => 'POST',
  CURLOPT_POSTFIELDS =>'{
    "codigoRastreo":'XXXXXXXX'
}',
  CURLOPT_HTTPHEADER => array(
    'Authorization: Bearer [token]',
    'Content-Type: application/json'
  ),
));

$response = curl_exec($curl);

curl_close($curl);
echo $response;

var axios = require('axios');
var data = JSON.Stringify({
  "codigoRastreo": 'XXXXXXXX'
});

var config = {
  method: 'post',
  url: 'https://plataforma.paycode.com.mx/Api/v1/pagos/consultar_estatus',
  headers: { 
    'Authorization': '[token]', 
    'Content-Type': 'application/json'
  },
  data : data
};

axios(config)
.then(function (response) {
  console.log(JSON.Stringify(response.data));
})
.catch(function (error) {
  console.log(error);
});



Este es un ejemplo de respuesta satisfactoria del endpoint, La respuesta del mismo esta en formato JSON.

{
    "success": true,
    "data": {
        "estatus": "Rechazado",
        "ultima_actualizacion": "2021-02-12 09:52:35"
    }
}

Este es un ejemplo de respuesta rechazada del endpoint, La respuesta del mismo esta en formato JSON.

{
    "error": "-80", 
}

Cree un objeto de rastreo para generar un consulta de estatus de cobro, los clientes podrán consultar el estatus del cobro enviado a traves de un código de rastreo.

Información de petición
Categoria Valor
Método HTTP POST
EndPoint /Api/v2/pagos/consultar_estatus
Headers
Tipo Valor
Authorization Bearer [token]
Content-Type application/json
Esquema de entrada de la petición

El contenido del esquema debe de estar en formato JSON.

Campo Tipo de dato Requerido Definición
clave_rastreo String True Identificador de hasta 20 posiciones alfanuméricas que la institución le proporciona al usuario al momento en que se instruye el pago.
Esquema de salida de una petición satisfactoria
Campo Tipo de dato Definición
status String Estatus de la petición
data Object Objeto con que contiene el estatus actual del objeto y su ultima fecha de actulización
data.estatus Strig Estado actual del cobro push
data.ultima_actualizacion Strig Fecha con de la ultima transacción del cobro push
Esquema de salida de una petición no satisfatoria
Campo Tipo de dato Definición
error String Identificador de error

Cobros por codigo QR v2

El módulo de códigos QR nos permite integrar códigos QR de manera sencilla.

Crear codigo QR v2

import requests
import json

url = "https://plataforma.paycode.com.mx/Api/v2/qr/crear_qr"

payload = json.dumps({
  "amount": 1,
  "concept": "XXXXXXX",
  "limit_date": "2021-06-19 11:44:22",
  "type": 0,
  "reference": 7000003
})
headers = {
  'Authorization': 'Bearer [token]',
  'Content-Type': 'application/json'
}

response = requests.request("POST", url, headers=headers, data=payload)

print(response.text)


<?php

$curl = curl_init();

curl_setopt_array($curl, array(
  CURLOPT_URL => 'https://plataforma.paycode.com.mx/Api/v2/qr/crear_qr',
  CURLOPT_RETURNTRANSFER => true,
  CURLOPT_ENCODING => '',
  CURLOPT_MAXREDIRS => 10,
  CURLOPT_TIMEOUT => 0,
  CURLOPT_FOLLOWLOCATION => true,
  CURLOPT_HTTP_VERSION => CURL_HTTP_VERSION_1_1,
  CURLOPT_CUSTOMREQUEST => 'POST',
  CURLOPT_POSTFIELDS =>'{
    "amount": 1,
    "concept": "XXXXXXX",
    "limit_date": "2021-06-19 11:44:22",
    "type": 0,
    "reference": 7000003
}',
  CURLOPT_HTTPHEADER => array(
    'Authorization: Bearer [token]',
    'Content-Type: application/json'
  ),
));

$response = curl_exec($curl);

curl_close($curl);
echo $response;


var axios = require('axios');
var data = JSON.stringify({
  "amount": 1,
  "concept": "XXXXXXX",
  "limit_date": "2021-06-19 11:44:22",
  "type": 0,
  "reference": 7000003
});

var config = {
  method: 'post',
  url: 'https://plataforma.paycode.com.mx/Api/v2/qr/crear_qr',
  headers: { 
    'Authorization': 'Bearer [token]', 
    'Content-Type': 'application/json'
  },
  data : data
};

axios(config)
.then(function (response) {
  console.log(JSON.stringify(response.data));
})
.catch(function (error) {
  console.log(error);
});


Este es un ejemplo de respuesta satisfactoria del endpoint, La respuesta del mismo esta en formato JSON.

{
    "status": "exitoso",
    "json_pago": "",
    "clave_rastreo": "XXXXXXX",
    "ref_pago": "XXXXXXX",
    "empresa_cobra": "XXXXXX"
}

Este es un ejemplo de respuesta rechazada del endpoint, La respuesta del mismo esta en formato JSON.

{
    "error": "-80", 
}

Recupera un objeto QR el cual nos permitirá poder hacer el renderizado de un código QR de manera sencilla usando base64, los códigos QR cuentan con una vida util de 3 minutos como minimo y como maximo de 30 días, si el código QR no se encuentra en este rango sera ilegible.

Ejemplo:

<img alt="" src="data:image/png;base64, infromación del QR">

Es recomendable almacenar el valor clave_rastreo al momento de enviar el estatus de cada código QR.

Información de petición
Categoria Valor
Método HTTP POST
EndPoint /Api/v2/qr/crear_qr
Headers
Tipo Valor
Authorization Bearer [token]
Content-Type application/json
Esquema de entrada de la petición
Campo Tipo de dato Requerido Definición
amount float True Monto del cargo
concept String True Concepto del cobro menor a 40 caracteres
limit_date String True Fecha límite del pago, minimo 3 minutos, maximo 30 días
reference Integer True Número de identificación de hasta siete posiciones que el usuario selecciona al momento de instruir su pago
type Integer True Tipo de cobro [1=>Unico, 2=>Recurrente]
Esquema de salida de una petición satisfactoria
Campo Tipo de dato Definición
status String Estatus de la petición
json_pago String Cadena con el contenido para poder hacer el render de una imagen base64
clave_rastreo Strig Identificador de hasta 20 posiciones alfanuméricas que la institución le proporciona al usuario al momento en que se instruye el pago
ref_pago Strig Identificador del pago
empresa_cobra Strig Razón social de la empresa que cobra
Esquema de salida de una petición no satisfatoria
Campo Tipo de dato Definición
error String Identificador de error

Actualizar código QR v2

import requests
import json

url = "https://plataforma.paycode.com.mx/Api/v2/qr/refrescar_qr"

payload = json.dumps({
  "clave_rastro": "XXXXXXXXX",
  "ref_pag": "XXXXXXXXX"
})
headers = {
  'Authorization': 'Bearer [token]',
  'Content-Type': 'application/json'
}

response = requests.request("POST", url, headers=headers, data=payload)

print(response.text)


<?php

$curl = curl_init();

curl_setopt_array($curl, array(
  CURLOPT_URL => 'https://plataforma.paycode.com.mx/Api/v2/qr/refrescar_qr',
  CURLOPT_RETURNTRANSFER => true,
  CURLOPT_ENCODING => '',
  CURLOPT_MAXREDIRS => 10,
  CURLOPT_TIMEOUT => 0,
  CURLOPT_FOLLOWLOCATION => true,
  CURLOPT_HTTP_VERSION => CURL_HTTP_VERSION_1_1,
  CURLOPT_CUSTOMREQUEST => 'POST',
  CURLOPT_POSTFIELDS =>'
{"clave_rastro":"XXXXXX","ref_pag":"XXXXXX"  }',
  CURLOPT_HTTPHEADER => array(
    'Authorization: Bearer [token]',
    'Content-Type: application/json'
  ),
));

$response = curl_exec($curl);

curl_close($curl);
echo $response;


var axios = require('axios');
var data = JSON.stringify({
  "clave_rastro": "XXXXXXX",
  "ref_pag": "XXXXXXX"
});

var config = {
  method: 'post',
  url: 'https://plataforma.paycode.com.mx/Api/v2/qr/refrescar_qr',
  headers: { 
    'Authorization': 'Bearer [token]', 
    'Content-Type': 'application/json'
  },
  data : data
};

axios(config)
.then(function (response) {
  console.log(JSON.stringify(response.data));
})
.catch(function (error) {
  console.log(error);
});



Este es un ejemplo de respuesta satisfactoria del endpoint, La respuesta del mismo esta en formato JSON.

{
    "status": "exitoso",
    "json_pago": "",
    "clave_rastreo": "XXXXXXX",
    "ref_pago": "XXXXXXX",
    "empresa_cobra": "XXXXXX"
}

Este es un ejemplo de respuesta rechazada del endpoint, La respuesta del mismo esta en formato JSON.

{
    "error": "-80", 
}

Recupera objeto refrescar QR, el cual nos va a permitir generar un nuevo codigo QR pasando como parametros la clave de rastreo y la referencia de pago.

Información de petición
Categoria Valor
Método HTTP POST
EndPoint Api/v2/qr/refrescar_qr
Headers
Tipo Valor
Authorization Bearer [token]
Content-Type application/json
Esquema de entrada de la petición
Campo Tipo de dato Definición
clave_rastreo String Identificador de hasta 20 posiciones alfanuméricas que la institución le proporciona al usuario al momento en que se instruye el pago.
ref_pago String Identificador del pago
Esquema de salida de una petición satisfactoria
Campo Tipo de dato Definición
status String Estatus de la petición
json_pago String Cadena con el contenido para poder hacer el render de una imagen base64
clave_rastreo Strig Identificador de hasta 20 posiciones alfanuméricas que la institución le proporciona al usuario al momento en que se instruye el pago
ref_pago Strig Identificador del pago
empresa_cobra Strig Razón social de la empresa que cobra
Esquema de salida de una petición no satisfatoria
Campo Tipo de dato Definición
error String Identificador de error

Obtener estatus de código QR v2

import requests
import json

url = "https://plataforma.paycode.com.mx/Api/v2/qr/consultar_estatus"

payload = json.dumps({
  "claveRastreo": "XXXXXXXXX"
})
headers = {
  'Authorization': 'Bearer [token]',
  'Content-Type': 'application/json'
}

response = requests.request("POST", url, headers=headers, data=payload)

print(response.text)


<?php

$curl = curl_init();

curl_setopt_array($curl, array(
  CURLOPT_URL => 'https://plataforma.paycode.com.mx/Api/v2/qr/consultar_estatus',
  CURLOPT_RETURNTRANSFER => true,
  CURLOPT_ENCODING => '',
  CURLOPT_MAXREDIRS => 10,
  CURLOPT_TIMEOUT => 0,
  CURLOPT_FOLLOWLOCATION => true,
  CURLOPT_HTTP_VERSION => CURL_HTTP_VERSION_1_1,
  CURLOPT_CUSTOMREQUEST => 'POST',
  CURLOPT_POSTFIELDS =>'{
    "claveRastreo":"XXXXXXXXX"
}',
  CURLOPT_HTTPHEADER => array(
    'Authorization: Bearer [token]',
    'Content-Type: application/json'
  ),
));

$response = curl_exec($curl);

curl_close($curl);
echo $response;

var axios = require('axios');
var data = JSON.stringify({
  "claveRastreo": "XXXXXXXX"
});

var config = {
  method: 'post',
  url: 'https://plataforma.paycode.com.mx/Api/v2/qr/consultar_estatus',
  headers: { 
    'Authorization': 'Bearer [token]', 
    'Content-Type': 'application/json'
  },
  data : data
};

axios(config)
.then(function (response) {
  console.log(JSON.stringify(response.data));
})
.catch(function (error) {
  console.log(error);
});



Este es un ejemplo de respuesta satisfactoria del endpoint, La respuesta del mismo esta en formato JSON.

{
    "success": true,
    "data": {
        "estatus": "Rechazado",
        "ultima_actualizacion": "2021-02-12 09:52:35"
    }
}

Este es un ejemplo de respuesta rechazada del endpoint, La respuesta del mismo esta en formato JSON.

{
    "error": "-80", 
}

Recupera un objeto el cual nos permite saber el estatus actual del código QR.

Información de petición
Categoria Valor
Método HTTP POST
EndPoint Api/v2/qr/consultar_estatus
Headers
Tipo Valor
Authorization Bearer [token]
Content-Type application/json
Esquema de entrada de la petición

El contenido del esquema debe de estar en formato JSON.

Campo Tipo de dato Requerido Definición
clave_rastreo String True Identificador de hasta 20 posiciones alfanuméricas que la institución le proporciona al usuario al momento en que se instruye el pago.
Esquema de salida de una petición satisfactoria
Campo Tipo de dato Definición
status String Estatus de la petición
data Object Objeto con que contiene el estatus actual del objeto y su ultima fecha de actulización
data.estatus Strig Estado actual del último escaneo del código QR
data.ultima_actualizacion Strig Fecha con de la ultima transacción del código QR
Esquema de salida de una petición no satisfatoria
Campo Tipo de dato Definición
error String Identificador de error

El módulo de links de pago es una opción fácil para cobrar a tus clientes enviando notificaciones en forma de mensaje por Whatsapp, mensaje de texto ó correo sin necesidad de tener un sitio web o tienda en línea, tus clientes podrán acceder al sitio https://checkout.paycode.com.mx/ donde podran pagar.

import requests
import json

url = "https://plataforma.paycode.com.mx/Api/v2/links-pago/crear_link"

payload = json.dumps({
  "require_info": 0,
  "auto_invoicing": False,
  "concept": "sum concept",
  "customer_code": "0000000",
  "type_link": "2",
  "expiration_time": {
    "days": 1,
    "hours": 0,
    "mins": 0,
    "secs": 0
  },
  "images_link": {
    "url_img_product": "https://img.com/img.jpg",
    "url_logo": "https://img.com/img.jpg"
  },
  "notifications": {
    "email": True,
    "sms": True
  },
  "payment_method": {
    "codi": True,
    "credit_card": True,
    "spei": True
  },
  "products": [
    {
      "amount": "12",
      "name": "pago unico",
      "product_code": "0000000",
      "quantity": 1
    }
  ],
  "redirect_url": "https://callback.com/redirect_success",
  "sms_text": "PayCode: tiene una nueva solicitud de pago. Puede realizar el pago en el siguiente enlace #LINK_PAGO, #NEGOCIO envío una solicitud de pago por el importe de #TOTAL MXN.",
  "style_configuration": {
    "backgoround": "#000000",
    "color_btn": "#000000",
    "colortext_btn": "#FFFFFF"
  }
})
headers = {
  'Authorization': 'Bearer [token]',
  'Content-Type': 'application/json'
}

response = requests.request("POST", url, headers=headers, data=payload)

print(response.text)

<?php

$curl = curl_init();

curl_setopt_array($curl, array(
  CURLOPT_URL => 'https://plataforma.paycode.com.mx/Api/v2/links-pago/crear_link',
  CURLOPT_RETURNTRANSFER => true,
  CURLOPT_ENCODING => '',
  CURLOPT_MAXREDIRS => 10,
  CURLOPT_TIMEOUT => 0,
  CURLOPT_FOLLOWLOCATION => true,
  CURLOPT_HTTP_VERSION => CURL_HTTP_VERSION_1_1,
  CURLOPT_CUSTOMREQUEST => 'POST',
  CURLOPT_POSTFIELDS =>'{
  "require_info":0,
  "auto_invoicing": false,
  "concept": "sum concept",
  "customer_code": "0000000",
  "type_link":"2",
  "expiration_time": 
    {
      "days": 1,
      "hours": 0,
      "mins": 0,
      "secs": 0
    }
  ,
  "images_link": {
    "url_img_product": "https://img.com/img.jpg",
    "url_logo": "https://img.com/img.jpg"
  },
  "notifications": {
    "email": true,
    "sms": true
  },
  "payment_method": {
    "codi": true,
    "credit_card": true,
    "spei": true
  },
  "products": [
    {
      "amount": "12",
      "name": "pago unico",
      "product_code": "0000000",
      "quantity": 1
    }
  ],
  "redirect_url": "https://callback.com/redirect_success",
  "sms_text": "PayCode: tiene una nueva solicitud de pago. Puede realizar el pago en el siguiente enlace #LINK_PAGO, #NEGOCIO envío una solicitud de pago por el importe de #TOTAL MXN.",
  "style_configuration": {
    "backgoround": "#000000",
    "color_btn": "#000000",
    "colortext_btn": "#FFFFFF"
  }
}',
  CURLOPT_HTTPHEADER => array(
    'Authorization: Bearer [token]',
    'Content-Type: application/json'
  ),
));

$response = curl_exec($curl);

curl_close($curl);
echo $response;


var axios = require('axios');
var data = JSON.stringify({
  "require_info": 0,
  "auto_invoicing": false,
  "concept": "sum concept",
  "customer_code": "0000000",
  "type_link": "2",
  "expiration_time": {
    "days": 1,
    "hours": 0,
    "mins": 0,
    "secs": 0
  },
  "images_link": {
    "url_img_product": "https://img.com/img.jpg",
    "url_logo": "https://img.com/img.jpg"
  },
  "notifications": {
    "email": true,
    "sms": true
  },
  "payment_method": {
    "codi": true,
    "credit_card": true,
    "spei": true
  },
  "products": [
    {
      "amount": "12",
      "name": "pago unico",
      "product_code": "0000000",
      "quantity": 1
    }
  ],
  "redirect_url": "https://callback.com/redirect_success",
  "sms_text": "PayCode: tiene una nueva solicitud de pago. Puede realizar el pago en el siguiente enlace #LINK_PAGO, #NEGOCIO envío una solicitud de pago por el importe de #TOTAL MXN.",
  "style_configuration": {
    "backgoround": "#000000",
    "color_btn": "#000000",
    "colortext_btn": "#FFFFFF"
  }
});

var config = {
  method: 'post',
  url: 'https://plataforma.paycode.com.mx/Api/v2/links-pago/crear_link',
  headers: { 
    'Authorization': 'Bearer [token]', 
    'Content-Type': 'application/json'
  },
  maxRedirects: 0,
  data : data
};

axios(config)
.then(function (response) {
  console.log(JSON.stringify(response.data));
})
.catch(function (error) {
  console.log(error);
});


Este es un ejemplo de respuesta satisfactoria del endpoint, La respuesta del mismo esta en formato JSON.

{
    "success": true,
    "link": "https://checkout.paycode.com.mx/XXXXXX-CCCC-XXXXXXXX"
}

Este es un ejemplo de respuesta rechazada del endpoint, La respuesta del mismo esta en formato JSON.

{
    "error": "-80", 
}

Recupera un objeto link de pago el cual nos permitara poder generar un URL única donde tus clientes podran pagar algún servicio.

Información de petición
Categoria Valor
Método HTTP POST
EndPoint /Api/v2/links-pago/crear_link
Headers
Tipo Valor
Authorization Bearer [token]
Content-Type application/json
Esquema de entrada de la petición
Campo Tipo de dato Requerido Definición
require_info integer false Valor que terminte solicitar datos del cliente (Nombre, Apellido, Email)
type_link integer false Define el tipo de link, 1 para un link de pago único, 2 para un link de pago permanente este link puede pagarse mas de una vez
expiration_time object true Define el tiempo de duración del link de pago
expiration_time.days integer true Define los días de vida del link de pago, para cobros CoDi los dias maximos son 30
expiration_time.hours integer false Horas de vida del link de pago
expiration_time.mins integer false Minutos de vida del link de pago
expiration_time.secs integer false Segundos de vida del link de pago
images_link object true Define las imagenes del producto y logo del link de pago
images_link.url_img_product String true Url de imagen del producto
images_link.url_logo String true Url de imagen del logo del negocio
notifications object true Define los medios de notificación del link de pago
notifications.email Boolean true Se enviara notificación por email
notifications.sms Boolean true Se enviara notificación por SMS
payment_method object true Define los metodos de pago que se habilitaran para el link de pago
payment_method.codi Boolean false Define CoDi como método de pago
payment_method.credit_card Boolean false Define tarjeta de crédito como método de pago
payment_method.spei Boolean false Define SPEI como método de pago
concept String True Concepto del cobro menor a 40 caracteres
customer_code String True Código único de usario al cual se le generara el cobro, el código se puede definir a través de la plataforma de PayCode al momento de dar de alta a un cliente
products Array True Arreglo que contiene los productos asociados al link de pago
products.x.product_code String True Código único de producto al cual se le generara el cobro, el código se puede definir a través de la plataforma de PayCode al momento de dar de alta a un producto
products.x.quantity Integer false Cantidad del producto asociado
products.x.amount float false Precio por unidad del producto
auto_invoicing Boolean True Facturación (alpha), por default false
sms_text String True Texto de hasta 250 caracteres que se enviará en las notificaciones via SMS y Correo, los valores que se pueden sustituir son los siguientes:
'#NOMBRE' => Nombre del cliente a quien va dirigido el link de pago,
'#TOTAL'=>Monto total del link de pago,
'#FECHA_LIMITE'=>Fecha de vencimiento,
'#LINK_PAGO'=>URL del link de pago,
'#CONCEPTO'=>Concepto del link de pago,
'#NEGOCIO'=> Nombre del negocio que cobra
redirect_url String True URL a donde se realizará un redireccionamiento posterior a efectuar el cobro por algún Método de pago
style_configuration object true Define parametros de estilo para el link de pago
style_configuration.backgoround Boolean true Define el color de fondo del link de pago
style_configuration.color_btn Boolean true Define el color de fondo de los botones
style_configuration.colortext_btn Boolean true Define el color de texto del botón
Esquema de salida de una petición satisfactoria
Campo Tipo de dato Definición
success Boolean Estatus de la petición
link String URL del link de pago
Esquema de salida de una petición no satisfatoria
Campo Tipo de dato Definición
error String Identificador de error

Cobros por tarjeta débito/crédito v2

Módulo pago por tarjeta nos permite generar transacciones a través de nuestro API con total seguridad

Crear cargo

Recupera un objeto tarjeta el cual nos permitirá realizar un cobro con tarjeta de crédito / débito.

import requests
import json

url = "https://plataforma.paycode.com.mx/Api/v2/cobros/pago_tarjeta_ecomerce"

payload = json.dumps({
  "save_card":true, 
  "amount": "23.00",
  "card": {
    "card_number": "5111111111111118",
    "sec_code": "000",
    "exp_month": "00",
    "exp_year": "20",
    "cardholder_name": "XXXXXX"
  },
  "client": {
    "num_cel": "5555555555",
    "first_name": "XXXXXX",
    "paternal_surname": "XXXXXX",
    "maternal_surname": "XXXXXX",
    "concept": "XXXXXX"
  },
   "ip":"000.000.000.000"
})
headers = {
  'Authorization': 'Bearer [token]',
  'Content-Type': 'application/json'
}

response = requests.request("POST", url, headers=headers, data=payload)

print(response.text)

<?php

$curl = curl_init();

curl_setopt_array($curl, array(
  CURLOPT_URL => 'https://plataforma.paycode.com.mx/Api/v2/cobros/pago_tarjeta_ecomerce',
  CURLOPT_RETURNTRANSFER => true,
  CURLOPT_ENCODING => '',
  CURLOPT_MAXREDIRS => 10,
  CURLOPT_TIMEOUT => 0,
  CURLOPT_FOLLOWLOCATION => true,
  CURLOPT_HTTP_VERSION => CURL_HTTP_VERSION_1_1,
  CURLOPT_CUSTOMREQUEST => 'POST',
  CURLOPT_POSTFIELDS =>'{  "save_card":true,  "amount": "23.00", 
    "card": {
        "card_number": "5111111111111118",
        "sec_code": "000",
        "exp_month": "00",
        "exp_year": "20",        
        "cardholder_name": "XXXXXX"

    },
    "client": {                                       
                "num_cel"              : "5555555555",
                "first_name"          : "XXXXXX",
                "paternal_surname"     : "XXXXXX",
                "maternal_surname"     : "XXXXXX",
                "concept"              : "XXXXXX" 
             },
     "ip":"000.000.000.000"
}',
  CURLOPT_HTTPHEADER => array(
    'Authorization: Bearer [token]',
    'Content-Type: application/json'
  ),
));

$response = curl_exec($curl);

curl_close($curl);
echo $response;



var axios = require('axios');
var data = JSON.stringify({
  "save_card":true, 
  "amount": "23.00",
  "card": {
    "card_number": "1111111111111111",
    "sec_code": "000",
    "exp_month": "00",
    "exp_year": "00",
    "cardholder_name": "XXXXXX"
  },
  "client": {
    "num_cel": "5555555555",
    "first_name": "XXXXXX",
    "paternal_surname": "XXXXXX",
    "maternal_surname": "XXXXXX",
    "concept": "XXXXXX"
  },
  "ip":"000.000.000.000"
});

var config = {
  method: 'post',
  url: 'https://plataforma.paycode.com.mx/Api/v2/cobros/pago_tarjeta_ecomerce',
  headers: { 
    'Authorization': 'Bearer [token]', 
    'Content-Type': 'application/json'
  },
  data : data
};

axios(config)
.then(function (response) {
  console.log(JSON.stringify(response.data));
})
.catch(function (error) {
  console.log(error);
});


Este es un ejemplo de respuesta satisfactoria del endpoint con el campo save_card definido con valor false, La respuesta del mismo esta en formato JSON.

{
    "success": true,
    "display_message": "APROBADO",
    "reference_number": "000000006216",
    "track_code": "0X0X0X0X0X"
}

Este es un ejemplo de respuesta satisfactoria del endpoint con el campo save_card definido con valor true, La respuesta del mismo esta en formato JSON.

{
    "success": true,
    "display_message": "APROBADO",
    "reference_number": "000000006216",
    "track_code": "0X0X0X0X0X",
    "token_card": "XXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXX"
}

Este es un ejemplo de respuesta rechazada del endpoint, La respuesta del mismo esta en formato JSON.


{
    "success": false,
    "display_message": "RECHAZADA",
    "reference_number": "000000006216",
    "track_code": "0X0X0X0X0X"
}

Recupera un objeto tarjeta el cual nos permitirá poder generar una transacción via e-comerce, aceptamos tarjetas Visa / Mastercard y AMEX.

Información de petición
Categoria Valor
Método HTTP POST
EndPoint /Api/v2/cobros/pago_tarjeta_ecomerce
Headers
Tipo Valor
Authorization Bearer [token]
Content-Type application/json
Esquema de entrada de la petición
Campo Tipo de dato Requerido Definición
save_card Boolean false Indica si requiere tokenizar la tarjeta fase BETA
amount float true Monto del cargo
card Object true Objeto que contiene los datos de la tarjeta
card.card_number String true Número de tarjeta a la que se realizara el cobro
card.sec_code String true Código de serguridad de la tarjeta a la que se realizara el cobro
card.exp_month String true Mes de expiración de la tarjeta (MM)
card.exp_year String true Año de expiración de la tarjeta (YY)
card.cardholder_name String true Nombre del propietario de la tarjeta
client Object true Objeto que contiene los datos del cliente
client.num_cel Integer true Número telefónico del cliente
client.first_name String true Nombre del cliente
client.paternal_surname String true Apellido paterno del cliente
client.maternal_surname String true Apellido materno del cliente
client.concept String true Concepto del cobro menor a 40 caracteres
ip String true IP pública del cliente
Esquema de salida de una petición satisfactoria con el campo save_card definido con valor false
Campo Tipo de dato Definición
successful String Estatus de la petición
display_message String Cadena con el mensaje de estatus de la transacción
reference_number String Número de referencia
track_code String Identificador de 10 posiciones alfanuméricas servira para consultar el estatus del cobro
Esquema de salida de una petición satisfactoria con el campo save_card definido con valor true
Campo Tipo de dato Definición
successful String Estatus de la petición
display_message String Cadena con el mensaje de estatus de la transacción
reference_number String Número de referencia
track_code String Identificador de 10 posiciones alfanuméricas servira para consultar el estatus del cobro
token_card String Identificador el cual se podrá utilizar para genera transacciones sin necesidad de mandar los datos de la tarjeta
Esquema de salida de una petición no satisfatoria
Campo Tipo de dato Definición
error String Identificador de error

Crear cargo por token BETA

Recupera un objeto tarjeta el cual nos permitirá realizar un cobro con tarjeta de crédito / débito.

import requests
import json

url = "https://plataforma.paycode.com.mx/Api/v2/cobros/pago_token_ecomerce"

payload = json.dumps({

  "amount": "23.00",
  "token_card":"XXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXX",
  "ip":"000.000.000.000"
})
headers = {
  'Authorization': 'Bearer [token]',
  'Content-Type': 'application/json'
}

response = requests.request("POST", url, headers=headers, data=payload)

print(response.text)

<?php

$curl = curl_init();

curl_setopt_array($curl, array(
  CURLOPT_URL => 'https://plataforma.paycode.com.mx/Api/v2/cobros/pago_token_ecomerce',
  CURLOPT_RETURNTRANSFER => true,
  CURLOPT_ENCODING => '',
  CURLOPT_MAXREDIRS => 10,
  CURLOPT_TIMEOUT => 0,
  CURLOPT_FOLLOWLOCATION => true,
  CURLOPT_HTTP_VERSION => CURL_HTTP_VERSION_1_1,
  CURLOPT_CUSTOMREQUEST => 'POST',
  CURLOPT_POSTFIELDS =>'{  "amount": "23.00",
  "token_card":"XXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXX", "ip":"000.000.000.000"
  }',
  CURLOPT_HTTPHEADER => array(
    'Authorization: Bearer [token]',
    'Content-Type: application/json'
  ),
));

$response = curl_exec($curl);

curl_close($curl);
echo $response;



var axios = require('axios');
var data = JSON.stringify({
  "amount": "23.00",
  "token_card":"XXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXX",
  "ip":"000.000.000.000"
});

var config = {
  method: 'post',
  url: 'https://plataforma.paycode.com.mx/Api/v2/cobros/pago_token_ecomerce',
  headers: { 
    'Authorization': 'Bearer [token]', 
    'Content-Type': 'application/json'
  },
  data : data
};

axios(config)
.then(function (response) {
  console.log(JSON.stringify(response.data));
})
.catch(function (error) {
  console.log(error);
});


Este es un ejemplo de respuesta satisfactoria del endpoint, La respuesta del mismo esta en formato JSON.

{
    "success": true,
    "display_message": "APROBADO",
    "reference_number": "000000006216",
    "track_code": "0X0X0X0X0X"
}

Este es un ejemplo de respuesta rechazada del endpoint, La respuesta del mismo esta en formato JSON.


{
    "success": false,
    "display_message": "RECHAZADA",
    "reference_number": "000000006216",
    "track_code": "0X0X0X0X0X"
}

Recupera un objeto tarjeta el cual nos permitirá poder generar una transacción via e-comerce, aceptamos tarjetas Visa / Mastercard y AMEX.

Información de petición
Categoria Valor
Método HTTP POST
EndPoint /Api/v2/cobros/pago_token_ecomerce
Headers
Tipo Valor
Authorization Bearer [token]
Content-Type application/json
Esquema de entrada de la petición
Campo Tipo de dato Requerido Definición
token_card String true Identificador el cual se podrá utilizar para genera transacciones sin necesidad de mandar los datos de la tarjeta
amount float true Monto del cargo
ip String true IP pública del cliente
Esquema de salida de una petición satisfactoria
Campo Tipo de dato Definición
successful String Estatus de la petición
display_message String Cadena con el mensaje de estatus de la transacción
reference_number String Número de referencia
track_code String Identificador de 10 posiciones alfanuméricas servira para consultar el estatus del cobro
Esquema de salida de una petición no satisfatoria
Campo Tipo de dato Definición
error String Identificador de error

Obtener transacciones

Recupera un objeto transacciones el cual listara las transacciones realizadas.

import requests

url = "https://plataforma.paycode.com.mx/Api/v2/transacciones/obtener_transacciones"

payload={}
headers = {
  'Authorization': 'Bearer [token]'
}

response = requests.request("GET", url, headers=headers, data=payload)

print(response.text)


<?php

$curl = curl_init();

curl_setopt_array($curl, array(
  CURLOPT_URL => 'https://plataforma.paycode.com.mx/Api/v2/transacciones/obtener_transacciones',
  CURLOPT_RETURNTRANSFER => true,
  CURLOPT_ENCODING => '',
  CURLOPT_MAXREDIRS => 10,
  CURLOPT_TIMEOUT => 0,
  CURLOPT_FOLLOWLOCATION => true,
  CURLOPT_HTTP_VERSION => CURL_HTTP_VERSION_1_1,
  CURLOPT_CUSTOMREQUEST => 'GET',
  CURLOPT_HTTPHEADER => array(
    'Authorization: Bearer [token]'
  ),
));

$response = curl_exec($curl);

curl_close($curl);
echo $response;



var axios = require('axios');

var config = {
  method: 'get',
  url: 'https://plataforma.paycode.com.mx/Api/v2/transacciones/obtener_transacciones',
  headers: { 
    'Authorization': 'Bearer [token]'
  }
};

axios(config)
.then(function (response) {
  console.log(JSON.stringify(response.data));
})
.catch(function (error) {
  console.log(error);
});


Este es un ejemplo de respuesta satisfactoria del endpoint, La respuesta del mismo esta en formato JSON.

{
    "success": true,
    "data": [{
      "negocio": "PayCode",
      "identificador": XXXXXXXX,
      "fecha_transaccion": "XXXXXXXXX",
      "tipo_lectura": "key_entry",
      "monto": "1.00",
      "propina": "0.00",
      "numero_autorizacion": XXXXXXXXXX,
      "referencia": "XXXXXXXXXX",
      "codigo_resultado": "00",
      "reference_number": "XXXXXXXXXX"
    }]
}

Este es un ejemplo de respuesta rechazada del endpoint, La respuesta del mismo esta en formato JSON.


{
    "success": false,
    "data": "[]",

}

Información de petición
Categoria Valor
Método HTTP GET
EndPoint /Api/v2/transacciones/obtener_transacciones
Headers
Tipo Valor
Authorization Bearer [token]
Content-Type application/json
Esquema de entrada de la petición

El contenido del esquema debe de estar en formato JSON.

No requiere ningún esquema de entrada

Esquema de salida de una petición satisfactoria
Campo Tipo de dato Definición
successful string Estatus de la petición
data array Arreglo que contiene información de transacciones
Esquema de salida de una petición no satisfatoria
Campo Tipo de dato Definición
error String Identificador de error

Obtener estatus de transacciones

Recupera un objeto transacciones el cual nos permitirá conocer el estatus de la transacción.

import requests
import json

url = "https://plataforma.paycode.com.mx/Api/v2/transacciones/obtener_estatus_transacciones"

payload = json.dumps({
  "transactions": [
    XXXXX
  ]
})
headers = {
  'Authorization': 'Bearer [token]',
  'Content-Type': 'application/json'
}

response = requests.request("POST", url, headers=headers, data=payload)

print(response.text)


<?php

$curl = curl_init();

curl_setopt_array($curl, array(
  CURLOPT_URL => 'https://plataforma.paycode.com.mx/Api/v2/transacciones/obtener_estatus_transacciones',
  CURLOPT_RETURNTRANSFER => true,
  CURLOPT_ENCODING => '',
  CURLOPT_MAXREDIRS => 10,
  CURLOPT_TIMEOUT => 0,
  CURLOPT_FOLLOWLOCATION => true,
  CURLOPT_HTTP_VERSION => CURL_HTTP_VERSION_1_1,
  CURLOPT_CUSTOMREQUEST => 'POST',
  CURLOPT_POSTFIELDS =>'{
    "transactions":[XXXXXXX]
}',
  CURLOPT_HTTPHEADER => array(
    'Authorization: Bearer [token]',
    'Content-Type: application/json'
  ),
));

$response = curl_exec($curl);

curl_close($curl);
echo $response;


var axios = require('axios');
var data = JSON.stringify({
  "transactions": [
    226379
  ]
});

var config = {
  method: 'post',
  url: 'https://plataforma.paycode.com.mx/Api/v2/transacciones/obtener_estatus_transacciones',
  headers: { 
    'Authorization': 'Bearer [token]', 
    'Content-Type': 'application/json'
  },
  data : data
};

axios(config)
.then(function (response) {
  console.log(JSON.stringify(response.data));
})
.catch(function (error) {
  console.log(error);
});


Este es un ejemplo de respuesta satisfactoria del endpoint, La respuesta del mismo esta en formato JSON.

{
    "success": true,
    "data":  [{
      "negocio": "PayCode",
      "identificador": XXXXXXXX,
      "fecha_transaccion": "XXXXXXXXX",
      "tipo_lectura": "key_entry",
      "monto": "1.00",
      "propina": "0.00",
      "numero_autorizacion": XXXXXXXXXX,
      "referencia": "XXXXXXXXXX",
      "codigo_resultado": "00",
      "reference_number": "XXXXXXXXXX",
      "conciliado":true
    }],

}

Este es un ejemplo de respuesta rechazada del endpoint, La respuesta del mismo esta en formato JSON.


{
    "success": false,
    "data": [],

}

Recupera un objeto tarjeta el cual nos permitirá poder conocer el estatus de las transacciones, se pueden consultar hasta 50 transacciones por petición.

Información de petición
Categoria Valor
Método HTTP POST
EndPoint /Api/v2/transacciones/obtener_estatus_transacciones
Headers
Tipo Valor
Authorization Bearer [token]
Content-Type application/json
Esquema de entrada de la petición
Campo Tipo de dato Requerido Definición
transactions array true Arreglo que contendra todos los indentificadores de las transacciones
Esquema de salida de una petición satisfactoria
Campo Tipo de dato Definición
negocio string Nombre del negocio
identificador integer Número de identificación de la transacción
fecha_transaccion date Fecha en la que se realizo la transacción
tipo_lectura string Método por el cual se realizo la transacción
propina integer Cantidad de propina
numero_autorizacion integer Número asignado de autorización para la transacción
referencia string Referencia de la transacción
codigo_resultado string Código de respuesta de la transacción
tipo_transaccion integer Tipo de transacción [sale 0, void 1, refund 2, auth 3, completion 4, cancel 5, chargeback 6]
aprobada boolean Define si fue aprobada o rechazada la transacción
reversada boolean Define si fue devuelta la transacción
terminal_id integer Número de terminal
banco string Nombre de banco
tipo_tarjeta integer Define el tipo de tarjeta [credit 0, debit 1, prepaid 2, charge_card 3]
marca_tarjeta string Marca de la tarjeta
conciliado boolean Define si la transacción fue concilida
Esquema de salida de una petición no satisfatoria
Campo Tipo de dato Definición
error String Identificador de error

Crear devolución

Módulo devolución por tarjeta nos permite generar una devolución sobre una transacciones dentro de las primeras 24 horas en las que fue ralizada la transacción, pasado este tiempo la peticion retornara false.

import requests
import json

url = "https://plataforma.paycode.com.mx/Api/v2/cobros/void_tarjeta_ecomerce"

payload = json.dumps({
  "track_code": 00000000
})
headers = {
  'Authorization': 'Bearer [token]',
  'Content-Type': 'application/json'
}

response = requests.request("POST", url, headers=headers, data=payload)

print(response.text)


<?php

$curl = curl_init();

curl_setopt_array($curl, array(
  CURLOPT_URL => 'https://plataforma.paycode.com.mx/Api/v2/cobros/void_tarjeta_ecomerce',
  CURLOPT_RETURNTRANSFER => true,
  CURLOPT_ENCODING => '',
  CURLOPT_MAXREDIRS => 10,
  CURLOPT_TIMEOUT => 0,
  CURLOPT_FOLLOWLOCATION => true,
  CURLOPT_HTTP_VERSION => CURL_HTTP_VERSION_1_1,
  CURLOPT_CUSTOMREQUEST => 'POST',
  CURLOPT_POSTFIELDS =>'{
  "track_code":00000000

}',
  CURLOPT_HTTPHEADER => array(
    'Authorization: Bearer [token]',
    'Content-Type: application/json'
  ),
));

$response = curl_exec($curl);

curl_close($curl);
echo $response;



var axios = require('axios');
var data = JSON.stringify({
  "track_code": 00000000
});

var config = {
  method: 'post',
  url: 'https://plataforma.paycode.com.mx/Api/v2/cobros/void_tarjeta_ecomerce',
  headers: { 
    'Authorization': 'Bearer [token]', 
    'Content-Type': 'application/json'
  },
  maxRedirects: 0,
  data : data
};

axios(config)
.then(function (response) {
  console.log(JSON.stringify(response.data));
})
.catch(function (error) {
  console.log(error);
});



Este es un ejemplo de respuesta satisfactoria del endpoint, La respuesta del mismo esta en formato JSON.

{
    "successfull": true,
    "display_message": "APROBADO",
    "result_code": "00",
}

Este es un ejemplo de respuesta rechazada del endpoint, La respuesta del mismo esta en formato JSON.


{
    "success": false,
    "display_message": "RECHAZADA",
    "result_code": "56",

}

Recupera un objeto devolución el cual nos permitirá realizar una devolución sobre una transacción de tarjeta de débito/crédito.

Información de petición
Categoria Valor
Método HTTP POST
EndPoint /Api/v2/cobros/void_tarjeta_ecomerce
Headers
Tipo Valor
Authorization Bearer [token]
Content-Type application/json
Esquema de entrada de la petición
Campo Tipo de dato Requerido Definición
track_code integer true Identificador de la transacción
Esquema de salida de una petición satisfactoria
Campo Tipo de dato Definición
successful String Estatus de la petición
display_message String Cadena que nos indica el estatus de la petición
result_code String Código de respuesta
Esquema de salida de una petición no satisfatoria
Campo Tipo de dato Definición
successful String Estatus de la petición
display_message String Cadena que nos indica el estatus de la petición
result_code String Código de respuesta

Facturación v2

Módulo facturación, permitirá generar facturas a través de nuestro API con total seguridad

Crear factura

Recupera un objeto factura el cual nos permitirá realizar una operación de facturación.

import requests
import json

url = "https://plataforma.paycode.com.mx/Api/v2/facturacion/crear_factura"

payload = json.dumps({
  "emission_date": "2018-02-22T11:11:50",
  "subtotal": 430,
  "total": 430,
  "iva": 72.48,
  "amount_lrcs": "DOS MIL CIENTO DIESIOCHO 00/100",
  "currency":"MXN",
  "exchange_rate":1,
  "observations": {
    "first_observation": "PRIMERA OBSERVACIÓN",
    "second_observation": "SEGUNDA OBSERVACIÓN",
    "third_observation":"TERCERA OBSERVACIÓN",

  },
  "cfdi_relation":"51454E3B-F9D2-4016-A8FA-D71B3970567A",
  "receptor": {
    "rfc": "5555555555",
    "name": "XXXXXX",
    "country": "XXXXXX",
    "address": "XXXXXX",
    "number": "XXXXXX",
    "interior_num": "XXXXXX",
    "reference_address":"XXXXX",
    "cp":78485
  },
  "quantities":1,
  "unit":"A1-Unidad",
  "description":"10101506 - Galletas",
  "price":"115.11",
  "discount":0,
})
headers = {
  'Authorization': 'Bearer [token]',
  'Content-Type': 'application/json'
}

response = requests.request("POST", url, headers=headers, data=payload)

print(response.text)

<?php

$curl = curl_init();

curl_setopt_array($curl, array(
  CURLOPT_URL => 'https://plataforma.paycode.com.mx/Api/v2/facturacion/crear_factura',
  CURLOPT_RETURNTRANSFER => true,
  CURLOPT_ENCODING => '',
  CURLOPT_MAXREDIRS => 10,
  CURLOPT_TIMEOUT => 0,
  CURLOPT_FOLLOWLOCATION => true,
  CURLOPT_HTTP_VERSION => CURL_HTTP_VERSION_1_1,
  CURLOPT_CUSTOMREQUEST => 'POST',
  CURLOPT_POSTFIELDS =>'{
    "emission_date": "2018-02-22T11:11:50",
    "subtotal": 430,
    "total": 430,
    "iva": 72.48,
    "amount_lrcs": "DOS MIL CIENTO DIESIOCHO 00/100",
    "currency":"MXN",
    "exchange_rate":1,
    "observations": {
      "first_observation": "PRIMERA OBSERVACIÓN",
      "second_observation": "SEGUNDA OBSERVACIÓN",
      "third_observation":"TERCERA OBSERVACIÓN",

    },
    "cfdi_relation":"51454E3B-F9D2-4016-A8FA-D71B3970567A",
    "receptor": {
      "rfc": "5555555555",
      "name": "XXXXXX",
      "country": "XXXXXX",
      "address": "XXXXXX",
      "number": "XXXXXX",
      "interior_num": "XXXXXX",
      "reference_address":"XXXXX",
      "cp":78485
    },
    "quantities":1,
    "unit":"A1-Unidad",
    "description":"10101506 - Galletas",
    "price":"115.11",
    "discount":0,
  }',
  CURLOPT_HTTPHEADER => array(
    'Authorization: Bearer [token]',
    'Content-Type: application/json'
  ),
));

$response = curl_exec($curl);

curl_close($curl);
echo $response;



var axios = require('axios');
var data = JSON.stringify({
    "emission_date": "2018-02-22T11:11:50",
    "subtotal": 430,
    "total": 430,
    "iva": 72.48,
    "amount_lrcs": "DOS MIL CIENTO DIESIOCHO 00/100",
    "currency":"MXN",
    "exchange_rate":1,
    "observations": {
      "first_observation": "PRIMERA OBSERVACIÓN",
      "second_observation": "SEGUNDA OBSERVACIÓN",
      "third_observation":"TERCERA OBSERVACIÓN",

    },
    "cfdi_relation":"51454E3B-F9D2-4016-A8FA-D71B3970567A",
    "receptor": {
      "rfc": "5555555555",
      "name": "XXXXXX",
      "country": "XXXXXX",
      "address": "XXXXXX",
      "number": "XXXXXX",
      "interior_num": "XXXXXX",
      "reference_address":"XXXXX",
      "cp":78485
    },
    "quantities":1,
    "unit":"A1-Unidad",
    "description":"10101506 - Galletas",
    "price":"115.11",
    "discount":0,
  });

var config = {
  method: 'post',
  url: 'https://plataforma.paycode.com.mx/Api/v2/facturacion/crear_factura',
  headers: { 
    'Authorization': 'Bearer [token]', 
    'Content-Type': 'application/json'
  },
  data : data
};

axios(config)
.then(function (response) {
  console.log(JSON.stringify(response.data));
})
.catch(function (error) {
  console.log(error);
});


Este es un ejemplo de respuesta satisfactoria del endpoint, La respuesta del mismo esta en formato JSON.

{
    "success": true,
    "URL_PDF": "https://plataforma.paycode.com.mx/Api/v2/facturacion/archivo/xxx-xxxx-xxx-xxx-xxxx-xxxx-xx",
    "URL_XML": "https://plataforma.paycode.com.mx/Api/v2/facturacion/archivo/xxx-xxxx-xxx-xxx-xxxx-xxxx-xx"
}

Este es un ejemplo de respuesta rechazada del endpoint, La respuesta del mismo esta en formato JSON.


{
    "success": false,

    "error": -81
}

Información de petición
Categoria Valor
Método HTTP POST
EndPoint /Api/v2/facturacion/crear_factura
Headers
Tipo Valor
Authorization Bearer [token]
Content-Type application/json
Esquema de entrada de la petición
Campo Tipo de dato Requerido Definición
emission_date string true Fecha en la que se emitió la factura
subtotal float true Subtotal del monto requerido
total float true Total neto del monto requerido
iva float true IVA de la cantidad
amount_lrcs string true Cantidad total en letra
currency string true Tipo de moneda ISO 4217
exchange_rate int true Tipo de cambio
observations object true Objeto que contiene los observaciones
observations.first_observation string true Observación sobre la factura
observations.second_observation string true Segunda Observación sobre la factura
observations.third_observation string true Tercera Observación sobre la factura
cfdi_relation string true CFDI
receptor object true Objeto que contiene los datos del receptor
receptor.rfc string true RFC del receptor de la factura
receptor.name String true Nombre de la empresa receptora
receptor.country String true País de la empresa receptora
receptor.address string true Dirección de la empresa receptora
receptor.number int true Número de la dirección de la empresa receptora
receptor.interior_num int true Número interior de la empresa receptora
receptor.reference_address string true Referencia sobre la dirección de la empresa receptora
receptor.cp int true Código postal de la empresa receptora
quantities int true Cantidad de unidades a facturar
unit int true Tipo de unidad a facturar
description string true Descripción de las unidades a facturar
price float true Precio de las unidades a facturar
discount float true Descuento de las unidades a facturar
Esquema de salida de una petición satisfactoria
Campo Tipo de dato Definición
successful String Estatus de la petición
URL_PDF String URL de descarga de la factura en formato PDF
URL_XML Strig URL de descarga de la factura en formato XML
Esquema de salida de una petición no satisfatoria
Campo Tipo de dato Definición
successful String Estatus de la petición
error String Identificador de error

Cobros por SPEI

El módulo de cobros SPEI nos permite integrar cobros a traves de SPEI.

Crear cobro SPEI

import requests
import json

url = "https://plataforma.paycode.com.mx/Api/v2/payments/payment_spei"

payload = json.dumps({
  "clabe": "XXXXXXXXXXXXXXXXX",
  "amount": 3.10,
  "concept": "concepto",
  "limit_date": "2021-06-19 15:18:29"
})
headers = {
  'Content-Type': 'application/json'
  'Authorization': 'Bearer [token]',
}

response = requests.request("POST", url, headers=headers, data=payload)

print(response.text)


<?php

$curl = curl_init();

curl_setopt_array($curl, array(
  CURLOPT_URL => 'https://plataforma.paycode.com.mx/Api/v2/payments/payment_spei',
  CURLOPT_RETURNTRANSFER => true,
  CURLOPT_ENCODING => '',
  CURLOPT_MAXREDIRS => 10,
  CURLOPT_TIMEOUT => 0,
  CURLOPT_FOLLOWLOCATION => true,
  CURLOPT_HTTP_VERSION => CURL_HTTP_VERSION_1_1,
  CURLOPT_CUSTOMREQUEST => 'POST',
  CURLOPT_POSTFIELDS =>'{ "clabe": "XXXXXXXXXXXXXXXXX",
  "amount": 3.10,
  "concept": "concepto",
  "limit_date": "2021-06-19 15:18:29"
}',
  CURLOPT_HTTPHEADER => array(
    'Authorization: Bearer [token]',
    'Content-Type: application/json'
  ),
));

$response = curl_exec($curl);

curl_close($curl);
echo $response;



var axios = require('axios');
var data = JSON.stringify({
    "clabe": "XXXXXXXXXXXXXXXXX",
    "amount": 3.10,
    "concept": "concepto",
    "limit_date": "2021-06-19 15:18:29"
});

var config = {
  method: 'post',
  url: 'https://plataforma.paycode.com.mx/Api/v2/payments/payment_spei',
  headers: { 
    'Authorization': 'Bearer [token]', 
    'Content-Type': 'application/json'
  },
  data : data
};

axios(config)
.then(function (response) {
  console.log(JSON.stringify(response.data));
})
.catch(function (error) {
  console.log(error);
});


Este es un ejemplo de respuesta satisfactoria del endpoint , La respuesta del mismo esta en formato JSON.

{
    "success": true,
    "data": {
        "code": "8eNt-vmL-8Mut",
        "concept": "PAY000000056",
        "beneficiary": "PayCode",
        "bank": "STP",
        "clabe": "646180238065900013"
    }
}

Este es un ejemplo de respuesta rechazada del endpoint, La respuesta del mismo esta en formato JSON.


{
    "success": false,
    "error": "0X0X0X0X0X",

}

Recupera un objeto Spei el cual nos permitirá poder generar un cobro SPEI.

Información de petición
Categoria Valor
Método HTTP POST
EndPoint /Api/v2/payments/payment_spei
Headers
Tipo Valor
Authorization Bearer [token]
Content-Type application/json
Esquema de entrada de la petición
Campo Tipo de dato Requerido Definición
clabe String true Cuenta CLABE del cliente
amount float true Monto del cargo
concept String true Concepto del carga, máximo 40 caracteres
limit_date String true Fecha de vencimiento del cobro Y-mm-dd H:m:s
Esquema de salida de una petición satisfactoria
Campo Tipo de dato Definición
successful String Estatus de la petición
data Object Objeto con datos de cobro
data.code String Identificador del pago
data.concept String Concepto del carga, máximo 40 caracteres
data.beneficiary String Nombre del beneficiario
data.bank String Nombre del banco
data.clabe String Cuenta CLABE del cliente
Esquema de salida de una petición no satisfatoria
Campo Tipo de dato Definición
error String Identificador de error

Webhook

El módulo webhook nos ayudara a enviar actualizaciones de los cobros al momento que el cliente efectue alguna acción sobre el cobro.

Agregar URL

import requests
import json

url = "https://plataforma.paycode.com.mx/Api/v2/qr/agregar_url"

payload = json.dumps({ "url": "https://backend.com/webhook" }) headers = { 'Authorization': 'Bearer [token]', 'Content-Type': 'application/json' }

response = requests.request("POST", url, headers=headers, data=payload)

print(response.text)

<?php
$curl = curl_init();

curl_setopt_array($curl, array( CURLOPT_URL => 'https://plataforma.paycode.com.mx/Api/v2/qr/agregar_url', CURLOPT_RETURNTRANSFER => true, CURLOPT_ENCODING => '', CURLOPT_MAXREDIRS => 10, CURLOPT_TIMEOUT => 0, CURLOPT_FOLLOWLOCATION => true, CURLOPT_HTTP_VERSION => CURL_HTTP_VERSION_1_1, CURLOPT_CUSTOMREQUEST => 'POST', CURLOPT_POSTFIELDS =>'{ "url":"https://backend.com/webhook" }', CURLOPT_HTTPHEADER => array( 'Authorization: Bearer [token]', 'Content-Type: application/json' ), ));

$response = curl_exec($curl);

curl_close($curl); echo $response;


var axios = require('axios');
var data = JSON.stringify({
  "url": "https://backend.com/webhook"
});

var config = { method: 'post', url: 'https://plataforma.paycode.com.mx/Api/v2/qr/agregar_url', headers: { 'Authorization': 'Bearer [token]', 'Content-Type': 'application/json' }, data : data };

axios(config) .then(function (response) { console.log(JSON.stringify(response.data)); }) .catch(function (error) { console.log(error); });

Este es un ejemplo de respuesta satisfactoria del endpoint, La respuesta del mismo esta en formato JSON.

{
    "success": true,
    "data": "Se inserto correctamente",
}

Este es un ejemplo de respuesta rechazada del endpoint, La respuesta del mismo esta en formato JSON.

{
    "success": false,
    "data": "Ocurrio un error",
}

Se definirá una URL la cual recibirá los estatus los cobros (CoDi,SPEI,links de pago y tarjeta) al momento de que el cliente ejerza una acción sobre un cobro ('Enviado', 'Pospuesto', 'Rechazado','Reintegrada', 'Cancelado', 'Vencido') se enviará la el estatus del cobro a la URL definida en este Endpoint.

Se almacena la respuesta del Endpoint con la finalidad de poder reenviar la información en caso de que el URL no esté disponible al momento de enviar una actualización sobre un cobro. el parámetro para definir si la respuesta fue recibida correctamente es un código HTTP 200.

Se enviará el siguiente objeto:
{
"monto": 0,
"concepto": "XXXXXXXX",
"clave_rastreo": "XXXXXXXX",
"numeroCuentaCliente": "XXXXXXXX",
"horaProcMensajeCobro": "2020-06-09 07:01:33",
"resultadoMensajeCobro": "XXXXXXXX",
"horaSolicitudMensajeCobro": "2020-06-09 04:38:35"
}

Para links de pago se enviara este objeto:
{
"success": true,
"hash": "XX8X-XX8X-XX8",
"paid_at": "2020-06-09 04:38:35",
"amout_paid": "19.99",
"status": "paid",
"type_paid": "credit card",
}

Información de petición
Categoria Valor
Método HTTP POST
EndPoint Api/v2/qr/agregar_url
Headers
Tipo Valor
Authorization Bearer [token]
Content-Type application/json
Esquema de entrada de la petición

El contenido del esquema debe de estar en formato JSON.

Campo Tipo de dato Requerido Definición
url String True URL a la que se enviarán las actualizaciones de los cobros.
Esquema de salida de una petición satisfactoria
Campo Tipo de dato Definición
succes Boolean Respuesta de la petición
data String Mensaje de respuesta
Esquema de salida de una petición no satisfatoria
Campo Tipo de dato Definición
error String Identificador de error

Actualizar URL

import requests
import json

url = "https://dev.paycode.com.mx/Api/v2/qr/actualizar_url"

payload = json.dumps({ "url": "https://backend.com/updatehook" }) headers = { 'Authorization': 'Bearer [token]', 'Content-Type': 'application/json' }

response = requests.request("POST", url, headers=headers, data=payload)

print(response.text)

<?php

$curl = curl_init();

curl_setopt_array($curl, array( CURLOPT_URL => 'https://dev.paycode.com.mx/Api/v2/qr/actualizar_url', CURLOPT_RETURNTRANSFER => true, CURLOPT_ENCODING => '', CURLOPT_MAXREDIRS => 10, CURLOPT_TIMEOUT => 0, CURLOPT_FOLLOWLOCATION => true, CURLOPT_HTTP_VERSION => CURL_HTTP_VERSION_1_1, CURLOPT_CUSTOMREQUEST => 'POST', CURLOPT_POSTFIELDS =>'{ "url":"https://backend.com/updatehook" }', CURLOPT_HTTPHEADER => array( 'Authorization: Bearer [token]', 'Content-Type: application/json' ), ));

$response = curl_exec($curl);

curl_close($curl); echo $response;


var axios = require('axios');
var data = JSON.stringify({
  "url": "https://backend.com/updatehook"
});

var config = { method: 'post', url: 'https://dev.paycode.com.mx/Api/v2/qr/actualizar_url', headers: { 'Authorization': 'Bearer [token]', 'Content-Type': 'application/json' }, data : data };

axios(config) .then(function (response) { console.log(JSON.stringify(response.data)); }) .catch(function (error) { console.log(error); });

Este es un ejemplo de respuesta satisfactoria del endpoint, La respuesta del mismo esta en formato JSON.

{
    "success": true,
    "data": "Se actualizo correctamente",
}

Este es un ejemplo de respuesta rechazada del endpoint, La respuesta del mismo esta en formato JSON.

{
    "success": false,
    "data": "Ocurrio un error",
}

Recupera un token nuevo usando el token actual, siempre y cuando no se halla expirado.

Información de petición
Categoria Valor
Método HTTP POST
EndPoint Api/v2/qr/actualizar_url
Headers
Tipo Valor
Authorization Bearer [token]
Content-Type application/json
Esquema de entrada de la petición

El contenido del esquema debe de estar en formato JSON.

Campo Tipo de dato Requerido Definición
url String True URL a la que se enviarán las actualizaciones de los cobros.
Esquema de salida de una petición satisfactoria
Campo Tipo de dato Definición
succes Boolean Respuesta de la petición
data String Mensaje de respuesta
Esquema de salida de una petición no satisfatoria
Campo Tipo de dato Definición
error String Identificador de error

Errores

Codigo de errores Definición
400 Bad Request -- Petición no valida.
401 Unauthorized -- Claves de login incorrectas.
403 Forbidden -- No tiene permisos necesarios para este Endpoint.
404 Not Found -- URL no valida.
405 Method Not Allowed -- Verbo HTTP no valido.
Codigo de errores Definición
500 Internal Server Error -- Problema con el servidor.
503 Service Unavailable -- Temporalmente fuera de servicio .
Codigo de errores Definición
-10 Número celular requerido
-11 Número de cel. tiene que ser numérico
-12 Número de cel. tiene que tener 10 caracteres
-13 Recurrencia del pago requerida
-14 Recurrencia no puede ser numérica
-15 Recurrencia supera los 30 caracteres
-16 Concepto requerido
-17 Concepto supera los 40 caracteres
-18 Fecha límite requerida
-19 Formato de fecha límite incorrecto
-20 Nombre requerido
-21 Nombre no puede contener caracteres numéricos
-22 Nombre supera los 40 caracteres
-23 Apellido paterno requerido
-24 Apellido paterno no puede contener caracteres numéricos
-25 Apellido paterno supera los 40 caracteres
-26 Apellido materno requerido
-27 Apellido materno no puede contener caracteres numéricos
-28 Apellido materno supera los 40 caracteres
-29 Monto requerido
-30 Monto tiene que ser numérico
-31 Monto supera la cantidad de 8000
-41 Monto requerido
-42 Monto tiene que ser de tipo númerico
-43 Monto supera la cantidad de 8000
-44 Concepto requerido
-45 Concepto tiene más de 40 caracteres
-46 Fecha requerida
-47 Error en el formato de la fecha
-48 Tipo de pago requerido
-49 Tipo de pago tiene que ser numerico
-50 Pago tiene que ser opción 0 o 1
-51 Referencia requerida
-52 Referencia tiene que ser tipo númerico
-53 Referencia tiene que tener 7 caracteres
-61 Numero de cel. requerido
-62 Número de cel. tiene que ser numérico
-63 Número de cel. tiene que tener 10 caracteres
-64 Monto requerido
-65 Monto tiene que ser numérico
-66 Monto supera la cantidad de 8000
-67 Concepto requerido
-68 Concepto supera los 40 caracteres
-69 Fecha límite es requerida
-70 Formato de fecha límite incorrecto
-71 Nombre requerido
-72 Nombre no puede contener caracteres númericos
-73 Nombre supera los 40 caracteres
-74 Apellido paterno requerido
-75 Apellido paterno no puede contener caracteres númericos
-76 Apellido paterno supera los 40 caracteres
-77 Apellido materno requerido
-78 Apellido materno no puede contener caracteres númericos
-79 Apellido materno supera los 40 caracteres
-90 Clave de rastreo requerida
-91 Clave de rastreo supera 40 caracteres
-92 Referencia de pago requerida
-93 Referencia de pago supera los 40 caracteres