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 NCMPRODUTO, Rota de envio do NCM PRODUTO ao PDVSYNC
idsrota1,rota2

Dados:

ID Rota Serviço 
Totvs custom tabs box items
defaultyes
referenciarota1
CAMPOVALORDESCRIÇÃO
ID EmpresaCódigo do Winthor cadastrado em empresa na rotina 2650StatusATIVOAutenticadorNÃOArquiteturaJSON

Ordem Execução

4

Tipo de Processo

1-BUSCAR
Código da rota de envio dos PRODUTO ao PDVSYNC
Bloco de código
languagejs
themeEclipse
firstline1
titleLayout de comunicaçãotransformação
[
  {
	"name    "operation": "WTA - Buscar Produto - PDV",
	"requestmodify-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": "tamanho",
					"value": "{{PAGE_SIZE}}"
				},
				{
					"key": "pagina",
					"value": "{{PAGE}}"
				} ,
{
          "produto": {
            "idRetaguarda": "=toString(@(1,codigo))",
            "idExterno": "=concat('pdvsync-produto-', @(1,idRetaguarda),'-',@(1,codfilial),'-',@(1,dtultalter))",
            "codigoProduto": "@(1,idRetaguarda)",
            "codigoFilial": "{{FILIAL_ID_PROPRIETARIO}}",
            "embalagens": {
              "*": {
             {
					"key   "idRetaguarda": "ultAlter",
					"value": "{{LAST_CHANGE}}"
				}
			]
		}
	},
	"response": []
}
Bloco de código
languagejs
themeEclipse
titleLayout de transformação
 [{
    "operation": "modify-overwrite-beta",
    "spec": {
=concat(@(1,codigoDeBarra),'-',@(1,produto))",
                "IdProdutoRetaguarda":"=concat(@(3,codigoDeBarra),'-',@(1,produto))",
                "itemsdescricao": {
["@(1,descricao)", "=concat(@(3,descricao),' - ',@(1,embalagem))"]
              }
           "*": { }
          },
          "produtoncm": {
            "idExterno*": {
              "=concat('pdvsync-produto-codigoNcm_": "=split('\\.', @(1,codigo),'-',@(1,codfilial),'-',@(1,dtultaltercodigoNcm))",
              "codigoProdutocodigo_Ncm": "=join('', @(1,codigocodigoNcm_))",
            "codigoFilial": "{{FILIAL_ID_PROPRIETARIO}}"
 }
          },
          "ncmicms": {
            "*": {
              "codigoNcm_idRetaguardaIcms": "=split('\\.', concat(@(1,codigoNcmid),'-ICMS')",
              "codigo_NcmidRetaguardaSt": "=joinconcat('', @(1,codigoNcm_)id),'-ST')",
            }
  "codigoFilial": "@(3,produto.codfilial)",
       },
          "icms"fcp": {
                "*percentualFcp": {
                  "idRetaguardaIcmsvalor": "=concat(@(1,idvalor),'-ICMS')",
                  "idRetaguardaStpercentualFcp_": "=concat(split('\\.',@(1,idvalor),'-ST')",
               "codigoFilial":   "{{FILIAL_ID_PROPRIETARIO}}" //"@(3,produto.codfilial)"
percentual_Fcp": "=join(',',@(1,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",
   //FILTRAR ICMS e PISCOFINS VALIDOS ID != 0
  {
    "codigooperation": "items.[&2].[0].codigoProdutoshift",
    "spec": {
       "origemProditems": "items.[&2].[0].origemProduto",{
            //tipoMercadoria"*": {
            "tipoMercadoriaproduto": {"items[&1].produto",
              "PRODUTO_ACABADO": {"ncm": "items[&1].ncm",
                "#ProdutoAcabado"piscofins": "items.[&4].[0].tipoProduto"{
              },"*": {
              "MATERIA_PRIMAcodTribPisCofins": {
                "#MateriaPrima"0": { "@2": "items.[&4].[0].tipoProduto"piscofins_ignorado[]" },
              },  "*": { "@2": "items[&5].piscofins[]" }
              "KIT": {}
            }
    "#Kit": "items.[&4].[0].tipoProduto"
     },
         },
   "icms": {
            "MATERIAL_CONSUMO*": {
                "#Consumoid": "items.[&4].[0].tipoProduto"{
              },
  "0":            "SERVICOS": {
{ "@2": "icms_ignorado[]" },
                "*": { "#Servico@2": "items.[&45].icms[0].tipoProduto" }
              },
            }
   "BOI_CASADO": {
      }
        }
  "#Kit": "items.[&4].[0].tipoProduto"
   }
       }
    },
  {
        "operation": "shift",
    "CESTA_BASICAspec": {
        "items": {
        "#Kit*": "items.[&4].[0].tipoProduto"{
              },//Produto
              "*"produto": {
                "#NãoInformado@(1,icms[0].cst)": "items.[&42].[0].tipoProdutocstIcms",
            "codigoCest":  }
"items.[&2].cest",
             }"idExterno": "idExterno",
            //tipoFracaoProduto"idRetaguarda": "items.[&2].idRetaguarda",
            "tipoFracaoProdutosituacao": {
              "NAO_ACEITA_FRACIONAMENTOInativo": {
                "#false"#0": "items.[&4].[0].fracionado"situacao" }
              },
              "*multiplo": {
                "#truevalor": "items.[&43].[0].fracionadoquantidadeMovimentacao"
              }
            },
            "cnpjFornecedordescricao": "items.[&2].[0].cnpjFornecedordescricao",
          },
  "@(1,produto.unidade.sigla)": "items.[&2].unidadeMedida",
       //NCM
          "ncmdescontoMaximo": {"items.[&2].descontoMaximo",
            "*codigo": {
  "items.[&2].codigoProduto",
            "codigoNcmcodfilial": "items[&3][0].ncms[&12].idRetaguardaidProprietario",
            //  "@(2,produto.codigoFilial)origemProd": "items.[&3][02].ncms[&1].idProprietario"origemProduto",
            }"codigoDeBarra": "items.[&2].codigoAlternativo",
          },
      "origemProd": {
    //PISCOFINS
          "piscofinsNacional": {
                "*#0": {"items.[&4].origemProduto"
              "codTribPisCofins": "items[&3][0].pisCofins[&1].idRetaguarda",
},
              "*": {
                "@(2,produto.codigoFilial)#1": "items.[&3][04].pisCofins[&1].idProprietarioorigemProduto"
              }
            },
            //ICMS/STtipoMercadoria
            "icmstipoMercadoria": {
              "*PRODUTO_ACABADO": {
                "substituicaoTributaria#5": {"items.[&4].tipoProduto"
              },
      "icmsExterno        "KIT": {
                  "valor#3": {"items.[&4].tipoProduto"
              },
        "0": {
     "MATERIAL_CONSUMO": {
                "@(4,idRetaguardaIcms)#1": "items.[&5][04].impostos[&1].idRetaguarda"tipoProduto"
              },
              "SERVICOS": {
                "@(4,codigoFilial)#6": "items[&5][0].impostos[&14].idProprietariotipoProduto"
              },
       },
       "BOI_CASADO": {
                "*#3": {"items.[&4].tipoProduto"
              },
        "@(4,idRetaguardaSt)": "items[&5][0].impostos[&1].idRetaguarda",
     "CESTA_BASICA": {
                "@(4,codigoFilial)#3": "items[&5][0].impostos[&14].idProprietariotipoProduto"
               },
     }
         "*": {
        }
        "#0": "items.[&4].tipoProduto"
              }
              },
              //FECPtipoFracaoProduto
              "fcptipoFracaoProduto": {
                "idNAO_ACEITA_FRACIONAMENTO": "items[&4][0].fcps[&2].idRetaguarda",{
                "@(3,produto.codigoFilial)":#false": "items.[&4][0].fcps[&2].idProprietario",fracionado"
              },
      "percentualFcp        "*": "items.[&4][0].fcps[&2].percentualFcp",{
                "codigoBeneficioFiscal#true": "items.[&4][0].fcps[&2].codigoBeneficioFiscal",.fracionado"
              }
  "descontaDesoneracaoNf": "items.[&4][0].fcps[&2].descontaDesoneracaoNf",
          },
            "valorBaseFcpcnpjFornecedor": "items.[&4][0].fcps[&2].valorBaseFcpcnpjFornecedor",
              }"embalagens": {
            }
          }"*": {
        }
      }
    }
  }  "IdProdutoRetaguarda":"items.[&4].produtoEmbalagens[&1].IdProdutoRetaguarda",
  {
    "operation": "default",
    "spec": {
      "_attr_access"idRetaguarda": "items.[&4].produtoEmbalagens[&1].idRetaguarda",
       "items[]": {
        "*[]descricao": {
   "items.[&4].produtoEmbalagens[&1].descricao",
       "*": {
            "idInquilinocodigoDeBarra": "{{ID_INQUILINO}}items.[&4].produtoEmbalagens[&1].codigoBarras",
                "idProprietariounidade": "{{FILIAL_ID_PROPRIETARIO}}",
            "loteOrigem": "{{LOTE_ORIGEM}}",
     "sigla": "items.[&5].produtoEmbalagens[&2].unidadeMedida"
      "indiceTributoImpressora": "",
         },
   "tipo": 0,
            "situacaofatorConversao": 1,
{
                  "escalaRelevantevalor": true,"items.[&5].produtoEmbalagens[&2].quantidade"
            "valorBaseFcp": 0    },
                "codigoBeneficioFiscalinativo": "AB",{
            "percentualFcp": 1,
            "codigoAlternativo"false": { "#1": "654321"items.[&6].produtoEmbalagens[&3].situacao" },
            "tipoArredondaTrunca": "01",
            "cstIcms": "CST",
 "*": { "#0": "items.[&6].produtoEmbalagens[&3].situacao" }
              "percentualReducaoIcms": 1,
  }
             "aliquotaIcms": 1, }
            "vlicmsret": 1},
            "motivoDesoneracaoIcmsprodutoKits": 1,{
              "descontaDesoneracaoNf*": false,
{
                "cestidRetaguardaProduto": "cest"items.[&4].produtoKits[&1].idRetaguardaProduto",
                "arredondaTruncaidRetaguardaProdutoKit": "Arredondaitems.[&4].produtoKits[&1].idRetaguardaProdutoKit",
            "impostos[]": {
              "*[]"descricao": " "items.[&4].produtoKits[&1].descricao",
            }
          }
        }
      }
    }
  }
]

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
"quantidadeVendaKit": "items.[&4].produtoKits[&1].quantidadeVendaKit",
				"tipoValorKit": "items.[&4].produtoKits[&1].tipoValorKit",
				"situacao": "items.[&4].produtoKits[&1].situacao",
				"valorDesconto": "items.[&4].produtoKits[&1].valorDesconto",
				"novoValorUnitario": "items.[&4].produtoKits[&1].novoValorUnitario"
              }
            }	
          },
          //NCM
          "ncm_old": {
            "*": {
              "id": "items[&3].ncms[&1].idRetaguarda",
              "@(2,produto.codfilial)": "items.[&3].ncms[&1].idProprietario"
            }
          },
          "ncm": {
            "*": {
              "id": {
                "0": {
                  "@(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": ""
  },
  
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

3-PROCESSAR
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_NCM}}",
			"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_NCMPRODUTO}}https://pdvsync-core-produto-devqa-aadivv24nq-ue.a.run.app/api/retaguarda/produtosSTRING