UNPKG

@bitgo/utxo-bin

Version:

Command-line utility for BitGo UTXO transactions

119 lines 14.7 kB
"use strict"; var __createBinding = (this && this.__createBinding) || (Object.create ? (function(o, m, k, k2) { if (k2 === undefined) k2 = k; var desc = Object.getOwnPropertyDescriptor(m, k); if (!desc || ("get" in desc ? !m.__esModule : desc.writable || desc.configurable)) { desc = { enumerable: true, get: function() { return m[k]; } }; } Object.defineProperty(o, k2, desc); }) : (function(o, m, k, k2) { if (k2 === undefined) k2 = k; o[k2] = m[k]; })); var __setModuleDefault = (this && this.__setModuleDefault) || (Object.create ? (function(o, v) { Object.defineProperty(o, "default", { enumerable: true, value: v }); }) : function(o, v) { o["default"] = v; }); var __importStar = (this && this.__importStar) || (function () { var ownKeys = function(o) { ownKeys = Object.getOwnPropertyNames || function (o) { var ar = []; for (var k in o) if (Object.prototype.hasOwnProperty.call(o, k)) ar[ar.length] = k; return ar; }; return ownKeys(o); }; return function (mod) { if (mod && mod.__esModule) return mod; var result = {}; if (mod != null) for (var k = ownKeys(mod), i = 0; i < k.length; i++) if (k[i] !== "default") __createBinding(result, mod, k[i]); __setModuleDefault(result, mod); return result; }; })(); var __importDefault = (this && this.__importDefault) || function (mod) { return (mod && mod.__esModule) ? mod : { "default": mod }; }; Object.defineProperty(exports, "__esModule", { value: true }); exports.isSupportedDepositType = isSupportedDepositType; const assert_1 = __importDefault(require("assert")); const yargs_1 = __importDefault(require("yargs")); const utxolib = __importStar(require("@bitgo/utxo-lib")); const fixtures_1 = require("./fixtures"); const bip32_util_1 = require("./bip32.util"); const cmdParse_1 = require("../src/commands/cmdAddress/cmdParse"); const args_1 = require("../src/args"); const scriptTypesSingleSig = ['p2pkh', 'p2wkh']; const scriptTypes = [...utxolib.bitgo.outputScripts.scriptTypes2Of3, ...scriptTypesSingleSig]; function isSupportedDepositType(network, scriptType) { if (network === args_1.bitcoinRegtest) { return isSupportedDepositType(utxolib.networks.bitcoin, scriptType); } if (scriptType === 'p2pkh') { return true; } if (scriptType === 'p2wkh') { return utxolib.supportsSegwit(network); } return utxolib.bitgo.outputScripts.isSupportedScriptType(network, scriptType); } /** * * @param keys - Pubkeys to use for generating the address. * If scriptType is single-sig, the first key will be used. * @param scriptType * @param network * @return {Buffer} scriptPubKey */ function createScriptPubKey(keys, scriptType, network) { const pubkeys = keys.map((k) => k.publicKey); switch (scriptType) { case 'p2sh': case 'p2shP2wsh': case 'p2wsh': case 'p2tr': case 'p2trMusig2': return utxolib.bitgo.outputScripts.createOutputScript2of3(pubkeys, scriptType).scriptPubKey; case 'p2pkh': return utxolib.payments.p2pkh({ pubkey: keys[0].publicKey }).output; case 'p2wkh': return utxolib.payments.p2wpkh({ pubkey: keys[0].publicKey }).output; default: throw new Error(`unsupported output type ${scriptType}`); } } function getAddresses(n) { const keys = (0, bip32_util_1.getKeyTriple)('parseAddress'); return scriptTypes .filter((t) => isSupportedDepositType(n, t)) .flatMap((t) => utxolib.addressFormat.addressFormats .filter((format) => utxolib.addressFormat.isSupportedAddressFormat(format, n)) .map((format) => [ t, format, utxolib.addressFormat.fromOutputScriptWithFormat(createScriptPubKey(keys, t, n), format, n), ])); } function parse(address, args) { return (0, cmdParse_1.getAddressParser)((0, yargs_1.default)([]).command(cmdParse_1.cmdParse).parseSync(args)).parse(address); } function testParseAddress(network, type, addressFormat, address, args, suffix) { describe(`parse address ${address} with arguments ${args.join(' ')}`, function () { it(`formats address`, async function () { const formatted = (0, fixtures_1.formatTreeNoColor)(parse(address, args), { showAll: true }); const addrNoColon = address.replace(':', '_'); const filename = [(0, args_1.getNetworkName)(network), type, addressFormat, addrNoColon + suffix].join('_'); assert_1.default.strictEqual(await (0, fixtures_1.getFixtureString)(`test/fixtures/formatAddress/${filename}.txt`, formatted), formatted); }); }); } (0, args_1.getNetworkList)().forEach((n) => { getAddresses(n).forEach(([type, addressFormat, address], i) => { testParseAddress(n, type, addressFormat, address, [], ''); if ([utxolib.networks.bitcoin, utxolib.networks.bitcoincash, utxolib.networks.ecash].includes(n)) { testParseAddress(n, type, addressFormat, address, ['--all'], '.all'); } }); }); //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"parseAddress.js","sourceRoot":"","sources":["../../test/parseAddress.ts"],"names":[],"mappings":"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","sourcesContent":["import assert from 'assert';\n\nimport yargs from 'yargs';\nimport * as utxolib from '@bitgo/utxo-lib';\n\nimport { formatTreeNoColor, getFixtureString } from './fixtures';\nimport { getKeyTriple, KeyTriple } from './bip32.util';\nimport { getAddressParser, cmdParse } from '../src/commands/cmdAddress/cmdParse';\nimport { bitcoinRegtest, getNetworkList, getNetworkName } from '../src/args';\n\nconst scriptTypesSingleSig = ['p2pkh', 'p2wkh'] as const;\nconst scriptTypes = [...utxolib.bitgo.outputScripts.scriptTypes2Of3, ...scriptTypesSingleSig] as const;\ntype ScriptType = (typeof scriptTypes)[number];\n\nexport function isSupportedDepositType(network: utxolib.Network, scriptType: ScriptType): boolean {\n  if (network === bitcoinRegtest) {\n    return isSupportedDepositType(utxolib.networks.bitcoin, scriptType);\n  }\n\n  if (scriptType === 'p2pkh') {\n    return true;\n  }\n\n  if (scriptType === 'p2wkh') {\n    return utxolib.supportsSegwit(network);\n  }\n\n  return utxolib.bitgo.outputScripts.isSupportedScriptType(network, scriptType);\n}\n\n/**\n *\n * @param keys - Pubkeys to use for generating the address.\n *               If scriptType is single-sig, the first key will be used.\n * @param scriptType\n * @param network\n * @return {Buffer} scriptPubKey\n */\nfunction createScriptPubKey(keys: KeyTriple, scriptType: ScriptType, network: utxolib.Network): Buffer {\n  const pubkeys = keys.map((k) => k.publicKey);\n\n  switch (scriptType) {\n    case 'p2sh':\n    case 'p2shP2wsh':\n    case 'p2wsh':\n    case 'p2tr':\n    case 'p2trMusig2':\n      return utxolib.bitgo.outputScripts.createOutputScript2of3(pubkeys, scriptType).scriptPubKey;\n    case 'p2pkh':\n      return utxolib.payments.p2pkh({ pubkey: keys[0].publicKey }).output as Buffer;\n    case 'p2wkh':\n      return utxolib.payments.p2wpkh({ pubkey: keys[0].publicKey }).output as Buffer;\n    default:\n      throw new Error(`unsupported output type ${scriptType}`);\n  }\n}\n\nfunction getAddresses(n: utxolib.Network): [type: string, format: string, address: string][] {\n  const keys = getKeyTriple('parseAddress');\n  return scriptTypes\n    .filter((t) => isSupportedDepositType(n, t))\n    .flatMap((t) =>\n      utxolib.addressFormat.addressFormats\n        .filter((format) => utxolib.addressFormat.isSupportedAddressFormat(format, n))\n        .map((format): [string, string, string] => [\n          t,\n          format,\n          utxolib.addressFormat.fromOutputScriptWithFormat(createScriptPubKey(keys, t, n), format, n),\n        ])\n    );\n}\n\nfunction parse(address: string, args: string[]) {\n  return getAddressParser(yargs([]).command(cmdParse).parseSync(args)).parse(address);\n}\n\nfunction testParseAddress(\n  network: utxolib.Network,\n  type: string,\n  addressFormat: string,\n  address: string,\n  args: string[],\n  suffix: string\n) {\n  describe(`parse address ${address} with arguments ${args.join(' ')}`, function () {\n    it(`formats address`, async function () {\n      const formatted = formatTreeNoColor(parse(address, args), { showAll: true });\n      const addrNoColon = address.replace(':', '_');\n      const filename = [getNetworkName(network), type, addressFormat, addrNoColon + suffix].join('_');\n      assert.strictEqual(await getFixtureString(`test/fixtures/formatAddress/${filename}.txt`, formatted), formatted);\n    });\n  });\n}\n\ngetNetworkList().forEach((n) => {\n  getAddresses(n).forEach(([type, addressFormat, address], i) => {\n    testParseAddress(n, type, addressFormat, address, [], '');\n    if ([utxolib.networks.bitcoin, utxolib.networks.bitcoincash, utxolib.networks.ecash].includes(n)) {\n      testParseAddress(n, type, addressFormat, address, ['--all'], '.all');\n    }\n  });\n});\n"]}