Browse Source

script: use ecc.isPoint for canonical public keys

addLowRGrinding
Daniel Cousens 7 years ago
parent
commit
726e4c53b6
  1. 14
      src/script.js

14
src/script.js

@ -1,5 +1,6 @@
var Buffer = require('safe-buffer').Buffer var Buffer = require('safe-buffer').Buffer
var bip66 = require('bip66') var bip66 = require('bip66')
let ecc = require('tiny-secp256k1')
var pushdata = require('pushdata-bitcoin') var pushdata = require('pushdata-bitcoin')
var typeforce = require('typeforce') var typeforce = require('typeforce')
var types = require('./types') var types = require('./types')
@ -170,18 +171,7 @@ function toStack (chunks) {
} }
function isCanonicalPubKey (buffer) { function isCanonicalPubKey (buffer) {
if (!Buffer.isBuffer(buffer)) return false return ecc.isPoint(buffer)
if (buffer.length < 33) return false
switch (buffer[0]) {
case 0x02:
case 0x03:
return buffer.length === 33
case 0x04:
return buffer.length === 65
}
return false
} }
function isDefinedHashType (hashType) { function isDefinedHashType (hashType) {

Loading…
Cancel
Save