# Interface de MerchHier - Hierarquia Mercadológica --- ###### 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 hierarquia mercadológica para envio de departamento, classe e subclasse 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 itens na fila AQ etMerchHierFromRMS; 2. Na aplicação RIB rib-zth, o subscriber merchhier_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-MerchHier-AppServiceDecorator; 4. O decorator zth-MerchHier-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 ### createMrchHrDeptDesc; Transformação do payload createMrchrDeptDesc no formato XML para a requisição JSON enviada à Zanthus. ### updateMrchHrDeptDesc; Transformação do payload updateMrchrDeptDesc no formato XML para a requisição JSON enviada à Zanthus. ### deleteMchHrDeptDesc; Transformação do payload deleteMrchrDeptDesc no formato XML para a requisição JSON enviada à Zanthus. ### createMrchHrClsDesc; Transformação do payload createMrchrClsDesc no formato XML para a requisição JSON enviada à Zanthus. ### updateMrchHrClsDesc; Transformação do payload updateMrchrClsDesc no formato XML para a requisição JSON enviada à Zanthus. ### deleteMrchHrClsDesc; Transformação do payload deleteMrchrClsDesc no formato XML para a requisição JSON enviada à Zanthus. ### CreateMrchHrSclsDesc; Transformação do payload createMrchrSclsDesc no formato XML para a requisição JSON enviada à Zanthus. ### updateMrchHrClsDesc; Transformação do payload updateMrchrSclsDesc no formato XML para a requisição JSON enviada à Zanthus. ### deleteMrchHrSclsDesc; Transformação do payload deleteMrchrSclsDesc no formato XML para a requisição JSON enviada à Zanthus. --- ## TRANSFORMAÇÕES As seguintes transformações em XQuery estão configuradas no decorator zth-MerchHier-AppServiceDecorator. Para este fluxo de integração são gerados os seguintes objetos JSON de acordo com a operação executada: **DEPARTAMENTO – objeto que contém os dados da hierarquia mercadológica;** #### MrchHrDeptDescToReplaceDepartamento Esta XQuery recebe como parâmetro de entrada o payload XML createMrchrDeptDesc e o transforma no JSON: DEPARTAMENTO. 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: **CreateMrchrDeptDesc UpdateMrchrDeptDesc** #### MrchHrDeptRefToDeleteDepartamento Esta XQuery recebe como parâmetro de entrada o payload XML MrchrDeptRef definido no arquivo, e o transforma no objeto JSON: DEPARTAMENTO. Esse objeto é encapsulados pelo objeto DELETE, que realiza a delação do dado na Zanthus. Utilizada nas seguintes operações: **deleteMrchrDeptDesc** #### MrchHrClsToReplaceClasse Esta XQuery recebe como parâmetro de entrada o payload XML createMrchrClsDesc, definido no arquivo, e o transforma no objeto JSON: DEPARTAMENTO. Esse objeto é encapsulado pelo objeto REPLACE, que realiza a delação do dado na Zanthus. Utilizada nas seguintes operações: **CreateMrchrClsDesc UpdateMrchrClsDesc** #### MrchHrClsRefToDeleteClasse Esta XQuery recebe como parâmetro de entrada o payload XML MrchrClsRef, definido no arquivo, e o transforma no objeto JSON: DEPARTAMENTO. Esse objeto é encapsulados pelo objeto DELETE, que realiza a delação do dado na Zanthus. Utilizada nas seguintes operações: **DeleteMrchrClsDesc** #### MrchHrSclsToReplaceSubClasse Esta XQuery recebe como parâmetro de entrada o payload XML createMrchrSclsDesc, definido no arquivo, e o transforma no objeto JSON: DEPARTAMENTO. Esse objeto é encapsulado pelo objeto REPLACE, que realiza a delação do dado na Zanthus. Utilizada nas seguintes operações: **CreateMrchrSclsDesc UpdateMrchrSclsDesc** #### MrchHrClsRefToDeleteSubClasse Esta XQuery recebe como parâmetro de entrada o payload XML MrchrSclsRef, definido no arquivo, e o transforma no objeto JSON: DEPARTAMENTO. Esse objeto é encapsulados pelo objeto DELETE, que realiza a delação do dado na Zanthus. Utilizada nas seguintes operações: **deleteMrchrSclsDesc** --- ## 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. --- ## 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 | - ÍndIce: [ToC]