@bitgo-beta/utxo-bin 2.8.3-beta.8 → 2.8.3-beta.80
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.
- package/README.md +50 -80
- package/dist/bin/index.js +9 -2
- package/dist/src/InputParser.d.ts +44 -0
- package/dist/src/InputParser.d.ts.map +1 -0
- package/dist/src/InputParser.js +239 -0
- package/dist/src/OutputParser.d.ts +24 -0
- package/dist/src/OutputParser.d.ts.map +1 -0
- package/dist/src/OutputParser.js +52 -0
- package/dist/src/Parser.d.ts +7 -1
- package/dist/src/Parser.d.ts.map +1 -1
- package/dist/src/Parser.js +26 -2
- package/dist/src/ParserTx.d.ts +28 -0
- package/dist/src/ParserTx.d.ts.map +1 -0
- package/dist/src/ParserTx.js +94 -0
- package/dist/src/ScriptParser.d.ts +21 -0
- package/dist/src/ScriptParser.d.ts.map +1 -0
- package/dist/src/ScriptParser.js +77 -0
- package/dist/src/TxParser.d.ts +9 -6
- package/dist/src/TxParser.d.ts.map +1 -1
- package/dist/src/TxParser.js +21 -23
- package/dist/src/commands.d.ts +35 -1
- package/dist/src/commands.d.ts.map +1 -1
- package/dist/src/commands.js +123 -19
- package/dist/src/fetch.d.ts +4 -3
- package/dist/src/fetch.d.ts.map +1 -1
- package/dist/src/fetch.js +14 -3
- package/dist/src/format.d.ts +1 -1
- package/dist/src/format.d.ts.map +1 -1
- package/dist/src/format.js +14 -7
- package/dist/src/generateAddress.d.ts +11 -0
- package/dist/src/generateAddress.d.ts.map +1 -0
- package/dist/src/generateAddress.js +29 -0
- package/dist/src/parseString.d.ts +5 -0
- package/dist/src/parseString.d.ts.map +1 -0
- package/dist/src/parseString.js +29 -0
- package/dist/src/parseUnknown.d.ts +5 -0
- package/dist/src/parseUnknown.d.ts.map +1 -0
- package/dist/src/parseUnknown.js +50 -0
- package/dist/src/readStdin.d.ts +5 -0
- package/dist/src/readStdin.d.ts.map +1 -0
- package/dist/src/readStdin.js +42 -0
- package/dist/test/fixtures.d.ts +24 -0
- package/dist/test/fixtures.d.ts.map +1 -0
- package/dist/test/fixtures.js +95 -0
- package/dist/test/parseAddress.d.ts +10 -0
- package/dist/test/parseAddress.d.ts.map +1 -0
- package/dist/test/parseAddress.js +87 -0
- package/dist/test/parseScript.d.ts +2 -0
- package/dist/test/parseScript.d.ts.map +1 -0
- package/dist/test/parseScript.js +38 -0
- package/dist/test/parseTransaction.d.ts +2 -0
- package/dist/test/parseTransaction.d.ts.map +1 -0
- package/dist/test/parseTransaction.js +66 -0
- package/dist/test/stringToBuffer.d.ts +2 -0
- package/dist/test/stringToBuffer.d.ts.map +1 -0
- package/dist/test/stringToBuffer.js +16 -0
- package/dist/tsconfig.tsbuildinfo +1 -4635
- package/package.json +7 -6
- package/dist/src/InputOutputParser.d.ts +0 -35
- package/dist/src/InputOutputParser.d.ts.map +0 -1
- package/dist/src/InputOutputParser.js +0 -196
|
@@ -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 @@
|
|
|
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,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 @@
|
|
|
1
|
+
{"version":3,"file":"parseScript.d.ts","sourceRoot":"","sources":["../../test/parseScript.ts"],"names":[],"mappings":""}
|
|
@@ -0,0 +1,38 @@
|
|
|
1
|
+
"use strict";
|
|
2
|
+
Object.defineProperty(exports, "__esModule", { value: true });
|
|
3
|
+
const assert = require("assert");
|
|
4
|
+
const utxolib = require("@bitgo-beta/utxo-lib");
|
|
5
|
+
const fixtures_1 = require("./fixtures");
|
|
6
|
+
const ScriptParser_1 = require("../src/ScriptParser");
|
|
7
|
+
function testParseScript(type) {
|
|
8
|
+
let tx;
|
|
9
|
+
before('setup transaction', async function () {
|
|
10
|
+
tx = await fixtures_1.getTransactionWithSpendType(utxolib.networks.testnet, {
|
|
11
|
+
scriptType: type,
|
|
12
|
+
spendType: type === 'p2trMusig2' ? 'scriptPath' : undefined,
|
|
13
|
+
fixtureType: 'psbtFullSigned',
|
|
14
|
+
});
|
|
15
|
+
});
|
|
16
|
+
const parser = new ScriptParser_1.ScriptParser();
|
|
17
|
+
function parse(label, script) {
|
|
18
|
+
return parser.node(label, undefined, [parser.parse(script)]);
|
|
19
|
+
}
|
|
20
|
+
it(`parse script ${type}`, async function () {
|
|
21
|
+
if (tx.transaction instanceof utxolib.bitgo.UtxoTransaction) {
|
|
22
|
+
return this.skip();
|
|
23
|
+
}
|
|
24
|
+
const nodes = tx.transaction.data.inputs.flatMap((input) => {
|
|
25
|
+
return [
|
|
26
|
+
...(input.redeemScript ? [parse('redeemScript', input.redeemScript)] : []),
|
|
27
|
+
...(input.witnessScript ? [parse('witnessScript', input.witnessScript)] : []),
|
|
28
|
+
];
|
|
29
|
+
});
|
|
30
|
+
const root = new ScriptParser_1.ScriptParser().node('inputScripts', undefined, nodes);
|
|
31
|
+
const formatted = fixtures_1.formatTreeNoColor(root, { showAll: true });
|
|
32
|
+
assert.strictEqual(formatted, await fixtures_1.getFixtureString(`test/fixtures/formatScript/${type}.txt`, formatted));
|
|
33
|
+
});
|
|
34
|
+
}
|
|
35
|
+
utxolib.bitgo.outputScripts.scriptTypes2Of3.forEach((scriptType) => {
|
|
36
|
+
testParseScript(scriptType);
|
|
37
|
+
});
|
|
38
|
+
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoicGFyc2VTY3JpcHQuanMiLCJzb3VyY2VSb290IjoiIiwic291cmNlcyI6WyIuLi8uLi90ZXN0L3BhcnNlU2NyaXB0LnRzIl0sIm5hbWVzIjpbXSwibWFwcGluZ3MiOiI7O0FBQUEsaUNBQWlDO0FBQ2pDLGdEQUFnRDtBQUNoRCx5Q0FBNkc7QUFFN0csc0RBQW1EO0FBRW5ELFNBQVMsZUFBZSxDQUFDLElBQWdEO0lBQ3ZFLElBQUksRUFBaUIsQ0FBQztJQUN0QixNQUFNLENBQUMsbUJBQW1CLEVBQUUsS0FBSztRQUMvQixFQUFFLEdBQUcsTUFBTSxzQ0FBMkIsQ0FBQyxPQUFPLENBQUMsUUFBUSxDQUFDLE9BQU8sRUFBRTtZQUMvRCxVQUFVLEVBQUUsSUFBSTtZQUNoQixTQUFTLEVBQUUsSUFBSSxLQUFLLFlBQVksQ0FBQyxDQUFDLENBQUMsWUFBWSxDQUFDLENBQUMsQ0FBQyxTQUFTO1lBQzNELFdBQVcsRUFBRSxnQkFBZ0I7U0FDOUIsQ0FBQyxDQUFDO0lBQ0wsQ0FBQyxDQUFDLENBQUM7SUFFSCxNQUFNLE1BQU0sR0FBRyxJQUFJLDJCQUFZLEVBQUUsQ0FBQztJQUVsQyxTQUFTLEtBQUssQ0FBQyxLQUFhLEVBQUUsTUFBYztRQUMxQyxPQUFPLE1BQU0sQ0FBQyxJQUFJLENBQUMsS0FBSyxFQUFFLFNBQVMsRUFBRSxDQUFDLE1BQU0sQ0FBQyxLQUFLLENBQUMsTUFBTSxDQUFDLENBQUMsQ0FBQyxDQUFDO0lBQy9ELENBQUM7SUFFRCxFQUFFLENBQUMsZ0JBQWdCLElBQUksRUFBRSxFQUFFLEtBQUs7UUFDOUIsSUFBSSxFQUFFLENBQUMsV0FBVyxZQUFZLE9BQU8sQ0FBQyxLQUFLLENBQUMsZUFBZSxFQUFFO1lBQzNELE9BQU8sSUFBSSxDQUFDLElBQUksRUFBRSxDQUFDO1NBQ3BCO1FBRUQsTUFBTSxLQUFLLEdBQUcsRUFBRSxDQUFDLFdBQVcsQ0FBQyxJQUFJLENBQUMsTUFBTSxDQUFDLE9BQU8sQ0FBQyxDQUFDLEtBQUssRUFBRSxFQUFFO1lBQ3pELE9BQU87Z0JBQ0wsR0FBRyxDQUFDLEtBQUssQ0FBQyxZQUFZLENBQUMsQ0FBQyxDQUFDLENBQUMsS0FBSyxDQUFDLGNBQWMsRUFBRSxLQUFLLENBQUMsWUFBWSxDQUFDLENBQUMsQ0FBQyxDQUFDLENBQUMsRUFBRSxDQUFDO2dCQUMxRSxHQUFHLENBQUMsS0FBSyxDQUFDLGFBQWEsQ0FBQyxDQUFDLENBQUMsQ0FBQyxLQUFLLENBQUMsZUFBZSxFQUFFLEtBQUssQ0FBQyxhQUFhLENBQUMsQ0FBQyxDQUFDLENBQUMsQ0FBQyxFQUFFLENBQUM7YUFDOUUsQ0FBQztRQUNKLENBQUMsQ0FBQyxDQUFDO1FBRUgsTUFBTSxJQUFJLEdBQUcsSUFBSSwyQkFBWSxFQUFFLENBQUMsSUFBSSxDQUFDLGNBQWMsRUFBRSxTQUFTLEVBQUUsS0FBSyxDQUFDLENBQUM7UUFFdkUsTUFBTSxTQUFTLEdBQUcsNEJBQWlCLENBQUMsSUFBSSxFQUFFLEVBQUUsT0FBTyxFQUFFLElBQUksRUFBRSxDQUFDLENBQUM7UUFFN0QsTUFBTSxDQUFDLFdBQVcsQ0FBQyxTQUFTLEVBQUUsTUFBTSwyQkFBZ0IsQ0FBQyw4QkFBOEIsSUFBSSxNQUFNLEVBQUUsU0FBUyxDQUFDLENBQUMsQ0FBQztJQUM3RyxDQUFDLENBQUMsQ0FBQztBQUNMLENBQUM7QUFFRCxPQUFPLENBQUMsS0FBSyxDQUFDLGFBQWEsQ0FBQyxlQUFlLENBQUMsT0FBTyxDQUFDLENBQUMsVUFBVSxFQUFFLEVBQUU7SUFDakUsZUFBZSxDQUFDLFVBQVUsQ0FBQyxDQUFDO0FBQzlCLENBQUMsQ0FBQyxDQUFDIiwic291cmNlc0NvbnRlbnQiOlsiaW1wb3J0ICogYXMgYXNzZXJ0IGZyb20gJ2Fzc2VydCc7XG5pbXBvcnQgKiBhcyB1dHhvbGliIGZyb20gJ0BiaXRnby1iZXRhL3V0eG8tbGliJztcbmltcG9ydCB7IGZvcm1hdFRyZWVOb0NvbG9yLCBnZXRGaXh0dXJlU3RyaW5nLCBnZXRUcmFuc2FjdGlvbldpdGhTcGVuZFR5cGUsIFBhcnNlZEZpeHR1cmUgfSBmcm9tICcuL2ZpeHR1cmVzJztcbmltcG9ydCB7IFBhcnNlck5vZGUgfSBmcm9tICcuLi9zcmMvUGFyc2VyJztcbmltcG9ydCB7IFNjcmlwdFBhcnNlciB9IGZyb20gJy4uL3NyYy9TY3JpcHRQYXJzZXInO1xuXG5mdW5jdGlvbiB0ZXN0UGFyc2VTY3JpcHQodHlwZTogdXR4b2xpYi5iaXRnby5vdXRwdXRTY3JpcHRzLlNjcmlwdFR5cGUyT2YzKSB7XG4gIGxldCB0eDogUGFyc2VkRml4dHVyZTtcbiAgYmVmb3JlKCdzZXR1cCB0cmFuc2FjdGlvbicsIGFzeW5jIGZ1bmN0aW9uICgpIHtcbiAgICB0eCA9IGF3YWl0IGdldFRyYW5zYWN0aW9uV2l0aFNwZW5kVHlwZSh1dHhvbGliLm5ldHdvcmtzLnRlc3RuZXQsIHtcbiAgICAgIHNjcmlwdFR5cGU6IHR5cGUsXG4gICAgICBzcGVuZFR5cGU6IHR5cGUgPT09ICdwMnRyTXVzaWcyJyA/ICdzY3JpcHRQYXRoJyA6IHVuZGVmaW5lZCxcbiAgICAgIGZpeHR1cmVUeXBlOiAncHNidEZ1bGxTaWduZWQnLFxuICAgIH0pO1xuICB9KTtcblxuICBjb25zdCBwYXJzZXIgPSBuZXcgU2NyaXB0UGFyc2VyKCk7XG5cbiAgZnVuY3Rpb24gcGFyc2UobGFiZWw6IHN0cmluZywgc2NyaXB0OiBCdWZmZXIpOiBQYXJzZXJOb2RlIHtcbiAgICByZXR1cm4gcGFyc2VyLm5vZGUobGFiZWwsIHVuZGVmaW5lZCwgW3BhcnNlci5wYXJzZShzY3JpcHQpXSk7XG4gIH1cblxuICBpdChgcGFyc2Ugc2NyaXB0ICR7dHlwZX1gLCBhc3luYyBmdW5jdGlvbiAodGhpczogTW9jaGEuQ29udGV4dCkge1xuICAgIGlmICh0eC50cmFuc2FjdGlvbiBpbnN0YW5jZW9mIHV0eG9saWIuYml0Z28uVXR4b1RyYW5zYWN0aW9uKSB7XG4gICAgICByZXR1cm4gdGhpcy5za2lwKCk7XG4gICAgfVxuXG4gICAgY29uc3Qgbm9kZXMgPSB0eC50cmFuc2FjdGlvbi5kYXRhLmlucHV0cy5mbGF0TWFwKChpbnB1dCkgPT4ge1xuICAgICAgcmV0dXJuIFtcbiAgICAgICAgLi4uKGlucHV0LnJlZGVlbVNjcmlwdCA/IFtwYXJzZSgncmVkZWVtU2NyaXB0JywgaW5wdXQucmVkZWVtU2NyaXB0KV0gOiBbXSksXG4gICAgICAgIC4uLihpbnB1dC53aXRuZXNzU2NyaXB0ID8gW3BhcnNlKCd3aXRuZXNzU2NyaXB0JywgaW5wdXQud2l0bmVzc1NjcmlwdCldIDogW10pLFxuICAgICAgXTtcbiAgICB9KTtcblxuICAgIGNvbnN0IHJvb3QgPSBuZXcgU2NyaXB0UGFyc2VyKCkubm9kZSgnaW5wdXRTY3JpcHRzJywgdW5kZWZpbmVkLCBub2Rlcyk7XG5cbiAgICBjb25zdCBmb3JtYXR0ZWQgPSBmb3JtYXRUcmVlTm9Db2xvcihyb290LCB7IHNob3dBbGw6IHRydWUgfSk7XG5cbiAgICBhc3NlcnQuc3RyaWN0RXF1YWwoZm9ybWF0dGVkLCBhd2FpdCBnZXRGaXh0dXJlU3RyaW5nKGB0ZXN0L2ZpeHR1cmVzL2Zvcm1hdFNjcmlwdC8ke3R5cGV9LnR4dGAsIGZvcm1hdHRlZCkpO1xuICB9KTtcbn1cblxudXR4b2xpYi5iaXRnby5vdXRwdXRTY3JpcHRzLnNjcmlwdFR5cGVzMk9mMy5mb3JFYWNoKChzY3JpcHRUeXBlKSA9PiB7XG4gIHRlc3RQYXJzZVNjcmlwdChzY3JpcHRUeXBlKTtcbn0pO1xuIl19
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"parseTransaction.d.ts","sourceRoot":"","sources":["../../test/parseTransaction.ts"],"names":[],"mappings":""}
|
|
@@ -0,0 +1,66 @@
|
|
|
1
|
+
"use strict";
|
|
2
|
+
Object.defineProperty(exports, "__esModule", { value: true });
|
|
3
|
+
const yargs = require("yargs");
|
|
4
|
+
const assert = require("assert");
|
|
5
|
+
const utxolib = require("@bitgo-beta/utxo-lib");
|
|
6
|
+
const fixtures_1 = require("./fixtures");
|
|
7
|
+
const commands_1 = require("../src/commands");
|
|
8
|
+
function getArgs({ showAll }) {
|
|
9
|
+
return showAll ? ['--all'] : [];
|
|
10
|
+
}
|
|
11
|
+
function getParams() {
|
|
12
|
+
return ['psbtUnsigned', 'psbtHalfSigned', 'psbtFullSigned', 'networkFullSigned'].flatMap((fixtureType) => {
|
|
13
|
+
return [false, true].flatMap((showAll) => {
|
|
14
|
+
return utxolib.bitgo.outputScripts.scriptTypes2Of3.flatMap((scriptType) => {
|
|
15
|
+
if (scriptType === 'p2trMusig2') {
|
|
16
|
+
return [
|
|
17
|
+
{ scriptType, spendType: 'keyPath', showAll, fixtureType },
|
|
18
|
+
{ scriptType, spendType: 'scriptPath', showAll, fixtureType },
|
|
19
|
+
];
|
|
20
|
+
}
|
|
21
|
+
return [{ scriptType, spendType: undefined, showAll, fixtureType }];
|
|
22
|
+
});
|
|
23
|
+
});
|
|
24
|
+
});
|
|
25
|
+
}
|
|
26
|
+
getParams().forEach(({ scriptType, spendType, fixtureType, showAll }) => {
|
|
27
|
+
describe(`parse ${fixtureType} ${scriptType} ${spendType ? spendType : 'default'} spend [args=${getArgs({
|
|
28
|
+
showAll,
|
|
29
|
+
})}`, function () {
|
|
30
|
+
function parse(tx, prevOutputs) {
|
|
31
|
+
return commands_1.getTxParser(yargs.command(commands_1.cmdParseTx).parse([...getArgs({ showAll }), '--parseError=throw'])).parse(tx, {
|
|
32
|
+
prevOutputs,
|
|
33
|
+
});
|
|
34
|
+
}
|
|
35
|
+
let fixture;
|
|
36
|
+
before(async function () {
|
|
37
|
+
fixture = await fixtures_1.getTransactionWithSpendType(utxolib.networks.testnet, {
|
|
38
|
+
scriptType,
|
|
39
|
+
spendType,
|
|
40
|
+
fixtureType,
|
|
41
|
+
});
|
|
42
|
+
});
|
|
43
|
+
it(`parses`, function () {
|
|
44
|
+
parse(fixture.transaction);
|
|
45
|
+
if (fixture.prevOutputs) {
|
|
46
|
+
parse(fixture.transaction, fixture.prevOutputs);
|
|
47
|
+
}
|
|
48
|
+
});
|
|
49
|
+
[false, true].forEach((usePrevOuts) => {
|
|
50
|
+
it(`formats [usePrevOuts=${usePrevOuts}]`, async function () {
|
|
51
|
+
if (usePrevOuts && !fixture.prevOutputs) {
|
|
52
|
+
this.skip();
|
|
53
|
+
}
|
|
54
|
+
const formatted = fixtures_1.formatTreeNoColor(parse(fixture.transaction, usePrevOuts ? fixture.prevOutputs : undefined), {
|
|
55
|
+
showAll,
|
|
56
|
+
});
|
|
57
|
+
const fixtureName = spendType ? `${scriptType}_${spendType}` : scriptType;
|
|
58
|
+
const filename = [fixtureName, fixtureType, showAll ? 'all' : '', usePrevOuts ? 'prevOuts' : '']
|
|
59
|
+
.filter((v) => v !== '')
|
|
60
|
+
.join('_');
|
|
61
|
+
assert.strictEqual(formatted, await fixtures_1.getFixtureString(`test/fixtures/formatTransaction/${filename}.txt`, formatted));
|
|
62
|
+
});
|
|
63
|
+
});
|
|
64
|
+
});
|
|
65
|
+
});
|
|
66
|
+
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoicGFyc2VUcmFuc2FjdGlvbi5qcyIsInNvdXJjZVJvb3QiOiIiLCJzb3VyY2VzIjpbIi4uLy4uL3Rlc3QvcGFyc2VUcmFuc2FjdGlvbi50cyJdLCJuYW1lcyI6W10sIm1hcHBpbmdzIjoiOztBQUNBLCtCQUErQjtBQUMvQixpQ0FBaUM7QUFDakMsZ0RBQWdEO0FBQ2hELHlDQUE2RztBQUU3Ryw4Q0FBMEQ7QUFVMUQsU0FBUyxPQUFPLENBQUMsRUFBRSxPQUFPLEVBQXdCO0lBQ2hELE9BQU8sT0FBTyxDQUFDLENBQUMsQ0FBQyxDQUFDLE9BQU8sQ0FBQyxDQUFDLENBQUMsQ0FBQyxFQUFFLENBQUM7QUFDbEMsQ0FBQztBQUVELFNBQVMsU0FBUztJQUNoQixPQUFRLENBQUMsY0FBYyxFQUFFLGdCQUFnQixFQUFFLGdCQUFnQixFQUFFLG1CQUFtQixDQUFXLENBQUMsT0FBTyxDQUFDLENBQUMsV0FBVyxFQUFFLEVBQUU7UUFDbEgsT0FBTyxDQUFDLEtBQUssRUFBRSxJQUFJLENBQUMsQ0FBQyxPQUFPLENBQUMsQ0FBQyxPQUFPLEVBQUUsRUFBRTtZQUN2QyxPQUFPLE9BQU8sQ0FBQyxLQUFLLENBQUMsYUFBYSxDQUFDLGVBQWUsQ0FBQyxPQUFPLENBQUMsQ0FBQyxVQUFVLEVBQWdCLEVBQUU7Z0JBQ3RGLElBQUksVUFBVSxLQUFLLFlBQVksRUFBRTtvQkFDL0IsT0FBTzt3QkFDTCxFQUFFLFVBQVUsRUFBRSxTQUFTLEVBQUUsU0FBUyxFQUFFLE9BQU8sRUFBRSxXQUFXLEVBQUU7d0JBQzFELEVBQUUsVUFBVSxFQUFFLFNBQVMsRUFBRSxZQUFZLEVBQUUsT0FBTyxFQUFFLFdBQVcsRUFBRTtxQkFDOUQsQ0FBQztpQkFDSDtnQkFDRCxPQUFPLENBQUMsRUFBRSxVQUFVLEVBQUUsU0FBUyxFQUFFLFNBQVMsRUFBRSxPQUFPLEVBQUUsV0FBVyxFQUFFLENBQUMsQ0FBQztZQUN0RSxDQUFDLENBQUMsQ0FBQztRQUNMLENBQUMsQ0FBQyxDQUFDO0lBQ0wsQ0FBQyxDQUFDLENBQUM7QUFDTCxDQUFDO0FBRUQsU0FBUyxFQUFFLENBQUMsT0FBTyxDQUFDLENBQUMsRUFBRSxVQUFVLEVBQUUsU0FBUyxFQUFFLFdBQVcsRUFBRSxPQUFPLEVBQUUsRUFBRSxFQUFFO0lBQ3RFLFFBQVEsQ0FBQyxTQUFTLFdBQVcsSUFBSSxVQUFVLElBQUksU0FBUyxDQUFDLENBQUMsQ0FBQyxTQUFTLENBQUMsQ0FBQyxDQUFDLFNBQVMsZ0JBQWdCLE9BQU8sQ0FBQztRQUN0RyxPQUFPO0tBQ1IsQ0FBQyxFQUFFLEVBQUU7UUFDSixTQUFTLEtBQUssQ0FBQyxFQUFZLEVBQUUsV0FBd0M7WUFDbkUsT0FBTyxzQkFBVyxDQUFDLEtBQUssQ0FBQyxPQUFPLENBQUMscUJBQVUsQ0FBQyxDQUFDLEtBQUssQ0FBQyxDQUFDLEdBQUcsT0FBTyxDQUFDLEVBQUUsT0FBTyxFQUFFLENBQUMsRUFBRSxvQkFBb0IsQ0FBQyxDQUFRLENBQUMsQ0FBQyxLQUFLLENBQy9HLEVBQUUsRUFDRjtnQkFDRSxXQUFXO2FBQ1osQ0FDRixDQUFDO1FBQ0osQ0FBQztRQUVELElBQUksT0FBc0IsQ0FBQztRQUMzQixNQUFNLENBQUMsS0FBSztZQUNWLE9BQU8sR0FBRyxNQUFNLHNDQUEyQixDQUFDLE9BQU8sQ0FBQyxRQUFRLENBQUMsT0FBTyxFQUFFO2dCQUNwRSxVQUFVO2dCQUNWLFNBQVM7Z0JBQ1QsV0FBVzthQUNaLENBQUMsQ0FBQztRQUNMLENBQUMsQ0FBQyxDQUFDO1FBRUgsRUFBRSxDQUFDLFFBQVEsRUFBRTtZQUNYLEtBQUssQ0FBQyxPQUFPLENBQUMsV0FBVyxDQUFDLENBQUM7WUFDM0IsSUFBSSxPQUFPLENBQUMsV0FBVyxFQUFFO2dCQUN2QixLQUFLLENBQUMsT0FBTyxDQUFDLFdBQVcsRUFBRSxPQUFPLENBQUMsV0FBVyxDQUFDLENBQUM7YUFDakQ7UUFDSCxDQUFDLENBQUMsQ0FBQztRQUVILENBQUMsS0FBSyxFQUFFLElBQUksQ0FBQyxDQUFDLE9BQU8sQ0FBQyxDQUFDLFdBQVcsRUFBRSxFQUFFO1lBQ3BDLEVBQUUsQ0FBQyx3QkFBd0IsV0FBVyxHQUFHLEVBQUUsS0FBSztnQkFDOUMsSUFBSSxXQUFXLElBQUksQ0FBQyxPQUFPLENBQUMsV0FBVyxFQUFFO29CQUN2QyxJQUFJLENBQUMsSUFBSSxFQUFFLENBQUM7aUJBQ2I7Z0JBQ0QsTUFBTSxTQUFTLEdBQUcsNEJBQWlCLENBQUMsS0FBSyxDQUFDLE9BQU8sQ0FBQyxXQUFXLEVBQUUsV0FBVyxDQUFDLENBQUMsQ0FBQyxPQUFPLENBQUMsV0FBVyxDQUFDLENBQUMsQ0FBQyxTQUFTLENBQUMsRUFBRTtvQkFDN0csT0FBTztpQkFDUixDQUFDLENBQUM7Z0JBQ0gsTUFBTSxXQUFXLEdBQUcsU0FBUyxDQUFDLENBQUMsQ0FBQyxHQUFHLFVBQVUsSUFBSSxTQUFTLEVBQUUsQ0FBQyxDQUFDLENBQUMsVUFBVSxDQUFDO2dCQUMxRSxNQUFNLFFBQVEsR0FBRyxDQUFDLFdBQVcsRUFBRSxXQUFXLEVBQUUsT0FBTyxDQUFDLENBQUMsQ0FBQyxLQUFLLENBQUMsQ0FBQyxDQUFDLEVBQUUsRUFBRSxXQUFXLENBQUMsQ0FBQyxDQUFDLFVBQVUsQ0FBQyxDQUFDLENBQUMsRUFBRSxDQUFDO3FCQUM3RixNQUFNLENBQUMsQ0FBQyxDQUFDLEVBQUUsRUFBRSxDQUFDLENBQUMsS0FBSyxFQUFFLENBQUM7cUJBQ3ZCLElBQUksQ0FBQyxHQUFHLENBQUMsQ0FBQztnQkFDYixNQUFNLENBQUMsV0FBVyxDQUNoQixTQUFTLEVBQ1QsTUFBTSwyQkFBZ0IsQ0FBQyxtQ0FBbUMsUUFBUSxNQUFNLEVBQUUsU0FBUyxDQUFDLENBQ3JGLENBQUM7WUFDSixDQUFDLENBQUMsQ0FBQztRQUNMLENBQUMsQ0FBQyxDQUFDO0lBQ0wsQ0FBQyxDQUFDLENBQUM7QUFDTCxDQUFDLENBQUMsQ0FBQyIsInNvdXJjZXNDb250ZW50IjpbImltcG9ydCAqIGFzIG1vY2hhIGZyb20gJ21vY2hhJztcbmltcG9ydCAqIGFzIHlhcmdzIGZyb20gJ3lhcmdzJztcbmltcG9ydCAqIGFzIGFzc2VydCBmcm9tICdhc3NlcnQnO1xuaW1wb3J0ICogYXMgdXR4b2xpYiBmcm9tICdAYml0Z28tYmV0YS91dHhvLWxpYic7XG5pbXBvcnQgeyBmb3JtYXRUcmVlTm9Db2xvciwgZ2V0Rml4dHVyZVN0cmluZywgZ2V0VHJhbnNhY3Rpb25XaXRoU3BlbmRUeXBlLCBQYXJzZWRGaXh0dXJlIH0gZnJvbSAnLi9maXh0dXJlcyc7XG5pbXBvcnQgeyBQYXJzZXJOb2RlIH0gZnJvbSAnLi4vc3JjL1BhcnNlcic7XG5pbXBvcnQgeyBjbWRQYXJzZVR4LCBnZXRUeFBhcnNlciB9IGZyb20gJy4uL3NyYy9jb21tYW5kcyc7XG5pbXBvcnQgeyBQYXJzZXJUeCB9IGZyb20gJy4uL3NyYy9QYXJzZXJUeCc7XG5cbnR5cGUgVGVzdFBhcmFtcyA9IHtcbiAgc2NyaXB0VHlwZTogdXR4b2xpYi5iaXRnby5vdXRwdXRTY3JpcHRzLlNjcmlwdFR5cGUyT2YzO1xuICBzcGVuZFR5cGU6ICdrZXlQYXRoJyB8ICdzY3JpcHRQYXRoJyB8IHVuZGVmaW5lZDtcbiAgZml4dHVyZVR5cGU6ICdwc2J0VW5zaWduZWQnIHwgJ3BzYnRIYWxmU2lnbmVkJyB8ICdwc2J0RnVsbFNpZ25lZCcgfCAnbmV0d29ya0Z1bGxTaWduZWQnO1xuICBzaG93QWxsOiBib29sZWFuO1xufTtcblxuZnVuY3Rpb24gZ2V0QXJncyh7IHNob3dBbGwgfTogeyBzaG93QWxsOiBib29sZWFuIH0pOiBzdHJpbmdbXSB7XG4gIHJldHVybiBzaG93QWxsID8gWyctLWFsbCddIDogW107XG59XG5cbmZ1bmN0aW9uIGdldFBhcmFtcygpOiBUZXN0UGFyYW1zW10ge1xuICByZXR1cm4gKFsncHNidFVuc2lnbmVkJywgJ3BzYnRIYWxmU2lnbmVkJywgJ3BzYnRGdWxsU2lnbmVkJywgJ25ldHdvcmtGdWxsU2lnbmVkJ10gYXMgY29uc3QpLmZsYXRNYXAoKGZpeHR1cmVUeXBlKSA9PiB7XG4gICAgcmV0dXJuIFtmYWxzZSwgdHJ1ZV0uZmxhdE1hcCgoc2hvd0FsbCkgPT4ge1xuICAgICAgcmV0dXJuIHV0eG9saWIuYml0Z28ub3V0cHV0U2NyaXB0cy5zY3JpcHRUeXBlczJPZjMuZmxhdE1hcCgoc2NyaXB0VHlwZSk6IFRlc3RQYXJhbXNbXSA9PiB7XG4gICAgICAgIGlmIChzY3JpcHRUeXBlID09PSAncDJ0ck11c2lnMicpIHtcbiAgICAgICAgICByZXR1cm4gW1xuICAgICAgICAgICAgeyBzY3JpcHRUeXBlLCBzcGVuZFR5cGU6ICdrZXlQYXRoJywgc2hvd0FsbCwgZml4dHVyZVR5cGUgfSxcbiAgICAgICAgICAgIHsgc2NyaXB0VHlwZSwgc3BlbmRUeXBlOiAnc2NyaXB0UGF0aCcsIHNob3dBbGwsIGZpeHR1cmVUeXBlIH0sXG4gICAgICAgICAgXTtcbiAgICAgICAgfVxuICAgICAgICByZXR1cm4gW3sgc2NyaXB0VHlwZSwgc3BlbmRUeXBlOiB1bmRlZmluZWQsIHNob3dBbGwsIGZpeHR1cmVUeXBlIH1dO1xuICAgICAgfSk7XG4gICAgfSk7XG4gIH0pO1xufVxuXG5nZXRQYXJhbXMoKS5mb3JFYWNoKCh7IHNjcmlwdFR5cGUsIHNwZW5kVHlwZSwgZml4dHVyZVR5cGUsIHNob3dBbGwgfSkgPT4ge1xuICBkZXNjcmliZShgcGFyc2UgJHtmaXh0dXJlVHlwZX0gJHtzY3JpcHRUeXBlfSAke3NwZW5kVHlwZSA/IHNwZW5kVHlwZSA6ICdkZWZhdWx0J30gc3BlbmQgW2FyZ3M9JHtnZXRBcmdzKHtcbiAgICBzaG93QWxsLFxuICB9KX1gLCBmdW5jdGlvbiAoKSB7XG4gICAgZnVuY3Rpb24gcGFyc2UodHg6IFBhcnNlclR4LCBwcmV2T3V0cHV0cz86IHV0eG9saWIuVHhPdXRwdXQ8YmlnaW50PltdKTogUGFyc2VyTm9kZSB7XG4gICAgICByZXR1cm4gZ2V0VHhQYXJzZXIoeWFyZ3MuY29tbWFuZChjbWRQYXJzZVR4KS5wYXJzZShbLi4uZ2V0QXJncyh7IHNob3dBbGwgfSksICctLXBhcnNlRXJyb3I9dGhyb3cnXSkgYXMgYW55KS5wYXJzZShcbiAgICAgICAgdHgsXG4gICAgICAgIHtcbiAgICAgICAgICBwcmV2T3V0cHV0cyxcbiAgICAgICAgfVxuICAgICAgKTtcbiAgICB9XG5cbiAgICBsZXQgZml4dHVyZTogUGFyc2VkRml4dHVyZTtcbiAgICBiZWZvcmUoYXN5bmMgZnVuY3Rpb24gKCkge1xuICAgICAgZml4dHVyZSA9IGF3YWl0IGdldFRyYW5zYWN0aW9uV2l0aFNwZW5kVHlwZSh1dHhvbGliLm5ldHdvcmtzLnRlc3RuZXQsIHtcbiAgICAgICAgc2NyaXB0VHlwZSxcbiAgICAgICAgc3BlbmRUeXBlLFxuICAgICAgICBmaXh0dXJlVHlwZSxcbiAgICAgIH0pO1xuICAgIH0pO1xuXG4gICAgaXQoYHBhcnNlc2AsIGZ1bmN0aW9uICgpIHtcbiAgICAgIHBhcnNlKGZpeHR1cmUudHJhbnNhY3Rpb24pO1xuICAgICAgaWYgKGZpeHR1cmUucHJldk91dHB1dHMpIHtcbiAgICAgICAgcGFyc2UoZml4dHVyZS50cmFuc2FjdGlvbiwgZml4dHVyZS5wcmV2T3V0cHV0cyk7XG4gICAgICB9XG4gICAgfSk7XG5cbiAgICBbZmFsc2UsIHRydWVdLmZvckVhY2goKHVzZVByZXZPdXRzKSA9PiB7XG4gICAgICBpdChgZm9ybWF0cyBbdXNlUHJldk91dHM9JHt1c2VQcmV2T3V0c31dYCwgYXN5bmMgZnVuY3Rpb24gKHRoaXM6IG1vY2hhLkNvbnRleHQpIHtcbiAgICAgICAgaWYgKHVzZVByZXZPdXRzICYmICFmaXh0dXJlLnByZXZPdXRwdXRzKSB7XG4gICAgICAgICAgdGhpcy5za2lwKCk7XG4gICAgICAgIH1cbiAgICAgICAgY29uc3QgZm9ybWF0dGVkID0gZm9ybWF0VHJlZU5vQ29sb3IocGFyc2UoZml4dHVyZS50cmFuc2FjdGlvbiwgdXNlUHJldk91dHMgPyBmaXh0dXJlLnByZXZPdXRwdXRzIDogdW5kZWZpbmVkKSwge1xuICAgICAgICAgIHNob3dBbGwsXG4gICAgICAgIH0pO1xuICAgICAgICBjb25zdCBmaXh0dXJlTmFtZSA9IHNwZW5kVHlwZSA/IGAke3NjcmlwdFR5cGV9XyR7c3BlbmRUeXBlfWAgOiBzY3JpcHRUeXBlO1xuICAgICAgICBjb25zdCBmaWxlbmFtZSA9IFtmaXh0dXJlTmFtZSwgZml4dHVyZVR5cGUsIHNob3dBbGwgPyAnYWxsJyA6ICcnLCB1c2VQcmV2T3V0cyA/ICdwcmV2T3V0cycgOiAnJ11cbiAgICAgICAgICAuZmlsdGVyKCh2KSA9PiB2ICE9PSAnJylcbiAgICAgICAgICAuam9pbignXycpO1xuICAgICAgICBhc3NlcnQuc3RyaWN0RXF1YWwoXG4gICAgICAgICAgZm9ybWF0dGVkLFxuICAgICAgICAgIGF3YWl0IGdldEZpeHR1cmVTdHJpbmcoYHRlc3QvZml4dHVyZXMvZm9ybWF0VHJhbnNhY3Rpb24vJHtmaWxlbmFtZX0udHh0YCwgZm9ybWF0dGVkKVxuICAgICAgICApO1xuICAgICAgfSk7XG4gICAgfSk7XG4gIH0pO1xufSk7XG4iXX0=
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"stringToBuffer.d.ts","sourceRoot":"","sources":["../../test/stringToBuffer.ts"],"names":[],"mappings":""}
|
|
@@ -0,0 +1,16 @@
|
|
|
1
|
+
"use strict";
|
|
2
|
+
Object.defineProperty(exports, "__esModule", { value: true });
|
|
3
|
+
const assert = require("assert");
|
|
4
|
+
const parseString_1 = require("../src/parseString");
|
|
5
|
+
describe('stringToBuffer', function () {
|
|
6
|
+
const bytes = Buffer.alloc(32, 42);
|
|
7
|
+
it('converts hex and base64', function () {
|
|
8
|
+
for (const e of ['hex', 'base64']) {
|
|
9
|
+
const str = bytes.toString(e);
|
|
10
|
+
assert.deepStrictEqual(parseString_1.stringToBuffer(str, ['hex', 'base64']), bytes);
|
|
11
|
+
const strNl = [str.slice(0, 4), str.slice(4)].join('\n');
|
|
12
|
+
assert.deepStrictEqual(parseString_1.stringToBuffer(strNl, ['hex', 'base64']), bytes);
|
|
13
|
+
}
|
|
14
|
+
});
|
|
15
|
+
});
|
|
16
|
+
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoic3RyaW5nVG9CdWZmZXIuanMiLCJzb3VyY2VSb290IjoiIiwic291cmNlcyI6WyIuLi8uLi90ZXN0L3N0cmluZ1RvQnVmZmVyLnRzIl0sIm5hbWVzIjpbXSwibWFwcGluZ3MiOiI7O0FBQUEsaUNBQWlDO0FBRWpDLG9EQUFvRDtBQUVwRCxRQUFRLENBQUMsZ0JBQWdCLEVBQUU7SUFDekIsTUFBTSxLQUFLLEdBQUcsTUFBTSxDQUFDLEtBQUssQ0FBQyxFQUFFLEVBQUUsRUFBRSxDQUFDLENBQUM7SUFDbkMsRUFBRSxDQUFDLHlCQUF5QixFQUFFO1FBQzVCLEtBQUssTUFBTSxDQUFDLElBQUksQ0FBQyxLQUFLLEVBQUUsUUFBUSxDQUFDLEVBQUU7WUFDakMsTUFBTSxHQUFHLEdBQUcsS0FBSyxDQUFDLFFBQVEsQ0FBQyxDQUFDLENBQUMsQ0FBQztZQUM5QixNQUFNLENBQUMsZUFBZSxDQUFDLDRCQUFjLENBQUMsR0FBRyxFQUFFLENBQUMsS0FBSyxFQUFFLFFBQVEsQ0FBQyxDQUFDLEVBQUUsS0FBSyxDQUFDLENBQUM7WUFFdEUsTUFBTSxLQUFLLEdBQUcsQ0FBQyxHQUFHLENBQUMsS0FBSyxDQUFDLENBQUMsRUFBRSxDQUFDLENBQUMsRUFBRSxHQUFHLENBQUMsS0FBSyxDQUFDLENBQUMsQ0FBQyxDQUFDLENBQUMsSUFBSSxDQUFDLElBQUksQ0FBQyxDQUFDO1lBQ3pELE1BQU0sQ0FBQyxlQUFlLENBQUMsNEJBQWMsQ0FBQyxLQUFLLEVBQUUsQ0FBQyxLQUFLLEVBQUUsUUFBUSxDQUFDLENBQUMsRUFBRSxLQUFLLENBQUMsQ0FBQztTQUN6RTtJQUNILENBQUMsQ0FBQyxDQUFDO0FBQ0wsQ0FBQyxDQUFDLENBQUMiLCJzb3VyY2VzQ29udGVudCI6WyJpbXBvcnQgKiBhcyBhc3NlcnQgZnJvbSAnYXNzZXJ0JztcblxuaW1wb3J0IHsgc3RyaW5nVG9CdWZmZXIgfSBmcm9tICcuLi9zcmMvcGFyc2VTdHJpbmcnO1xuXG5kZXNjcmliZSgnc3RyaW5nVG9CdWZmZXInLCBmdW5jdGlvbiAoKSB7XG4gIGNvbnN0IGJ5dGVzID0gQnVmZmVyLmFsbG9jKDMyLCA0Mik7XG4gIGl0KCdjb252ZXJ0cyBoZXggYW5kIGJhc2U2NCcsIGZ1bmN0aW9uICgpIHtcbiAgICBmb3IgKGNvbnN0IGUgb2YgWydoZXgnLCAnYmFzZTY0J10pIHtcbiAgICAgIGNvbnN0IHN0ciA9IGJ5dGVzLnRvU3RyaW5nKGUpO1xuICAgICAgYXNzZXJ0LmRlZXBTdHJpY3RFcXVhbChzdHJpbmdUb0J1ZmZlcihzdHIsIFsnaGV4JywgJ2Jhc2U2NCddKSwgYnl0ZXMpO1xuXG4gICAgICBjb25zdCBzdHJObCA9IFtzdHIuc2xpY2UoMCwgNCksIHN0ci5zbGljZSg0KV0uam9pbignXFxuJyk7XG4gICAgICBhc3NlcnQuZGVlcFN0cmljdEVxdWFsKHN0cmluZ1RvQnVmZmVyKHN0ck5sLCBbJ2hleCcsICdiYXNlNjQnXSksIGJ5dGVzKTtcbiAgICB9XG4gIH0pO1xufSk7XG4iXX0=
|