PHP WebShell

Текущая директория: /usr/lib/node_modules/bitgo/node_modules/@bitgo/sdk-core/dist/src/bitgo/enterprise

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

"use strict";
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.Enterprise = void 0;
/**
 * @prettier
 */
const _ = __importStar(require("lodash"));
const internal_1 = require("../internal");
const wallet_1 = require("../wallet");
const ecdsa_1 = require("../utils/tss/ecdsa");
const sdk_lib_mpc_1 = require("@bitgo/sdk-lib-mpc");
const ecdh_1 = require("../ecdh");
const buffer_1 = require("buffer");
class Enterprise {
    constructor(bitgo, baseCoin, enterpriseData) {
        this.bitgo = bitgo;
        this.baseCoin = baseCoin;
        if (!_.isObject(enterpriseData)) {
            throw new Error('enterpriseData has to be an object');
        }
        if (!_.isString(enterpriseData.id)) {
            throw new Error('enterprise id has to be a string');
        }
        if (!_.isString(enterpriseData.name)) {
            throw new Error('enterprise name has to be a string');
        }
        this._enterprise = enterpriseData;
        this.id = enterpriseData.id;
        this.name = enterpriseData.name;
    }
    /**
     * Enterprise URL for v1 methods, such as getting users
     * @param query
     */
    url(query = '') {
        return this.bitgo.url(`/enterprise/${this.id}${query}`);
    }
    /**
     * Enterprise URL for v2 methods, such as getting fee address balances
     * @param query
     */
    coinUrl(query = '') {
        return this.baseCoin.url(`/enterprise/${this.id}${query}`);
    }
    /**
     * Get the wallets associated with this Enterprise
     * @param params
     */
    async coinWallets(params = {}) {
        if (params.skip && params.prevId) {
            throw new Error('cannot specify both skip and prevId');
        }
        const walletData = (await this.bitgo
            .get(this.baseCoin.url('/wallet/enterprise/' + this.id))
            .query(params)
            .result());
        return walletData.wallets.map((w) => {
            return new wallet_1.Wallet(this.bitgo, this.baseCoin, w);
        });
    }
    /**
     * Get the users associated with this Enterprise
     * @param params
     */
    async users(params = {}) {
        return await this.bitgo.get(this.url('/user')).result();
    }
    /**
     * Get the fee address balance for this Enterprise
     * @param params
     */
    async getFeeAddressBalance(params = {}) {
        return await this.bitgo.get(this.coinUrl('/feeAddressBalance')).result();
    }
    /**
     * Add a user to this Enterprise
     * @param params
     */
    async addUser(params = {}) {
        return await this.bitgo.post(this.url('/user')).send(params).result();
    }
    /**
     * Remove a user from this Enterprise
     * @param params
     */
    async removeUser(params = {}) {
        return await this.bitgo.del(this.url('/user')).send(params).result();
    }
    /**
     * Get the first pending transaction for this Enterprise
     * @param params
     */
    async getFirstPendingTransaction(params = {}) {
        return (0, internal_1.getFirstPendingTransaction)({ enterpriseId: this.id }, this.baseCoin, this.bitgo);
    }
    /**
     * Verifies and signs bitgo proofs for the enterprise
     * @param userPassword - enterprise admin's login password
     */
    async verifyEcdsaBitGoChallengeProofs(userPassword) {
        return ecdsa_1.EcdsaUtils.getVerifyAndSignBitGoChallenges(this.bitgo, this.id, userPassword);
    }
    /**
     * Manages all the challenges and signatures and uploads them to enable
     * ECDSA signing on enterprise. Also generates a client side Ntilde challenge
     * if not provided, but note that can take approx. a minute.
     * @param userPassword
     * @param bitgoInstChallengeProofSignature
     * @param bitgoNitroChallengeProofSignature
     * @param challenge
     */
    async uploadAndEnableTssEcdsaSigning(userPassword, bitgoInstChallengeProofSignature, bitgoNitroChallengeProofSignature, openSSLBytes, challenge) {
        await ecdsa_1.EcdsaUtils.initiateChallengesForEnterprise(this.bitgo, this.id, userPassword, bitgoInstChallengeProofSignature, bitgoNitroChallengeProofSignature, openSSLBytes, challenge);
    }
    /**
     * Fetches the existing TSS ECDSA enterprise challenge if one exists.
     * Can be used with uploadAndEnableTssEcdsaSigning to re-sign the
     * enterprise challenge with new signatures.
     */
    async getExistingTssEcdsaChallenge() {
        const urlPath = `/enterprise/${this.id}/tssconfig`;
        const tssConfig = await this.bitgo.get(this.bitgo.url(urlPath, 2)).send().result();
        const enterpriseChallenge = tssConfig?.ecdsa.challenge?.enterprise;
        if (!enterpriseChallenge) {
            throw new Error('No existing ECDSA challenge on the enterprise.');
        }
        if (!enterpriseChallenge.ntildeProof) {
            throw new Error('Existing ECDSA challenge does not have a proof. Please contact your enterprise admin to set this up.');
        }
        return sdk_lib_mpc_1.EcdsaTypes.deserializeNtildeWithProofs({
            ntilde: enterpriseChallenge.ntilde,
            h1: enterpriseChallenge.h1,
            h2: enterpriseChallenge.h2,
            ntildeProof: enterpriseChallenge.ntildeProof,
        });
    }
    /**
     * Resigns the enterprise and bitgo challenges with a new ECDH keychain.
     * Verifies that the old keychain signed the challenges previously.
     * @param oldEcdhKeypair - the old keychain that signed the challenges
     * @param newEcdhKeypair - the new keychain that will sign the challenges
     * @param entChallenge - existing signed enterprise challenge
     * @param bitgoInstChallenge - existing signed bitgo institutional challenge
     * @param bitgoNitroChallenge - existing signed bitgo nitro challenge
     */
    async resignEnterpriseChallenges(oldEcdhKeypair, newEcdhKeypair, entChallenge, bitgoInstChallenge, bitgoNitroChallenge) {
        // Verify all the challenges were signed by the old keypair
        if (!(0, ecdh_1.verifyEcdhSignature)(ecdsa_1.EcdsaUtils.getMessageToSignFromChallenge(entChallenge), entChallenge.verifiers.adminSignature, buffer_1.Buffer.from(oldEcdhKeypair.derivedPubKey, 'hex'))) {
            throw new Error(`Cannot re-sign. The Enterprise TSS config was signed by another user.`);
        }
        if (!(0, ecdh_1.verifyEcdhSignature)(ecdsa_1.EcdsaUtils.getMessageToSignFromChallenge(bitgoInstChallenge), bitgoInstChallenge.verifiers.adminSignature, buffer_1.Buffer.from(oldEcdhKeypair.derivedPubKey, 'hex'))) {
            throw new Error(`Cannot re-sign. The BitGo Institutional TSS config was signed by another user.`);
        }
        if (!(0, ecdh_1.verifyEcdhSignature)(ecdsa_1.EcdsaUtils.getMessageToSignFromChallenge(bitgoNitroChallenge), bitgoNitroChallenge.verifiers.adminSignature, buffer_1.Buffer.from(oldEcdhKeypair.derivedPubKey, 'hex'))) {
            throw new Error(`Cannot re-sign. The BitGo Nitro TSS config was signed by another user.`);
        }
        // Once all the challenges are verified, we can re-sign them with the new keypair.
        const signedEntChallenge = ecdsa_1.EcdsaUtils.signChallenge(entChallenge, newEcdhKeypair.xprv, newEcdhKeypair.derivationPath);
        const signedBitGoInstChallenge = ecdsa_1.EcdsaUtils.signChallenge(bitgoInstChallenge, newEcdhKeypair.xprv, newEcdhKeypair.derivationPath);
        const signedBitGoNitroChallenge = ecdsa_1.EcdsaUtils.signChallenge(bitgoNitroChallenge, newEcdhKeypair.xprv, newEcdhKeypair.derivationPath);
        await ecdsa_1.EcdsaUtils.uploadChallengesToEnterprise(this.bitgo, this.id, entChallenge, signedEntChallenge.toString('hex'), signedBitGoInstChallenge.toString('hex'), signedBitGoNitroChallenge.toString('hex'));
    }
    /**
     *  Check if the enterprise has a set of featureFlags
     * @param flags
     */
    hasFeatureFlags(flags) {
        return flags.every((targetFlag) => this._enterprise.featureFlags?.includes(targetFlag));
    }
}
exports.Enterprise = Enterprise;
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"enterprise.js","sourceRoot":"","sources":["../../../../src/bitgo/enterprise/enterprise.ts"],"names":[],"mappings":"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","sourcesContent":["/**\n * @prettier\n */\nimport * as _ from 'lodash';\nimport { IBaseCoin } from '../baseCoin';\nimport { BitGoBase } from '../bitgoBase';\nimport { EnterpriseData, EnterpriseFeatureFlag, IEnterprise } from '../enterprise';\nimport { getFirstPendingTransaction } from '../internal';\nimport { ListWalletOptions, Wallet } from '../wallet';\nimport { BitGoProofSignatures, EcdsaUtils, SerializedNtildeWithVerifiers } from '../utils/tss/ecdsa';\nimport { EcdsaTypes } from '@bitgo/sdk-lib-mpc';\nimport { verifyEcdhSignature } from '../ecdh';\nimport { Buffer } from 'buffer';\nimport { EcdhDerivedKeypair } from '../keychain';\n\nexport class Enterprise implements IEnterprise {\n  private readonly bitgo: BitGoBase;\n  private readonly baseCoin: IBaseCoin;\n  public readonly id: string;\n  public readonly name: string;\n  public readonly _enterprise: EnterpriseData;\n\n  constructor(bitgo: BitGoBase, baseCoin: IBaseCoin, enterpriseData: EnterpriseData) {\n    this.bitgo = bitgo;\n    this.baseCoin = baseCoin;\n    if (!_.isObject(enterpriseData)) {\n      throw new Error('enterpriseData has to be an object');\n    }\n    if (!_.isString(enterpriseData.id)) {\n      throw new Error('enterprise id has to be a string');\n    }\n    if (!_.isString(enterpriseData.name)) {\n      throw new Error('enterprise name has to be a string');\n    }\n    this._enterprise = enterpriseData;\n    this.id = enterpriseData.id;\n    this.name = enterpriseData.name;\n  }\n\n  /**\n   * Enterprise URL for v1 methods, such as getting users\n   * @param query\n   */\n  url(query = ''): string {\n    return this.bitgo.url(`/enterprise/${this.id}${query}`);\n  }\n\n  /**\n   * Enterprise URL for v2 methods, such as getting fee address balances\n   * @param query\n   */\n  coinUrl(query = ''): string {\n    return this.baseCoin.url(`/enterprise/${this.id}${query}`);\n  }\n\n  /**\n   * Get the wallets associated with this Enterprise\n   * @param params\n   */\n  async coinWallets(params: ListWalletOptions = {}): Promise<Wallet[]> {\n    if (params.skip && params.prevId) {\n      throw new Error('cannot specify both skip and prevId');\n    }\n\n    const walletData = (await this.bitgo\n      .get(this.baseCoin.url('/wallet/enterprise/' + this.id))\n      .query(params)\n      .result()) as any;\n    return walletData.wallets.map((w) => {\n      return new Wallet(this.bitgo, this.baseCoin, w);\n    });\n  }\n\n  /**\n   * Get the users associated with this Enterprise\n   * @param params\n   */\n  async users(params: Record<string, never> = {}): Promise<any> {\n    return await this.bitgo.get(this.url('/user')).result();\n  }\n\n  /**\n   * Get the fee address balance for this Enterprise\n   * @param params\n   */\n  async getFeeAddressBalance(params: Record<string, never> = {}): Promise<any> {\n    return await this.bitgo.get(this.coinUrl('/feeAddressBalance')).result();\n  }\n\n  /**\n   * Add a user to this Enterprise\n   * @param params\n   */\n  async addUser(params: any = {}): Promise<any> {\n    return await this.bitgo.post(this.url('/user')).send(params).result();\n  }\n\n  /**\n   * Remove a user from this Enterprise\n   * @param params\n   */\n  async removeUser(params: any = {}): Promise<any> {\n    return await this.bitgo.del(this.url('/user')).send(params).result();\n  }\n\n  /**\n   * Get the first pending transaction for this Enterprise\n   * @param params\n   */\n  async getFirstPendingTransaction(params: Record<string, never> = {}): Promise<any> {\n    return getFirstPendingTransaction({ enterpriseId: this.id }, this.baseCoin, this.bitgo);\n  }\n\n  /**\n   * Verifies and signs bitgo proofs for the enterprise\n   * @param userPassword - enterprise admin's login password\n   */\n  async verifyEcdsaBitGoChallengeProofs(userPassword: string): Promise<BitGoProofSignatures> {\n    return EcdsaUtils.getVerifyAndSignBitGoChallenges(this.bitgo, this.id, userPassword);\n  }\n\n  /**\n   * Manages all the challenges and signatures and uploads them to enable\n   * ECDSA signing on enterprise. Also generates a client side Ntilde challenge\n   * if not provided, but note that can take approx. a minute.\n   * @param userPassword\n   * @param bitgoInstChallengeProofSignature\n   * @param bitgoNitroChallengeProofSignature\n   * @param challenge\n   */\n  async uploadAndEnableTssEcdsaSigning(\n    userPassword: string,\n    bitgoInstChallengeProofSignature: Buffer,\n    bitgoNitroChallengeProofSignature: Buffer,\n    openSSLBytes: Uint8Array,\n    challenge?: EcdsaTypes.DeserializedNtildeWithProofs\n  ): Promise<void> {\n    await EcdsaUtils.initiateChallengesForEnterprise(\n      this.bitgo,\n      this.id,\n      userPassword,\n      bitgoInstChallengeProofSignature,\n      bitgoNitroChallengeProofSignature,\n      openSSLBytes,\n      challenge\n    );\n  }\n\n  /**\n   * Fetches the existing TSS ECDSA enterprise challenge if one exists.\n   * Can be used with uploadAndEnableTssEcdsaSigning to re-sign the\n   * enterprise challenge with new signatures.\n   */\n  async getExistingTssEcdsaChallenge(): Promise<EcdsaTypes.DeserializedNtildeWithProofs> {\n    const urlPath = `/enterprise/${this.id}/tssconfig`;\n    const tssConfig = await this.bitgo.get(this.bitgo.url(urlPath, 2)).send().result();\n    const enterpriseChallenge = tssConfig?.ecdsa.challenge?.enterprise;\n    if (!enterpriseChallenge) {\n      throw new Error('No existing ECDSA challenge on the enterprise.');\n    }\n    if (!enterpriseChallenge.ntildeProof) {\n      throw new Error(\n        'Existing ECDSA challenge does not have a proof. Please contact your enterprise admin to set this up.'\n      );\n    }\n    return EcdsaTypes.deserializeNtildeWithProofs({\n      ntilde: enterpriseChallenge.ntilde,\n      h1: enterpriseChallenge.h1,\n      h2: enterpriseChallenge.h2,\n      ntildeProof: enterpriseChallenge.ntildeProof,\n    });\n  }\n\n  /**\n   * Resigns the enterprise and bitgo challenges with a new ECDH keychain.\n   * Verifies that the old keychain signed the challenges previously.\n   * @param oldEcdhKeypair - the old keychain that signed the challenges\n   * @param newEcdhKeypair - the new keychain that will sign the challenges\n   * @param entChallenge - existing signed enterprise challenge\n   * @param bitgoInstChallenge - existing signed bitgo institutional challenge\n   * @param bitgoNitroChallenge - existing signed bitgo nitro challenge\n   */\n  async resignEnterpriseChallenges(\n    oldEcdhKeypair: EcdhDerivedKeypair,\n    newEcdhKeypair: EcdhDerivedKeypair,\n    entChallenge: SerializedNtildeWithVerifiers,\n    bitgoInstChallenge: SerializedNtildeWithVerifiers,\n    bitgoNitroChallenge: SerializedNtildeWithVerifiers\n  ): Promise<void> {\n    // Verify all the challenges were signed by the old keypair\n    if (\n      !verifyEcdhSignature(\n        EcdsaUtils.getMessageToSignFromChallenge(entChallenge),\n        entChallenge.verifiers.adminSignature,\n        Buffer.from(oldEcdhKeypair.derivedPubKey, 'hex')\n      )\n    ) {\n      throw new Error(`Cannot re-sign. The Enterprise TSS config was signed by another user.`);\n    }\n    if (\n      !verifyEcdhSignature(\n        EcdsaUtils.getMessageToSignFromChallenge(bitgoInstChallenge),\n        bitgoInstChallenge.verifiers.adminSignature,\n        Buffer.from(oldEcdhKeypair.derivedPubKey, 'hex')\n      )\n    ) {\n      throw new Error(`Cannot re-sign. The BitGo Institutional TSS config was signed by another user.`);\n    }\n    if (\n      !verifyEcdhSignature(\n        EcdsaUtils.getMessageToSignFromChallenge(bitgoNitroChallenge),\n        bitgoNitroChallenge.verifiers.adminSignature,\n        Buffer.from(oldEcdhKeypair.derivedPubKey, 'hex')\n      )\n    ) {\n      throw new Error(`Cannot re-sign. The BitGo Nitro TSS config was signed by another user.`);\n    }\n\n    // Once all the challenges are verified, we can re-sign them with the new keypair.\n    const signedEntChallenge = EcdsaUtils.signChallenge(\n      entChallenge,\n      newEcdhKeypair.xprv,\n      newEcdhKeypair.derivationPath\n    );\n    const signedBitGoInstChallenge = EcdsaUtils.signChallenge(\n      bitgoInstChallenge,\n      newEcdhKeypair.xprv,\n      newEcdhKeypair.derivationPath\n    );\n    const signedBitGoNitroChallenge = EcdsaUtils.signChallenge(\n      bitgoNitroChallenge,\n      newEcdhKeypair.xprv,\n      newEcdhKeypair.derivationPath\n    );\n    await EcdsaUtils.uploadChallengesToEnterprise(\n      this.bitgo,\n      this.id,\n      entChallenge,\n      signedEntChallenge.toString('hex'),\n      signedBitGoInstChallenge.toString('hex'),\n      signedBitGoNitroChallenge.toString('hex')\n    );\n  }\n\n  /**\n   *  Check if the enterprise has a set of featureFlags\n   * @param flags\n   */\n  hasFeatureFlags(flags: EnterpriseFeatureFlag[]): boolean {\n    return flags.every((targetFlag) => this._enterprise.featureFlags?.includes(targetFlag));\n  }\n}\n"]}

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


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