@bitgo-beta/utxo-bin 2.8.3-beta.9 → 2.8.3-beta.90

This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
Files changed (67) hide show
  1. package/README.md +107 -86
  2. package/dist/bin/index.js +9 -2
  3. package/dist/src/AddressParser.d.ts +1 -0
  4. package/dist/src/AddressParser.d.ts.map +1 -1
  5. package/dist/src/AddressParser.js +7 -1
  6. package/dist/src/InputParser.d.ts +44 -0
  7. package/dist/src/InputParser.d.ts.map +1 -0
  8. package/dist/src/InputParser.js +239 -0
  9. package/dist/src/OutputParser.d.ts +24 -0
  10. package/dist/src/OutputParser.d.ts.map +1 -0
  11. package/dist/src/OutputParser.js +52 -0
  12. package/dist/src/Parser.d.ts +7 -1
  13. package/dist/src/Parser.d.ts.map +1 -1
  14. package/dist/src/Parser.js +29 -2
  15. package/dist/src/ParserTx.d.ts +28 -0
  16. package/dist/src/ParserTx.d.ts.map +1 -0
  17. package/dist/src/ParserTx.js +94 -0
  18. package/dist/src/ScriptParser.d.ts +21 -0
  19. package/dist/src/ScriptParser.d.ts.map +1 -0
  20. package/dist/src/ScriptParser.js +77 -0
  21. package/dist/src/TxParser.d.ts +9 -6
  22. package/dist/src/TxParser.d.ts.map +1 -1
  23. package/dist/src/TxParser.js +21 -23
  24. package/dist/src/commands.d.ts +36 -1
  25. package/dist/src/commands.d.ts.map +1 -1
  26. package/dist/src/commands.js +151 -19
  27. package/dist/src/fetch.d.ts +4 -3
  28. package/dist/src/fetch.d.ts.map +1 -1
  29. package/dist/src/fetch.js +14 -3
  30. package/dist/src/format.d.ts +1 -1
  31. package/dist/src/format.d.ts.map +1 -1
  32. package/dist/src/format.js +17 -7
  33. package/dist/src/generateAddress.d.ts +32 -0
  34. package/dist/src/generateAddress.d.ts.map +1 -0
  35. package/dist/src/generateAddress.js +104 -0
  36. package/dist/src/parseString.d.ts +5 -0
  37. package/dist/src/parseString.d.ts.map +1 -0
  38. package/dist/src/parseString.js +29 -0
  39. package/dist/src/parseUnknown.d.ts +5 -0
  40. package/dist/src/parseUnknown.d.ts.map +1 -0
  41. package/dist/src/parseUnknown.js +50 -0
  42. package/dist/src/readStdin.d.ts +5 -0
  43. package/dist/src/readStdin.d.ts.map +1 -0
  44. package/dist/src/readStdin.js +42 -0
  45. package/dist/test/fixtures.d.ts +24 -0
  46. package/dist/test/fixtures.d.ts.map +1 -0
  47. package/dist/test/fixtures.js +95 -0
  48. package/dist/test/generateAddress.d.ts +2 -0
  49. package/dist/test/generateAddress.d.ts.map +1 -0
  50. package/dist/test/generateAddress.js +29 -0
  51. package/dist/test/parseAddress.d.ts +10 -0
  52. package/dist/test/parseAddress.d.ts.map +1 -0
  53. package/dist/test/parseAddress.js +87 -0
  54. package/dist/test/parseScript.d.ts +2 -0
  55. package/dist/test/parseScript.d.ts.map +1 -0
  56. package/dist/test/parseScript.js +38 -0
  57. package/dist/test/parseTransaction.d.ts +2 -0
  58. package/dist/test/parseTransaction.d.ts.map +1 -0
  59. package/dist/test/parseTransaction.js +66 -0
  60. package/dist/test/stringToBuffer.d.ts +2 -0
  61. package/dist/test/stringToBuffer.d.ts.map +1 -0
  62. package/dist/test/stringToBuffer.js +16 -0
  63. package/dist/tsconfig.tsbuildinfo +1 -4635
  64. package/package.json +8 -6
  65. package/dist/src/InputOutputParser.d.ts +0 -35
  66. package/dist/src/InputOutputParser.d.ts.map +0 -1
  67. package/dist/src/InputOutputParser.js +0 -196
