# Interface de Sortimento e Preços
###### Informações:
> Cliente : Grupo Nós
> Criado por : Logic Information Systems - 02/01/2023
> Introdução: Readme para descrever tecnicamente o fluxo de integração de sortimento de items para as lojas e envio de preços com origem no RMS e destino no Zanthus.
## ARQUITETURA
### Visão geral:
1. O RIB publica as mensagens de criação, modificação ou exclusão de lojas na fila AQ etItemLocFromRMS;
2. Na aplicação RIB rib-zth, o subscriber itemLoc_sub lê as mensagens de itens publicadas na fila. O rib-zth envia essas mensagens para o injector do RSB em uma chamada SOAP, passando os seguintes parâmetros:
- family;
- Messagetype;
- businessObjectId;
- retailPayload
3. O injector RibZthToRsbZthRouting-ServicesIntegrationFlow, com base nos dados enviados pelo rib-zth, realiza a chamada à operação correspondente do decorator zth-ItemLoc-AppServiceDecorator;
4. O decorator zth-ItemLoc-AppServiceDecorator trata a mensagem recebida, aplicando os filtros configurados e transformando os dados com base no mapeamento definido. Após realizar a transformação, realiza uma chamada REST à API da Zanthus passando um JSON no body da mensagem.
A API da Zanthus responde à requisição do decorator com um payload no formato JSON. O serviço então converte a resposta para o formato XML e realiza as seguintes validações:
1. Se o HTTP Status retornado é 200 e a resposta não contém pelo menos um nó listaNaoProcessados.
2. Se a resposta não contém um nó resultado ou se esse nó tem um conteúdo diferente de error.
Caso as validações sejam cumpridas, o serviço finaliza com sucesso.
## OPERAÇÕES/FILTROS
As seguintes operações estão configuradas no decorator zth-ItemLoc-AppServiceDecorator. Na seção de Anexos encontram-se arquivos JSON de exemplo gerados em cada operação e enviados para Zanthus.
### createItemLocDesc;
Filtro de integração somente para Lojas; Integração não é realizada para Warehouses.
Consulta ao micro-serviço “rms-item” para verificação de filtros de UDA Venda e Food Service;
Transformação do payload ItemLocDesc no formato XML para a requisição JSON enviada à Zanthus
### updateItemLocDesc;
Filtro de integração somente para Lojas; Integração não é realizada para Warehouses;
Consulta ao micro-serviço “rms-item” para verificação de filtros de UDA Venda e Food Service;
Transformação do payload UpdateItemLocDesc no formato XML para a requisição JSON enviada à Zanthus
### deleteItemLocDesc;
Filtro de integração somente para Lojas; Integração não é realizada para Warehouses;
Consulta ao micro-serviço “rms-item” para verificação de filtros de UDA Venda e Food Service;
Transformação do payload deleteItemLoc no formato XML para a requisição JSON enviada à Zanthus.
## TRANSFORMAÇÕES
As seguintes transformações em XQuery estão configuradas no decorator zth-ItemLoc-AppServiceDecorator.
Para este fluxo de integração são gerados os seguintes objetos JSON de acordo com a operação executada:
**MERCADORIAS – objeto que contém os dados do sortimento do produto;**
**MERCADORIA_TIPO_VENDAS – objeto que contém o sortimento e ativação do produto.**
#### ItemLocDescToReplaceMercadoriaTipoVenda
Esta XQuery recebe como parâmetro de entrada o payload XML ItemLocDesc e o transforma em dois objetos JSON: MERCADORIAS e MERCADORIA_TIPO_VENDA. Esses objetos são encapsulados pelo objeto REPLACE, que realiza a criação ou modificação do dado na Zanthus. Utilizada nas seguintes operações:
**CreateItemlocDesc**
**UpdateItemLocDesc**
#### ItemLocRefToDeleteMercadoriaTipoVenda
Esta XQuery recebe como parâmetro de entrada o payload XML ItemLocRef, definido no arquivo, e o transforma em dois objetos JSON: MERCADORIAS e MERCADORIA_TIPO_VENDA. Esses objetos são encapsulados pelo objeto DELETE, que realiza a delação do dado na Zanthus. Utilizada nas seguintes operações:
**DeleteItemLocRef**
## LOGS
As mensagens que passam por este fluxo de integração são registradas no banco de dados do RSB na tabela **rsb_soainfra.RSB_SERVICE_ACTIVITY.** Nessa tabela podem ser encontrados os payloads das requisições enviadas no formato XML e as respostas retornadas pela API da Zanthus.
Este fluxo também realiza um filtro nas mensagens com base em regras definidas pela área de negócio, com o objetivo de integrar somente os dados necessários para o destino. As mensagens que não atendem às regras estabelecidas são descartadas e registradas no log do domínio do Weblogic rsb_server1-diagnostic.log.
Abaixo um exemplo de mensagem registrada nesse log.
*zth-ItemLoc-AppServiceDecorator - createItemLocDesc operation: Excluded message for item 101 (Items com LOCTYPE W não são integrados)*
## Informações de Software para abertura do decorator
| Softwares | Versão/Ambiente |
| ----------------- |:----------------------- |
| JDeveloper Studio Developer |12.2 Studio - Instalação Local |
| Console Weblogic Grupo Nós | QAS/SDX/PRD |
- Auto-generated Table of Content
[ToC]