承接 qnox/qnox_flutterwave 相关项目开发

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

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

qnox/qnox_flutterwave

最新稳定版本:v1.0.2

Composer 安装命令:

composer require qnox/qnox_flutterwave

包简介

Flutterwave V4 Api Integration

README 文档

README

Packagist-friendly SDK that wraps the Flutterwave v4 APIs for PHP and Laravel projects. Class/file names are prefixed with Qnox to avoid collisions with other packages.

Requirements

  • PHP 8.2+
  • Laravel 8–12 (optional; for auto-discovery)
  • guzzlehttp/guzzle ^7.7

Installation

composer require qnox/qnox_flutterwave:^1.0.0

Laravel integration

  • Auto-discovered provider: Qnox\QnoxFlutterwave\QnoxFlutterwaveServiceProvider.
  • Facade alias: QnoxFlutterwaveQnox\QnoxFlutterwave\Facades\QnoxFlutterwave.
  • Publish config (optional): php artisan vendor:publish --tag=qnox-flutterwave-config.

Configuration

Environment keys (defaults target the Flutterwave sandbox):

FLW_CLIENT_ID=your-client-id #from flutterwave
FLW_CLIENT_SECRET=your-client-secret #from flutterwave
FLW_ENCRYPTION_KEY=your-base64-aes-key   # used for card field encryption from flutterwave
FLW_SECRET_HASH=your-webhook-secret-hash # for signature checks
FLW_MODE=sandbox  # or live; URLs are handled internally

Usage

use Qnox\QnoxFlutterwave\Facades\QnoxFlutterwave;

// Get OAuth token (auto-cached)
$token = QnoxFlutterwave::getAccessToken();
$accessToken = $token['access_token'];

// Create or search a customer
$customer = QnoxFlutterwave::createCustomer($accessToken, 'user@example.com');

// Create a mobile-money payment method
$method = QnoxFlutterwave::createMobilePaymentMethod($accessToken, [
    'mobile_money' => ['network' => 'AIRTEL', 'country_code' => 255, 'phone_number' => '713380217'],
    'type' => 'mobile_money',
    'customer_id' => $customer['data']['id'],
]);

// Charge the customer
$charge = QnoxFlutterwave::createCharge($accessToken, [
    'currency' => 'TZS',
    'recurring' => false,
    'amount' => 2000,
    'reference' => 'ref-' . time(),
    'customer_id' => $customer['data']['id'],
    'payment_method_id' => $method['data']['id'],
    'redirect_url' => 'https://example.com/redirect',
]);

// Continue a charge when Flutterwave asks for more input (e.g., OTP)
$updatedCharge = QnoxFlutterwave::updateCharge($accessToken, $charge['data']['id'], [
    // Provide the fields indicated in the charge's next_action response
    'otp' => '123456',
    // 'action' => 'resend_otp', // other keys vary by flow; see Flutterwave docs
]);

Card encryption helper

$nonce = QnoxFlutterwave::generateNonce(); // e.g. 12 chars
$encryptedNumber = QnoxFlutterwave::encryptGCMField($cardNumber, $nonce, env('FLW_ENCRYPTION_KEY'));

Webhook verification

$isValid = QnoxFlutterwave::verifyWebhookSignature(
    request()->header('flutterwave-signature'),
    request()->getContent()
);
abort_unless($isValid, 401);

Roadmap

  • Add higher-level DTOs and validation around request payloads.
  • Expand coverage beyond customers/payment methods/charges (transfers, settlements, virtual accounts).
  • More Laravel niceties: middleware for webhook verification and test fakes.

Contributing

Issues and PRs are welcome. Please describe the endpoint/flow you’re targeting and link the relevant Flutterwave docs.

License

MIT

统计信息

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

GitHub 信息

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

其他信息

  • 授权协议: MIT
  • 更新时间: 2025-12-23

承接程序开发

PHP开发

VUE

Vue开发

前端开发

小程序开发

公众号开发

系统定制

数据库设计

云部署

网站建设

安全加固