Páginas filhas
  • DR VA Integração API Produto - Requisições de Produto

Versões comparadas

Chave

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

...

Totvs custom tabs box
tabsClassificação de Produto, Preço do Produto, Saldo de Produtos por Grupo, Saldo de Produto por Lote, Saldo de Produto por Empresa
idsclassificacaoproduto,precoproduto,saldogrupo,saldoloteproduto,saldoproduto
Totvs custom tabs box items
defaultyes
referenciaclassificacaoproduto

01. INTRODUÇÃO

Obter classificação de produto 

Totvs custom tabs box items
defaultno
referenciaconsultarclassificacoesdeproduto
precoproduto
Bloco de código
titleURL
https://www30.bhan.com.br:9443/api/v1/produto/classificacaoproduto
Bloco de código
titleMÉTODO
POST
Bloco de código
titleCABEÇALHO
Token: "XXXXXXXXXXXXXX"
Bloco de código
titleEXEMPLO REQUISIÇÃO
collapsetrue
{
    "cdProduto": 999999999,
    "cdBarra": "XXXXXXXXXXXXX"
}
Bloco de código
titleEXEMPLO RESPOSTA
collapsetrue
[
    {
        "cdProduto": 10,						//Código do produto

01. INTRODUÇÃO

Requisição que tem a finalidade de retornar os preços de um ou mais produtos, incluindo os valores promocionais.

Observação: Se a grade possuir um produto padrão configurado, todos os produtos receberão o mesmo valor do produto padrão.

02. UTILIZAÇÃO

Totvs custom tabs box
tabsEnvio, Retorno, Exemplo de Implementação
idsenvio,retorno,cod
{ "produtos": [

        
{
"cdBarra": "5809600000107",				//Código de barras do produto
        "
cdProduto
dsProduto": "
XXXXXXXXXXXXXXXXXXXX"
BASICA AMARELO DV",		//Descrição do 
}
produto
    
],
    "
cdPreco
cdTpClassificacao": 
9999,
22,				//Código do tipo de classificação
    
"inPromocao":
 
9,
   "
empresas
dsTpClassificacao": 
[
"MARCA",			//Descrição do tipo de classificação
    
{
    "cdClassificacao": "3",					//Código da classificação
        "
cdEmpresa
dsClassificacao": 
9999,
"CLAS 3",			//Descrição classificação
        "
nrCNPJEmpresa
cdGrupo": "
XXXXXXXXXXXXXX"
2",							//Código do grupo
        
} ] }

URL

HEADER

BODY

{ "produtos": [ {
"dsGrupo": "BASICA",					//Descrição do grupo
        "cdNivel": "300 2",						//Código do nível
        "dsNivel": "BASICA",					//Descrição do nível
        
"
cdProduto
cdCor": "
100" }
1",							//Código da cor
    
],
    "
cdPreco
dsCor": 
1,
"UN",							//Descrição da cor
        "
inPromocao
cdTamanho": 1,
"empresas": [
							//Código do tamanho
        "dsTamanho": "34",						//Descrição do 
{
tamanho
        
"cdEspecie": "
cdEmpresa": 1
SVC"						//Código da espécie
    
}
]
}
Totvs custom tabs box items
defaultyes
referenciaenvio
Totvs custom tabs box
tabsURL, Body, Exemplo de Requisição, Detalhamento dos Campos
idsurlE,corpoE,exE,campE
Totvs custom tabs box items
defaultyes
referenciaurlE

Button
Cor#61affe
TextoPOST
Link.
 https://www30.bhan.com.br:9443/api/v1/produto/precoproduto

Totvs custom tabs box items
defaultno
referenciacorpoE
Bloco de código
languagexml
themeRDark
firstline1
titleBody
linenumberstrue
Totvs custom tabs box items
defaultno
referenciaexE

Button
Cor#61affe
TextoPOST
Link.
 https://www30.bhan.com.br:9443/api/v1/produto/precoproduto

AuthorizationBearer {{token}}
Bloco de código
languagexml
themeRDark
firstline1
titleBody
linenumberstrue
Totvs custom tabs box items
defaultno
referenciaprecoproduto

01. INTRODUÇÃO

Requisição que tem a finalidade de retornar os preços de um ou mais produtos, incluindo os valores promocionais.

Observação: Se a grade possuir um produto padrão configurado, todos os produtos receberão o mesmo valor do produto padrão.

02. UTILIZAÇÃO


Totvs custom tabs box
tabsEnvio, Retorno, Exemplo de Implementação
idsenvio,retorno,cod
Totvs custom tabs box items
defaultyes
referenciaenvio
Totvs custom tabs box
tabsURL, Body, Exemplo de Requisição, Detalhamento dos Campos
idsurlE,corpoE,exE,campE

*Neste campo podemos informar o código sku do produto ou o código de barras do produto.

**Neste campo podemos informar 1 (um) para retornar os valores promocionais ou 0 (zero) para NÃO retornar os valores promocionais.

***Neste campo quando Código da Empresa for informado, não existe a necessidade de informar o CNPJ. Porém, caso o Código não for informado, o documento se torna obrigatório!

Todos os campos são obrigatórios. Caso possua a opção de informar  código e/ou documento, pelo menos um dos campos deve ser informado!
Totvs custom tabs box items
defaultyes
referenciaurlE

Button
Cor#61affe
TextoPOST
Link.
 https://www30.bhan.com.br:9443/api/v1/produto/precoproduto

campE

Image RemovedImage Removed

NomeTipoDescriçãoExemploVA
cdProdutostringCódigo do produto *"cdProduto": "100"Referência 1
cdPrecointCódigo do Preço"cdPreco": 1Referência 2
inPromocaointValor de Promoção **"inPromocao": 1--
cdEmpresaintCódigo da Empresa ***"cdEmpresa": 1Referência 3
nrCNPJEmpresastringCNPJ da Empresa ***"nrCNPJEmpresa": "12345678901234"--
Informações

Totvs custom tabs box items
defaultno
referencia
retorno
corpoE
Totvs custom tabs box
tabsSucesso, Erro
idssucesso,erro
Totvs custom tabs box items
defaultyes
referenciasucesso
Bloco de código
languagexml
themeRDark
firstline1
titleStatus 200 OKBody
linenumberstrue
{
    "precosprodutos": [
        {
            "cdSKUcdProduto": 9999999,"XXXXXXXXXXXXXXXXXXXX"
        }
    "cdProduto": "XXXXXXXXXX"],
            "dsProduto"cdPreco": "XXXXXXXXXX"9999,
            "cdReferencia"inPromocao": "XXXXXXXXXX"9,
            "cdCorempresas": "XXXXXXXXX",[
            "dsTamanho": "XXXXXXXXXX",{
            "cdEmpresa": 9999999999999,
            "nrCNPJEmpresa": "XXXXXXXXXXXXXXXXXXXXXXXXX",
        }
    "vlPreco": 999999999.99,
            "vlPrecoPromocao": 999999999.99
        }
    ]
}]
}
Totvs custom tabs box items
defaultno
referenciaerroexE
code

