PHP WebShell

Текущая директория: /opt/BitGoJS/modules/utxo-bin/node_modules/bitcoinjs-lib/src/payments

Просмотр файла: p2tr_ns.js

'use strict';
Object.defineProperty(exports, '__esModule', { value: true });
exports.p2tr_ns = void 0;
const networks_1 = require('../networks');
const bscript = require('../script');
const lazy = require('./lazy');
const OPS = bscript.OPS;
const typef = require('typeforce');
function stacksEqual(a, b) {
  if (a.length !== b.length) return false;
  return a.every((x, i) => {
    return x.equals(b[i]);
  });
}
// input: [signatures ...]
// output: [pubKeys[0:n-1] OP_CHECKSIGVERIFY] pubKeys[n-1] OP_CHECKSIG
function p2tr_ns(a, opts) {
  if (
    !a.input &&
    !a.output &&
    !(a.pubkeys && a.pubkeys.length) &&
    !a.signatures
  )
    throw new TypeError('Not enough data');
  opts = Object.assign({ validate: true }, opts || {});
  if (!opts.eccLib) throw new Error('ECC Library is required for p2tr_ns.');
  const ecc = opts.eccLib;
  function isAcceptableSignature(x) {
    if (Buffer.isBuffer(x))
      return (
        // empty signatures may be represented as empty buffers
        (opts && opts.allowIncomplete && x.length === 0) ||
        bscript.isCanonicalSchnorrSignature(x)
      );
    return !!(opts && opts.allowIncomplete && x === OPS.OP_0);
  }
  typef(
    {
      network: typef.maybe(typef.Object),
      output: typef.maybe(typef.Buffer),
      pubkeys: typef.maybe(typef.arrayOf(ecc.isXOnlyPoint)),
      signatures: typef.maybe(typef.arrayOf(isAcceptableSignature)),
      input: typef.maybe(typef.Buffer),
    },
    a,
  );
  const network = a.network || networks_1.bitcoin;
  const o = { network };
  const _chunks = lazy.value(() => {
    if (!a.output) return;
    return bscript.decompile(a.output);
  });
  lazy.prop(o, 'output', () => {
    if (!a.pubkeys) return;
    return bscript.compile(
      [].concat(
        ...a.pubkeys.map((pk, i, pks) => [
          pk,
          i === pks.length - 1 ? OPS.OP_CHECKSIG : OPS.OP_CHECKSIGVERIFY,
        ]),
      ),
    );
  });
  lazy.prop(o, 'n', () => {
    if (!o.pubkeys) return;
    return o.pubkeys.length;
  });
  lazy.prop(o, 'pubkeys', () => {
    const chunks = _chunks();
    if (!chunks) return;
    return chunks.filter((_, index) => index % 2 === 0);
  });
  lazy.prop(o, 'signatures', () => {
    if (!a.input) return;
    return bscript.decompile(a.input).reverse();
  });
  lazy.prop(o, 'input', () => {
    if (!a.signatures) return;
    return bscript.compile([...a.signatures].reverse());
  });
  lazy.prop(o, 'witness', () => {
    if (!o.input) return;
    return [];
  });
  lazy.prop(o, 'name', () => {
    if (!o.n) return;
    return `p2tr_ns(${o.n})`;
  });
  // extended validation
  if (opts.validate) {
    const chunks = _chunks();
    if (chunks) {
      if (chunks[chunks.length - 1] !== OPS.OP_CHECKSIG)
        throw new TypeError('Output ends with unexpected opcode');
      if (
        chunks
          .filter((_, index) => index % 2 === 1)
          .slice(0, -1)
          .some(op => op !== OPS.OP_CHECKSIGVERIFY)
      )
        throw new TypeError('Output contains unexpected opcode');
      if (o.n > 16 || o.n !== chunks.length / 2)
        throw new TypeError('Output contains too many pubkeys');
      if (o.pubkeys.some(x => !ecc.isXOnlyPoint(x)))
        throw new TypeError('Output contains invalid pubkey(s)');
      if (a.pubkeys && !stacksEqual(a.pubkeys, o.pubkeys))
        throw new TypeError('Pubkeys mismatch');
    }
    if (a.pubkeys && a.pubkeys.length) {
      o.n = a.pubkeys.length;
    }
    if (a.signatures) {
      if (a.signatures.length < o.n)
        throw new TypeError('Not enough signatures provided');
      if (a.signatures.length > o.n)
        throw new TypeError('Too many signatures provided');
    }
    if (a.input) {
      if (!o.signatures.every(isAcceptableSignature))
        throw new TypeError('Input has invalid signature(s)');
      if (a.signatures && !stacksEqual(a.signatures, o.signatures))
        throw new TypeError('Signature mismatch');
      if (o.n !== o.signatures.length)
        throw new TypeError(
          `Signature count mismatch (n: ${o.n}, signatures.length: ${
            o.signatures.length
          }`,
        );
    }
  }
  return Object.assign(o, a);
}
exports.p2tr_ns = p2tr_ns;

Выполнить команду


Для локальной разработки. Не используйте в интернете!