API Documentos Contables/Actividades
Descripción: Esta API permite la sincronización de las actividades de proyectos vinculadas a proyectos entre SERPI y la plataforma que lo requiera, este mismo conjunto de datos en el proceso de facturación es referenciado como Categorias de ´proyectos.
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 Consulta (GET) "> GET/users
EndPoint: https://www.apis.serpi.com.co/api/v1/Actividades
EndPoint con parámetros: https://www.apis.serpi.com.co/api/v1/Actividades?limite=50&pagina=1
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 SerpiERPPará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,
"message": "x registro(s) encontrados",
"result": [
{
"id": 6,
"codigo": "GP",
"actividad": "GASTO PORTUARIO",
"codigoProyecto": 1
}
]
}
{
"success": true
"code": 201,
"message": "No se encontraron registros",
"result": []
}Campo de resultados
| Campo | Tipo de dato | Descripción |
|---|---|---|
| id | int | Corresponde al identificador de la Actividad |
| codigo | string | Codigo de Actividad |
| Actividad | string | Descripcion Actividad |
| codigoProyecto | int | identificador del proyecto correspondiente |
</Tab>
<Tab name = "API Creación (POST) "> POST /users
EndPoint: https://www.apis.serpi.com.co/api/v1/Actividades
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 SerpiERPRequest
{
"codigo": "PRE",
"actividad": "PRUEBA",
"codigoProyecto": 1
}Campos del request
| Campo | Tipo de dato | Longitud | Requerido | Descripción |
|---|---|---|---|---|
| codigo | string | 50 | SI | codigo de Actividad |
| actividad | string | 50 | SI | Descripcion Actividad |
| codigoProyecto | int | 50 | SI | identificador del proyecto correspondiente |
Authorization:
Usar Bearer. Ejemplo “bearer {{token}}”.
{{token}} Token de autorizacion generado por SerpiERPResponse
{
"success": true,
"code": 201,
"errors": null,
"message": "registro creado exitosamente"
}
{
"success": true
"code": 201,
"message": "No se encontraron registros",
"result": []
}</Tab>
<Tab name = "API Modificar(PUT) "> PUT/users
EndPoint: https://www.apis.serpi.com.co/api/v1/Actividades
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 SerpiERPRequest
{
"id": 314,
"codigo": "PRI",
"actividad": "PRUEBA",
"codigoProyecto": 1
}Campos del request
| Campo | Tipo de dato | Longitud | Requerido | Descripción |
|---|---|---|---|---|
| id | int | 50 | SI | identificador de Actividad |
| codigo | string | 50 | SI | codigo de Actividad |
| actividad | string | 50 | SI | Descripcion de Actividad |
| codigoProyecto | int | 50 | SI | identificador del Proyecto |
Authorization:
Usar Bearer. Ejemplo “bearer {{token}}”.
{{token}} Token de autorizacion generado por SerpiERPResponse
{
"success": true
"code": 200,
"message": "registro modificado exitosamente"
}
{
"success": false,
"code": 400,
"errors": [
"El campo abreviatura es obligatorio"
],
"message": "Se presentaron errores al modificar el registro"
}
{
"success": false,
"code": 204,
"errors": null,
"message": "No se encontraron registros con el id xx"
}</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:///www.apis.serpi.com.co/api/v1/Actividades")
.method("GET", body)
.addHeader("secretkey", "{Secret Key}")
.addHeader("Authorization", "{Bearer Token}")
.build();
Response response = client.newCall(request).execute();Response
{
"code": 200,
"error": null,
"msg": "Information found for the current month",
"data": [
{
"operation": "",
"description": "",
"items": "",
"date": ""
}
]
}</Tab>
<Tab name = "Python"> Request
import requests
url = "https://www.apis.serpi.com.co/api/v1/Actividades"
payload = {}
headers = {
'secretkey': '{Secret Key}',
'Authorization': '{Bearer Token}'
}
response = requests.request("GET", url, headers=headers, data=payload)
print(response.text)Response
{
"code": 200,
"error": null,
"msg": "Information found for the current month",
"data": [
{
"operation": "",
"description": "",
"items": "",
"date": ""
}
]
}</Tab>
<Tab name = "Php"> Request
<?php
require_once 'HTTP/Request2.php';
$request = new HTTP_Request2();
$request->setUrl('https://www.apis.serpi.com.co/api/v1/Actividades');
$request->setMethod(HTTP_Request2::METHOD_GET);
$request->setConfig(array(
'follow_redirects' => TRUE
));
$request->setHeader(array(
'secretkey' => '{Secret Key}',
'Authorization' => '{Bearer Token}'
));
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();
}Response
{
"code": 200,
"error": null,
"msg": "Information found for the current month",
"data": [
{
"operation": "",
"description": "",
"items": "",
"date": ""
}
]
}</Tab>
</Tabs>