API Formulas
Descripción: Esta API permite la sincronización del agrupador definido como Formulas entre SERPI y la plataforma que lo requiera permitiendo tener un manejo estándar entre las dos Plataformas.
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
¿Cómo funciona?
- El consumo de esta API se realiza por método GET.
- 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 Consulta Tipo de Materiales(GET)">
EndPoint: https://www.apis.serpi.com.co/api/v1/Formula/GetTipoMaterial
| 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á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": "2 registro(s) encontrados",
"result": [
{
"id": 1,
"tipoMaterial": "COMPONENTE"
},
{
"id": 2,
"tipoMaterial": "PRODUCTO SECUNDARIO"
}
]
}
{
"success": true,
"code": 204,
"message": "No se encontraron registros",
}| Campo | Tipo de dato | Descripción |
|---|---|---|
| id | int | Corresponde al identificador del tipo de material |
| tipoMaterial | string | Tipo de Material |
</Tab>
<Tab name = "API Consultar Formulas(GET) ">
EndPoint: https://www.apis.serpi.com.co/api/v1/Formula/ConsultarFormula?limite=10&pagina=1&idArticulo
| 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á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 | Id del articulo a buscar |
Response
{
"success": true,
"code": 200,
"errors": null,
"message": "1 registro(s) encontrados",
"result": [
{
"id": 60,
"idArticulo": 120,
"codigo": "COD1",
"descripcion": "ARTICULO1",
"naturaleza": "E",
"idunidadmedida": 4,
"unidadmedida": "KILOGRAMOS",
"materiales": [
{
"idDetalle": 60,
"idArticulo": 649,
"codigo": "COD60",
"descripcion": "ARTICULO60",
"idTipoMaterial": 1,
"tipoMaterial": "COMPONENTE",
"cantidad": 0.0025,
"idunidadmedida": 3,
"unidadmedida": "UNIDAD"
},
{
"idDetalle": 60,
"idArticulo": 282,
"codigo": "COD2",
"descripcion": "CODIGO2",
"idTipoMaterial": 1,
"tipoMaterial": "COMPONENTE",
"cantidad": 0.003,
"idunidadmedida": 4,
"unidadmedida": "KILOGRAMOS"
}
]
}
]
}
{
"success": true,
"code": 204,
"message": "No se encontraron registros",
}| Campo | Tipo | Descripción |
|---|---|---|
| id | int | Corresponde al id del registro de la formula |
| idArticulo | int | Id del Articulo |
| codigo | string | Codigo del Articulo |
| descripcion | string | Descripcion del Articulo |
| naturaleza | string | E=Ensamble, S=Desemsamble |
| idunidadmedida | int | Id de la unidad de medida |
| unidadmedida | string | Descripcion de la unidad de medida |
| materiales | Array[ObjetoMateriales] | Array de objetos de los materiales de la formula |
ObjetoMateriales
| Campo | Tipo | Descripción |
|---|---|---|
| idDetalle | Int | Corresponde al id del material |
| idArticulo | int | Id del Articulo |
| codigo | string | Codigo del Articulo |
| descripcion | string | Descripcion del Articulo |
| IdTipoMaterial | int | Id del tipo de material |
| TipoMaterial | string | Descripcion del tipo de material |
| cantidad | decimal | Cantidad vendida |
| Idunidadmedida | int | Id de la unidad de medida |
| unidadmedida | string | Descripcion de la unidad de medida |
</Tab>
<Tab name = "API Creación (POST) "> EndPoint: https://www.apis.serpi.com.co/api/v1/Formula
| 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
[
{
"idArticulo": 120,
"naturaleza": "E",
"idunidadmedida": 4,
"materiales": [
{
"idArticulo": 649,
"idTipoMaterial": 1,
"cantidad": 0.0025,
"idunidadmedida": 3
},
{
"idArticulo": 282,
"idTipoMaterial": 2,
"cantidad": 0.003,
"idunidadmedida": 4
}
]
}
]
| Campo | Tipo | Requerido | Descripción |
|---|---|---|---|
| idArticulo | Int | SI | Id del Articulo |
| naturaleza | String | SI | E=Ensamble, S=Desemsamble |
| idunidadmedida | Int | NO | Id de la unidad de medida |
| materiales | Array[ObjetoMateriales] | SI | Array de objetos de los materiales de la formula |
ObjetoMateriales
| Campo | Tipo | Requerido | Descripción |
|---|---|---|---|
| idArticulo | Int | SI | Id del Articulo |
| idTipoMaterial | Int | SI | Id del tipo de material |
| cantidad | decimal | SI | Cantidad vendida |
| idunidadmedida | Int | NO | Id de la unidad de medida |
Response
{
"success": true,
"code": 201,
"errors": [],
"message": "Se crearon 1 de 1 Formulas"
}</Tab>
<Tab name = "API Eliminar(DELETE) "> EndPoint: https://www.apis.serpi.com.co/api/v1/Formula?idFormula
| 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 SerpiERPResponse
{
"success": true,
"code": 200,
"errors": [],
"message": " Se elimino la formula correctamente"
}</Tab> </Tabs>
¿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/Formula")
.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/Formula");
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/Formula');
$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>