Documentation Mercado Libre
Check out all the necessary information about APIs Mercado Libre.Documentation
Sending tax data
For the automatic invoicing of the items by Mercado Libre, the seller must first send the fiscal data of the products.
Send tax data
First, you must create the fiscal configurations before linking with an item.
Request:
curl -X POST -H 'Authorization: Bearer $ACCESS_TOKEN' -H "Content-Type: application/json" -d
{
"query": "mutation createFiscalInformationMLC($input: CreateFiscalInformationMLCInput!) {\n createFiscalInformationMLC(input: $input) {\n sku\n iva\n description\n ila\n\t\tretention\n\t\ttaxCode\n }\n}",
"variables": {
"input": {
"sku": "String",
"iva": "19",
"description": "String",
"ila": "",
"retention": "14",
"taxCode": "14"
}
}
}
https://api.mercadolibre.com/fiscal_information/graphql
Example:
curl -X POST -H 'Authorization: Bearer $ACCESS_TOKEN' -H "Content-Type: application/json" -d
{
"query": "mutation createFiscalInformationMLC($input: CreateFiscalInformationMLCInput!) {\n createFiscalInformationMLC(input: $input) {\n sku\n iva\n description\n ila\n\t\tretention\n\t\ttaxCode\n }\n}",
"variables": {
"input": {
"sku": "DOCMLC1",
"iva": "19",
"description": "Tacho De Basura Set De 2, Piezas De12 Litros Marca Begonia",
"ila": "",
"retention": "14",
"taxCode": "14"
}
}
}
https://api.mercadolibre.com/fiscal_information/graphql
Response:
{
"data": {
"createFiscalInformationMLC": {
"sku": "DOCMLC1",
"iva": "19",
"description": "Tacho De Basura Set De 2, Piezas De12 Litros Marca Begonia",
"ila": "",
"retention": "14",
"taxCode": "14"
}
}
}
Configure tax data by product/variation
After reporting the fiscal data, link the item through the SKU:
Request:
curl -X POST -H 'Authorization: Bearer $ACCESS_TOKEN' -H "Content-Type: application/json" -d
{
"query": "mutation createFiscalInformationLinkToItem($input: CreateFiscalInformationLinkToItemInput!) {\n createFiscalInformationLinkToItem(input: $input) {\n itemId\n variationId\n type\n components {\n sku\n quantity\n percentageShare\n }\n }\n}",
"variables": {
"input": {
"itemId": "String",
"variationId": "String",
"components": [
{
"sku": "String",
"quantity": 1,
"percentageShare": 100
}
]
}
}
}
https://api.mercadolibre.com/fiscal_information/graphql
Example:
curl -X POST -H 'Authorization: Bearer $ACCESS_TOKEN' -H "Content-Type: application/json" -d
{
"query": "mutation createFiscalInformationLinkToItem($input: CreateFiscalInformationLinkToItemInput!) {\n createFiscalInformationLinkToItem(input: $input) {\n itemId\n variationId\n type\n components {\n sku\n quantity\n percentageShare\n }\n }\n}",
"variables": {
"input": {
"itemId": "MLC1056231867",
"variationId": "175219804700",
"components": [
{
"sku": "DOCMLC1",
"quantity": 1,
"percentageShare": 100
}
]
}
}
}
https://api.mercadolibre.com/fiscal_information/graphql
Response:
{
"data": {
"createFiscalInformationLinkToItem": {
"itemId": "MLC1056231867",
"variationId": "175219804700",
"components": [
{
"sku": "DOCMLC1",
"quantity": 1,
"percentageShare": 100
}
]
}
}
}
When the item is unique, the variation_id field will be null.
Send and configure fiscal data by product/variation
You can also send the tax data and link to the item/variation in a single call:
Request:
curl -X POST -H 'Authorization: Bearer $ACCESS_TOKEN' -H "Content-Type: application/json" -d
{
"query": "mutation($input: CreateOrUpdateFiscalInformationMLCAndLinkToItemInput!) {\n createOrUpdateFiscalInformationMLCAndLinkToItem(input: $input) {\n itemId\n variationId\n type\n components {\n quantity\n percentageShare\n fiscalInformation {\n ... on FiscalInformationMLC {\n sku\n iva\n description\n ila\n retention\n taxCode\n taxDescription\n }\n }\n }\n }\n}\n",
"variables": {
"input": {
"itemId": "String",
"variationId": "String",
"components": [
{
"quantity": 1,
"percentageShare": 100,
"sku": "String",
"iva": "19",
"description": "String",
"ila": "",
"retention": "14",
"taxCode": "14"
}
]
}
}
}
https://api.mercadolibre.com/fiscal_information/graphql
Example:
curl -X POST -H 'Authorization: Bearer $ACCESS_TOKEN' -H "Content-Type: application/json" -d
{
"query": "mutation($input: CreateOrUpdateFiscalInformationMLCAndLinkToItemInput!) {\n createOrUpdateFiscalInformationMLCAndLinkToItem(input: $input) {\n itemId\n variationId\n type\n components {\n quantity\n percentageShare\n fiscalInformation {\n ... on FiscalInformationMLC {\n sku\n iva\n description\n ila\n retention\n taxCode\n taxDescription\n }\n }\n }\n }\n}\n",
"variables": {
"input": {
"itemId": "MLC1056231867",
"variationId": "175219804700",
"components": [
{
"quantity": 1,
"percentageShare": 100,
"sku": "DOCMLC1",
"iva": "19",
"description": "Tacho De Basura Set De 2, Piezas De12 Litros Marca Begonia",
"ila": "",
"retention": "14",
"taxCode": "14"
}
]
}
}
}
https://api.mercadolibre.com/fiscal_information/graphql
Response:
{
"data": {
"createOrUpdateFiscalInformationMLCAndLinkToItem": {
"itemId": "MLC1056231867",
"variationId": "175219804700",
"type": "SINGLE",
"components": [
{
"quantity": 1,
"percentageShare": 100,
"fiscalInformation": {
"sku": "DOCMLC1",
"iva": "19",
"description": "Tacho De Basura Set De 2, Piezas De12 Litros Marca Begonia",
"ila": "",
"retention": "14",
"taxCode": "14"
}
}
]
}
}
}
Consult all the items associated with the SKU
Request:
curl -X POST -H 'Authorization: Bearer $ACCESS_TOKEN' -H "Content-Type: application/json" -d
{
"query": "query getAllItemsLinkedBySku($sku: String!) {\n getAllItemsLinkedBySku(sku: $sku) {\n itemId\n variationId\n }\n}",
"variables": {
"sku": "teste2"
}
}
https://api.mercadolibre.com/fiscal_information/graphql
Example:
curl -X POST -H 'Authorization: Bearer $ACCESS_TOKEN' -H "Content-Type: application/json" -d
{
"query": "query getAllItemsLinkedBySku($sku: String!) {\n getAllItemsLinkedBySku(sku: $sku) {\n itemId\n variationId\n }\n}",
"variables": {
"sku": "DOCMLC1"
}
}
https://api.mercadolibre.com/fiscal_information/graphql
Response:
{
"data": {
"getAllItemsLinkedBySku": [
{
"itemId": "MLC1056231867",
"variationId": "175219804700"
}
]
}
}
Consult fiscal data by item/variation
You can also search for the information linked to a publication in Mercado Libre:
Request:
curl -X POST -H 'Authorization: Bearer $ACCESS_TOKEN' -H "Content-Type: application/json" -d
{
"query": "query getFiscalInformationsByItem($itemId: String!, $defaultDataIfNotExists: Boolean, $allVariations: Boolean) {\n getFiscalInformationsByItem(itemId: $itemId, allVariations: $allVariations, defaultDataIfNotExists: $defaultDataIfNotExists) {\n itemId\n variationId\n type\n components {\n sku\n quantity\n percentageShare\n fiscalInformation {\n ... on FiscalInformationMLC {\n sku\n iva\n description\n ila\n retention\n taxCode\n taxDescription\n }\n }\n }\n }\n}",
"variables": {
"itemId": "String",
"allVariations": true,
"defaultDataIfNotExists": true
}
}
https://api.mercadolibre.com/fiscal_information/graphql
Example:
curl -X POST -H 'Authorization: Bearer $ACCESS_TOKEN' -H "Content-Type: application/json" -d
{
"query": "query getFiscalInformationsByItem($itemId: String!, $defaultDataIfNotExists: Boolean, $allVariations: Boolean) {\n getFiscalInformationsByItem(itemId: $itemId, allVariations: $allVariations, defaultDataIfNotExists: $defaultDataIfNotExists) {\n itemId\n variationId\n type\n components {\n sku\n quantity\n percentageShare\n fiscalInformation {\n ... on FiscalInformationMLC {\n sku\n iva\n description\n ila\n retention\n taxCode\n taxDescription\n }\n }\n }\n }\n}",
"variables": {
"itemId": "MLC1056231867",
"allVariations": true,
"defaultDataIfNotExists": true
}
}
https://api.mercadolibre.com/fiscal_information/graphql
Response:
{
"data": {
"getFiscalInformationsByItem": [
{
"itemId": "MLC1056231867",
"variationId": "175219804700",
"type": "SINGLE",
"components": [
{
"sku": "DOCMLC1",
"quantity": 1,
"percentageShare": 100,
"fiscalInformation": {
"sku": "DOCMLC1",
"iva": "19",
"description": "Tacho De Basura Set De 2, Piezas De12 Litros Marca Begonia",
"ila": "",
"retention": "14",
"taxCode": "14",
"taxDescription": "Para Facturas de venta del contribuyente."
}
}
]
}
]
}
}
These are the possible ways of doing the search:
- itemId: when the publication has no variation.
- itemId + variationId: when the publication has a variation, to obtain the data only of the requested variations.
- itemId + allVariations: when the publication has variation, to obtain the data of all the variations of this publication.
Update tax data
The resource allows the complete or partial update of the fiscal data of a publication:
Request:
curl -X POST -H 'Authorization: Bearer $ACCESS_TOKEN' -H "Content-Type: application/json" -d
{
"query": "mutation updateFiscalInformationMLC(\n $where: UpdateFiscalInformationMLCWhere!\n $input: UpdateFiscalInformationMLCInput!\n) {\n updateFiscalInformationMLC(where: $where, input: $input) {\n sku\n iva\n description\n retention\n ila\n taxCode\n }\n}",
"variables": {
"where": {
"sku": "String"
},
"input": {
"iva": "19",
"description": "String",
"retention": "14",
"ila": "",
"taxCode": "14"
}
}
}
https://api.mercadolibre.com/fiscal_information/graphql
Example:
curl -X POST -H 'Authorization: Bearer $ACCESS_TOKEN' -H "Content-Type: application/json" -d
{
"query": mutation updateFiscalInformationMLC(
$where: UpdateFiscalInformationMLCWhere!
$input: UpdateFiscalInformationMLCInput!) {
updateFiscalInformationMLC(where: $where, input: $input) {
sku
iva
description
ila
retention
taxCode
}
}
"variables": {
"where": {
"sku": "String"
},
"input": {
"iva": "19",
"description": "New description",
"ila": "",
"retention": "14",
"taxCode": "14"
}
}
{
"query": "mutation updateFiscalInformationMLC(\n $where: UpdateFiscalInformationMLCWhere!\n $input: UpdateFiscalInformationMLCInput!\n) {\n updateFiscalInformationMLC(where: $where, input: $input) {\n sku\n iva\n description\n retention\n ila\n taxCode\n }\n}",
"variables": {
"where": {
"sku": "DOCMLC1"
},
"input": {
"iva": "19",
"description": "New description",
"retention": "14",
"ila": "",
"taxCode": "14"
}
}
}
https://api.mercadolibre.com/fiscal_information/graphql
Response:
{
"data": {
"updateFiscalInformationMLC": {
"sku": "DOCMLC1",
"iva": "19",
"description": "New description",
"ila": "",
"retention": "14",
"taxCode": "14"
}
}
}
To partially update the fiscal data, it is necessary to send only the necessary fields in the variables after the input.
Check if a publication can be billed
This resource allows us to identify if a specific publication has all the necessary data so that our biller can issue the sales invoice. You can search by publication or by variations:
Query by publication:
Request:
curl -X GET -H 'Authorization: Bearer $ACCESS_TOKEN' https://api.mercadolibre.com//can_invoice/items/$ITEM_ID
Example:
curl -X GET -H 'Authorization: Bearer $ACCESS_TOKEN' https://api.mercadolibre.com//can_invoice/items/MLC1984512046
Response:
{
"item_id": "MLC1984512046",
"seller_id": "809726122",
"variation_id": "",
"status": true
}
Query for variation:
Request:
curl -X GET -H 'Authorization: Bearer $ACCESS_TOKEN' https://api.mercadolibre.com//can_invoice/items/$ITEM_IDvariations/$VARIATION_ID
Example:
curl -X GET -H 'Authorization: Bearer $ACCESS_TOKEN' https://api.mercadolibre.com//can_invoice/items/MLB1398143045/variations/$VARIATION_ID
Response:
{
"item_id": "MLC1984512046",
"seller_id": "809726122",
"variation_id": "94754627308",
"status": true
}
The status field indicates whether the post is ready to be billed.