Библиотека Laravel для интеграции Amplify Pay
PHP 5,4+ и композитор требуются.
Чтобы получить последнюю версию Laravel Amplify, требуется, как ниже
" composer require dubems/laravel-amplify"
Затем вам нужно будет запустить composer install или composer update , чтобы загрузить его и обновить AutoLoader.
После установки Laravel Amplify вам необходимо зарегистрировать поставщика услуг. Откройте config/app.php и добавьте следующее в ключ providers .
DubemsAmplifyAmplifyServiceProvider::class,Также зарегистрируйте фасад так:
' aliases ' => [
...
' Amplify ' => Dubems Amplify Facades Amplify::class,
...
]Вы можете опубликовать файл конфигурации, используя эту команду:
php artisan vendor:publish --provider= " DubemsAmplifyAmplifyServiceProvider " В вашем каталоге config будет размещен файл с именем amplify.php с некоторыми значениями по умолчанию:
<?php
return [
/**
* Merchant ID gotten from your Amplify dashboard
*/
' merchantId ' => getenv ( ' AMPLIFY_MERCHANT_ID ' ),
/**
* API Key from amplify dashboard
*/
' apiKey ' => getenv ( ' AMPLIFY_API_KEY ' ),
/**
* Amplify payment Url
*/
' paymentUrl ' => getenv ( ' AMPLIFY_PAYMENT_URL ' ),
/**
* Redirect Url after successful transaction
*/
' redirectUrl ' => getenv ( ' AMPLIFY_REDIRECT_URL ' )
];## Общий поток оплаты
Хотя есть несколько способов оплаты заказа, большинство платежных шлюзов ожидают, что вы будете следовать следующему потоку в процессе оформления заказа:
### 1. Клиент перенаправляется на поставщика платежей после того, как клиент прошел процесс оформления заказа и готов к оплате, клиент должен быть перенаправлен на место поставщика платежей.
Пере перенаправление достигается путем подачи формы с некоторыми скрытыми полями. Форма должна публиковать на сайте поставщика платежей. Скрытые поля минимально указывают сумму, которая должна быть оплачена, и в некоторых других областях
### 2. Клиент платит на сайте поставщика платежей, который клиент прибывает на сайт поставщика платежей и выбирает способ оплаты. Все шаги, необходимые для оплаты заказа, выполняются поставщиком платежей.
### 3. Клиент перенаправляется обратно после оплаты заказа, который клиент перенаправляется обратно. В запросе перенаправления на сайте магазина некоторые значения возвращаются.
Откройте свой файл .ENV и добавьте свой общедоступный ключ, секретный ключ, продавцу по электронной почте и URL -адресу платежей, как SO:
AMPLIFY_MERCHANT_ID = XXXXXXX
AMPLIFY_API_KEY = XXXXXX
AMPLIFY_PAYMENT_URL =https: //api.amplifypay.com
AMPLIFY_REDIRECT_URL =https: //xxxxxНастройка маршрутов и методов контроллера, как SO:
Route:: post ( ' /pay ' , ' PaymentController@redirectToGateway ' )-> name ( ' pay ' ); // Laravel 5.1.17 and above
Route:: get ( ' /payment/callback ' , ' PaymentController@handleGatewayCallback ' ); <?php
namespace App Http Controllers ;
use Illuminate Http Request ;
use App Http Requests ;
use App Http Controllers Controller ;
use Amplify ;
class PaymentController extends Controller
{
/**
* Redirect the User to Amplify Payment Page
* @return Url
*/
public function redirectToGateway ()
{
return Amplify:: getAuthorizationUrl ()-> redirect ();
}
/**
* Get Amplify payment information
* @return void
*/
public function handleGatewayCallback ()
{
$ response = Amplify:: handlePaymentCallback ();
dd ( $ response );
// Now you have the payment details,
// you can store the authorization_code in your db to allow for recurrent subscriptions
// you can then redirect or do whatever you want
}
}Другие методы и пример использования можно найти ниже
/** Create Subscription */
public function createSubscription ()
{
$ data = [ ' planName ' => ' Sliver members ' , ' frequency ' => ' Weekly ' ];
$ response = Amplify:: createSubscription ( $ data );
dd ( $ response );
}
/** Delete a particular subscription */ */
public function deleteSubscription ()
{
$ id = ' xyz ' ;
$ response = Amplify:: deleteSubscription ( $ id );
dd ( $ response );
}
/** Update a particular subscription */
public function updateSubscription ()
{
$ data = [ ' planName ' => ' Gold members ' , ' frequency ' => ' Weekly ' ];
$ planId = ' xyz ' ;
$ response = Amplify:: updateSubscription ( $ planId , $ data );
dd ( $ response );
}
/** Get a particular subscription */
public function fetchSubscription ()
{
$ id = ' id ' ;
$ response = Amplify:: fetchSubscription ( $ id );
dd ( $ response );
}
/** Fetch all subscription */
public function fetchAllSubscription ()
{
$ allSub = Amplify:: fetchAllSubscription ();
dd ( $ allSub );
}
Примерная форма будет выглядеть так:
< form method =" POST " action =" {{ route('pay') }} " accept-charset =" UTF-8 " class =" form-horizontal " role =" form " >
< div class =" row " style =" margin-bottom:40px; " >
< div class =" col-md-8 col-md-offset-2 " >
< p >
< div >
A cup of coffee
₦ 800
</ div >
</ p >
< input type =" hidden " name =" email " value =" [email protected] " > {{-- required --}}
< input type =" hidden " name =" description " value =" XYZ " >
< input type =" hidden " name =" amount " value =" 800 " > {{-- required in naira --}}
< input type =" hidden " name =" name " value =" Nriagu Dubem " >
< input type =" hidden " name =" planId " value =" Your plan ID " >
{{ csrf_field() }} {{-- works only when using laravel 5.1, 5.2 --}}
< input type =" hidden " name =" _token " value =" {{ csrf_token() }} " > {{-- employ this in place of csrf_field only in laravel 5.0 --}}
< p >
< button class =" btn btn-success btn-lg btn-block " type =" submit " value =" Pay Now! " >
< i class =" fa fa-plus-circle fa-lg " > </ i > Pay Now!
</ button >
</ p >
</ div >
</ div >
</ form > PAN = 5060 9905 8000 0217 499
EXPYEAR = 20
EXPMONTH = 04
CVV = 111
If prompted for Amount Validation, Enter 1.10Пожалуйста, не стесняйтесь раскошелиться на этот пакет и внести свой вклад, отправив запрос на притяжение, чтобы улучшить функциональные возможности.
Светь репо, я бы хотел внимания! Вы также можете поделиться ссылкой для этого репозитория в Twitter или Hackernews? Распространите слово!
Не забудьте подписаться на меня в Твиттере!
Спасибо! Нриагу Чидубем.
Лицензия MIT (MIT). Пожалуйста, смотрите файл лицензии для получения дополнительной информации.