digikraaft / paystack-php
PHP Implementation of Paystack API
Installs: 3 711
Dependents: 5
Suggesters: 0
Security: 0
Stars: 5
Watchers: 3
Forks: 1
Open Issues: 0
Requires
- php: ^8.0|^8.1|^8.2
- ext-json: *
- guzzlehttp/guzzle: ^7.2.0
Requires (Dev)
- friendsofphp/php-cs-fixer: ^2.16
- mockery/mockery: ^1.4
- php-coveralls/php-coveralls: ^2.2
- phpunit/phpunit: ^9.0
- scrutinizer/ocular: ^1.7
- vimeo/psalm: ^3.11
README
This package provides an expressive and convenient way to interact with the Paystack API.
Installation
You can install the package via composer:
composer require digikraaft/paystack-php
Usage
All APIs documented in Paystack's Developer Reference are currently supported by this package. Using the individual API follows a general convention so that it can be simple and predictable.
<?php
{API_NAME}::{API_END_POINT}();
Before this, the API key needs to be set. For example, to access the customer/list
endpoint,
<?php
use Digikraaft\Paystack\Paystack;
use Digikraaft\Paystack\Customer;
Paystack::setApiKey('sk_1234abcd');
$customers = Customer::list();
You can easily pass parameters to be sent as arguments to the API_END_POINT
method like this:
<?php
use Digikraaft\Paystack\Paystack;
use Digikraaft\Paystack\Customer;
Paystack::setApiKey('sk_1234abcd');
$params = [
'perPage' => 10,
'page' => 2,
];
$customers = Customer::list($params);
This also applies to POST
and PUT
requests.
For endpoints that require path parameters like the fetch customer
with the request like /customer/email_or_id_or_customer_code
,
simply pass in a string into the API_END_POINT
like this:
<?php
use Digikraaft\Paystack\Paystack;
use Digikraaft\Paystack\Customer;
Paystack::setApiKey('sk_1234abcd');
$customer = Customer::fetch('CUS_abc1234');
For API_END_POINT
s that take both path and body parameters like the update customer
with the PUT
request customer/id_or_customer_code
,
simply pass in a string as the first argument, an array as the second like this:
<?php
use Digikraaft\Paystack\Paystack;
use Digikraaft\Paystack\Customer;
$params = [
'first_name' => 'Tim',
'last_name' => 'Oladoyinbo',
];
Paystack::setApiKey('sk_1234abcd');
$customer = Customer::update('CUS_abc1234', $params);
There are a few exceptions to the API_END_POINT
convention.
The endpoint paymentrequest/list
becomes Invoice::list()
. This applies to all other actions as documented in the Paystack reference.
The endpoint bvn/match
becomes Bank::bvnMatch(array $params)
The endpoint decision/bin/{bin}
becomes Bank::resolveCardBin(string $bin)
This package returns the exact response from the Paystack API but as the stdClass
type such that responses can be accessed like this:
<?php
use Digikraaft\Paystack\Paystack;
use Digikraaft\Paystack\Customer;
Paystack::setApiKey('sk_1234abcd');
$customer = Customer::fetch('CUS_abc1234');
if ($customer->status && $customer->status == true) {
echo $customer->data->first_name;
}
Future updates will see to improving on how the response object is handled.
Documentation
For detailed documentation, check the wiki page here
Todo
- Comprehensive tests
- Better API response handling
Testing
composer test
More Good Stuff
Check here for more awesome free stuff!
Alternatives
- paystack-php
- perfectmak/paystack-php
- matscode/paystack-php
- PHP Library For Paystack.co (Unofficial)
- Cakephp-Paystack
Changelog
Please see CHANGELOG for more information on what has changed recently.
Contributing
Please see CONTRIBUTING for details.
Security
If you discover any security related issues, please email dev@digitalkraaft.com instead of using the issue tracker.
Credits
License
The MIT License (MIT). Please see License File for more information.