A Node.js SDK for First Iraqi Bank's online payment.
- Authentication: Authentication of the user and the credentials you were given, and giving you a token for your future requests.
- Payment Creation: Used to create a payment and getting QR codes and dynamic links to forward the user to the payment screen.
- Checking payment status: Used to check the status of a payment.
- Payment Cancellation: Used to cancel an active payment that has not been paid yet.
- Payment Refund: Used to refund a paid payment.
All methods use promise meaning you can either use the async...await
or then...catch
or try...catch
For Yarn
yarn add fib-sdk
For NPM
npm install fib-sdk --save
import { Fib } from 'fib-sdk';
const fib = new Fib(clientId:string, clientSecret:string, sandbox?:boolean);
const Fib = require('fib-sdk').Fib;
const fib = new Fib(clientId:string, clientSecret:string, sandbox?:boolean);
OR
const { Fib } = require('fib-sdk');
const fib = new Fib(clientId:string, clientSecret:string, sandbox?:boolean);
PS: If you're in a development environment or testing the package make sure to set the sandbox
parameter to true
while initializing the Fib instance, incase of production environment, you can set it to false
or leave it since it's defaulted to false
.
Authenticating with FIB using your client_id
and client_secret
that you have provided while creating the Fib instance, simply call the authenticate()
method, it will return true
if successfull.
await fib.authenticate(); // returns boolean
You can get status
information from the fib instance, for example after successful authentication the Fib instance status field should equal READY
let status = fib.status; // INITIALIZED | READY | FAILED
After creating a Fib instance and authenticating, you can create a payment instance by calling the create()
method from the payment instance, this will return the API request's response object, you can create a payment like this:
const payment = fib.payment
const paymentResponse = await payment.create({
// Payment value and currency
monetaryValue: {
// the amount of the payment.
amount: number,
// the currency of the payment; currently only IQD is supported currently.
currency: 'IQD' | 'USD',
},
// The callback url that FIB will send a POST request to when status of the created payment changes.
// Callback URL should be able to handle POST requests with request body that contains two properties:
// id : this will be the payment id.
// status : this will be the payment status.
statusCallbackUrl?: string,
// Description of the payment to help your customer to identify it in the FIB app, with the maximum length of 50 characters.
description?: string,
})
Example of a payment response data:
paymentResponse.data = {
// A unique identifier of the payment.
paymentId: string,
// Expected values are: PAID | UNPAID | DECLINED.
status: string,
// an ISO-8601-formatted date-time string, representing a moment in time when the payment expires.
validUntil: string,
//a JSON object, containing two key-value pairs; the amount and currency of the payment.
amount: {
amount: number,
currency: string,
};
// Expected Values are:
// SERVER_FAILURE : Payment failure due to some internal error.
// PAYMENT_EXPIRATION : Payment has expired.
// PAYMENT_CANCELLATION : Payment canceled by the user.
decliningReason?: string,
// an ISO-8601-formatted date-time string, representing a moment in time when the payment is declined.
declinedAt?: string,
// a JSON object, containing two key-value pairs; the name and iban of the customer.
paidBy?: {
name: string;
iban: string;
},
}
You can also get the paymentId
, qrCode
, readableCode
, personalAppLink
, businessAppLink
, corporateAppLink
, validUntil
, amount
, currency
, and status
informations from payment instance:
let paymentId = payment.paymentId;
let paymentStatus = payment.status; // NO_PAYMENT | PAID | UNPAID | AUTH_FAILD | DECLINED
you can fetch fresh information about your payment from the FIB's payment API service by calling the getStatus()
method, the method returns the API request's response object, which will also updates the payment instance's fields data, for example:
let paymentStatusResponse = await payment.getStatus();
Example of payment response data:
paymentStatusResponse.data = {
// A unique identifier of the payment.
paymentId: string,
// Expected values are: PAID | UNPAID | DECLINED | REFUND_REQUESTED | REFUNDED.
status: string,
// an ISO-8601-formatted date-time string, representing a moment in time when the payment expires.
validUntil: string,
// a JSON object, containing two key-value pairs; the amount and currency of the payment.
amount: {
amount: number,
currency: string,
};
// Expected Values are:
// SERVER_FAILURE : Payment failure due to some internal error.
// PAYMENT_EXPIRATION : Payment has expired.
// PAYMENT_CANCELLATION : Payment canceled by the user.
decliningReason?: string,
// an ISO-8601-formatted date-time string, representing a moment in time when the payment is declined.
declinedAt?: string,
// a JSON object, containing two key-value pairs; the name and iban of the customer.
paidBy?: {
name: string,
iban: string,
}
}
You can also get status information of your previous payments by their paymentId, you can call getStatusById()
method as it follows:
const paymentStatusByIdResponse = await payment.getStatusById(paymentId:number);
console.log(paymentStatusByIdResponse.data);
To cancel a created payment, you can call the cancel()
method with your payment instance and this will cancel the payment from FIB and change the status of the payment instance to DECLINED
, the method returns a boolean value, it returns true
if the cancelation was successful.
let cancelPayment = await payment.cancel(); // returns boolean
To refund a created payment, you can call the refund()
method with your payment instance and this will refund the payment from FIB and change the status of the payment instance to REFUND_REQUESTED
, after a short of time status will change to REFUNDED
and the amount will be refunded, The method returns a boolean value, it returns true
if the refund was susccessful, if payment is not paid it will return false
.
- Only Payments with
PAID
status can be refunded. - Only payments that was paid in the last 24 hours can be refunded.
let refundPayment = await payment.refund(); // returns boolean
You can also refund previous payments by their paymentId, you can call refundById()
method as it follows:
const refundPayment = await payment.refundById(paymentId:string);
console.log(refundPayment); // returns boolean
Clone the project
https://github.com/kurdi-dev/fib-sdk.git
Go to the project directory
cd fib-sdk
Install dependencies
npm install # or yarn install
To do a one-off build, use:
npm run build # or yarn build
To run tests, use:
npm run test # or yarn test
Contributions are always welcome!
If any issues are found or you have any feedback, please reach out to me at walid@kurdi.dev