address: throw Invalid address instead of hash/version for fromBase58Check

This commit is contained in:
Daniel Cousens 2015-07-21 12:29:35 +10:00
parent 20a17cc915
commit 1a4000cc98
3 changed files with 13 additions and 10 deletions

View file

@ -14,12 +14,11 @@ function findScriptTypeByVersion (version) {
function fromBase58Check (string) {
var payload = base58check.decode(string)
if (payload.length !== 21) throw new TypeError('Invalid address length')
var version = payload.readUInt8(0)
var hash = payload.slice(1)
if (hash.length !== 20) throw new TypeError('Invalid hash length')
if (version & ~0xff) throw new TypeError('Invalid version byte')
return { hash: hash, version: version }
}
@ -46,11 +45,15 @@ function toBase58Check (hash, version) {
}
function toOutputScript (address) {
var decode = fromBase58Check(address)
var scriptType = findScriptTypeByVersion(decode.version)
var payload = base58check.decode(address)
if (payload.length !== 21) throw new TypeError('Invalid hash length')
if (scriptType === 'pubkeyhash') return scripts.pubKeyHashOutput(decode.hash)
if (scriptType === 'scripthash') return scripts.scriptHashOutput(decode.hash)
var version = payload.readUInt8(0)
var hash = payload.slice(1)
var scriptType = findScriptTypeByVersion(version)
if (scriptType === 'pubkeyhash') return scripts.pubKeyHashOutput(hash)
if (scriptType === 'scripthash') return scripts.scriptHashOutput(hash)
throw new Error(address + ' has no matching Script')
}

View file

@ -89,7 +89,7 @@ describe('Bitcoin-core', function () {
var address = Address.fromBase58Check(string)
assert.notEqual(allowedNetworks.indexOf(address.version), -1, 'Invalid network')
}, /Invalid (checksum|hash length|network)/)
}, /Invalid (checksum|address length|network)/)
})
})
})

View file

@ -34,12 +34,12 @@
{
"description": "hash too short",
"base58check": "7SeEnXWPaCCALbVrTnszCVGfRU8cGfx",
"exception": "Invalid hash length"
"exception": "Invalid address length"
},
{
"description": "hash too long",
"base58check": "j9ywUkWg2fTQrouxxh5rSZhRvrjMkEUfuiKe",
"exception": "Invalid hash length"
"exception": "Invalid address length"
}
],
"fromOutputScript": [