PHP WebShell

Текущая директория: /usr/lib/node_modules/bitgo/node_modules/@bitgo/utxo-core/dist/src/testutil/descriptor

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

"use strict";
var __importDefault = (this && this.__importDefault) || function (mod) {
    return (mod && mod.__esModule) ? mod : { "default": mod };
};
Object.defineProperty(exports, "__esModule", { value: true });
exports.getDefaultXPubs = getDefaultXPubs;
exports.getUnspendableKey = getUnspendableKey;
exports.getPsbtParams = getPsbtParams;
exports.containsKey = containsKey;
exports.getTapLeafScripts = getTapLeafScripts;
exports.getDescriptor = getDescriptor;
exports.getDescriptorMap = getDescriptorMap;
const assert_1 = __importDefault(require("assert"));
const wasm_miniscript_1 = require("@bitgo/wasm-miniscript");
const utxo_lib_1 = require("@bitgo/utxo-lib");
const key_utils_1 = require("../key.utils");
function getDefaultXPubs(seed) {
    return (0, key_utils_1.getKeyTriple)(seed).map((k) => k.neutered().toBase58());
}
function getUnspendableKey() {
    /*
    https://github.com/bitcoin/bips/blob/master/bip-0341.mediawiki#constructing-and-spending-taproot-outputs
  
    ```
    If one or more of the spending conditions consist of just a single key (after aggregation), the most likely one should
    be made the internal key. If no such condition exists, it may be worthwhile adding one that consists of an aggregation
    of all keys participating in all scripts combined; effectively adding an "everyone agrees" branch. If that is
    inacceptable, pick as internal key a "Nothing Up My Sleeve" (NUMS) point, i.e., a point with unknown discrete
    logarithm.
  
    One example of such a point is H = lift_x(0x50929b74c1a04954b78b4b6035e97a5e078a5a0f28ec96d547bfee9ace803ac0) which is
    constructed by taking the hash of the standard uncompressed encoding of the secp256k1 base point G as X coordinate.
    In order to avoid leaking the information that key path spending is not possible it is recommended to pick a fresh
    integer r in the range 0...n-1 uniformly at random and use H + rG as internal key. It is possible to prove that this
    internal key does not have a known discrete logarithm with respect to G by revealing r to a verifier who can then
    reconstruct how the internal key was created.
    ```
  
    We could do the random integer trick here, but for internal testing it is sufficient to use the fixed point.
    */
    return '50929b74c1a04954b78b4b6035e97a5e078a5a0f28ec96d547bfee9ace803ac0';
}
function toDescriptorMap(v) {
    return new Map(Object.entries(v).map(([k, v]) => [k, wasm_miniscript_1.Descriptor.fromString(v, 'derivable')]));
}
function toXPub(k, path) {
    if (typeof k === 'string') {
        return k + '/' + path;
    }
    return k.neutered().toBase58() + '/' + path;
}
function toPlain(k, { xonly = false } = {}) {
    if (typeof k === 'string') {
        if (k.startsWith('xpub') || k.startsWith('xprv')) {
            return toPlain(utxo_lib_1.bip32.fromBase58(k), { xonly });
        }
        return k;
    }
    return k.publicKey.subarray(xonly ? 1 : 0).toString('hex');
}
function toXOnly(k) {
    return toPlain(k, { xonly: true });
}
function multiArgs(m, n, keys, path) {
    if (n < m) {
        throw new Error(`Cannot create ${m} of ${n} multisig`);
    }
    if (keys.length < n) {
        throw new Error(`Not enough keys for ${m} of ${n} multisig: keys.length=${keys.length}`);
    }
    keys = keys.slice(0, n);
    return [m, ...keys.map((k) => toXPub(k, path))];
}
function getPsbtParams(t) {
    switch (t) {
        case 'Wsh2Of3CltvDrop':
            return { locktime: 1 };
        default:
            return {};
    }
}
function getDescriptorNode(template, keys = getDefaultXPubs(), path = '0/*') {
    switch (template) {
        case 'Wsh2Of3':
            return {
                wsh: { multi: multiArgs(2, 3, keys, path) },
            };
        case 'Wsh2Of3CltvDrop':
            const { locktime } = getPsbtParams(template);
            (0, assert_1.default)(locktime);
            return {
                wsh: {
                    and_v: [{ 'r:after': locktime }, { multi: multiArgs(2, 3, keys, path) }],
                },
            };
        case 'Wsh2Of2':
            return {
                wsh: { multi: multiArgs(2, 2, keys, path) },
            };
        case 'Tr2Of3-NoKeyPath':
            return {
                tr: [getUnspendableKey(), { multi_a: multiArgs(2, 3, keys, path) }],
            };
        case 'Tr1Of3-NoKeyPath-Tree':
            return {
                tr: [
                    getUnspendableKey(),
                    [{ pk: toXPub(keys[0], path) }, [{ pk: toXPub(keys[1], path) }, { pk: toXPub(keys[2], path) }]],
                ],
            };
        case 'Tr1Of3-NoKeyPath-Tree-Plain':
            return {
                tr: [getUnspendableKey(), [{ pk: toXOnly(keys[0]) }, [{ pk: toXOnly(keys[1]) }, { pk: toXOnly(keys[2]) }]]],
            };
    }
    throw new Error(`Unknown descriptor template: ${template}`);
}
function getTapLeafScriptNodes(t) {
    if (Array.isArray(t)) {
        if (t.length !== 2) {
            throw new Error(`expected tuple, got: ${JSON.stringify(t)}`);
        }
        return t.map((v) => (Array.isArray(v) ? getTapLeafScriptNodes(v) : v)).flat();
    }
    if (typeof t === 'object') {
        const node = t;
        if (!('tr' in node)) {
            throw new Error(`TapLeafScripts are only supported for Taproot descriptors, got: ${t}`);
        }
        if (!Array.isArray(node.tr) || node.tr.length !== 2) {
            throw new Error(`expected tuple, got: ${JSON.stringify(node.tr)}`);
        }
        const tapscript = node.tr[1];
        if (!Array.isArray(tapscript)) {
            throw new Error(`expected tapscript to be an array, got: ${JSON.stringify(tapscript)}`);
        }
        return getTapLeafScriptNodes(tapscript);
    }
    throw new Error(`Invalid input: ${JSON.stringify(t)}`);
}
function containsKey(script, key) {
    if (script instanceof wasm_miniscript_1.Miniscript) {
        script = wasm_miniscript_1.ast.fromMiniscript(script);
    }
    if ('pk' in script) {
        return script.pk === toXOnly(key);
    }
    throw new Error(`Unsupported script type: ${JSON.stringify(script)}`);
}
function getTapLeafScripts(d) {
    return getTapLeafScriptNodes(wasm_miniscript_1.ast.fromDescriptor(d)).map((n) => wasm_miniscript_1.Miniscript.fromString(wasm_miniscript_1.ast.formatNode(n), 'tap').toString());
}
function getDescriptor(template, keys = getDefaultXPubs(), path = '0/*') {
    return wasm_miniscript_1.Descriptor.fromStringDetectType(wasm_miniscript_1.ast.formatNode(getDescriptorNode(template, keys, path)));
}
function getDescriptorMap(template, keys = getDefaultXPubs()) {
    return toDescriptorMap({
        external: getDescriptor(template, keys, '0/*').toString(),
        internal: getDescriptor(template, keys, '1/*').toString(),
    });
}
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"descriptors.js","sourceRoot":"","sources":["../../../../src/testutil/descriptor/descriptors.ts"],"names":[],"mappings":"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","sourcesContent":["import assert from 'assert';\n\nimport { Miniscript, Descriptor, ast } from '@bitgo/wasm-miniscript';\nimport { bip32, BIP32Interface } from '@bitgo/utxo-lib';\n\nimport { DescriptorMap, PsbtParams } from '../../descriptor';\nimport { getKeyTriple, Triple, KeyTriple } from '../key.utils';\n\nexport function getDefaultXPubs(seed?: string): Triple<string> {\n  return getKeyTriple(seed).map((k) => k.neutered().toBase58()) as Triple<string>;\n}\n\nexport function getUnspendableKey(): string {\n  /*\n  https://github.com/bitcoin/bips/blob/master/bip-0341.mediawiki#constructing-and-spending-taproot-outputs\n\n  ```\n  If one or more of the spending conditions consist of just a single key (after aggregation), the most likely one should\n  be made the internal key. If no such condition exists, it may be worthwhile adding one that consists of an aggregation\n  of all keys participating in all scripts combined; effectively adding an \"everyone agrees\" branch. If that is\n  inacceptable, pick as internal key a \"Nothing Up My Sleeve\" (NUMS) point, i.e., a point with unknown discrete\n  logarithm.\n\n  One example of such a point is H = lift_x(0x50929b74c1a04954b78b4b6035e97a5e078a5a0f28ec96d547bfee9ace803ac0) which is\n  constructed by taking the hash of the standard uncompressed encoding of the secp256k1 base point G as X coordinate.\n  In order to avoid leaking the information that key path spending is not possible it is recommended to pick a fresh\n  integer r in the range 0...n-1 uniformly at random and use H + rG as internal key. It is possible to prove that this\n  internal key does not have a known discrete logarithm with respect to G by revealing r to a verifier who can then\n  reconstruct how the internal key was created.\n  ```\n\n  We could do the random integer trick here, but for internal testing it is sufficient to use the fixed point.\n  */\n  return '50929b74c1a04954b78b4b6035e97a5e078a5a0f28ec96d547bfee9ace803ac0';\n}\n\nfunction toDescriptorMap(v: Record<string, string>): DescriptorMap {\n  return new Map(Object.entries(v).map(([k, v]) => [k, Descriptor.fromString(v, 'derivable')]));\n}\n\nexport type DescriptorTemplate =\n  | 'Wsh2Of3'\n  | 'Tr1Of3-NoKeyPath-Tree'\n  // no xpubs, just plain keys\n  | 'Tr1Of3-NoKeyPath-Tree-Plain'\n  | 'Tr2Of3-NoKeyPath'\n  | 'Wsh2Of2'\n  /*\n   * This is a wrapped segwit 2of3 multisig that also uses a relative locktime with\n   * an OP_DROP (requiring a miniscript extension).\n   * It is basically what is used in CoreDao staking transactions.\n   */\n  | 'Wsh2Of3CltvDrop';\n\nfunction toXPub(k: BIP32Interface | string, path: string): string {\n  if (typeof k === 'string') {\n    return k + '/' + path;\n  }\n  return k.neutered().toBase58() + '/' + path;\n}\n\nfunction toPlain(k: BIP32Interface | string, { xonly = false } = {}): string {\n  if (typeof k === 'string') {\n    if (k.startsWith('xpub') || k.startsWith('xprv')) {\n      return toPlain(bip32.fromBase58(k), { xonly });\n    }\n    return k;\n  }\n  return k.publicKey.subarray(xonly ? 1 : 0).toString('hex');\n}\n\nfunction toXOnly(k: BIP32Interface | string): string {\n  return toPlain(k, { xonly: true });\n}\n\nfunction multiArgs(m: number, n: number, keys: BIP32Interface[] | string[], path: string): [number, ...string[]] {\n  if (n < m) {\n    throw new Error(`Cannot create ${m} of ${n} multisig`);\n  }\n  if (keys.length < n) {\n    throw new Error(`Not enough keys for ${m} of ${n} multisig: keys.length=${keys.length}`);\n  }\n  keys = keys.slice(0, n);\n  return [m, ...keys.map((k) => toXPub(k, path))];\n}\n\nexport function getPsbtParams(t: DescriptorTemplate): Partial<PsbtParams> {\n  switch (t) {\n    case 'Wsh2Of3CltvDrop':\n      return { locktime: 1 };\n    default:\n      return {};\n  }\n}\n\nfunction getDescriptorNode(\n  template: DescriptorTemplate,\n  keys: KeyTriple | string[] = getDefaultXPubs(),\n  path = '0/*'\n): ast.DescriptorNode {\n  switch (template) {\n    case 'Wsh2Of3':\n      return {\n        wsh: { multi: multiArgs(2, 3, keys, path) },\n      };\n    case 'Wsh2Of3CltvDrop':\n      const { locktime } = getPsbtParams(template);\n      assert(locktime);\n      return {\n        wsh: {\n          and_v: [{ 'r:after': locktime }, { multi: multiArgs(2, 3, keys, path) }],\n        },\n      };\n    case 'Wsh2Of2':\n      return {\n        wsh: { multi: multiArgs(2, 2, keys, path) },\n      };\n    case 'Tr2Of3-NoKeyPath':\n      return {\n        tr: [getUnspendableKey(), { multi_a: multiArgs(2, 3, keys, path) }],\n      };\n    case 'Tr1Of3-NoKeyPath-Tree':\n      return {\n        tr: [\n          getUnspendableKey(),\n          [{ pk: toXPub(keys[0], path) }, [{ pk: toXPub(keys[1], path) }, { pk: toXPub(keys[2], path) }]],\n        ],\n      };\n    case 'Tr1Of3-NoKeyPath-Tree-Plain':\n      return {\n        tr: [getUnspendableKey(), [{ pk: toXOnly(keys[0]) }, [{ pk: toXOnly(keys[1]) }, { pk: toXOnly(keys[2]) }]]],\n      };\n  }\n  throw new Error(`Unknown descriptor template: ${template}`);\n}\n\ntype TapTree = [TapTree, TapTree] | ast.MiniscriptNode;\n\nfunction getTapLeafScriptNodes(t: ast.DescriptorNode | TapTree): ast.MiniscriptNode[] {\n  if (Array.isArray(t)) {\n    if (t.length !== 2) {\n      throw new Error(`expected tuple, got: ${JSON.stringify(t)}`);\n    }\n    return t.map((v) => (Array.isArray(v) ? getTapLeafScriptNodes(v) : v)).flat();\n  }\n\n  if (typeof t === 'object') {\n    const node = t;\n    if (!('tr' in node)) {\n      throw new Error(`TapLeafScripts are only supported for Taproot descriptors, got: ${t}`);\n    }\n    if (!Array.isArray(node.tr) || node.tr.length !== 2) {\n      throw new Error(`expected tuple, got: ${JSON.stringify(node.tr)}`);\n    }\n    const tapscript = node.tr[1];\n    if (!Array.isArray(tapscript)) {\n      throw new Error(`expected tapscript to be an array, got: ${JSON.stringify(tapscript)}`);\n    }\n    return getTapLeafScriptNodes(tapscript);\n  }\n\n  throw new Error(`Invalid input: ${JSON.stringify(t)}`);\n}\n\nexport function containsKey(script: Miniscript | ast.MiniscriptNode, key: BIP32Interface | string): boolean {\n  if (script instanceof Miniscript) {\n    script = ast.fromMiniscript(script);\n  }\n  if ('pk' in script) {\n    return script.pk === toXOnly(key);\n  }\n  throw new Error(`Unsupported script type: ${JSON.stringify(script)}`);\n}\n\nexport function getTapLeafScripts(d: Descriptor): string[] {\n  return getTapLeafScriptNodes(ast.fromDescriptor(d)).map((n) =>\n    Miniscript.fromString(ast.formatNode(n), 'tap').toString()\n  );\n}\n\nexport function getDescriptor(\n  template: DescriptorTemplate,\n  keys: KeyTriple | string[] = getDefaultXPubs(),\n  path = '0/*'\n): Descriptor {\n  return Descriptor.fromStringDetectType(ast.formatNode(getDescriptorNode(template, keys, path)));\n}\n\nexport function getDescriptorMap(\n  template: DescriptorTemplate,\n  keys: KeyTriple | string[] = getDefaultXPubs()\n): DescriptorMap {\n  return toDescriptorMap({\n    external: getDescriptor(template, keys, '0/*').toString(),\n    internal: getDescriptor(template, keys, '1/*').toString(),\n  });\n}\n"]}

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


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