charlesassets / LaravelPerfectMoney by charlesassets

Laravel Package for Perfect Money Payments
4,376
10
2
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: 2024-11-19 03:08:48
Package Statistics
Total Downloads: 4,376
Monthly Downloads: 150
Daily Downloads: 21
Total Stars: 10
Total Watchers: 2
Total Forks: 11
Total Open Issues: 2

Laravel Perfect Money

Latest Version on Packagist Software License Total Downloads

Install

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.

1.Publish view

php artisan vendor:publish --provider="charlesassets\LaravelPerfectMoney\LaravelPerfectMoneyServiceProvider" --tag="views"

2.Edit your view at /resources/views/vendor/perfectmoney/perfectmoney.php

Usage

###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');

API MODULES

Get Balance

$pm = new PerfectMoney;
$balance = $pm->getBalance();

if($balance['status'] == 'success')
{
	return $balance['USD'];
}

Send Money

// 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'];
}

Change log

Please see CHANGELOG for more information what has changed recently.

Contributing

Please see CONTRIBUTING and CONDUCT for details.

Security

If you discover any security related issues, please email charlesassets.com@gmail.com instead of using the issue tracker.

Credits

License

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