Listar Productos
Permite obtener el listado de productos registrados en el sistema de forma paginada. Este endpoint soporta filtros por código de producto, fecha de creación y fecha de modificación, así como ordenamiento configurable.
Método: GET
Endpoint
Sección titulada «Endpoint»https://api.ventasremotas.com/v1/productsEncabezados de la solicitud
Sección titulada «Encabezados de la solicitud»| Header | Valor | Descripción | Requerido |
|---|---|---|---|
Accept | application/json | Indica que la respuesta debe estar en formato JSON | No |
Subscription-Key | {subscription_key} | Clave de suscripción para acceder a la API | Sí |
Authorization | Bearer {access_token} | Token de acceso obtenido del endpoint /token | Sí |
Parámetros de Consulta (Query Parameters)
Sección titulada «Parámetros de Consulta (Query Parameters)»Todos los parámetros son opcionales. Si no se especifican, se retornan todos los productos con la paginación por defecto.
Filtros
Sección titulada «Filtros»| Parámetro | Tipo | Descripción |
|---|---|---|
code | String | Filtra por código exacto de producto. Longitud máxima: 20 caracteres. |
created_from | Date | Retorna productos cuya fecha de creación es mayor o igual a este valor. Formato: YYYY-MM-DD. |
modified_from | Date | Retorna productos cuya fecha de modificación es mayor o igual a este valor. Formato: YYYY-MM-DD. |
Ordenamiento
Sección titulada «Ordenamiento»| Parámetro | Tipo | Descripción |
|---|---|---|
sort | String | Campo y dirección de ordenamiento. Por defecto: fecha de creación descendente. |
Campos de ordenamiento disponibles
Sección titulada «Campos de ordenamiento disponibles»| Valor | Descripción |
|---|---|
created_at | Ordena por fecha de creación ascendente (ASC) |
-created_at | Ordena por fecha de creación descendente (DESC) |
Paginación
Sección titulada «Paginación»| Parámetro | Tipo | Por defecto | Restricciones | Descripción |
|---|---|---|---|---|
page | Number | 1 | Mínimo: 1 | Número de página (1-indexed) |
limit | Number | 100 | Mínimo: 1, Máximo: 1000 | Cantidad de resultados por página |
Ejemplo de Solicitud
Sección titulada «Ejemplo de Solicitud»Petición básica (sin filtros)
Sección titulada «Petición básica (sin filtros)»curl -X GET "https://api.ventasremotas.com/v1/products" \ -H "Accept: application/json" \ -H "Subscription-Key: tu-subscription-key" \ -H "Authorization: Bearer tu-access-token"Petición con filtro por producto
Sección titulada «Petición con filtro por producto»curl -X GET "https://api.ventasremotas.com/v1/products?code=PROD-001" \ -H "Accept: application/json" \ -H "Subscription-Key: tu-subscription-key" \ -H "Authorization: Bearer tu-access-token"Petición con filtro de fecha y paginación
Sección titulada «Petición con filtro de fecha y paginación»curl -X GET "https://api.ventasremotas.com/v1/products?created_from=2024-01-01&page=1&limit=50" \ -H "Accept: application/json" \ -H "Subscription-Key: tu-subscription-key" \ -H "Authorization: Bearer tu-access-token"Petición con ordenamiento ascendente
Sección titulada «Petición con ordenamiento ascendente»curl -X GET "https://api.ventasremotas.com/v1/products?sort=created_at&page=2&limit=100" \ -H "Accept: application/json" \ -H "Subscription-Key: tu-subscription-key" \ -H "Authorization: Bearer tu-access-token"Petición con múltiples filtros de fecha
Sección titulada «Petición con múltiples filtros de fecha»curl -X GET "https://api.ventasremotas.com/v1/products?created_from=2024-01-01&modified_from=2024-06-01&sort=-created_at&limit=200" \ -H "Accept: application/json" \ -H "Subscription-Key: tu-subscription-key" \ -H "Authorization: Bearer tu-access-token"Ejemplo de Respuesta
Sección titulada «Ejemplo de Respuesta»{ "data": [ { "code": "PROD-001", "description": "Aceite de motor 10W40 1L", "tax": 19.0, "group_code": "GRP-LUBRIC", "family_code": "FAM-ACEITES", "line_code": "LIN-MOTOR", "state": "Y", "charges": 0.0, "business_unit": "AUTOMOTRIZ", "observations": "Producto de alta rotación", "ean": "7701234567890", "volume": 1.0, "weight": 0.95, "reference": "REF-ACE-10W40", "commercial_unit": "CASTROL", "qr_code": null, "transmitted": null, "created_at": "2024-06-15T10:30:00", "updated_at": "2024-09-20T14:15:00" } ], "meta": { "totalItems": 850, "itemCount": 100, "itemsPerPage": 100, "totalPages": 9, "currentPage": 1 }, "links": { "self": "https://api.ventasremotas.com/v1/products?page=1&limit=100", "first": "https://api.ventasremotas.com/v1/products?page=1&limit=100", "prev": null, "next": "https://api.ventasremotas.com/v1/products?page=2&limit=100", "last": "https://api.ventasremotas.com/v1/products?page=9&limit=100" }}Descripción de campos de respuesta
Sección titulada «Descripción de campos de respuesta»Objeto data[] (Producto)
Sección titulada «Objeto data[] (Producto)»Cada elemento del array data contiene los siguientes campos:
| Campo | Tipo | Descripción |
|---|---|---|
code | String | Código de producto asignado desde el ERP |
description | String | Descripción detallada del producto (puede ser null) |
tax | Number | Porcentaje de impuesto asignado al producto, usualmente el IVA |
group_code | String | Primer nivel de jerarquía del producto |
family_code | String | Segundo nivel de jerarquía del producto |
line_code | String | Tercer nivel de jerarquía del producto |
state | String | Determina el estado del producto: Y (activo) o N (inactivo) |
charges | Number | Cargos en valor del producto, usualmente el impoconsumo (puede ser null) |
business_unit | String | Unidad de negocio a la que pertenece (puede ser null) |
observations | String | Observaciones del producto (puede ser null) |
ean | String | Información del código EAN del producto (puede ser null) |
volume | Number | Volumen del producto (puede ser null) |
weight | Number | Peso del producto (puede ser null) |
reference | String | Código referencia del producto (puede ser null) |
commercial_unit | String | Casa comercial a la que pertenece el producto (puede ser null) |
qr_code | String | Código QR del producto (puede ser null) |
transmitted | String | Indica si el producto fue descargado a la interfaz (puede ser null) |
created_at | DateTime | Fecha de creación del producto. Formato: yyyy-MM-ddTHH:mm:ss |
updated_at | DateTime | Fecha de actualización del producto. Formato: yyyy-MM-ddTHH:mm:ss (puede ser null) |
Objeto meta (Metadatos de paginación)
Sección titulada «Objeto meta (Metadatos de paginación)»| Campo | Tipo | Descripción |
|---|---|---|
totalItems | Number | Cantidad total de productos que coinciden con los filtros |
itemCount | Number | Cantidad de productos en la página actual |
itemsPerPage | Number | Cantidad de items por página solicitados |
totalPages | Number | Total de páginas disponibles |
currentPage | Number | Número de la página actual |
Objeto links (Enlaces de navegación)
Sección titulada «Objeto links (Enlaces de navegación)»| Campo | Tipo | Descripción |
|---|---|---|
self | String | URL de la página actual |
first | String | URL de la primera página |
prev | String | URL de la página anterior (null si es la primera página) |
next | String | URL de la página siguiente (null si es la última página) |
last | String | URL de la última página |
Los errores de validación de parámetros de consulta retornan un array de errores, donde cada error indica el parámetro problemático:
Filtro no válido
Sección titulada «Filtro no válido»{ "statusCode": 400, "errors": [ { "param": "invalid_param", "message": "The field is not a valid filter parameter" } ]}Valor de filtro vacío
Sección titulada «Valor de filtro vacío»{ "statusCode": 400, "errors": [ { "param": "code", "message": "Value must not be empty" } ]}Fecha con formato inválido
Sección titulada «Fecha con formato inválido»{ "statusCode": 400, "errors": [ { "param": "created_from", "message": "Value '15-01-2024' is not a valid date (expected format: YYYY-MM-DD)" } ]}Valor excede longitud máxima
Sección titulada «Valor excede longitud máxima»{ "statusCode": 400, "errors": [ { "param": "code", "message": "Value exceeds maximum length of 20" } ]}Campo de ordenamiento inválido
Sección titulada «Campo de ordenamiento inválido»{ "statusCode": 400, "errors": [ { "param": "sort", "message": "The field 'invalid_field' is not a valid sort field." } ]}Parámetro sort vacío
Sección titulada «Parámetro sort vacío»{ "statusCode": 400, "errors": [ { "param": "sort", "message": "The parameter must not be empty" } ]}Parámetro de paginación inválido
Sección titulada «Parámetro de paginación inválido»{ "statusCode": 400, "errors": [ { "param": "page", "message": "The parameter must be a valid integer" } ]}Página menor al mínimo
Sección titulada «Página menor al mínimo»{ "statusCode": 400, "errors": [ { "param": "page", "message": "The parameter must be greater than or equal to 1" } ]}Límite excede el máximo
Sección titulada «Límite excede el máximo»{ "statusCode": 400, "errors": [ { "param": "limit", "message": "The parameter must be less than or equal to 1000" } ]}Límite vacío
Sección titulada «Límite vacío»{ "statusCode": 400, "errors": [ { "param": "limit", "message": "The parameter must not be empty" } ]}Tabla resumen de errores de validación
Sección titulada «Tabla resumen de errores de validación»Errores de filtros:
| Error | Aplica a |
|---|---|
The field is not a valid filter parameter | Cualquier parámetro no reconocido |
Value must not be empty | code |
Value 'X' is not a valid date (expected format: YYYY-MM-DD) | created_from, modified_from |
Value exceeds maximum length of 20 | code |
Errores de ordenamiento:
| Error | Aplica a |
|---|---|
The parameter must not be empty | sort |
The field 'X' is not a valid sort field. | sort |
Errores de paginación:
| Error | Aplica a |
|---|---|
The parameter must not be empty | page, limit |
The parameter must be a valid integer | page, limit |
The parameter must be greater than or equal to 1 | page, limit |
The parameter must be less than or equal to 1000 | limit |
Error de conexión a base de datos
Sección titulada «Error de conexión a base de datos»{ "statusCode": 500, "errors": [ { "message": "Error connecting to database" } ]}Error de operación en base de datos
Sección titulada «Error de operación en base de datos»{ "statusCode": 500, "errors": [ { "message": "Database operation failed" } ]}Error en validaciones
Sección titulada «Error en validaciones»{ "statusCode": 500, "errors": [ { "message": "Unexpected error in the validations" } ]}Error inesperado
Sección titulada «Error inesperado»{ "statusCode": 500, "errors": [ { "message": "Unexpected error" } ]}Error del Servidor
Estos errores indican problemas internos en el servidor o la base de datos. Si persisten, contacta al equipo de soporte.