potelo / multi-payment
Fornece uma interface para controlar pagamentos de múltiplos gateways
Installs: 7 746
Dependents: 0
Suggesters: 0
Security: 0
Stars: 7
Watchers: 4
Forks: 3
Open Issues: 1
pkg:composer/potelo/multi-payment
Requires
- php: ^8.0|^8.1|^8.2|^8.3
- illuminate/config: ^8.0|^9.0|^10.0
- illuminate/support: ^8.0|^9.0|^10.0
- iugu/iugu: dev-master
Requires (Dev)
- orchestra/testbench: ~8.0
- phpunit/phpunit: ^9.5
- dev-main
- 2.2.3
- 2.2.0
- v2.1.3
- v2.1.2
- v2.1.1
- v2.1.0
- v2.0.3
- v2.0.2
- v2.0.1
- v2.0.0
- v1.1.5
- v1.1.4
- v1.1.3
- v1.1.2
- v1.1.1
- v1.1.0
- v1.0.0
- v0.4.0
- v0.3.0
- v0.2.3
- v0.2.2
- v0.2.1
- v0.2.0
- v0.1.0
- dev-customer-create
- dev-charge-with-credit-card
- dev-ultimos-digitos-sandbox
- dev-search-card
- dev-fix-credit-card-data
- dev-fix-pix-info
- dev-revert-v1.1.1
- dev-gateway-options
- dev-iugu-due-at
- dev-iugu-expires_in
- dev-order-id
- dev-fix-fatura-duplicada
- dev-custom-variable
- dev-cpfcnpj-valid
- dev-remove-moip
- dev-charge-exception
- dev-reset-v1.1.0
- dev-gabrielpeixoto-patch-1
- dev-create-many
This package is auto-updated.
Last update: 2025-10-01 00:13:23 UTC
README
MultiPayment permite gerenciar pagamentos de diversos gateways de pagamento. Atualmente suporta o Iugu.
Requisitos
- PHP 8.0+
- Laravel 8.0+
Instalação
Instale esse pacote pelo composer:
composer require potelo/multi-payment "dev-main"  
Configuração
Após instalar o pacote rode o comando abaixo para publicar as configurações no projeto Laravel
php artisan vendor:publish --provider="Potelo\MultiPayment\Providers\MultiPaymentServiceProvider"  
Verifique se o arquivo multi-payment.php foi criado no diretório config/.
Agora configure as variáveis de ambiente no arquivo .env:
APP_ENV=local MULTIPAYMENT_DEFAULT=iugu #iugu IUGU_ID= IUGU_APIKEY=
Opcionalmente você pode configurar o Trait, para facilitar o uso do método charge junto a um usuário.
use Potelo\MultiPayment\MultiPaymentTrait; class User extends Authenticatable { use MultiPaymentTrait; }
Usando o Trait:
$usuario = User::find(1); $usuario->charge($options, 'iugu', 10000);
Também é possível utilizar o Facade:
\Potelo\MultiPayment\Facades\MultiPayment::charge($options);
Utilizando
MultiPayment:
Usando a classe MultiPayment:
$payment = new \Potelo\MultiPayment\MultiPayment(); // gateway default será usado // ou $payment = new \Potelo\MultiPayment\MultiPayment('iugu'); // ou $payment = new \Potelo\MultiPayment\MultiPayment(); $payment->setGateway('iugu');
InvoiceBuilder
$multiPayment = new \Potelo\MultiPayment\MultiPayment('iugu'); $invoiceBuilder = $multiPayment->newInvoice(); $invoice = $invoiceBuilder->setPaymentMethod('payment_method') ->addCustomer('name', 'email', 'tax_document', 'phone_area', 'phone_number') ->addCustomerAddress('zip_code', 'street', 'number') ->addItem('description', 'quantity', 'price') ->create();
Confira src/MultiPayment/Builders/InvoiceBuilder.php para saber quais métodos estão disponíveis.
CustomerBuilder
$multiPayment = new \Potelo\MultiPayment\MultiPayment('iugu'); $customerBuilder = $multiPayment->newCustomer(); $customer = $customerBuilder->setName('Nome') ->setEmail('email') ->setTaxDocument('01234567891') ->setPhone('999999999', '71') ->addAddress('45400000', 'Rua', 'S/N') ->create();
Confira src/MultiPayment/Builders/CustomerBuilder.php para saber quais métodos estão disponíveis.
getInvoice
$invoiceId = '312ASDHGZXSGRTET312ASDHGZXSGRTET'; $payment = new \Potelo\MultiPayment\MultiPayment('iugu'); $foundInvoice = $payment->getInvoice($invoiceId);
charge
$options = [ 'amount' => 10000, 'customer' => [ 'name' => 'Nome do cliente', 'email' => 'email@example.com', 'tax_document' => '12345678901', 'phone_area' => '71', 'phone_number' => '999999999', 'address' => [ 'street' => 'Rua do cliente', 'number' => '123', 'complement' => 'Apto. 123', 'district' => 'Bairro do cliente', 'city' => 'Cidade do cliente', 'state' => 'SP', 'zip_code' => '12345678', ], ], 'items' => [ [ 'description' => 'Produto 1', 'quantity' => 1, 'price' => 10000, ], [ 'description' => 'Produto 2', 'quantity' => 2, 'price' => 5000, ], ], 'payment_method' => 'credit_card', 'credit_card' => [ 'number' => '1234567890123456', 'month' => '12', 'year' => '2022', 'cvv' => '123', 'first_name' => 'João', 'last_name' => 'Maria' ], ]; $payment = new \Potelo\MultiPayment\MultiPayment(); $payment->setGateway('iugu')->charge($options);
| atributo | obrigatório | tipo | descrição | exemplo | 
|---|---|---|---|---|
| amount | obrigatório caso itemsnão seja informado | int | valor em centavos | 10000 | 
| customer | obrigatório | array | array com os dados do cliente | ['name' => 'Nome do cliente'...] | 
| customer.name | obrigatório | string | nome do cliente | 'Nome do cliente' | 
| customer.email | obrigatório | string | email do cliente | 'joaomaria@email.com' | 
| customer.tax_document | string | cpf ou cnpj do cliente | '12345678901' | |
| birth_date | string formato yyyy-mm-dd | data de nascimento | '01/01/1990' | |
| customer.phone_number | string | telefone | '999999999' | |
| customer.phone_area | string | DDD | '999999999' | |
| customer.address | obrigatório para o método de pagamento bank_slip | array | array com os dados do endereço do cliente | ['street' => 'Rua do cliente'...] | 
| customer.address.street | obrigatório | string | nome da rua | 'Nome da rua' | 
| customer.address.number | obrigatório | string | número da casa | '123' | 
| customer.address.district | obrigatório | string | bairro | 'Bairro do cliente' | 
| customer.address.city | obrigatório | string | cidade | 'Salvador' | 
| customer.address.state | obrigatório | string | estado | 'Bahia' | 
| customer.address.complement | obrigatório | string | complemento | 'Apto. 123' | 
| customer.address.zip_code | obrigatório | string | cep | '12345678' | 
| items | obrigatório caso amountnão tenha sido informado | array | array com os itens da compra | [['description' => 'Produto 1',... | 
| items.description | obrigatório | string | descrição do item | 'Produto 1' | 
| items.quantity | obrigatório | int | quantidade do item | 1 | 
| items.price | obrigatório | int | valor do item | 10000 | 
| payment_method | 'credit_card','bank_slip' | método de pagamento | 'credit_card' | |
| expires_at | obrigatório caso payment_methodseja'bank_slip'ou'pix' | string no formato yyyy-mm-dd | data de expiração da fatura | 2021-10-10 | 
| credit_card | obrigatório caso payment_methodseja'credit_card' | array | array com os dados do cartão de crédito | ['number' => '1234567890123456',... | 
| credit_card.token | string | token do cartão para o gateway escolhido | 'abcdefghijklmnopqrstuvwxyz' | |
| credit_card.number | obrigatório caso tokennão tenha sido informado | string | número do cartão de crédito | '1234567890123456' | 
| credit_card.month | obrigatório caso tokennão tenha sido informado | string | mês de expiração do cartão de crédito | '12' | 
| credit_card.year | obrigatório caso tokennão tenha sido informado | string | ano de expiração do cartão de crédito | '2022' | 
| credit_card.cvv | obrigatório caso tokennão tenha sido informado | string | código de segurança do cartão de crédito | '123' | 
| credit_card.first_name | string | primeiro nome no cartão de crédito | 'João' | |
| credit_card.last_name | string | último nome no cartão de crédito | 'Maria' | |
| bank_slip | array | array com os dados do boleto | ['expires_at' => '2022-12-31',... | 
Models
Customer
$customer = new Customer(); $customer->name = 'Teste'; $customer->email = 'teste@email.com'; $customer->taxDocument = '12345678901'; $customer->save('iugu'); echo $customer->id; // 7D96C7C932F2427CAF54F042345A13C60CD7
Invoice
$invoice = new Invoice(); $invoice->customer = $customer; $item = new InvoiceItem(); $item->description = 'Teste'; $item->price = 10000; $item->quantity = 1; $invoice->items[] = $item; $invoice->paymentMethod = Invoice::PAYMENT_METHOD_CREDIT_CARD; $invoice->creditCard = new CreditCard(); $invoice->creditCard->number = '4111111111111111'; $invoice->creditCard->firstName = 'João'; $invoice->creditCard->lastName = 'Silva'; $invoice->creditCard->month = '11'; $invoice->creditCard->year = '2022'; $invoice->creditCard->cvv = '123'; $invoice->creditCard->customer = $customer; $invoice->save('iugu'); echo $invoice->id; // CB1FA9B5BD1C42B287F4AC7F6259E45D