shabayek/laravel-payment

Laravel Package For Payment Methods

v0.8.0 2022-04-12 23:19 UTC

README

Github Status Styleci Status Packagist version mit Packagist PHP Version Support Packagist Downloads

This is a Laravel Package for Payment Gateway Integration. It has a clear and consistent API, is fully unit tested, and even comes with an example application to get you started.

Note this package under development Don't use it in production.

Usage

  • Install laravel payment package with composer
composer require shabayek/laravel-payment
  • Publish the config file with following command
php artisan vendor:publish --provider="Shabayek\Payment\PaymentServiceProvider" --tag=config
  • Initiate a payment with the following code:
$method_id = 1; // payment method id from the config file
$payment = Payment::via($method_id);
  • Implement customer details contracts on user model by adding Billable trait
use Shabayek\Payment\Concerns\Billable;
use Illuminate\Notifications\Notifiable;
use Illuminate\Foundation\Auth\User as Authenticatable;

class User extends Authenticatable
{
    use Billable, Notifiable;

}
  • Following columns is default for billable user
    • first_name
    • last_name
    • email
    • phone

if you want to change the column name you can do add public methods on your model with convention name CamelCase like firstName + Column FirstNameColumn

    /**
     * Get the first name.
     *
     * @return string|null
     */
    public function firstNameColumn()
    {
        return $this->name; // OR $this->first_name;
    }
  • Implement address details with relation to address model

    The default relation is address if you want change the relation name you can do add public methods on your user model

    /**
     * Get the billable billing relations.
     *
     * @return Model
     */
    public function billingRelation()
    {
        return $this->address_relation; // OR $this->address;
    }
  • Pass the user model to payment gateway
$payment->customer($user);
  • Add items with loop array of data items
    $items = [
        [
            "name" => "item1",
            "price" => 100,
            "quantity" => 2,
            "description" => "item1 description",
        ],
        [
            "name" => "item2",
            "price" => 200,
            "quantity" => 1,
            "description" => "item2 description",
        ],
    ];
    $payment->items($items);
    // OR By One
    $name = "item1";
    $price = 100;
    $quantity = 2; // Default 1
    $description = "item1 description"; // Default null

    $payment->addItem($name, $price, $quantity, $description);
  • Set transaction id will send to gateway
$payment->transaction($transaction_id);
  • Check the payment is online to get pay url
if ($payment->isOnline()) {
    $url = $payment->purchase();
}
  • The MasterCard method adds a new way to get the checkout form

pass the transaction model will update successIndicator and return view with checkout form

$payment->checkoutForm(Transaction $transaction);
  • Print the errors messages
$payment->getErrors();
$payment->isSuccess();
  • When callback from payment gateway, you can use the following code to verify the payment
$payment = $payment->pay($request);

// function array with payment status and message
// return [
//     'success' => $isSuccess,
//     'message' => $message,
//     'data' => []
// ];
  • Check the payment status
$method_id = 1; // payment method id from the config file
$payment_order_id = 111; // payment order id
$payment_status = Payment::via($method_id)->verify($payment_order_id);

Change log

Please see CHANGELOG for more information on what has been changed recently.

Contributing

Please see CONTRIBUTING for details.

Security Vulnerabilities

If you've found a bug regarding security please mail esmail.shabayek@gmail.com instead of using the issue tracker.

License

The Laravel payment methods package is open-sourced software licensed under the MIT license.