adhere to standard 5.0.0
This commit is contained in:
parent
e97389ed08
commit
56160622ca
3 changed files with 13 additions and 24 deletions
|
@ -64,6 +64,6 @@
|
||||||
"mocha": "^2.2.0",
|
"mocha": "^2.2.0",
|
||||||
"proxyquire": "^1.4.0",
|
"proxyquire": "^1.4.0",
|
||||||
"sinon": "^1.12.2",
|
"sinon": "^1.12.2",
|
||||||
"standard": "^4.0.0"
|
"standard": "^5.0.0"
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
|
@ -74,7 +74,7 @@ HDNode.fromBase58 = function (string, networks) {
|
||||||
}
|
}
|
||||||
|
|
||||||
if (version !== network.bip32.private &&
|
if (version !== network.bip32.private &&
|
||||||
version !== network.bip32.public) throw new Error('Invalid network')
|
version !== network.bip32.public) throw new Error('Invalid network')
|
||||||
|
|
||||||
// 1 byte: depth: 0x00 for master nodes, 0x01 for level-1 descendants, ...
|
// 1 byte: depth: 0x00 for master nodes, 0x01 for level-1 descendants, ...
|
||||||
var depth = buffer.readUInt8(4)
|
var depth = buffer.readUInt8(4)
|
||||||
|
|
|
@ -33,7 +33,7 @@ function extractInput (txIn) {
|
||||||
var hashType, parsed, pubKeys, signatures
|
var hashType, parsed, pubKeys, signatures
|
||||||
|
|
||||||
switch (scriptType) {
|
switch (scriptType) {
|
||||||
case 'pubkeyhash': {
|
case 'pubkeyhash':
|
||||||
parsed = ECSignature.parseScriptSignature(scriptSig.chunks[0])
|
parsed = ECSignature.parseScriptSignature(scriptSig.chunks[0])
|
||||||
hashType = parsed.hashType
|
hashType = parsed.hashType
|
||||||
pubKeys = scriptSig.chunks.slice(1)
|
pubKeys = scriptSig.chunks.slice(1)
|
||||||
|
@ -41,9 +41,8 @@ function extractInput (txIn) {
|
||||||
prevOutScript = scripts.pubKeyHashOutput(bcrypto.hash160(pubKeys[0]))
|
prevOutScript = scripts.pubKeyHashOutput(bcrypto.hash160(pubKeys[0]))
|
||||||
|
|
||||||
break
|
break
|
||||||
}
|
|
||||||
|
|
||||||
case 'pubkey': {
|
case 'pubkey':
|
||||||
parsed = ECSignature.parseScriptSignature(scriptSig.chunks[0])
|
parsed = ECSignature.parseScriptSignature(scriptSig.chunks[0])
|
||||||
hashType = parsed.hashType
|
hashType = parsed.hashType
|
||||||
signatures = [parsed.signature]
|
signatures = [parsed.signature]
|
||||||
|
@ -53,9 +52,8 @@ function extractInput (txIn) {
|
||||||
}
|
}
|
||||||
|
|
||||||
break
|
break
|
||||||
}
|
|
||||||
|
|
||||||
case 'multisig': {
|
case 'multisig':
|
||||||
signatures = scriptSig.chunks.slice(1).map(function (chunk) {
|
signatures = scriptSig.chunks.slice(1).map(function (chunk) {
|
||||||
if (chunk === ops.OP_0) return chunk
|
if (chunk === ops.OP_0) return chunk
|
||||||
|
|
||||||
|
@ -70,7 +68,6 @@ function extractInput (txIn) {
|
||||||
}
|
}
|
||||||
|
|
||||||
break
|
break
|
||||||
}
|
|
||||||
}
|
}
|
||||||
|
|
||||||
return {
|
return {
|
||||||
|
@ -146,15 +143,13 @@ TransactionBuilder.prototype.addInput = function (txHash, vout, sequence, prevOu
|
||||||
|
|
||||||
// if we can, extract pubKey information
|
// if we can, extract pubKey information
|
||||||
switch (prevOutType) {
|
switch (prevOutType) {
|
||||||
case 'multisig': {
|
case 'multisig':
|
||||||
input.pubKeys = prevOutScript.chunks.slice(1, -2)
|
input.pubKeys = prevOutScript.chunks.slice(1, -2)
|
||||||
break
|
break
|
||||||
}
|
|
||||||
|
|
||||||
case 'pubkey': {
|
case 'pubkey':
|
||||||
input.pubKeys = prevOutScript.chunks.slice(0, 1)
|
input.pubKeys = prevOutScript.chunks.slice(0, 1)
|
||||||
break
|
break
|
||||||
}
|
|
||||||
}
|
}
|
||||||
|
|
||||||
if (prevOutType !== 'scripthash') {
|
if (prevOutType !== 'scripthash') {
|
||||||
|
@ -230,13 +225,12 @@ TransactionBuilder.prototype.__build = function (allowIncomplete) {
|
||||||
|
|
||||||
if (input.signatures) {
|
if (input.signatures) {
|
||||||
switch (scriptType) {
|
switch (scriptType) {
|
||||||
case 'pubkeyhash': {
|
case 'pubkeyhash':
|
||||||
var pkhSignature = input.signatures[0].toScriptSignature(input.hashType)
|
var pkhSignature = input.signatures[0].toScriptSignature(input.hashType)
|
||||||
scriptSig = scripts.pubKeyHashInput(pkhSignature, input.pubKeys[0])
|
scriptSig = scripts.pubKeyHashInput(pkhSignature, input.pubKeys[0])
|
||||||
break
|
break
|
||||||
}
|
|
||||||
|
|
||||||
case 'multisig': {
|
case 'multisig':
|
||||||
// Array.prototype.map is sparse-compatible
|
// Array.prototype.map is sparse-compatible
|
||||||
var msSignatures = input.signatures.map(function (signature) {
|
var msSignatures = input.signatures.map(function (signature) {
|
||||||
return signature && signature.toScriptSignature(input.hashType)
|
return signature && signature.toScriptSignature(input.hashType)
|
||||||
|
@ -257,13 +251,11 @@ TransactionBuilder.prototype.__build = function (allowIncomplete) {
|
||||||
var redeemScript = allowIncomplete ? undefined : input.redeemScript
|
var redeemScript = allowIncomplete ? undefined : input.redeemScript
|
||||||
scriptSig = scripts.multisigInput(msSignatures, redeemScript)
|
scriptSig = scripts.multisigInput(msSignatures, redeemScript)
|
||||||
break
|
break
|
||||||
}
|
|
||||||
|
|
||||||
case 'pubkey': {
|
case 'pubkey':
|
||||||
var pkSignature = input.signatures[0].toScriptSignature(input.hashType)
|
var pkSignature = input.signatures[0].toScriptSignature(input.hashType)
|
||||||
scriptSig = scripts.pubKeyInput(pkSignature)
|
scriptSig = scripts.pubKeyInput(pkSignature)
|
||||||
break
|
break
|
||||||
}
|
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@ -322,24 +314,21 @@ TransactionBuilder.prototype.sign = function (index, keyPair, redeemScript, hash
|
||||||
|
|
||||||
var pubKeys = []
|
var pubKeys = []
|
||||||
switch (scriptType) {
|
switch (scriptType) {
|
||||||
case 'multisig': {
|
case 'multisig':
|
||||||
pubKeys = redeemScript.chunks.slice(1, -2)
|
pubKeys = redeemScript.chunks.slice(1, -2)
|
||||||
break
|
break
|
||||||
}
|
|
||||||
|
|
||||||
case 'pubkeyhash': {
|
case 'pubkeyhash':
|
||||||
var pkh1 = redeemScript.chunks[2]
|
var pkh1 = redeemScript.chunks[2]
|
||||||
var pkh2 = bcrypto.hash160(keyPair.getPublicKeyBuffer())
|
var pkh2 = bcrypto.hash160(keyPair.getPublicKeyBuffer())
|
||||||
|
|
||||||
assert.deepEqual(pkh1, pkh2, 'privateKey cannot sign for this input')
|
assert.deepEqual(pkh1, pkh2, 'privateKey cannot sign for this input')
|
||||||
pubKeys = [kpPubKey]
|
pubKeys = [kpPubKey]
|
||||||
break
|
break
|
||||||
}
|
|
||||||
|
|
||||||
case 'pubkey': {
|
case 'pubkey':
|
||||||
pubKeys = redeemScript.chunks.slice(0, 1)
|
pubKeys = redeemScript.chunks.slice(0, 1)
|
||||||
break
|
break
|
||||||
}
|
|
||||||
}
|
}
|
||||||
|
|
||||||
if (!input.prevOutScript) {
|
if (!input.prevOutScript) {
|
||||||
|
|
Loading…
Add table
Reference in a new issue