Skip to content

Unofficial NodeJS implementation of Novin Pardakht Eghtesad Novin Gateway API

Notifications You must be signed in to change notification settings

pouriaMaleki/eghtesad-novin-checkout

Folders and files

NameName
Last commit message
Last commit date

Latest commit

 

History

9 Commits
 
 
 
 
 
 
 
 
 
 
 
 
 
 

Repository files navigation

Eghtesad Novin Ckeckout:

Unofficial Novin Pardakht - Eghtesad Novin Gateway implementation in Node.JS

Warning: Eghtesad Novin gateway API's are not persistent and they will change without notifing users.

This module needs openssl installed on your computer (or server) and should be visible in $PATH. (Pre-installed on most linux distros - except light weight docker images)

Notice: They are not checking IP's so you can test it on your development machine.

Installation

Install the package from 'npm' or 'yarn'.

NPM

npm install eghtesad-novin-checkout

Yarn

yarn add eghtesad-novin-checkout

Usage:

Create An Instance

Import the package:

const EghtesadNovin = require('eghtesad-novin-checkout');
// or (ES6):
import EghtesadNovin from 'eghtesad-novin-checkout';

Then create an instance:

const eghtesadNovin = new EghtesadNovin({
  username: 'xxxxxxx',
  password: 'xxxxxxx',
  pemKeyAddress: './private.pem' // the one that they emailed to you
});

API

Request Token:

eghtesadNovin.requestPaymentToken(
  1000, // String, Payment Amount In Rials
  '12345678912', // String, invoiceNumber Generated By You
  'https://call.back/enbank' // Payment Callback URL
).then(function (response) {
  // send this token to client and make a Post request with token from there
  console.log(response.token, response.expirationDate);
}).catch(function (error) {
  console.error(error);
});

After making Post request to bank URL, user will follow bank instructions then he will posted to your callbackUrl, make sure that your endpoint should accept Post method.
These parameters will be accesible via bank Post request in endpoint:

  • State // if payment is successfull they will send "ok" string (do toLowerCase to avoid furture problems)
  • token // same as your request
  • RefNum // use to finalize payment
  • traceNumLbl // actually this should be RefNum

Payment Finalization:

enghtesadNovin.recievePay(
  'XXXXXXXXXX', // token
  '1111111111' // RefNum, Get From Payment Callback Post Params
).then(function (response) {
  console.log(response.TraceNo, response.traceNumLbl, response.CustomerRefNum, response.CardMaskPan, response.CardHashPan);
  // some of values may not sent from bank
}).catch(function (error) {
  console.error(error);
});

Related projects:

Thanks to Sina Bakhtiari there is an open source Unofficial NodeJS implementation of Behpardakht Mellat Gateway API available.

About

Unofficial NodeJS implementation of Novin Pardakht Eghtesad Novin Gateway API

Topics

Resources

Stars

Watchers

Forks

Releases

No releases published

Packages

No packages published