Requisitos — Remove Recommended Item
Task #194882 · Endpoint DELETE api/payment/v2/{id}/remove-recommended-item
Task pai: #194882 — [Back] 04 - Remover item recomendado Contexto: US 194871 — MVP Upsell (Pedido) Spec tecnica: a ser criada ADRs relacionados: ADR-005 · ADR-007 · ADR-008 · ADR-009
Visão geral
O cliente que adicionou um item recomendado ao pedido via zzlink pode desistir e removê-lo antes de finalizar o pagamento. O endpoint recebe o identificador do item já presente no cart, valida que é um item originado de uma recomendação, remove-o via Cart API e retorna os valores atualizados do pedido para que o front possa atualizar a tela sem recarregar.
Papéis
- Cliente: pessoa que acessa o zzlink para efetuar o pagamento
- Checkout service: orquestrador da operação — valida, chama Cart API, atualiza Payment
- Cart API: responsável por localizar e remover o item do cart e recalcular totais
Requisitos
RF-01 — Receber e validar o contexto do pedido
User Story: Como cliente no zzlink, quero remover um item recomendado que adicionei ao meu pedido, para que ele não seja incluído no pagamento que vou realizar.
Acceptance Criteria:
WHENo cliente chamaDELETE api/payment/v2/{id}/remove-recommended-itemTHENo sistemaSHALLexigir autenticação viaPaymentsScheme(token JWT já presente no zzlink para operações de finalização).WHENo{id}(GUID do payment) não corresponde a nenhum paymentTHENo sistemaSHALLretornar400com mensagem"Payment não encontrado".WHENo payment encontrado é do tipoEcommerce(nãoStore)THENo sistemaSHALLretornar400com mensagem"Operação não disponível para este tipo de pedido".
RF-02 — Validar o item a remover
Acceptance Criteria:
WHENocartItemIdinformado não corresponde a nenhumCartItemno cart vinculado ao paymentTHENo sistemaSHALLretornar400com mensagem"Item não encontrado no pedido".WHENoCartItemencontrado temIsFromRecommendation = falseTHENo sistemaSHALLretornar400com mensagem"Item não pode ser removido".WHENtodas as validações passamTHENo sistemaSHALLprosseguir para a chamada à Cart API.
Dependência: A validação do critério 2 depende da flag
IsFromRecommendationemCartItemsModel, que será adicionada em US separada.
RF-03 — Remover o item via Cart API
Acceptance Criteria:
WHENo sistema chama a Cart API para remover o itemTHENo sistemaSHALLchamarDELETE api/cart/{cartId}/items/{cartItemId}comApiKey "internal".WHENa Cart API retorna sucessoTHENo sistemaSHALLprosseguir para o ajuste doPayment.Total.WHENa Cart API retorna404(item não encontrado)THENo sistemaSHALLretornar400com mensagem"Item não encontrado no pedido"e registrar a falha na alllogs.WHENa Cart API retorna qualquer outro erroTHENo sistemaSHALLretornar400com mensagem"Não foi possível remover o item"e registrar a falha na alllogs.
RF-04 — Atualizar o Payment e retornar o DTO consolidado
Acceptance Criteria:
WHENa Cart API confirma sucessoTHENo sistemaSHALLatualizar sincronamente o campoTotaldoPaymentModelcom o novo total do cart.WHENoPayment.Totalé atualizado com sucessoTHENo sistemaSHALLretornar200com oRemoveRecommendedItemResponseDTOcontendo:values—Valuesrecalculado com o novo totalproducts—List<Product>completa e atualizada dosCartItems(sem o item removido, cada item comcartItemId)paymentMethods—PaymentMethodscom parcelas recalculadas para o novo totalrecommendedItems—List<RecommendedItemsInfoDTO>atualizada
RF-05 — Auditoria (alllogs)
Acceptance Criteria:
WHENo endpoint é chamado com dados válidos de autenticaçãoTHENo sistemaSHALLregistrar na alllogs a tentativa de remover o item (payment GUID, cartItemId).WHENa operação conclui com sucessoTHENo sistemaSHALLregistrar na alllogs o resultado positivo.WHENa operação falha em qualquer etapa (Cart API, atualização do payment, etc.)THENo sistemaSHALLregistrar na alllogs a falha com o motivo.
Contrato do endpoint
Request
DELETE api/payment/v2/{id}/remove-recommended-item
Authorization: Bearer {token PaymentsScheme}
Content-Type: application/json
{
"cartItemId": 0
}
Response 200
{
"values": {
"products": { "value": 0.0, "description": "R$ 0,00", "amount": 0 },
"discount": { "value": 0.0, "description": "R$ 0,00" },
"discountPix": { "value": 0.0, "description": "R$ 0,00" },
"bonus": { "value": 0.0, "description": "R$ 0,00" },
"subtotal": { "value": 0.0, "description": "R$ 0,00" },
"subtotalWhenPix": { "value": 0.0, "description": "R$ 0,00" },
"shipment": { "value": 0.0, "description": "R$ 0,00" },
"total": { "value": 0.0, "description": "R$ 0,00" },
"totalWhenPix": { "value": 0.0, "description": "R$ 0,00" }
},
"products": [
{
"itemId": 0,
"name": "string",
"size": "string",
"amount": 0,
"fullPrice": 0.0,
"price": 0.0,
"total": 0.0,
"url": "string"
}
],
"paymentMethods": {
"creditCard": true,
"pix": { "operator": 0, "key": "string", "discountPercentage": null, "discountValue": null },
"boleto": false,
"installments": [
{ "installment": "1", "value": 0.0, "description": "1x de R$ 0,00" }
],
"isTwoCreditCardsAllowed": false
},
"recommendedItems": [
{
"recommendedItemId": 0,
"productId": "string",
"sku": "string",
"productName": "string",
"description": "string",
"thumbnail": "string",
"images": [],
"fullPrice": 0.0,
"discountValue": 0.0,
"discountType": 0,
"size": "string"
}
]
}
Responses 400
| Cenário | Mensagem |
|---|---|
| Payment não encontrado | "Payment não encontrado" |
| Payment não é do tipo Store | "Operação não disponível para este tipo de pedido" |
cartItemId não encontrado no cart | "Item não encontrado no pedido" |
Item não originado de recomendação (IsFromRecommendation = false) | "Item não pode ser removido" |
| Cart API retornou 404 | "Item não encontrado no pedido" |
| Outro erro da Cart API | "Não foi possível remover o item" |
Dependências
| Dependência | Task | Status |
|---|---|---|
Cart API — endpoint DELETE api/cart/{cartId}/items/{cartItemId} | Task 05 — Cart API: Remove Item | Pendente de refinamento |
Flag IsFromRecommendation em CartItemsModel | US separada (a ser criada) | Pendente |
cartItemId exposto no Product DTO | ADR-008 | Decisao tomada |
Fora de escopo
- Lógica interna da Cart API (remoção do item, recálculo de totais do cart) — responsabilidade da task separada da Cart API
- Adição de item recomendado — task #194882 item 02
- Validação de janela de validade (1h) — não se aplica ao remove; o item já foi aceito e está no cart
Questões abertas
Nenhuma.