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
src
|
@ -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')
|
||||
}
|
||||
|
|
Loading…
Add table
Add a link
Reference in a new issue