taitech / azampay
A package library for integrating your composer/php-based project with AzamPay
1.0.2
2024-12-04 12:20 UTC
Requires
- php: ^8.1
- guzzlehttp/guzzle: ^7.5
This package is auto-updated.
Last update: 2025-04-04 13:09:12 UTC
README
A robust PHP package for seamless integration with Azampay payment services, supporting Mobile Money (MNO), Bank, and Merchant payment options.
Features
- Mobile Money (MNO) payments integration
- Bank payments processing
- Merchant services support
- Environment switching (Sandbox/Production)
- Simple credential management
- Flexible service selection
Installation
composer require taitech/azampay
Quick Start
use Taitech\Azampay\AzampayService; // Initialize the service $azampay = new AzampayService( appName: 'YOUR_APP_NAME', clientId: 'YOUR_CLIENT_ID', secret: 'YOUR_CLIENT_SECRET', env: 'SANDBOX', // or 'PRODUCTION' service: 'MNO' // or 'BANK' or 'MERCHANT' );
Configuration
The package requires the following configuration parameters:
- appName: Your application name registered with Azampay
- clientId: Your Azampay client ID
- secret: Your Azampay client secret
- env: Environment setting (SANDBOX or PRODUCTION)
- service: Service type (MNO, BANK, or MERCHANT)
Service Types
Mobile Money (MNO)
$azampay = new AzampayService( appName: 'YOUR_APP_NAME', clientId: 'YOUR_CLIENT_ID', secret: 'YOUR_CLIENT_SECRET', env: 'SANDBOX', // or 'PRODUCTION' service: 'MNO' );
Bank Payments
$azampay = new AzampayService( appName: 'YOUR_APP_NAME', clientId: 'YOUR_CLIENT_ID', secret: 'YOUR_CLIENT_SECRET', env: 'SANDBOX', // or 'PRODUCTION' service: 'BANK' );
Merchant Services
$azampay = new AzampayService( appName: 'YOUR_APP_NAME', clientId: 'YOUR_CLIENT_ID', secret: 'YOUR_CLIENT_SECRET', env: 'SANDBOX', // or 'PRODUCTION' service: 'MERCHANT' );
Usage
Initiate Payment and Checkout
// vendor credentials $app = 'YOUR_APP_NAME'; $clientId = 'YOUR_CLIENT_ID'; $secret = 'YOUR_SECRET_KEY'; try { $azampay = new AzampayService( $app, // App Name $clientId, // Client ID $secret, // Client Secret 'SANDBOX', // Environment (SANDBOX/PRODUCTION) 'MNO', // Service (MNO, BANK, MERCHANT) ); // Example of calling the checkout method for MNO [MOBILE PAYMENT] $payload = [ 'amount' => 5000, 'accountNumber' => '255713295803', 'provider' => 'Tigo', 'additionalProperties' => [ 'router' => "Home", 'mac' => "A6:47:F6:52:38:D5", ], ]; $response = $azampay->checkout($payload); // Output the final JSON response header('Content-Type: application/json'); echo json_encode($response, JSON_PRETTY_PRINT | JSON_UNESCAPED_UNICODE); } catch (Exception $e) { echo "Error: " . $e->getMessage(); }
Contributing
- Fork the repository
- Create your feature branch (
git checkout -b feature/your-feature
) - Commit your changes (
git commit -am 'Add some feature'
) - Push to the branch (
git push origin feature/your-feature
) - Create a new Pull Request
- Ensure your code adheres to the project's coding standards
- Provide clear and concise commit messages
For more details, please refer to the CONTRIBUTING file.
License
This project is licensed under the MIT License - see the LICENSE file for details.
Support
For any issues or questions, please open an issue on the GitHub repository.
Changelog
All notable changes to this project will be documented in this file.
The format is based on Keep a Changelog, and this project adheres to Semantic Versioning.
[1.0.0] - 2024-01-01
Added
- Initial release
- Support for Mobile Money (MNO) payments
- Support for Bank payments
- Support for Merchant services
- Environment switching capability
- Flexible service selection