GITHUB BLOG
Gerencianet Sdk Typescript
Gerencianet TypeScript SDK - Integração de Typescript com as APIs Efí Pay
Este pacote oferece uma SDK moderna para integrar a API da Gerencianet com TypeScript. Diferente da SDK oficial, esta versão foi desenvolvida com foco total no TypeScript, proporcionando segurança de tipos e melhor reportagem de erros durante o desenvolvimento.
Atenção: O pacote está em desenvolvimento ativo. Atualmente, a API de PIX já está completamente integrada, exceto os Endpoints exclusivos da Efí Pay. Outras funcionalidades serão implementadas em futuras atualizações.
Ir para:
-
-
Variáveis de Ambiente (Environment Variables)
-
Instalação
Variáveis de Ambiente (Environment Variables)
As variáveis de ambiente Não são mais obrigatórias para que o sdk funcione, porém é recomendável utilizá-las. Elas são usadas para informar as Credenciais necessárias para utilizar as APIs da Efí Pay, para configurá-las siga os passos abaixo:
Gerar automaticamente as Variáveis Ambientes
Agora é possível utilizar o SDK para gerar automaticamente todas as variáveis ambientes necessárias. Por padrão elas serão geradas com valores dummy padrão, porém você pode inserir o valor de cada uma delas durante a criação se desejar.
Para criar as variáveis de ambiente, importe a classe EfiPay
de @bruno-valero/gerencianet-sdk-typescript
e use seu método estático generateDotEnv
passando os valores das variáveis que você deseja. Não é obrigatório preencher todas as variáveis, as que não forem preenchidas por você serão substituídas por valores dummy padrão.
Observe o exemplo:
Lembrando que para que as variáveis sejam efetivamente geradas, será necessário executar o script criado.
Criar .env
através do SDK
Se você ainda não criou um arquivo .env
na raiz do seu projeto, o método EfiPay.generateDotEnv()
irá criar este arquivo e escrever nele todas as variáveis de ambiente necessárias.
Lembrando que para que as variáveis sejam efetivamente geradas, será necessário executar o script criado.
Escrever as Variáveis de Ambiente em um .env
já existente
Caso já haja um arquivo .env
na raiz do seu projeto, ao usar o método EfiPay.generateDotEnv()
ele irá escrever todas as variáveis de ambiente necessárias abaixo do conteúdo já existente no seu arquivo .env
, portanto nenhuma das variáveis que você escreveu previamente serão substituídas ou sobrescritas.
Lembrando que para que as variáveis sejam efetivamente geradas, será necessário executar o script criado.
Sobrescrever .env
com as novas Variáveis de Ambiente
Caso já haja um arquivo .env
na raiz do seu projeto e você queira sobrescrever completamente seu com as variáveis geradas automaticamente, basta passar a propriedade mode: "overwite"
, da seguinte forma:
Lembrando que para que as variáveis sejam efetivamente geradas, será necessário executar o script criado.
Executar a geração automática das Variáveis de Ambiente
Após criar o script que irá gerar as variáveis de ambiente conforme os exemplos de código acima, será necessário executá-lo para que as variáveis de ambiente sejam efetivamente geradas.
Então para facilitar o trabalho, escreva o script em um arquivo na raiz do seu projeto chamado generate-dot-env.js
, agora basta abrir o terminal no diretório raiz do projeto e digitar o comando node ./generate-dot-env.js
Gerar manualmente as Variáveis de Ambiente
Caso você queira escrever manualmente o conteúdo de suas variáveis de ambiente, siga os passos abaixo:
- Crie um arquivo na raiz do projeto com nome de
.env
. - Abra o arquivo num editor de texto e armazene as seguintes variáveis de ambiente.
- Se não estiver usando um framework, será necessário instalar o
dotenv
para ter acesso às variáveis de ambiente. Se for o caso, execute:
Validação e Segurança de Tipagem
Para obter maior segurança de tipagem é recomendado criar um arquivo para validar as variáveis de ambiente. Abaixo está um exemplo utilizando a biblioteca zod
.
Instale a biblioteca
Crie um arquivo com nome env.ts
e valide as variáveis da seguinte forma:
Credenciais
Para poder utilizar as APIs da Efí Pay é necessário fornecer algumas credenciais que serão passadas através das Variáveis de Ambiente, vamos entender cada uma delas.
Primeiro Passo - Criação da Conta
É necessário criar uma conta na gerencianet (Efí Pay) para poder obter as credenciais das APIs Efí Pay. Assista o vídeo que explica o processo de criação de contas se necessário.
Segundo Passo - Criação de um Aplicativo
Para ter acesso às suas credenciais é necessário criar um aplicativo. Ele representa uma conta dentro da Gerencianet que terá acesso às APIs da Efí Pay de forma que você pode ter diversos aplicativos, cada um contendo suas próprias credenciais e representando, por exemplo, um negócio aberto por você.
-
Vá até a aba API
-
Então crie uma aplicação
Depois de criada, acesse a aba Aplicações de suas APIs. Ela listará todas as suas aplicações criadas. Escolha a aplicação que você acabou de criar e então terá acesso às suas credenciais Client ID e Client Secret de Produção e de Homologação.
Com essas credenciais, alimente as Variáveis de Ambiente CLIENT_ID_HOMOLOGACAO
, CLIENT_SECRET_HOMOLOGACAO
e CLIENT_ID_PRODUCAO
, CLIENT_SECRET_PRODUCAO
. Lembrando que agora é possível gerá-las automaticamente através do SDK.
Terceiro Passo - Criação dos Certificados
Acesse a aba Meus Certificados abaixo da aba Aplicações e então crie um certificado para Produção e outro para Homologação.
Ao criar um certificado, você receberá um arquivo que deve ser baixado no seu computador, certifique-se de não perder este arquivo, pois ele só pode ser baixado no momento da criação do certificado e não estará disponível para download posteriormente.
Salve o arquivo em algum lugar dentro do seu projeto e após fazer isso alimente as Variáveis de Ambiente CERTIFICADO_HOMOLOGACAO_PATH
e CERTIFICADO_PRODUCAO_PATH
com o caminho do arquivo onde você salvou os certificados, exemplo: "./src/certificados/homologacao.p12"
. Lembrando que agora é possível gerá-las automaticamente através do SDK.
Certificados em formato base64
Agora o SDK oferece uma forma de converter seus cerificados em formato base64
.
Para realizar a conversão certifique-se de ter salvo os certificados em algum lugar em seu computador, então importe a classe EfiPay
de @bruno-valero/gerencianet-sdk-typescript
e use seu método estático generateBase64FromCertificate
passando os caminhos onde os certificados estão salvos. Não é obrigatório passar os caminhos de todos os certificados, os que não forem preenchidos por você serão substituídas por valores dummy padrão.
Observe o exemplo:
Criação do arquivo .env
Caso o arquivo .env
não exista na raiz do seu projeto, o SDK irá criá-lo após a execução do script de conversão, preenchendo todas as variáveis de ambiente com valores dummy padrão, exceto as variáveis que irão conter o conteúdo dos seus certificados convertidos em base64
.
Arquivo .env
já existente
Caso o arquivo .env
já exista na raiz do seu projeto, ao executar o script de conversão, o SDK irá preencher todas as variáveis de ambiente com valores já existentes (as variáveis de ambiente que não existirem no .env
, serão preenchidas com valores dummy padrão), exceto as variáveis que irão conter o conteúdo dos seus certificados convertidos em base64
.
Executar a conversão dos certificados em em formato base64
Após criar o script que irá converter os certificados em em formato base64
conforme o exemplo de código acima, será necessário executá-lo para que os certificados sejam efetivamente convertidos.
Então para facilitar o trabalho, escreva o script em um arquivo na raiz do seu projeto chamado certificates-to-base64.js
, agora basta abrir o terminal no diretório raiz do projeto e digitar o comando node ./certificates-to-base64.js
Quarto Passo - Criação da Chave Pix
Para receber uma transação PIX é necessário criar uma chave PIX, que pode ser seu CPF, Número de Celular, Email ou uma Chave Aleatória.
Entre em sua conta da Efí Pay, vá até a aba Pix e escolha a opção Minhas Chaves então clique no botão Cadastrar Chave, escolha o tipo de chave, exemplo CPF, Email, etc. Por fim alimente a Variável de Ambiente PIX_KEY
com o valor de sua chave.
Após cumprir estes passos, todas as credenciais necessárias para o funcionamento do sdk estão configuradas.
Utilização do SDK
Para utilizar o SDK integrado ao typescript, basta importá-lo no arquivo e instanciar a classe EfiPay
passando como parâmetro o tipo da conexão que pode ser "PRODUCTION"
ou "SANDBOX"
, da seguinte forma:
- Tipo "PRODUCTION": É a conexão com as APIs de Produção, ou seja, destinado a transações financeiras reais
- Tipo "SANDBOX": É a conexão com as APIs de Homologação, ou seja, destinado a transações financeiras fictícias
Utilizar certificados em formato base64
Agora é possível instanciar a classe EfiPay
configurada para aceitar certificados em formato base64
.
Caso você não tenha os certificados, veja como obtê-los e como convertê-los em formato base64
.
Para utilizar o SDK com certificados em formato base64
, basta ter feito o processo de conversão e instanciar a classe EfiPay
passando a propriedade certificateType: "base64"
da seguinte forma:
Utilizar certificados em formato Buffer
Agora é possível instanciar a classe EfiPay
configurada para aceitar certificados em formato Buffer
.
Esta opção é útil, caso você não queira deixar o certificado salvo em sua aplicação, deixando-o hospedado num Amazon S3, Google Cloud Storage, entre outros.
Há duas formas de utilizar os certificados em formato Buffer
:
-
- Instanciar a classe
EfiPay
passando diretamente o certificado em formato buffer, sem a utilização das variáveis de ambiente. Execute o código abaixo para obter oBuffer
de seu certificado através doconsole.log
.
- Instanciar a classe
-
- Salvar o Buffer em formato
base64
através do método estáticoEfiPay.generateBase64FromBufferCertificate
. Esse método irá gerar um arquivo.env
da mesma forma que é explicado aqui. Abaixo há um exemplo de como obter os dados a partir da url de download, transformar a resposta emBuffer
e com isso utilizar o métodoEfiPay.generateBase64FromBufferCertificate
.
- Salvar o Buffer em formato
Utilizar o SDK sem as Variáveis de Ambiente
Agora é possível utilizar o SDK sem as variáveis de ambiente. Basta passar as credenciais manualmente, da seguinte forma:
API PIX
A API Pix Efí oferece recursos avançados para integração com sua aplicação, permitindo que você crie soluções personalizadas e ofereça opções de pagamento inovadoras aos seus clientes. É possível criar cobranças, verificar os Pix recebidos, devolver e enviar Pix.
Cobranças imediatas - imediateCharge
Responsável pela gestão de cobranças imediatas. As cobranças, no contexto da API Pix representam uma transação financeira entre um pagador e um recebedor, cuja forma de pagamento é o Pix.
Informação
É possível dividir o recebimento do pix em até 20 pessoas, um exemplo de contexto onde isto seria útil é em casos que uma comissão deve ser pagada para um dos contribuintes de um serviço.
A divisão do recebimento pode ser feita após criar a cobrança imediata e antes do pagador realizar o envio. Para dividir, basta utilizar o split de pagamento pix
- Testes de Integração Realizados
Para entender mais sobre as cobranças imediatas, leia as anotações typescript do SDK ou visite a documentação oficial
Para utilizar as cobranças imediatas através do SDK acesse a propriedade imediateCharge
da api PIX, dessa forma:
Cobranças com vencimento - dueCharge
Responsável pela gestão de cobranças com vencimento. As cobranças, no contexto da API Pix, representam uma transação financeira entre um pagador e um recebedor, cuja forma de pagamento é o Pix.
Informação
É possível dividir o recebimento do pix em até 20 pessoas, um exemplo de contexto onde isto seria útil é em casos que uma comissão deve ser pagada para um dos contribuintes de um serviço.
A divisão do recebimento pode ser feita após criar a cobrança com vencimento e antes do pagador realizar o envio. Para dividir, basta utilizar o split de pagamento pix
- Testes de Integração Realizados
Para entender mais sobre as cobranças com vencimento, leia as anotações typescript do SDK ou visite a documentação oficial
Para utilizar as cobranças com vencimento através do SDK acesse a propriedade dueCharge
da api PIX, dessa forma:
Envio e Pagamento Pix - sendAndPayment
Traz as funcionalidades disponíveis para a gestão do Envio de Pix e do Pagamento de QR Codes Pix
- Testes de Integração Não Realizados
Para entender mais sobre as envio e pagamento pix, leia as anotações typescript do SDK ou visite a documentação oficial
Para utilizar as envio e pagamento pix através do SDK acesse a propriedade sendAndPayment
da api PIX, dessa forma:
Webhooks - webhooks
Gerenciamento de notificações por parte do PSP recebedor a pessoa usuária recebedora.
- Testes de Integração Realizados
Para entender mais sobre as webhooks, leia as anotações typescript do SDK ou visite a documentação oficial
Para utilizar as webhooks através do SDK acesse a propriedade webhooks
da api PIX, dessa forma:
Gestão de Pix - manage
Gestão das transações Pix, isto é, a manutenção dos recebimentos e devoluções Pix.
- Testes de Integração Não Realizados
Para entender mais sobre as gestão de pix, leia as anotações typescript do SDK ou visite a documentação oficial
Para utilizar as gestão de pix através do SDK acesse a propriedade manage
da api PIX, dessa forma:
Payload Locations - payloadLocations
Destinado a lidar com configuração e remoção de locations para uso dos payloads.
- Testes de Integração Realizados
Para entender mais sobre as payload locations, leia as anotações typescript do SDK ou visite a documentação oficial
Para utilizar as payload locations através do SDK acesse a propriedade payloadLocations
da api PIX, dessa forma:
Cobranças em Lote - batchCollections
Responsável pela gestão de cobranças em lote. As cobranças, no contexto da API Pix, representam uma transação financeira entre um pagador e um recebedor, cuja forma de pagamento é o Pix.
- Testes de Integração Realizados
Atenção - Ainda não foram realizados corretamente para o método updateDueChargeBatch
Para entender mais sobre as Cobranças em Lote, leia as anotações typescript do SDK ou visite a documentação oficial
Para utilizar as Cobranças em Lote através do SDK acesse a propriedade batchCollections
da api PIX, dessa forma:
Split de pagamento Pix - paymentSplit
Realização do Split de pagamento na API Pix Efí. Responsável pela configuração dos Splits de pagamento na API Pix. As cobranças, no contexto da API Pix representam uma transação financeira entre um pagador e um recebedor, cuja forma de pagamento é o Pix.
Realizar o split de pagamento após criar uma cobrança
É possível realizar a divisão do pagamento depois de criar uma cobrança imediata ou uma cobrança com vencimento.
Importante!
O Split de pagamento Pix só pode ser realizado entre contas Efí, com limite máximo de 20 contas para o repasse.
Informação
Uma mesma configuração de Split pode ser utilizada em várias cobranças. Isso significa que você pode definir uma divisão de valores para um parceiro e aplicá-la em todas as cobranças relacionadas.
Configure Split de Pagamento em QR Code e copia e cola estático!
Você tem a flexibilidade de dividir o pagamento dos QR Codes e copia e cola estático entre diferentes contas Efí. Isso significa que, ao gerar um QR Code ou um código copia e cola estáticos para pagamento, você pode especificar como o valor recebido será distribuído, facilitando a gestão financeira e assegurando que os fundos sejam alocados corretamente desde o início.
Instruções para testes em Homologação
No processo de split de pagamento, é essencial fornecer uma conta digital EFÍ válida. É importante destacar que não é possível realizar o split para a própria conta. Portanto, se estiver realizando testes em ambiente de homologação e não possuir uma conta válida para os repasses, será necessário criar uma subconta. Veja como fazer isso aqui.
- Testes de Integração Realizados
Para entender mais sobre as Split de pagamento Pix, leia as anotações typescript do SDK ou visite a documentação oficial
Para utilizar as Split de pagamento Pix através do SDK acesse a propriedade paymentSplit
da api PIX, dessa forma:
API Cobranças
A API Cobranças Efí oferece recursos avançados que permitem emitir diferentes tipos de cobranças, tais como Boleto, Cartão de crédito, Carnê, Links de pagamento, Assinaturas (Recorrência) e Marketplace (Split de pagamento).
Cartão - card
As transações online via cartão de crédito exigem apenas a numeração de face e o código no verso do cartão, o que pode resultar em transações suspeitas. Por isso, é importante adotar procedimentos de segurança para evitar prejuízos financeiros, como o Chargeback.
Quando uma transação com cartão de crédito é realizada, ela passa por três etapas: autorização da operadora, análise de segurança e captura. Cada transação é analisada para identificar possíveis riscos. Se for aprovada, o valor é debitado na fatura do cliente. Caso contrário, o valor fica reservado até que a comunicação reversa seja concluída e o limite do cartão seja reestabelecido.
As funcionalidades estão em desenvolvimento
Lista de Cartões aceitos pela Efí Pay
- Visa
- Master
- AmericanExpress
- Elo
- Hipercard
Atenção!
Para fazer o pagamento com cartão de crédito, é necessário obter o payment_token da transação. Portanto, é imprescindível seguir os procedimentos para obter o payment_token conforme descrito no documento antes de criar a cobrança com cartão de crédito. Outra informação importante é você precisa cadastrar o ramo de atividade em sua conta. Confira mais detalhes aqui.
Tokenização de cartão
Se você precisa reutilizar o payment_token para fins de recorrência, utilize o atributo reuse
com o valor booleano true
. Dessa forma, o payment_token pode ser usado em mais de uma transação de forma segura, sem a necessidade de salvar os dados do cartão
Simulação em Ambiente de Homologação
A simulação de cobranças de cartão em ambiente de Homologação funciona com base na análise imediata de acordo com o último dígito do número do cartão de crédito utilizado:
- Cartão com final 1 retorna:
"reason":"Dados do cartão inválidos."
- Cartão com final 2 retorna:
"reason":"Transação não autorizada por motivos de segurança."
- Cartão com final 3 retorna:
"reason":"Transação não autorizada, tente novamente mais tarde."
- Demais finais têm transação aprovada.
- Testes de Integração Não Realizados
Para entender mais sobre o Cartão, leia as anotações typescript do SDK ou visite a documentação oficial
Para utilizar o Cartão através do SDK acesse a propriedade card
da api Cobranca, dessa forma: