bitgo
Version:
BitGo JavaScript SDK
126 lines • 19.6 kB
JavaScript
"use strict";
//
// Tests for enterprises
//
Object.defineProperty(exports, "__esModule", { value: true });
const nock = require("nock");
const sinon = require("sinon");
const sdk_core_1 = require("@bitgo/sdk-core");
const sdk_test_1 = require("@bitgo/sdk-test");
const bitgo_1 = require("../../../src/bitgo");
const ecdsaNtilde_1 = require("./internal/tssUtils/mocks/ecdsaNtilde");
const utxo_lib_1 = require("@bitgo/utxo-lib");
describe('Enterprise:', function () {
let bitgo;
let enterprise;
let baseCoin;
let bgUrl;
before(function () {
bitgo = sdk_test_1.TestBitGo.decorate(bitgo_1.BitGo, { env: 'test' });
bitgo.initializeTestVars();
baseCoin = bitgo.coin('tbtc');
enterprise = new sdk_core_1.Enterprise(bitgo, baseCoin, { id: '593f1ece99d37c23080a557283edcc89', name: 'Test Enterprise' });
bgUrl = sdk_core_1.common.Environments[bitgo.getEnv()].uri;
});
describe('Transaction data', function () {
it('should search for pending transaction correctly', async function () {
const params = { enterpriseId: enterprise.id };
const scope = nock(bgUrl).get('/api/v2/tbtc/tx/pending/first').query(params).reply(200);
await enterprise.getFirstPendingTransaction().should.be.resolved();
scope.isDone().should.be.True();
});
});
it('should fetch the tss config correctly', async function () {
const scope = nock(bgUrl)
.get(`/api/v2/enterprise/${enterprise.id}/tssconfig`)
.reply(200, {
ecdsa: {
challenge: {
enterprise: {
...ecdsaNtilde_1.mockChallengeA,
verifiers: {
adminSignature: 'hex sig',
},
},
},
},
});
await enterprise.getExistingTssEcdsaChallenge().should.be.resolved();
scope.isDone().should.be.True();
});
describe('Resign enterprise challenge', function () {
const bitgo = sdk_test_1.TestBitGo.decorate(bitgo_1.BitGo, { env: 'mock' });
const enterprise = new sdk_core_1.Enterprise(bitgo, bitgo.coin('tbtc'), { id: '123', name: 'Test Enterprise' });
const oldAdminEcdhKey = bitgo.keychains().create();
const oldAdminDerivationPath = 'm/0/0';
const newAdminEcdhKey = bitgo.keychains().create();
const newAdminDerivationPath = 'm/0/1';
const entChallenge = {
ntilde: 'ent ntilde',
h1: 'ent h1',
h2: 'ent h2',
};
const bitgoChallenge = {
ntilde: 'bitgo ntilde',
h1: 'bitgo h1',
h2: 'bitgo h2',
};
const signedEntChallenge = sdk_core_1.ECDSAUtils.EcdsaUtils.signChallenge(entChallenge, oldAdminEcdhKey.xprv, oldAdminDerivationPath);
const signedBitgoChallenge = sdk_core_1.ECDSAUtils.EcdsaUtils.signChallenge(bitgoChallenge, oldAdminEcdhKey.xprv, oldAdminDerivationPath);
const newSignedEntChallenge = sdk_core_1.ECDSAUtils.EcdsaUtils.signChallenge(entChallenge, newAdminEcdhKey.xprv, newAdminDerivationPath);
const newSignedBitgoChallenge = sdk_core_1.ECDSAUtils.EcdsaUtils.signChallenge(bitgoChallenge, newAdminEcdhKey.xprv, newAdminDerivationPath);
const entChallengeWithVerifiers = {
...entChallenge,
verifiers: {
adminSignature: signedEntChallenge.toString('hex'),
},
};
const bitgoChallengeWithVerifier = {
...bitgoChallenge,
verifiers: {
adminSignature: signedBitgoChallenge.toString('hex'),
},
};
it('should verify and resign enterprise challenge', async function () {
const stubuUploadChallenges = sinon.stub(sdk_core_1.ECDSAUtils.EcdsaUtils, 'uploadChallengesToEnterprise');
await enterprise
.resignEnterpriseChallenges({
xprv: oldAdminEcdhKey.xprv,
derivationPath: oldAdminDerivationPath,
derivedPubKey: utxo_lib_1.bip32
.fromBase58(oldAdminEcdhKey.xpub)
.derivePath(oldAdminDerivationPath)
.publicKey.toString('hex'),
}, {
xprv: newAdminEcdhKey.xprv,
derivationPath: newAdminDerivationPath,
derivedPubKey: utxo_lib_1.bip32
.fromBase58(newAdminEcdhKey.xpub)
.derivePath(newAdminDerivationPath)
.publicKey.toString('hex'),
}, entChallengeWithVerifiers, bitgoChallengeWithVerifier, bitgoChallengeWithVerifier)
.should.not.be.rejected();
stubuUploadChallenges.should.be.calledWith(bitgo, '123', entChallengeWithVerifiers, newSignedEntChallenge.toString('hex'), newSignedBitgoChallenge.toString('hex'), newSignedBitgoChallenge.toString('hex'));
});
it('should fail when the old ecdh keychain is incorrect', async function () {
await enterprise
.resignEnterpriseChallenges({
xprv: newAdminEcdhKey.xprv,
derivationPath: newAdminDerivationPath,
derivedPubKey: utxo_lib_1.bip32
.fromBase58(newAdminEcdhKey.xpub)
.derivePath(newAdminDerivationPath)
.publicKey.toString('hex'),
}, {
xprv: newAdminEcdhKey.xprv,
derivationPath: newAdminDerivationPath,
derivedPubKey: utxo_lib_1.bip32
.fromBase58(newAdminEcdhKey.xpub)
.derivePath(newAdminDerivationPath)
.publicKey.toString('hex'),
}, entChallengeWithVerifiers, bitgoChallengeWithVerifier, bitgoChallengeWithVerifier)
.should.be.rejectedWith('Cannot re-sign. The Enterprise TSS config was signed by another user.');
});
});
});
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"enterprise.js","sourceRoot":"","sources":["../../../../test/v2/unit/enterprise.ts"],"names":[],"mappings":"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","sourcesContent":["//\n// Tests for enterprises\n//\n\nimport nock = require('nock');\nimport * as sinon from 'sinon';\nimport { common, ECDSAUtils, Enterprise } from '@bitgo/sdk-core';\n\nimport { TestBitGo } from '@bitgo/sdk-test';\nimport { BitGo } from '../../../src/bitgo';\nimport { mockChallengeA } from './internal/tssUtils/mocks/ecdsaNtilde';\nimport { bip32 } from '@bitgo/utxo-lib';\n\ndescribe('Enterprise:', function () {\n  let bitgo;\n  let enterprise;\n  let baseCoin;\n  let bgUrl;\n\n  before(function () {\n    bitgo = TestBitGo.decorate(BitGo, { env: 'test' });\n    bitgo.initializeTestVars();\n    baseCoin = bitgo.coin('tbtc');\n    enterprise = new Enterprise(bitgo, baseCoin, { id: '593f1ece99d37c23080a557283edcc89', name: 'Test Enterprise' });\n    bgUrl = common.Environments[bitgo.getEnv()].uri;\n  });\n\n  describe('Transaction data', function () {\n    it('should search for pending transaction correctly', async function () {\n      const params = { enterpriseId: enterprise.id };\n      const scope = nock(bgUrl).get('/api/v2/tbtc/tx/pending/first').query(params).reply(200);\n      await enterprise.getFirstPendingTransaction().should.be.resolved();\n      scope.isDone().should.be.True();\n    });\n  });\n\n  it('should fetch the tss config correctly', async function () {\n    const scope = nock(bgUrl)\n      .get(`/api/v2/enterprise/${enterprise.id}/tssconfig`)\n      .reply(200, {\n        ecdsa: {\n          challenge: {\n            enterprise: {\n              ...mockChallengeA,\n              verifiers: {\n                adminSignature: 'hex sig',\n              },\n            },\n          },\n        },\n      });\n    await enterprise.getExistingTssEcdsaChallenge().should.be.resolved();\n    scope.isDone().should.be.True();\n  });\n\n  describe('Resign enterprise challenge', function () {\n    const bitgo = TestBitGo.decorate(BitGo, { env: 'mock' });\n    const enterprise = new Enterprise(bitgo, bitgo.coin('tbtc'), { id: '123', name: 'Test Enterprise' });\n\n    const oldAdminEcdhKey = bitgo.keychains().create();\n    const oldAdminDerivationPath = 'm/0/0';\n\n    const newAdminEcdhKey = bitgo.keychains().create();\n    const newAdminDerivationPath = 'm/0/1';\n\n    const entChallenge = {\n      ntilde: 'ent ntilde',\n      h1: 'ent h1',\n      h2: 'ent h2',\n    };\n    const bitgoChallenge = {\n      ntilde: 'bitgo ntilde',\n      h1: 'bitgo h1',\n      h2: 'bitgo h2',\n    };\n\n    const signedEntChallenge = ECDSAUtils.EcdsaUtils.signChallenge(\n      entChallenge,\n      oldAdminEcdhKey.xprv,\n      oldAdminDerivationPath\n    );\n\n    const signedBitgoChallenge = ECDSAUtils.EcdsaUtils.signChallenge(\n      bitgoChallenge,\n      oldAdminEcdhKey.xprv,\n      oldAdminDerivationPath\n    );\n\n    const newSignedEntChallenge = ECDSAUtils.EcdsaUtils.signChallenge(\n      entChallenge,\n      newAdminEcdhKey.xprv,\n      newAdminDerivationPath\n    );\n\n    const newSignedBitgoChallenge = ECDSAUtils.EcdsaUtils.signChallenge(\n      bitgoChallenge,\n      newAdminEcdhKey.xprv,\n      newAdminDerivationPath\n    );\n\n    const entChallengeWithVerifiers: ECDSAUtils.SerializedNtildeWithVerifiers = {\n      ...entChallenge,\n      verifiers: {\n        adminSignature: signedEntChallenge.toString('hex'),\n      },\n    };\n    const bitgoChallengeWithVerifier: ECDSAUtils.SerializedNtildeWithVerifiers = {\n      ...bitgoChallenge,\n      verifiers: {\n        adminSignature: signedBitgoChallenge.toString('hex'),\n      },\n    };\n\n    it('should verify and resign enterprise challenge', async function () {\n      const stubuUploadChallenges = sinon.stub(ECDSAUtils.EcdsaUtils, 'uploadChallengesToEnterprise');\n      await enterprise\n        .resignEnterpriseChallenges(\n          {\n            xprv: oldAdminEcdhKey.xprv,\n            derivationPath: oldAdminDerivationPath,\n            derivedPubKey: bip32\n              .fromBase58(oldAdminEcdhKey.xpub)\n              .derivePath(oldAdminDerivationPath)\n              .publicKey.toString('hex'),\n          },\n          {\n            xprv: newAdminEcdhKey.xprv,\n            derivationPath: newAdminDerivationPath,\n            derivedPubKey: bip32\n              .fromBase58(newAdminEcdhKey.xpub)\n              .derivePath(newAdminDerivationPath)\n              .publicKey.toString('hex'),\n          },\n          entChallengeWithVerifiers,\n          bitgoChallengeWithVerifier,\n          bitgoChallengeWithVerifier\n        )\n        .should.not.be.rejected();\n      stubuUploadChallenges.should.be.calledWith(\n        bitgo,\n        '123',\n        entChallengeWithVerifiers,\n        newSignedEntChallenge.toString('hex'),\n        newSignedBitgoChallenge.toString('hex'),\n        newSignedBitgoChallenge.toString('hex')\n      );\n    });\n\n    it('should fail when the old ecdh keychain is incorrect', async function () {\n      await enterprise\n        .resignEnterpriseChallenges(\n          {\n            xprv: newAdminEcdhKey.xprv,\n            derivationPath: newAdminDerivationPath,\n            derivedPubKey: bip32\n              .fromBase58(newAdminEcdhKey.xpub)\n              .derivePath(newAdminDerivationPath)\n              .publicKey.toString('hex'),\n          },\n          {\n            xprv: newAdminEcdhKey.xprv,\n            derivationPath: newAdminDerivationPath,\n            derivedPubKey: bip32\n              .fromBase58(newAdminEcdhKey.xpub)\n              .derivePath(newAdminDerivationPath)\n              .publicKey.toString('hex'),\n          },\n          entChallengeWithVerifiers,\n          bitgoChallengeWithVerifier,\n          bitgoChallengeWithVerifier\n        )\n        .should.be.rejectedWith('Cannot re-sign. The Enterprise TSS config was signed by another user.');\n    });\n  });\n});\n"]}