namigo-sdk / namigo-sdk-php
Namigo PHP Payment SDK
v0.1.2
2022-02-22 05:56 UTC
Requires
- php: >=5.3.0
- ext-json: *
- rmccue/requests: v1.8.0
Requires (Dev)
- phpunit/phpunit: ~4.8|~5.0
- raveren/kint: 1.*
This package is not auto-updated.
Last update: 2025-03-26 21:01:55 UTC
README
Prerequisites
- A minimum of PHP 5.3 is required
Installation
- If your project using composer, run the below command
composer require psp-sdk/psp-sdk-php
- If you are not using composer, download the latest release from the releases section.
You should download the
psp-sdk-php-master.zip
file. After that, includeNamipay.php
in your application and you can use the API as usual.
##Note: This PHP library follows the following practices:
- Namespaced under
Namipay\Api
- API throws exceptions instead of returning errors
- Options are passed as an array instead of multiple arguments wherever possible
- All requests and responses are communicated over JSON
Basic Usage
Instantiate the namipay php instance with user_name
, password
& secret_key(These will be different for Test and Live). You can obtain the keys from the dashboard app (https://go.namipay.com.sa/user-api-keys)
use Namipay\Api\Api; $secret_key = 'dCtLbk5FYVFGMVYrbFNGZTdEdzVpbSt3TFlYOC9NczNLaDZ0ZFo1WHcwVT0='; $api_user_name = 'psp_test.eaohcfml.ZWFvaGNmbWw='; $api_password = 'L1VPcklHbnh6T3RyWkdEVWZhci9HR1hSaHlrb0MwVEN5R0VtcUxkWHMwWT0='; $apiMode = 0; // 0=Test, 1=Live $api = new Api($api_user_name, $api_password, $apiMode);
The resources can be accessed via the $api
object. All the methods invocations follows the following pattern
//$api->class->function() to access the API //Example //This is for encrypt decrypt before call API //Create Payment $paymentParm = array('customer' =>array('name'=>'Raj', 'email'=>'raj2022@example.com') ,'order'=>array('amount'=>'1', 'currency' => 'SAR'),'sourceOfFunds' => array('provided'=>array('card'=>array('number'=>'5123450000000008','expiry'=>array('month'=>'12','year'=>'2023'), 'cvv'=>'999')), 'cardType' => 'C'), 'remark'=>array('description'=>'This payment is done by card')); $api->encryptDecrypt->create($paymentParm, $secret_key, 'encrypt'); // Payment API //Alwase send $param['trandata'] in encrypted string $param['trandata'] = $encripted_result['content']['apiResponse']; $result = $api->payment->createPayment($param); //STC Pay Create Payment $stcParm = array('Customer' =>array('Name'=>'Dharmraj Kumhar', 'Email'=>'developers.wdp@gmail.com'),'DirectPaymentAuthorizeV4RequestMessage' =>array('MobileNo'=>'966557877988','Amount'=>'11','MerchantNote'=>'STC Payment')); $encripted_result = $api->encryptDecrypt->create($stcParm, $secret_key, 'encrypt'); // Payment API //Alwase send $param['trandata'] in encrypted string $param['trandata'] = $encripted_result['content']['apiResponse']; $result = $api->payment->stcPay($param); //Refund Transaction $refundParm = array('transaction' =>array('id'=>'nt8my581z620365207292e','amount'=>'1', 'currency' => 'SAR'), 'remark'=>array('description'=>'Refund transaction')); $encripted_result = $api->encryptDecrypt->create($refundParm, $secret_key, 'encrypt'); $param['trandata'] = $encripted_result['content']['apiResponse']; $result = $api->payment->refund($param); //Retrive Transaction $result = $api->payment->retriveTransaction($transactionId); //Transaction List between two date range $AllTransParm = array('transaction' =>array('startdate'=>'2022-01-15','enddate'=>'2022-02-09')); $result = $api->payment->transactionList($AllTransParm); //subscription $parms = array('customer' =>array('name'=>'Raj','email'=>'raj2022@example.com', 'interval'=>'1','interval_type'=>'3','interval_count'=>''),'order'=>array('amount'=>'1','currency' => 'SAR'),'sourceOfFunds' => array('provided'=>array('card'=>array('number'=>'5123450000000008','expiry'=>array('month'=>'12','year'=>'2023'), 'cvv'=>'999')),'cardType' => 'C')); $encripted_result = $api->encryptDecrypt->create($parms, $secret_key, 'encrypt'); $param['trandata'] = $encripted_result['content']['apiResponse']; if(!empty($encripted_result['content']['apiResponse']) && $encripted_result['code'] == 200){ $result = $api->payment->subscription($param); } //subscription detail $customer_id = "202130020209387"; $result = $api->payment->subscriptionDetail($customer_id); //subscription cancel $customer_id = "202130294267467"; $result = $api->payment->cancelSubscription($customer_id);
License
The Namigo PHP SDK is released under the MIT License. See LICENSE file for more details.