address: throw Invalid address instead of hash/version for fromBase58Check
This commit is contained in:
parent
20a17cc915
commit
1a4000cc98
3 changed files with 13 additions and 10 deletions
|
@ -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')
|
||||
}
|
||||
|
|
|
@ -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)/)
|
||||
})
|
||||
})
|
||||
})
|
||||
|
|
4
test/fixtures/address.json
vendored
4
test/fixtures/address.json
vendored
|
@ -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": [
|
||||
|
|
Loading…
Reference in a new issue