API Articulos/Proveedores

De WikiSerpi
Ir a la navegación Ir a la búsqueda

Descripción: Esta API permite la sincronizacion de articulos de proveedores entre SERPI y la plataforma que lo requiera permitiendo tener un manejo estandar entre las dos herramientas.

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:

Tipos de peticiones: GET, POST, PUT

¿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.
  • 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

<Tabs> <Tab name = "API Consultar(GET)"> GET/users

EndPoint: https://www.apis.serpi.com.co/api/v1/ArticuloProveedor?limite=10&pagina=1&idArticulo=2

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
idArticulo int No Identificador del articulo a filtrar

Response

{
    "success": true,
    "code": 200,
    "errors": null,
    "message": "1 registro(s) encontrados",
    "result": [
        {
            "id": 1,
            "idArticulo": 2,
            "descripcion": "ARTICULO1",
            "nitProveedor": "1234567890",
            "codigoProveedor": "101",
            "descripcionProveedor": "ARTICULO UNO",
            "proveedorPredeterminado": true,
            "multiploCompra": 1.00,
            "pedidoMinimo": 1.00000
        }
    ]
}

{
    "success": true,
    "code": 204,
    "message": "No se encontraron registros",
}

Campo de resultados

Campo Tipo Descripción
id int Corresponde al id del registro ArticuloProveedor
idArticulo int Id del artículo al que pertenece el registro
descripcion string Descripción del artículo
nitProveedor string Número de identificación del proveedor
codigoProveedor string Código del artículo del proveedor
descripcionProveedor string Descripción del artículo del proveedor
proveedorPredeterminado bool Indica si es el proveedor predeterminado del artículo
multiploCompra decimal Múltiplo de compra
pedidoMinimo decimal Pedido mínimo

</Tab>

<Tab name = "API Crear(POST)"> POST /users

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

Headers

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

Body:

[
	{
		"idArticulo": 2,
		"nitProveedor": "1234567890",
		"codigoProveedor": "101",
		"descripcionProveedor": "ARTICULO UNO",
		"proveedorPredeterminado": true,
		"multiploCompra": 1.00,
		"pedidoMinimo": 1.00000
    }

]

Campos del request

Campo Tipo Requerido Descripción
idArticulo int SI Id del artículo al que pertenece el registro
nitProveedor string SI Número de identificación del proveedor
codigoProveedor string SI Código del artículo del proveedor
descripcionProveedor string SI Descripción del artículo del proveedor
proveedorPredeterminado bool SI Indica si es el proveedor predeterminado del artículo
multiploCompra decimal NO Múltiplo de compra
pedidoMinimo decimal NO Pedido mínimo



Authorization:

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

Response

{
    "success": true,
    "code": 201,
    "errors": [],
    "message": "Se crearon 10 de 10 articulos proveedores"
}

</Tab>


<Tab name = "API Modificar(PUT)"> PUT/users

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

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

Body:

[
	{
		"id": 1,
		"idArticulo": 2,
		"nitProveedor": "1234567890",
		"codigoProveedor": "101",
		"descripcionProveedor": "ARTICULO UNO",
		"proveedorPredeterminado": true,
		"multiploCompra": 1.00,
		"pedidoMinimo": 1.00000
    }
]

Authorization:

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

Response

{
    "success": true,
    "code": 200,
    "errors": [],
    "message": "Se modificaron 10 de 10 articulos proveedores"
}

</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://apis.serpi.com.co/api/v1/ArticuloProveedor")
  .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://apis.serpi.com.co/api/v1/ArticuloProveedor");
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://apis.serpi.com.co/api/v1/ArticuloProveedor');
$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>