intagono / openpay
Library that will be used to connect to OpenPay Payment Gateway
This package is not auto-updated.
Last update: 2024-11-09 19:31:45 UTC
README
Library that simplifies the process of OpenPay Payment Gateway Api
Installation
Begin by installing this package through Composer.
{ "require": { "intagono/openpay": "dev-master" } }
Laravel 5
Register the following Service Provider and Alias
// config/app.php 'providers' => [ Intagono\Openpay\OpenpayServiceProvider::class, ]; 'aliases' => [ 'IntagonoOpenpay' => Intagono\Openpay\OpenpayFacade::class, ];
Then, publish the default configuration.
php artisan vendor:publish
This will add a new configuration file to: config/openpay.php
.
You will need to create these variables in your .env file with the appropriate values.
<?php return [ /* | (Boolean) Determines if Openpay is running in production mode. */ 'production_mode' => env('OPENPAY_PRODUCTION_MODE'), /* | Your Merchant ID, found in Openpay Dashboard -- Configuration. */ 'merchant_id' => env('OPENPAY_MERCHANT_ID'), /* | Your Private Key, found in Openpay Dashboard -- Configuration. */ 'private_key' => env('OPENPAY_PRIVATE_KEY'), ];
If you want to handle all Openpay Exceptions in one same place, use the following trait in your Exception Handler and modify the render method.
// app/Exceptions/Handler.php use Intagono\Openpay\OpenpayExceptionTrait; class Handler extends ExceptionHandler { use OpenPayExceptionTrait; ... public function render($request, Exception $e) { if ($this->isOpenPayException($e)) { return $this->renderOpenPayException($request, $e); } else { return parent::render($request, $e); } } }
By default, this trait will catch all Openpay Exceptions and will redirect back with input and the error message. In case of ajax it will return a response with the error message.
Usage
Constructor Injection.
<?php use Intagono\Openpay\Openpay; class Foo { /** * @var \Intagono\Openpay\Openpay */ protected $openpay; /** * Constructor */ public function __construct(Openpay $openpay) { $this->openpay = $openpay; } }
Facade
$charge = IntagonoOpenpay::charge($chargeRequest);
Outside Laravel
Intagono\Openpay\Openpay
has a dependency in the Openpay core.
require 'vendor/autoload.php'; $openpayCore = \Openpay::getInstance($merchantId, $privayeKey); $intagonoOpenpay = new \Intagono\Openpay\Openpay($openpayCore);