Versões comparadas

Chave

  • Esta linha foi adicionada.
  • Esta linha foi removida.
  • A formatação mudou.

Objetivo

Este documento tem como objetivo explicar o funcionamento da integração do PRODUTO entre o Winthor e PDVSYNC.

Pré-Requisitos e Restrições

  • Necessário a instalação dos  serviços:
    winthor-integracao-2650
    winthor-integracao-config
  • winthor-integracao-core
  • winthor-tributacao
  • Rotas de lotes de origem configuradas (PDVSYNC - LOTE DE ORIGEM)

Rotas de serviços

Para integração de PRODUTO é necessário cadastrar as seguintes rotas e serviços na rotina 2650:

...

Totvs custom tabs box
tabsRota de busca do PRODUTO, Rota de envio do PRODUTO ao PDVSYNC
idsrota1,rota2

Dados:

JSON
Totvs custom tabs box items
defaultyes
referenciarota1
CAMPOVALORDESCRIÇÃO
ID EmpresaCódigo do Winthor cadastrado em empresa na rotina 2650StatusATIVOAutenticadorNÃOArquitetura

Ordem Execução

4

Tipo de Processo

1-BUSCARID Rota Serviço Código da rota de envio dos PRODUTO ao PDVSYNC
Bloco de código
languagejs
themeEclipsefirstline1
titleLayout de comunicaçãotransformação
[
  {
	"name    "operation": "WTA - Buscar Produto - PDV",
	"request"modify-overwrite-beta",
    "spec": {
		"method      "items": "GET",
		"header{
        "*": [
			{
				"key": "Authorization",
				"value": "Bearer {{TOKEN}}"
			},
			{
				"key": "Accept",
				"value": "*/*"
			}
		],
		"url": {
			"raw": "{{URL_BASE}}/winthor/tributacao/v0/saida/produtotributacao/consultar",
			"query": [
				{
					"key": "pageSize",
					"value": "{{PAGE_SIZE}}"
				},
				{
					"key": "page",
					"value": "{{PAGE}}"
				} ,
   			    {
					"key": "filial",
					"value": "{{FILIAL}}"
				} {
          "produto": {
            "idRetaguarda": "=toString(@(1,codigo))",
            "idExterno": "=concat('pdvsync-produto-', @(1,idRetaguarda),'-',@(1,codfilial),'-',@(1,dtultalter))",
            "codigoProduto": "@(1,idRetaguarda)",
            "codigoFilial": "{{FILIAL_ID_PROPRIETARIO}}",
            "embalagens": {
              "*": {
                "idRetaguarda": "=concat(@(1,codigoDeBarra),'-',@(1,produto))",
                {
					"key"IdProdutoRetaguarda": "dataUltimaAlteracao",
					"value": "{{LAST_CHANGE}}"
				}
			]
		}
	},
	"response": []
}
Bloco de código
languagejs
themeEclipse
titleLayout de transformação
[{
	    "operation": "modify-overwrite-beta",
	    "spec": {
	"=concat(@(3,codigoDeBarra),'-',@(1,produto))",
                "descricao": ["@(1,descricao)", "=concat(@(3,descricao),' - ',@(1,embalagem))"]
           "items": {
	  }
      "*": {
	     }
     "produto": {
	     },
          "idExternoncm": "=concat('pdvsync-produto-', @(1,codigo),'-',@(1,codfilial),'-',@(1,dtultalter))",
	{
            "codigoProduto*": "@(1,codigo)",
	{
              "codigoFilialcodigoNcm_": "{{FILIAL_ID_PROPRIETARIO}}"
	=split('\\.', @(1,codigoNcm))",
               },
	"codigo_Ncm": "=join('', @(1,codigoNcm_))"
           "ncm": {
	}
          },
          "*icms": {
	            "*": {
              "codigoNcm_idRetaguardaIcms": "=split('\\.', concat(@(1,codigoNcmid),'-ICMS')",
	              "codigo_NcmidRetaguardaSt": "=joinconcat('', @(1,codigoNcm_)id),'-ST')",
	               }
	"codigoFilial": "@(3,produto.codfilial)",
           },
	          "icmsfcp": {
	                "*percentualFcp": {
	                  "idRetaguardaIcmsvalor": "=concat(@(1,idvalor),'-ICMS')",
	                  "idRetaguardaStpercentualFcp_": "=concat(split('\\.',@(1,idvalor),'-ST')",
	                  "codigoFilialpercentual_Fcp": "=join(',',@(3,produto.codfilial1,percentualFcp_))"
	                },
	          }
	        }
	"valorBaseFcp": {
      }
	    }
	  },
	  {
	    "operationvalor": "shift=concat(@(1,valor),'')",
	    "spec": {
	      "items": {
	        "*valorBaseFcp_": {
	   "=split('\\.',@(1,valor))",
       //Produto
	           "produtovalorBase_Fcp": {
	"=join(',',@(1,valorBaseFcp_))"
               "idExterno": "idExterno",
	 }
             "codigoProduto": "items.[&2].[0].idRetaguarda",
	 }
            "descricao": "items.[&2].[0].descricao",
	}
          }
  "@(1,produto.unidade.sigla)": "items.[&2].[0].unidadeMedida",
	     }
       "descontoMaximo": "items.[&2].[0].descontoMaximo",
	}
    }
  }
  ,
    "codigo": "items.[&2].[0].codigoProduto",
	       //FILTRAR ICMS e PISCOFINS VALIDOS ID != 0
  {
     "codfilialoperation": "items.[&2].[0].idProprietarioshift",
	     "spec": {
      "items": {
    //    "origemProd*": {
          "produto": "items.[&21].[0].origemProdutoproduto",
          "ncm": "items[&1].ncm",
	            "origemProdpiscofins": {
	              "Nacional*": {
	                "#0codTribPisCofins": "items.[&4].[0].origemProduto"
	{
                },
	"0": { "@2": "piscofins_ignorado[]" },
                "*": {
	                "#1@2": "items.[&45].piscofins[0].origemProduto" }
	              }
	            },
	            //tipoMercadoria
	  },
          "tipoMercadoriaicms": {
	              "PRODUTO_ACABADO*": {
	                "#2id": "items.[&4].[0].tipoProduto"
	   {
           },
	     "0":         "KIT": {
	{ "@2": "icms_ignorado[]" },
                "*": { "#2@2": "items.[&45].icms[0].tipoProduto" }
	              },
	            }
  "MATERIAL_CONSUMO": {
	       }
         "#0": "items.[&4].[0].tipoProduto"
	}
      }
    }
    },
	  {
        "operation": "shift",
    "SERVICOSspec": {
	        "items": {
        "#5*": "items.[&4].[0].tipoProduto"
	{
          //Produto
    },
	               "BOI_CASADOproduto": {
	                "#2"@(1,icms[0].cst)": "items.[&42].[0].tipoProdutocstIcms",
	              }"codigoCest": "items.[&2].cest",
	              "CESTA_BASICAidExterno": {"idExterno",
	                "#2idRetaguarda": "items.[&42].[0].tipoProduto"
	              },
	idRetaguarda",
              "*situacao": {
	              "Inativo": { "#0": "items.[&4].[0].tipoProduto"
	 situacao" }
             },
	             },
	"multiplo": {
               //tipoFracaoProduto
	"valor": "items.[&3].quantidadeMovimentacao"
            "tipoFracaoProduto": {
	  },
            "NAO_ACEITA_FRACIONAMENTOdescricao": {
	 "items.[&2].descricao",
               "#false"@(1,produto.unidade.sigla)": "items.[&42].[0].fracionadounidadeMedida",
	              }"descontoMaximo": "items.[&2].descontoMaximo",
	              "*codigo": {
	 "items.[&2].codigoProduto",
               "#truecodfilial": "items.[&42].[0].fracionadoidProprietario",
	            //  }
	            },
	"origemProd": "items.[&2].origemProduto",
            "cnpjFornecedorcodigoDeBarra": "items.[&2].[0].cnpjFornecedorcodigoAlternativo",
	             },
	"origemProd": {
          //NCM
	    "Nacional": {
                "ncm#0": {
	 "items.[&4].origemProduto"
              },
              "*": {
	                "id#1": "items[&3][0].ncms[&14].idRetaguardaorigemProduto",
	              "@(2,produto.codfilial)": "items.[&3][0].ncms[&1].idProprietario"
	 }
             },
	          },
	          //PISCOFINStipoMercadoria
	            "piscofinstipoMercadoria": {
	              "*PRODUTO_ACABADO": {
	                "codTribPisCofins#5": "items[&3][0].pisCofins[&14].idRetaguardatipoProduto",
	              "@(2,produto.codfilial)": "items.[&3][0].pisCofins[&1].idProprietario"
	},
              "KIT": }{
	          },
	      "#3": "items.[&4].tipoProduto"
   //ICMS/ST
	          "icms": {
	 },
              "*MATERIAL_CONSUMO": {
	                "substituicaoTributaria#1": {
	  "items.[&4].tipoProduto"
              },
              "icmsExternoSERVICOS": {
	                  "valor#6": {
	"items.[&4].tipoProduto"
              },
        "0": {
	     "BOI_CASADO": {
                "@(4,idRetaguardaIcms)":#3": "items[&7][0].impostos[&54].idRetaguarda",
	tipoProduto"
              },
              "CESTA_BASICA": {
                "@(4,codigoFilial)#3": "items[&7][0].impostos[&54].idProprietariotipoProduto"
	                    },
	                    "*": {
	                      "@(4,idRetaguardaSt)"#0": "items[&7][0].impostos[&54].idRetaguardatipoProduto",
	              }
        "@(4,codigoFilial)": "items[&7][0].impostos[&5].idProprietario"
	   },
                 }
	//tipoFracaoProduto
            "tipoFracaoProduto": {
     }
	            "NAO_ACEITA_FRACIONAMENTO": {
    }
	              },
	"#false": "items.[&4].fracionado"
              //FECP},
	              "fcp*": {
	                "id#true": "items.[&4][0].fcps[&2].idRetaguarda",
	fracionado"
              }
  "@(3,produto.codfilial)": "items.[&4][0].fcps[&2].idProprietario",
	          },
            "@(1,fcp.percentualFcp.valor)cnpjFornecedor": "items.[&4][0].fcps[&2].percentualFcpcnpjFornecedor",
	              "embalagens": {
              "@(1,fcp.codigoBeneficioFiscal.valor)": "*": {
                "IdProdutoRetaguarda":"items.[&4][0].fcpsprodutoEmbalagens[&21].codigoBeneficioFiscalIdProdutoRetaguarda",
	                "descontaDesoneracaoNfidRetaguarda": "items.[&4][0].fcpsprodutoEmbalagens[&21].descontaDesoneracaoNfidRetaguarda",
	                "@(1,fcp.valorBaseFcp.valor)descricao": "items.[&4][0].fcpsprodutoEmbalagens[&21].valorBaseFcpdescricao",
	              }
	            }
	"codigoDeBarra": "items.[&4].produtoEmbalagens[&1].codigoBarras",
          }
	        }
	"unidade": {
      }
	    }
	  },
	  {
	    "operationsigla": "default",
	items.[&5].produtoEmbalagens[&2].unidadeMedida"
       "spec": {
	      "_attr_access": "items"  },
	       "items[]": {
	        "*[]fatorConversao": {
	                  "*valor": {
	"items.[&5].produtoEmbalagens[&2].quantidade"
               "idInquilino": "{{ID_INQUILINO}}",
	                "idProprietarioinativo": "{{FILIAL_ID_PROPRIETARIO}}",
	     {
       "loteOrigem": "{{LOTE_ORIGEM}}",
	          "false": { "indiceTributoImpressora#1": "items.[&6].produtoEmbalagens[&3].situacao" },
	            "tipo": 0,
	     "*": {      "situacao#0": 1,
	"items.[&6].produtoEmbalagens[&3].situacao" }
               "escalaRelevante": true,
	 }
             "codigoAlternativo": "654321",
	 }
            "tipoArredondaTrunca": "0"},
	            "cstIcmsprodutoKits": "CST",
	{
              "percentualReducaoIcms*": 0,{
	            "aliquotaIcms": 0,
	       "idRetaguardaProduto":"items.[&4].produtoKits[&1].idRetaguardaProduto",
     "vlicmsret": 0,
	            "cestidRetaguardaProdutoKit": "cestitems.[&4].produtoKits[&1].idRetaguardaProdutoKit",
	                "arredondaTruncadescricao": "0items.[&4].produtoKits[&1].descricao",
            	"descontoMaximo    "quantidadeVendaKit": 99"items.[&4].produtoKits[&1].quantidadeVendaKit",
	            "impostos[]": {
	              "*": {
	    				"tipoValorKit": "items.[&4].produtoKits[&1].tipoValorKit",
				"situacao": "items.[&4].produtoKits[&1].situacao",
				"valorDesconto": "items.[&4].produtoKits[&1].valorDesconto",
				"novoValorUnitario": "items.[&4].produtoKits[&1].novoValorUnitario"
             "idRetaguarda": "0",
	 }
            }	
     "idProprietario": "0"
	              },
	            },
	  //NCM
          "pisCofins[]ncm_old": {
	              "*": {
	                "idRetaguardaid": "0items[&3].ncms[&1].idRetaguarda",
	                "idProprietario"@(2,produto.codfilial)": "0"
	items.[&3].ncms[&1].idProprietario"
            }
          },
	          "ncm": {
   }
	         "*": }
	{
              "id": }
	{
             }
	   "0": }{
	   }
	]

