abraham-flutterwave / laravel-payment
The Official Flutterwave Package for Laravel.
Installs: 1 214
Dependents: 0
Suggesters: 0
Security: 0
Stars: 3
Watchers: 1
Forks: 1
Open Issues: 1
Type:laravel-library
Requires
- php: ^7.4 || ^8.0
- ext-json: *
- illuminate/support: ^7.0|^v8.83|^9.39|^10.0|^11.0
Requires (Dev)
- laravel/pint: ^1.2
- nunomaduro/phpinsights: ^2.6
- orchestra/testbench: ^7.11
- pestphp/pest: ^1.22
This package is auto-updated.
Last update: 2024-03-31 01:09:07 UTC
README
Flutterwave Laravel.
This Flutterwave Laravel Package provides easy access to Flutterwave for Business (F4B) v3 APIs from Laravel apps. It abstracts the complexity involved in direct integration and allows you to make quick calls to the APIs.
Available features include:
- Collections: Card, Account, Mobile money, Bank Transfers, USSD, Barter, NQR.
Table of Contents
- Requirements
- Installation
- Initialization
- Usage
- Testing
- Debugging Errors
- Support
- Contribution guidelines
- License
- Changelog
Requirements
- Flutterwave for business API Keys
- Acceptable PHP versions: >= 7.3
Installation
The vendor folder is committed into the project to allow easy installation for those who do not have composer installed. It is recommended to update the project dependencies using:
$ composer require abraham-flutterwave/laravel-payment
Ensure that you publish your config file by running:
$ php artisan vendor:publish --provider="Flutterwave\Payments\Providers\FlutterwaveServiceProvider"
Initialization
In your .env file add the following environment variables:
PUBLIC_KEY="****YOUR**PUBLIC**KEY****" // can be gotten from the dashboard SECRET_KEY="****YOUR**SECRET**KEY****" // can be gotten from the dashboard ENCRYPTION_KEY="Encryption key" ENV="staging/production"
Business Settings/preferences like logo, name, payment method can be set in the config file config/flutterwave.php
'businessName' => env('BUSINESS_NAME', 'Flutterwave Store'), 'transactionPrefix' => env('TRANSACTION_PREFIX', 'LARAVEL-'), 'logo' => env('BUSINESS_LOGO', 'https://res.cloudinary.com/decagon/image/upload/v1593642339/decagon-logo.png'), 'title' => env('TITLE', 'Flutterwave Store'), 'description' => env('DESCRIPTION', 'Flutterwave Store Description'), 'country' => env('COUNTRY', 'NG'), 'currency' => env('CURRENCY', Currency::NGN), 'paymentType' => [ 'card', 'account', 'banktransfer', 'mpesa', 'mobilemoneyrwanda', 'mobilemoneyzambia', 'mobilemoneyuganda', 'ussd', 'qr', 'mobilemoneyghana', 'credit', 'barter', 'payattitude', 'mobilemoneyfranco', 'mobilemoneytanzania', 'paga', '1voucher', ],
Usage
Render Payment Modal
There are two types of modal that can be rendered, the inline modal and the standard modal. The inline modal is rendered on your website while the standard modal is rendered on a flutterwave hosted page.
Inline Modal
use Flutterwave\Payments\Facades\Flutterwave; use Flutterwave\Payments\Data\Currency; $payload = [ "tx_ref" => Flutterwave::generateTransactionReference(), "amount" => 100, "currency" => Currency::NGN, "customer" => [ "email" => "developers@flutterwavego.com" ], ]; $payment_details = Flutterwave::render('inline', $payload); return view('flutterwave::modal', compact('payment_details'));
Standard Modal
use Flutterwave\Payments\Facades\Flutterwave; use Flutterwave\Payments\Data\Currency; $payload = [ "tx_ref" => Flutterwave::generateTransactionReference(), "amount" => 100, "currency" => Currency::NGN, "customer" => [ "email" => "developers@flutterwavego.com" ], ]; $payment_link = Flutterwave::render('standard', $payload); return redirect($payment_link);
Logging
To enable logging, simple add the following to your config file config/logging.php
'flutterwave' => [ 'driver' => 'single', 'path' => storage_path('logs/flutterwave.log'), 'level' => 'debug', ],
Webhook Setup
Create a Webhook url to receive payment notification on Payment events. Below is a sample of a webhook url implementation using the new package.
use Flutterwave\Payments\Facades\Flutterwave; use Flutterwave\Payments\Data\Status; Route::post('flutterwave/payment/webhook', function () { $method = request()->method(); if ($method === 'POST') { //get the request body $body = request()->getContent(); $webhook = Flutterwave::use('webhooks'); $transaction = Flutterwave::use('transactions'); //get the request signature $signature = request()->header($webhook::SECURE_HEADER); //verify the signature $isVerified = $webhook->verifySignature($body, $signature); if ($isVerified) { [ 'tx_ref' => $tx_ref, 'id' => $id ] = $webhook->getHook(); [ 'status' => $status, 'data' => $transactionData ] = $transaction->verifyTransactionReference($tx_ref); $responseData = ['tx_ref' => $tx_ref, 'id' => $id]; if ($status === 'success') { switch ($transactionData['status']) { case Status::SUCCESSFUL: // do something //save to database //send email break; case Status::PENDING: // do something //save to database //send email break; case Status::FAILED: // do something //save to database //send email break; } } return response()->json(['status' => 'success', 'message' => 'Webhook verified by Flutterwave Laravel Package', 'data' => $responseData]); } return response()->json(['status' => 'error', 'message' => 'Access denied. Hash invalid'])->setStatusCode(401); } // return 404 return abort(404); })->name('flutterwave.webhook');
Testing
All of the SDK's tests are written with PHP's phpunit
module. The tests currently test:
Modals
,
Webhooks
,
Transactions
,
They can be run like so:
phpunit
NOTE: If the test fails for creating a subaccount, just change the
account_number
account_bank
andbusinesss_email
to something different
NOTE: The test may fail for account validation -
Pending OTP validation
depending on whether the service is down or not
Debugging Errors
We understand that you may run into some errors while integrating our library. You can read more about our error messages here.
For authorization
and validation
error responses, double-check your API keys and request. If you get a server
error, kindly engage the team for support.
Support
For additional assistance using this library, contact the developer experience (DX) team via email or on slack.
You can also follow us @FlutterwaveEng and let us know what you think 😊.
Contribution guidelines
Read more about our community contribution guidelines here
License
By contributing to this library, you agree that your contributions will be licensed under its MIT license.
Copyright (c) Flutterwave Inc.
Flutterwave API References
TODOs
- Add other Flutterwave Services - card,transfer,subaccount,payoutsubaccounts,plans and momo
- Console Commands - Webhooks, Make Payment, and Refunds.