2017-01-03 22:45:54 +11:00
|
|
|
// OP_RETURN {aa21a9ed} {commitment}
|
2016-12-13 11:03:07 +00:00
|
|
|
|
2018-12-28 15:09:51 +09:00
|
|
|
import * as bscript from '../../script'
|
|
|
|
import * as types from '../../types'
|
2018-06-25 16:25:12 +10:00
|
|
|
const Buffer = require('safe-buffer').Buffer
|
|
|
|
const typeforce = require('typeforce')
|
|
|
|
const OPS = require('bitcoin-ops')
|
2016-12-13 11:03:07 +00:00
|
|
|
|
2018-12-28 15:09:51 +09:00
|
|
|
const HEADER: Buffer = Buffer.from('aa21a9ed', 'hex')
|
2017-01-03 22:45:54 +11:00
|
|
|
|
2018-12-28 15:09:51 +09:00
|
|
|
export function check (script: Buffer | Array<number | Buffer>): boolean {
|
2018-06-25 16:37:45 +10:00
|
|
|
const buffer = bscript.compile(script)
|
2016-12-13 11:03:07 +00:00
|
|
|
|
|
|
|
return buffer.length > 37 &&
|
|
|
|
buffer[0] === OPS.OP_RETURN &&
|
|
|
|
buffer[1] === 0x24 &&
|
2017-01-03 22:45:54 +11:00
|
|
|
buffer.slice(2, 6).equals(HEADER)
|
2016-12-13 11:03:07 +00:00
|
|
|
}
|
|
|
|
|
|
|
|
check.toJSON = function () { return 'Witness commitment output' }
|
|
|
|
|
2018-12-28 15:09:51 +09:00
|
|
|
export function encode (commitment: Buffer): Buffer {
|
2016-12-13 11:03:07 +00:00
|
|
|
typeforce(types.Hash256bit, commitment)
|
|
|
|
|
2018-06-25 16:37:45 +10:00
|
|
|
const buffer = Buffer.allocUnsafe(36)
|
2017-04-19 17:24:58 +10:00
|
|
|
HEADER.copy(buffer, 0)
|
|
|
|
commitment.copy(buffer, 4)
|
|
|
|
|
|
|
|
return bscript.compile([OPS.OP_RETURN, buffer])
|
2016-12-13 11:03:07 +00:00
|
|
|
}
|
|
|
|
|
2018-12-28 15:09:51 +09:00
|
|
|
export function decode (buffer: Buffer): Buffer {
|
2016-12-13 11:03:07 +00:00
|
|
|
typeforce(check, buffer)
|
|
|
|
|
2018-12-29 01:55:07 +09:00
|
|
|
return (<Buffer>(<Array<number | Buffer>>bscript.decompile(buffer))[1]).slice(4, 36)
|
2016-12-13 11:03:07 +00:00
|
|
|
}
|