PHP WebShell

Текущая директория: /opt/BitGoJS/modules/sdk-core/dist/src/bitgo/recovery

Просмотр файла: initiate.js

"use strict";
/**
 * @prettier
 */
Object.defineProperty(exports, "__esModule", { value: true });
exports.getKrsProvider = getKrsProvider;
exports.checkKrsProvider = checkKrsProvider;
exports.getIsKrsRecovery = getIsKrsRecovery;
exports.getIsUnsignedSweep = getIsUnsignedSweep;
exports.validateKey = validateKey;
exports.getBip32Keys = getBip32Keys;
const utxo_lib_1 = require("@bitgo/utxo-lib");
const config_1 = require("../config");
/**
 * @param coin
 * @param krsProviderName
 * @param checkCoinFamilySupport - assert that krsProvider explicitly supports coin
 * @return KrsProvider
 */
function getKrsProvider(coin, krsProviderName, { checkCoinFamilySupport = true } = {}) {
    if (!krsProviderName) {
        throw new Error(`no krsProvider name`);
    }
    const krsProvider = config_1.krsProviders[krsProviderName];
    if (krsProvider === undefined) {
        throw new Error('unknown key recovery service provider');
    }
    if (checkCoinFamilySupport && !krsProvider.supportedCoins.includes(coin.getFamily())) {
        throw new Error('specified key recovery service does not support recoveries for this coin');
    }
    return krsProvider;
}
/**
 * Wrapper for {@see getKrsProvider} returning void
 */
