Para cancelar 100% do pedido e criar um crédito para todos os itens através da API REST do Magento 2, você deve seguir um processo semelhante ao anterior, mas garantindo que todos os itens do pedido sejam incluídos no crédito. Aqui está como você pode fazer isso:
Passo 1: Autenticação
Primeiro, obtenha o token de autenticação, conforme descrito anteriormente:
POST <magento_url>/rest/V1/integration/admin/token
Passo 2: Obtenha as Informações do Pedido
Antes de criar o crédito, você precisa das informações do pedido, incluindo os order_item_id
s e as quantidades dos itens.
GET <magento_url>/rest/V1/orders/<order_id>
Authorization: Bearer your_access_token
Content-Type: application/json
{
"entity_id": 1,
"items": [
{
"item_id": 1,
"qty_ordered": 2,
"product_id": 123,
...
},
...
],
...
}
Passo 3: Criar o Crédito (Credit Memo)
Com as informações do pedido em mãos, você pode criar o crédito incluindo todos os itens do pedido.
POST <magento_url>/rest/V1/creditmemo
{
"entity": {
"invoice_id": <invoice_id>, // O ID da fatura relacionada
"items": [
{
"order_item_id": <order_item_id_1>,
"qty": <qty_ordered_1>
},
{
"order_item_id": <order_item_id_2>,
"qty": <qty_ordered_2>
},
...
],
"shipping_amount": 0,
"adjustment_positive": 0,
"adjustment_negative": 0
},
"appendComment": true,
"comment": {
"comment": "Cancelamento total do pedido",
"is_visible_on_front": 1
},
"isOffline": false,
"notify": true
}
Considerações Importantes:
- Todos os Itens do Pedido: Certifique-se de incluir todos os
order_item_id
s do pedido com a quantidade total (qty
) que foi originalmente solicitada. - invoice_id: Deve ser o ID da fatura contra a qual o crédito será emitido. Se o pedido foi faturado, isso é necessário.
- shipping_amount: Se você deseja reembolsar o valor do frete, coloque o valor correspondente aqui.
- adjustment_positive/negative: Use esses campos se precisar ajustar o valor do crédito para mais ou para menos.
Passo 4: Executar a Chamada da API
Envie a requisição. Se tudo estiver configurado corretamente, o Magento retornará uma resposta com os detalhes do crédito criado, indicando que o cancelamento total do pedido foi processado com sucesso.
{
"entity_id": 1,
"increment_id": "100000001",
"state": 2,
"invoice_id": 1,
"order_id": 1,
"created_at": "2024-08-19 10:00:00",
"updated_at": "2024-08-19 10:00:00",
"grand_total": 200.00,
...
}
Os campos adjustment_positive
e adjustment_negative
na API de geração do creditmemo
no Magento 2 são usados para fazer ajustes manuais no valor total do crédito a ser emitido. Eles permitem que você adicione ou subtraia valores específicos do total do crédito, além dos valores calculados automaticamente com base nos itens do pedido, impostos, e frete. Aqui está o que cada um faz:
1. adjustment_positive
:
Este campo permite adicionar um valor extra ao crédito que está sendo emitido.
- Finalidade: Usado quando você deseja aumentar o valor total do crédito para o cliente por qualquer motivo, como oferecer um reembolso adicional, uma compensação, ou um bônus.
- Valor: Um valor numérico que será adicionado ao total do
creditmemo
.
Exemplo de Uso: Se você quiser adicionar R$ 10,00 ao total do crédito, você configuraria o campo assim:
“adjustment_positive”: 10.00
2. adjustment_negative
:
Este campo permite subtrair um valor do crédito total que está sendo emitido.
- Finalidade: Usado quando você precisa reduzir o valor total do crédito, talvez devido a taxas, fretes não reembolsáveis, ou outro ajuste que precisa ser deduzido do valor total a ser devolvido ao cliente.
- Valor: Um valor numérico que será subtraído do total do
creditmemo
.
Exemplo de Uso: Se você precisar subtrair R$ 5,00 do total do crédito, você configuraria o campo assim:
"adjustment_negative": 5.00
Exemplo Completo de Uso:
Suponha que você queira criar um creditmemo
com um ajuste positivo de R$ 15,00 e um ajuste negativo de R$ 5,00:
{
"entity": {
"invoice_id": 123,
"items": [
{
"order_item_id": 456,
"qty": 1
}
],
"shipping_amount": 0,
"adjustment_positive": 15.00,
"adjustment_negative": 5.00
},
"appendComment": true,
"comment": {
"comment": "Crédito com ajuste",
"is_visible_on_front": 1
},
"isOffline": false,
"notify": true
}
Resultado:
- O
adjustment_positive
adicionará R$ 15,00 ao total do crédito. - O
adjustment_negative
subtrairá R$ 5,00 do total do crédito. - O valor final do
creditmemo
será ajustado de acordo com esses valores, além do valor dos itens, impostos, e quaisquer outros cálculos padrão do Magento.
Estes campos são úteis para cenários em que você precisa de flexibilidade adicional na emissão de créditos, permitindo ajustes específicos de acordo com a política ou situação particular de um pedido.