Diferencia entre revisiones de «API BI Cartera»

De WikiSerpi
Ir a la navegación Ir a la búsqueda
Sin resumen de edición
Sin resumen de edición
Línea 1: Línea 1:
'''Descripción:'''
'''Descripción:'''
Este conjunto de APIs esta dispuesto con el fin de consultar, agregar y modificar los datos correspondientes
PENDIENTE


'''Autorización:'''
'''Autorización:'''
Línea 6: Línea 6:


'''Beneficio:'''
'''Beneficio:'''
Este API permite.
PENDIENTE


'''Tipos de peticiones:'''
'''Tipos de peticiones:'''
GET,  
GET, POST, PUT


'''¿Cómo funciona?'''
'''¿Cómo funciona?'''
*Tenga en cuenta que un mismo token no puede ser consumidos de manera simultanea, por lo cual puede programar que la siguiente API sea consumida cuando el resultado de la anterior sea exitoso.
PENDIENTE
*En términos de tiempo, para hacer seguimiento a su operación puede hacer un consumo cada 5 minutos de la información.


== Métodos ==
== Métodos ==
<Tabs>
<Tabs>
<!-- ***************** GET ****************** -->
<!-- ************************************************************** GET ********************************************************************** -->
<Tab name = "API Consulta (GET)  ">
<Tab name = "API Consulta (GET)  ">
'''GET/users'''


'''EndPoint:'''
'''EndPoint:'''
https://localhost:44305/api/v1/BICartera
https://www.apis.serpi.com.co/api/v1/Pais


