mirror of
https://github.com/BlueWallet/BlueWallet.git
synced 2025-02-22 23:08:07 +01:00
42 lines
1.2 KiB
JavaScript
42 lines
1.2 KiB
JavaScript
import { LegacyWallet } from './legacy-wallet';
|
|
import { BitcoinUnit } from '../models/bitcoinUnits';
|
|
const bitcoin = require('bitcoinjs-lib');
|
|
|
|
export class SegwitBech32Wallet extends LegacyWallet {
|
|
constructor() {
|
|
super();
|
|
this.type = 'segwitBech32';
|
|
this.preferredBalanceUnit = BitcoinUnit.BTC;
|
|
}
|
|
|
|
getPreferredBalanceUnit() {
|
|
return this.preferredBalanceUnit || BitcoinUnit.BTC;
|
|
}
|
|
|
|
getTypeReadable() {
|
|
return 'P2 WPKH';
|
|
}
|
|
|
|
getAddress() {
|
|
if (this._address) return this._address;
|
|
let address;
|
|
try {
|
|
let keyPair = bitcoin.ECPair.fromWIF(this.secret);
|
|
let pubKey = keyPair.getPublicKeyBuffer();
|
|
let scriptPubKey = bitcoin.script.witnessPubKeyHash.output.encode(bitcoin.crypto.hash160(pubKey));
|
|
address = bitcoin.address.fromOutputScript(scriptPubKey);
|
|
} catch (err) {
|
|
return false;
|
|
}
|
|
this._address = address;
|
|
|
|
return this._address;
|
|
}
|
|
|
|
static witnessToAddress(witness) {
|
|
const pubKey = Buffer.from(witness, 'hex');
|
|
const pubKeyHash = bitcoin.crypto.hash160(pubKey);
|
|
const scriptPubKey = bitcoin.script.witnessPubKeyHash.output.encode(pubKeyHash);
|
|
return bitcoin.address.fromOutputScript(scriptPubKey, bitcoin.networks.bitcoin);
|
|
}
|
|
}
|