承接 zenithpay/laravel-zenithpay 相关项目开发

从需求分析到上线部署,全程专人跟进,保证项目质量与交付效率

邮箱:yvsm@zunyunkeji.com | QQ:316430983 | 微信:yvsm316

zenithpay/laravel-zenithpay

最新稳定版本:v1.0.1

Composer 安装命令:

composer require zenithpay/laravel-zenithpay

包简介

Laravel package for ZenithPay virtual account gateway

README 文档

README

A Laravel package for integrating ZenithPay dedicated virtual accounts into your application. This package provides a simple and elegant way to create and manage dedicated virtual accounts for your customers.

Latest Version License

Requirements

  • PHP 8.0 or higher
  • Laravel 10.x, 11.x, or 12.x

Installation

Install the package via Composer:

composer require zenithpay/laravel-zenithpay

Publish Configuration

Publish the configuration file to customize the package settings:

php artisan vendor:publish --tag=zenithpay-config

This will create a config/zenithpay.php file in your application.

Environment Configuration

Add the following environment variables to your .env file:

ZENITHPAY_BASE_URL=https://zenithpay.ng
ZENITHPAY_MERCHANT_ID=your_merchant_id
ZENITHPAY_SECRET_KEY=your_secret_key
ZENITHPAY_WEBHOOK_SECRET=your_webhook_secret

Getting Your API Credentials:

  1. Sign up for a ZenithPay account at https://zenithpay.ng
  2. Navigate to your dashboard settings
  3. Copy your Merchant ID and Secret Key
  4. Generate a webhook secret for secure webhook verification

Configuration

The config/zenithpay.php file contains the following options:

return [
    'base_url' => env('ZENITHPAY_BASE_URL', 'https://api.zenithpay.com'),
    'merchant_id' => env('ZENITHPAY_MERCHANT_ID'),
    'secret_key' => env('ZENITHPAY_SECRET_KEY'),
    'webhook_secret' => env('ZENITHPAY_WEBHOOK_SECRET'),
];

Usage

Using the Facade

Import the ZenithPay facade at the top of your file:

use ZenithPay\Facades\ZenithPay;

Creating a Dedicated Virtual Account

Create a dedicated virtual account for a customer:

use ZenithPay\Facades\ZenithPay;
use Illuminate\Http\Client\RequestException;

public function createAccount()
{
    try {
        $response = ZenithPay::createDedicatedAccount([
            'bvn'          => '12345678901',
            'account_name' => 'John Doe',
            'first_name'   => 'John',
            'last_name'    => 'Doe',
            'email'        => 'john@example.com',
        ]);

        return response()->json([
            'success' => true,
            'data' => $response
        ]);

    } catch (RequestException $e) {
        return response()->json([
            'success' => false,
            'message' => 'Failed to create account',
            'error' => $e->response->json()
        ], $e->response->status());
    }
}

Using Dependency Injection

You can also inject the ZenithPayClient directly into your controllers or services:

use ZenithPay\Services\ZenithPayClient;

class PaymentController extends Controller
{
    protected $zenithPay;

    public function __construct(ZenithPayClient $zenithPay)
    {
        $this->zenithPay = $zenithPay;
    }

    public function createAccount(Request $request)
    {
        $response = $this->zenithPay->createDedicatedAccount([
            'bvn'          => $request->bvn,
            'account_name' => $request->account_name,
            'first_name'   => $request->first_name,
            'last_name'    => $request->last_name,
            'email'        => $request->email,
        ]);

        return response()->json($response);
    }
}

API Reference

Create Dedicated Account

Creates a dedicated virtual account for a customer.

Method: createDedicatedAccount(array $data): array

Parameters:

Parameter Type Required Description
bvn string Yes Customer's Bank Verification Number (11 digits)
account_name string Yes Full name for the account
first_name string Yes Customer's first name
last_name string Yes Customer's last name
email string Yes Customer's email address

Example Request:

$response = ZenithPay::createDedicatedAccount([
    'bvn'          => '12345678901',
    'account_name' => 'John Doe',
    'first_name'   => 'John',
    'last_name'    => 'Doe',
    'email'        => 'john@example.com',
]);

Example Response:

{
  "reference": "ZTSVA-01JY73PXPSASK9MBCP7P7VW8",
  "account_number": "6639486000",
  "bank": "PALMPAY",
  "account_name": "John INVENTURES LTD(ZenithPay)",
  "status": "Enabled"
}

Response Fields:

Field Type Description
reference string Unique reference for the virtual account
account_number string The generated virtual account number
bank string Bank provider for the virtual account
account_name string The registered account name
status string Account status (Enabled/Disabled)

Error Handling

The package throws Illuminate\Http\Client\RequestException when API requests fail. Always wrap your calls in try-catch blocks:

use Illuminate\Http\Client\RequestException;

try {
    $response = ZenithPay::createDedicatedAccount($data);

} catch (RequestException $e) {
    // Get the status code
    $statusCode = $e->response->status();

    // Get the error response body
    $error = $e->response->json();

    // Log the error
    \Log::error('ZenithPay API Error', [
        'status' => $statusCode,
        'error' => $error
    ]);

    // Handle the error appropriately
}

Common Error Codes

Status Code Description
400 Bad Request - Invalid parameters
401 Unauthorized - Invalid API credentials
422 Unprocessable Entity - Validation error
500 Internal Server Error - ZenithPay server error

Testing

For testing purposes, you can mock the ZenithPayClient:

use ZenithPay\Services\ZenithPayClient;

public function test_create_account()
{
    $mock = $this->mock(ZenithPayClient::class);

    $mock->shouldReceive('createDedicatedAccount')
         ->once()
         ->with([
             'bvn' => '12345678901',
             'account_name' => 'John Doe',
             'first_name' => 'John',
             'last_name' => 'Doe',
             'email' => 'john@example.com',
         ])
         ->andReturn([
             'reference' => 'ZTSVA-TEST123',
             'account_number' => '1234567890',
             'bank' => 'TEST BANK',
             'account_name' => 'John Doe',
             'status' => 'Enabled'
         ]);

    // Your test assertions here
}

Security

  • Never commit your .env file or expose your API credentials
  • Store your ZENITHPAY_SECRET_KEY securely
  • Use HTTPS for all API communications
  • Validate webhook signatures using the ZENITHPAY_WEBHOOK_SECRET

Changelog

Please see CHANGELOG for more information on what has changed recently.

Contributing

Contributions are welcome! Please feel free to submit a Pull Request.

Credits

License

The MIT License (MIT). Please see License File for more information.

Support

For support, please contact:

Resources

统计信息

  • 总下载量: 9
  • 月度下载量: 0
  • 日度下载量: 0
  • 收藏数: 0
  • 点击次数: 0
  • 依赖项目数: 0
  • 推荐数: 0

GitHub 信息

  • Stars: 0
  • Watchers: 0
  • Forks: 0
  • 开发语言: PHP

其他信息

  • 授权协议: MIT
  • 更新时间: 2025-08-18