Passo a passo: | Card |
---|
default | true |
---|
id | Custo Médio |
---|
label | 1. LIMITE DE CRÉDITO |
---|
| Deck of Cards |
---|
startHidden | false |
---|
effectDuration | 0.5 |
---|
id | Cards |
---|
effectType | horizontal |
---|
loopCards | true |
---|
| Card |
---|
default | true |
---|
id | Custo Médio |
---|
label | Pontos de Entrada |
---|
|
|
Card |
---|
default | true |
---|
id | 0607202023 |
---|
label | ExecAuto |
---|
| Conceito (O que é um ExecAuto?)
Expandir |
---|
title | Como saber se um fonte possui ExecAuto? |
---|
| Basicamente, as funções que recebem parâmetros podem ser chamadas via ExecAuto, parâmetros são passados entre parênteses após o nome da função.
Exemplo de Função que possui parâmetros:
Exemplo de função que não possui parâmetros:
Após verificar se a função tem parâmetros, deve-se verificar se existe um Modelo de ExecAuto para esta função publicado no TDN. Páginas de Rotinas Automáticas (ExecAuto):
Aviso |
---|
| Caso a rotina possua parâmetros e não possua um exemplo publicado no TDN, é necessário solicitar a documentação do ExecAuto ao time de desenvolvimento através de uma Issue de Documentação. |
|
|
Card |
---|
default | true |
---|
id | 0607202023 |
---|
label | Execauto Via API REST |
---|
| Para testes de chamada de execauto via API REST, siga os passos abaixo: Deck of Cards |
---|
| | Expandir |
---|
title | Fonte de exemplo de API REST para chamada de execauto |
| Fonte de Exemplo: #INCLUDE'PROTHEUS.CH' #INCLUDE 'TOTVS.CH' #INCLUDE 'RESTFUL.CH' #INCLUDE 'RWMAKE.CH' #INCLUDE 'TOPCONN.CH' #INCLUDE "FWMVCDEF.CH"
// API para chamar execauto via REST
WSRESTFULEXECTST2DESCRIPTION"TESTE" WSMETHODGETDESCRIPTION"TESTE"WSSYNTAX"/EXECTST" ENDWSRESTFUL
WSMETHODGETWSSERVICEEXECTST2 U_MyMata410() //Função a ser chamada Return |
---|
1 - Salvar o fonte com o nome "execviarest.prw". 2 - Na "Função a ser chamada" colocar o nome da função do execauto que irá utilizar: Exemplo: U_MyMata410() |
| expand | titlelabel | 2 - Ajustes no fonte |
---|
| Ajustes a serem feitos no fonte do execauto: 1 - | No fonte do execauto não No fonte do execauto fazer | expand | titlelabel | 3 - Compilação dos fontes |
---|
|
| e REST Compilar o fonte Fonte da API: execviarest.prw 2 - | Compilar o fonte Fonte do execauto "ajustado" | 3 | Subir um serviço de REST, para isso utilize o exemplo abaixo: ;===================================== ;============== WEB REST =============== ;===================================== [HTTPV11] Enable=1 AddressFamily=1 Sockets=HTTPREST [HTTPREST] Port=8086 <<-- Porta do REST IPsBind= MaxQueue=10 URIs=HTTPURI SECURITY=0 [HTTPURI] URL=/rest PrepareIn=ALL Instances=1,10 OnStart=REST_START OnConnect=REST_CONNECT OnExit=REST |
---|
|
| Expandir |
---|
| _EXIT [HTTPJOB] MAIN=HTTP_START ENVIRONMENT=12.1.2310 <<-- Nome do seu ambiente [ONSTART] jobs=HTTPJOB RefreshRate=120 ;===================================== |
---|
Não se esqueça de validar se o REST está no ar, feche o console do App Server e abra novamente verificando se exibe a mensagem de REST, validando também se o REST está no ar através do navegador da internet. Dica |
---|
| "Fique atento ao utilizar o parâmetro de configuração com a chave Security=0, pois isso fará com que as integrações (APIs) não exijam autenticação, consequentemente dados do seu ambiente poderão ser consultados sem qualquer controle de autorização." |
Dica |
---|
| - Temos também uma documentação complementar sobre a configuração através do APWebWizard: Configurando REST
|
|
Card |
---|
| Para fazer a chamada da API iremos utilizar o Postman.
1 - Baixar e instalar | 1 - Instalar Aqui você poderá informar Informar os dados de acesso ao Postman, campos a preencher na aba "Headers": - GET: Coloque o endereço de seu REST + o texto: /EXECTST2
- Key: tenantid
- Value: 99,01 <empresa,filial>
Image Added |
---|
|
Card |
---|
| No Postman clique no botão "Send" para executar a API: Image Added |
---|
|
|
|
Card |
---|
default | true |
---|
id | 0607202023 |
---|
label | Execauto Via API WebService |
---|
| Para testes de chamada de execauto via API WebService, siga os passos abaixo: Deck of Cards |
---|
| Card |
---|
label | 1 - Fonte de exemplo |
---|
| Fonte de exemplo de API WS para chamada de execauto: #include"protheus.ch" #include"totvs.ch" #include"apwebsrv.ch" // API para chamar execauto via WS
WSSERVICEwsteste01 WSDATAcumped ASstring WSDATAcRet ASstring WSDATAUserCodeASString
WSMETHODwsteste ENDWSSERVICE
WSMETHODwstesteWSRECEIVEUserCode,cumpedWSSENDcRetWSSERVICEwsteste01 U_MyMata410() //função a ser chamada
RetURN.T. |
---|
1 - Salvar o fonte com o nome "execviaws.prw". 2 - Na "Função a ser chamada" colocar o nome da função do execauto que irá utilizar: Exemplo: U_MyMata410() |
Card |
---|
label | 2 - Ajustes no fonte |
---|
| Ajustes a serem feitos no fonte do execauto: 1 - Não fazer a abertura do ambiente: PREPARE ENVIRONMENT ou RpcSetEnv. 2 - Fazer o tratamento para a função "MostraErro" conforme documentação abaixo: | "Key" na aba "Headers": tenantid"Value" na aba "Headers": 99,01 (empresa,filial) Card |
---|
label | 3 - Compilação dos fontes |
---|
| Compilar os fontes: 1 - Fonte da API: execviaws.prw 2 - Fonte do execauto "ajustado" |
Card |
---|
| Expandir |
---|
title | Configurando o WEBSERVICE |
---|
| Para utilizar a API é necessário que os WebServices estejam ativos. Ambos serviços dependem do serviço HTTP do Protheus, que permite que as informações sejam publicadas na WEB. A configuração inicia-se habilitando o serviço HTTP e configurando a porta que todos os outros serviços dependentes deste irão utilizar para a publicação das informações.
Informações |
---|
Os serviços devem ser configurados pelo WIZARD, pois a cada módulo WEB instalado são descompactados arquivos importantes no diretório informado na configuração. Estes arquivos são de extensão exclusiva da Microsiga, os *.MZP, e que apenas com o Wizard será possível a correta instalação. No exemplo acima, a configuração está sendo realizada para o caminho LOCALHOST. Para publicá-lo informe o nome da máquina ou o endereço IP. Caso seu serviço HTTP esteja configurado para a porta 80, não deve informá-lo no host. Exemplo localhost/ws. |
Deck of Cards |
---|
| Card |
---|
label | Se possuir apenas uma filial |
---|
| Card |
---|
default | true |
---|
id | Custo Médio |
---|
label | Configuração dos Web Services |
---|
| A - Acesse o Wizard de configuração dos Serviços;
B - Em Servidor Internet (HTTP/FTP), verifique se o serviço de HTTP já existe, confirme se está habilitado e para qual porta está configurada. Pois estas são informações indispensáveis para o correto funcionamento dos WebServices e Portais.
Expandir |
---|
title | C - Configurando HTTP/FTP |
---|
| - Realize o Download dos Arquivos de Portais (web_files) do Portal do Cliente;
- Inclua uma pasta web dentro da Protheus Data do Sistema e insira os web_files;
- Insira também os arquivo web_files na pasta systemload
- Selecionar a opção: <HTTP> e clicar na barra superior <Editar> conforme exemplo;
- O sistema apresentará a tela para Configuração da Seçãoonde os principais campos são:
- Flag para Habilitar o Protocolo;
- Path de Arquivos = Caminho da Pasta Web;
- Ambiente = Nome do Ambiente;
- Porta de Conexão = Porta de configuração dos Serviços;
Dica |
---|
| Na configuração da Seção, inserimos como exemplo a porta 92, porém ela pode ser alterada caso prefira. Caso definida a porta padrão do serviço HTTP que é a 80, não é necessário especificá-la na configuração do WS e Portais. |
Basta confirmar e gravar as configurações |
D - Configure os Módulos da Web: Expandir |
---|
title | WS TOTVS Linha Protheus Web Services |
---|
| - Realize as configurações básicas, campos importantes:
- Módulo Web = WS - TOTVS Linha Protheus Web Services;
- Nome da Instância = ws;
- Diretório Raiz das Imagens (Web Path) = Diretório da Pasta Web onde o sistema irá criar a pasta "ws";
- Selecione o Environment = Nome do Ambiente;
- Flag para habilitar processos na inicialização do Servidor.
- Realize a Configuração de Host x Empresas/Filiais, campos importantes:
- Host = Server e porta dos Web Services (Deve ser informada a porta informada na Configuração HTTP/FTP);
- Selecione a Empresa/Filial = Empresa e Filial de acesso (Para configuração Multifilial, consulte a respectiva aba).
- Clique em "Relacionar" e em "Avançar".
Finalizar e confirmar a configuração. |
E - Configure o Portal (Protheus) Expandir |
---|
| - Realize as configurações básicas, campos importantes:
- Módulo Web = PP - Portal Protheus;
- Nome da Instância = pp;
- Diretório Raiz das Imagens (Web Path) = Diretório da Pasta Web onde o sistema irá criar a pasta "pp";
- Selecione o Environment = Nome do Ambiente;
- URL do Protheus Web Services = Server e Porta de configuração dos Web Services.
- Realize a Configuração de Host x Empresas/Filiais, campos importantes:
- Host = Server e porta do Portal (Deve ser informada a porta informada na Configuração HTTP/FTP);
- Selecione a Empresa/Filial = Empresa e Filial de acesso (Para configuração Multifilial, consulte a respectiva aba).
- Clique em "Relacionar" e em "Avançar".
- Realize a Configuração de Usuários, onde irá definir o número mínimo e máximo de usuários para acesso.
Finalizar e confirmar a configuração. Inclua na pasta pp os colocar o arquivos da pasta web na systemload |
F - Após as configurações acima, o sistema irá inserir as informações de acesso aos Web Services no arquivo AppServer.ini do Protheus, verifique se as informações estão de acordo com o exemplo abaixo, caso não estejam realize ajustes (Lembrando que a Porta e o Nome do Ambiente serão os que preencheu durante a configuração): Expandir |
---|
| [HTTP] ENABLE=1 PORT=81
[localhost:92/ws] ENABLE=1 PATH=c:\seuambiente\Protheus_Data\web\ws ENVIRONMENT=12.1.025 INSTANCENAME=ws RESPONSEJOB=JOB_WS_9901 DEFAULTPAGE=wsindex.apw SECURITY=0
[JOB_WS_9901] TYPE=WEBEX ENVIRONMENT=12.1.025 INSTANCES=1,1 SIGAWEB=WS INSTANCENAME=ws ONSTART=__WSSTART ONCONNECT=__WSCONNECT PREPAREIN=99,01 SECURITY=0
[localhost:92/pp] ENABLE=1 PATH=c:\seuambiente\Protheus_Data\web\pp ENVIRONMENT=12.1.025 INSTANCENAME=pp RESPONSEJOB=JOB_PP SECURITY=0
[JOB_PP] TYPE=WEBEX ENVIRONMENT=ENVIRONMENT INSTANCES=1,1 SIGAWEB=PP INSTANCENAME=pp ONSTART=STARTWEBEX ONCONNECT=CONNECTWEBEX ONEXIT=FINISHWEBEX WEBSERVICELOCATION=http://localhost:92/ws SECURITY=0
Dica |
---|
| "Fique atento ao utilizar o parâmetro de configuração com a chave Security=0, pois isso fará com que as integrações (APIs) não exijam autenticação, consequentemente dados do seu ambiente poderão ser consultados sem qualquer controle de autorização." |
|
G - Por fim, reinicie o Server do Protheus e verifique se o serviço do WebService subiu de forma correta no Browser, basta digitar o caminho que configurou no Wizard e verificar se o sistema indica como Habilitado: Image Added |
|
Card |
---|
| Card |
---|
default | true |
---|
id | 060720201 |
---|
label | Configuração dos Web Services Multifilial |
---|
| O processo de configuração para uma nova filial é basicamente o mesmo, mas é necessário ter um novo WebService e Portal.
Expandir |
---|
title | A - Configurar WS TOTVS Linha Protheus Web Services |
---|
| - Realize as configurações básicas, campos importantes:
- Módulo Web = WS - TOTVS Linha Protheus Web Services;
- Nome da Instância = ws;
- Diretório Raiz das Imagens (Web Path) = Diretório da Pasta Web onde o sistema irá criar a pasta "ws";
- Selecione o Environment = Nome do Ambiente;
- Flag para habilitar processos na inicialização do Servidor.
- Realize a Configuração de Host x Empresas/Filiais, campos importantes:
- Host = Server e porta dos Web Services (Deve ser informada a porta informada na Configuração HTTP/FTP);
- Selecione a Empresa/Filial = Empresa e Filial de acesso (Para configuração Multifilial, consulte a respectiva aba).
- Clique em "Relacionar" e em "Avançar".
Finalizar e confirmar a configuração. |
Expandir |
---|
title | B - Configurar PP Portal Protheus |
---|
| - Realize as configurações básicas, campos importantes:
- Módulo Web = PP - Portal Protheus;
- Nome da Instância = pp;
- Diretório Raiz das Imagens (Web Path) = Diretório da Pasta Web onde o sistema irá criar a pasta "pp";
- Selecione o Environment = Nome do Ambiente;
- URL do Protheus Web Services = Server e Porta de configuração dos Web Services.
- Realize a Configuração de Host x Empresas/Filiais, campos importantes:
- Host = Server e porta do Portal (Deve ser informada a porta informada na Configuração HTTP/FTP);
- Selecione a Empresa/Filial = Empresa e Filial de acesso (Para configuração Multifilial, consulte a respectiva aba).
- Clique em "Relacionar" e em "Avançar".
Finalizar e confirmar a configuração. |
Informações |
---|
Os serviços devem ser configurados pelo WIZARD, pois a cada módulo WEB instalado são descompactados arquivos importantes no diretório informado na configuração. Estes arquivos são de extensão exclusiva da Microsiga, os *.MZP, e que apenas com o Wizard será possível a correta instalação. No exemplo acima, a configuração está sendo realizada para o caminho LOCALHOST. Para publicá-lo informe o nome da máquina ou o endereço IP. Caso seu serviço HTTP esteja configurado para a porta 80, não deve informá-lo no host. Exemplo localhost/ws. Pra cada filial nova é necessário configurar um novo portal. |
C - Após as configurações acima, o sistema irá inserir as informações de acesso aos Web Services no arquivo AppServer.ini do Protheus, verifique se as informações estão de acordo com o exemplo abaixo, caso não estejam realize ajustes (Lembrando que a Porta e o Nome do Ambiente serão os que preencheu durante a configuração): Expandir |
---|
| [HTTP] ENABLE=1 PATH=C:\nome do ambiente\Protheus_Data\Web PORT=91 ENVIRONMENT=nome do ambiente [localhost:91/ws] ENABLE=1 PATH=C:\nome do ambiente\Protheus_Data\web\WS ENVIRONMENT=nome do ambiente INSTANCENAME=WS RESPONSEJOB=JOB_WS_9901 → (Filial 01) DEFAULTPAGE=wsindex.apw [JOB_WS_9901] TYPE=WEBEX ENVIRONMENT=nome do ambiente INSTANCES=1,1 SIGAWEB=WS INSTANCENAME=WS ONSTART=__WSSTART ONCONNECT=__WSCONNECT PREPAREIN=99,01 → (Filial 01) [ONSTART] ;JOBS=JOB_WS_9901,JOB_PP,JOB_WS02_9902,JOB_PP02 [localhost:91/pp] ENABLE=1 PATH=C:\nome do ambiente\Protheus_Data\web\pp ENVIRONMENT=nome do ambiente INSTANCENAME=pp RESPONSEJOB=JOB_PP [JOB_PP] TYPE=WEBEX ENVIRONMENT=nome do ambiente INSTANCES=1,1 SIGAWEB=PP INSTANCENAME=PP ONSTART=STARTWEBEX ONCONNECT=CONNECTWEBEX ONEXIT=FINISHWEBEX WEBSERVICELOCATION=http://localhost:91/ws → (URL da filial 01)
[localhost:91/ws02] ENABLE=1 PATH=C:\nome do ambiente\Protheus_Data\web\WS02 ENVIRONMENT=nome do ambiente INSTANCENAME=WS02 RESPONSEJOB=JOB_WS02_9902 → (Filial 02) DEFAULTPAGE=wsindex.apw [JOB_WS02_9902] TYPE=WEBEX ENVIRONMENT=nome do ambiente INSTANCES=1,1 SIGAWEB=WS INSTANCENAME=WS02 ONSTART=__WSSTART ONCONNECT=__WSCONNECT PREPAREIN=99,02 → (Filial 02) [localhost:91/pp02] ENABLE=1 PATH=C:\nome do ambiente\Protheus_Data\web\pp02 ENVIRONMENT= nome do ambiente INSTANCENAME=pp02 RESPONSEJOB=JOB_PP02 [JOB_PP02] TYPE=WEBEX ENVIRONMENT=nome do ambiente INSTANCES=1,1 SIGAWEB=PP INSTANCENAME=pp02 ONSTART=STARTWEBEX ONCONNECT=CONNECTWEBEX ONEXIT=FINISHWEBEX WEBSERVICELOCATION=http://localhost:91/ws02 → (URL da Filial 02) |
D - Por fim, reinicie o Server do Protheus e verifique se o serviço do WebService subiu de forma correta no Browser, basta digitar o caminho que configurou no Wizard e verificar se o sistema indica como Habilitado: Image Added |
|
|
|
|
Card |
---|
| Para fazer a chamada da API iremos utilizar o SoapUI:
1 - Baixar e instalar o SoapUI: https://www.soapui.org/downloads/latest-release/ Dica |
---|
| Para fazer a configuração do SoapUI é necessário compilar o fonte da API e subir o appserver do WebService. |
2 - No SoapUI clicar em: File > New SOAP Project
3 - Informar os dados de acesso ao SoapUI, campos a preencher: - Project Name: Nome do seu projeto
- Initial WSDL: Coloque o endereço de seu Webservice + o texto: /WSTESTE01.apw?WSDL
- Clicar em "OK"
Image Added
4 - No SoapUI dê um duplo clique em "Request 1" e configure da seguinte forma: Image Added Dica |
---|
| - USERCODE: Admin
- CUMPED: Senha do usuário admin
|
|
Card |
---|
| No SoapUI dê um duplo clique em "Request 1" e clique no botão "play".
Image Added | Image Removed |
|
Card |
---|
default | true |
---|
id | 0607202023 |
---|
label | API Padrão Sales Taxes |
---|
| Para testes da API Padrão Sales Taxes, siga os passos abaixo: Documentação: API para Consulta de Valores e Tributos (SalesTaxes) em Pedidos de Venda TOTVS Deck of Cards |
---|
| Card |
---|
| Subir um serviço de REST, para isso utilize o exemplo abaixo: ;===================================== ;============== WEB REST =============== ;===================================== [HTTPV11] Enable=1 AddressFamily=1 Sockets=HTTPREST [HTTPREST] Port=8086 <<-- Porta do REST IPsBind= MaxQueue=10 URIs=HTTPURI SECURITY=0 [HTTPURI] URL=/rest PrepareIn=ALL Instances=1,10 OnStart=REST_START OnConnect=REST_CONNECT OnExit=REST_EXIT [HTTPJOB] MAIN=HTTP_START ENVIRONMENT=12.1.2310 <<-- Nome do seu ambiente [ONSTART] jobs=HTTPJOB RefreshRate=120 ;===================================== |
---|
Não se esqueça de validar se o REST está no ar, feche o console do App Server e abra novamente verificando se exibe a mensagem de REST, validando também se o REST está no ar através do navegador da internet. Dica |
---|
| "Fique atento ao utilizar o parâmetro de configuração com a chave Security=0, pois isso fará com que as integrações (APIs) não exijam autenticação, consequentemente dados do seu ambiente poderão ser consultados sem qualquer controle de autorização." |
Dica |
---|
| - Temos também uma documentação complementar sobre a configuração através do APWebWizard: Configurando REST
|
|
|
| Via API WS | 2 - GET - Consultar os Impostos de um Pedido de Venda |
---|
| Para fazer a chamada da API iremos utilizar o Postman. Observação: 1 - Caso a planilha financeira do pedido esteja retornando os valores corretamente e o valor do imposto na API esteja retornando errado transferir para o Suporte Fiscal 2 - Caso a planilha financeira do pedido e o valor do imposto na API esteja retornando os valores corretamente, testar via POST
1 - Baixar e instalar o Postman: https://www.postman.com/downloads/ 2 - Informar os dados de acesso ao Postman: - GET: <Endereço do REST> + <api/fat/v1/salesTaxes/> + <Número do pedido>
- Exemplo: localhost:8087/rest/api/fat/v1/salesTaxes/000264
Image Added |
---|
Exemplo de Pedido calculando ICMS e ICMS-ST: Image Added
Image Added
Retorno da API: { "valor_contabil": 1101.7, "valor_mercadoria": 1000, "total_impostos_embutidos": 70, "total_impostos_sem_incidencia": 101.7, "total_impostos": 171.7, "TaxesDetail": [ { "imposto": "ICM", "descricao": "ICMS", "base_calculo": 1000, "aliquota": 7, "valor": 70 }, { "imposto": "ICR", "descricao": "ICMS Retido ", "base_calculo": 1010, "aliquota": 17, "valor": 101.7 } ], "itens": [ { "produto": { "valor_mercadoria": 1000, "valor_st": 101.7, "valor_total": 1101.7, "seguro": 0, "valor_csll": 0, "valor_unitario": 0, "quantidade": 1, "aliquota_pis": 0.65, "aliquota_ipi": 0, "valor_pis": 0, "valor_pis_apur": 0, "valor_pis_st": 0, "aliquota_cofins": 2, "valor_cofins": 0, "valor_cofins_apur": 0, "valor_cofins_st": 0, "aliquota_st": 17, "aliquota_icms": 7, "frete": 0, "codigo_produto": "000005 ", "aliquota_csll": 1, "valor_icms": 70, "valor_ipi": 0, "desconto": 0, "despesas_acessorias": 0, "tes": "505" } } ], "desconto": 0, "base_duplicada": 1101.7, "seguro": 0, "frete": 0, "despesas_acessorias": 0 } |
---|
|
Card |
---|
label | 3 - POST - Consultar os Impostos de uma Simulação de Pedido de Venda |
---|
| Para fazer a chamada da API iremos utilizar o Postman. Obs.: Caso o
1 - Baixar e instalar o Postman: https://www.postman.com/downloads/ 2 - Informar os dados de acesso ao Postman, campos a preencher na aba "Body": - GET: <Endereço do REST> + <api/fat/v1/salesTaxes/>
- Exemplo: localhost:8087/rest/api/fat/v1/salesTaxes
Image Added |
---|
Exemplo de Requisição: - Para consultar cada tag consulte a documentação da API
{ "BranchId": "01", "CompanyInternalId": "99", "SalesType": "N", "CustomerId": "000003", "CustomerUnit": "01", "CustomerIdDelivery": "000003", "CustomerUnitDelivery": "01", "CustomerType": "F", "Payment": "001", "DiscountPercentage1": 0, "DiscountPercentage2": 0, "DiscountPercentage3": 0, "DiscountPercentage4": 0, "Currency": 1, "Freight": 0, "Insurance": 0, "Expense": 0, "ListofProducts": [ { "BranchId": "01", "CompanyInternalId": "99", "ItemId": "01", "ProductId": "000005", "Quantity": 1, "UnitaryValue": 1000, "TotalValue": 1000, "PriceList": 1000, "TES": "501", "ItemDiscountPercentage": 0, "ItemDiscountValue":0, "OperationType": "" } ] } |
---|
Retorno da API: { "valor_contabil": 1101.7, "valor_mercadoria": 1000, "total_impostos_embutidos": 70, "total_impostos_sem_incidencia": 101.7, "total_impostos": 171.7, "TaxesDetail": [ { "imposto": "ICM", "descricao": "ICMS", "base_calculo": 1000, "aliquota": 7, "valor": 70 }, { "imposto": "ICR", "descricao": "ICMS Retido ", "base_calculo": 1010, "aliquota": 17, "valor": 101.7 } ], "itens": [ { "produto": { "valor_mercadoria": 1000, "valor_st": 101.7, "valor_total": 1101.7, "seguro": 0, "valor_csll": 0, "valor_unitario": 0, "quantidade": 1, "aliquota_pis": 0.65, "aliquota_ipi": 0, "valor_pis": 0, "valor_pis_apur": 0, "valor_pis_st": 0, "aliquota_cofins": 2, "valor_cofins": 0, "valor_cofins_apur": 0, "valor_cofins_st": 0, "aliquota_st": 17, "aliquota_icms": 7, "frete": 0, "codigo_produto": "000005 ", "aliquota_csll": 1, "valor_icms": 70, "valor_ipi": 0, "desconto": 0, "despesas_acessorias": 0, "tes": "505" } } ], "desconto": 0, "base_duplicada": 1101.7, "seguro": 0, "frete": 0, "despesas_acessorias": 0 } |
---|
|
|
|
|
|
|