telebirr-node

1.1.1 • Public • Published

telebirr-node

Telebirr integration package for node

Usage

install the package npm i telebirr-node

const Telebirr = require('telebirr-node');

const telebirr = new Telebirr({
  appId: 'YOUR TELEBIRR APP ID',
  appKey: 'YOUR TELEBIRR APP KEY',
  shortCode: 'TELEBIRR SHORT CODE',
  publicKey: 'YOUR TELEBIRR PUBLIC KEY',
});

const { success, response, error } = await telebirr.makePayment({
  paymentMethod: 'web | app',
  nonce: 'a unique random string ( should be unique for each request )',
  notifyUrl: 'https://www.example.com/yourapp-webhook', // callback url for payment confirmation
  totalAmount: 4.5, // amount to charge
  outTradeNo: 'unique identifier (order no)',
  receiveName: 'Almaz Werku', // receiver's name
  returnApp: 'com.example.app', // your application package name
  returnUrl: 'https://yourwebsite.com', // redirect url after payment completion'
  subject: 'payment for ...',
  timeoutExpress: '120', // valid for 2 hours
});

Handling callback notifications

  • once user completes the payment, you'll receive an encrypted plaintext on the notifyUrl you provided.

  • Make sure the endpoint accepts plaintext request body

  • you need to decrypt the text to get the transaction details

const {
  msisdn, // the phone number from which the payment was done
  outTradeNo, // unique identifier provided when creating the payment
  totalAmount,
  tradeDate,
  tradeNo,
  tradeStatus,
  transactionNo,
} = telebirr.getDecryptedCallbackNotification(encryptedTextFromTelebirr);

Reference:

Owner: Vernu, Repo: Repository

Package Sidebar

Install

npm i telebirr-node

Weekly Downloads

6

Version

1.1.1

License

ISC

Unpacked Size

14.8 kB

Total Files

6

Last publish

Collaborators

  • yabeye