function checkKrsProvider(coin, krsProviderName, options = {}) {
    getKrsProvider(coin, krsProviderName, options);
}
function getIsKrsRecovery({ backupKey, userKey }) {
    return backupKey.startsWith('xpub') && !userKey.startsWith('xpub');
}
function getIsUnsignedSweep({ backupKey, userKey, isTss, }) {
    if (isTss) {
        try {
            return typeof JSON.parse(backupKey) === 'string' && typeof JSON.parse(userKey) === 'string';
        }
        catch (e) {
            return true;
        }
    }
    return backupKey.startsWith('xpub') && userKey.startsWith('xpub');
}
function validateKey(bitgo, { key, source, passphrase, isUnsignedSweep, isKrsRecovery }) {
    if (!key.startsWith('xprv') && !isUnsignedSweep) {
        // Try to decrypt the key
        try {
            if (source === 'user' || (source === 'backup' && !isKrsRecovery)) {
                return utxo_lib_1.bip32.fromBase58(bitgo.decrypt({ password: passphrase, input: key }));
            }
        }
        catch (e) {
            throw new Error(`Failed to decrypt ${source} key with passcode - try again!`);
        }
    }
    try {
        return utxo_lib_1.bip32.fromBase58(key);
    }
    catch (e) {
        throw new Error(`Failed to validate ${source} key - try again!`);
    }
}
function getBip32Keys(bitgo, params, { requireBitGoXpub }) {
    const isKrsRecovery = getIsKrsRecovery(params);
    const isUnsignedSweep = getIsUnsignedSweep(params);
    const keys = [
        // Box A
        validateKey(bitgo, {
            key: params.userKey,
            source: 'user',
            passphrase: params.walletPassphrase,
            isKrsRecovery,
            isUnsignedSweep,
        }),
        // Box B
        validateKey(bitgo, {
            key: params.backupKey,
            source: 'backup',
            passphrase: params.walletPassphrase,
            isKrsRecovery,
            isUnsignedSweep,
        }),
    ];
    if (requireBitGoXpub) {
        if (!params.bitgoKey) {
            throw new Error(`BitGo xpub required but not provided`);
        }
        try {
            // Box C
            keys.push(utxo_lib_1.bip32.fromBase58(params.bitgoKey));
        }
        catch (e) {
            throw new Error('Failed to parse bitgo xpub!');
        }
    }
    return keys;
}
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"initiate.js","sourceRoot":"","sources":["../../../../src/bitgo/recovery/initiate.ts"],"names":[],"mappings":"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","sourcesContent":["/**\n * @prettier\n */\n\nimport { bip32, BIP32Interface } from '@bitgo/utxo-lib';\nimport { BaseCoin } from '../baseCoin';\nimport { BitGoBase } from '../bitgoBase';\nimport { KrsProvider, krsProviders } from '../config';\n\ninterface ValidateKeyOptions {\n  key: string;\n  source: string;\n  passphrase?: string;\n  isUnsignedSweep: boolean;\n  isKrsRecovery: boolean;\n}\n\nexport interface InitiateRecoveryOptions {\n  userKey: string;\n  backupKey: string;\n  bitgoKey?: string; // optional for xrp recoveries\n  recoveryDestination: string;\n  walletPassphrase?: string;\n}\n\nexport interface InitiateConsolidationRecoveryOptions {\n  userKey: string;\n  backupKey: string;\n  bitgoKey?: string;\n  walletPassphrase?: string;\n}\n\ntype GetKrsProviderOptions = { checkCoinFamilySupport?: boolean };\n\n/**\n * @param coin\n * @param krsProviderName\n * @param checkCoinFamilySupport - assert that krsProvider explicitly supports coin\n * @return KrsProvider\n */\nexport function getKrsProvider(\n  coin: BaseCoin,\n  krsProviderName: string | undefined,\n  { checkCoinFamilySupport = true }: GetKrsProviderOptions = {}\n): KrsProvider {\n  if (!krsProviderName) {\n    throw new Error(`no krsProvider name`);\n  }\n\n  const krsProvider = krsProviders[krsProviderName];\n\n  if (krsProvider === undefined) {\n    throw new Error('unknown key recovery service provider');\n  }\n\n  if (checkCoinFamilySupport && !krsProvider.supportedCoins.includes(coin.getFamily())) {\n    throw new Error('specified key recovery service does not support recoveries for this coin');\n  }\n\n  return krsProvider;\n}\n\n/**\n * Wrapper for {@see getKrsProvider} returning void\n */\nexport function checkKrsProvider(\n  coin: BaseCoin,\n  krsProviderName: string | undefined,\n  options: GetKrsProviderOptions = {}\n): void {\n  getKrsProvider(coin, krsProviderName, options);\n}\n\nexport function getIsKrsRecovery({ backupKey, userKey }: { backupKey: string; userKey: string }): boolean {\n  return backupKey.startsWith('xpub') && !userKey.startsWith('xpub');\n}\n\nexport function getIsUnsignedSweep({\n  backupKey,\n  userKey,\n  isTss,\n}: {\n  backupKey: string;\n  userKey: string;\n  isTss?: boolean;\n}): boolean {\n  if (isTss) {\n    try {\n      return typeof JSON.parse(backupKey) === 'string' && typeof JSON.parse(userKey) === 'string';\n    } catch (e) {\n      return true;\n    }\n  }\n  return backupKey.startsWith('xpub') && userKey.startsWith('xpub');\n}\n\nexport function validateKey(\n  bitgo: BitGoBase,\n  { key, source, passphrase, isUnsignedSweep, isKrsRecovery }: ValidateKeyOptions\n): BIP32Interface {\n  if (!key.startsWith('xprv') && !isUnsignedSweep) {\n    // Try to decrypt the key\n    try {\n      if (source === 'user' || (source === 'backup' && !isKrsRecovery)) {\n        return bip32.fromBase58(bitgo.decrypt({ password: passphrase, input: key }));\n      }\n    } catch (e) {\n      throw new Error(`Failed to decrypt ${source} key with passcode - try again!`);\n    }\n  }\n  try {\n    return bip32.fromBase58(key);\n  } catch (e) {\n    throw new Error(`Failed to validate ${source} key - try again!`);\n  }\n}\n\nexport function getBip32Keys(\n  bitgo: BitGoBase,\n  params: InitiateRecoveryOptions | InitiateConsolidationRecoveryOptions,\n  { requireBitGoXpub }: { requireBitGoXpub: boolean }\n): BIP32Interface[] {\n  const isKrsRecovery = getIsKrsRecovery(params);\n  const isUnsignedSweep = getIsUnsignedSweep(params);\n  const keys = [\n    // Box A\n    validateKey(bitgo, {\n      key: params.userKey,\n      source: 'user',\n      passphrase: params.walletPassphrase,\n      isKrsRecovery,\n      isUnsignedSweep,\n    }),\n    // Box B\n    validateKey(bitgo, {\n      key: params.backupKey,\n      source: 'backup',\n      passphrase: params.walletPassphrase,\n      isKrsRecovery,\n      isUnsignedSweep,\n    }),\n  ];\n\n  if (requireBitGoXpub) {\n    if (!params.bitgoKey) {\n      throw new Error(`BitGo xpub required but not provided`);\n    }\n    try {\n      // Box C\n      keys.push(bip32.fromBase58(params.bitgoKey));\n    } catch (e) {\n      throw new Error('Failed to parse bitgo xpub!');\n    }\n  }\n\n  return keys;\n}\n"]}

Выполнить команду


Для локальной разработки. Не используйте в интернете!