|
@ -1,27 +1,34 @@ |
|
|
/* global describe, it */ |
|
|
/* global describe, it */ |
|
|
|
|
|
|
|
|
var assert = require('assert') |
|
|
let assert = require('assert') |
|
|
var bigi = require('bigi') |
|
|
let bitcoin = require('../../') |
|
|
var bitcoin = require('../../') |
|
|
let dhttp = require('dhttp/200') |
|
|
var dhttp = require('dhttp/200') |
|
|
|
|
|
|
|
|
|
|
|
// deterministic RNG for testing only
|
|
|
// deterministic RNG for testing only
|
|
|
function rng () { return Buffer.from('zzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzz') } |
|
|
function rng () { return Buffer.from('zzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzz') } |
|
|
|
|
|
|
|
|
|
|
|
// TODO: remove
|
|
|
|
|
|
let baddress = bitcoin.address |
|
|
|
|
|
let bcrypto = bitcoin.crypto |
|
|
|
|
|
function getAddress (node, network) { |
|
|
|
|
|
network = network || bitcoin.networks.bitcoin |
|
|
|
|
|
return baddress.toBase58Check(bcrypto.hash160(node.getPublicKeyBuffer()), network.pubKeyHash) |
|
|
|
|
|
} |
|
|
|
|
|
|
|
|
describe('bitcoinjs-lib (addresses)', function () { |
|
|
describe('bitcoinjs-lib (addresses)', function () { |
|
|
it('can generate a random address', function () { |
|
|
it('can generate a random address', function () { |
|
|
var keyPair = bitcoin.ECPair.makeRandom({ rng: rng }) |
|
|
var keyPair = bitcoin.ECPair.makeRandom({ rng: rng }) |
|
|
var address = keyPair.getAddress() |
|
|
var address = getAddress(keyPair) |
|
|
|
|
|
|
|
|
assert.strictEqual(address, '1F5VhMHukdnUES9kfXqzPzMeF1GPHKiF64') |
|
|
assert.strictEqual(address, '1F5VhMHukdnUES9kfXqzPzMeF1GPHKiF64') |
|
|
}) |
|
|
}) |
|
|
|
|
|
|
|
|
it('can generate an address from a SHA256 hash', function () { |
|
|
it('can generate an address from a SHA256 hash', function () { |
|
|
var hash = bitcoin.crypto.sha256(Buffer.from('correct horse battery staple')) |
|
|
var hash = bitcoin.crypto.sha256(Buffer.from('correct horse battery staple')) |
|
|
var d = bigi.fromBuffer(hash) |
|
|
|
|
|
|
|
|
|
|
|
var keyPair = new bitcoin.ECPair(d) |
|
|
var keyPair = bitcoin.ECPair.makeRandom({ rng: () => hash }) |
|
|
var address = keyPair.getAddress() |
|
|
var address = getAddress(keyPair) |
|
|
|
|
|
|
|
|
// Generating addresses from SHA256 hashes is not secure if the input to the hash function is predictable
|
|
|
// Generating addresses from SHA256 hashes is not secure if the input to the hash function is predictable
|
|
|
// Do not use with predictable inputs
|
|
|
// Do not use with predictable inputs
|
|
|
assert.strictEqual(address, '1C7zdTfnkzmr13HfA2vNm5SJYRK6nEKyq8') |
|
|
assert.strictEqual(address, '1C7zdTfnkzmr13HfA2vNm5SJYRK6nEKyq8') |
|
@ -29,7 +36,7 @@ describe('bitcoinjs-lib (addresses)', function () { |
|
|
|
|
|
|
|
|
it('can import an address via WIF', function () { |
|
|
it('can import an address via WIF', function () { |
|
|
var keyPair = bitcoin.ECPair.fromWIF('Kxr9tQED9H44gCmp6HAdmemAzU3n84H3dGkuWTKvE23JgHMW8gct') |
|
|
var keyPair = bitcoin.ECPair.fromWIF('Kxr9tQED9H44gCmp6HAdmemAzU3n84H3dGkuWTKvE23JgHMW8gct') |
|
|
var address = keyPair.getAddress() |
|
|
var address = getAddress(keyPair) |
|
|
|
|
|
|
|
|
assert.strictEqual(address, '19AAjaTUbRjQCMuVczepkoPswiZRhjtg31') |
|
|
assert.strictEqual(address, '19AAjaTUbRjQCMuVczepkoPswiZRhjtg31') |
|
|
}) |
|
|
}) |
|
@ -100,7 +107,7 @@ describe('bitcoinjs-lib (addresses)', function () { |
|
|
|
|
|
|
|
|
it('can support the retrieval of transactions for an address (via 3PBP)', function (done) { |
|
|
it('can support the retrieval of transactions for an address (via 3PBP)', function (done) { |
|
|
var keyPair = bitcoin.ECPair.makeRandom() |
|
|
var keyPair = bitcoin.ECPair.makeRandom() |
|
|
var address = keyPair.getAddress() |
|
|
var address = getAddress(keyPair) |
|
|
|
|
|
|
|
|
dhttp({ |
|
|
dhttp({ |
|
|
method: 'POST', |
|
|
method: 'POST', |
|
@ -120,20 +127,20 @@ describe('bitcoinjs-lib (addresses)', function () { |
|
|
|
|
|
|
|
|
// other networks
|
|
|
// other networks
|
|
|
it('can generate a Testnet address', function () { |
|
|
it('can generate a Testnet address', function () { |
|
|
var testnet = bitcoin.networks.testnet |
|
|
let testnet = bitcoin.networks.testnet |
|
|
var keyPair = bitcoin.ECPair.makeRandom({ network: testnet, rng: rng }) |
|
|
let keyPair = bitcoin.ECPair.makeRandom({ network: testnet, rng: rng }) |
|
|
var wif = keyPair.toWIF() |
|
|
let wif = keyPair.toWIF() |
|
|
var address = keyPair.getAddress() |
|
|
let address = getAddress(keyPair, testnet) |
|
|
|
|
|
|
|
|
assert.strictEqual(address, 'mubSzQNtZfDj1YdNP6pNDuZy6zs6GDn61L') |
|
|
assert.strictEqual(address, 'mubSzQNtZfDj1YdNP6pNDuZy6zs6GDn61L') |
|
|
assert.strictEqual(wif, 'cRgnQe9MUu1JznntrLaoQpB476M8PURvXVQB5R2eqms5tXnzNsrr') |
|
|
assert.strictEqual(wif, 'cRgnQe9MUu1JznntrLaoQpB476M8PURvXVQB5R2eqms5tXnzNsrr') |
|
|
}) |
|
|
}) |
|
|
|
|
|
|
|
|
it('can generate a Litecoin address', function () { |
|
|
it('can generate a Litecoin address', function () { |
|
|
var litecoin = bitcoin.networks.litecoin |
|
|
let litecoin = bitcoin.networks.litecoin |
|
|
var keyPair = bitcoin.ECPair.makeRandom({ network: litecoin, rng: rng }) |
|
|
let keyPair = bitcoin.ECPair.makeRandom({ network: litecoin, rng: rng }) |
|
|
var wif = keyPair.toWIF() |
|
|
let wif = keyPair.toWIF() |
|
|
var address = keyPair.getAddress() |
|
|
let address = getAddress(keyPair, litecoin) |
|
|
|
|
|
|
|
|
assert.strictEqual(address, 'LZJSxZbjqJ2XVEquqfqHg1RQTDdfST5PTn') |
|
|
assert.strictEqual(address, 'LZJSxZbjqJ2XVEquqfqHg1RQTDdfST5PTn') |
|
|
assert.strictEqual(wif, 'T7A4PUSgTDHecBxW1ZiYFrDNRih2o7M8Gf9xpoCgudPF9gDiNvuS') |
|
|
assert.strictEqual(wif, 'T7A4PUSgTDHecBxW1ZiYFrDNRih2o7M8Gf9xpoCgudPF9gDiNvuS') |
|
|