UNPKG

@qiushaoxi/hw-app-ont

Version:

Ledger Javascript API for ONT and NEO.

51 lines (47 loc) 1.45 kB
import { utils } from 'ontology-ts-sdk'; export function splitPath(path: string) { let result: number[] = []; let components = path.split('/'); components.forEach(element => { let number = parseInt(element, 10); if (isNaN(number)) { throw Error(`Path ${path} is invalid.`); } if (element.length > 1 && element[element.length - 1] === "'") { number += 0x80000000; } result.push(number); }); return result; } export function convertPathToBuffer(path: string) { const paths = splitPath(path); const buffer = Buffer.alloc(paths.length * 4); paths.forEach((element, index) => { buffer.writeUInt32BE(element, 4 * index); }); return buffer; } export function convertDerToHex(response: string) { const ss = new utils.StringReader(response); // The first byte is format. It is usually 0x30 (SEQ) or 0x31 (SET) // The second byte represents the total length of the DER module. ss.read(2); // Now we read each field off // Each field is encoded with a type byte, length byte followed by the data itself ss.read(1); // Read and drop the type const r = ss.readNextBytes(); ss.read(1); const s = ss.readNextBytes(); // We will need to ensure both integers are 32 bytes long const integers = [r, s].map(i => { if (i.length < 64) { i = i.padStart(64, '0'); } if (i.length > 64) { i = i.substr(-64); } return i; }); return integers.join(''); }