lucas-simas / getnet-php
SDK php para integração com a API Getnet
dev-master
2024-11-18 21:06 UTC
Requires
- php: ^8.2
Requires (Dev)
- kint-php/kint: ^5.1.0
- monolog/monolog: *
- phpstan/phpstan: ^1.10.67
- phpunit/phpunit: ^11.1.2
This package is auto-updated.
Last update: 2024-12-18 21:21:32 UTC
README
GETNET SDK PHP - API v1
E-commerce
Todos os passos e processos referentes à integração com o sistema de captura e autorização de transações financeiras da Getnet via as funcionalidades da API.
Documentação oficial
Pré-requisitos
- PHP
^8.2
Composer
add composer.json
"lucas-simas/getnet-php": "dev-master"
ou execute
composer require lucas-simas/getnet-php
Exemplo Autorização com cartão de crédito MasterCard R$27,50 em 2x
use Getnet\API\Getnet; use Getnet\API\Transaction; use Getnet\API\Environment; use Getnet\API\Token; use Getnet\API\Credit; use Getnet\API\Customer; use Getnet\API\Card; use Getnet\API\Order; use Getnet\API\Boleto; include 'vendor/autoload.php'; $client_id = "xxxxxxxx-xxxx-xxxx-xxxxxxxxxxxxxxxxx"; $client_secret = "xxxxxxxx-xxxx-xxxx-xxxxxxxxxxxxxxxxx"; $seller_id = "xxxxxxxx-xxxx-xxxx-xxxxxxxxxxxxxxxxx"; $environment = Environment::sandbox(); //Opicional, passar chave se você quiser guardar o token do auth na sessão para não precisar buscar a cada trasação, só quando expira $keySession = null; //Autenticação da API $getnet = new Getnet($client_id, $client_secret, $environment, $keySession); // Inicia uma transação $transaction = new Transaction(); // Dados do pedido - Transação $transaction->setSellerId($seller_id); $transaction->setCurrency("BRL"); $transaction->setAmount(27.50); // Detalhes do Pedido $transaction->order("123456") ->setProductType(Order::PRODUCT_TYPE_SERVICE) ->setSalesTax(0); // Gera token do cartão $tokenCard = new Token("5155901222280001", "customer_210818263", $getnet); // Ou para usar um cartão já tokenizado que está salvo // $tokenCard = new \Getnet\API\Entity\CardToken('Pass your card token'); // Dados do método de pagamento do comprador $transaction->credit() ->setAuthenticated(false) ->setDynamicMcc("1799") ->setSoftDescriptor("LOJA*TESTE*COMPRA-123") ->setDelayed(false) ->setPreAuthorization(false) ->setNumberInstallments(2) ->setSaveCardData(false) ->setTransactionType(Credit::TRANSACTION_TYPE_INSTALL_NO_INTEREST) ->card($tokenCard) ->setBrand(Card::BRAND_MASTERCARD) ->setExpirationMonth("12") ->setExpirationYear("30") ->setCardholderName("Jax Teller") ->setSecurityCode("123"); // Dados pessoais do comprador $transaction->customer("customer_210818263") ->setDocumentType(Customer::DOCUMENT_TYPE_CPF) ->setEmail("customer@email.com.br") ->setFirstName("Jax") ->setLastName("Teller") ->setName("Jax Teller") ->setPhoneNumber("5551999887766") ->setDocumentNumber("12345678912") ->billingAddress() ->setCity("São Paulo") ->setComplement("Sons of Anarchy") ->setCountry("Brasil") ->setDistrict("Centro") ->setNumber("1000") ->setPostalCode("90230060") ->setState("SP") ->setStreet("Av. Brasil"); // Dados de entrega do pedido $transaction->shipping() ->setFirstName("Jax") ->setEmail("customer@email.com.br") ->setName("Jax Teller") ->setPhoneNumber("5551999887766") ->setShippingAmount(0) ->address() ->setCity("Porto Alegre") ->setComplement("Sons of Anarchy") ->setCountry("Brasil") ->setDistrict("São Geraldo") ->setNumber("1000") ->setPostalCode("90230060") ->setState("RS") ->setStreet("Av. Brasil"); //Ou pode adicionar entrega com os mesmos dados do customer //$transaction->addShippingByCustomer($transaction->getCustomer())->setShippingAmount(0); // FingerPrint - Antifraude $transaction->device("device_id")->setIpAddress("127.0.0.1"); // Processa a Transação $response = $getnet->authorize($transaction); // Resultado da transação - Consultar tabela abaixo $response->getStatus();
CONFIRMA PAGAMENTO (CAPTURA)
// Autenticação da API $getnet = new Getnet($client_id, $client_secret, $environment, $keySession); // Processa a confirmação da autorização $capture = $getnet->authorizeConfirm("PAYMENT_ID"); // Resultado da transação - Consultar tabela abaixo $capture->getStatus();
CANCELA PAGAMENTO (CRÉDITO e DÉBITO)
// Autenticação da API $getnet = new Getnet($client_id, $client_secret, $environment, $keySession); $cancel = $getnet->authorizeCancel("[PAYMENT_ID]", [AMOUNT]); // Resultado da transação - Consultar tabela abaixo $cancel->getStatus();
PAGAMENTO VIA PIX
// Autenticação da API $getnet = new Getnet($client_id, $client_secret, $environment); // Atenção Obrigatório adicionar seller_id no header do PIX $getnet->setSellerId($seller_id); // Cria a transação $transaction = new PixTransaction(75.50); $transaction->setCurrency("BRL"); $transaction->setOrderId('DEV-1608748980'); $transaction->setCustomerId('12345'); // Cria a transação e retorna dados do QR Code // Pagamento é confirmado via notificações https://developers.getnet.com.br/api#tag/Notificacoes-1.0 // O QR Code PIX tem um limite de expiração, que é de 3 minutos, após esse período deve ser gerado um novo QR Code e o anterior deve ser desconsiderado. $response = $getnet->pix($transaction); print $response->getQrCode();
CARTÃO DE DÉBITO
// Autenticação da API $getnet = new Getnet($client_id, $client_secret, $environment, $keySession); // URL de callback $URL_NOTIFY = "http://localhost/url-notify"; //Adicionar dados do Pagamento no lugar do credit ou resto é igual ao cartão de crédito $transaction->debit() ->setCardholderMobile("5551999887766") ->setDynamicMcc("1799") ->setSoftDescriptor("LOJA*TESTE*COMPRA-123") ->card($tokenCard) ->setBrand(Card::BRAND_MASTERCARD) ->setExpirationMonth("12") ->setExpirationYear("30") ->setCardholderName("Jax Teller") ->setSecurityCode("123"); $response = $getnet->authorize($transaction);
*Depois de autorizar é preciso redirecionar o cliente para o redirect_url passando uma url de callback
<form action="<?php echo $response->getRedirectUrl();?>" method="post" target="_blank"> <input type="hidden" name="MD" value="<?php echo $response->getIssuerPaymentId();?>" /> <input type="hidden" name="PaReq" value="<?php echo $response->getPayerAuthenticationRequest();?>" /> <input type="hidden" name="TermUrl" value="<?php echo $URL_NOTIFY;?>" /> <input type="submit" value="Authentication Card" /> </form>
*Depois do cliente finalizar o pagamento e você receber o callback
//CONFIRMAR O PAGAMENTO COM payer_authentication_response recibo na URL de Noficação $response = $getnet->authorizeConfirmDebit($response->getPaymentId(), $payer_authentication_response); // Resultado da transação - Consultar tabela abaixo $response->getStatus();
BOLETO BANCÁRIO (SANTANDER)
//Autenticação da API $getnet = new Getnet($client_id, $client_secret, $environment, $keySession); //Cria a transação $transaction = new Transaction(); $transaction->setSellerId($seller_id); $transaction->setCurrency("BRL"); $transaction->setAmount(75.50); //Adicionar dados do Pedido $transaction->order("123456") ->setProductType(Order::PRODUCT_TYPE_SERVICE) ->setSalesTax(0); $transaction->boleto("000001946598") ->setDocumentNumber("170500000019763") ->setExpirationDate("21/11/2018") ->setProvider(Boleto::PROVIDER_SANTANDER) ->setInstructions("Não receber após o vencimento"); //Adicionar dados do cliente $transaction->customer("customer_210818263") ->setDocumentType(Customer::DOCUMENT_TYPE_CPF) ->setEmail("customer@email.com.br") ->setFirstName("Jax") ->setLastName("Teller") ->setName("Jax Teller") ->setPhoneNumber("5551999887766") ->setDocumentNumber("12345678912") ->billingAddress() ->setCity("São Paulo") ->setComplement("Sons of Anarchy") ->setCountry("Brasil") ->setDistrict("Centro") ->setNumber("1000") ->setPostalCode("90230060") ->setState("SP") ->setStreet("Av. Brasil"); $response = $getnet->boleto($transaction); // Resultado da transação - Consultar tabela abaixo $response->getStatus();
SALVAR CARTÃO NO COFRE
//Autenticação da API $getnet = new Getnet($client_id, $client_secret, $environment, $keySession); $card_number = '5155901222280001'; $customer_id = 'customer_210818263'; // Generate token $cardService = new \Getnet\API\Service\CardService($getnet); $cardToken = $cardService->generateCardToken($card_number, $customer_id); $card = new Card($cardToken); $card->setBrand(Card::BRAND_MASTERCARD) ->setExpirationMonth("12") ->setExpirationYear("30") ->setCardholderName("Jax Teller") ->setSecurityCode("123") ->setCustomerId($customer_id); // Save $saveCard = $cardService->saveCard($card); // Get by card_id $savedCard = $cardService->getCard($saveCard->getCardId()); // Get by customer_id $cards = $cardService->getCardsByCustomerId($customer_id); // Delete $delete = $cardService->deleteCard($saveCard->getCardId());
BUSCAR E USAR CARTÃO SALVO NO COFRE
$cardService = new \Getnet\API\Service\CardService($getnet); $card = $cardService->getCard("pass-card-id"); // Adicionar dados do Pagamento, atenção o SecurityCode não fica salvo $transaction->credit() ->setAuthenticated(false) ->setDynamicMcc("1799") ->setSoftDescriptor("LOJA*TESTE*COMPRA-123") ->setDelayed(false) ->setPreAuthorization(false) ->setNumberInstallments(2) ->setSaveCardData(false) ->setTransactionType(Credit::TRANSACTION_TYPE_INSTALL_NO_INTEREST) ->setCard($card->setSecurityCode('123')); ...
REQUESTS CUSTOMIZADOS PARA OUTROS ENDPOINTS DA API
//Autenticação da API $getnet = new Getnet($client_id, $client_secret, $environment, $keySession); // List customers $response = $getnet->customRequest('GET', '/v1/customers?page=1&limit=5'); print_r($response['customers']);
Possíveis status de resposta de uma transação
Cartões para testes
Ambientes disponíveis
Meios de Pagamento
Métodos de Pagamento
Instalar e configurar ambiente para desenvolvimento/alterações
- Clone o repositório
- Instale as dependências rodando
composer install
na raiz do projeto - Na pasta
config
crie um arquivoconfig/env.test.php
baseado noconfig/env.test.php.txt
- Adicione suas credenciais do sandbox da getnet no
config/env.test.php
- Rodar testes
composer test
composer test:unit
composer test:e2e
composer phpstan