2017-09-27 00:30:31 +02:00
|
|
|
// <scriptSig> {serialized scriptPubKey script}
|
2016-12-14 05:52:38 +01:00
|
|
|
|
2018-12-28 06:55:30 +01:00
|
|
|
import * as bscript from '../../script'
|
2018-06-25 08:25:12 +02:00
|
|
|
const typeforce = require('typeforce')
|
2017-09-27 00:30:31 +02:00
|
|
|
|
2018-12-28 06:55:30 +01:00
|
|
|
import * as p2ms from '../multisig'
|
|
|
|
import * as p2pk from '../pubkey'
|
|
|
|
import * as p2pkh from '../pubkeyhash'
|
2017-09-27 00:30:31 +02:00
|
|
|
|
2018-12-28 06:55:30 +01:00
|
|
|
export function check (chunks: Array<Buffer>, allowIncomplete?: boolean): boolean {
|
|
|
|
typeforce(typeforce.Array, chunks)
|
2017-09-27 00:30:31 +02:00
|
|
|
if (chunks.length < 1) return false
|
|
|
|
|
2018-06-25 08:37:45 +02:00
|
|
|
const witnessScript = chunks[chunks.length - 1]
|
2017-09-27 00:30:31 +02:00
|
|
|
if (!Buffer.isBuffer(witnessScript)) return false
|
|
|
|
|
2018-06-25 08:37:45 +02:00
|
|
|
const witnessScriptChunks = bscript.decompile(witnessScript)
|
2017-09-27 00:30:31 +02:00
|
|
|
|
|
|
|
// is witnessScript a valid script?
|
2018-06-05 12:17:06 +02:00
|
|
|
if (!witnessScriptChunks || witnessScriptChunks.length === 0) return false
|
2017-09-27 00:30:31 +02:00
|
|
|
|
2018-06-25 08:37:45 +02:00
|
|
|
const witnessRawScriptSig = bscript.compile(chunks.slice(0, -1))
|
2017-09-27 00:30:31 +02:00
|
|
|
|
|
|
|
// match types
|
|
|
|
if (p2pkh.input.check(witnessRawScriptSig) &&
|
|
|
|
p2pkh.output.check(witnessScriptChunks)) return true
|
|
|
|
|
|
|
|
if (p2ms.input.check(witnessRawScriptSig, allowIncomplete) &&
|
|
|
|
p2ms.output.check(witnessScriptChunks)) return true
|
|
|
|
|
|
|
|
if (p2pk.input.check(witnessRawScriptSig) &&
|
|
|
|
p2pk.output.check(witnessScriptChunks)) return true
|
|
|
|
|
|
|
|
return false
|
|
|
|
}
|
|
|
|
check.toJSON = function () { return 'witnessScriptHash input' }
|