Parametros: 

CHAVEVALORTIPO DE VALOR
{{LAST_CHANGE}}  SELECT 
    TO_CHAR(
        NVL((SELECT MAX(DATACRIACAO) FROM PCINTEGRACAOCORE WHERE IDROTASERVICO = :IDROTASERVICO AND STATUS = 2), TO_DATE('01/01/1900')) -1,
        'RRRR-MM-DD"T"HH24:MI:SS'
    ) DT 
FROM DUAL

SELECT

{{FILIAL}}1STRING
                  "@(2,id)": "ncm_ignorados"
                },
                "*": {
                  "@(2,id)": "items[&5].ncms[&3].idRetaguarda",
                  "@(4,produto.codfilial)": "items.[&5].ncms[&3].idProprietario"
                }
              }
            }
          },
          //PISCOFINS
          "piscofins": {
            "*": {
              "codTribPisCofins": "items[&3].pisCofins[&1].idRetaguarda",
              "@(2,produto.codfilial)": "items.[&3].pisCofins[&1].idProprietario"
            }
          },
          //ICMS/ST
          "icms": {
            "*": {
              "substituicaoTributaria": {
                "icmsExterno": {
                  "valor": {
                    "0": {
                      "@(4,idRetaguardaIcms)": "items[&7].impostos[&5].idRetaguarda",
                      "@(4,codigoFilial)": "items[&7].impostos[&5].idProprietario"
                    },
                    "*": {
                      "@(4,idRetaguardaSt)": "items[&7].impostos[&5].idRetaguarda",
                      "@(4,codigoFilial)": "items[&7].impostos[&5].idProprietario"
                    }
                  }
                }
              },
              //FECP
              "fcp": {
                "id": "items[&4].fcps[&2].idRetaguarda",
                "@(3,produto.codfilial)": "items.[&4].fcps[&2].idProprietario",
                "@(1,fcp.percentualFcp.percentual_Fcp)": "items.[&4].fcps[&2].percentualFcp",
                "@(1,fcp.codigoBeneficioFiscal.valor)": "items.[&4].fcps[&2].codigoBeneficioFiscal",
                "descontaDesoneracaoNf": "items.[&4].fcps[&2].descontaDesoneracaoNf",
                "@(1,fcp.valorBaseFcp.valorBase_Fcp)": "items.[&4].fcps[&2].valorBaseFcp"
              }
            }
          }
        }
      }
    }
        },
  {
    "operation": "default",
    "spec": {
      "_attr_access": "items",
      "items[]": {
        "*": {
          "idInquilino": "{{ID_INQUILINO}}",
          "idProprietario": "{{FILIAL_ID_PROPRIETARIO}}",
          "loteOrigem": "{{LOTE_ORIGEM}}",
          "indiceTributoImpressora": "",
          "tipo": 0,
          "situacao": 1,
          "escalaRelevante": true,
          "codigoAlternativo": "0",
          "tipoArredondaTrunca": "0",
          "cstIcms": "",
          "percentualReducaoIcms": 0,
          "aliquotaIcms": 0,
          "vlicmsret": 0,
          "cest": "",
          "arredondaTrunca": "0",
          "descontoMaximo": 99,
          "impostos[]": {
            "*": {
              "idRetaguarda": "0",
              "idProprietario": "0"
            }
          },
          "pisCofins[]": {
            "*": {
              "idRetaguarda": "0",
              "idProprietario": "0"
            }
          }
        }
      }
    }
       }
  ]



