A modern, maintainable, and extensible Paystack integration for Laravel, built on top of the matscode/paystack-php-sdk. Feel free to reference the main SDK to see other available api method/property
- Clean, service-based Paystack API integration
- Laravel service provider and facade
- Global
paystack()
helper for convenient access - Uses matscode/paystack-php-sdk under the hood
- Configurable via
config/paystack.php
- Well-documented
- PHP 8.0+
- Laravel 9.0+
- matscode/paystack-php-sdk (installed automatically)
Install via Composer:
composer require matscode/paystack-laravel-sdk
Optionally, publish the config file:
php artisan vendor:publish --provider="Matscode\\PaystackLaravel\\PaystackServiceProvider" --tag="config"
Set your Paystack secret key in your .env
file:
PAYSTACK_SECRET_KEY=sk_test_xxxxxxxxxxxxxxxxxxxxxxxx
You can use the Paystack SDK in Laravel via:
- The
Paystack
Facade (recommended) - Dependency Injection (
Matscode\Paystack\Paystack
) - The
paystack()
helper (just likerequest()
orauth()
)
Note:
Access Style Facade ( Paystack
)DI ( app(...)
)Helper ( paystack()
)Method call ✅ Yes ✅ Yes ✅ Yes Property access ❌ No ✅ Yes ✅ Yes
- For the Facade, you must use static method calls for resources, such as
Paystack::transaction()
. Property access likePaystack::transaction
will not work.- For DI and the helper, both method calls (
->transaction()
) and property access (->transaction
) are supported.- Always use the method call syntax for maximum compatibility.
Initializes a new transaction and returns an authorization URL for the customer to complete payment. The response contains the transaction reference and other details.
// Using the Facade
Paystack::transaction()->initialize([
'email' => 'customer@email.com',
'amount' => 500000, // amount in kobo
'callback_url' => 'https://yourapp.com/paystack/transaction/verify',
]);
// Using the helper
paystack()->transaction->initialize([
'email' => 'customer@email.com',
'amount' => 500000, // amount in kobo
'callback_url' => 'https://yourapp.com/paystack/transaction/verify',
]);
Retrieves a list of all transactions carried out on your Paystack account. Returns an array of transaction objects.
// Using the Facade
Paystack::transaction()->list();
// Using the helper
paystack()->transaction->list();
Verifies the status of a transaction using its reference. Returns the transaction details if found.
// Using the Facade
$verification = Paystack::transaction()->verify($reference);
// Using the helper
$verification = paystack()->transaction->verify($reference);
Checks if a transaction was successful using its reference. Returns true
if successful, otherwise false
.
// Using the Facade
$isSuccessful = Paystack::transaction()->isSuccessful($reference); // returns true/false
// Using the helper
$isSuccessful = paystack()->transaction->isSuccessful($reference);
You can use the Paystack facade with method chaining to initialize a transaction and get the payment authorization URL:
use Paystack; // Make sure the facade is properly registered
// ... inside your controller or service
$response = Paystack::transaction()
->setCallbackUrl('https://yourapp.com/paystack/verify')
->setEmail('customer@email.com')
->setAmount(75000) // amount in Naira
->initialize();
$authorizationUrl = $response->data->authorization_url;
// Using the helper
$response = paystack()->transaction
->setCallbackUrl('https://yourapp.com/paystack/verify')
->setEmail('customer@email.com')
->setAmount(75000)
->initialize();
$authorizationUrl = $response->data->authorization_url;
setCallbackUrl()
sets the URL Paystack will redirect to after payment.setEmail()
sets the customer's email.setAmount()
sets the amount (in Naira, not kobo, when using this method).initialize()
sends the request to Paystack and returns the response.- The authorization URL for redirecting the user is in
$response->data->authorization_url
.
If you want to use the array method (amount in kobo):
// Using the Facade
$response = Paystack::transaction()->initialize([
'email' => 'customer@email.com',
'amount' => 500000, // amount in kobo
'callback_url' => 'https://yourapp.com/paystack/verify',
]);
$authorizationUrl = $response['data']['authorization_url'];
// Using the helper
$response = paystack()->transaction->initialize([
'email' => 'customer@email.com',
'amount' => 500000, // amount in kobo
'callback_url' => 'https://yourapp.com/paystack/verify',
]);
$authorizationUrl = $response['data']['authorization_url'];
Retrieves a list of all supported banks for your Paystack account. Useful for populating bank selection dropdowns in forms.
// Using the Facade
Paystack::bank()->list();
// Using the helper
paystack()->bank->list();
Resolves and validates a Nigerian bank account number and bank code. Returns the account name and other details if valid.
// Using the Facade
$account = Paystack::bank()->resolve($bankCode, $accountNumber);
// Using the helper
$account = paystack()->bank->resolve($bankCode, $accountNumber);
Note: More resources (Customers, Plans, Subscription, Transfers, etc.) may be added as the SDK evolves. For the latest, see the PHP SDK documentation.
This library is licensed under the GNU General Public License v3.0 (GPL-3.0). See the LICENSE file for the full license text.