Documentation Mercado Libre
Check out all the necessary information about APIs Mercado Libre.Documentation
Dynamic Freight
Dynamic Freight is a Mercado Envios 1 functionality that is a feature that speeds up the selection of prices and shipping times for sellers and provides buyers with accurate information on delivery times. This configuration verifies the prices and shipping conditions in real time, and shows the shipping cost before the purchase, improving the experience and logistic efficiency. Also, to correctly register the development of this functionality it is necessary to undergo a homologation process.
Homologation dynamics
Homologation is a process in which Mercado Libre verifies and approves an external URL so that users can register with Mercado Libre from that website in a safe and reliable manner. This involves technical tests, security evaluation and implementing the necessary measures to guarantee the authenticity and protection of users' data. Once approved, the URL becomes a valid channel for ME1 users.
Homologation requirements
Below are the homologation requirements to ensure a successful integration with our dynamic freight platform:
- Compliance with the contract
- Optimal response time
- Infrastructure location
- Specification of the data’s origin and destination
- Use of cache
- Error monitoring
- Mercado Libre contingency
- The URL does not have a specific structure, which provides flexibility in the setup.
- Each request should contain only one item from one seller. This is essential to maintain the efficiency of data transmission.
- Use the HTTP GET method to access the endpoint. This method is suitable for requesting data and is commonly used in web integrations.
- Clearly outline the data source (origin) and the destination system. Understanding these aspects is critical to ensure a smooth and accurate data flow.
- Get familiar with the need to keep the response time below 400 ms and understand its importance for a successful integration.
- Before activating the endpoint, submit it to an initial load validation. This involves evaluating its response time under normal conditions of use.
- If the response time exceeds the limit, corrective actions are required. This may include code and infrastructure review and optimization.
- If the response time meets the 400 ms requirement, the integration is approved and can be activated for sellers.
- Make sure you continue to optimize the response time continuously to deliver an exceptional user experience.
- Consider that the current dynamic freight infrastructure is located in the East region of the United States, specifically in Virginia.
- Evaluate if it is necessary to optimize your application or adjust the settings to make the most of the infrastructure location.
Compliance with the contract
Here is a step-by-step approach to creating the endpoint for homologation:
Optimal response time
This approach is essential to ensure an efficient user experience and to avoid integration problems with sellers, for this purpose:
Infrastructure location
Following these steps, you will be able to make informed decisions to improve the performance of your application based on the infrastructure location:
Data origin and destination
Data source specifications (origin)
The data source specifications are part of the communication protocol or data exchange in the homologation process:
Example by Zip_Code:
{
"seller_id": 337352780,
"buyer_id": 3123212,
"declared_value": 69.9,
"items": [
{
"id": "MLB1223500643",
"variation_id": 0,
"category_id": "ABC1234",
"price": 69.9,
"quantity": 1,
"sku": "RB-PC890A",
"store_id": 231,
"dimensions": {
"height": 10,
"width": 10,
"length": 31,
"weight": 500
}
}
],
"destination": {
"type": "zipcode",
"value": "88063038"
},
"origin": {
"type": "zipcode",
"value": "88063038"
}
}
Example by City:
{
"seller_id": 337352780,
"buyer_id": 3123212,
"declared_value": 69.9,
"items": [
{
"id": "MLB1223500643",
"variation_id": 0,
"category_id": "ABC1234",
"price": 69.9,
"quantity": 1,
"sku": "RB-PC890A",
"store_id": 231,
"dimensions": {
"height": 10,
"width": 10,
"length": 31,
"weight": 500
}
}
],
"destination": {
"type": "city",
"value": "Ñuble/Yungay"
},
"origin": {
"type": "city",
"value": "Metropolitana/Pudahuel"
}
}
Response parameters:
seller_id (string): mandatory. It is the identification of the account within Mercado Libre.
buyer_id (string): Opcional. optional. It is the identification of the user that is buying on Mercado Libre. It is available only when the user that is making the quote is logged in the Mercado Libre platform.
declared_value (float): optional. This is the value that will be declared on the invoice.
items (array): mandatory. Information about the item purchased.
- items.id (string): mandatory. It is the identification of the product registered in Mercado Libre.
- items.variation_id (string): mandatory. It is the identification of the variation chosen by the buyer for the purchase, it has data only when the quote corresponds to an item with variation.
- items.category_id (string): optional. It is the identification of the product category within Mercado Libre.
- items.price (float): optional. It is the unit price of the product multiplied by the number of items chosen by the buyer at the time of the quote.
- items.quantity (int): mandatory. It is the quantity that will be purchased of the same product.
- items.sku (string): mandatory. It is the identification of the product when it is purchased.
- items.store_id (string): optional. It is the identification of the official store within Mercado Libre.
- items.dimensions (object): mandatory. It is the list of measurements of a product.
- items.dimensions.length (float): mandatory. It is the length of the product (in centimeters).
- items.dimensions.width (float): mandatory. It is the width of the product (in centimeters).
- items.dimensions.height (float): mandatory. It is the height of the product (in centimeters).
- items.dimensions.weight (float): mandatory. It is the weight of the product (in grams).
origin (object): optional. It is the information of the address of origin of the delivery or of the seller.
destination (object): mandatory. It is the information of the address where the product will be delivered. Below is the detail according to each country:
Country | Detail |
---|---|
Brazil | Zip Code |
Argentina | Zip Code |
Mexico | Zip Code |
Chile | Region / Commune |
Colombia | Department / Township |
Perú | Department / Province or District |
Uruguay | Department / Township |
Specifications of the destination of the data (destination)
The data destination specifications are part of the communication protocol or data exchange in the homologation process:
Example:
{
"destinations":[
"88063038"
],
"packages":[
{
"dimensions":{
"height":10,
"width":10,
"length":15,
"weight":500
},
"items":[
{
"id":"MLB1223500643",
"variation_id":3123212,
"quantity":1,
"dimensions":{
"height":10,
"width":10,
"length":15,
"weight":500
}
}
],
"quotations":[
{
"price":119.88,
"handling_time":0,
"shipping_time":4,
"promise":4,
"service":99
},
{
"price":0,
"handling_time":0,
"shipping_time":6,
"promise":6,
"service":99
}
]
}
]
}
Response parameters:
destinations (array): information containing zip codes or other identification of destinations to which packages will be sent.
packages (array): information representing the packages created by the vendor.
- packages.dimensions (object): mandatory. It is the list of measurements of the package. items (array): mandatory. Information about the purchased item.
- items.id (string): mandatory. It is the identification of the item registered in Mercado Libre.
- items.variation_id (string): mandatory. It is the identification of the variation chosen by the buyer.
- items.quantity (int): this is the quantity of product to be shipped.
- items.dimensions (object): mandatory. This is the list of item measurements. quotations (array): mandatory. information about the freight for a product.
- quotations.price (float): this is the freight price that will be presented to the buyer.
- quotations.handling_time (int): this is the time, in business days, that will be used to separate and pack the product. It covers all processes prior to the actual shipment of the package. If this information is not available, the value 0 should be returned.
- quotations.shipping_time (int): this is the time, in business days, the package takes in transit (from the time it enters the vehicle to the time it is delivered to the buyer).
- quotations.promise (int): it is the sum of the values of handling_time and shipping_time.
- quotations.service (int) : it is the service/carrier code with unique identification ranging from 0 to 99, assigned by the seller/integrator.
- For error code 3 (no coverage), the HTTP status should be 400 (Incorrect request).
- For any other error code or internal error related to the quote, the HTTP status should be 500 (Internal Server Error).
In the event that an internal error occurs or an item is related to an error, the structure of the response should follow the following format:
Response example:
{
"message": "any message",
"error_code": 1
}
Use of the cache
In this context, RFC IETF 7234 a widely recognized specification that establishes best practices for caching HTTP calls, will be used.
HTTP verbs
In this context, it is essential to align the semantics of our calls with the HTTP protocol, which suggests that only GET calls should be cached.
Headers
Additional headers should be added to calls and responses made to integrators. In the case of calls, the following headers should be added:
Attribute | Description |
---|---|
If-None-Match | Identifier of the resource (quote) in question (header ETag). It is used to check if the resource version is still valid. It is valid if the partner returns HTTP status 304 with no content. Otherwise, it returns a new version of the resource and a new ETag. |
Por otro lado, en las respuestas proporcionadas de los integradores, es necesario incluir los siguientes encabezados adicionales:
Attribute | Description |
---|---|
Cache-Control | Used to specify the directives for the cache of the responses. The directives that you must adapt are:
|
Age | Time in seconds since the resource version became valid. In case this control does not exist by the partners, you must send the value zero (0). |
ETag | Resource version identifier. It is mandatory to use it. |
In order to optimize our responses and reduce the number of calls, the attribute called "destinations" will contain a list of destinations in the form of strings, indicating all the places where the quote can be used. Now, with a single quote, multiple calls can be avoided, significantly improving the efficiency of our APIs.
Here is an example of how the returned ETag header can be checked to determine if the cached response is still valid. Example of a call with cache validation:
Headers | Status | Body |
---|---|---|
- Cache-Control:private;max-age:1000000 - Age:50000 - ETag:0943dc18-a8d7-4508-97a9-ba9221fa |
304 | No Content |
To provide more detailed control over caching, we are introducing the "no-store" directive in the "Cache-Control" header of our responses. This directive allows partners to indicate that a quotation should not be cached.
Example of a response without allowing caching:
Headers | Status | Body |
---|---|---|
- Cache-Control:no-store | 200 | Same body as in the quote reply |
Ejemplo de respuesta con caché:
Headers | Status | Body |
---|---|---|
- Cache-Control:private;max-age:1000000 - Age:0 - ETag:0943dc18-a8d7-4508-97a9-ba9221fa |
200 | Same body as in the quote reply |
Error monitoring
The following is a list of possible errors related to the handling of Dynamic Freight:
Parameter | Description | Possible Solution |
---|---|---|
-1 | This error occurs when the integrator application experiences internal problems that prevent it from functioning properly. As a result, the buyer will receive a quote from the MELI calculator in contingency mode. | In case of an internal error in the integrator application, it is recommended to consider the Contingency Table as a backup plan. When an internal error is detected, the application automatically activates the query to the Contingency Table. |
1 | This error occurs when the product selected by the buyer is not in stock. As a result, it is not possible to calculate a shipping quote for a product that is not in stock. | It is recommended to implement an effective inventory management process or consider showing alternatives of similar products available. |
2 | This error occurs when the destination (zip code, commune, etc.) provided by the buyer is invalid. As a result, an accurate shipping quote cannot be calculated. | When verifying the destination as invalid, the application should query the Contingency Table. If the Contingency Table contains valid information for the destination entered, this information should be used to calculate the shipping quote. |
3 | This error occurs when the product selected by the buyer is not available for delivery to the specified destination. As a result, a shipping quote cannot be calculated. | If the product is not available at the original location, the Contingency Table may contain information on alternative products or alternative delivery locations. |
4 | This error occurs when the application cannot find the product specified by the buyer. This makes it impossible to calculate an accurate shipping quote. | Ensure that the product database is up to date and easily accessible to the application. |
Mercado Libre contingency
The Contingency Table, also known as the Axado Table, is a carrier template that can be uploaded directly from Mercado Libre. Its main function is to act as a backup plan in case the integrator's endpoint or URL fails. In other words, it is a security tool designed to keep the sellers' operation running even when unexpected problems arise.
Here are some criteria to take into account:
- Initial requirement: MELI's Commercial Advisor will request the Contingency Table from the seller when activating the integration with the dynamic freight integrator.
- Seller responsibility: the seller must complete and keep this table updated with the values both in the integrator and in MELI.
- Establish freight rules: it is recommended that the seller establishes clear freight rules, such as zero cost for nearby locations to optimize delivery.
- Easy update: if the seller wants to update the table, they can do so from the “My profile” section, then “Orders”, “Selling preferences” and finally “Carriers”.
In addition, we attach a breakdown by country along with a reference link to the Model Contingency Table:
Country | Details | Link |
---|---|---|
Brazil | Zip code | https://www.mercadolivre.com.br/transportadoras/config |
Argentina | Zip code | https://www.mercadolibre.com.ar/transportadoras/config |
México | Zip code | https://www.mercadolibre.com.mx/transportadoras/config |
Chile | Region / Commune | https://www.mercadolibre.cl/transportadoras/config |
Colombia | Department / Township | https://www.mercadolibre.com.co/transportadoras/config |
Perú | Department / Province or District | https://www.mercadolibre.com.pe/transportadoras/config |
Uruguay | Department / Township | https://www.mercadolibre.com.uy/transportadoras/config |