yogeshgupta / phonepe-laravel
Complete PhonePe Payment Gateway v2 integration for Laravel with OAuth, Webhook, Auto-Logging, Events & Facade
Installs: 643
Dependents: 0
Suggesters: 0
Security: 0
Stars: 0
Watchers: 1
Forks: 0
Open Issues: 1
pkg:composer/yogeshgupta/phonepe-laravel
Requires
- php: ^8.1
- illuminate/support: ^9.0|^10.0|^11.0|^12.0
README
A Laravel package for integrating the PhonePe API v2 payment gateway, developed by Yogesh Gupta. This is a standalone implementation designed to simplify PhonePe payment gateway integration in Laravel applications, supporting the PhonePe checkout v2 API for secure and efficient transactions.
Features
- Initiate payments using the PhonePe API v2.
- Verify payment status with the PhonePe checkout v2 endpoint.
- Support for UAT and production environments.
- Token caching for efficient PhonePe API v2 calls.
- Laravel configuration and facade for easy Laravel PhonePe integration.
Requirements
- PHP >= 8.1
- Laravel 9.x, 10.x, 11.x, or 12.x
Installation
- Install the package via Composer:
composer require yogeshgupta/phonepe-laravel
- Publish the configuration file:
php artisan vendor:publish --tag=phonepe-config
This will create a config/phonepe.php file in your Laravel project.
- Add your PhonePe credentials to your
.envfile:
PHONEPE_ENV=uat PHONEPE_UAT_CLIENT_ID=SU2504041946024365502022 PHONEPE_UAT_CLIENT_VERSION=1 PHONEPE_UAT_CLIENT_SECRET=ae83cba2-07c0-43a9-b0c4-1d84c261fd12 PHONEPE_PROD_CLIENT_ID=your_prod_client_id PHONEPE_PROD_CLIENT_VERSION=your_prod_client_version PHONEPE_PROD_CLIENT_SECRET=your_prod_client_secret PHONEPE_REDIRECT_URL=https://your-app.com/phonepe/process
Configuration
The configuration file (config/phonepe.php) allows you to customize:
- Environment (
uatorprod) - Client ID, version, and secret for both environments
- Token cache path
- Redirect URL after PhonePe API v2 payment
Example configuration:
return [ 'environment' => env('PHONEPE_ENV', 'uat'), 'uat' => [ 'client_id' => env('PHONEPE_UAT_CLIENT_ID', 'SU2504041946024365502022'), 'client_version' => env('PHONEPE_UAT_CLIENT_VERSION', 1), 'client_secret' => env('PHONEPE_UAT_CLIENT_SECRET', 'ae83cba2-07c0-43a9-b0c4-1d84c261fd12'), 'base_url' => 'https://api-preprod.phonepe.com/apis/pg-sandbox', 'auth_url' => 'https://api-preprod.phonepe.com/apis/pg-sandbox', 'token_cache_path' => storage_path('app/phonepe/phonepe_token_uat.json'), ], 'prod' => [ // ... ], ];
Usage
Initiating a Payment
use YogeshGupta\PhonePe\Facades\PhonePe; $result = PhonePe::initiatePayment(10000, 'SUB123'); // Amount in paisa, subscription ID if ($result['success']) { return redirect($result['redirectUrl']); } else { \Log::error('Payment initiation failed: ' . $result['error']); return back()->withErrors(['error' => $result['error']]); }
Verifying Payment Status
use YogeshGupta\PhonePe\Facades\PhonePe; $result = PhonePe::verifyPhonePePayment('merchantOrderId123'); if ($result['success']) { \Log::info('Payment status: ' . json_encode($result['data'])); return response()->json($result['data']); } else { \Log::error('Payment verification failed: ' . $result['error']); return response()->json(['error' => $result['error']], 400); }
Example Controller
namespace App\Http\Controllers; use YogeshGupta\PhonePe\Facades\PhonePe; use Illuminate\Http\Request; class PaymentController extends Controller { public function initiate(Request $request) { $amount = $request->input('amount'); // Amount in paisa $subscriptionId = $request->input('subscription_id'); $result = PhonePe::initiatePayment($amount, $subscriptionId); if ($result['success']) { return redirect($result['redirectUrl']); } return back()->withErrors(['error' => $result['error']]); } public function verify(Request $request) { $merchantOrderId = $request->input('merchantOrderId'); $result = PhonePe::verifyPhonePePayment($merchantOrderId); if ($result['success']) { \Log::info('Payment status: ' . json_encode($result['data'])); return response()->json($result['data']); } \Log::error('Verification failed: ' . $result['error']); return response()->json(['error' => $result['error']], 400); } }
Testing
To run tests (if included):
vendor/bin/phpunit vendor/yogeshgupta/phonepe-laravel/tests
Contributing
Contributions are welcome! Please follow these steps:
- Fork the repository.
- Create a feature branch (
git checkout -b feature/your-feature). - Commit your changes (
git commit -m 'Add your feature'). - Push to the branch (
git push origin feature/your-feature). - Open a pull request.
Issues
Report bugs or suggest features by opening an issue on the GitHub repository.
License
This Laravel PhonePe integration package is licensed under the MIT License.