Documentation Mercado Envíos
Check out all the necessary information about APIs Mercado Envíos.Documentation
Envíos Turbo
Envíos Turbo is a delivery service that focuses on providing fast shipments in less than three hours. It is designed to serve areas close to the seller and is based on the Flex logistics model. This service aims to offer an extremely fast delivery option, which can be providing a high-quality service to users.
Find more information related to Turbo on the following pages:
- Envíos Flex
- How do you calculate delivery times with Envíos Turbo?
- Frequently Asked Questions about Envíos Turbo
- Take your sales to a new level with Envíos Turbo
- Firt Steps with Envíos Turbo
Coverage areas by country
To be able to offer Envíos Turbo, the seller’s delivery address must be enabled for one of the coverage areas by country:
Country | Coverage |
---|---|
Argentina | - AMBA (Área Metropolitana de Buenos Aires) |
Setting up a test user
To configure the Envíos Turbo functionality for test users, consider:
1. Log in to the account you want to enable Envíos Turbo for.
2. Validate that the user already has Flex Shipping active, as this is a prerequisite.
3. Make sure that the account has active ads in ME2.
4. Check that the account has a Yellow or Green reputation.
5. Make sure you have an email address compatible with your country's coverage area.
6. Set up the shipping address in AMBA.
7. Activate Envíos Turbo on the account by going to "My Profile" > "Sales" > "Sales Preferences".
Once you have completed these steps, you can use Envíos Turbo as a test user.
Check a user’s subscriptions
This endpoint allows checking the subscriptions a user has.
- If the user activates both services, Flex and Turbo, they will have two subscriptions, as Flex is a requirement to access Turbo.
Request:
curl -X GET -H 'Authorization: Bearer $ACCESS_TOKEN' https://api.mercadolibre.com/shipping/flex/sites/$SITE_ID/users/$USER_ID/subscriptions/v1
Example:
curl -X GET -H 'Authorization: Bearer $ACCESS_TOKEN' https://api.mercadolibre.com/shipping/flex/sites/MLA/users/1438865529/subscriptions/v1
Response:
[
{
"id": 111181,
"site_id": "MLA",
"user_id": 1438865529,
"mode": "FLEX",
"configuration_type": {
"coverage": "zone",
"delivery": "custom"
},
"service_id": 736230,
"status": {
"id": "in",
},
"creation_date": "2023-08-02T06:34:40Z"
},
{
"id": 111183,
"site_id": "MLA",
"user_id": 1438865529,
"mode": "TURBO",
"configuration_type": {
"coverage": "radius",
"delivery": "accurate"
},
"service_id": 738216,
"status": {
"id": "in",
},
"creation_date": "2023-08-02T06:35:30Z"
}
]
Response parameters:
- id unique subscription ID.
- site_id country identifier.
- user_id user ID.
- mode type of subscription (TURBO in this case)
- configuration_type type of subscription settings (TURBO in this case).
- configuration_type.coverage type of coverage.
- configuration_type.delivery type of delivery.
- service_id service ID associated with the subscription.
- status status of the subscription.
- status.id: status types of the subscription:
- in: The subscription is active. In this status the user can change their settings and will receive shipment orders for the subscription mode.
- out: The subscription is not active. In this status the user cannot change the settings.
- pending: The subscription is pending activation. In this status the user can change his settings although they will not receive orders for shipments.
- creation_date date of the subscription creation.
Response status codes:
Code | Message | Description | Recommendation |
---|---|---|---|
200 - OK | - | Settings were successfully updated. | - |
400 - Bad Request | empty site id | The site_id is empty. | Validate the site_id. |
400 - Bad Request | invalid site_id | Invalid site_id. | Validate if the site_id is enabled for Envios Turbo. |
400 - Bad Request | can't access to resource | Invalid site_id. | Validate if the site_id is enabled for Envios Turbo |
404 - Not Found | user not found | The user does not exist. | Validate the user_id. |
Identify Turbo orders
This endpoint determines whether a shipment will be handled by the Turbo service, allowing the transaction to be effectively completed.
Request:
curl -X GET -H 'Authorization: Bearer $ACCESS_TOKEN' https://api.mercadolibre.com/shipments/$SHIPMENT_ID
Example:
curl -X GET -H 'Authorization: Bearer $ACCESS_TOKEN' https://api.mercadolibre.com/shipments/42469883906
Response:
"tags": [
"turbo"
]
Check the subscription settings
This endpoint allows you to check the settings of the subscriptions a user has, in this case of Turbo.
Llamada:
curl -X POST -H 'Authorization: Bearer $ACCESS_TOKEN' https://api.mercadolibre.com/shipping/flex/sites/$SITE_ID/configuration/v3
Ejemplo:
curl -X POST -H 'Authorization: Bearer $ACCESS_TOKEN' https://api.mercadolibre.com/shipping/flex/sites/MLA/configuration/v3
{
"query": "{ configuration(user_id: 1438865529, service_id: 738216) { address { id address_line city { id name } zip_code } subscription { site_id user_id service_id status { id } creation_date training_times { original { value unit } remaining { value unit } activation_date } } delivery_window is_moderated delivery_ranges { week { capacity type processing_time from to et_hour calculated_cutoff } saturday { capacity type processing_time from to et_hour calculated_cutoff } sunday { capacity type processing_time from to et_hour calculated_cutoff } } working_days radius availables { capacity_range { from to } accurate_ranges { from to } radius_range { from to } } disabled_features } }"
}
Response:
{
"configuration": {
"address": {
"address_line": "Testing Street 1450",
"city": {
"id": "TUxBQlNBQTM3Mzda",
"name": "Saavedra"
},
"id": "1316123989",
"zip_code": "1430"
},
"availables": {
"capacity_range": {
"from": 1,
"to": 5
},
"accurate_ranges": [
{
"from": 10
"to": 12
},
{
"from": 11
"to": 13
},
{
"from": 12
"to": 14
},
{
"from": 13
"to": 15
},
{
"from": 14
"to": 16
},
{
"from": 15
"to": 17
},
{
"from": 16
"to": 18
}
],
"radius_range" {
"from": 1,
"to": 5
}
},
"delivery_ranges": {
"saturday": null,
"sunday": null,
"week": [
{
"calculated_cutoff": 10,
"capacity": 5,
"et_hour": null,
"from": 10,
"processing_time": 0,
"to": 12,
"type": "etd"
},
{
"calculated_cutoff": 11,
"capacity": 5,
"et_hour": null,
"from": 11,
"processing_time": 0,
"to": 13,
"type": "etd"
},
{
"calculated_cutoff": 12,
"capacity": 5,
"et_hour": null,
"from": 12,
"processing_time": 0,
"to": 14,
"type": "etd"
},
{
"calculated_cutoff": 13,
"capacity": 5,
"et_hour": null,
"from": 13,
"processing_time": 0,
"to": 15,
"type": "etd"
},
{
"calculated_cutoff": 14,
"capacity": 5,
"et_hour": null,
"from": 14,
"processing_time": 0,
"to": 16,
"type": "etd"
},
{
"calculated_cutoff": 15,
"capacity": 5,
"et_hour": null,
"from": 15,
"processing_time": 0,
"to": 17,
"type": "etd"
},
{
"calculated_cutoff": 16,
"capacity": 5,
"et_hour": null,
"from": 16,
"processing_time": 0,
"to": 18,
"type": "cpt"
}
]
},
"delivery_window": "same_day",
"disabled_features": [],
"is_moderated": false,
"subscription": {
"creation_date": "2023-08-02T06:35:30Z",
"service_id": 738216,
"site_id": "MLA",
"status": {
"id": "in"
},
"training_times": null,
"user_id": 1438865529
},
"working_days": [
"week"
],
"radius": 8000
}
}
Response parameters:
- address: information about the user's address.
- availables: contains information on the capacity, cuts and ranges available for the service.
- availables.capacity_range: range of values for capacity.
- availables.accurate_ranges: turbo time ranges available (at least 3 must be selected by the user).
- availables.radius_range: range of available radiuses in kilometers.
- delivery_ranges: information on available capacity, cuts and ranges for different days of the week.
- delivery_ranges.saturday: delivery ranges and capacity for Saturdays (consider that Turbo is currently not available for Saturdays).
- delivery_ranges.sunday: delivery ranges and capacity for Sundays (consider that Turbo is currently not available for Sundays).
- delivery_ranges.week: delivery ranges and capacity for the days of the week.
- delivery_window: the type of service for delivery. The only possible value for Turbo is "same_day" (same day shipment).
- disabled_features: disabled features for the service including, for example: "CUTOFF_BY_ZONE" and "CAPACITY_BY_DAY".
- is_moderated: indicates whether the service is moderated (true/false).
- subscription: information about the user's subscription.
- working_days: available working days.
- radius: the coverage radius in meters. The coverage is defined by a circle with a center in the direction of the seller and the defined radius.
Response status codes:
Code | Message | Description | Recommendation |
---|---|---|---|
200 - OK | - | The settings were successfully updated. | - |
400 - Bad Request | empty site ID | The site_id is empty. | Validate the site_id. |
400 - Bad Request | invalid site_id | Invalid site_id. | Validate if the site_id is enabled for Envíos Turbo. |
400 - Bad Request | can't access to resource | Invalid site_id. | Validate if the site_id is enabled for Envíos Turbo. |
400 - Bad Request | invalid JSON body | The JSON is invalid. | Validate the established query scheme. |
400 - Bad Request | failed to create schema in graphql operation | Invalid GraphQL for the defined scheme. | Validate the established query scheme. |
400 - Bad Request | invalid query | Invalid GraphQL for the defined scheme. | Validate the established query scheme. |
404 - Not Found | subscriptions not found | No subscription to Envíos Turbo for the combination of user_id and service_id sent. | Validate the user_id and service_id at the endpoint. |
404 - Not Found | user not found | The user doesn’t exist. | Validate the user_id. |
Set delivery time ranges and delivery limits
Through this endpoint, it’s possible to set different aspects for Envíos Turbo such as:
- Delivery time ranges
- Delivery limits
Request:
curl -X PUT -H 'Authorization: Bearer $ACCESS_TOKEN' https://api.mercadolibre.com/shipping/flex/sites/$SITE_ID/users/$USER_ID/services/$SERVICE_ID/configuration/delivery/accurate/v3
Example:
curl -X PUT -H 'Authorization: Bearer $ACCESS_TOKEN' https://api.mercadolibre.com/shipping/flex/sites/MLA/users/1438865529/services/736230/configuration/delivery/accurate/v3
{
"delivery_ranges": {
"week": [
{
"from": 10,
"to": 12,
"capacity": 30
},
{
"from": 11,
"to": 13,
"capacity": 20
},
{
"from": 12,
"to": 14,
"capacity": 10
}
]
}
}
Response parameters:
- delivery_ranges.week: information on delivery range and shipping limit.
- from: beginning of the time range for delivery.
- to: end of the time range for delivery.
- capacity: delivery capacity for the given time range.
Code | Message | Description | Recommendation |
---|---|---|---|
200 - OK | - | The settings were successfully updated. | - |
400 - Bad Request | invalid user_id | Invalid User_id. | Validate the user_id (must be an integer).. |
400 - Bad Request | invalid service_id | Invalid Service_id. | Validate the service_id (must be an integer).. |
400 - Bad Request | invalid JSON body | The JSON is invalid. | Validate the established query scheme. |
404 - Not Found | can't update delivery custom | The settings update could not be performed because there is no Envios Turbo subscription for the user_id and service_id combination submitted. | Validate the user_id and service_id at the endpoint. |
Expand Turbo coverage area
This endpoint allows you to add more coverage areas for Envíos Turbo.
Request:
curl -X PUT -H 'Authorization: Bearer $ACCESS_TOKEN' https://api.mercadolibre.com/shipping/flex/sites/$SITE_ID/users/$USER_ID/services/$SERVICE_ID/configuration/coverage/radius/v3
Example:
curl -X PUT -H 'Authorization: Bearer $ACCESS_TOKEN' https://api.mercadolibre.com/shipping/flex/sites/MLA/users/1438865529/services/736230/configuration/coverage/radius/v3
{
"radius": 8000
}
Response status codes:
Code | Message | Description | Recommendation |
---|---|---|---|
200 - OK | - | The settings were successfully updated. | - |
400 - Bad Request | invalid user_id | Invalid user_id. | Validate the user_id (must be an integer). |
400 - Bad Request | invalid service_id | Invalid service_id. | Validate the service_id (must be an integer). |
400 - Bad Request | invalid JSON body | The JSON is invalid. | Validate the established query scheme. |
404 - Not Found | can't update delivery custom | The settings update could not be performed because there is no Shipping Turbo subscription for the user_id and service_id combination sent. | Validate the user_id and service_id at the endpoint. |
Turbo items management
Item management in Turbo involves the activation of Turbo for those items. In order to achieve this, it is crucial to consider the following:
1. Before activating Turbo, it is necessary to enable Flex.
2. Items with active Flex will be offered by Turbo as long as they meet the dimensional and weight restrictions of Shipping Turbo.
3. Activation is automatic once the prerequisites have been met.