Parametros: 

CHAVEVALORTIPO DE VALOR
{{LAST_CHANGE}}  SELECT 
    TO_CHAR(
        NVL((SELECT MAX(DATACRIACAO) FROM PCINTEGRACAOCORE WHERE IDROTASERVICO = :IDROTASERVICO AND STATUS = 2), TO_DATE('01/01/1900')) -1,
        'RRRR-MM-DD"T"HH24:MI:SS'
    ) DT 
FROM DUAL

SELECT

{{FILIAL}}2STRING
Totvs custom tabs box items
defaultno
referenciarota2


Dados: 

CAMPOVALORDESCRIÇÃO
ID Empresa
Código do Winthor cadastrado em empresa na rotina 2650
StatusATIVO
AutenticadorNÃO
ArquiteturaJSON

Ordem Execução

1

Tipo de Processo

4-ENVIAR
Bloco de código
languagejs
themeEclipse
firstline1
titleLayout de comunicação
{
  "name": "WTA - Buscar Produto - PDV",
  "request": {
    "method": "GET",
    "header": [
      {
        "key": "Authorization",
        "value": "Bearer {{TOKEN}}"
      },
      {
        "key": "Accept",
        "value": "*/*"
      }
    ],
    "url": {
      "raw": "{{URL_BASE}}/winthor/tributacao/v0/saida/produtotributacao/consultar",
      "query": [
        {
          "key": "pageSize",
          "value": "{{PAGE_SIZE}}"
        },
        {
          "key": "page",
          "value": "{{PAGE}}"
        },
        {
          "key": "filial",
          "value": "{{FILIAL}}"
        },
        {
          "key": "dataUltimaAlteracao",
          "value": "{{LAST_CHANGE}}"
        },
        {
          "key": "dataExclusao",
          "value": "{{DATAMENOS60DIAS}}"
        },
        {
          "key": "revenda",
          "value": "{{REVENDA}}"
        },
        {
          "key": "tipoMercadoria",
          "value": "{{TIPOMERCADORIA}}"
        }
      ]
    },
    "bodyraw": ""
  },
  "response": []
}
Totvs custom tabs box items
defaultno
referenciarota2

