networks: remove estimateFee entirely
This commit is contained in:
parent
7d2e1cd3ba
commit
bd464d7cb5
3 changed files with 41 additions and 193 deletions
|
@ -1,7 +1,7 @@
|
||||||
// https://en.bitcoin.it/wiki/List_of_address_prefixes
|
// https://en.bitcoin.it/wiki/List_of_address_prefixes
|
||||||
// Dogecoin BIP32 is a proposed standard: https://bitcointalk.org/index.php?topic=409731
|
// Dogecoin BIP32 is a proposed standard: https://bitcointalk.org/index.php?topic=409731
|
||||||
|
|
||||||
var networks = {
|
module.exports = {
|
||||||
bitcoin: {
|
bitcoin: {
|
||||||
magic: 0xd9b4bef9,
|
magic: 0xd9b4bef9,
|
||||||
messagePrefix: '\x18Bitcoin Signed Message:\n',
|
messagePrefix: '\x18Bitcoin Signed Message:\n',
|
||||||
|
@ -12,8 +12,7 @@ var networks = {
|
||||||
pubKeyHash: 0x00,
|
pubKeyHash: 0x00,
|
||||||
scriptHash: 0x05,
|
scriptHash: 0x05,
|
||||||
wif: 0x80,
|
wif: 0x80,
|
||||||
dustThreshold: 546, // https://github.com/bitcoin/bitcoin/blob/v0.9.2/src/core.h#L151-L162
|
dustThreshold: 546 // https://github.com/bitcoin/bitcoin/blob/v0.9.2/src/core.h#L151-L162
|
||||||
feePerKb: 10000 // https://github.com/bitcoin/bitcoin/blob/v0.9.2/src/main.cpp#L53
|
|
||||||
},
|
},
|
||||||
testnet: {
|
testnet: {
|
||||||
magic: 0xd9b4bef9,
|
magic: 0xd9b4bef9,
|
||||||
|
@ -25,8 +24,7 @@ var networks = {
|
||||||
pubKeyHash: 0x6f,
|
pubKeyHash: 0x6f,
|
||||||
scriptHash: 0xc4,
|
scriptHash: 0xc4,
|
||||||
wif: 0xef,
|
wif: 0xef,
|
||||||
dustThreshold: 546,
|
dustThreshold: 546
|
||||||
feePerKb: 10000
|
|
||||||
},
|
},
|
||||||
litecoin: {
|
litecoin: {
|
||||||
magic: 0xd9b4bef9,
|
magic: 0xd9b4bef9,
|
||||||
|
@ -38,9 +36,7 @@ var networks = {
|
||||||
pubKeyHash: 0x30,
|
pubKeyHash: 0x30,
|
||||||
scriptHash: 0x05,
|
scriptHash: 0x05,
|
||||||
wif: 0xb0,
|
wif: 0xb0,
|
||||||
dustThreshold: 0, // https://github.com/litecoin-project/litecoin/blob/v0.8.7.2/src/main.cpp#L360-L365
|
dustThreshold: 0 // https://github.com/litecoin-project/litecoin/blob/v0.8.7.2/src/main.cpp#L360-L365
|
||||||
dustSoftThreshold: 100000, // https://github.com/litecoin-project/litecoin/blob/v0.8.7.2/src/main.h#L53
|
|
||||||
feePerKb: 100000 // https://github.com/litecoin-project/litecoin/blob/v0.8.7.2/src/main.cpp#L56
|
|
||||||
},
|
},
|
||||||
dogecoin: {
|
dogecoin: {
|
||||||
messagePrefix: '\x19Dogecoin Signed Message:\n',
|
messagePrefix: '\x19Dogecoin Signed Message:\n',
|
||||||
|
@ -51,37 +47,6 @@ var networks = {
|
||||||
pubKeyHash: 0x1e,
|
pubKeyHash: 0x1e,
|
||||||
scriptHash: 0x16,
|
scriptHash: 0x16,
|
||||||
wif: 0x9e,
|
wif: 0x9e,
|
||||||
dustThreshold: 0, // https://github.com/dogecoin/dogecoin/blob/v1.7.1/src/core.h#L155-L160
|
dustThreshold: 0 // https://github.com/dogecoin/dogecoin/blob/v1.7.1/src/core.h#L155-L160
|
||||||
dustSoftThreshold: 100000000, // https://github.com/dogecoin/dogecoin/blob/v1.7.1/src/main.h#L62
|
|
||||||
feePerKb: 100000000 // https://github.com/dogecoin/dogecoin/blob/v1.7.1/src/main.cpp#L58
|
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
function estimateFee (tx, network) {
|
|
||||||
var baseFee = network.feePerKb
|
|
||||||
var byteSize = tx.byteLength()
|
|
||||||
|
|
||||||
var fee = baseFee * Math.ceil(byteSize / 1000)
|
|
||||||
if (network.dustSoftThreshold === undefined) return fee
|
|
||||||
|
|
||||||
tx.outs.forEach(function (output) {
|
|
||||||
if (output.value < network.dustSoftThreshold) {
|
|
||||||
fee += baseFee
|
|
||||||
}
|
|
||||||
})
|
|
||||||
|
|
||||||
return fee
|
|
||||||
}
|
|
||||||
|
|
||||||
// FIXME: 1.5.3 compatibility patch(s)
|
|
||||||
function patchEstimateFee (network, tx) {
|
|
||||||
return estimateFee(tx, network)
|
|
||||||
}
|
|
||||||
|
|
||||||
for (var networkName in networks) {
|
|
||||||
var network = networks[networkName]
|
|
||||||
|
|
||||||
network.estimateFee = patchEstimateFee.bind(null, network)
|
|
||||||
}
|
|
||||||
|
|
||||||
module.exports = networks
|
|
||||||
|
|
144
test/fixtures/network.json
vendored
144
test/fixtures/network.json
vendored
|
@ -1,116 +1,30 @@
|
||||||
{
|
[
|
||||||
"valid": {
|
{
|
||||||
"constants": [
|
"network": "bitcoin",
|
||||||
{
|
"bip32": {
|
||||||
"network": "bitcoin",
|
"private": "xprv9s21ZrQH143K3QTDL4LXw2F7HEK3wJUD2nW2nRk4stbPy6cq3jPPqjiChkVvvNKmPGJxWUtg6LnF5kejMRNNU3TGtRBeJgk33yuGBxrMPHi",
|
||||||
"bip32": {
|
"public": "xpub661MyMwAqRbcFtXgS5sYJABqqG9YLmC4Q1Rdap9gSE8NqtwybGhePY2gZ29ESFjqJoCu1Rupje8YtGqsefD265TMg7usUDFdp6W1EGMcet8"
|
||||||
"private": "xprv9s21ZrQH143K3QTDL4LXw2F7HEK3wJUD2nW2nRk4stbPy6cq3jPPqjiChkVvvNKmPGJxWUtg6LnF5kejMRNNU3TGtRBeJgk33yuGBxrMPHi",
|
}
|
||||||
"public": "xpub661MyMwAqRbcFtXgS5sYJABqqG9YLmC4Q1Rdap9gSE8NqtwybGhePY2gZ29ESFjqJoCu1Rupje8YtGqsefD265TMg7usUDFdp6W1EGMcet8"
|
},
|
||||||
}
|
{
|
||||||
},
|
"network": "testnet",
|
||||||
{
|
"bip32": {
|
||||||
"network": "testnet",
|
"private": "tprv8ZgxMBicQKsPeDgjzdC36fs6bMjGApWDNLR9erAXMs5skhMv36j9MV5ecvfavji5khqjWaWSFhN3YcCUUdiKH6isR4Pwy3U5y5egddBr16m",
|
||||||
"bip32": {
|
"public": "tpubD6NzVbkrYhZ4XgiXtGrdW5XDAPFCL9h7we1vwNCpn8tGbBcgfVYjXyhWo4E1xkh56hjod1RhGjxbaTLV3X4FyWuejifB9jusQ46QzG87VKp"
|
||||||
"private": "tprv8ZgxMBicQKsPeDgjzdC36fs6bMjGApWDNLR9erAXMs5skhMv36j9MV5ecvfavji5khqjWaWSFhN3YcCUUdiKH6isR4Pwy3U5y5egddBr16m",
|
}
|
||||||
"public": "tpubD6NzVbkrYhZ4XgiXtGrdW5XDAPFCL9h7we1vwNCpn8tGbBcgfVYjXyhWo4E1xkh56hjod1RhGjxbaTLV3X4FyWuejifB9jusQ46QzG87VKp"
|
},
|
||||||
}
|
{
|
||||||
},
|
"network": "litecoin",
|
||||||
{
|
"bip32": {
|
||||||
"network": "litecoin",
|
"private": "Ltpv71G8qDifUiNetP6nmxPA5STrUVmv2J9YSmXajv8VsYBUyuPhvN9xCaQrfX2wo5xxJNtEazYCFRUu5FmokYMM79pcqz8pcdo4rNXAFPgyB4k",
|
||||||
"bip32": {
|
"public": "Ltub2SSUS19CirucWFod2ZsYA2J4v4U76YiCXHdcQttnoiy5aGanFHCPDBX7utfG6f95u1cUbZJNafmvzNCzZZJTw1EmyFoL8u1gJbGM8ipu491"
|
||||||
"private": "Ltpv71G8qDifUiNetP6nmxPA5STrUVmv2J9YSmXajv8VsYBUyuPhvN9xCaQrfX2wo5xxJNtEazYCFRUu5FmokYMM79pcqz8pcdo4rNXAFPgyB4k",
|
}
|
||||||
"public": "Ltub2SSUS19CirucWFod2ZsYA2J4v4U76YiCXHdcQttnoiy5aGanFHCPDBX7utfG6f95u1cUbZJNafmvzNCzZZJTw1EmyFoL8u1gJbGM8ipu491"
|
},
|
||||||
}
|
{
|
||||||
},
|
"network": "dogecoin",
|
||||||
{
|
"bip32": {
|
||||||
"network": "dogecoin",
|
"private": "dgpv51eADS3spNJh9Gjth94XcPwAczvQaDJs9rqx11kvxKs6r3Ek8AgERHhjLs6mzXQFHRzQqGwqdeoDkZmr8jQMBfi43b7sT3sx3cCSk5fGeUR",
|
||||||
"bip32": {
|
"public": "dgub8kXBZ7ymNWy2S8Q3jNgVjFUm5ZJ3QLLaSTdAA89ukSv7Q6MSXwE14b7Nv6eDpE9JJXinTKc8LeLVu19uDPrm5uJuhpKNzV2kAgncwo6bNpP"
|
||||||
"private": "dgpv51eADS3spNJh9Gjth94XcPwAczvQaDJs9rqx11kvxKs6r3Ek8AgERHhjLs6mzXQFHRzQqGwqdeoDkZmr8jQMBfi43b7sT3sx3cCSk5fGeUR",
|
}
|
||||||
"public": "dgub8kXBZ7ymNWy2S8Q3jNgVjFUm5ZJ3QLLaSTdAA89ukSv7Q6MSXwE14b7Nv6eDpE9JJXinTKc8LeLVu19uDPrm5uJuhpKNzV2kAgncwo6bNpP"
|
|
||||||
}
|
|
||||||
}
|
|
||||||
],
|
|
||||||
"estimateFee": [
|
|
||||||
{
|
|
||||||
"description": "when txSize < 1kb",
|
|
||||||
"network": "bitcoin",
|
|
||||||
"txSize": 1,
|
|
||||||
"fee": 10000
|
|
||||||
},
|
|
||||||
{
|
|
||||||
"description": "when txSize >= 1kb",
|
|
||||||
"network": "bitcoin",
|
|
||||||
"txSize": 1000,
|
|
||||||
"fee": 10000
|
|
||||||
},
|
|
||||||
{
|
|
||||||
"description": "rounding",
|
|
||||||
"network": "bitcoin",
|
|
||||||
"txSize": 2800,
|
|
||||||
"fee": 30000
|
|
||||||
},
|
|
||||||
{
|
|
||||||
"description": "when outputs.value > DUST_SOFT_LIMIT, feePerKb is used",
|
|
||||||
"network": "dogecoin",
|
|
||||||
"txSize": 1000,
|
|
||||||
"outputs": [
|
|
||||||
{
|
|
||||||
"value": 100000000
|
|
||||||
}
|
|
||||||
],
|
|
||||||
"fee": 100000000
|
|
||||||
},
|
|
||||||
{
|
|
||||||
"description": "when not every outputs.value > DUST_SOFT_LIMIT",
|
|
||||||
"network": "dogecoin",
|
|
||||||
"txSize": 1000,
|
|
||||||
"outputs": [
|
|
||||||
{
|
|
||||||
"value": 99999999
|
|
||||||
},
|
|
||||||
{
|
|
||||||
"value": 99999999
|
|
||||||
}
|
|
||||||
],
|
|
||||||
"fee": 300000000
|
|
||||||
},
|
|
||||||
{
|
|
||||||
"description": "rounding",
|
|
||||||
"network": "dogecoin",
|
|
||||||
"txSize": 2800,
|
|
||||||
"fee": 300000000
|
|
||||||
},
|
|
||||||
{
|
|
||||||
"description": "when outputs.value > DUST_SOFT_LIMIT, feePerKb is used",
|
|
||||||
"network": "litecoin",
|
|
||||||
"txSize": 1000,
|
|
||||||
"outputs": [
|
|
||||||
{
|
|
||||||
"value": 100000
|
|
||||||
}
|
|
||||||
],
|
|
||||||
"fee": 100000
|
|
||||||
},
|
|
||||||
{
|
|
||||||
"description": "when not every outputs.value > DUST_SOFT_LIMIT",
|
|
||||||
"network": "litecoin",
|
|
||||||
"txSize": 1000,
|
|
||||||
"outputs": [
|
|
||||||
{
|
|
||||||
"value": 99999
|
|
||||||
},
|
|
||||||
{
|
|
||||||
"value": 99999
|
|
||||||
}
|
|
||||||
],
|
|
||||||
"fee": 300000
|
|
||||||
},
|
|
||||||
{
|
|
||||||
"description": "rounding",
|
|
||||||
"network": "litecoin",
|
|
||||||
"txSize": 2800,
|
|
||||||
"fee": 300000
|
|
||||||
}
|
|
||||||
]
|
|
||||||
}
|
}
|
||||||
}
|
]
|
||||||
|
|
|
@ -1,52 +1,21 @@
|
||||||
/* global describe, it, before, after */
|
/* global describe, it */
|
||||||
|
|
||||||
var assert = require('assert')
|
var assert = require('assert')
|
||||||
var networks = require('../src/networks')
|
var networks = require('../src/networks')
|
||||||
var sinon = require('sinon')
|
|
||||||
|
|
||||||
var HDNode = require('../src/hdnode')
|
var HDNode = require('../src/hdnode')
|
||||||
var Transaction = require('../src/transaction')
|
|
||||||
|
|
||||||
var fixtures = require('./fixtures/network')
|
var fixtures = require('./fixtures/network')
|
||||||
|
|
||||||
describe('networks', function () {
|
describe('networks', function () {
|
||||||
var txByteLength
|
fixtures.forEach(function (f) {
|
||||||
before(function () {
|
var network = networks[f.network]
|
||||||
txByteLength = sinon.stub(Transaction.prototype, 'byteLength')
|
|
||||||
})
|
|
||||||
|
|
||||||
after(function () {
|
Object.keys(f.bip32).forEach(function (name) {
|
||||||
Transaction.prototype.byteLength.restore()
|
var extb58 = f.bip32[name]
|
||||||
})
|
|
||||||
|
|
||||||
describe('constants', function () {
|
it(extb58 + ' auto-detects ' + f.network, function () {
|
||||||
fixtures.valid.constants.forEach(function (f) {
|
assert.equal(HDNode.fromBase58(extb58).network, network)
|
||||||
var network = networks[f.network]
|
|
||||||
|
|
||||||
Object.keys(f.bip32).forEach(function (name) {
|
|
||||||
var extb58 = f.bip32[name]
|
|
||||||
|
|
||||||
it('resolves ' + extb58 + ' to ' + f.network, function () {
|
|
||||||
assert.equal(HDNode.fromBase58(extb58).network, network)
|
|
||||||
})
|
|
||||||
})
|
|
||||||
})
|
|
||||||
})
|
|
||||||
|
|
||||||
describe('estimateFee', function () {
|
|
||||||
fixtures.valid.estimateFee.forEach(function (f) {
|
|
||||||
describe('(' + f.network + ')', function () {
|
|
||||||
var network = networks[f.network]
|
|
||||||
|
|
||||||
it('calculates the fee correctly for ' + f.description, function () {
|
|
||||||
txByteLength.returns(f.txSize)
|
|
||||||
|
|
||||||
var estimateFee = network.estimateFee
|
|
||||||
var tx = new Transaction()
|
|
||||||
tx.outs = f.outputs || []
|
|
||||||
|
|
||||||
assert.equal(estimateFee(tx), f.fee)
|
|
||||||
})
|
|
||||||
})
|
})
|
||||||
})
|
})
|
||||||
})
|
})
|
||||||
|
|
Loading…
Reference in a new issue