'''EndPoint con parámetros:'''
{| class="wikitable"
https://www.apis.serpi.com.co/api/v1/BICartera?centroopeid=1&terceroid=10707&cuentaid=2358&fechacorte=2023-12-31&cuenta=2815&grupo=28&limite=100&pagina=1
|+ Headers
 
|-
''' Headers '''
{| class="wikitable left"
! Header !! Descripción  
! Header !! Descripción  
|-
|-
Línea 35: Línea 31:


'''Authorization:'''
'''Authorization:'''
<syntaxhighlight line="1">
<syntaxhighlight >
Usar Bearer. Ejemplo “bearer {{token}}”.
Usar Bearer. Ejemplo “bearer {{token}}”.
{{token}} Token de autorizacion generado por SerpiERP
{{token}} Token de autorizacion generado por SerpiERP
</syntaxhighlight>
</syntaxhighlight>


'''Parámetros'''
{| class="wikitable"
{| class="wikitable"
|+ Parámetros
|-
! Parámetro !! Tipo de dato !! Requerido !! Descripción
! Parámetro !! Tipo de dato !! Requerido !! Descripción
|-
|-
Línea 47: Línea 44:
|-
|-
| Página || int || No || Este parámetro indica el número de la página que se debe devolver. Por ejemplo, si se establece en 3, se devolverán los resultados de la tercera página
| Página || int || No || Este parámetro indica el número de la página que se debe devolver. Por ejemplo, si se establece en 3, se devolverán los resultados de la tercera página
|}
'''Response'''
<syntaxhighlight lang="JSON">
{
    "success": true,
    "code": 200,
    "errors": null,
    "message": "1 registro(s) encontrados",
    "result": [
        {
            "id": 1,
            "nombre": "COLOMBIA",
            "codigo": "57",
            "codigo_alfa": "CO"
        }
]
}
{
"success": true
"code": 201,
"message": "No se encontraron registros",
"result": []
}
</syntaxhighlight>
{| class="wikitable"
|+ Campos de resultados
|-
! Campo !! Tipo de dato !! Descripción
|-
|-
| centroopeid|| int || No || Cedula o nit del tercero a filtrar
| id || int || Identificador del país
|-
|-
| terceroid|| int|| No || Fecha inicial para filtrar por fecha de creación del tercero
| nombre || string  || Nombre del país
|-
|-
| cuentaid|| int|| No || Fecha final para filtrar por fecha de creación del tercero
| codigo || string || Código del país
|-
|-
| fechacorte|| Date || No || Fecha final para filtrar por fecha de creación del tercero
| codigo_alfa || string || Nomenclatura del país
|}
</Tab>
 
<!-- ************************************************************** POST ********************************************************************** -->
<Tab name = "API Creación (POST) ">
'''EndPoint:'''
https://www.apis.serpi.com.co/api/v1/Pais
 
{| class="wikitable"
|+ Headers
|-
|-
| cuenta|| Date || No || Fecha final para filtrar por fecha de creación del tercero
! Header !! Descripción
|-
|-
| grupo|| Date || No || Fecha final para filtrar por fecha de creación del tercero
| secretkey || Secretkey proporcionada al cliente para consumos de las APIs
|}
|}


'''Response'''
'''Authorization:'''
<syntaxhighlight lang="JSON" line="1">
<syntaxhighlight>
Usar Bearer. Ejemplo “bearer {{token}}”.
{{token}} Token de autorizacion generado por SerpiERP
</syntaxhighlight>
 
 
'''Request'''
<syntaxhighlight lang="JSON">
{
{
"success": true
  "nombre": "PAIS DEMO",
"code": 200,
  "codigo": "1",
"message": "x registro(s) encontrados",
  "codigo_alfa": "PD"
"result": [
}
{
</syntaxhighlight>
            "id": 1,
 
            "tipoidentidad": "CC",
 
            "identificacion": "123456789",
{| class="wikitable"
            "dv": 0,
|+ Campos del request
            "tipopersona": 2,
|-
            "primernombre": "PEDRO",
! Campo !! Tipo de dato !! Longitud !! Requerido !! Descripción
            "segundonombre": "LUIS",
|-
            "primerapellido": "PEREZ",
| nombre || string || 45 || Si || Nombre del país
            "segundoapellido": "LOPEZ",
|-
            "nombrecompleto": "PEDRO LUIS PEREZ LOPEZ",
| codigo || string || 3 || Si || Código del país
            "razonsocial": null,
|-
            "escliente": true,
| codigo_alfa || string || 5 || No || Nomenclatura del país
            "esproveedor": true,
|}
            "esempleado": false,
 
            "esvendedor": false,
==== '''AVISO IMPORTANTE:''' ====
            "esotro": false,
Donde los '''campos no sean obligatorios''' y no se desea asignar algún valor, pruebe digitando '''null''' o '''0''' en los valores de los campos de tipo numérico (int o double). Si es un campo de tipo string no obligatorio, siempre digite '''null'''.
            "escobrador": false,
            "cumple_dia": 0,
            "cumplea_mes": 0,
            "cumplea_ano": 0,
            "genero": "N",
            "direccion": "CRA 1 25 05",
            "direccion2": null,
            "telefono": null,
            "ext": 0,
            "movil": null,
            "pais": "COLOMBIA",
            "departamento": "VALLE",
            "ciudad": "SANTIAGO DE CALI",
            "codciudad": "76001",
            "zona": 0,
            "email": "prueba@mail.com",
            "activo": true,
            "cupocredito": 0.00,
            "periodopago": 0,
            "codigociiu": null,
            "descuentoventa": 0,
            "categoriatercero": 1,
            "formapago": 0,
            "listaprecios": 2,
            "grupoventas": 1,
            "grupocompras": 2,
            "vendedor": 0,
            "cobrador": 0,
            "fechacreacion": "2020-01-04 10:16:30",
            "regimen": 2,
            "banco": 0,
            "tipo_cuenta": null,
            "cuenta_bancaria": null,
            "limite_credito": 0.00000,
            "camposPersonalizados": {
                "ACTIVIDADECONOMICAMUNICIPAL": "BC44",
                "Comentarios": "Cliente proveedor de software",
                "Comuna": 11,
                "FechaAniversario": "2016-06-01",
                "ClienteNacional": true,
                "Ranking": "2",
                "TieneAsesor": "N",
                "Vetado": "3",
                "TipodeEmpresa": [
                    "b",
                    "c"
                ],
                "continente": ""
            }


]
}


'''Response'''
<syntaxhighlight lang="JSON">
{
{
     "success": true,
     "success": true,
     "code": 204,
     "code": 201,
     "message": "No se encontraron registros",
    "errors": null,
     "message": "registro creado exitosamente"
}
}
</syntaxhighlight>


'''Validaciones'''
<syntaxhighlight lang="JSON">
{
{
     "success": false,
     "success": false,
     "code": 400,
     "code": 400,
     "message": "El formato de las fechas es invalido. Ejemplo 2023-12-31",
    "errors": null,
     "message": "El codigo del pais ya existe"
}
}
</syntaxhighlight>
</Tab>


<!-- ************************************************************** PUT ********************************************************************** -->
<Tab name = "API Modificar(PUT) ">
'''EndPoint:'''
https://www.apis.serpi.com.co/api/v1/Pais
{| class="wikitable"
|+ Headers
|-
! Header !! Descripción
|-
| secretkey || Secretkey proporcionada al cliente para consumos de las APIs
|}
'''Authorization:'''
<syntaxhighlight>
Usar Bearer. Ejemplo “bearer {{token}}”.
{{token}} Token de autorizacion generado por SerpiERP
</syntaxhighlight>
</syntaxhighlight>




'''Request'''
<syntaxhighlight lang="JSON">
{
  "id": 1,
  "nombre": "PAIS DEMO",
  "codigo": "1",
  "codigo_alfa": "PD"
}
</syntaxhighlight>




{| class="wikitable"
|+ Campos del request
|-
! Campo !! Tipo de dato !! Longitud !! Requerido !! Descripción
|-
| id || int || 11 || Si || Identificador del país
|-
| nombre || string || 45 || Si || Nombre del país
|-
| codigo || string || 3 || Si || Código del país
|-
| codigo_alfa || string || 5 || No || Nomenclatura del país
|}
==== '''AVISO IMPORTANTE:''' ====
Donde los '''campos no sean obligatorios''' y no se desea asignar algún valor, pruebe digitando '''null''' o '''0''' en los valores de los campos de tipo numérico (int o double). Si es un campo de tipo string no obligatorio, siempre digite '''null'''.
'''Response'''
<syntaxhighlight lang="JSON">
{
    "success": true,
    "code": 200,
    "errors": null,
    "message": "registro modificado exitosamente"
}
{
    "success": false,
    "code": 204,
    "errors": null,
    "message": "No se encontraron registros con el id X"
}
</syntaxhighlight>
'''Validaciones'''
<syntaxhighlight lang="JSON">
{
    "success": false,
    "code": 400,
    "errors": [
        "El campo id es obligatorio"
    ],
    "message": "Se presentaron errores al modificar el registro"
}
</syntaxhighlight>
</Tab>
</Tabs>


== Códigos de estado HTTP ==
== Códigos de estado HTTP ==
Línea 178: Línea 255:
| 503 || El servidor no está disponible actualmente debido a una sobrecarga o mantenimiento temporal
| 503 || El servidor no está disponible actualmente debido a una sobrecarga o mantenimiento temporal
|}
|}


== ¿Cómo consumir la API? ==
== ¿Cómo consumir la API? ==
Línea 192: Línea 268:
RequestBody body = RequestBody.create(mediaType, "");
RequestBody body = RequestBody.create(mediaType, "");
Request request = new Request.Builder()
Request request = new Request.Builder()
   .url("https://localhost:44305/api/v1/Tercero")
   .url("https://localhost:44305/api/v1/Pais")
   .method("GET", body)
   .method("GET", body)
   .addHeader("secretkey", "{{secret key}}")
   .addHeader("secretkey", "{{secret key}}")
Línea 205: Línea 281:
<syntaxhighlight lang="c#">
<syntaxhighlight lang="c#">
var client = new HttpClient();
var client = new HttpClient();
var request = new HttpRequestMessage(HttpMethod.Get, "https://localhost:44305/api/v1/Tercero");
var request = new HttpRequestMessage(HttpMethod.Get, "https://localhost:44305/api/v1/Pais");
request.Headers.Add("secretkey", "{{secret key}}");
request.Headers.Add("secretkey", "{{secret key}}");
request.Headers.Add("Authorization", "Bearer{{token}}");
request.Headers.Add("Authorization", "Bearer{{token}}");
Línea 222: Línea 298:
require_once 'HTTP/Request2.php';
require_once 'HTTP/Request2.php';
$request = new HTTP_Request2();
$request = new HTTP_Request2();
$request->setUrl('https://localhost:44305/api/v1/Tercero');
$request->setUrl('https://localhost:44305/api/v1/Pais');
$request->setMethod(HTTP_Request2::METHOD_GET);
$request->setMethod(HTTP_Request2::METHOD_GET);
$request->setConfig(array(
$request->setConfig(array(
Línea 229: Línea 305:
$request->setHeader(array(
$request->setHeader(array(
   'secretkey' => '{{secret key}}',
   'secretkey' => '{{secret key}}',
   'Authorization' => 'Bearer{{token}}'
   'Authorization' => 'Bearer {{token}}'
));
));
$request->setBody('');
$request->setBody('');

Revisión del 12:07 11 dic 2023

Descripción: PENDIENTE

Autorización: Se requiere autenticación para todas las solicitudes. Las credenciales de autenticación deben ser incluidas en la cabecera de todas las solicitudes a través del campo Authorization utilizando el token de acceso entregado SERPI ERP.

Beneficio: PENDIENTE

Tipos de peticiones: GET, POST, PUT

¿Cómo funciona? PENDIENTE

Métodos

<Tabs> <Tab name = "API Consulta (GET) ">

EndPoint: https://www.apis.serpi.com.co/api/v1/Pais

Headers
Header Descripción
secretkey Secretkey proporcionada al cliente para consumos de las APIs

Authorization:

Usar Bearer. Ejemplo “bearer {{token}}”.
{{token}} Token de autorizacion generado por SerpiERP
Parámetros
Parámetro Tipo de dato Requerido Descripción
Límite int No Este parámetro indica la cantidad de resultados que se deben devolver en una sola página
Página int No Este parámetro indica el número de la página que se debe devolver. Por ejemplo, si se establece en 3, se devolverán los resultados de la tercera página

Response

{
    "success": true,
    "code": 200,
    "errors": null,
    "message": "1 registro(s) encontrados",
    "result": [
        {
            "id": 1,
            "nombre": "COLOMBIA",
            "codigo": "57",
            "codigo_alfa": "CO"
        }
	]
}

{
	"success": true
	"code": 201,
	"message": "No se encontraron registros",
	"result": []
}
Campos de resultados
Campo Tipo de dato Descripción
id int Identificador del país
nombre string Nombre del país
codigo string Código del país
codigo_alfa string Nomenclatura del país

</Tab>

<Tab name = "API Creación (POST) "> EndPoint: https://www.apis.serpi.com.co/api/v1/Pais

Headers
Header Descripción
secretkey Secretkey proporcionada al cliente para consumos de las APIs

Authorization:

Usar Bearer. Ejemplo “bearer {{token}}”.
{{token}} Token de autorizacion generado por SerpiERP


Request

{
  "nombre": "PAIS DEMO",
  "codigo": "1",
  "codigo_alfa": "PD"
}


Campos del request
Campo Tipo de dato Longitud Requerido Descripción
nombre string 45 Si Nombre del país
codigo string 3 Si Código del país
codigo_alfa string 5 No Nomenclatura del país

AVISO IMPORTANTE:

Donde los campos no sean obligatorios y no se desea asignar algún valor, pruebe digitando null o 0 en los valores de los campos de tipo numérico (int o double). Si es un campo de tipo string no obligatorio, siempre digite null.


Response

{
    "success": true,
    "code": 201,
    "errors": null,
    "message": "registro creado exitosamente"
}

Validaciones

{
    "success": false,
    "code": 400,
    "errors": null,
    "message": "El codigo del pais ya existe"
}

</Tab>

<Tab name = "API Modificar(PUT) "> EndPoint: https://www.apis.serpi.com.co/api/v1/Pais

Headers
Header Descripción
secretkey Secretkey proporcionada al cliente para consumos de las APIs

Authorization:

Usar Bearer. Ejemplo “bearer {{token}}”.
{{token}} Token de autorizacion generado por SerpiERP


Request

{
  "id": 1,
  "nombre": "PAIS DEMO",
  "codigo": "1",
  "codigo_alfa": "PD"
}


Campos del request
Campo Tipo de dato Longitud Requerido Descripción
id int 11 Si Identificador del país
nombre string 45 Si Nombre del país
codigo string 3 Si Código del país
codigo_alfa string 5 No Nomenclatura del país

AVISO IMPORTANTE:

Donde los campos no sean obligatorios y no se desea asignar algún valor, pruebe digitando null o 0 en los valores de los campos de tipo numérico (int o double). Si es un campo de tipo string no obligatorio, siempre digite null.


Response

{
    "success": true,
    "code": 200,
    "errors": null,
    "message": "registro modificado exitosamente"
}

{
    "success": false,
    "code": 204,
    "errors": null,
    "message": "No se encontraron registros con el id X"
}

Validaciones

{
    "success": false,
    "code": 400,
    "errors": [
        "El campo id es obligatorio"
    ],
    "message": "Se presentaron errores al modificar el registro"
}

</Tab> </Tabs>

Códigos de estado HTTP

Código Descripción
200 La solicitud ha sido exitosa
201 La solicitud ha tenido éxito y ha llevado a la creación de un recurso
204 La solicitud se ha completado correctamente, pero no hay contenido para devolver en la respuesta
400 El servidor no puede o no procesará la petición debido a algo que es percibido como un error del cliente
401 La solicitud requiere autenticación, pero el cliente no ha proporcionado credenciales válidas o no está autorizado para acceder al recurso
403 El servidor ha entendido la solicitud, pero se niega a cumplirla debido a que el cliente no tiene permisos para acceder al recurso
404 El recurso solicitado no se ha encontrado en el servidor
500 Internal Server Error
503 El servidor no está disponible actualmente debido a una sobrecarga o mantenimiento temporal

¿Cómo consumir la API?

<Tabs>

<Tab name = "Java"> Request

OkHttpClient client = new OkHttpClient().newBuilder()
  .build();
MediaType mediaType = MediaType.parse("text/plain");
RequestBody body = RequestBody.create(mediaType, "");
Request request = new Request.Builder()
  .url("https://localhost:44305/api/v1/Pais")
  .method("GET", body)
  .addHeader("secretkey", "{{secret key}}")
  .addHeader("Authorization", "Bearer{{token}}")
  .build();
Response response = client.newCall(request).execute();

</Tab>

<Tab name = "C#"> Request

var client = new HttpClient();
var request = new HttpRequestMessage(HttpMethod.Get, "https://localhost:44305/api/v1/Pais");
request.Headers.Add("secretkey", "{{secret key}}");
request.Headers.Add("Authorization", "Bearer{{token}}");
var content = new StringContent("", null, "text/plain");
request.Content = content;
var response = await client.SendAsync(request);
response.EnsureSuccessStatusCode();
Console.WriteLine(await response.Content.ReadAsStringAsync());

</Tab>

<Tab name = "PHP"> Request

<?php
require_once 'HTTP/Request2.php';
$request = new HTTP_Request2();
$request->setUrl('https://localhost:44305/api/v1/Pais');
$request->setMethod(HTTP_Request2::METHOD_GET);
$request->setConfig(array(
  'follow_redirects' => TRUE
));
$request->setHeader(array(
  'secretkey' => '{{secret key}}',
  'Authorization' => 'Bearer {{token}}'
));
$request->setBody('');
try {
  $response = $request->send();
  if ($response->getStatus() == 200) {
    echo $response->getBody();
  }
  else {
    echo 'Unexpected HTTP status: ' . $response->getStatus() . ' ' .
    $response->getReasonPhrase();
  }
}
catch(HTTP_Request2_Exception $e) {
  echo 'Error: ' . $e->getMessage();
}

</Tab>

</Tabs>