Dados: 

CAMPOVALORDESCRIÇÃO
ID EmpresaCódigo do Winthor cadastrado em empresa na rotina 2650StatusATIVOAutenticadorNÃOArquiteturaJSON

Ordem Execução

1

Tipo de Processo

4-ENVIAR
Bloco de código
languagejs
themeEclipse
firstline1
titleLayout de comunicação
{
		"name": "PDV-SYNC Salvar Produto",
		"request": {
			"method": "POST",
			"header": [
				{
					"key": "Accept",
					"value": "*/*"
				},
				{
					"key": "Content-Type",
					"value": "application/json"
				}
			],
			"url": {
				"raw": "{{URL_ENVIAR_PRODUTO}}",
				"query": []
			},
			"bodyraw": {{CLIENT_JSON}}
		},
		"response": []
	}	
Bloco de código
languagejs
themeEclipse
titleLayout de transformação
[
	{
		"operation": "default",
		"spec": {
			"status": 2
		}
	}
]


Parâmetros: 

CHAVEVALORTIPO DE VALOR
{{FILIAL_ID_PROPRIETARIO}}Informar IDSTRING
{{ID_INQUILINO}}Informar ID

STRING
{{CLIENT_JSON}}:PCINTEGRACAOCORE.DADOSTRANSFORMADOSSTRING
{{URL_ENVIAR_PRODUTO}}https://pdvsync-core-produto-qa-aadivv24nq-ue.a.run.app/api/retaguarda/produtosSTRING



...