@@ -0,0 +1,104 @@
1
+ "use strict";
2
+ Object.defineProperty(exports, "__esModule", { value: true });
3
+ exports.generateAddress = exports.parseIndexRange = exports.getRange = exports.formatAddressWithFormatString = exports.formatAddressTree = exports.getAddressPlaceholderDescription = void 0;
4
+ const assert = require("assert");
5
+ const utxolib = require("@bitgo-beta/utxo-lib");
6
+ const Parser_1 = require("./Parser");
7
+ const parseUnknown_1 = require("./parseUnknown");
8
+ const format_1 = require("./format");
9
+ function getDefaultChainCodes() {
10
+ return utxolib.bitgo.chainCodes.filter(
11
+ // these are rare and show an annoying warning in stderr
12
+ (c) => utxolib.bitgo.scriptTypeForChain(c) !== 'p2tr' && utxolib.bitgo.scriptTypeForChain(c) !== 'p2trMusig2');
13
+ }
14
+ const placeholders = {
15
+ '%c': 'chain',
16
+ '%i': 'index',
17
+ '%p': 'userPath',
18
+ '%t': 'type',
19
+ '%p0': 'userPath',
20
+ '%p1': 'backupPath',
21
+ '%p2': 'bitgoPath',
22
+ '%k0': 'userKey',
23
+ '%k1': 'backupKey',
24
+ '%k2': 'bitgoKey',
25
+ '%s': 'scriptPubKey',
26
+ '%r': 'redeemScript',
27
+ '%w': 'witnessScript',
28
+ '%a': 'address',
29
+ };
30
+ function getAddressPlaceholderDescription() {
31
+ return Object.entries(placeholders)
32
+ .map(([placeholder, prop]) => `${placeholder} -> ${prop}`)
33
+ .join('\n');
34
+ }
35
+ exports.getAddressPlaceholderDescription = getAddressPlaceholderDescription;
36
+ function getAddressProperties(keys, chain, index, network) {
37
+ var _a, _b;
38
+ const [userPath, backupPath, bitgoPath] = keys.triple.map((k) => keys.getDerivationPath(k, chain, index));
39
+ const scripts = utxolib.bitgo.getWalletOutputScripts(keys, chain, index);
40
+ const [userKey, backupKey, bitgoKey] = keys.triple.map((k) => k.derivePath(userPath).publicKey.toString('hex'));
41
+ const address = utxolib.address.fromOutputScript(scripts.scriptPubKey, network);
42
+ return {
43
+ chain,
44
+ index,
45
+ type: utxolib.bitgo.scriptTypeForChain(chain),
46
+ userPath,
47
+ backupPath,
48
+ bitgoPath,
49
+ userKey,
50
+ backupKey,
51
+ bitgoKey,
52
+ scriptPubKey: scripts.scriptPubKey.toString('hex'),
53
+ redeemScript: (_a = scripts.redeemScript) === null || _a === void 0 ? void 0 : _a.toString('hex'),
54
+ witnessScript: (_b = scripts.witnessScript) === null || _b === void 0 ? void 0 : _b.toString('hex'),
55
+ address,
56
+ };
57
+ }
58
+ function formatAddressTree(props) {
59
+ const parser = new Parser_1.Parser();
60
+ return format_1.formatTree(parseUnknown_1.parseUnknown(parser, 'address', props));
61
+ }
62
+ exports.formatAddressTree = formatAddressTree;
63
+ function formatAddressWithFormatString(props, format) {
64
+ // replace all patterns with a % prefix from format string with the corresponding property
65
+ // e.g. %p0 -> userPath, %k1 -> backupKey, etc.
66
+ return format.replace(/%[a-z0-9]+/gi, (match) => {
67
+ if (match in placeholders) {
68
+ const prop = placeholders[match];
69
+ return String(props[prop]);
70
+ }
71
+ return match;
72
+ });
73
+ }
74
+ exports.formatAddressWithFormatString = formatAddressWithFormatString;
75
+ function getRange(start, end) {
76
+ return Array.from({ length: end - start + 1 }, (_, i) => start + i);
77
+ }
78
+ exports.getRange = getRange;
79
+ function parseIndexRange(ranges) {
80
+ return ranges.flatMap((range) => {
81
+ const [start, end] = range.split('-');
82
+ if (end) {
83
+ return getRange(Number(start), Number(end));
84
+ }
85
+ return [Number(start)];
86
+ });
87
+ }
88
+ exports.parseIndexRange = parseIndexRange;
89
+ function* generateAddress(argv) {
90
+ var _a, _b;
91
+ const xpubs = [argv.userKey, argv.backupKey, argv.bitgoKey].map((k) => utxolib.bip32.fromBase58(k));
92
+ assert(utxolib.bitgo.isTriple(xpubs));
93
+ const rootXpubs = new utxolib.bitgo.RootWalletKeys(xpubs);
94
+ const chains = (_a = argv.chain) !== null && _a !== void 0 ? _a : getDefaultChainCodes();
95
+ for (const i of argv.index) {
96
+ for (const chain of chains) {
97
+ assert(utxolib.bitgo.isChainCode(chain));
98
+ // yield formatAddress(rootXpubs, chain, i, argv.network ?? utxolib.networks.bitcoin, argv.format);
99
+ yield getAddressProperties(rootXpubs, chain, i, (_b = argv.network) !== null && _b !== void 0 ? _b : utxolib.networks.bitcoin);
100
+ }
101
+ }
102
+ }
103
+ exports.generateAddress = generateAddress;
104
+ //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"generateAddress.js","sourceRoot":"","sources":["../../src/generateAddress.ts"],"names":[],"mappings":"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","sourcesContent":["import * as assert from 'assert';\nimport * as utxolib from '@bitgo-beta/utxo-lib';\nimport { Parser } from './Parser';\nimport { parseUnknown } from './parseUnknown';\nimport { formatTree } from './format';\n\nfunction getDefaultChainCodes(): number[] {\n  return utxolib.bitgo.chainCodes.filter(\n    // these are rare and show an annoying warning in stderr\n    (c) => utxolib.bitgo.scriptTypeForChain(c) !== 'p2tr' && utxolib.bitgo.scriptTypeForChain(c) !== 'p2trMusig2'\n  );\n}\n\ntype AddressProperties = {\n  chain: utxolib.bitgo.ChainCode;\n  index: number;\n  type: utxolib.bitgo.outputScripts.ScriptType;\n  userPath: string;\n  backupPath: string;\n  bitgoPath: string;\n  userKey: string;\n  backupKey: string;\n  bitgoKey: string;\n  redeemScript?: string;\n  witnessScript?: string;\n  scriptPubKey: string;\n  address: string;\n};\n\nconst placeholders = {\n  '%c': 'chain',\n  '%i': 'index',\n  '%p': 'userPath',\n  '%t': 'type',\n  '%p0': 'userPath',\n  '%p1': 'backupPath',\n  '%p2': 'bitgoPath',\n  '%k0': 'userKey',\n  '%k1': 'backupKey',\n  '%k2': 'bitgoKey',\n  '%s': 'scriptPubKey',\n  '%r': 'redeemScript',\n  '%w': 'witnessScript',\n  '%a': 'address',\n} as const;\n\nexport function getAddressPlaceholderDescription(): string {\n  return Object.entries(placeholders)\n    .map(([placeholder, prop]) => `${placeholder} -> ${prop}`)\n    .join('\\n');\n}\n\nfunction getAddressProperties(\n  keys: utxolib.bitgo.RootWalletKeys,\n  chain: utxolib.bitgo.ChainCode,\n  index: number,\n  network: utxolib.Network\n): AddressProperties {\n  const [userPath, backupPath, bitgoPath] = keys.triple.map((k) => keys.getDerivationPath(k, chain, index));\n  const scripts = utxolib.bitgo.getWalletOutputScripts(keys, chain, index);\n  const [userKey, backupKey, bitgoKey] = keys.triple.map((k) => k.derivePath(userPath).publicKey.toString('hex'));\n  const address = utxolib.address.fromOutputScript(scripts.scriptPubKey, network);\n  return {\n    chain,\n    index,\n    type: utxolib.bitgo.scriptTypeForChain(chain),\n    userPath,\n    backupPath,\n    bitgoPath,\n    userKey,\n    backupKey,\n    bitgoKey,\n    scriptPubKey: scripts.scriptPubKey.toString('hex'),\n    redeemScript: scripts.redeemScript?.toString('hex'),\n    witnessScript: scripts.witnessScript?.toString('hex'),\n    address,\n  };\n}\n\nexport function formatAddressTree(props: AddressProperties): string {\n  const parser = new Parser();\n  return formatTree(parseUnknown(parser, 'address', props));\n}\n\nexport function formatAddressWithFormatString(props: AddressProperties, format: string): string {\n  // replace all patterns with a % prefix from format string with the corresponding property\n  // e.g. %p0 -> userPath, %k1 -> backupKey, etc.\n  return format.replace(/%[a-z0-9]+/gi, (match) => {\n    if (match in placeholders) {\n      const prop = placeholders[match as keyof typeof placeholders];\n      return String(props[prop]);\n    }\n    return match;\n  });\n}\n\nexport function getRange(start: number, end: number): number[] {\n  return Array.from({ length: end - start + 1 }, (_, i) => start + i);\n}\n\nexport function parseIndexRange(ranges: string[]): number[] {\n  return ranges.flatMap((range) => {\n    const [start, end] = range.split('-');\n    if (end) {\n      return getRange(Number(start), Number(end));\n    }\n    return [Number(start)];\n  });\n}\n\nexport function* generateAddress(argv: {\n  network?: utxolib.Network;\n  userKey: string;\n  backupKey: string;\n  bitgoKey: string;\n  chain?: number[];\n  format: string;\n  index: number[];\n}): Generator<AddressProperties> {\n  const xpubs = [argv.userKey, argv.backupKey, argv.bitgoKey].map((k) => utxolib.bip32.fromBase58(k));\n  assert(utxolib.bitgo.isTriple(xpubs));\n  const rootXpubs = new utxolib.bitgo.RootWalletKeys(xpubs);\n  const chains = argv.chain ?? getDefaultChainCodes();\n  for (const i of argv.index) {\n    for (const chain of chains) {\n      assert(utxolib.bitgo.isChainCode(chain));\n      // yield formatAddress(rootXpubs, chain, i, argv.network ?? utxolib.networks.bitcoin, argv.format);\n      yield getAddressProperties(rootXpubs, chain, i, argv.network ?? utxolib.networks.bitcoin);\n    }\n  }\n}\n"]}
@@ -0,0 +1,5 @@
1
+ /// <reference types="node" />
2
+ declare type Format = 'hex' | 'base64';
3
+ export declare function stringToBuffer(data: string, format: Format | Format[]): Buffer;
4
+ export {};
5
+ //# sourceMappingURL=parseString.d.ts.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"parseString.d.ts","sourceRoot":"","sources":["../../src/parseString.ts"],"names":[],"mappings":";AAAA,aAAK,MAAM,GAAG,KAAK,GAAG,QAAQ,CAAC;AAC/B,wBAAgB,cAAc,CAAC,IAAI,EAAE,MAAM,EAAE,MAAM,EAAE,MAAM,GAAG,MAAM,EAAE,GAAG,MAAM,CAyB9E"}
@@ -0,0 +1,29 @@
1
+ "use strict";
2
+ Object.defineProperty(exports, "__esModule", { value: true });
3
+ exports.stringToBuffer = void 0;
4
+ function stringToBuffer(data, format) {
5
+ if (typeof format !== 'string') {
6
+ for (const f of format) {
7
+ try {
8
+ return stringToBuffer(data, f);
9
+ }
10
+ catch (err) {
11
+ // ignore, try next
12
+ }
13
+ }
14
+ throw new Error(`could not parse data, formats: ${format}`);
15
+ }
16
+ // strip all whitespace
17
+ data = data.replace(/\s*/g, '');
18
+ if (format === 'hex') {
19
+ data = data.toLowerCase();
20
+ }
21
+ const buf = Buffer.from(data, format);
22
+ // make sure there were no decoding errors
23
+ if (buf.toString(format) !== data) {
24
+ throw new Error(`invalid ${format}`);
25
+ }
26
+ return buf;
27
+ }
28
+ exports.stringToBuffer = stringToBuffer;
29
+ //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoicGFyc2VTdHJpbmcuanMiLCJzb3VyY2VSb290IjoiIiwic291cmNlcyI6WyIuLi8uLi9zcmMvcGFyc2VTdHJpbmcudHMiXSwibmFtZXMiOltdLCJtYXBwaW5ncyI6Ijs7O0FBQ0EsU0FBZ0IsY0FBYyxDQUFDLElBQVksRUFBRSxNQUF5QjtJQUNwRSxJQUFJLE9BQU8sTUFBTSxLQUFLLFFBQVEsRUFBRTtRQUM5QixLQUFLLE1BQU0sQ0FBQyxJQUFJLE1BQU0sRUFBRTtZQUN0QixJQUFJO2dCQUNGLE9BQU8sY0FBYyxDQUFDLElBQUksRUFBRSxDQUFDLENBQUMsQ0FBQzthQUNoQztZQUFDLE9BQU8sR0FBRyxFQUFFO2dCQUNaLG1CQUFtQjthQUNwQjtTQUNGO1FBQ0QsTUFBTSxJQUFJLEtBQUssQ0FBQyxrQ0FBa0MsTUFBTSxFQUFFLENBQUMsQ0FBQztLQUM3RDtJQUVELHVCQUF1QjtJQUN2QixJQUFJLEdBQUcsSUFBSSxDQUFDLE9BQU8sQ0FBQyxNQUFNLEVBQUUsRUFBRSxDQUFDLENBQUM7SUFFaEMsSUFBSSxNQUFNLEtBQUssS0FBSyxFQUFFO1FBQ3BCLElBQUksR0FBRyxJQUFJLENBQUMsV0FBVyxFQUFFLENBQUM7S0FDM0I7SUFFRCxNQUFNLEdBQUcsR0FBRyxNQUFNLENBQUMsSUFBSSxDQUFDLElBQUksRUFBRSxNQUFNLENBQUMsQ0FBQztJQUN0QywwQ0FBMEM7SUFDMUMsSUFBSSxHQUFHLENBQUMsUUFBUSxDQUFDLE1BQU0sQ0FBQyxLQUFLLElBQUksRUFBRTtRQUNqQyxNQUFNLElBQUksS0FBSyxDQUFDLFdBQVcsTUFBTSxFQUFFLENBQUMsQ0FBQztLQUN0QztJQUNELE9BQU8sR0FBRyxDQUFDO0FBQ2IsQ0FBQztBQXpCRCx3Q0F5QkMiLCJzb3VyY2VzQ29udGVudCI6WyJ0eXBlIEZvcm1hdCA9ICdoZXgnIHwgJ2Jhc2U2NCc7XG5leHBvcnQgZnVuY3Rpb24gc3RyaW5nVG9CdWZmZXIoZGF0YTogc3RyaW5nLCBmb3JtYXQ6IEZvcm1hdCB8IEZvcm1hdFtdKTogQnVmZmVyIHtcbiAgaWYgKHR5cGVvZiBmb3JtYXQgIT09ICdzdHJpbmcnKSB7XG4gICAgZm9yIChjb25zdCBmIG9mIGZvcm1hdCkge1xuICAgICAgdHJ5IHtcbiAgICAgICAgcmV0dXJuIHN0cmluZ1RvQnVmZmVyKGRhdGEsIGYpO1xuICAgICAgfSBjYXRjaCAoZXJyKSB7XG4gICAgICAgIC8vIGlnbm9yZSwgdHJ5IG5leHRcbiAgICAgIH1cbiAgICB9XG4gICAgdGhyb3cgbmV3IEVycm9yKGBjb3VsZCBub3QgcGFyc2UgZGF0YSwgZm9ybWF0czogJHtmb3JtYXR9YCk7XG4gIH1cblxuICAvLyBzdHJpcCBhbGwgd2hpdGVzcGFjZVxuICBkYXRhID0gZGF0YS5yZXBsYWNlKC9cXHMqL2csICcnKTtcblxuICBpZiAoZm9ybWF0ID09PSAnaGV4Jykge1xuICAgIGRhdGEgPSBkYXRhLnRvTG93ZXJDYXNlKCk7XG4gIH1cblxuICBjb25zdCBidWYgPSBCdWZmZXIuZnJvbShkYXRhLCBmb3JtYXQpO1xuICAvLyBtYWtlIHN1cmUgdGhlcmUgd2VyZSBubyBkZWNvZGluZyBlcnJvcnNcbiAgaWYgKGJ1Zi50b1N0cmluZyhmb3JtYXQpICE9PSBkYXRhKSB7XG4gICAgdGhyb3cgbmV3IEVycm9yKGBpbnZhbGlkICR7Zm9ybWF0fWApO1xuICB9XG4gIHJldHVybiBidWY7XG59XG4iXX0=
@@ -0,0 +1,5 @@
1
+ import { Parser, ParserNode } from './Parser';
2
+ export declare function parseUnknown(p: Parser, label: string | number, obj: unknown, { omit }?: {
3
+ omit?: string[];
4
+ }): ParserNode;
5
+ //# sourceMappingURL=parseUnknown.d.ts.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"parseUnknown.d.ts","sourceRoot":"","sources":["../../src/parseUnknown.ts"],"names":[],"mappings":"AAAA,OAAO,EAAqB,MAAM,EAAE,UAAU,EAAmB,MAAM,UAAU,CAAC;AAgBlF,wBAAgB,YAAY,CAC1B,CAAC,EAAE,MAAM,EACT,KAAK,EAAE,MAAM,GAAG,MAAM,EACtB,GAAG,EAAE,OAAO,EACZ,EAAE,IAAS,EAAE,GAAE;IAAE,IAAI,CAAC,EAAE,MAAM,EAAE,CAAA;CAAO,GACtC,UAAU,CAwCZ"}
@@ -0,0 +1,50 @@
1
+ "use strict";
2
+ Object.defineProperty(exports, "__esModule", { value: true });
3
+ exports.parseUnknown = void 0;
4
+ const Parser_1 = require("./Parser");
5
+ function omitObject(v) {
6
+ return typeof v === 'function';
7
+ }
8
+ function getPrototypeKeys(obj) {
9
+ const keys = [];
10
+ let proto = obj;
11
+ while (proto && proto !== Object.prototype) {
12
+ keys.push(...Object.getOwnPropertyNames(proto));
13
+ proto = Object.getPrototypeOf(proto);
14
+ }
15
+ return keys;
16
+ }
17
+ function parseUnknown(p, label, obj, { omit = [] } = {}) {
18
+ if (Parser_1.isParserNodeValue(obj)) {
19
+ if (typeof obj === 'string') {
20
+ obj = JSON.stringify(obj);
21
+ }
22
+ return p.node(label, obj);
23
+ }
24
+ if (typeof obj !== 'object' || obj === null) {
25
+ throw new Error(`expected object, got ${typeof obj}`);
26
+ }
27
+ if (Array.isArray(obj)) {
28
+ return p.node(label, `length: ${obj.length}`, obj.filter((v) => !omitObject(v)).map((v, i) => parseUnknown(p, i, v)));
29
+ }
30
+ const allKeys = getPrototypeKeys(obj);
31
+ if (allKeys.length > 0) {
32
+ return p.node(label, undefined, allKeys.flatMap((k) => {
33
+ const objAsRecord = obj;
34
+ if (omitObject(objAsRecord[k]) || (omit === null || omit === void 0 ? void 0 : omit.includes(k))) {
35
+ return [];
36
+ }
37
+ try {
38
+ return [parseUnknown(p, k, objAsRecord[k])];
39
+ }
40
+ catch (e) {
41
+ return [p.node(k, `Error: ${e.message}}`)];
42
+ }
43
+ }));
44
+ }
45
+ else {
46
+ return p.node(label, '{}');
47
+ }
48
+ }
49
+ exports.parseUnknown = parseUnknown;
50
+ //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoicGFyc2VVbmtub3duLmpzIiwic291cmNlUm9vdCI6IiIsInNvdXJjZXMiOlsiLi4vLi4vc3JjL3BhcnNlVW5rbm93bi50cyJdLCJuYW1lcyI6W10sIm1hcHBpbmdzIjoiOzs7QUFBQSxxQ0FBa0Y7QUFFbEYsU0FBUyxVQUFVLENBQUMsQ0FBVTtJQUM1QixPQUFPLE9BQU8sQ0FBQyxLQUFLLFVBQVUsQ0FBQztBQUNqQyxDQUFDO0FBRUQsU0FBUyxnQkFBZ0IsQ0FBQyxHQUFZO0lBQ3BDLE1BQU0sSUFBSSxHQUFhLEVBQUUsQ0FBQztJQUMxQixJQUFJLEtBQUssR0FBRyxHQUFHLENBQUM7SUFDaEIsT0FBTyxLQUFLLElBQUksS0FBSyxLQUFLLE1BQU0sQ0FBQyxTQUFTLEVBQUU7UUFDMUMsSUFBSSxDQUFDLElBQUksQ0FBQyxHQUFHLE1BQU0sQ0FBQyxtQkFBbUIsQ0FBQyxLQUFLLENBQUMsQ0FBQyxDQUFDO1FBQ2hELEtBQUssR0FBRyxNQUFNLENBQUMsY0FBYyxDQUFDLEtBQUssQ0FBQyxDQUFDO0tBQ3RDO0lBQ0QsT0FBTyxJQUFJLENBQUM7QUFDZCxDQUFDO0FBRUQsU0FBZ0IsWUFBWSxDQUMxQixDQUFTLEVBQ1QsS0FBc0IsRUFDdEIsR0FBWSxFQUNaLEVBQUUsSUFBSSxHQUFHLEVBQUUsS0FBMEIsRUFBRTtJQUV2QyxJQUFJLDBCQUFpQixDQUFDLEdBQUcsQ0FBQyxFQUFFO1FBQzFCLElBQUksT0FBTyxHQUFHLEtBQUssUUFBUSxFQUFFO1lBQzNCLEdBQUcsR0FBRyxJQUFJLENBQUMsU0FBUyxDQUFDLEdBQUcsQ0FBQyxDQUFDO1NBQzNCO1FBQ0QsT0FBTyxDQUFDLENBQUMsSUFBSSxDQUFDLEtBQUssRUFBRSxHQUFzQixDQUFDLENBQUM7S0FDOUM7SUFFRCxJQUFJLE9BQU8sR0FBRyxLQUFLLFFBQVEsSUFBSSxHQUFHLEtBQUssSUFBSSxFQUFFO1FBQzNDLE1BQU0sSUFBSSxLQUFLLENBQUMsd0JBQXdCLE9BQU8sR0FBRyxFQUFFLENBQUMsQ0FBQztLQUN2RDtJQUVELElBQUksS0FBSyxDQUFDLE9BQU8sQ0FBQyxHQUFHLENBQUMsRUFBRTtRQUN0QixPQUFPLENBQUMsQ0FBQyxJQUFJLENBQ1gsS0FBSyxFQUNMLFdBQVcsR0FBRyxDQUFDLE1BQU0sRUFBRSxFQUN2QixHQUFHLENBQUMsTUFBTSxDQUFDLENBQUMsQ0FBQyxFQUFFLEVBQUUsQ0FBQyxDQUFDLFVBQVUsQ0FBQyxDQUFDLENBQUMsQ0FBQyxDQUFDLEdBQUcsQ0FBQyxDQUFDLENBQUMsRUFBRSxDQUFDLEVBQUUsRUFBRSxDQUFDLFlBQVksQ0FBQyxDQUFDLEVBQUUsQ0FBQyxFQUFFLENBQUMsQ0FBQyxDQUFDLENBQ3ZFLENBQUM7S0FDSDtJQUVELE1BQU0sT0FBTyxHQUFHLGdCQUFnQixDQUFDLEdBQUcsQ0FBQyxDQUFDO0lBQ3RDLElBQUksT0FBTyxDQUFDLE1BQU0sR0FBRyxDQUFDLEVBQUU7UUFDdEIsT0FBTyxDQUFDLENBQUMsSUFBSSxDQUNYLEtBQUssRUFDTCxTQUFTLEVBQ1QsT0FBTyxDQUFDLE9BQU8sQ0FBQyxDQUFDLENBQUMsRUFBRSxFQUFFO1lBQ3BCLE1BQU0sV0FBVyxHQUFHLEdBQThCLENBQUM7WUFDbkQsSUFBSSxVQUFVLENBQUMsV0FBVyxDQUFDLENBQUMsQ0FBQyxDQUFDLEtBQUksSUFBSSxhQUFKLElBQUksdUJBQUosSUFBSSxDQUFFLFFBQVEsQ0FBQyxDQUFDLENBQUMsQ0FBQSxFQUFFO2dCQUNuRCxPQUFPLEVBQUUsQ0FBQzthQUNYO1lBQ0QsSUFBSTtnQkFDRixPQUFPLENBQUMsWUFBWSxDQUFDLENBQUMsRUFBRSxDQUFDLEVBQUUsV0FBVyxDQUFDLENBQUMsQ0FBQyxDQUFDLENBQUMsQ0FBQzthQUM3QztZQUFDLE9BQU8sQ0FBQyxFQUFFO2dCQUNWLE9BQU8sQ0FBQyxDQUFDLENBQUMsSUFBSSxDQUFDLENBQUMsRUFBRSxVQUFVLENBQUMsQ0FBQyxPQUFPLEdBQUcsQ0FBQyxDQUFDLENBQUM7YUFDNUM7UUFDSCxDQUFDLENBQUMsQ0FDSCxDQUFDO0tBQ0g7U0FBTTtRQUNMLE9BQU8sQ0FBQyxDQUFDLElBQUksQ0FBQyxLQUFLLEVBQUUsSUFBSSxDQUFDLENBQUM7S0FDNUI7QUFDSCxDQUFDO0FBN0NELG9DQTZDQyIsInNvdXJjZXNDb250ZW50IjpbImltcG9ydCB7IGlzUGFyc2VyTm9kZVZhbHVlLCBQYXJzZXIsIFBhcnNlck5vZGUsIFBhcnNlck5vZGVWYWx1ZSB9IGZyb20gJy4vUGFyc2VyJztcblxuZnVuY3Rpb24gb21pdE9iamVjdCh2OiB1bmtub3duKTogYm9vbGVhbiB7XG4gIHJldHVybiB0eXBlb2YgdiA9PT0gJ2Z1bmN0aW9uJztcbn1cblxuZnVuY3Rpb24gZ2V0UHJvdG90eXBlS2V5cyhvYmo6IHVua25vd24pOiBzdHJpbmdbXSB7XG4gIGNvbnN0IGtleXM6IHN0cmluZ1tdID0gW107XG4gIGxldCBwcm90byA9IG9iajtcbiAgd2hpbGUgKHByb3RvICYmIHByb3RvICE9PSBPYmplY3QucHJvdG90eXBlKSB7XG4gICAga2V5cy5wdXNoKC4uLk9iamVjdC5nZXRPd25Qcm9wZXJ0eU5hbWVzKHByb3RvKSk7XG4gICAgcHJvdG8gPSBPYmplY3QuZ2V0UHJvdG90eXBlT2YocHJvdG8pO1xuICB9XG4gIHJldHVybiBrZXlzO1xufVxuXG5leHBvcnQgZnVuY3Rpb24gcGFyc2VVbmtub3duKFxuICBwOiBQYXJzZXIsXG4gIGxhYmVsOiBzdHJpbmcgfCBudW1iZXIsXG4gIG9iajogdW5rbm93bixcbiAgeyBvbWl0ID0gW10gfTogeyBvbWl0Pzogc3RyaW5nW10gfSA9IHt9XG4pOiBQYXJzZXJOb2RlIHtcbiAgaWYgKGlzUGFyc2VyTm9kZVZhbHVlKG9iaikpIHtcbiAgICBpZiAodHlwZW9mIG9iaiA9PT0gJ3N0cmluZycpIHtcbiAgICAgIG9iaiA9IEpTT04uc3RyaW5naWZ5KG9iaik7XG4gICAgfVxuICAgIHJldHVybiBwLm5vZGUobGFiZWwsIG9iaiBhcyBQYXJzZXJOb2RlVmFsdWUpO1xuICB9XG5cbiAgaWYgKHR5cGVvZiBvYmogIT09ICdvYmplY3QnIHx8IG9iaiA9PT0gbnVsbCkge1xuICAgIHRocm93IG5ldyBFcnJvcihgZXhwZWN0ZWQgb2JqZWN0LCBnb3QgJHt0eXBlb2Ygb2JqfWApO1xuICB9XG5cbiAgaWYgKEFycmF5LmlzQXJyYXkob2JqKSkge1xuICAgIHJldHVybiBwLm5vZGUoXG4gICAgICBsYWJlbCxcbiAgICAgIGBsZW5ndGg6ICR7b2JqLmxlbmd0aH1gLFxuICAgICAgb2JqLmZpbHRlcigodikgPT4gIW9taXRPYmplY3QodikpLm1hcCgodiwgaSkgPT4gcGFyc2VVbmtub3duKHAsIGksIHYpKVxuICAgICk7XG4gIH1cblxuICBjb25zdCBhbGxLZXlzID0gZ2V0UHJvdG90eXBlS2V5cyhvYmopO1xuICBpZiAoYWxsS2V5cy5sZW5ndGggPiAwKSB7XG4gICAgcmV0dXJuIHAubm9kZShcbiAgICAgIGxhYmVsLFxuICAgICAgdW5kZWZpbmVkLFxuICAgICAgYWxsS2V5cy5mbGF0TWFwKChrKSA9PiB7XG4gICAgICAgIGNvbnN0IG9iakFzUmVjb3JkID0gb2JqIGFzIFJlY29yZDxzdHJpbmcsIHVua25vd24+O1xuICAgICAgICBpZiAob21pdE9iamVjdChvYmpBc1JlY29yZFtrXSkgfHwgb21pdD8uaW5jbHVkZXMoaykpIHtcbiAgICAgICAgICByZXR1cm4gW107XG4gICAgICAgIH1cbiAgICAgICAgdHJ5IHtcbiAgICAgICAgICByZXR1cm4gW3BhcnNlVW5rbm93bihwLCBrLCBvYmpBc1JlY29yZFtrXSldO1xuICAgICAgICB9IGNhdGNoIChlKSB7XG4gICAgICAgICAgcmV0dXJuIFtwLm5vZGUoaywgYEVycm9yOiAke2UubWVzc2FnZX19YCldO1xuICAgICAgICB9XG4gICAgICB9KVxuICAgICk7XG4gIH0gZWxzZSB7XG4gICAgcmV0dXJuIHAubm9kZShsYWJlbCwgJ3t9Jyk7XG4gIH1cbn1cbiJdfQ==
@@ -0,0 +1,5 @@
1
+ /**
2
+ * Reads from stdin until Ctrl-D is pressed.
3
+ */
4
+ export declare function readStdin(): Promise<string>;
5
+ //# sourceMappingURL=readStdin.d.ts.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"readStdin.d.ts","sourceRoot":"","sources":["../../src/readStdin.ts"],"names":[],"mappings":"AAKA;;GAEG;AACH,wBAAsB,SAAS,IAAI,OAAO,CAAC,MAAM,CAAC,CAgCjD"}
@@ -0,0 +1,42 @@
1
+ "use strict";
2
+ /*
3
+ * Contains a high-performance implementation of reading from stdin.
4
+ * Standard readline is extremely slow for long lines.
5
+ */
6
+ Object.defineProperty(exports, "__esModule", { value: true });
7
+ exports.readStdin = void 0;
8
+ /**
9
+ * Reads from stdin until Ctrl-D is pressed.
10
+ */
11
+ async function readStdin() {
12
+ return new Promise((resolve, reject) => {
13
+ // Using readline is not an option because it is extremely slow for long lines.
14
+ // By enabling raw mode, we can read more than 4096 bytes, but it requires manual Ctrl-C/Ctrl-D handling
15
+ if (!process.stdin.setRawMode) {
16
+ throw new Error('stdin is not a tty');
17
+ }
18
+ process.stdin.setRawMode(true);
19
+ const buf = [];
20
+ process.stdin.on('data', (chunk) => {
21
+ if (chunk[0] === 0x03) {
22
+ // Ctrl-C
23
+ process.exit(130);
24
+ }
25
+ if (chunk[0] === 0x04) {
26
+ // Ctrl-D
27
+ process.stdin.emit('end');
28
+ return;
29
+ }
30
+ buf.push(chunk);
31
+ process.stdout.write(chunk);
32
+ });
33
+ process.stdin.on('end', () => {
34
+ resolve(Buffer.concat(buf).toString('utf8'));
35
+ });
36
+ process.stdin.on('error', (err) => {
37
+ reject(err);
38
+ });
39
+ });
40
+ }
41
+ exports.readStdin = readStdin;
42
+ //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoicmVhZFN0ZGluLmpzIiwic291cmNlUm9vdCI6IiIsInNvdXJjZXMiOlsiLi4vLi4vc3JjL3JlYWRTdGRpbi50cyJdLCJuYW1lcyI6W10sIm1hcHBpbmdzIjoiO0FBQUE7OztHQUdHOzs7QUFFSDs7R0FFRztBQUNJLEtBQUssVUFBVSxTQUFTO0lBQzdCLE9BQU8sSUFBSSxPQUFPLENBQUMsQ0FBQyxPQUFPLEVBQUUsTUFBTSxFQUFFLEVBQUU7UUFDckMsK0VBQStFO1FBQy9FLHdHQUF3RztRQUN4RyxJQUFJLENBQUMsT0FBTyxDQUFDLEtBQUssQ0FBQyxVQUFVLEVBQUU7WUFDN0IsTUFBTSxJQUFJLEtBQUssQ0FBQyxvQkFBb0IsQ0FBQyxDQUFDO1NBQ3ZDO1FBQ0QsT0FBTyxDQUFDLEtBQUssQ0FBQyxVQUFVLENBQUMsSUFBSSxDQUFDLENBQUM7UUFDL0IsTUFBTSxHQUFHLEdBQWEsRUFBRSxDQUFDO1FBRXpCLE9BQU8sQ0FBQyxLQUFLLENBQUMsRUFBRSxDQUFDLE1BQU0sRUFBRSxDQUFDLEtBQUssRUFBRSxFQUFFO1lBQ2pDLElBQUksS0FBSyxDQUFDLENBQUMsQ0FBQyxLQUFLLElBQUksRUFBRTtnQkFDckIsU0FBUztnQkFDVCxPQUFPLENBQUMsSUFBSSxDQUFDLEdBQUcsQ0FBQyxDQUFDO2FBQ25CO1lBQ0QsSUFBSSxLQUFLLENBQUMsQ0FBQyxDQUFDLEtBQUssSUFBSSxFQUFFO2dCQUNyQixTQUFTO2dCQUNULE9BQU8sQ0FBQyxLQUFLLENBQUMsSUFBSSxDQUFDLEtBQUssQ0FBQyxDQUFDO2dCQUMxQixPQUFPO2FBQ1I7WUFDRCxHQUFHLENBQUMsSUFBSSxDQUFDLEtBQUssQ0FBQyxDQUFDO1lBQ2hCLE9BQU8sQ0FBQyxNQUFNLENBQUMsS0FBSyxDQUFDLEtBQUssQ0FBQyxDQUFDO1FBQzlCLENBQUMsQ0FBQyxDQUFDO1FBRUgsT0FBTyxDQUFDLEtBQUssQ0FBQyxFQUFFLENBQUMsS0FBSyxFQUFFLEdBQUcsRUFBRTtZQUMzQixPQUFPLENBQUMsTUFBTSxDQUFDLE1BQU0sQ0FBQyxHQUFHLENBQUMsQ0FBQyxRQUFRLENBQUMsTUFBTSxDQUFDLENBQUMsQ0FBQztRQUMvQyxDQUFDLENBQUMsQ0FBQztRQUVILE9BQU8sQ0FBQyxLQUFLLENBQUMsRUFBRSxDQUFDLE9BQU8sRUFBRSxDQUFDLEdBQUcsRUFBRSxFQUFFO1lBQ2hDLE1BQU0sQ0FBQyxHQUFHLENBQUMsQ0FBQztRQUNkLENBQUMsQ0FBQyxDQUFDO0lBQ0wsQ0FBQyxDQUFDLENBQUM7QUFDTCxDQUFDO0FBaENELDhCQWdDQyIsInNvdXJjZXNDb250ZW50IjpbIi8qXG4gKiBDb250YWlucyBhIGhpZ2gtcGVyZm9ybWFuY2UgaW1wbGVtZW50YXRpb24gb2YgcmVhZGluZyBmcm9tIHN0ZGluLlxuICogU3RhbmRhcmQgcmVhZGxpbmUgaXMgZXh0cmVtZWx5IHNsb3cgZm9yIGxvbmcgbGluZXMuXG4gKi9cblxuLyoqXG4gKiBSZWFkcyBmcm9tIHN0ZGluIHVudGlsIEN0cmwtRCBpcyBwcmVzc2VkLlxuICovXG5leHBvcnQgYXN5bmMgZnVuY3Rpb24gcmVhZFN0ZGluKCk6IFByb21pc2U8c3RyaW5nPiB7XG4gIHJldHVybiBuZXcgUHJvbWlzZSgocmVzb2x2ZSwgcmVqZWN0KSA9PiB7XG4gICAgLy8gVXNpbmcgcmVhZGxpbmUgaXMgbm90IGFuIG9wdGlvbiBiZWNhdXNlIGl0IGlzIGV4dHJlbWVseSBzbG93IGZvciBsb25nIGxpbmVzLlxuICAgIC8vIEJ5IGVuYWJsaW5nIHJhdyBtb2RlLCB3ZSBjYW4gcmVhZCBtb3JlIHRoYW4gNDA5NiBieXRlcywgYnV0IGl0IHJlcXVpcmVzIG1hbnVhbCBDdHJsLUMvQ3RybC1EIGhhbmRsaW5nXG4gICAgaWYgKCFwcm9jZXNzLnN0ZGluLnNldFJhd01vZGUpIHtcbiAgICAgIHRocm93IG5ldyBFcnJvcignc3RkaW4gaXMgbm90IGEgdHR5Jyk7XG4gICAgfVxuICAgIHByb2Nlc3Muc3RkaW4uc2V0UmF3TW9kZSh0cnVlKTtcbiAgICBjb25zdCBidWY6IEJ1ZmZlcltdID0gW107XG5cbiAgICBwcm9jZXNzLnN0ZGluLm9uKCdkYXRhJywgKGNodW5rKSA9PiB7XG4gICAgICBpZiAoY2h1bmtbMF0gPT09IDB4MDMpIHtcbiAgICAgICAgLy8gQ3RybC1DXG4gICAgICAgIHByb2Nlc3MuZXhpdCgxMzApO1xuICAgICAgfVxuICAgICAgaWYgKGNodW5rWzBdID09PSAweDA0KSB7XG4gICAgICAgIC8vIEN0cmwtRFxuICAgICAgICBwcm9jZXNzLnN0ZGluLmVtaXQoJ2VuZCcpO1xuICAgICAgICByZXR1cm47XG4gICAgICB9XG4gICAgICBidWYucHVzaChjaHVuayk7XG4gICAgICBwcm9jZXNzLnN0ZG91dC53cml0ZShjaHVuayk7XG4gICAgfSk7XG5cbiAgICBwcm9jZXNzLnN0ZGluLm9uKCdlbmQnLCAoKSA9PiB7XG4gICAgICByZXNvbHZlKEJ1ZmZlci5jb25jYXQoYnVmKS50b1N0cmluZygndXRmOCcpKTtcbiAgICB9KTtcblxuICAgIHByb2Nlc3Muc3RkaW4ub24oJ2Vycm9yJywgKGVycikgPT4ge1xuICAgICAgcmVqZWN0KGVycik7XG4gICAgfSk7XG4gIH0pO1xufVxuIl19
@@ -0,0 +1,24 @@
1
+ import * as utxolib from '@bitgo-beta/utxo-lib';
2
+ import { ParserNode } from '../src/Parser';
3
+ export declare function formatTreeNoColor(n: ParserNode, { showAll }: {
4
+ showAll: boolean;
5
+ }): string;
6
+ export declare type ParsedFixture = {
7
+ transaction: utxolib.bitgo.UtxoTransaction<bigint>;
8
+ prevOutputs: utxolib.TxOutput<bigint>[];
9
+ } | {
10
+ transaction: utxolib.bitgo.UtxoPsbt;
11
+ prevOutputs: undefined;
12
+ };
13
+ declare type FixtureParams = {
14
+ fixtureType: 'psbtUnsigned' | 'psbtHalfSigned' | 'psbtFullSigned' | 'networkFullSigned';
15
+ scriptType: utxolib.bitgo.outputScripts.ScriptType2Of3;
16
+ spendType?: 'keyPath' | 'scriptPath';
17
+ };
18
+ export declare function getPsbt(network: utxolib.Network, params: FixtureParams, { writeFixture }?: {
19
+ writeFixture?: string;
20
+ }): Promise<ParsedFixture>;
21
+ export declare function getTransactionWithSpendType(network: utxolib.Network, params: FixtureParams): Promise<ParsedFixture>;
22
+ export declare function getFixtureString(path: string, defaultValue: string): Promise<string>;
23
+ export {};
24
+ //# sourceMappingURL=fixtures.d.ts.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"fixtures.d.ts","sourceRoot":"","sources":["../../test/fixtures.ts"],"names":[],"mappings":"AAGA,OAAO,KAAK,OAAO,MAAM,sBAAsB,CAAC;AAGhD,OAAO,EAAE,UAAU,EAAE,MAAM,eAAe,CAAC;AAE3C,wBAAgB,iBAAiB,CAAC,CAAC,EAAE,UAAU,EAAE,EAAE,OAAO,EAAE,EAAE;IAAE,OAAO,EAAE,OAAO,CAAA;CAAE,GAAG,MAAM,CAE1F;AAED,oBAAY,aAAa,GACrB;IACE,WAAW,EAAE,OAAO,CAAC,KAAK,CAAC,eAAe,CAAC,MAAM,CAAC,CAAC;IACnD,WAAW,EAAE,OAAO,CAAC,QAAQ,CAAC,MAAM,CAAC,EAAE,CAAC;CACzC,GACD;IACE,WAAW,EAAE,OAAO,CAAC,KAAK,CAAC,QAAQ,CAAC;IACpC,WAAW,EAAE,SAAS,CAAC;CACxB,CAAC;AAEN,aAAK,aAAa,GAAG;IACnB,WAAW,EAAE,cAAc,GAAG,gBAAgB,GAAG,gBAAgB,GAAG,mBAAmB,CAAC;IACxF,UAAU,EAAE,OAAO,CAAC,KAAK,CAAC,aAAa,CAAC,cAAc,CAAC;IACvD,SAAS,CAAC,EAAE,SAAS,GAAG,YAAY,CAAC;CACtC,CAAC;AAIF,wBAAsB,OAAO,CAC3B,OAAO,EAAE,OAAO,CAAC,OAAO,EACxB,MAAM,EAAE,aAAa,EACrB,EAAE,YAAY,EAAE,GAAE;IAAE,YAAY,CAAC,EAAE,MAAM,CAAA;CAAO,GAC/C,OAAO,CAAC,aAAa,CAAC,CAmCxB;AAED,wBAAsB,2BAA2B,CAC/C,OAAO,EAAE,OAAO,CAAC,OAAO,EACxB,MAAM,EAAE,aAAa,GACpB,OAAO,CAAC,aAAa,CAAC,CA4CxB;AAED,wBAAsB,gBAAgB,CAAC,IAAI,EAAE,MAAM,EAAE,YAAY,EAAE,MAAM,GAAG,OAAO,CAAC,MAAM,CAAC,CAU1F"}
@@ -0,0 +1,95 @@
1
+ "use strict";
2
+ Object.defineProperty(exports, "__esModule", { value: true });
3
+ exports.getFixtureString = exports.getTransactionWithSpendType = exports.getPsbt = exports.formatTreeNoColor = void 0;
4
+ const fs_1 = require("fs");
5
+ const chalk_1 = require("chalk");
6
+ const utxolib = require("@bitgo-beta/utxo-lib");
7
+ const format_1 = require("../src/format");
8
+ function formatTreeNoColor(n, { showAll }) {
9
+ return format_1.formatTree(n, { hide: showAll ? [] : undefined, chalk: new chalk_1.Instance({ level: 0 }) });
10
+ }
11
+ exports.formatTreeNoColor = formatTreeNoColor;
12
+ const walletKeys = utxolib.testutil.getDefaultWalletKeys();
13
+ async function getPsbt(network, params, { writeFixture } = {}) {
14
+ const inputs = [
15
+ { scriptType: params.spendType === 'keyPath' ? 'taprootKeyPathSpend' : params.scriptType, value: BigInt(10000) },
16
+ ];
17
+ const outputs = [{ scriptType: params.scriptType, value: BigInt(9000) }];
18
+ let stage = params.fixtureType;
19
+ if (stage.startsWith('psbt')) {
20
+ stage = stage.slice('psbt'.length).toLowerCase();
21
+ }
22
+ if (stage !== 'unsigned' && stage !== 'halfsigned' && stage !== 'fullsigned') {
23
+ throw new Error(`invalid stage ${stage}`);
24
+ }
25
+ if (params.spendType === 'keyPath' && writeFixture === undefined) {
26
+ // because we currently cannot create deterministic signatures for taprootKeyPathSpend, we
27
+ // store a copy in fixtures/psbt and use that instead of creating a new one
28
+ const filename = `test/fixtures/psbt/${params.scriptType}.${params.spendType}.${stage}.json`;
29
+ try {
30
+ const psbtHex = JSON.parse(await fs_1.promises.readFile(filename, 'utf8'));
31
+ const transaction = utxolib.bitgo.createPsbtFromHex(psbtHex, network);
32
+ return { transaction, prevOutputs: undefined };
33
+ }
34
+ catch (e) {
35
+ if (e.code === 'ENOENT') {
36
+ return await getPsbt(network, params, { writeFixture: filename });
37
+ }
38
+ throw e;
39
+ }
40
+ }
41
+ const transaction = utxolib.testutil.constructPsbt(inputs, outputs, network, walletKeys, stage);
42
+ if (writeFixture) {
43
+ await fs_1.promises.writeFile(writeFixture, JSON.stringify(transaction.toHex()), 'utf8');
44
+ }
45
+ return {
46
+ transaction,
47
+ prevOutputs: undefined,
48
+ };
49
+ }
50
+ exports.getPsbt = getPsbt;
51
+ async function getTransactionWithSpendType(network, params) {
52
+ if (params.fixtureType !== 'networkFullSigned') {
53
+ return await getPsbt(network, params);
54
+ }
55
+ if (params.scriptType === 'p2trMusig2') {
56
+ if (!params.spendType) {
57
+ throw new Error('p2trMusig2 requires params');
58
+ }
59
+ }
60
+ else {
61
+ if (params.spendType) {
62
+ throw new Error('only p2trMusig2 requires spendType');
63
+ }
64
+ }
65
+ const filename = `spend_${params.scriptType}${params.spendType ? `${params.spendType}` : ''}.json`;
66
+ const f = await JSON.parse(await fs_1.promises.readFile(`../utxo-lib/test/integration_local_rpc/fixtures/${utxolib.getNetworkName(network)}/v1/${filename}`, 'utf8'));
67
+ function getPrevOut(i) {
68
+ for (const t of inputTxs) {
69
+ if (t.getHash().equals(i.hash) && i.index in t.outs) {
70
+ return t.outs[i.index];
71
+ }
72
+ }
73
+ throw new Error(`missing input ${utxolib.bitgo.formatOutputId(utxolib.bitgo.getOutputIdForInput(i))}`);
74
+ }
75
+ const inputTxs = f.inputs.map((i) => utxolib.bitgo.createTransactionFromBuffer(Buffer.from(i.hex, 'hex'), network, { amountType: 'bigint' }));
76
+ const tx = utxolib.bitgo.createTransactionFromBuffer(Buffer.from(f.transaction.hex, 'hex'), network, {
77
+ amountType: 'bigint',
78
+ });
79
+ return { transaction: tx, prevOutputs: tx.ins.map((i) => getPrevOut(i)) };
80
+ }
81
+ exports.getTransactionWithSpendType = getTransactionWithSpendType;
82
+ async function getFixtureString(path, defaultValue) {
83
+ try {
84
+ return await fs_1.promises.readFile(path, 'utf8');
85
+ }
86
+ catch (e) {
87
+ if (e.code === 'ENOENT') {
88
+ await fs_1.promises.writeFile(path, defaultValue, 'utf8');
89
+ throw new Error(`wrote default value for ${path}`);
90
+ }
91
+ throw e;
92
+ }
93
+ }
94
+ exports.getFixtureString = getFixtureString;
95
+ //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"fixtures.js","sourceRoot":"","sources":["../../test/fixtures.ts"],"names":[],"mappings":"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","sourcesContent":["import { promises as fs } from 'fs';\n\nimport { Instance } from 'chalk';\nimport * as utxolib from '@bitgo-beta/utxo-lib';\n\nimport { formatTree } from '../src/format';\nimport { ParserNode } from '../src/Parser';\n\nexport function formatTreeNoColor(n: ParserNode, { showAll }: { showAll: boolean }): string {\n  return formatTree(n, { hide: showAll ? [] : undefined, chalk: new Instance({ level: 0 }) });\n}\n\nexport type ParsedFixture =\n  | {\n      transaction: utxolib.bitgo.UtxoTransaction<bigint>;\n      prevOutputs: utxolib.TxOutput<bigint>[];\n    }\n  | {\n      transaction: utxolib.bitgo.UtxoPsbt;\n      prevOutputs: undefined;\n    };\n\ntype FixtureParams = {\n  fixtureType: 'psbtUnsigned' | 'psbtHalfSigned' | 'psbtFullSigned' | 'networkFullSigned';\n  scriptType: utxolib.bitgo.outputScripts.ScriptType2Of3;\n  spendType?: 'keyPath' | 'scriptPath';\n};\n\nconst walletKeys = utxolib.testutil.getDefaultWalletKeys();\n\nexport async function getPsbt(\n  network: utxolib.Network,\n  params: FixtureParams,\n  { writeFixture }: { writeFixture?: string } = {}\n): Promise<ParsedFixture> {\n  const inputs: utxolib.testutil.Input[] = [\n    { scriptType: params.spendType === 'keyPath' ? 'taprootKeyPathSpend' : params.scriptType, value: BigInt(10_000) },\n  ];\n  const outputs = [{ scriptType: params.scriptType, value: BigInt(9_000) }];\n  let stage: string = params.fixtureType;\n  if (stage.startsWith('psbt')) {\n    stage = stage.slice('psbt'.length).toLowerCase();\n  }\n  if (stage !== 'unsigned' && stage !== 'halfsigned' && stage !== 'fullsigned') {\n    throw new Error(`invalid stage ${stage}`);\n  }\n  if (params.spendType === 'keyPath' && writeFixture === undefined) {\n    // because we currently cannot create deterministic signatures for taprootKeyPathSpend, we\n    // store a copy in fixtures/psbt and use that instead of creating a new one\n    const filename = `test/fixtures/psbt/${params.scriptType}.${params.spendType}.${stage}.json`;\n    try {\n      const psbtHex = JSON.parse(await fs.readFile(filename, 'utf8'));\n      const transaction = utxolib.bitgo.createPsbtFromHex(psbtHex, network);\n      return { transaction, prevOutputs: undefined };\n    } catch (e) {\n      if (e.code === 'ENOENT') {\n        return await getPsbt(network, params, { writeFixture: filename });\n      }\n      throw e;\n    }\n  }\n  const transaction = utxolib.testutil.constructPsbt(inputs, outputs, network, walletKeys, stage);\n  if (writeFixture) {\n    await fs.writeFile(writeFixture, JSON.stringify(transaction.toHex()), 'utf8');\n  }\n  return {\n    transaction,\n    prevOutputs: undefined,\n  };\n}\n\nexport async function getTransactionWithSpendType(\n  network: utxolib.Network,\n  params: FixtureParams\n): Promise<ParsedFixture> {\n  if (params.fixtureType !== 'networkFullSigned') {\n    return await getPsbt(network, params);\n  }\n\n  if (params.scriptType === 'p2trMusig2') {\n    if (!params.spendType) {\n      throw new Error('p2trMusig2 requires params');\n    }\n  } else {\n    if (params.spendType) {\n      throw new Error('only p2trMusig2 requires spendType');\n    }\n  }\n\n  const filename = `spend_${params.scriptType}${params.spendType ? `${params.spendType}` : ''}.json`;\n  type Fixture = {\n    transaction: { hex: string };\n    inputs: { hex: string }[];\n  };\n\n  const f: Fixture = await JSON.parse(\n    await fs.readFile(\n      `../utxo-lib/test/integration_local_rpc/fixtures/${utxolib.getNetworkName(network)}/v1/${filename}`,\n      'utf8'\n    )\n  );\n\n  function getPrevOut(i: utxolib.TxInput): utxolib.TxOutput<bigint> {\n    for (const t of inputTxs) {\n      if (t.getHash().equals(i.hash) && i.index in t.outs) {\n        return t.outs[i.index];\n      }\n    }\n    throw new Error(`missing input ${utxolib.bitgo.formatOutputId(utxolib.bitgo.getOutputIdForInput(i))}`);\n  }\n\n  const inputTxs = f.inputs.map((i) =>\n    utxolib.bitgo.createTransactionFromBuffer(Buffer.from(i.hex, 'hex'), network, { amountType: 'bigint' })\n  );\n  const tx = utxolib.bitgo.createTransactionFromBuffer(Buffer.from(f.transaction.hex, 'hex'), network, {\n    amountType: 'bigint',\n  });\n  return { transaction: tx, prevOutputs: tx.ins.map((i) => getPrevOut(i)) };\n}\n\nexport async function getFixtureString(path: string, defaultValue: string): Promise<string> {\n  try {\n    return await fs.readFile(path, 'utf8');\n  } catch (e) {\n    if ((e as any).code === 'ENOENT') {\n      await fs.writeFile(path, defaultValue, 'utf8');\n      throw new Error(`wrote default value for ${path}`);\n    }\n    throw e;\n  }\n}\n"]}
@@ -0,0 +1,2 @@
1
+ export {};
2
+ //# sourceMappingURL=generateAddress.d.ts.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"generateAddress.d.ts","sourceRoot":"","sources":["../../test/generateAddress.ts"],"names":[],"mappings":""}
@@ -0,0 +1,29 @@
1
+ "use strict";
2
+ Object.defineProperty(exports, "__esModule", { value: true });
3
+ const assert = require("assert");
4
+ const generateAddress_1 = require("../src/generateAddress");
5
+ const parseAddress_1 = require("./parseAddress");
6
+ describe('generateAddresses', function () {
7
+ it('should generate addresses', function () {
8
+ const [userKey, backupKey, bitgoKey] = parseAddress_1.getKeyTriple('generateAddress').map((k) => k.neutered().toBase58());
9
+ const lines = [];
10
+ for (const l of generateAddress_1.generateAddress({
11
+ userKey,
12
+ backupKey,
13
+ bitgoKey,
14
+ index: generateAddress_1.parseIndexRange(['0-1']),
15
+ format: '%a',
16
+ chain: [0, 1],
17
+ })) {
18
+ lines.push(generateAddress_1.formatAddressWithFormatString(l, '%a'));
19
+ }
20
+ assert.strictEqual(lines.length, 4);
21
+ assert.deepStrictEqual(lines, [
22
+ '38FHxcU7KY4E2nDEezEVcKWGvHy9717ehF',
23
+ '35Qg1UqVWSJdtF1ysfz9h3KRGdk9uH8iYx',
24
+ '3ARnshsLXE9QfJemQdoKL2kp6TRqGohLDz',
25
+ '3QxKW93NN8CQrKaNqkDsAXPyxPsrxfTYME',
26
+ ]);
27
+ });
28
+ });
29
+ //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiZ2VuZXJhdGVBZGRyZXNzLmpzIiwic291cmNlUm9vdCI6IiIsInNvdXJjZXMiOlsiLi4vLi4vdGVzdC9nZW5lcmF0ZUFkZHJlc3MudHMiXSwibmFtZXMiOltdLCJtYXBwaW5ncyI6Ijs7QUFBQSxpQ0FBaUM7QUFDakMsNERBQXlHO0FBQ3pHLGlEQUE4QztBQUU5QyxRQUFRLENBQUMsbUJBQW1CLEVBQUU7SUFDNUIsRUFBRSxDQUFDLDJCQUEyQixFQUFFO1FBQzlCLE1BQU0sQ0FBQyxPQUFPLEVBQUUsU0FBUyxFQUFFLFFBQVEsQ0FBQyxHQUFHLDJCQUFZLENBQUMsaUJBQWlCLENBQUMsQ0FBQyxHQUFHLENBQUMsQ0FBQyxDQUFDLEVBQUUsRUFBRSxDQUFDLENBQUMsQ0FBQyxRQUFRLEVBQUUsQ0FBQyxRQUFRLEVBQUUsQ0FBQyxDQUFDO1FBQzNHLE1BQU0sS0FBSyxHQUFHLEVBQUUsQ0FBQztRQUNqQixLQUFLLE1BQU0sQ0FBQyxJQUFJLGlDQUFlLENBQUM7WUFDOUIsT0FBTztZQUNQLFNBQVM7WUFDVCxRQUFRO1lBQ1IsS0FBSyxFQUFFLGlDQUFlLENBQUMsQ0FBQyxLQUFLLENBQUMsQ0FBQztZQUMvQixNQUFNLEVBQUUsSUFBSTtZQUNaLEtBQUssRUFBRSxDQUFDLENBQUMsRUFBRSxDQUFDLENBQUM7U0FDZCxDQUFDLEVBQUU7WUFDRixLQUFLLENBQUMsSUFBSSxDQUFDLCtDQUE2QixDQUFDLENBQUMsRUFBRSxJQUFJLENBQUMsQ0FBQyxDQUFDO1NBQ3BEO1FBRUQsTUFBTSxDQUFDLFdBQVcsQ0FBQyxLQUFLLENBQUMsTUFBTSxFQUFFLENBQUMsQ0FBQyxDQUFDO1FBQ3BDLE1BQU0sQ0FBQyxlQUFlLENBQUMsS0FBSyxFQUFFO1lBQzVCLG9DQUFvQztZQUNwQyxvQ0FBb0M7WUFDcEMsb0NBQW9DO1lBQ3BDLG9DQUFvQztTQUNyQyxDQUFDLENBQUM7SUFDTCxDQUFDLENBQUMsQ0FBQztBQUNMLENBQUMsQ0FBQyxDQUFDIiwic291cmNlc0NvbnRlbnQiOlsiaW1wb3J0ICogYXMgYXNzZXJ0IGZyb20gJ2Fzc2VydCc7XG5pbXBvcnQgeyBmb3JtYXRBZGRyZXNzV2l0aEZvcm1hdFN0cmluZywgZ2VuZXJhdGVBZGRyZXNzLCBwYXJzZUluZGV4UmFuZ2UgfSBmcm9tICcuLi9zcmMvZ2VuZXJhdGVBZGRyZXNzJztcbmltcG9ydCB7IGdldEtleVRyaXBsZSB9IGZyb20gJy4vcGFyc2VBZGRyZXNzJztcblxuZGVzY3JpYmUoJ2dlbmVyYXRlQWRkcmVzc2VzJywgZnVuY3Rpb24gKCkge1xuICBpdCgnc2hvdWxkIGdlbmVyYXRlIGFkZHJlc3NlcycsIGZ1bmN0aW9uICgpIHtcbiAgICBjb25zdCBbdXNlcktleSwgYmFja3VwS2V5LCBiaXRnb0tleV0gPSBnZXRLZXlUcmlwbGUoJ2dlbmVyYXRlQWRkcmVzcycpLm1hcCgoaykgPT4gay5uZXV0ZXJlZCgpLnRvQmFzZTU4KCkpO1xuICAgIGNvbnN0IGxpbmVzID0gW107XG4gICAgZm9yIChjb25zdCBsIG9mIGdlbmVyYXRlQWRkcmVzcyh7XG4gICAgICB1c2VyS2V5LFxuICAgICAgYmFja3VwS2V5LFxuICAgICAgYml0Z29LZXksXG4gICAgICBpbmRleDogcGFyc2VJbmRleFJhbmdlKFsnMC0xJ10pLFxuICAgICAgZm9ybWF0OiAnJWEnLFxuICAgICAgY2hhaW46IFswLCAxXSxcbiAgICB9KSkge1xuICAgICAgbGluZXMucHVzaChmb3JtYXRBZGRyZXNzV2l0aEZvcm1hdFN0cmluZyhsLCAnJWEnKSk7XG4gICAgfVxuXG4gICAgYXNzZXJ0LnN0cmljdEVxdWFsKGxpbmVzLmxlbmd0aCwgNCk7XG4gICAgYXNzZXJ0LmRlZXBTdHJpY3RFcXVhbChsaW5lcywgW1xuICAgICAgJzM4Rkh4Y1U3S1k0RTJuREVlekVWY0tXR3ZIeTk3MTdlaEYnLFxuICAgICAgJzM1UWcxVXFWV1NKZHRGMXlzZno5aDNLUkdkazl1SDhpWXgnLFxuICAgICAgJzNBUm5zaHNMWEU5UWZKZW1RZG9LTDJrcDZUUnFHb2hMRHonLFxuICAgICAgJzNReEtXOTNOTjhDUXJLYU5xa0RzQVhQeXhQc3J4ZlRZTUUnLFxuICAgIF0pO1xuICB9KTtcbn0pO1xuIl19
@@ -0,0 +1,10 @@
1
+ import { BIP32Interface } from 'bip32';
2
+ import * as utxolib from '@bitgo-beta/utxo-lib';
3
+ declare type Triple<T> = [T, T, T];
4
+ declare type KeyTriple = Triple<BIP32Interface>;
5
+ declare const scriptTypes: readonly ["p2sh", "p2shP2wsh", "p2wsh", "p2tr", "p2trMusig2", "p2pkh", "p2wkh"];
6
+ declare type ScriptType = (typeof scriptTypes)[number];
7
+ export declare function getKeyTriple(seed: string): KeyTriple;
8
+ export declare function isSupportedDepositType(network: utxolib.Network, scriptType: ScriptType): boolean;
9
+ export {};
10
+ //# sourceMappingURL=parseAddress.d.ts.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"parseAddress.d.ts","sourceRoot":"","sources":["../../test/parseAddress.ts"],"names":[],"mappings":"AAGA,OAAO,EAAE,cAAc,EAAE,MAAM,OAAO,CAAC;AACvC,OAAO,KAAK,OAAO,MAAM,sBAAsB,CAAC;AAKhD,aAAK,MAAM,CAAC,CAAC,IAAI,CAAC,CAAC,EAAE,CAAC,EAAE,CAAC,CAAC,CAAC;AAE3B,aAAK,SAAS,GAAG,MAAM,CAAC,cAAc,CAAC,CAAC;AAGxC,QAAA,MAAM,WAAW,iFAAqF,CAAC;AACvG,aAAK,UAAU,GAAG,CAAC,OAAO,WAAW,CAAC,CAAC,MAAM,CAAC,CAAC;AAK/C,wBAAgB,YAAY,CAAC,IAAI,EAAE,MAAM,GAAG,SAAS,CAEpD;AAED,wBAAgB,sBAAsB,CAAC,OAAO,EAAE,OAAO,CAAC,OAAO,EAAE,UAAU,EAAE,UAAU,GAAG,OAAO,CAUhG"}
@@ -0,0 +1,87 @@
1
+ "use strict";
2
+ Object.defineProperty(exports, "__esModule", { value: true });
3
+ exports.isSupportedDepositType = exports.getKeyTriple = void 0;
4
+ const assert = require("assert");
5
+ const crypto = require("crypto");
6
+ const yargs = require("yargs");
7
+ const utxolib = require("@bitgo-beta/utxo-lib");
8
+ const commands_1 = require("../src/commands");
9
+ const fixtures_1 = require("./fixtures");
10
+ const scriptTypesSingleSig = ['p2pkh', 'p2wkh'];
11
+ const scriptTypes = [...utxolib.bitgo.outputScripts.scriptTypes2Of3, ...scriptTypesSingleSig];
12
+ function getKey(seed) {
13
+ return utxolib.bip32.fromSeed(crypto.createHash('sha256').update(seed).digest());
14
+ }
15
+ function getKeyTriple(seed) {
16
+ return [getKey(seed + '.0'), getKey(seed + '.1'), getKey(seed + '.2')];
17
+ }
18
+ exports.getKeyTriple = getKeyTriple;
19
+ function isSupportedDepositType(network, scriptType) {
20
+ if (scriptType === 'p2pkh') {
21
+ return true;
22
+ }
23
+ if (scriptType === 'p2wkh') {
24
+ return utxolib.supportsSegwit(network);
25
+ }
26
+ return utxolib.bitgo.outputScripts.isSupportedScriptType(network, scriptType);
27
+ }
28
+ exports.isSupportedDepositType = isSupportedDepositType;
29
+ /**
30
+ *
31
+ * @param keys - Pubkeys to use for generating the address.
32
+ * If scriptType is single-sig, the first key will be used.
33
+ * @param scriptType
34
+ * @param network
35
+ * @return {Buffer} scriptPubKey
36
+ */
37
+ function createScriptPubKey(keys, scriptType, network) {
38
+ const pubkeys = keys.map((k) => k.publicKey);
39
+ switch (scriptType) {
40
+ case 'p2sh':
41
+ case 'p2shP2wsh':
42
+ case 'p2wsh':
43
+ case 'p2tr':
44
+ case 'p2trMusig2':
45
+ return utxolib.bitgo.outputScripts.createOutputScript2of3(pubkeys, scriptType).scriptPubKey;
46
+ case 'p2pkh':
47
+ return utxolib.payments.p2pkh({ pubkey: keys[0].publicKey }).output;
48
+ case 'p2wkh':
49
+ return utxolib.payments.p2wpkh({ pubkey: keys[0].publicKey }).output;
50
+ default:
51
+ throw new Error(`unsupported output type ${scriptType}`);
52
+ }
53
+ }
54
+ function getAddresses(n) {
55
+ const keys = getKeyTriple('parseAddress');
56
+ return scriptTypes
57
+ .filter((t) => isSupportedDepositType(n, t))
58
+ .flatMap((t) => utxolib.addressFormat.addressFormats
59
+ .filter((format) => utxolib.addressFormat.isSupportedAddressFormat(format, n))
60
+ .map((format) => [
61
+ t,
62
+ format,
63
+ utxolib.addressFormat.fromOutputScriptWithFormat(createScriptPubKey(keys, t, n), format, n),
64
+ ]));
65
+ }
66
+ function parse(address, args) {
67
+ return commands_1.getAddressParser(yargs.command(commands_1.cmdParseAddress).parseSync(args)).parse(address);
68
+ }
69
+ function testParseAddress(network, type, addressFormat, address, args, suffix) {
70
+ describe(`parse address ${address} with arguments ${args.join(' ')}`, function () {
71
+ it(`formats address`, async function () {
72
+ const formatted = fixtures_1.formatTreeNoColor(parse(address, args), { showAll: true });
73
+ const addrNoColon = address.replace(':', '_');
74
+ const filename = [utxolib.getNetworkName(network), type, addressFormat, addrNoColon + suffix].join('_');
75
+ assert.strictEqual(await fixtures_1.getFixtureString(`test/fixtures/formatAddress/${filename}.txt`, formatted), formatted);
76
+ });
77
+ });
78
+ }
79
+ utxolib.getNetworkList().forEach((n) => {
80
+ getAddresses(n).forEach(([type, addressFormat, address], i) => {
81
+ testParseAddress(n, type, addressFormat, address, [], '');
82
+ if ([utxolib.networks.bitcoin, utxolib.networks.bitcoincash, utxolib.networks.ecash].includes(n) && i === 0) {
83
+ testParseAddress(n, type, addressFormat, address, ['--all'], '.all');
84
+ }
85
+ });
86
+ });
87
+ //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"parseAddress.js","sourceRoot":"","sources":["../../test/parseAddress.ts"],"names":[],"mappings":"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","sourcesContent":["import * as assert from 'assert';\nimport * as crypto from 'crypto';\nimport * as yargs from 'yargs';\nimport { BIP32Interface } from 'bip32';\nimport * as utxolib from '@bitgo-beta/utxo-lib';\n\nimport { cmdParseAddress, getAddressParser } from '../src/commands';\nimport { formatTreeNoColor, getFixtureString } from './fixtures';\n\ntype Triple<T> = [T, T, T];\n\ntype KeyTriple = Triple<BIP32Interface>;\n\nconst scriptTypesSingleSig = ['p2pkh', 'p2wkh'] as const;\nconst scriptTypes = [...utxolib.bitgo.outputScripts.scriptTypes2Of3, ...scriptTypesSingleSig] as const;\ntype ScriptType = (typeof scriptTypes)[number];\n\nfunction getKey(seed: string): BIP32Interface {\n  return utxolib.bip32.fromSeed(crypto.createHash('sha256').update(seed).digest());\n}\nexport function getKeyTriple(seed: string): KeyTriple {\n  return [getKey(seed + '.0'), getKey(seed + '.1'), getKey(seed + '.2')];\n}\n\nexport function isSupportedDepositType(network: utxolib.Network, scriptType: ScriptType): boolean {\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(cmdParseAddress).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 = [utxolib.getNetworkName(network), type, addressFormat, addrNoColon + suffix].join('_');\n      assert.strictEqual(await getFixtureString(`test/fixtures/formatAddress/${filename}.txt`, formatted), formatted);\n    });\n  });\n}\n\nutxolib.getNetworkList().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) && i === 0) {\n      testParseAddress(n, type, addressFormat, address, ['--all'], '.all');\n    }\n  });\n});\n"]}
@@ -0,0 +1,2 @@
1
+ export {};
2
+ //# sourceMappingURL=parseScript.d.ts.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"parseScript.d.ts","sourceRoot":"","sources":["../../test/parseScript.ts"],"names":[],"mappings":""}