import zbase32 from 'zbase32' function convertBigEndianBufferToLong(longBuffer) { let longValue = 0 const byteArray = Buffer.from(longBuffer).swap64() for (let i = byteArray.length - 1; i >= 0; i--) { longValue = (longValue * 256) + byteArray[i] } return longValue } export function decodeInvoice(payreq) { const payreqBase32 = zbase32.decode(payreq) const bufferHexRotated = Buffer.from(payreqBase32).toString('hex') const bufferHex = bufferHexRotated.substr(bufferHexRotated.length - 1, bufferHexRotated.length) + bufferHexRotated.substr(0, bufferHexRotated.length - 1) const buffer = Buffer.from(bufferHex, 'hex') const pubKeyBuffer = buffer.slice(0, 33) const pubKeyHex = pubKeyBuffer.toString('hex') const paymentHashBuffer = buffer.slice(33, 65) const paymentHashHex = paymentHashBuffer.toString('hex') const valueBuffer = buffer.slice(65, 73) const amount = convertBigEndianBufferToLong(valueBuffer) return { payreq, amount, r_hash: paymentHashHex, } }