Browse Source

Merge pull request #133 from dcousens/network

Updates network.js constant names
hk-custom-address
Kyle Drake 11 years ago
parent
commit
95b3fd32a3
  1. 6
      src/address.js
  2. 6
      src/eckey.js
  3. 14
      src/hdwallet.js
  4. 36
      src/network.js
  5. 4
      src/script.js
  6. 2
      src/wallet.js
  7. 36
      test/address.js
  8. 4
      test/eckey.js
  9. 8
      test/hdwallet.js
  10. 2
      test/message.js
  11. 4
      test/script.js
  12. 4
      test/wallet.js

6
src/address.js

@ -1,7 +1,7 @@
var base58 = require('./base58') var base58 = require('./base58')
var base58check = require('./base58check') var base58check = require('./base58check')
var convert = require('./convert') var convert = require('./convert')
var mainnet = require('./network').mainnet.addressVersion var bitcoin = require('./network').bitcoin.pubKeyHash
function Address(bytes, version) { function Address(bytes, version) {
if (!(this instanceof Address)) { if (!(this instanceof Address)) {
@ -21,7 +21,7 @@ function Address(bytes, version) {
} }
else if (bytes.length <= 40) { else if (bytes.length <= 40) {
this.hash = convert.hexToBytes(bytes) this.hash = convert.hexToBytes(bytes)
this.version = version || mainnet this.version = version || bitcoin
} }
else { else {
throw new Error('Invalid or unrecognized input') throw new Error('Invalid or unrecognized input')
@ -29,7 +29,7 @@ function Address(bytes, version) {
} }
else { else {
this.hash = bytes this.hash = bytes
this.version = version || mainnet this.version = version || bitcoin
} }
} }

6
src/eckey.js

@ -74,7 +74,7 @@ ECKey.version_bytes = {
} }
ECKey.prototype.toWif = function(version) { ECKey.prototype.toWif = function(version) {
version = version || Network.mainnet.addressVersion version = version || Network.bitcoin.pubKeyHash
return base58check.encode(this.toBytes(), ECKey.version_bytes[version]) return base58check.encode(this.toBytes(), ECKey.version_bytes[version])
} }
@ -169,7 +169,7 @@ ECPubKey.prototype.toBin = function(compressed) {
} }
ECPubKey.prototype.toWif = function(version) { ECPubKey.prototype.toWif = function(version) {
version = version || Network.mainnet.addressVersion version = version || Network.bitcoin.pubKeyHash
return base58check.encode(this.toBytes(), version) return base58check.encode(this.toBytes(), version)
} }
@ -177,7 +177,7 @@ ECPubKey.prototype.toWif = function(version) {
ECPubKey.prototype.toString = ECPubKey.prototype.toHex ECPubKey.prototype.toString = ECPubKey.prototype.toHex
ECPubKey.prototype.getAddress = function(version) { ECPubKey.prototype.getAddress = function(version) {
version = version || Network.mainnet.addressVersion version = version || Network.bitcoin.pubKeyHash
return new Address(crypto.hash160(this.toBytes()), version) return new Address(crypto.hash160(this.toBytes()), version)
} }

14
src/hdwallet.js

@ -21,7 +21,7 @@ function HDWallet(seed, network) {
var I = HmacSHA512(seed, 'Bitcoin seed') var I = HmacSHA512(seed, 'Bitcoin seed')
this.chaincode = I.slice(32) this.chaincode = I.slice(32)
this.network = network || 'mainnet' this.network = network || 'bitcoin'
if(!Network.hasOwnProperty(this.network)) { if(!Network.hasOwnProperty(this.network)) {
throw new Error("Unknown network: " + this.network) throw new Error("Unknown network: " + this.network)
} }
@ -77,7 +77,7 @@ HDWallet.fromBytes = function(input) {
var hd = new HDWallet() var hd = new HDWallet()
// 4 byte: version bytes (mainnet: 0x0488B21E public, 0x0488ADE4 private // 4 byte: version bytes (bitcoin: 0x0488B21E public, 0x0488ADE4 private
// testnet: 0x043587CF public, 0x04358394 private) // testnet: 0x043587CF public, 0x04358394 private)
var versionBytes = input.slice(0, 4) var versionBytes = input.slice(0, 4)
var versionWord = convert.bytesToWords(versionBytes)[0] var versionWord = convert.bytesToWords(versionBytes)[0]
@ -86,8 +86,8 @@ HDWallet.fromBytes = function(input) {
for(var name in Network) { for(var name in Network) {
var network = Network[name] var network = Network[name]
for(var t in network.hdVersions) { for(var t in network.bip32) {
if (versionWord != network.hdVersions[t]) continue if (versionWord != network.bip32[t]) continue
type = t type = t
hd.network = name hd.network = name
@ -141,9 +141,9 @@ HDWallet.prototype.toBytes = function(priv) {
var buffer = [] var buffer = []
// Version // Version
// 4 byte: version bytes (mainnet: 0x0488B21E public, 0x0488ADE4 private; testnet: 0x043587CF public, // 4 byte: version bytes (bitcoin: 0x0488B21E public, 0x0488ADE4 private; testnet: 0x043587CF public,
// 0x04358394 private) // 0x04358394 private)
var version = Network[this.network].hdVersions[priv ? 'priv' : 'pub'] var version = Network[this.network].bip32[priv ? 'priv' : 'pub']
var vBytes = convert.wordsToBytes([version]) var vBytes = convert.wordsToBytes([version])
buffer = buffer.concat(vBytes) buffer = buffer.concat(vBytes)
@ -248,7 +248,7 @@ HDWallet.prototype.derivePrivate = function(index) {
} }
HDWallet.prototype.getKeyVersion = function() { HDWallet.prototype.getKeyVersion = function() {
return Network[this.network].addressVersion return Network[this.network].pubKeyHash
} }
HDWallet.prototype.toString = HDWallet.prototype.toBase58 HDWallet.prototype.toString = HDWallet.prototype.toBase58

36
src/network.js

@ -1,19 +1,29 @@
// https://en.bitcoin.it/wiki/List_of_address_prefixes
module.exports = { module.exports = {
mainnet: { bitcoin: {
addressVersion: 0, bip32: {
p2shVersion: 5, pub: 0x0488b21e,
hdVersions: { priv: 0x0488ade4
pub: 0x0488B21E, },
priv: 0x0488ADE4 pubKeyHash: 0x00,
} scriptHash: 0x05,
wif: 0x80
},
dogecoin: {
pubKeyHash: 0x30,
scriptHash: 0x20,
wif: 0x9e
},
litecoin: {
scriptHash: 0x30,
}, },
testnet: { testnet: {
addressVersion: 111, bip32: {
p2shVersion: 196, pub: 0x043587cf,
hdVersions: {
pub: 0x043587CF,
priv: 0x04358394 priv: 0x04358394
},
pubKeyHash: 0x6f,
scriptHash: 0xc4,
wif: 0xef
} }
} }
}

4
src/script.js

@ -369,8 +369,8 @@ Script.prototype.writeBytes = function(data) {
Script.createOutputScript = function(address) { Script.createOutputScript = function(address) {
var script = new Script() var script = new Script()
address = new Address(address) address = new Address(address)
if (address.version == network.mainnet.p2shVersion || if (address.version == network.bitcoin.scriptHash ||
address.version == network.testnet.p2shVersion) { address.version == network.testnet.scriptHash) {
// Standard pay-to-script-hash // Standard pay-to-script-hash
script.writeOp(Opcode.map.OP_HASH160) script.writeOp(Opcode.map.OP_HASH160)
script.writeBytes(address.hash) script.writeBytes(address.hash)

2
src/wallet.js

@ -7,7 +7,7 @@ function Wallet(seed, options) {
if (!(this instanceof Wallet)) { return new Wallet(seed, options); } if (!(this instanceof Wallet)) { return new Wallet(seed, options); }
var options = options || {} var options = options || {}
var network = options.network || 'mainnet' var network = options.network || 'bitcoin'
// Stored in a closure to make accidental serialization less likely // Stored in a closure to make accidental serialization less likely
var masterkey = null var masterkey = null

36
test/address.js

@ -3,26 +3,26 @@ var Address = require('../src/address')
var network = require('../src/network') var network = require('../src/network')
var base58 = require('../src/base58') var base58 = require('../src/base58')
var base58check = require('../src/base58check') var base58check = require('../src/base58check')
var mainnet = network.mainnet.addressVersion var bitcoin = network.bitcoin.pubKeyHash
var testnet = network.testnet.addressVersion var testnet = network.testnet.pubKeyHash
describe('Address', function() { describe('Address', function() {
var testnetAddress, mainnetAddress var testnetAddress, bitcoinAddress
var testnetP2shAddress, mainnetP2shAddress var testnetP2shAddress, bitcoinP2shAddress
beforeEach(function(){ beforeEach(function(){
mainnetAddress = '1A1zP1eP5QGefi2DMPTfTL5SLmv7DivfNa' bitcoinAddress = '1A1zP1eP5QGefi2DMPTfTL5SLmv7DivfNa'
testnetAddress = 'mzBc4XEFSdzCDcTxAgf6EZXgsZWpztRhef' testnetAddress = 'mzBc4XEFSdzCDcTxAgf6EZXgsZWpztRhef'
mainnetP2shAddress = '3NJZLcZEEYBpxYEUGewU4knsQRn1WM5Fkt' bitcoinP2shAddress = '3NJZLcZEEYBpxYEUGewU4knsQRn1WM5Fkt'
testnetP2shAddress = '2MxKEf2su6FGAUfCEAHreGFQvEYrfYNHvL7' testnetP2shAddress = '2MxKEf2su6FGAUfCEAHreGFQvEYrfYNHvL7'
}) })
describe('parsing', function() { describe('parsing', function() {
it('works with Address object', function() { it('works with Address object', function() {
var addr = new Address(new Address('mwrB4fgT1KSBCqELaWv7o7tsExuQzW3NY3', network.testnet.addressVersion)) var addr = new Address(new Address('mwrB4fgT1KSBCqELaWv7o7tsExuQzW3NY3', network.testnet.pubKeyHash))
assert.equal(addr.toString(), 'mwrB4fgT1KSBCqELaWv7o7tsExuQzW3NY3') assert.equal(addr.toString(), 'mwrB4fgT1KSBCqELaWv7o7tsExuQzW3NY3')
assert.equal(addr.version, network.testnet.addressVersion) assert.equal(addr.version, network.testnet.pubKeyHash)
}) })
it('works with hex', function() { it('works with hex', function() {
@ -37,15 +37,15 @@ describe('Address', function() {
}) })
it('works for byte input', function() { it('works for byte input', function() {
var hash = base58check.decode(mainnetAddress) var hash = base58check.decode(bitcoinAddress)
var addr = new Address(hash.payload) var addr = new Address(hash.payload)
assert.equal(addr.hash, hash.payload) assert.equal(addr.hash, hash.payload)
assert.equal(network.mainnet.addressVersion, hash.version) assert.equal(network.bitcoin.pubKeyHash, hash.version)
var hash = base58check.decode(testnetAddress) var hash = base58check.decode(testnetAddress)
var addr = new Address(hash.payload) var addr = new Address(hash.payload)
assert.equal(addr.hash, hash.payload) assert.equal(addr.hash, hash.payload)
assert.equal(network.testnet.addressVersion, hash.version) assert.equal(network.testnet.pubKeyHash, hash.version)
}) })
it('fails for bad input', function() { it('fails for bad input', function() {
@ -57,8 +57,8 @@ describe('Address', function() {
describe('getVersion', function() { describe('getVersion', function() {
it('returns the proper address version', function() { it('returns the proper address version', function() {
assert.equal(Address.getVersion(mainnetAddress), network.mainnet.addressVersion) assert.equal(Address.getVersion(bitcoinAddress), network.bitcoin.pubKeyHash)
assert.equal(Address.getVersion(testnetAddress), network.testnet.addressVersion) assert.equal(Address.getVersion(testnetAddress), network.testnet.pubKeyHash)
}) })
}) })
@ -72,9 +72,9 @@ describe('Address', function() {
describe('Constructor', function(){ describe('Constructor', function(){
it('resolves version correctly', function(){ it('resolves version correctly', function(){
assert.equal((new Address(testnetAddress)).version, testnet) assert.equal((new Address(testnetAddress)).version, testnet)
assert.equal((new Address(mainnetAddress)).version, mainnet) assert.equal((new Address(bitcoinAddress)).version, bitcoin)
assert.equal((new Address(testnetP2shAddress)).version, network.testnet.p2shVersion) assert.equal((new Address(testnetP2shAddress)).version, network.testnet.scriptHash)
assert.equal((new Address(mainnetP2shAddress)).version, network.mainnet.p2shVersion) assert.equal((new Address(bitcoinP2shAddress)).version, network.bitcoin.scriptHash)
}) })
}) })
@ -85,7 +85,7 @@ describe('Address', function() {
} }
validate(testnetAddress) validate(testnetAddress)
validate(mainnetAddress) validate(bitcoinAddress)
validate('12KYrjTdVGjFMtaxERSk3gphreJ5US8aUP') validate('12KYrjTdVGjFMtaxERSk3gphreJ5US8aUP')
validate('12QeMLzSrB8XH8FvEzPMVoRxVAzTr5XM2y') validate('12QeMLzSrB8XH8FvEzPMVoRxVAzTr5XM2y')
validate('1oNLrsHnBcR6dpaBpwz3LSwutbUNkNSjs') validate('1oNLrsHnBcR6dpaBpwz3LSwutbUNkNSjs')
@ -94,7 +94,7 @@ describe('Address', function() {
// p2sh addresses // p2sh addresses
validate(testnetP2shAddress) validate(testnetP2shAddress)
validate(mainnetP2shAddress) validate(bitcoinP2shAddress)
}) })
it('does not validate illegal examples', function() { it('does not validate illegal examples', function() {

4
test/eckey.js

@ -6,7 +6,7 @@ var bytesToHex = convert.bytesToHex
var hexToBytes = convert.hexToBytes var hexToBytes = convert.hexToBytes
var Address = require('../src/address') var Address = require('../src/address')
var Network = require('../src/network') var Network = require('../src/network')
var testnet = Network.testnet.addressVersion var testnet = Network.testnet.pubKeyHash
describe('ECKey', function() { describe('ECKey', function() {
describe('constructor', function() { describe('constructor', function() {
@ -83,7 +83,7 @@ describe('ECKey', function() {
return ECPubKey(x).toHex(false) return ECPubKey(x).toHex(false)
}) })
it('mainnet', function() { it('bitcoin', function() {
var addresses = [ var addresses = [
'19SgmoUj4xowEjwtXvNAtYTAgbvR9iBCui', '19SgmoUj4xowEjwtXvNAtYTAgbvR9iBCui',
'1MsHWS1BnwMc3tLE8G35UXsS58fKipzB7a', '1MsHWS1BnwMc3tLE8G35UXsS58fKipzB7a',

8
test/hdwallet.js

@ -2,8 +2,8 @@ var HDWallet = require('../src/hdwallet.js')
var assert = require('assert') var assert = require('assert')
var convert = require('../src/convert.js') var convert = require('../src/convert.js')
var Network = require('../src/network') var Network = require('../src/network')
var mainnet = Network.mainnet.addressVersion var bitcoin = Network.bitcoin.pubKeyHash
var testnet = Network.testnet.addressVersion var testnet = Network.testnet.pubKeyHash
var b2h = convert.bytesToHex var b2h = convert.bytesToHex
@ -241,8 +241,8 @@ describe('HDWallet', function() {
}) })
describe('network types', function() { describe('network types', function() {
it('ensures that a mainnet Wallet generates mainnet addresses', function() { it('ensures that a bitcoin Wallet generates bitcoin addresses', function() {
var wallet = new HDWallet('foobar', 'mainnet') var wallet = new HDWallet('foobar', 'bitcoin')
assert.equal(wallet.getAddress().toString(), '1JNymexJHEr5u1BndiChMStFkCgPm4EQ6o') assert.equal(wallet.getAddress().toString(), '1JNymexJHEr5u1BndiChMStFkCgPm4EQ6o')
}) })

2
test/message.js

@ -2,7 +2,7 @@ var assert = require('assert')
var convert = require('../').convert var convert = require('../').convert
var ECKey = require('../src/eckey').ECKey var ECKey = require('../src/eckey').ECKey
var Message = require('../').Message var Message = require('../').Message
var testnet = require('../').network.testnet.addressVersion var testnet = require('../').network.testnet.pubKeyHash
describe('Message', function() { describe('Message', function() {
var msg var msg

4
test/script.js

@ -109,7 +109,7 @@ describe('Script', function() {
'02fab2dea1458990793f56f42e4a47dbf35a12a351f26fa5d7e0cc7447eaafa21f', '02fab2dea1458990793f56f42e4a47dbf35a12a351f26fa5d7e0cc7447eaafa21f',
'036c6802ce7e8113723dd92cdb852e492ebb157a871ca532c3cb9ed08248ff0e19'] '036c6802ce7e8113723dd92cdb852e492ebb157a871ca532c3cb9ed08248ff0e19']
numSigs = 2 numSigs = 2
network = Network.mainnet.p2shVersion network = Network.bitcoin.scriptHash
}) })
it('should create valid multi-sig address', function() { it('should create valid multi-sig address', function() {
@ -118,7 +118,7 @@ describe('Script', function() {
var multiSigAddress = Address(multisig, network).toString() var multiSigAddress = Address(multisig, network).toString()
assert.ok(Address.validate(multiSigAddress)) assert.ok(Address.validate(multiSigAddress))
assert.equal(Address.getVersion(multiSigAddress), Network.mainnet.p2shVersion) assert.equal(Address.getVersion(multiSigAddress), Network.bitcoin.scriptHash)
assert.equal(multiSigAddress,'32vYjxBb7pHJJyXgNk8UoK3BdRDxBzny2v') assert.equal(multiSigAddress,'32vYjxBb7pHJJyXgNk8UoK3BdRDxBzny2v')
}) })

4
test/wallet.js

@ -25,8 +25,8 @@ describe('Wallet', function() {
assert.ok(Wallet(seed) instanceof Wallet) assert.ok(Wallet(seed) instanceof Wallet)
}) })
it('defaults to Bitcoin mainnet', function() { it('defaults to Bitcoin network', function() {
assert.equal(wallet.getMasterKey().network, 'mainnet') assert.equal(wallet.getMasterKey().network, 'bitcoin')
}) })
it("generates m/0' as the main account", function() { it("generates m/0' as the main account", function() {

Loading…
Cancel
Save