URL

language

Button

xml

Cor

theme

#61affe

RDark

Texto

firstline

POST

1

Link

titleStatus 400 Bad Request
linenumberstrue
{
    "dsErro": "Mensagem informativa do erro"
}
Totvs custom tabs box items
defaultno
referenciacod

.
 https://www30.bhan.com.br:9443/api/v1/produto/precoproduto


HEADER

AuthorizationBearer {{token}}


BODY


Bloco de código
languagexml
themeRDark
firstline1
titleBody
linenumberstrue
{
    "produtos": [
        {
            "cdProduto": "100"
        }
    ],
    "cdPreco": 1,
    "inPromocao": 1,
    "empresas": [
        {
            "cdEmpresa": 1
        }
    ]
Totvs custom tabs box
tabsConsulta Preço Produto, Token, Preço Produto
idsapi,token,prproduto
Totvs custom tabs box items
defaultyes
referenciaapi
using System.Collections.Generic; namespace Project1 { public class ApiPrecoProduto { static void Main(string[] args) { var token = Token.ObterToken(); var dto = PopularDto(); RequisicaoPrecoProduto.PrecoProdutoConsulta(token, dto); } private static PrecoProdutoDTO.Envio PopularDto() { var dto = new DtoBuilder() .ComProdutos(ObterProduto()) .ComCodigoPreco(1) .ComIncluiPromocao(1) .ComEmpresas(ObterEmpresa()) .Build(); return dto; } private static List<Empresa> ObterEmpresa() { var empresas = new List<Empresa>(); empresas.Add( new DtoEnvioEmpresaBuilder() .ComCodigoEmpresa(1) .ComNumeroCNPJEmpresa("12345678901234") .Build() ); return empresas; } private static List<Produto> ObterProduto() { var produtos = new List<Produto>(); produtos.Add( new DtoEnvioProdutoBuilder() .ComCodigoProduto("100") .Build() ); return produtos; } }

}
Totvs custom tabs box
tabsMain, DtoBuilder, DtoEnvioPrecoProdutoBuilder,
idsmain,dtoB,dtoI,envioPrecoProduto
Totvs custom tabs box items
defaultyes
referenciamain
Bloco de código
languagec#
themeRDark
firstline1
titleMain
linenumberstrue
public class DtoBuilder { private readonly PrecoProdutoDTO.Envio _dto; public DtoBuilder() { _dto = new PrecoProdutoDTO.Envio(); } public DtoBuilder ComProdutos(PrecoProdutoDTO.EnvioPrecoProduto _produto) { _dto.Produtos.Add(_produto); return this; } public DtoBuilder ComProdutos(List<PrecoProdutoDTO.EnvioPrecoProduto> _produtos) { _dto.Produtos = _produtos; return this; } public PrecoProdutoDTO.Envio Build() => _dto; }
Totvs custom tabs box items
defaultno
referencia
dtoB
Bloco de código
languagec#
themeRDark
firstline1
linenumberstrue
campE

Image AddedImage Added


NomeTipoDescriçãoExemploVA
cdProdutostringCódigo do produto *"cdProduto": "100"Referência 1
cdPrecointCódigo do Preço"cdPreco": 1Referência 2
inPromocaointValor de Promoção **"inPromocao": 1--
cdEmpresaintCódigo da Empresa ***"cdEmpresa": 1Referência 3
nrCNPJEmpresastringCNPJ da Empresa ***"nrCNPJEmpresa": "12345678901234"--



*Neste campo podemos informar o código sku do produto ou o código de barras do produto.

**Neste campo podemos informar 1 (um) para retornar os valores promocionais ou 0 (zero) para NÃO retornar os valores promocionais.

***Neste campo quando Código da Empresa for informado, não existe a necessidade de informar o CNPJ. Porém, caso o Código não for informado, o documento se torna obrigatório!

Informações

Todos os campos são obrigatórios. Caso possua a opção de informar  código e/ou documento, pelo menos um dos campos deve ser informado!

Totvs custom tabs box items
defaultno
referenciaretorno
Totvs custom tabs box
tabsSucesso, Erro
idssucesso,erro
nodtoI
Totvs custom tabs box items
default
yes
referencia
sucesso
c#
Bloco de código
language
xml
themeRDark
firstline1
titleStatus 200 OK
linenumberstrue
{
    
public class DtoEnvioPrecoProdutoBuilder
"precos": [
        {
        
private
 
readonly
 
PrecoProdutoDTO.EnvioPrecoProduto
 
_produto;
 "cdSKU": 9999999,
      
public
 
DtoEnvioPrecoProdutoBuilder()
     
{
"cdProduto": "XXXXXXXXXX",
            
_produto = new PrecoProdutoDTO.EnvioPrecoProduto();
"dsProduto": "XXXXXXXXXX",
        
}
    "cdReferencia": "XXXXXXXXXX",
   
public
 
DtoEnvioPrecoProdutoBuilder
 
ComCodigoProduto(string
 
codigoProduto)
      
{
"cdCor": "XXXXXXXXX",
            
_produto.CodigoProduto = codigoProduto;
"dsTamanho": "XXXXXXXXXX",
            
return this;
"cdEmpresa": 999999999,
        
}
    
public DtoEnvioPrecoProdutoBuilder ComCodigoPreco(int codigoPreco)
"nrCNPJEmpresa": "XXXXXXXXXXX",
        
{
    
_produto.CodigoPreco = codigoPreco;
"vlPreco": 999999999.99,
            
return this;
"vlPrecoPromocao": 999999999.99
        }
    
public DtoEnvioPrecoProdutoBuilder ComIncluiPromocao(int incluiPromocao)
]
}
Totvs custom tabs box items
defaultno
referenciaerro
Bloco de código
languagexml
themeRDark
firstline1
titleStatus 400 Bad Request
linenumberstrue
{
    "dsErro": "Mensagem informativa do erro"
}
Totvs custom tabs box items
defaultno
referenciacod
Totvs custom tabs box
tabsConsulta Preço Produto, Token, Preço Produto
idsapi,token,prproduto
Totvs custom tabs box items
defaultyes
referenciaapi
Totvs custom tabs box
tabsMain, DtoBuilder, DtoEnvioProdutoBuilder, DtoEnvioEmpresaBuilder
idsmain,dtoB,dtoProduto,dtoEmpresa
Totvs custom tabs box items
defaultyes
referenciamain
Bloco de código
languagec#
themeRDark
firstline1
titleMain
linenumberstrue
public class ApiPrecoProduto
    {     _produto.IncluiPromocao = incluiPromocao;
            return this;
        }
        public DtoEnvioPrecoProdutoBuilder ComCodigoEmpresa(int codigoEmpresa)
        {
            _produto.CodigoEmpresa = codigoEmpresa;
            return this;
        }
        publicstatic DtoEnvioPrecoProdutoBuildervoid ComNumeroCNPJEmpresaMain(string[] numeroCNPJEmpresaargs)
        {
            _produto.NumeroCNPJEmpresavar token = numeroCNPJEmpresaToken.ObterToken();
            var dto = PopularDto();
     return this       RequisicaoPrecoProduto.PrecoProdutoConsulta(token, dto);
        }

        private publicstatic PrecoProdutoDTO.EnvioPrecoProdutoEnvio BuildPopularDto()
        {
   => _produto;

    }
Totvs custom tabs box items
defaultno
referenciatoken
Totvs custom tabs box
tabsObter Token, LoginDTO
idsobterToken,login
Totvs custom tabs box items
defaultyes
referenciaobterToken
Bloco de código
languagec#
themeRDark
firstline1
titleToken
linenumberstrue
public class Token
    {
            var dto = new DtoBuilder()
                .ComProdutos(ObterProduto())
          private  const string _applicationJson = "application/json"; .ComCodigoPreco(1)
        private    const string _baseUri = @"http://www30.bhan.com.br:9443/api/v1/";.ComIncluiPromocao(1)
        private  const string _usuario = "desen";
  .ComEmpresas(ObterEmpresa())      private const string _senha   = "123456";


   
     public static string ObterToken()
        {.Build();
            LoginDTO.Envio login = new LoginDTO.Envio(_usuario, _senha);

return dto;
        }

        varprivate clientestatic =List<Empresa> PopularClienteObterEmpresa();
        {
    
        var empresas = new List<Empresa>();

            var uri = @"autorizacao/token";
      empresas.Add(
              var conteudo = new StringContentDtoEnvioEmpresaBuilder(_applicationJson);
            var  response = cliente.PostAsync(uri, conteudo).Result;

ComCodigoEmpresa(1)
               if (!response.IsSuccessStatusCode.ComNumeroCNPJEmpresa("12345678901234")
                throw new Exception.Build();

             var retorno = JsonConvert.DeserializeObject<LoginDTO.Retorno>(response.Content.ReadAsStringAsync().Result);
            return retorno.Token.Replace("Bearer", "").Trim();

empresas;
        }


        private static HttpClientList<Produto> PopularClienteObterProduto()
        {
            HttpClientvar clienteprodutos = new HttpClientList<Produto>();

            cliente.BaseAddress = new Uri($"{_baseUri}");
produtos.Add(
                 cliente.DefaultRequestHeaders.Accept.Clearnew DtoEnvioProdutoBuilder();
            cliente.DefaultRequestHeaders.Accept.Add(new MediaTypeWithQualityHeaderValue(_applicationJson));    .ComCodigoProduto("100")
            cliente.DefaultRequestHeaders.Add("usuario", _usuario);
             cliente.DefaultRequestHeaders.Add("senha", _senha);
.Build()
              cliente.Timeout = TimeSpan.FromDays(1);

            return clienteprodutos;
        }
    }
Totvs custom tabs box items
defaultno
referencialogindtoB
Bloco de código
languagec#
themeRDark
firstline1titleLogin
linenumberstrue
public class LoginDTODtoBuilder
    {
        publicprivate classreadonly PrecoProdutoDTO.Envio _dto;

        public DtoBuilder()
        {
            [JsonProperty("usuario")]_dto = new PrecoProdutoDTO.Envio();
        }

        public string Usuario { get; set; }

DtoBuilder ComProdutos(Produto _produto)
        {
            [JsonProperty("senha")]_dto.Produtos.Add(_produto);
            public string Senha { get; set;return this;
        }

        public DtoBuilder ComProdutos(List<Produto> _produtos)
  public Envio(string usuario, string senha)
  {
          {
  _dto.Produtos = _produtos;
            Usuarioreturn = usuariothis;
        }

        Senha = senha;
public DtoBuilder ComCodigoPreco(int codigoPreco)
        {
     }
        }

_dto.CodigoPreco = codigoPreco;
           public classreturn Retornothis;
        {}

        public DtoBuilder   [JsonProperty("cdToken")]ComIncluiPromocao(int incluiPromocao)
        {
    public string Token { get; set; }

  _dto.IncluiPromocao = incluiPromocao;
        [JsonProperty("dtExpiracao")]
    return this;
       public string DataExpiracao { get; set; }

        public DtoBuilder   public Retorno(string token, string dataExpitacaoComEmpresas(Empresa _empresa)
            {
                Token = token_dto.Empresas.Add(_empresa);
            return this;
        }

        public DtoBuilder ComEmpresas(List<Empresa> _empresas)
        {
            DataExpiracao_dto.Empresas = dataExpitacao_empresas;
            }return this;
        }

      }
Totvs custom tabs box items
defaultno
referenciaprproduto
consultar,dto
Totvs custom tabs box
tabsConsultarPrecoProduto, ConsultarPrecoProdutoDTO
ids
  public PrecoProdutoDTO.Envio Build() => _dto;
    }    
Totvs custom tabs box items
defaultyesno
referenciaconsultardtoProduto
Bloco de código
languagec#
themeRDark
firstline1
linenumberstrue
    public class PrecoProdutoDtoEnvioProdutoBuilder
    {
        private constreadonly string _balseUri = @"http://www30.bhan.com.br:9443/api/v1/";
Produto _produto;

        private const string _applicationJson = "application/json";

public DtoEnvioProdutoBuilder()
        {
         public static PrecoProdutoDTO.Retorno PrecoProdutoConsulta(string token, PrecoProdutoDTO.Envio dto) _produto = new Produto();
        {}

        public DtoEnvioProdutoBuilder ComCodigoProduto(string codigoProduto)
     var uri = @"produto/precoproduto"; {
            var json = JsonConvert.SerializeObject(dto)_produto.CodigoProduto = codigoProduto;
            varreturn clientethis;
 = PopularCliente(token);
      }

      var conteudo =public newProduto StringContentBuild(json, Encoding.UTF8,) => _applicationJson)produto;
    }
Totvs custom tabs box items
defaultno
referenciadtoEmpresa
Bloco de código
languagec#
themeRDark
firstline1
linenumberstrue
 public class DtoEnvioEmpresaBuilder
    {
    var response = cliente.PostAsync(uri, conteudo).Result  private readonly Empresa _empresa;

        public    if (!response.IsSuccessStatusCodeDtoEnvioEmpresaBuilder()
        {
        throw new Exception();

  _empresa =         return JsonConvert.DeserializeObject<PrecoProdutoDTO.Retorno>(response.Content.ReadAsStringAsync().Result)new Empresa();
        }

        privatepublic staticDtoEnvioEmpresaBuilder HttpClient PopularClienteComCodigoEmpresa(stringint tokencodigoEmpresa)
        {
            HttpClient cliente = new HttpClient()_empresa.CodigoEmpresa = codigoEmpresa;
            cliente.BaseAddress = new Uri($"{_balseUri}");
return this;
        }

      cliente.DefaultRequestHeaders.Accept.Clear();
  public DtoEnvioEmpresaBuilder ComNumeroCNPJEmpresa(string numeroCNPJEmpresa)
       cliente.DefaultRequestHeaders.Accept.Add(new MediaTypeWithQualityHeaderValue(_applicationJson)); {
            cliente.DefaultRequestHeaders.Authorization_empresa.NumeroCNPJEmpresa = new AuthenticationHeaderValue("Bearer", token)numeroCNPJEmpresa;

            return clientethis;
        }

        public Empresa Build() => _empresa;
    }    
Totvs custom tabs box items
defaultno
referenciatoken
Totvs custom tabs box
tabsObter Token, LoginDTO
idsobterToken,login
Totvs custom tabs box items
defaultyes
referenciadtoobterToken
Bloco de código
languagec#
themeRDark
firstline1
titleToken
linenumberstrue
    public class PrecoProdutoDTOToken
    {
        publicprivate classconst Envio
string _applicationJson       {= "application/json";
        private const string _baseUri public List<EnvioPrecoProduto> Produtos { get; set; }

= @"http://www30.bhan.com.br:9443/api/v1/";
        private const string _usuario public Envio()= "usuario";
        private const string  {_senha = "senha";


        public static string ObterToken()
     Produtos = new List<EnvioPrecoProduto>();{
            }
LoginDTO.EnvioToken login = new     }LoginDTO.EnvioToken(_usuario, _senha);

        public class EnvioPrecoProduto
  var cliente = PopularCliente();


   {
         var uri = [JsonProperty("cdProduto")]@"autorizacao/token";
            publicvar stringconteudo CodigoProduto= { get; set; }

new StringContent(_applicationJson);
            [JsonProperty("cdPreco")]var response = cliente.PostAsync(uri, conteudo).Result;

            public int CodigoPreco { get; set; }

 if (!response.IsSuccessStatusCode)
                throw new [JsonPropertyException("inPromocao")];

            publicvar intretorno IncluiPromocao { get; set; }

= JsonConvert.DeserializeObject<LoginDTO.RetornoToken>(response.Content.ReadAsStringAsync().Result);
            [JsonProperty("cdEmpresa")]return retorno.Token.Replace("Bearer", "").Trim();

            public int CodigoEmpresa { get; set; }


        private static HttpClient  [JsonProperty("nrCNPJEmpresa")]
      PopularCliente()
      public string NumeroCNPJEmpresa { get; set; }
        }
    HttpClient cliente = new HttpClient();
   
         cliente.BaseAddress = new Uri($"{_baseUri}");
        

    cliente.DefaultRequestHeaders.Accept.Clear();
    public class Retorno
        {cliente.DefaultRequestHeaders.Accept.Add(new MediaTypeWithQualityHeaderValue(_applicationJson));
            public List<RetornoPrecoProduto> precos { get; set; }

cliente.DefaultRequestHeaders.Add("usuario", _usuario);
            public Retorno()
            {
                precos = new List<RetornoPrecoProduto>();
            }
        }

        public class RetornoPrecoProdutocliente.DefaultRequestHeaders.Add("senha", _senha);
            cliente.Timeout = TimeSpan.FromDays(1);

            return cliente;
        }
    }
Totvs custom tabs box items
defaultno
referencialogin
Bloco de código
languagec#
themeRDark
firstline1
titleLogin
linenumberstrue
public class LoginDTO
    {
        public class EnvioToken
        {
            [JsonProperty("usuario")]
            public string Usuario { get; set; }

            [JsonProperty("senha")]
            public string Senha { get; set; }

            public EnvioToken(string usuario, string senha)
            {
                Usuario = usuario;
                Senha = senha;
            }
        }

        public class RetornoToken
        {
            [JsonProperty("cdToken")]
            public string Token { get; set; }

            [JsonProperty("dtExpiracao")]
            public string DataExpiracao { get; set; }

            public RetornoToken(string token, string dataExpitacao)
            {
                Token = token;
                DataExpiracao = dataExpitacao;
            }
        }
    }
Totvs custom tabs box items
defaultno
referenciaprproduto
Totvs custom tabs box
tabsRequisicaoPrecoProduto, PrecoProdutoDTO, Produto, Empresa
idsrequisicao,dto,produto,empresa
Totvs custom tabs box items
defaultyes
referenciarequisicao
Bloco de código
languagec#
themeRDark
firstline1
linenumberstrue
public class RequisicaoPrecoProduto
    {
        private const string _balseUri = @"http://www30.bhan.com.br:9443/api/v1/";
        private const string _applicationJson = "application/json";

        public static PrecoProdutoDTO.Retorno PrecoProdutoConsulta(string token, PrecoProdutoDTO.Envio dto)
        {
            var uri = @"produto/precoproduto";
            var json = JsonConvert.SerializeObject(dto);
            var cliente = PopularCliente(token);
            var conteudo = new StringContent(json, Encoding.UTF8, _applicationJson);
            var response = cliente.PostAsync(uri, conteudo).Result;

            if (!response.IsSuccessStatusCode)
                throw new Exception();

            return JsonConvert.DeserializeObject<PrecoProdutoDTO.Retorno>(response.Content.ReadAsStringAsync().Result);
        }

        private static HttpClient PopularCliente(string token)
        {
            HttpClient cliente = new HttpClient();
            cliente.BaseAddress = new Uri($"{_balseUri}");
            cliente.DefaultRequestHeaders.Accept.Clear();
            cliente.DefaultRequestHeaders.Accept.Add(new MediaTypeWithQualityHeaderValue(_applicationJson));
            cliente.DefaultRequestHeaders.Authorization = new AuthenticationHeaderValue("Bearer", token);

            return cliente;
        }
    }
Totvs custom tabs box items
defaultno
referenciadto
Bloco de código
languagec#
themeRDark
firstline1
linenumberstrue
public class PrecoProdutoDTO
    {
        public class Envio
        {
            public List<Produto> Produtos { get; set; }
            public List<Empresa> Empresas { get; set; }

            public Envio()
            {
                Produtos = new List<Produto>();
                Empresas = new List<Empresa>();
            }

            [JsonProperty("cdPreco")]
            public int CodigoPreco { get; set; }

            [JsonProperty("inPromocao")]
            public int IncluiPromocao { get; set; }
        }

        public class Retorno
        {
            public List<RetornoPrecoProduto> precos { get; set; }

            public Retorno()
            {
                precos = new List<RetornoPrecoProduto>();
            }
        } 
    }
Totvs custom tabs box items
defaultno
referenciaproduto
Bloco de código
languagec#
themeRDark
firstline1
linenumberstrue
    public class Produto
    {
        [JsonProperty("cdProduto")]
        public string CodigoProduto { get; set; }
    }
Totvs custom tabs box items
defaultno
referenciaempresa
Bloco de código
languagec#
themeRDark
firstline1
linenumberstrue
    public class Empresa
    {
        [JsonProperty("cdEmpresa")]
        public int CodigoEmpresa { get; set; }

        [JsonProperty("nrCNPJEmpresa")]
        public string NumeroCNPJEmpresa { get; set; }
    }
Totvs custom tabs box items
defaultno
referenciasaldogrupo

01. INTRODUÇÃO

Obter saldo dos produtos de um grupo por empresa

  • Requisição que retorna saldo de um grupo de produtos por empresa.
Totvs custom tabs box items
defaultno
referenciaconsultarclassificacoesdeproduto
Bloco de código
titleURL
https://www30.bhan.com.br:9443/api/v1/produto/saldogrupo
Bloco de código
titleMÉTODO
POST
Bloco de código
titleCABEÇALHO
Token: "XXXXXXXXXXXXXX"
Bloco de código
titleEXEMPLO REQUISIÇÃO
collapsetrue
{
    "cdReferencia": "XXXXXXXXXXXXXXXXXXXX",
    "cdGrupo": "XXXXXXXXXX",
    "cdCor": "XXXXXXXXXX",
    "dsTamanho": "XXXXXXXXXX",
    "cdSaldo": 9999,
    "inEstoque": 9,
    "inPedidoVenda": 9,
    "empresas": [
        {
            "cdEmpresa": 9999,
            "nrCNPJEmpresa": "XXXXXXXXXXXXXX"
        }
    ]
}
Bloco de código
titleEXEMPLO RESPOSTA
collapsetrue
{
   "saldos": [
        {
            "cdSKU": 999999999,									"Código reduzido do produto"
            "cdProduto": "XXXXXXXXXXXXXXXXXXXX",				"Código de barras do produto"
            "cdReferencia": "XXXXXXXXXXXXXXXXXXXX",				"Código da Referência"
            "cdCor": "XXXXXXXXXX",								"Código da Cor"
            "dsTamanho": "XXXXXXXXXX",							"Descrição do Tamanho"
            "cdEmpresa": 9999,									"Código da Empresa"
            "nrCNPJEmpresa": "XXXXXXXXXXXXXX",					"CNPJ da Empresa"
            "qtEstoque":9999999.999,							"Quantidade em estoque"
            "qtPedidoVenda":9999999.999							"Quantidade em Pedido de Venda"
        }
    ]
}  
Totvs custom tabs box items
defaultno
referenciasaldoloteproduto

01. INTRODUÇÃO

Obter saldo em lote produto por empresa

  • Requisição que retorna o saldo de lote de um ou mais produtos por empresa
Totvs custom tabs box items
defaultno
referenciaconsultarclassificacoesdeproduto
Bloco de código
titleURL
https://www30.bhan.com.br:9443/api/v1/produto/saldoloteproduto
Bloco de código
titleMÉTODO
POST
Bloco de código
titleCABEÇALHO
Token: "XXXXXXXXXXXXXX"
Bloco de código
titleEXEMPLO REQUISIÇÃO
collapsetrue
{  
   "produtos": [
        {
            "cdProduto": "XXXXXXXXXXXXXXXXXXXX"
        }
    ],
   "cdSaldo": 9999,
   "inEstoque":  9,
   "inPedidoVenda":  9,
   "inTransacao":  9,
   "empresas": [
        {
            "cdEmpresa": 9999,
            "nrCNPJEmpresa": "XXXXXXXXXXXXXX"
        }
    ]
}
Bloco de código
titleEXEMPLO RESPOSTA
collapsetrue
{
   "lotes": [
        {
            "cdSKU": 999999999,												"Código reduzido do produto"
            "cdProduto": "XXXXXXXXXXXXXXXXXXXX",							"Código de barras do produto"
            "cdEmpresa": 9999,												"Código da Empresa"
            "nrCNPJEmpresa": "XXXXXXXXXXXXXX",								"CNPJ da Empresa"
            "nrLote": 999999999,											"Número do Lote"
            "nrItem": 999999999,											"Número do Item do Lote"
            "cdLote": "XXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXX",				"Código do Lote"
            "qtEstoque":9999999.999,										"Quantidade em estoque"
            "qtPedidoVenda":9999999.999,									"Quantidade em Pedido de Venda"
            "qtTransacao":9999999.999										"Quantidade em Transação"
        }
    ]
} 
Totvs custom tabs box items
defaultno
referenciasaldoproduto

01. INTRODUÇÃO

Obter saldo de produto por empresa

  • Requisição que retorna saldo de um ou mais produtos por empresa.
Totvs custom tabs box items
defaultno
referenciasaldoproduto

01. INTRODUÇÃO

Obter saldo de produto por empresa

  • Requisição que retorna saldo de um ou mais produtos por empresa.
  • Link para documentação técnica: obter saldo produto por empresa
    Totvs custom tabs box items
    defaultno
    referenciaconsultarclassificacoesdeproduto
    Bloco de código
    titleURL
    https://www30.bhan.com.br:9443/api/v1/produto/saldoproduto
    Bloco de código
    titleMÉTODO
    POST
    Bloco de código
    titleCABEÇALHO
    Token: "XXXXXXXXXXXXXX"
    Bloco de código
    titleEXEMPLO REQUISIÇÃO
    collapsetrue
    {
        "produtos": [
            {
                
    [JsonProperty("cdSKU")]
    "cdProduto": "XXXXXXXXXXXXXXXXXXXX"
            }
        
    public
    ],
       
    int
     
    CodigoSKU { get; set; }
    "cdSaldo": 9999,               
    [JsonProperty("cdProduto")]
                
    public
    // 
    string
    informar 
    CodigoProduto
    o 
    {
    código 
    get;
    do 
    set;
    saldo 
    }
    desejado
        "inEstoque": 9,            
    [JsonProperty("dsProduto")]
                
    public
     
    string
     
    DescricaoProduto
     
    {
     
    get; set; }
    // informar igual a 1 para retornar o saldo em estoque
        
    [JsonProperty(
    "
    cdReferencia")]
    inPedidoVenda": 9,             
    public
     
    string
     
    CodigoReferencia
     
    {
     
    get;
     
    set;
     
    }
         // informar igual a 1 para 
    [JsonProperty("cdCor")]
    retornar o saldo em pedido de venda
        "empresas": [
      
    public
     
    string
     
    CodigoCor
     
    {
     
    get;
     
    set;
     
    }
    {
                
    [JsonProperty(
    "
    dsTamanho")]
    cdEmpresa": 9999,
                
    public string DescricaoTamanho { get; set; }
    "nrCNPJEmpresa": "XXXXXXXXXXXXXX"
            }
        ]
    }
    Bloco de código
    titleEXEMPLO RESPOSTA
    collapsetrue
    {
       "saldos": [
            
    [JsonProperty("cdEmpresa")]
    {
            
    public int CodigoEmpresa { get; set; }
    	"cdSKU": 999999999,								"Código reduzido do produto"
                "cdProduto": "XXXXXXXXXXXXXXXXXXXX",			"Código de barras do 
    [JsonProperty("nrCNPJEmpresa")]
    produto"
                "cdReferencia": 
    public string NumeroCNPJEmpresa { get; set; }
    "XXXXXXXXXXXXXXXXXXXX",			"Código da Referência"
                "cdCor": "XXXXXXXXXX",							"Código da 
    [JsonProperty("vlPreco")]
    Cor"
                
    public double ValorPreco { get; set; }
    "dsTamanho": "XXXXXXXXXX",						"Descrição do Tamanho"
                
    [JsonProperty(
    "
    vlPrecoPromocao
    cdEmpresa"
    )]
    : 9999,								"Código da Empresa"
             
    public
     
    double
     
    ValorPrecoPromocao
     
    { get; set; }
    "nrCNPJEmpresa": "XXXXXXXXXXXXXX",				"CNPJ da Empresa"
          
    }
        
    }
    Totvs custom tabs box items
    defaultno
    referenciasaldogrupo

    01. INTRODUÇÃO

    Obter saldo dos produtos de um grupo por empresa

    Totvs custom tabs box items
    defaultno
    referenciasaldoloteproduto

    01. INTRODUÇÃO

    Obter saldo em lote produto por empresa

      "qtEstoque":9999999.999,						"Quatidade em Estoque"
                "qtPedidoVenda":9999999.999						"Quantidade em Pedido de Venda"
            }
        ]
    }