Biblioteca Laravel para integrar o pagamento do Amplify
Php 5.4+ e compositor são necessários.
Para obter a versão mais recente do Laravel Amplify, é necessário como abaixo
" composer require dubems/laravel-amplify"
Você precisará executar composer install ou composer update para fazer o download e atualizar o Autoloader.
Depois que o Laravel Amplify for instalado, você precisa registrar o provedor de serviços. Abra config/app.php e adicione o seguinte à chave providers .
DubemsAmplifyAmplifyServiceProvider::class,Além disso, registre a fachada como assim:
' aliases ' => [
...
' Amplify ' => Dubems Amplify Facades Amplify::class,
...
]Você pode publicar o arquivo de configuração usando este comando:
php artisan vendor:publish --provider= " DubemsAmplifyAmplifyServiceProvider " Um arquivo de configuração chamado amplify.php com alguns padrões será colocado no seu diretório config :
<?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 ' )
];## Fluxo de pagamento geral
Embora existam várias maneiras de pagar um pedido, a maioria dos gateways de pagamento espera que você siga o seguinte fluxo em seu processo de checkout:
### 1. O cliente é redirecionado para o provedor de pagamento depois que o cliente passar pelo processo de checkout e está pronto para pagar, o cliente deve ser redirecionado para o local do provedor de pagamento.
O redirecionamento é realizado enviando um formulário com alguns campos ocultos. O formulário deve postar no local do provedor de pagamento. Os campos ocultos especificam minimamente o valor que deve ser pago e alguns outros campos
### 2. O cliente paga no site do provedor de pagamento que o cliente chega ao site do provedor de pagamentos e escolhe um método de pagamento. Todas as etapas necessárias para pagar o pedido são resolvidas pelo provedor de pagamento.
### 3. O cliente é redirecionado de volta depois de pagar o pedido que o cliente é redirecionado de volta. Na solicitação de redirecionamento ao site da loja, alguns valores são retornados.
Abra seu arquivo .env e adicione sua chave pública, chave secreta, email de comerciante e URL de pagamento como assim:
AMPLIFY_MERCHANT_ID = XXXXXXX
AMPLIFY_API_KEY = XXXXXX
AMPLIFY_PAYMENT_URL =https: //api.amplifypay.com
AMPLIFY_REDIRECT_URL =https: //xxxxxConfigurar rotas e métodos de controlador como assim:
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
}
}Outros métodos e exemplo de uso podem ser encontrados abaixo
/** 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 );
}
Um formulário de amostra ficará com isso:
< 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.10Sinta -se à vontade para bifurcar este pacote e contribuir enviando uma solicitação de tração para aprimorar as funcionalidades.
Estrela o repositório do Github, eu adoraria a atenção! Você também pode compartilhar o link para este repositório no Twitter ou Hackernews? Espalhe a palavra!
Não se esqueça de me seguir no Twitter!
Obrigado! Nriagu Chidubem.
A licença do MIT (MIT). Consulte o arquivo de licença para obter mais informações.