digikraaft/paystack-php
最新稳定版本:v2.2.0
Composer 安装命令:
composer require digikraaft/paystack-php
包简介
PHP Implementation of Paystack API
README 文档
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_POINTs 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.
统计信息
- 总下载量: 4.78k
- 月度下载量: 0
- 日度下载量: 0
- 收藏数: 6
- 点击次数: 1
- 依赖项目数: 5
- 推荐数: 0
其他信息
- 授权协议: MIT
- 更新时间: 2020-06-11