eghtesad-novin-checkout
v1.0.1
Published
Unofficial NodeJS implementation of Novin Pardakht Eghtesad Novin Gateway API
Downloads
20
Maintainers
Readme
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.