diff --git a/index.js b/index.js index 447ac87..d80ec69 100644 --- a/index.js +++ b/index.js @@ -1,12 +1,5 @@ var bitcore = module.exports; -// protocol -bitcore.Constants = require('./lib/protocol/constants'); -bitcore.Base58 = require('./lib/protocol/base58'); -bitcore.Base58Check = require('./lib/protocol/base58check'); -bitcore.BufferReader = require('./lib/protocol/bufferreader'); -bitcore.BufferWriter = require('./lib/protocol/bufferwriter'); -bitcore.Varint = require('./lib/protocol/varint'); // crypto bitcore.BN = require('./lib/crypto/bn'); @@ -15,12 +8,20 @@ bitcore.Hash = require('./lib/crypto/hash'); bitcore.Random = require('./lib/crypto/random'); bitcore.Point = require('./lib/crypto/point'); +// encoding +bitcore.Base58 = require('./lib/encoding/base58'); +bitcore.Base58Check = require('./lib/encoding/base58check'); +bitcore.BufferReader = require('./lib/encoding/bufferreader'); +bitcore.BufferWriter = require('./lib/encoding/bufferwriter'); +bitcore.Varint = require('./lib/encoding/varint'); + // main bitcoin library bitcore.Address = require('./lib/address'); bitcore.BIP32 = require('./lib/bip32'); bitcore.Block = require('./lib/block'); bitcore.Blockheader = require('./lib/blockheader'); bitcore.Keypair = require('./lib/keypair'); +bitcore.networks = require('./lib/networks'); bitcore.Opcode = require('./lib/opcode'); bitcore.Privkey = require('./lib/privkey'); bitcore.Pubkey = require('./lib/pubkey'); diff --git a/lib/address.js b/lib/address.js index 43369bd..39b993d 100644 --- a/lib/address.js +++ b/lib/address.js @@ -1,7 +1,7 @@ 'use strict'; -var base58check = require('./protocol/base58check'); -var constants = require('./protocol/constants'); +var base58check = require('./encoding/base58check'); +var networks = require('./networks'); var Hash = require('./crypto/hash'); function Address(buf) { @@ -29,16 +29,16 @@ Address.prototype.fromBuffer = function(buf) { if (buf.length !== 1 + 20) throw new Error('Address buffers must be exactly 21 bytes'); var version = buf[0]; - if (version === constants['mainnet']['pubkeyhash']) { + if (version === networks['mainnet']['pubkeyhash']) { this.networkstr = 'mainnet'; this.typestr = 'pubkeyhash'; - } else if (version === constants['mainnet']['scripthash']) { + } else if (version === networks['mainnet']['scripthash']) { this.networkstr = 'mainnet'; this.typestr = 'scripthash'; - } else if (version === constants['testnet']['pubkeyhash']) { + } else if (version === networks['testnet']['pubkeyhash']) { this.networkstr = 'testnet'; this.typestr = 'pubkeyhash'; - } else if (version === constants['testnet']['scripthash']) { + } else if (version === networks['testnet']['scripthash']) { this.networkstr = 'testnet'; this.typestr = 'scripthash'; } else { @@ -98,7 +98,7 @@ Address.prototype.isValid = function() { }; Address.prototype.toBuffer = function() { - var version = new Buffer([constants[this.networkstr][this.typestr]]); + var version = new Buffer([networks[this.networkstr][this.typestr]]); var buf = Buffer.concat([version, this.hashbuf]); return buf; }; diff --git a/lib/bip32.js b/lib/bip32.js index 34bfe5c..dba2b33 100644 --- a/lib/bip32.js +++ b/lib/bip32.js @@ -1,7 +1,7 @@ 'use strict'; -var Base58Check = require('./protocol/base58check'); -var constants = require('./protocol/constants'); +var Base58Check = require('./encoding/base58check'); +var networks = require('./networks'); var Hash = require('./crypto/hash'); var Point = require('./crypto/point'); var Random = require('./crypto/random'); @@ -38,7 +38,7 @@ BIP32.prototype.set = function(obj) { BIP32.prototype.fromRandom = function(networkstr) { if (!networkstr) networkstr = 'mainnet'; - this.version = constants[networkstr].bip32privkey; + this.version = networks[networkstr].bip32privkey; this.depth = 0x00; this.parentfingerprint = new Buffer([0, 0, 0, 0]); this.childindex = new Buffer([0, 0, 0, 0]); @@ -72,7 +72,7 @@ BIP32.prototype.fromSeed = function(bytes, networkstr) { this.parentfingerprint = new Buffer([0, 0, 0, 0]); this.childindex = new Buffer([0, 0, 0, 0]); this.chaincode = hash.slice(32, 64); - this.version = constants[networkstr].bip32privkey; + this.version = networks[networkstr].bip32privkey; this.keypair = new Keypair(); this.keypair.privkey = new Privkey({bn: BN().fromBuffer(hash.slice(0, 32))}); this.keypair.privkey2pubkey(); @@ -99,12 +99,12 @@ BIP32.prototype.initFromBytes = function(bytes) { var keyBytes = bytes.slice(45, 78); var isPrivate = - (this.version == constants.mainnet.bip32privkey || - this.version == constants.testnet.bip32privkey); + (this.version == networks.mainnet.bip32privkey || + this.version == networks.testnet.bip32privkey); var isPublic = - (this.version == constants.mainnet.bip32pubkey || - this.version == constants.testnet.bip32pubkey); + (this.version == networks.mainnet.bip32pubkey || + this.version == networks.testnet.bip32pubkey); if (isPrivate && keyBytes[0] == 0) { this.keypair = new Keypair(); @@ -130,13 +130,13 @@ BIP32.prototype.buildxpubkey = function() { var v = null; switch (this.version) { - case constants.mainnet.bip32pubkey: - case constants.mainnet.bip32privkey: - v = constants.mainnet.bip32pubkey; + case networks.mainnet.bip32pubkey: + case networks.mainnet.bip32privkey: + v = networks.mainnet.bip32pubkey; break; - case constants.testnet.bip32pubkey: - case constants.testnet.bip32privkey: - v = constants.testnet.bip32pubkey; + case networks.testnet.bip32pubkey: + case networks.testnet.bip32privkey: + v = networks.testnet.bip32pubkey; break; default: throw new Error('Unknown version'); @@ -248,8 +248,8 @@ BIP32.prototype.deriveChild = function(i) { var usePrivate = (i & 0x80000000) != 0; var isPrivate = - (this.version == constants.mainnet.bip32privkey || - this.version == constants.testnet.bip32privkey); + (this.version == networks.mainnet.bip32privkey || + this.version == networks.testnet.bip32privkey); if (usePrivate && (!this.hasprivkey || !isPrivate)) throw new Error('Cannot do private key derivation without private key'); @@ -316,8 +316,8 @@ BIP32.prototype.deriveChild = function(i) { BIP32.prototype.toString = function() { var isPrivate = - (this.version == constants.mainnet.bip32privkey || - this.version == constants.testnet.bip32privkey); + (this.version == networks.mainnet.bip32privkey || + this.version == networks.testnet.bip32privkey); if (isPrivate) return this.xprivkeyString(); diff --git a/lib/block.js b/lib/block.js index bf09b00..f465fbb 100644 --- a/lib/block.js +++ b/lib/block.js @@ -1,9 +1,9 @@ 'use strict'; var Hash = require('./crypto/hash'); -var BufferReader = require('./protocol/bufferreader'); -var BufferWriter = require('./protocol/bufferwriter'); -var Varint = require('./protocol/varint'); +var BufferReader = require('./encoding/bufferreader'); +var BufferWriter = require('./encoding/bufferwriter'); +var Varint = require('./encoding/varint'); var Transaction = require('./transaction'); var Blockheader = require('./blockheader'); diff --git a/lib/blockheader.js b/lib/blockheader.js index 81d7308..3dcad36 100644 --- a/lib/blockheader.js +++ b/lib/blockheader.js @@ -1,7 +1,7 @@ 'use strict'; -var BufferReader = require('./protocol/bufferreader'); -var BufferWriter = require('./protocol/bufferwriter'); +var BufferReader = require('./encoding/bufferreader'); +var BufferWriter = require('./encoding/bufferwriter'); var Blockheader = function Blockheader(version, prevblockidbuf, merklerootbuf, time, bits, nonce) { if (!(this instanceof Blockheader)) diff --git a/lib/networks.js b/lib/networks.js index f358816..97afe9c 100644 --- a/lib/networks.js +++ b/lib/networks.js @@ -22,7 +22,4 @@ exports.testnet = { bip32privkey: 0x04358394, }; -exports.ephemeral = { - prefix: 0x0f, - identity: 0x02 -}; +exports.livenet = exports.mainnet; diff --git a/lib/privkey.js b/lib/privkey.js index a7ed870..96b5ae7 100644 --- a/lib/privkey.js +++ b/lib/privkey.js @@ -3,8 +3,8 @@ var BN = require('./crypto/bn'); var Point = require('./crypto/point'); var Random = require('./crypto/random'); -var constants = require('./protocol/constants'); -var base58check = require('./protocol/base58check'); +var networks = require('./networks'); +var base58check = require('./encoding/base58check'); var Privkey = function Privkey(bn) { if (!(this instanceof Privkey)) @@ -50,7 +50,7 @@ Privkey.prototype.fromRandom = function() { Privkey.prototype.validate = function() { if (!this.bn.lt(Point.getN())) throw new Error('Number must be less than N'); - if (typeof constants[this.networkstr] === undefined) + if (typeof networks[this.networkstr] === undefined) throw new Error('Must specify the networkstr ("mainnet" or "testnet")'); if (typeof this.compressed !== 'boolean') throw new Error('Must specify whether the corresponding public key is compressed or not (true or false)'); @@ -68,9 +68,9 @@ Privkey.prototype.toWIF = function() { var privbuf = this.bn.toBuffer({size: 32}); var buf; if (compressed) - buf = Buffer.concat([new Buffer([constants[networkstr].privkey]), this.bn.toBuffer({size: 32}), new Buffer([0x01])]); + buf = Buffer.concat([new Buffer([networks[networkstr].privkey]), this.bn.toBuffer({size: 32}), new Buffer([0x01])]); else - buf = Buffer.concat([new Buffer([constants[networkstr].privkey]), this.bn.toBuffer({size: 32})]); + buf = Buffer.concat([new Buffer([networks[networkstr].privkey]), this.bn.toBuffer({size: 32})]); return base58check.encode(buf); }; @@ -85,9 +85,9 @@ Privkey.prototype.fromWIF = function(str) { else throw new Error('Length of buffer must be 33 (uncompressed) or 34 (compressed)'); - if (buf[0] === constants.mainnet.privkey) + if (buf[0] === networks.mainnet.privkey) this.networkstr = 'mainnet'; - else if (buf[0] === constants.testnet.privkey) + else if (buf[0] === networks.testnet.privkey) this.networkstr = 'testnet'; else throw new Error('Invalid networkstr'); diff --git a/lib/script.js b/lib/script.js index 377c41a..95a6ac4 100644 --- a/lib/script.js +++ b/lib/script.js @@ -1,7 +1,7 @@ 'use strict'; -var BufferReader = require('./protocol/bufferreader'); -var BufferWriter = require('./protocol/bufferwriter'); +var BufferReader = require('./encoding/bufferreader'); +var BufferWriter = require('./encoding/bufferwriter'); var Opcode = require('./opcode'); var Script = function Script(buf) { diff --git a/lib/transaction.js b/lib/transaction.js index 4959b8f..21b40d2 100644 --- a/lib/transaction.js +++ b/lib/transaction.js @@ -1,8 +1,8 @@ 'use strict'; -var BufferWriter = require('./protocol/bufferwriter'); -var BufferReader = require('./protocol/bufferreader'); -var Varint = require('./protocol/varint'); +var BufferWriter = require('./encoding/bufferwriter'); +var BufferReader = require('./encoding/bufferreader'); +var Varint = require('./encoding/varint'); var Hash = require('./crypto/hash'); var Txin = require('./txin'); var Txout = require('./txout'); diff --git a/lib/txin.js b/lib/txin.js index 0b70857..75d2a05 100644 --- a/lib/txin.js +++ b/lib/txin.js @@ -1,8 +1,8 @@ 'use strict'; -var BufferReader = require('./protocol/bufferreader'); -var BufferWriter = require('./protocol/bufferwriter'); -var Varint = require('./protocol/varint'); +var BufferReader = require('./encoding/bufferreader'); +var BufferWriter = require('./encoding/bufferwriter'); +var Varint = require('./encoding/varint'); var Script = require('./script'); var Txin = function Txin(txidbuf, txoutnum, scriptvi, script, seqnum) { diff --git a/lib/txout.js b/lib/txout.js index 05a825d..22a688d 100644 --- a/lib/txout.js +++ b/lib/txout.js @@ -1,9 +1,9 @@ 'use strict'; var BN = require('./crypto/bn'); -var BufferReader = require('./protocol/bufferreader'); -var BufferWriter = require('./protocol/bufferwriter'); -var Varint = require('./protocol/varint'); +var BufferReader = require('./encoding/bufferreader'); +var BufferWriter = require('./encoding/bufferwriter'); +var Varint = require('./encoding/varint'); var Script = require('./script'); var Txout = function Txout(valuebn, scriptvi, script) { diff --git a/test/networks.js b/test/networks.js index e5604d5..bbacbee 100644 --- a/test/networks.js +++ b/test/networks.js @@ -1,18 +1,24 @@ 'use strict'; var should = require('chai').should(); -var bitcore = require('../../'); -var constants = bitcore.Constants; +var bitcore = require('..'); +var networks = bitcore.networks; -describe('Constants', function() { +describe('networks', function() { - it('should contain all constants for livenet and testnet', function() { - for (var key in constants.livenet) { - if (constants.livenet.hasOwnProperty(key)) { - constants.testnet.hasOwnProperty(key).should.equal(true); + it('should contain all networks', function() { + should.exist(networks.livenet); + should.exist(networks.testnet); + should.exist(networks.mainnet); + }); + describe('contain all constants for livenet and testnet', function() { + for (var key in networks.livenet) { + if (networks.livenet.hasOwnProperty(key)) { + it('all should contain '+key, function() { + networks.testnet.hasOwnProperty(key).should.equal(true); + }); } } - }); });