PHPackages                             hamid-a/saderat-pg - PHPackages - PHPackages  [Skip to content](#main-content)[PHPackages](/)[Directory](/)[Categories](/categories)[Trending](/trending)[Leaderboard](/leaderboard)[Changelog](/changelog)[Analyze](/analyze)[Collections](/collections)[Log in](/login)[Sign up](/register)

1. [Directory](/)
2. /
3. [Payment Processing](/categories/payments)
4. /
5. hamid-a/saderat-pg

ActiveLibrary[Payment Processing](/categories/payments)

hamid-a/saderat-pg
==================

Saderat Payment Gateway PHP Package

0.9(8y ago)015MITPHPPHP &gt;=7.0

Since May 2Pushed 8y ago1 watchersCompare

[ Source](https://github.com/hamid-a/saderat-pg)[ Packagist](https://packagist.org/packages/hamid-a/saderat-pg)[ RSS](/packages/hamid-a-saderat-pg/feed)WikiDiscussions master Synced today

READMEChangelogDependenciesVersions (2)Used By (0)

Saderat Payment Gatewat
-----------------------

[](#saderat-payment-gatewat)

##### composer package with laravel support

[](#composer-package-with-laravel-support)

### Installation

[](#installation)

```
composer require hamid-a/saderat-pg

```

### Usage

[](#usage)

##### Initializing

[](#initializing)

```
use SaderatPaymentGateway\SaderatPG;

$tid = 'terminal-id';
$mid = 'merchant-id';
$public_key = __DIR__.'/saderat-public-key.pub'; // path to public key file
$private_key = __DIR__.'/saderat-private-key.key'; // path to private key file
$callback_url = 'callback-url'; // we can set calback url in initializing or getToken section

$gateway = new SaderatPG($tid, $mid, $public_key, $private_key, $callback_url);
```

Remember that keys must be in standard format:

```
-----BEGIN PRIVATE KEY-----
PRIVATE KEY CONTENT
-----END PRIVATE KEY-----

```

```
-----BEGIN PUBLIC KEY-----
PUUBLIC KEY CONTENT
-----END PUBLIC KEY-----

```

#### Get token

[](#get-token)

```
$amount = 1000; // in int format
$crn = 'customer receipt number'; // must be unique in each transaction
$callback_url = 'callback-url'; // we can set calback url in initializing or getToken section
token = '';
try {

    $token = $gateway->getToken($amount, $crn, $callback_url);

} catch (\Exception $e){
    echo 'Error code:'.$e->getCode().' Error message:'.$e->getMessage();
}
if($token != '') {
// redirect user to: https://mabna.shaparak.ir/?ID=$token
}
```

#### Verify transaction

[](#verify-transaction)

```
$verified = fasle;

try {

    $verified = $gateway->verifyTransaction($token, $_POST['CRN'], $_POST['TRN'], $_POST['SIGNATURE']);

} catch(\Exception $e){
    echo 'Error code:'.$e->getCode().' Error message:'.$e->getMessage();
}

if($verified) {
//transaction verified
} else {
// verification failed
}
```

### Laravel integration

[](#laravel-integration)

In laravel &gt;= 5.5 service provider and facade are registered automatically. But in older versions you should add facade and service provider in *config/app.php* file.

```
...
'providers' => [
    ...
    SaderatPaymentGateway\Laravel\SaderatPGServiceProvider::class,
],
'aliases' => [
    ...
    'SaderatPG' => SaderatPaymentGateway\Laravel\Facade\SaderatPG::class,
]

```

Add configs to *config/services.php*

```
    'saderat-pg' => [
        'mid' => 'your merchant id',
        'tid' => 'your terminal id',
        'public-key' => __DIR__.'/saderat-public-key.pub', // path to public key file
        'private-key' => __DIR__.'/saderat-private-key.key', // path to private key file
        'callback-url' => '' // callback url (not required but it should provided in getToken request)
    ]
```

Use facade for requests:

```
use SaderatPG;

// get token
$token = SaderatPG::getToken($amount, $crn, $callback_url);

// verify transaction
$verified = SaderatPG::verifyTransaction($token, $request->get('CRN'), $request->get('TRN'), $request->get('SIGNATURE'));
```

###  Health Score

22

—

LowBetter than 21% of packages

Maintenance20

Infrequent updates — may be unmaintained

Popularity6

Limited adoption so far

Community7

Small or concentrated contributor base

Maturity48

Maturing project, gaining track record

 Bus Factor1

Top contributor holds 100% of commits — single point of failure

How is this calculated?**Maintenance (25%)** — Last commit recency, latest release date, and issue-to-star ratio. Uses a 2-year decay window.

**Popularity (30%)** — Total and monthly downloads, GitHub stars, and forks. Logarithmic scaling prevents top-heavy scores.

**Community (15%)** — Contributors, dependents, forks, watchers, and maintainers. Measures real ecosystem engagement.

**Maturity (30%)** — Project age, version count, PHP version support, and release stability.

###  Release Activity

Cadence

Unknown

Total

1

Last Release

2981d ago

### Community

Maintainers

![](https://avatars.githubusercontent.com/u/5184138?v=4)[Hamid Azimi](/maintainers/hamid-a)[@hamid-a](https://github.com/hamid-a)

---

Top Contributors

[![hamid-a](https://avatars.githubusercontent.com/u/5184138?v=4)](https://github.com/hamid-a "hamid-a (2 commits)")

---

Tags

gatewaypayment gatewaysaderatsaderat payment gatewaysaderat bank

### Embed Badge

![Health badge](/badges/hamid-a-saderat-pg/health.svg)

```
[![Health](https://phpackages.com/badges/hamid-a-saderat-pg/health.svg)](https://phpackages.com/packages/hamid-a-saderat-pg)
```

###  Alternatives

[shetabit/payment

Laravel Payment Gateway Integration Package

944336.8k5](/packages/shetabit-payment)[shetabit/multipay

PHP Payment Gateway Integration Package

293355.3k4](/packages/shetabit-multipay)[tzsk/payu

PayU India Payment Gateway Integration with Laravel

46111.0k6](/packages/tzsk-payu)[parsisolution/gateway

A Laravel package for connecting to all Iraninan payment gateways

231.7k](/packages/parsisolution-gateway)

PHPackages © 2026

[Directory](/)[Categories](/categories)[Trending](/trending)[Changelog](/changelog)[Analyze](/analyze)
