PHP WebShell
Текущая директория: /opt/BitGoJS/modules/express/dist
Просмотр файла: fetchEncryptedPrivKeys.js
"use strict";
Object.defineProperty(exports, "__esModule", { value: true });
exports.fetchKeys = fetchKeys;
/**
* This tool will help you creates a private key JSON file to be used with the external singing mode feature.
* It creates a JSON file containing a list of wallet IDs and their corresponding encrypted user private keys.
*
* To run this file, use the command:
* `yarn ts-node <path/to/fetchEncryptedPrivKeys.ts>`
*
* Copyright 2022, BitGo, Inc. All Rights Reserved.
*/
const fs_1 = require("fs");
const bitgo_1 = require("bitgo");
require("dotenv/config");
const esAccessToken = process.env.BITGO_EXTERNAL_SIGNER_ACCESS_TOKEN;
const esWalletIDs = process.env.BITGO_EXTERNAL_SIGNER_WALLET_IDS; // example: "{"tbtc":[{"walletId":"xxx","walletPassword":"xxx","secret":"xxx"}],"hteth":["walletId":"xxx","walletPassword":"xxx"]}"
const esWalletWithPrv = process.env.BITGO_EXTERNAL_SIGNER_WALLET_IDS_WITH_PRV; // example: "[{"walletId":"xxx","encryptedPrv":"xxx"}]"
// TODO: set env to 'test' or 'prod'
const bg = new bitgo_1.BitGo({ env: process.env.BITGO_EXTERNAL_SIGNER_ENV ?? 'test' });
// TODO: set your access token here
const accessToken = esAccessToken || '';
// TODO: set your coin type and wallet ids here e.g.
const walletIds = esWalletIDs ? JSON.parse(esWalletIDs) : {};
// {
// tbtc: ['61f039aad587c2000745c687373e0111', '6225b081cd291300071fed36b1362222'],
// tbtc: [{
// walletId: '<WALLET_ID>',
// walletPassword: '<WALLET_PASSWORD>',
// secret: 'xprv...',
// }],
// gteth: ['61fb21819c54dd000755f8de3a18e333'],
// };
// TODO: set walletId and encryptedPrv here e.g.
const walletWithPrv = esWalletWithPrv ? JSON.parse(esWalletWithPrv) : [];
// [
// {
// walletId: '<WALLET_ID>',
// encryptedPrv: '<ENCRYPTED_PRV>',
// },
// ];
async function fetchKeys(ids, token, accessToken) {
bg.authenticateWithAccessToken({ accessToken: token });
// get the encrypted user privKey for each walletId and store in the JSON output
const output = {};
for (const [coinName, credentials] of Object.entries(ids)) {
const coin = bg.coin(coinName);
for (const credential of credentials) {
const id = typeof credential === 'string' ? credential : credential.walletId;
const wallet = await coin.wallets().get({ id });
const userKeyId = wallet.keyIds()[0];
const keychain = await coin.keychains().get({ id: userKeyId });
if (keychain.encryptedPrv === undefined) {
if (typeof credential === 'object') {
const encryptedPrv = bg.encrypt({ password: credential.walletPassword, input: credential.secret });
output[id] = encryptedPrv;
}
else {
console.warn(`could not find a ${coinName} encrypted user private key for wallet id ${id}, skipping`);
continue;
}
}
else {
output[id] = keychain.encryptedPrv;
}
}
}
for (const { walletId, encryptedPrv } of walletWithPrv) {
output[walletId] = encryptedPrv;
}
const data = JSON.stringify(output, null, '\t');
const fileName = 'encryptedPrivKeys.json';
(0, fs_1.writeFile)(fileName, data, (err) => {
if (err) {
throw err;
}
console.log(`Wallet IDs and encrypted private keys saved to ${fileName}`);
});
return Promise.resolve(output);
}
fetchKeys(walletIds, accessToken).catch((e) => console.error(e));
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"fetchEncryptedPrivKeys.js","sourceRoot":"","sources":["../src/fetchEncryptedPrivKeys.ts"],"names":[],"mappings":"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","sourcesContent":["/**\n * This tool will help you creates a private key JSON file to be used with the external singing mode feature.\n * It creates a JSON file containing a list of wallet IDs and their corresponding encrypted user private keys.\n *\n * To run this file, use the command:\n * `yarn ts-node <path/to/fetchEncryptedPrivKeys.ts>`\n *\n * Copyright 2022, BitGo, Inc.  All Rights Reserved.\n */\nimport { writeFile } from 'fs';\nimport { BitGo, EnvironmentName } from 'bitgo';\nimport 'dotenv/config';\n\ntype Output = {\n  [key: string]: string;\n};\n\ntype Credentials = {\n  walletId: string; // Id of the BitGo wallet.\n  walletPassword: string; // Password used for the wallet.\n  secret: string; // xprv of user key or backup key.\n};\n\ntype WalletIds = {\n  [key: string]: (string | Credentials)[];\n};\n\ntype WalletWithPrv = Array<{\n  walletId: string;\n  encryptedPrv: string;\n}>;\n\nconst esAccessToken = process.env.BITGO_EXTERNAL_SIGNER_ACCESS_TOKEN;\nconst esWalletIDs = process.env.BITGO_EXTERNAL_SIGNER_WALLET_IDS; // example: \"{\"tbtc\":[{\"walletId\":\"xxx\",\"walletPassword\":\"xxx\",\"secret\":\"xxx\"}],\"hteth\":[\"walletId\":\"xxx\",\"walletPassword\":\"xxx\"]}\"\nconst esWalletWithPrv = process.env.BITGO_EXTERNAL_SIGNER_WALLET_IDS_WITH_PRV; // example: \"[{\"walletId\":\"xxx\",\"encryptedPrv\":\"xxx\"}]\"\n\n// TODO: set env to 'test' or 'prod'\nconst bg = new BitGo({ env: (process.env.BITGO_EXTERNAL_SIGNER_ENV as EnvironmentName) ?? 'test' });\n\n// TODO: set your access token here\nconst accessToken = esAccessToken || '';\n\n// TODO: set your coin type and wallet ids here e.g.\nconst walletIds: WalletIds = esWalletIDs ? JSON.parse(esWalletIDs) : {};\n// {\n// tbtc: ['61f039aad587c2000745c687373e0111', '6225b081cd291300071fed36b1362222'],\n// tbtc: [{\n// walletId: '<WALLET_ID>',\n// walletPassword: '<WALLET_PASSWORD>',\n// secret: 'xprv...',\n// }],\n// gteth: ['61fb21819c54dd000755f8de3a18e333'],\n// };\n\n// TODO: set walletId and encryptedPrv here e.g.\nconst walletWithPrv: WalletWithPrv = esWalletWithPrv ? JSON.parse(esWalletWithPrv) : [];\n// [\n//   {\n//     walletId: '<WALLET_ID>',\n//     encryptedPrv: '<ENCRYPTED_PRV>',\n//   },\n// ];\n\nexport async function fetchKeys(ids: WalletIds, token: string, accessToken?: string): Promise<Record<string, string>> {\n  bg.authenticateWithAccessToken({ accessToken: token });\n\n  // get the encrypted user privKey for each walletId and store in the JSON output\n  const output: Output = {};\n  for (const [coinName, credentials] of Object.entries(ids)) {\n    const coin = bg.coin(coinName);\n    for (const credential of credentials) {\n      const id = typeof credential === 'string' ? credential : credential.walletId;\n      const wallet = await coin.wallets().get({ id });\n      const userKeyId = wallet.keyIds()[0];\n      const keychain = await coin.keychains().get({ id: userKeyId });\n\n      if (keychain.encryptedPrv === undefined) {\n        if (typeof credential === 'object') {\n          const encryptedPrv = bg.encrypt({ password: credential.walletPassword, input: credential.secret });\n          output[id] = encryptedPrv;\n        } else {\n          console.warn(`could not find a ${coinName} encrypted user private key for wallet id ${id}, skipping`);\n          continue;\n        }\n      } else {\n        output[id] = keychain.encryptedPrv;\n      }\n    }\n  }\n\n  for (const { walletId, encryptedPrv } of walletWithPrv) {\n    output[walletId] = encryptedPrv;\n  }\n\n  const data = JSON.stringify(output, null, '\\t');\n  const fileName = 'encryptedPrivKeys.json';\n  writeFile(fileName, data, (err) => {\n    if (err) {\n      throw err;\n    }\n    console.log(`Wallet IDs and encrypted private keys saved to ${fileName}`);\n  });\n\n  return Promise.resolve(output);\n}\n\nfetchKeys(walletIds, accessToken).catch((e) => console.error(e));\n"]}Выполнить команду
Для локальной разработки. Не используйте в интернете!