Ecosyste.ms: Awesome

An open API service indexing awesome lists of open source software.

Awesome Lists | Featured Topics | Projects

https://github.com/sowrensen/laravel-shurjopay

A package for handling ShurjoPay payment gateway in Laravel applications
https://github.com/sowrensen/laravel-shurjopay

composer composer-package laravel laravel-framework laravel-package package payment-gateway

Last synced: about 1 month ago
JSON representation

A package for handling ShurjoPay payment gateway in Laravel applications

Awesome Lists containing this project

README

        

# Laravel-ShurjoPay 💳

> A package for handling ShurjoPay payment gateway in Laravel applications

Laravel-ShurjoPay is a package for handling ShurjoPay payment gateway easily in Laravel applications. It has some advantages over the package provided by ShurjoPay and is much more configurable and well-structured.

##### Key differences with the official package

- Auto discovery for Laravel 5.5+ projects. 🔍
- ShurjoPay configurations can be defined on the fly. 🛸
- Uses **Guzzle** instead of cURL by default.

#### Changelog

For detailed changelog please see [this file](CHANGELOG.MD).

#### Requirements

- PHP >= 7.2
- Laravel >= 6.0

Installation
---

To install the package run

```
composer require sowrensen/laravel-shurjopay
```

Publish
---

To publish the config file, run the following command

```
php artisan vendor:publish --tag=ls-config
```

Environment Variables (Optional)
---

ShurjoPay would provide you some credentials, define them in your `.env` file:

```dotenv
SHURJOPAY_SERVER_URL=
MERCHANT_USERNAME=
MERCHANT_PASSWORD=
MERCHANT_KEY_PREFIX=
```

Now if you like to keep your secret credentials somewhere else, there's nothing to worry about. You can load them on the fly. 😁 Check the following section.

Usage
---

The usage of the package is simple. First import the `Sowren\ShurjoPay\ShurjoPayService` class.

```php
use Sowren\ShurjoPay\ShurjoPayService;
```

If you have defined your credentials in `.env` file, then just create an object,

```php
$client = new ShurjoPayService(500, route('home'));
```

If you want to load your ShurjoPay configuration in runtime, pass them to the constructor,

```php
$client = new ShurjoPayService(
500,
route('home'),
'serverUrl',
'merchantUsername',
'merchantPassword',
'merchantKeyPrefix'
);
```

...and call the `generateTxnId` and `makePayment` method.

```php
$txnId = $client->generateTxnId(); // Pass any string to set your own unique id
$client->makePayment();
```

That's it! After successful or failed attempt it will redirect to the route you provided along with ShurjoPay response parameters.