| Package Data | |
|---|---|
| Maintainer Username: | charlesassets | 
| Maintainer Contact: | charlesassets.com@gmail.com (Charles Patterson) | 
| Package Create Date: | 2016-10-11 | 
| Package Last Update: | 2020-11-16 | 
| Language: | PHP | 
| License: | MIT | 
| Last Refreshed: | 2025-10-22 15:08:34 | 
| Package Statistics | |
|---|---|
| Total Downloads: | 5,684 | 
| Monthly Downloads: | 161 | 
| Daily Downloads: | 5 | 
| Total Stars: | 10 | 
| Total Watchers: | 1 | 
| Total Forks: | 11 | 
| Total Open Issues: | 2 | 
Via Composer
$ composer require charlesassets/laravel-perfectmoney
Add Provider
charlesassets\LaravelPerfectMoney\LaravelPerfectMoneyServiceProvider::class,
Add Aliases
'PerfectMoney' => charlesassets\LaravelPerfectMoney\PerfectMoney::class,
##Configuration
Publish Configuration file
php artisan vendor:publish --provider="charlesassets\LaravelPerfectMoney\LaravelPerfectMoneyServiceProvider" --tag="config"
Edit .env
Add these lines at .env file, follow config/perfectmoney.php for configuration descriptions.
PM_ACCOUNTID=100000
PM_PASSPHRASE=your_pm_password
PM_MARCHANTID=U123456
PM_MARCHANT_NAME="My Company"
PM_UNITS=USD
PM_ALT_PASSPHRASE=your_alt_passphrase
PM_PAYMENT_URL=http://example.com/success
PM_PAYMENT_URL_METHOD=null
PM_NOPAYMENT_URL=http://example.com/fail
PM_NOPAYMENT_URL_METHOD=null
PM_STATUS_URL=null
PM_SUGGESTED_MEMO=null
##Customizing views (Optional)
If you want to customize form, follow these steps.
php artisan vendor:publish --provider="charlesassets\LaravelPerfectMoney\LaravelPerfectMoneyServiceProvider" --tag="views"
###Render Shopping Cart Form
PerfectMoney::render();
Sometimes you will need to customize the payment form. Just pass the parameters to render method .
PerfectMoney::render(['PAYMENT_UNITS' => 'EUR'], 'custom_view');
$pm = new PerfectMoney;
$balance = $pm->getBalance();
if($balance['status'] == 'success')
{
	return $balance['USD'];
}
// Required Fields
$amount = 10.00;
$sendTo = 'U1234567';
// Optional Fields
$description = 'Optional Description for send money';
$payment_id = 'Optional_payment_id';
$pm = new PerfectMoney;
// Send Funds with all fields
$sendMoney = $pm->getBalance($amount, $sendTo, $description, $payment_id);
if($sendMoney['status'] == 'success')
{
	// Some code here
}
// Send Funds with required fields
$sendMoney = $pm->getBalance($amount, $sendTo);
if($sendMoney['status'] == 'error')
{
	// Payment Failed
	return $sendMoney['message'];
}
Please see CHANGELOG for more information what has changed recently.
Please see CONTRIBUTING and CONDUCT for details.
If you discover any security related issues, please email charlesassets.com@gmail.com instead of using the issue tracker.
The MIT License (MIT). Please see License File for more information.