Browse Source

Merge pull request #575 from bitcoinjs/ectypes2

ECPair cleanup
hk-custom-address
Daniel Cousens 9 years ago
parent
commit
f1a20f1ec8
  1. 25
      src/ecpair.js

25
src/ecpair.js

@ -1,5 +1,5 @@
var baddress = require('./address')
var bcrypto = require('./crypto') var bcrypto = require('./crypto')
var bs58check = require('bs58check')
var ecdsa = require('./ecdsa') var ecdsa = require('./ecdsa')
var randomBytes = require('randombytes') var randomBytes = require('randombytes')
var typeforce = require('typeforce') var typeforce = require('typeforce')
@ -58,20 +58,24 @@ ECPair.fromPublicKeyBuffer = function (buffer, network) {
} }
ECPair.fromWIF = function (string, network) { ECPair.fromWIF = function (string, network) {
var buffer = bs58check.decode(string) var decoded = wif.decode(string)
var version = decoded.version
// [network, ...]
if (types.Array(network)) { if (types.Array(network)) {
var version = buffer[0]
network = network.filter(function (network) { network = network.filter(function (network) {
return version === network.wif return version === network.wif
}).pop() }).pop()
if (!network) throw new Error('Unknown network version') if (!network) throw new Error('Unknown network version')
}
// network
} else {
network = network || NETWORKS.bitcoin network = network || NETWORKS.bitcoin
var decoded = wif.decodeRaw(buffer, network.wif)
if (version !== network.wif) throw new Error('Invalid network version')
}
var d = BigInteger.fromBuffer(decoded.privateKey) var d = BigInteger.fromBuffer(decoded.privateKey)
return new ECPair(d, null, { return new ECPair(d, null, {
@ -97,14 +101,7 @@ ECPair.makeRandom = function (options) {
} }
ECPair.prototype.getAddress = function () { ECPair.prototype.getAddress = function () {
var pubKey = this.getPublicKeyBuffer() return baddress.toBase58Check(bcrypto.hash160(this.getPublicKeyBuffer()), this.getNetwork().pubKeyHash)
var pubKeyHash = bcrypto.hash160(pubKey)
var payload = new Buffer(21)
payload.writeUInt8(this.network.pubKeyHash, 0)
pubKeyHash.copy(payload, 1)
return bs58check.encode(payload)
} }
ECPair.prototype.getNetwork = function () { ECPair.prototype.getNetwork = function () {

Loading…
Cancel
Save