@bitgo/utxo-bin
Version:
Command-line utility for BitGo UTXO transactions
153 lines • 14.6 kB
JavaScript
;
var __createBinding = (this && this.__createBinding) || (Object.create ? (function(o, m, k, k2) {
if (k2 === undefined) k2 = k;
var desc = Object.getOwnPropertyDescriptor(m, k);
if (!desc || ("get" in desc ? !m.__esModule : desc.writable || desc.configurable)) {
desc = { enumerable: true, get: function() { return m[k]; } };
}
Object.defineProperty(o, k2, desc);
}) : (function(o, m, k, k2) {
if (k2 === undefined) k2 = k;
o[k2] = m[k];
}));
var __setModuleDefault = (this && this.__setModuleDefault) || (Object.create ? (function(o, v) {
Object.defineProperty(o, "default", { enumerable: true, value: v });
}) : function(o, v) {
o["default"] = v;
});
var __importStar = (this && this.__importStar) || (function () {
var ownKeys = function(o) {
ownKeys = Object.getOwnPropertyNames || function (o) {
var ar = [];
for (var k in o) if (Object.prototype.hasOwnProperty.call(o, k)) ar[ar.length] = k;
return ar;
};
return ownKeys(o);
};
return function (mod) {
if (mod && mod.__esModule) return mod;
var result = {};
if (mod != null) for (var k = ownKeys(mod), i = 0; i < k.length; i++) if (k[i] !== "default") __createBinding(result, mod, k[i]);
__setModuleDefault(result, mod);
return result;
};
})();
Object.defineProperty(exports, "__esModule", { value: true });
exports.readStringOptions = void 0;
exports.stringToBuffer = stringToBuffer;
exports.readStdin = readStdin;
exports.argToString = argToString;
const process = __importStar(require("process"));
const fs = __importStar(require("fs"));
function stringToBuffer(data, format) {
if (typeof format !== 'string') {
for (const f of format) {
try {
return stringToBuffer(data, f);
}
catch (err) {
// ignore, try next
}
}
throw new Error(`could not parse data, formats: ${format}`);
}
// strip all whitespace
data = data.replace(/\s*/g, '');
if (format === 'hex') {
data = data.toLowerCase();
}
const buf = Buffer.from(data, format);
// make sure there were no decoding errors
if (buf.toString(format) !== data) {
throw new Error(`invalid ${format}`);
}
return buf;
}
exports.readStringOptions = {
path: { type: 'string', nargs: 1, default: '' },
stdin: { type: 'boolean', default: false },
data: {
type: 'string',
description: 'hex or base64',
alias: 'hex',
},
clipboard: { type: 'boolean', default: false },
};
/**
* Reads from stdin until Ctrl-D is pressed.
*/
async function readStdin() {
/*
* High-performance implementation of reading from stdin.
* Standard readline is extremely slow for long lines.
*/
return new Promise((resolve, reject) => {
// Using readline is not an option because it is extremely slow for long lines.
// By enabling raw mode, we can read more than 4096 bytes, but it requires manual Ctrl-C/Ctrl-D handling
if (!process.stdin.setRawMode) {
throw new Error('stdin is not a tty');
}
process.stdin.setRawMode(true);
const buf = [];
process.stdin.on('data', (chunk) => {
if (chunk[0] === 0x03) {
// Ctrl-C
process.exit(130);
}
if (chunk[0] === 0x04) {
// Ctrl-D
process.stdin.emit('end');
return;
}
buf.push(chunk);
process.stdout.write(chunk);
});
process.stdin.on('end', () => {
resolve(Buffer.concat(buf).toString('utf8'));
});
process.stdin.on('error', (err) => {
reject(err);
});
});
}
/**
* @param argv
* @param input - optional input data. If set, this function just ensures that nothing else is set.
* @return string from specified source
*/
async function argToString(argv, input) {
if (argv.stdin || argv.path === '-') {
if (input) {
throw new Error(`conflicting arguments`);
}
console.log('Reading from stdin. Please paste hex-encoded transaction data.');
console.log('After inserting data, press Ctrl-D to finish. Press Ctrl-C to cancel.');
if (process.stdin.isTTY) {
input = await readStdin();
}
else {
input = await fs.promises.readFile('/dev/stdin', 'utf8');
}
}
if (argv.clipboard) {
if (input) {
throw new Error(`conflicting arguments`);
}
const { default: clipboardy } = await import('clipboardy');
input = await clipboardy.read();
}
if (argv.path) {
if (input) {
throw new Error(`conflicting arguments`);
}
input = (await fs.promises.readFile(argv.path, 'utf8')).toString();
}
if (argv.data) {
if (input) {
throw new Error(`conflicting arguments`);
}
input = argv.data;
}
return input;
}
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"parseString.js","sourceRoot":"","sources":["../../../src/args/parseString.ts"],"names":[],"mappings":"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","sourcesContent":["import * as process from 'process';\nimport * as fs from 'fs';\n\ntype Format = 'hex' | 'base64';\nexport function stringToBuffer(data: string, format: Format | Format[]): Buffer {\n  if (typeof format !== 'string') {\n    for (const f of format) {\n      try {\n        return stringToBuffer(data, f);\n      } catch (err) {\n        // ignore, try next\n      }\n    }\n    throw new Error(`could not parse data, formats: ${format}`);\n  }\n\n  // strip all whitespace\n  data = data.replace(/\\s*/g, '');\n\n  if (format === 'hex') {\n    data = data.toLowerCase();\n  }\n\n  const buf = Buffer.from(data, format);\n  // make sure there were no decoding errors\n  if (buf.toString(format) !== data) {\n    throw new Error(`invalid ${format}`);\n  }\n  return buf;\n}\n\nexport const readStringOptions = {\n  path: { type: 'string', nargs: 1, default: '' },\n  stdin: { type: 'boolean', default: false },\n  data: {\n    type: 'string',\n    description: 'hex or base64',\n    alias: 'hex',\n  },\n  clipboard: { type: 'boolean', default: false },\n} as const;\n\nexport type ReadStringOptions = {\n  clipboard?: boolean;\n  path?: string;\n  data?: string;\n  stdin: boolean;\n};\n\n/**\n * Reads from stdin until Ctrl-D is pressed.\n */\nexport async function readStdin(): Promise<string> {\n  /*\n   * High-performance implementation of reading from stdin.\n   * Standard readline is extremely slow for long lines.\n   */\n  return new Promise((resolve, reject) => {\n    // Using readline is not an option because it is extremely slow for long lines.\n    // By enabling raw mode, we can read more than 4096 bytes, but it requires manual Ctrl-C/Ctrl-D handling\n    if (!process.stdin.setRawMode) {\n      throw new Error('stdin is not a tty');\n    }\n    process.stdin.setRawMode(true);\n    const buf: Buffer[] = [];\n\n    process.stdin.on('data', (chunk) => {\n      if (chunk[0] === 0x03) {\n        // Ctrl-C\n        process.exit(130);\n      }\n      if (chunk[0] === 0x04) {\n        // Ctrl-D\n        process.stdin.emit('end');\n        return;\n      }\n      buf.push(chunk);\n      process.stdout.write(chunk);\n    });\n\n    process.stdin.on('end', () => {\n      resolve(Buffer.concat(buf).toString('utf8'));\n    });\n\n    process.stdin.on('error', (err) => {\n      reject(err);\n    });\n  });\n}\n\n/**\n * @param argv\n * @param input - optional input data. If set, this function just ensures that nothing else is set.\n * @return string from specified source\n */\nexport async function argToString(argv: ReadStringOptions, input?: string): Promise<string | undefined> {\n  if (argv.stdin || argv.path === '-') {\n    if (input) {\n      throw new Error(`conflicting arguments`);\n    }\n    console.log('Reading from stdin. Please paste hex-encoded transaction data.');\n    console.log('After inserting data, press Ctrl-D to finish. Press Ctrl-C to cancel.');\n    if (process.stdin.isTTY) {\n      input = await readStdin();\n    } else {\n      input = await fs.promises.readFile('/dev/stdin', 'utf8');\n    }\n  }\n\n  if (argv.clipboard) {\n    if (input) {\n      throw new Error(`conflicting arguments`);\n    }\n    const { default: clipboardy } = await import('clipboardy');\n    input = await clipboardy.read();\n  }\n\n  if (argv.path) {\n    if (input) {\n      throw new Error(`conflicting arguments`);\n    }\n    input = (await fs.promises.readFile(argv.path, 'utf8')).toString();\n  }\n\n  if (argv.data) {\n    if (input) {\n      throw new Error(`conflicting arguments`);\n    }\n    input = argv.data;\n  }\n\n  return input;\n}\n"]}