@bitgo-beta/sdk-core 8.2.1-beta.7 → 8.2.1-beta.9
This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
- package/dist/src/account-lib/mpc/tss/ecdsa/ecdsa.d.ts +8 -5
- package/dist/src/account-lib/mpc/tss/ecdsa/ecdsa.d.ts.map +1 -1
- package/dist/src/account-lib/mpc/tss/ecdsa/ecdsa.js +8 -41
- package/dist/src/account-lib/mpc/tss/ecdsa/types.d.ts +26 -104
- package/dist/src/account-lib/mpc/tss/ecdsa/types.d.ts.map +1 -1
- package/dist/src/account-lib/mpc/tss/ecdsa/types.js +1 -1
- package/dist/src/account-lib/util/crypto.d.ts +5 -25
- package/dist/src/account-lib/util/crypto.d.ts.map +1 -1
- package/dist/src/account-lib/util/crypto.js +10 -55
- package/dist/src/bitgo/enterprise/enterprise.d.ts +3 -3
- package/dist/src/bitgo/enterprise/enterprise.d.ts.map +1 -1
- package/dist/src/bitgo/enterprise/enterprise.js +7 -6
- package/dist/src/bitgo/enterprise/iEnterprise.d.ts +3 -3
- package/dist/src/bitgo/enterprise/iEnterprise.d.ts.map +1 -1
- package/dist/src/bitgo/enterprise/iEnterprise.js +1 -1
- package/dist/src/bitgo/tss/common.d.ts +4 -5
- package/dist/src/bitgo/tss/common.d.ts.map +1 -1
- package/dist/src/bitgo/tss/common.js +1 -1
- package/dist/src/bitgo/utils/tss/ecdsa/ecdsa.d.ts +5 -5
- package/dist/src/bitgo/utils/tss/ecdsa/ecdsa.d.ts.map +1 -1
- package/dist/src/bitgo/utils/tss/ecdsa/ecdsa.js +25 -17
- package/dist/src/bitgo/utils/tss/ecdsa/types.d.ts +4 -3
- package/dist/src/bitgo/utils/tss/ecdsa/types.d.ts.map +1 -1
- package/dist/src/bitgo/utils/tss/ecdsa/types.js +1 -1
- package/dist/src/bitgo/wallet/wallet.d.ts.map +1 -1
- package/dist/src/bitgo/wallet/wallet.js +4 -2
- package/dist/tsconfig.tsbuildinfo +97 -89
- package/package.json +5 -5
|
@@ -18,9 +18,6 @@ var __importStar = (this && this.__importStar) || function (mod) {
|
|
|
18
18
|
__setModuleDefault(result, mod);
|
|
19
19
|
return result;
|
|
20
20
|
};
|
|
21
|
-
var __importDefault = (this && this.__importDefault) || function (mod) {
|
|
22
|
-
return (mod && mod.__esModule) ? mod : { "default": mod };
|
|
23
|
-
};
|
|
24
21
|
Object.defineProperty(exports, "__esModule", { value: true });
|
|
25
22
|
exports.Enterprise = void 0;
|
|
26
23
|
/**
|
|
@@ -31,7 +28,7 @@ const internal_1 = require("../internal");
|
|
|
31
28
|
const trading_1 = require("../trading");
|
|
32
29
|
const wallet_1 = require("../wallet");
|
|
33
30
|
const ecdsa_1 = require("../utils/tss/ecdsa");
|
|
34
|
-
const
|
|
31
|
+
const sdk_lib_mpc_1 = require("@bitgo-beta/sdk-lib-mpc");
|
|
35
32
|
class Enterprise {
|
|
36
33
|
constructor(bitgo, baseCoin, enterpriseData) {
|
|
37
34
|
this.bitgo = bitgo;
|
|
@@ -153,10 +150,14 @@ class Enterprise {
|
|
|
153
150
|
if (!enterpriseChallenge) {
|
|
154
151
|
throw new Error('No existing ECDSA challenge on the enterprise.');
|
|
155
152
|
}
|
|
156
|
-
|
|
153
|
+
if (!enterpriseChallenge.ntildeProof) {
|
|
154
|
+
throw new Error('Existing ECDSA challenge does not have a proof. Please contact your enterprise admin to set this up.');
|
|
155
|
+
}
|
|
156
|
+
return sdk_lib_mpc_1.EcdsaTypes.deserializeNtildeWithProofs({
|
|
157
157
|
ntilde: enterpriseChallenge.ntilde,
|
|
158
158
|
h1: enterpriseChallenge.h1,
|
|
159
159
|
h2: enterpriseChallenge.h2,
|
|
160
|
+
ntildeProof: enterpriseChallenge.ntildeProof,
|
|
160
161
|
});
|
|
161
162
|
}
|
|
162
163
|
/**
|
|
@@ -168,4 +169,4 @@ class Enterprise {
|
|
|
168
169
|
}
|
|
169
170
|
}
|
|
170
171
|
exports.Enterprise = Enterprise;
|
|
171
|
-
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"enterprise.js","sourceRoot":"","sources":["../../../../src/bitgo/enterprise/enterprise.ts"],"names":[],"mappings":";;;;;;;;;;;;;;;;;;;;;;;;;AAAA;;GAEG;AACH,0CAA4B;AAI5B,0CAAyD;AACzD,wCAAuD;AACvD,sCAAmC;AACnC,8CAAsE;AAEtE,4EAAoD;AAEpD,MAAa,UAAU;IAOrB,YAAY,KAAgB,EAAE,QAAmB,EAAE,cAA8B;QAC/E,IAAI,CAAC,KAAK,GAAG,KAAK,CAAC;QACnB,IAAI,CAAC,QAAQ,GAAG,QAAQ,CAAC;QACzB,IAAI,CAAC,CAAC,CAAC,QAAQ,CAAC,cAAc,CAAC,EAAE;YAC/B,MAAM,IAAI,KAAK,CAAC,oCAAoC,CAAC,CAAC;SACvD;QACD,IAAI,CAAC,CAAC,CAAC,QAAQ,CAAC,cAAc,CAAC,EAAE,CAAC,EAAE;YAClC,MAAM,IAAI,KAAK,CAAC,kCAAkC,CAAC,CAAC;SACrD;QACD,IAAI,CAAC,CAAC,CAAC,QAAQ,CAAC,cAAc,CAAC,IAAI,CAAC,EAAE;YACpC,MAAM,IAAI,KAAK,CAAC,oCAAoC,CAAC,CAAC;SACvD;QACD,IAAI,CAAC,WAAW,GAAG,cAAc,CAAC;QAClC,IAAI,CAAC,EAAE,GAAG,cAAc,CAAC,EAAE,CAAC;QAC5B,IAAI,CAAC,IAAI,GAAG,cAAc,CAAC,IAAI,CAAC;IAClC,CAAC;IAED;;;OAGG;IACH,GAAG,CAAC,KAAK,GAAG,EAAE;QACZ,OAAO,IAAI,CAAC,KAAK,CAAC,GAAG,CAAC,eAAe,IAAI,CAAC,EAAE,GAAG,KAAK,EAAE,CAAC,CAAC;IAC1D,CAAC;IAED;;;OAGG;IACH,OAAO,CAAC,KAAK,GAAG,EAAE;QAChB,OAAO,IAAI,CAAC,QAAQ,CAAC,GAAG,CAAC,eAAe,IAAI,CAAC,EAAE,GAAG,KAAK,EAAE,CAAC,CAAC;IAC7D,CAAC;IAED;;;OAGG;IACH,KAAK,CAAC,WAAW,CAAC,SAAgC,EAAE;QAClD,MAAM,UAAU,GAAG,CAAC,MAAM,IAAI,CAAC,KAAK,CAAC,GAAG,CAAC,IAAI,CAAC,QAAQ,CAAC,GAAG,CAAC,qBAAqB,GAAG,IAAI,CAAC,EAAE,CAAC,CAAC,CAAC,MAAM,EAAE,CAAQ,CAAC;QAC9G,UAAU,CAAC,OAAO,GAAG,UAAU,CAAC,OAAO,CAAC,GAAG,CAAC,CAAC,CAAC,EAAE,EAAE;YAChD,OAAO,IAAI,eAAM,CAAC,IAAI,CAAC,KAAK,EAAE,IAAI,CAAC,QAAQ,EAAE,CAAC,CAAC,CAAC;QAClD,CAAC,CAAC,CAAC;QACH,OAAO,UAAU,CAAC;IACpB,CAAC;IAED;;;OAGG;IACH,KAAK,CAAC,KAAK,CAAC,SAAgC,EAAE;QAC5C,OAAO,MAAM,IAAI,CAAC,KAAK,CAAC,GAAG,CAAC,IAAI,CAAC,GAAG,CAAC,OAAO,CAAC,CAAC,CAAC,MAAM,EAAE,CAAC;IAC1D,CAAC;IAED;;;OAGG;IACH,KAAK,CAAC,oBAAoB,CAAC,SAAgC,EAAE;QAC3D,OAAO,MAAM,IAAI,CAAC,KAAK,CAAC,GAAG,CAAC,IAAI,CAAC,OAAO,CAAC,oBAAoB,CAAC,CAAC,CAAC,MAAM,EAAE,CAAC;IAC3E,CAAC;IAED;;;OAGG;IACH,KAAK,CAAC,OAAO,CAAC,SAAc,EAAE;QAC5B,OAAO,MAAM,IAAI,CAAC,KAAK,CAAC,IAAI,CAAC,IAAI,CAAC,GAAG,CAAC,OAAO,CAAC,CAAC,CAAC,IAAI,CAAC,MAAM,CAAC,CAAC,MAAM,EAAE,CAAC;IACxE,CAAC;IAED;;;OAGG;IACH,KAAK,CAAC,UAAU,CAAC,SAAc,EAAE;QAC/B,OAAO,MAAM,IAAI,CAAC,KAAK,CAAC,GAAG,CAAC,IAAI,CAAC,GAAG,CAAC,OAAO,CAAC,CAAC,CAAC,IAAI,CAAC,MAAM,CAAC,CAAC,MAAM,EAAE,CAAC;IACvE,CAAC;IAED;;;OAGG;IACH,KAAK,CAAC,0BAA0B,CAAC,SAAgC,EAAE;QACjE,OAAO,qCAA0B,CAAC,EAAE,YAAY,EAAE,IAAI,CAAC,EAAE,EAAE,EAAE,IAAI,CAAC,QAAQ,EAAE,IAAI,CAAC,KAAK,CAAC,CAAC;IAC1F,CAAC;IAED;;OAEG;IACH,WAAW;QACT,OAAO,IAAI,qBAAW,CAAC,IAAI,CAAC,KAAK,EAAE,IAAI,CAAC,EAAE,CAAC,CAAC;IAC9C,CAAC;IAED;;OAEG;IACH,YAAY;QACV,OAAO,IAAI,sBAAY,CAAC,IAAI,CAAC,KAAK,EAAE,IAAI,CAAC,EAAE,CAAC,CAAC;IAC/C,CAAC;IAED;;;OAGG;IACH,KAAK,CAAC,+BAA+B,CAAC,YAAoB;QACxD,OAAO,kBAAU,CAAC,+BAA+B,CAAC,IAAI,CAAC,KAAK,EAAE,IAAI,CAAC,EAAE,EAAE,YAAY,CAAC,CAAC;IACvF,CAAC;IAED;;;;;;;;OAQG;IACH,KAAK,CAAC,8BAA8B,CAClC,YAAoB,EACpB,gCAAwC,EACxC,iCAAyC,EACzC,SAA8B;QAE9B,MAAM,kBAAU,CAAC,+BAA+B,CAC9C,IAAI,CAAC,KAAK,EACV,IAAI,CAAC,EAAE,EACP,YAAY,EACZ,gCAAgC,EAChC,iCAAiC,EACjC,SAAS,CACV,CAAC;IACJ,CAAC;IAED;;;;OAIG;IACH,KAAK,CAAC,4BAA4B;;QAChC,MAAM,OAAO,GAAG,eAAe,IAAI,CAAC,EAAE,YAAY,CAAC;QACnD,MAAM,SAAS,GAAG,MAAM,IAAI,CAAC,KAAK,CAAC,GAAG,CAAC,IAAI,CAAC,KAAK,CAAC,GAAG,CAAC,OAAO,EAAE,CAAC,CAAC,CAAC,CAAC,IAAI,EAAE,CAAC,MAAM,EAAE,CAAC;QACnF,MAAM,mBAAmB,GAAG,MAAA,SAAS,aAAT,SAAS,uBAAT,SAAS,CAAE,KAAK,CAAC,SAAS,0CAAE,UAAU,CAAC;QACnE,IAAI,CAAC,mBAAmB,EAAE;YACxB,MAAM,IAAI,KAAK,CAAC,gDAAgD,CAAC,CAAC;SACnE;QACD,OAAO,eAAK,CAAC,iBAAiB,CAAC;YAC7B,MAAM,EAAE,mBAAmB,CAAC,MAAM;YAClC,EAAE,EAAE,mBAAmB,CAAC,EAAE;YAC1B,EAAE,EAAE,mBAAmB,CAAC,EAAE;SAC3B,CAAC,CAAC;IACL,CAAC;IAED;;;OAGG;IACH,eAAe,CAAC,KAA8B;QAC5C,OAAO,KAAK,CAAC,KAAK,CAAC,CAAC,UAAU,EAAE,EAAE,WAAC,OAAA,MAAA,IAAI,CAAC,WAAW,CAAC,YAAY,0CAAE,QAAQ,CAAC,UAAU,CAAC,CAAA,EAAA,CAAC,CAAC;IAC1F,CAAC;CACF;AArKD,gCAqKC","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 { Affirmations, Settlements } from '../trading';\nimport { Wallet } from '../wallet';\nimport { BitGoProofSignatures, EcdsaUtils } from '../utils/tss/ecdsa';\nimport { DeserializedNtilde } from '../../account-lib/mpc/tss/ecdsa/types';\nimport Ecdsa from '../../account-lib/mpc/tss/ecdsa';\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: Record<string, never> = {}): Promise<Wallet[]> {\n    const walletData = (await this.bitgo.get(this.baseCoin.url('/wallet/enterprise/' + this.id)).result()) as any;\n    walletData.wallets = walletData.wallets.map((w) => {\n      return new Wallet(this.bitgo, this.baseCoin, w);\n    });\n    return walletData;\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   * Manage settlements for an enterprise\n   */\n  settlements(): Settlements {\n    return new Settlements(this.bitgo, this.id);\n  }\n\n  /**\n   * Manage affirmations for an enterprise\n   */\n  affirmations(): Affirmations {\n    return new Affirmations(this.bitgo, this.id);\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    challenge?: DeserializedNtilde\n  ): Promise<void> {\n    await EcdsaUtils.initiateChallengesForEnterprise(\n      this.bitgo,\n      this.id,\n      userPassword,\n      bitgoInstChallengeProofSignature,\n      bitgoNitroChallengeProofSignature,\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<DeserializedNtilde> {\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    return Ecdsa.deserializeNtilde({\n      ntilde: enterpriseChallenge.ntilde,\n      h1: enterpriseChallenge.h1,\n      h2: enterpriseChallenge.h2,\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"]}
|
|
172
|
+
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"enterprise.js","sourceRoot":"","sources":["../../../../src/bitgo/enterprise/enterprise.ts"],"names":[],"mappings":";;;;;;;;;;;;;;;;;;;;;;AAAA;;GAEG;AACH,0CAA4B;AAI5B,0CAAyD;AACzD,wCAAuD;AACvD,sCAAmC;AACnC,8CAAsE;AACtE,yDAAqD;AAErD,MAAa,UAAU;IAOrB,YAAY,KAAgB,EAAE,QAAmB,EAAE,cAA8B;QAC/E,IAAI,CAAC,KAAK,GAAG,KAAK,CAAC;QACnB,IAAI,CAAC,QAAQ,GAAG,QAAQ,CAAC;QACzB,IAAI,CAAC,CAAC,CAAC,QAAQ,CAAC,cAAc,CAAC,EAAE;YAC/B,MAAM,IAAI,KAAK,CAAC,oCAAoC,CAAC,CAAC;SACvD;QACD,IAAI,CAAC,CAAC,CAAC,QAAQ,CAAC,cAAc,CAAC,EAAE,CAAC,EAAE;YAClC,MAAM,IAAI,KAAK,CAAC,kCAAkC,CAAC,CAAC;SACrD;QACD,IAAI,CAAC,CAAC,CAAC,QAAQ,CAAC,cAAc,CAAC,IAAI,CAAC,EAAE;YACpC,MAAM,IAAI,KAAK,CAAC,oCAAoC,CAAC,CAAC;SACvD;QACD,IAAI,CAAC,WAAW,GAAG,cAAc,CAAC;QAClC,IAAI,CAAC,EAAE,GAAG,cAAc,CAAC,EAAE,CAAC;QAC5B,IAAI,CAAC,IAAI,GAAG,cAAc,CAAC,IAAI,CAAC;IAClC,CAAC;IAED;;;OAGG;IACH,GAAG,CAAC,KAAK,GAAG,EAAE;QACZ,OAAO,IAAI,CAAC,KAAK,CAAC,GAAG,CAAC,eAAe,IAAI,CAAC,EAAE,GAAG,KAAK,EAAE,CAAC,CAAC;IAC1D,CAAC;IAED;;;OAGG;IACH,OAAO,CAAC,KAAK,GAAG,EAAE;QAChB,OAAO,IAAI,CAAC,QAAQ,CAAC,GAAG,CAAC,eAAe,IAAI,CAAC,EAAE,GAAG,KAAK,EAAE,CAAC,CAAC;IAC7D,CAAC;IAED;;;OAGG;IACH,KAAK,CAAC,WAAW,CAAC,SAAgC,EAAE;QAClD,MAAM,UAAU,GAAG,CAAC,MAAM,IAAI,CAAC,KAAK,CAAC,GAAG,CAAC,IAAI,CAAC,QAAQ,CAAC,GAAG,CAAC,qBAAqB,GAAG,IAAI,CAAC,EAAE,CAAC,CAAC,CAAC,MAAM,EAAE,CAAQ,CAAC;QAC9G,UAAU,CAAC,OAAO,GAAG,UAAU,CAAC,OAAO,CAAC,GAAG,CAAC,CAAC,CAAC,EAAE,EAAE;YAChD,OAAO,IAAI,eAAM,CAAC,IAAI,CAAC,KAAK,EAAE,IAAI,CAAC,QAAQ,EAAE,CAAC,CAAC,CAAC;QAClD,CAAC,CAAC,CAAC;QACH,OAAO,UAAU,CAAC;IACpB,CAAC;IAED;;;OAGG;IACH,KAAK,CAAC,KAAK,CAAC,SAAgC,EAAE;QAC5C,OAAO,MAAM,IAAI,CAAC,KAAK,CAAC,GAAG,CAAC,IAAI,CAAC,GAAG,CAAC,OAAO,CAAC,CAAC,CAAC,MAAM,EAAE,CAAC;IAC1D,CAAC;IAED;;;OAGG;IACH,KAAK,CAAC,oBAAoB,CAAC,SAAgC,EAAE;QAC3D,OAAO,MAAM,IAAI,CAAC,KAAK,CAAC,GAAG,CAAC,IAAI,CAAC,OAAO,CAAC,oBAAoB,CAAC,CAAC,CAAC,MAAM,EAAE,CAAC;IAC3E,CAAC;IAED;;;OAGG;IACH,KAAK,CAAC,OAAO,CAAC,SAAc,EAAE;QAC5B,OAAO,MAAM,IAAI,CAAC,KAAK,CAAC,IAAI,CAAC,IAAI,CAAC,GAAG,CAAC,OAAO,CAAC,CAAC,CAAC,IAAI,CAAC,MAAM,CAAC,CAAC,MAAM,EAAE,CAAC;IACxE,CAAC;IAED;;;OAGG;IACH,KAAK,CAAC,UAAU,CAAC,SAAc,EAAE;QAC/B,OAAO,MAAM,IAAI,CAAC,KAAK,CAAC,GAAG,CAAC,IAAI,CAAC,GAAG,CAAC,OAAO,CAAC,CAAC,CAAC,IAAI,CAAC,MAAM,CAAC,CAAC,MAAM,EAAE,CAAC;IACvE,CAAC;IAED;;;OAGG;IACH,KAAK,CAAC,0BAA0B,CAAC,SAAgC,EAAE;QACjE,OAAO,qCAA0B,CAAC,EAAE,YAAY,EAAE,IAAI,CAAC,EAAE,EAAE,EAAE,IAAI,CAAC,QAAQ,EAAE,IAAI,CAAC,KAAK,CAAC,CAAC;IAC1F,CAAC;IAED;;OAEG;IACH,WAAW;QACT,OAAO,IAAI,qBAAW,CAAC,IAAI,CAAC,KAAK,EAAE,IAAI,CAAC,EAAE,CAAC,CAAC;IAC9C,CAAC;IAED;;OAEG;IACH,YAAY;QACV,OAAO,IAAI,sBAAY,CAAC,IAAI,CAAC,KAAK,EAAE,IAAI,CAAC,EAAE,CAAC,CAAC;IAC/C,CAAC;IAED;;;OAGG;IACH,KAAK,CAAC,+BAA+B,CAAC,YAAoB;QACxD,OAAO,kBAAU,CAAC,+BAA+B,CAAC,IAAI,CAAC,KAAK,EAAE,IAAI,CAAC,EAAE,EAAE,YAAY,CAAC,CAAC;IACvF,CAAC;IAED;;;;;;;;OAQG;IACH,KAAK,CAAC,8BAA8B,CAClC,YAAoB,EACpB,gCAAwC,EACxC,iCAAyC,EACzC,SAAmD;QAEnD,MAAM,kBAAU,CAAC,+BAA+B,CAC9C,IAAI,CAAC,KAAK,EACV,IAAI,CAAC,EAAE,EACP,YAAY,EACZ,gCAAgC,EAChC,iCAAiC,EACjC,SAAS,CACV,CAAC;IACJ,CAAC;IAED;;;;OAIG;IACH,KAAK,CAAC,4BAA4B;;QAChC,MAAM,OAAO,GAAG,eAAe,IAAI,CAAC,EAAE,YAAY,CAAC;QACnD,MAAM,SAAS,GAAG,MAAM,IAAI,CAAC,KAAK,CAAC,GAAG,CAAC,IAAI,CAAC,KAAK,CAAC,GAAG,CAAC,OAAO,EAAE,CAAC,CAAC,CAAC,CAAC,IAAI,EAAE,CAAC,MAAM,EAAE,CAAC;QACnF,MAAM,mBAAmB,GAAG,MAAA,SAAS,aAAT,SAAS,uBAAT,SAAS,CAAE,KAAK,CAAC,SAAS,0CAAE,UAAU,CAAC;QACnE,IAAI,CAAC,mBAAmB,EAAE;YACxB,MAAM,IAAI,KAAK,CAAC,gDAAgD,CAAC,CAAC;SACnE;QACD,IAAI,CAAC,mBAAmB,CAAC,WAAW,EAAE;YACpC,MAAM,IAAI,KAAK,CACb,sGAAsG,CACvG,CAAC;SACH;QACD,OAAO,wBAAU,CAAC,2BAA2B,CAAC;YAC5C,MAAM,EAAE,mBAAmB,CAAC,MAAM;YAClC,EAAE,EAAE,mBAAmB,CAAC,EAAE;YAC1B,EAAE,EAAE,mBAAmB,CAAC,EAAE;YAC1B,WAAW,EAAE,mBAAmB,CAAC,WAAW;SAC7C,CAAC,CAAC;IACL,CAAC;IAED;;;OAGG;IACH,eAAe,CAAC,KAA8B;QAC5C,OAAO,KAAK,CAAC,KAAK,CAAC,CAAC,UAAU,EAAE,EAAE,WAAC,OAAA,MAAA,IAAI,CAAC,WAAW,CAAC,YAAY,0CAAE,QAAQ,CAAC,UAAU,CAAC,CAAA,EAAA,CAAC,CAAC;IAC1F,CAAC;CACF;AA3KD,gCA2KC","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 { Affirmations, Settlements } from '../trading';\nimport { Wallet } from '../wallet';\nimport { BitGoProofSignatures, EcdsaUtils } from '../utils/tss/ecdsa';\nimport { EcdsaTypes } from '@bitgo-beta/sdk-lib-mpc';\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: Record<string, never> = {}): Promise<Wallet[]> {\n    const walletData = (await this.bitgo.get(this.baseCoin.url('/wallet/enterprise/' + this.id)).result()) as any;\n    walletData.wallets = walletData.wallets.map((w) => {\n      return new Wallet(this.bitgo, this.baseCoin, w);\n    });\n    return walletData;\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   * Manage settlements for an enterprise\n   */\n  settlements(): Settlements {\n    return new Settlements(this.bitgo, this.id);\n  }\n\n  /**\n   * Manage affirmations for an enterprise\n   */\n  affirmations(): Affirmations {\n    return new Affirmations(this.bitgo, this.id);\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    challenge?: EcdsaTypes.DeserializedNtildeWithProofs\n  ): Promise<void> {\n    await EcdsaUtils.initiateChallengesForEnterprise(\n      this.bitgo,\n      this.id,\n      userPassword,\n      bitgoInstChallengeProofSignature,\n      bitgoNitroChallengeProofSignature,\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   *  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"]}
|
|
@@ -1,8 +1,8 @@
|
|
|
1
1
|
/// <reference types="node" />
|
|
2
|
+
import { EcdsaTypes } from '@bitgo-beta/sdk-lib-mpc';
|
|
2
3
|
import { ISettlements, IAffirmations } from '../trading';
|
|
3
4
|
import { IWallet } from '../wallet';
|
|
4
5
|
import { BitGoProofSignatures } from '../utils/tss/ecdsa';
|
|
5
|
-
import { DeserializedNtilde } from '../../account-lib/mpc/tss/ecdsa/types';
|
|
6
6
|
export declare type EnterpriseFeatureFlag = 'useEnterpriseEcdsaTssChallenge';
|
|
7
7
|
export interface EnterpriseData {
|
|
8
8
|
id: string;
|
|
@@ -21,8 +21,8 @@ export interface IEnterprise {
|
|
|
21
21
|
settlements(): ISettlements;
|
|
22
22
|
affirmations(): IAffirmations;
|
|
23
23
|
verifyEcdsaBitGoChallengeProofs(userPassword: string): Promise<BitGoProofSignatures>;
|
|
24
|
-
uploadAndEnableTssEcdsaSigning(userPassword: string, bitgoInstChallengeProofSignature: Buffer, bitgoNitroChallengeProofSignature: Buffer, challenge?:
|
|
25
|
-
getExistingTssEcdsaChallenge(): Promise<
|
|
24
|
+
uploadAndEnableTssEcdsaSigning(userPassword: string, bitgoInstChallengeProofSignature: Buffer, bitgoNitroChallengeProofSignature: Buffer, challenge?: EcdsaTypes.DeserializedNtildeWithProofs): Promise<void>;
|
|
25
|
+
getExistingTssEcdsaChallenge(): Promise<EcdsaTypes.DeserializedNtildeWithProofs>;
|
|
26
26
|
hasFeatureFlags(flags: EnterpriseFeatureFlag[]): boolean;
|
|
27
27
|
}
|
|
28
28
|
//# sourceMappingURL=iEnterprise.d.ts.map
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"iEnterprise.d.ts","sourceRoot":"","sources":["../../../../src/bitgo/enterprise/iEnterprise.ts"],"names":[],"mappings":";AAAA,OAAO,EAAE,
|
|
1
|
+
{"version":3,"file":"iEnterprise.d.ts","sourceRoot":"","sources":["../../../../src/bitgo/enterprise/iEnterprise.ts"],"names":[],"mappings":";AAAA,OAAO,EAAE,UAAU,EAAE,MAAM,yBAAyB,CAAC;AAErD,OAAO,EAAE,YAAY,EAAE,aAAa,EAAE,MAAM,YAAY,CAAC;AACzD,OAAO,EAAE,OAAO,EAAE,MAAM,WAAW,CAAC;AAEpC,OAAO,EAAE,oBAAoB,EAAE,MAAM,oBAAoB,CAAC;AAE1D,oBAAY,qBAAqB,GAAG,gCAAgC,CAAC;AAErE,MAAM,WAAW,cAAc;IAC7B,EAAE,EAAE,MAAM,CAAC;IACX,IAAI,EAAE,MAAM,CAAC;IACb,YAAY,CAAC,EAAE,MAAM,EAAE,CAAC;CACzB;AAED,MAAM,WAAW,WAAW;IAC1B,GAAG,CAAC,KAAK,CAAC,EAAE,MAAM,GAAG,MAAM,CAAC;IAC5B,OAAO,CAAC,KAAK,CAAC,EAAE,MAAM,GAAG,MAAM,CAAC;IAChC,WAAW,CAAC,MAAM,CAAC,EAAE,MAAM,CAAC,MAAM,EAAE,KAAK,CAAC,GAAG,OAAO,CAAC,OAAO,EAAE,CAAC,CAAC;IAChE,KAAK,CAAC,MAAM,CAAC,EAAE,MAAM,CAAC,MAAM,EAAE,KAAK,CAAC,GAAG,OAAO,CAAC,GAAG,CAAC,CAAC;IACpD,oBAAoB,CAAC,MAAM,CAAC,EAAE,MAAM,CAAC,MAAM,EAAE,KAAK,CAAC,GAAG,OAAO,CAAC,GAAG,CAAC,CAAC;IACnE,OAAO,CAAC,MAAM,CAAC,EAAE,GAAG,GAAG,OAAO,CAAC,GAAG,CAAC,CAAC;IACpC,UAAU,CAAC,MAAM,CAAC,EAAE,GAAG,GAAG,OAAO,CAAC,GAAG,CAAC,CAAC;IACvC,0BAA0B,CAAC,MAAM,CAAC,EAAE,MAAM,CAAC,MAAM,EAAE,KAAK,CAAC,GAAG,OAAO,CAAC,GAAG,CAAC,CAAC;IACzE,WAAW,IAAI,YAAY,CAAC;IAC5B,YAAY,IAAI,aAAa,CAAC;IAC9B,+BAA+B,CAAC,YAAY,EAAE,MAAM,GAAG,OAAO,CAAC,oBAAoB,CAAC,CAAC;IACrF,8BAA8B,CAC5B,YAAY,EAAE,MAAM,EACpB,gCAAgC,EAAE,MAAM,EACxC,iCAAiC,EAAE,MAAM,EACzC,SAAS,CAAC,EAAE,UAAU,CAAC,4BAA4B,GAClD,OAAO,CAAC,IAAI,CAAC,CAAC;IACjB,4BAA4B,IAAI,OAAO,CAAC,UAAU,CAAC,4BAA4B,CAAC,CAAC;IACjF,eAAe,CAAC,KAAK,EAAE,qBAAqB,EAAE,GAAG,OAAO,CAAC;CAC1D"}
|
|
@@ -1,3 +1,3 @@
|
|
|
1
1
|
"use strict";
|
|
2
2
|
Object.defineProperty(exports, "__esModule", { value: true });
|
|
3
|
-
//# sourceMappingURL=data:application/json;base64,
|
|
3
|
+
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiaUVudGVycHJpc2UuanMiLCJzb3VyY2VSb290IjoiIiwic291cmNlcyI6WyIuLi8uLi8uLi8uLi9zcmMvYml0Z28vZW50ZXJwcmlzZS9pRW50ZXJwcmlzZS50cyJdLCJuYW1lcyI6W10sIm1hcHBpbmdzIjoiIiwic291cmNlc0NvbnRlbnQiOlsiaW1wb3J0IHsgRWNkc2FUeXBlcyB9IGZyb20gJ0BiaXRnby1iZXRhL3Nkay1saWItbXBjJztcblxuaW1wb3J0IHsgSVNldHRsZW1lbnRzLCBJQWZmaXJtYXRpb25zIH0gZnJvbSAnLi4vdHJhZGluZyc7XG5pbXBvcnQgeyBJV2FsbGV0IH0gZnJvbSAnLi4vd2FsbGV0JztcbmltcG9ydCB7IEJ1ZmZlciB9IGZyb20gJ2J1ZmZlcic7XG5pbXBvcnQgeyBCaXRHb1Byb29mU2lnbmF0dXJlcyB9IGZyb20gJy4uL3V0aWxzL3Rzcy9lY2RzYSc7XG5cbmV4cG9ydCB0eXBlIEVudGVycHJpc2VGZWF0dXJlRmxhZyA9ICd1c2VFbnRlcnByaXNlRWNkc2FUc3NDaGFsbGVuZ2UnO1xuXG5leHBvcnQgaW50ZXJmYWNlIEVudGVycHJpc2VEYXRhIHtcbiAgaWQ6IHN0cmluZztcbiAgbmFtZTogc3RyaW5nO1xuICBmZWF0dXJlRmxhZ3M/OiBzdHJpbmdbXTtcbn1cblxuZXhwb3J0IGludGVyZmFjZSBJRW50ZXJwcmlzZSB7XG4gIHVybChxdWVyeT86IHN0cmluZyk6IHN0cmluZztcbiAgY29pblVybChxdWVyeT86IHN0cmluZyk6IHN0cmluZztcbiAgY29pbldhbGxldHMocGFyYW1zPzogUmVjb3JkPHN0cmluZywgbmV2ZXI+KTogUHJvbWlzZTxJV2FsbGV0W10+O1xuICB1c2VycyhwYXJhbXM/OiBSZWNvcmQ8c3RyaW5nLCBuZXZlcj4pOiBQcm9taXNlPGFueT47XG4gIGdldEZlZUFkZHJlc3NCYWxhbmNlKHBhcmFtcz86IFJlY29yZDxzdHJpbmcsIG5ldmVyPik6IFByb21pc2U8YW55PjtcbiAgYWRkVXNlcihwYXJhbXM/OiBhbnkpOiBQcm9taXNlPGFueT47XG4gIHJlbW92ZVVzZXIocGFyYW1zPzogYW55KTogUHJvbWlzZTxhbnk+O1xuICBnZXRGaXJzdFBlbmRpbmdUcmFuc2FjdGlvbihwYXJhbXM/OiBSZWNvcmQ8c3RyaW5nLCBuZXZlcj4pOiBQcm9taXNlPGFueT47XG4gIHNldHRsZW1lbnRzKCk6IElTZXR0bGVtZW50cztcbiAgYWZmaXJtYXRpb25zKCk6IElBZmZpcm1hdGlvbnM7XG4gIHZlcmlmeUVjZHNhQml0R29DaGFsbGVuZ2VQcm9vZnModXNlclBhc3N3b3JkOiBzdHJpbmcpOiBQcm9taXNlPEJpdEdvUHJvb2ZTaWduYXR1cmVzPjtcbiAgdXBsb2FkQW5kRW5hYmxlVHNzRWNkc2FTaWduaW5nKFxuICAgIHVzZXJQYXNzd29yZDogc3RyaW5nLFxuICAgIGJpdGdvSW5zdENoYWxsZW5nZVByb29mU2lnbmF0dXJlOiBCdWZmZXIsXG4gICAgYml0Z29OaXRyb0NoYWxsZW5nZVByb29mU2lnbmF0dXJlOiBCdWZmZXIsXG4gICAgY2hhbGxlbmdlPzogRWNkc2FUeXBlcy5EZXNlcmlhbGl6ZWROdGlsZGVXaXRoUHJvb2ZzXG4gICk6IFByb21pc2U8dm9pZD47XG4gIGdldEV4aXN0aW5nVHNzRWNkc2FDaGFsbGVuZ2UoKTogUHJvbWlzZTxFY2RzYVR5cGVzLkRlc2VyaWFsaXplZE50aWxkZVdpdGhQcm9vZnM+O1xuICBoYXNGZWF0dXJlRmxhZ3MoZmxhZ3M6IEVudGVycHJpc2VGZWF0dXJlRmxhZ1tdKTogYm9vbGVhbjtcbn1cbiJdfQ==
|
|
@@ -1,8 +1,7 @@
|
|
|
1
|
-
import { BitGoBase } from '../bitgoBase';
|
|
2
|
-
import { RequestType, TxRequest } from '../utils';
|
|
3
|
-
import { SignatureShareRecord } from '../utils/tss/baseTypes';
|
|
4
1
|
import openpgp from 'openpgp';
|
|
5
|
-
import {
|
|
2
|
+
import { EcdsaTypes } from '@bitgo-beta/sdk-lib-mpc';
|
|
3
|
+
import { BitGoBase } from '../bitgoBase';
|
|
4
|
+
import { RequestType, TxRequest, SignatureShareRecord } from '../utils';
|
|
6
5
|
/**
|
|
7
6
|
* Gets the latest Tx Request by id
|
|
8
7
|
*
|
|
@@ -49,5 +48,5 @@ export declare function commonVerifyWalletSignature(params: {
|
|
|
49
48
|
* @param requestType
|
|
50
49
|
* @param mpcAlgorithm
|
|
51
50
|
*/
|
|
52
|
-
export declare function getTxRequestChallenge(bitgo: BitGoBase, walletId: string, txRequestId: string, index: string, requestType: RequestType, mpcAlgorithm?: 'eddsa' | 'ecdsa'): Promise<SerializedNtilde>;
|
|
51
|
+
export declare function getTxRequestChallenge(bitgo: BitGoBase, walletId: string, txRequestId: string, index: string, requestType: RequestType, mpcAlgorithm?: 'eddsa' | 'ecdsa'): Promise<EcdsaTypes.SerializedNtilde>;
|
|
53
52
|
//# sourceMappingURL=common.d.ts.map
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"common.d.ts","sourceRoot":"","sources":["../../../../src/bitgo/tss/common.ts"],"names":[],"mappings":"
|
|
1
|
+
{"version":3,"file":"common.d.ts","sourceRoot":"","sources":["../../../../src/bitgo/tss/common.ts"],"names":[],"mappings":"AACA,OAAO,OAAO,MAAM,SAAS,CAAC;AAE9B,OAAO,EAAE,UAAU,EAAE,MAAM,yBAAyB,CAAC;AAErD,OAAO,EAAE,SAAS,EAAE,MAAM,cAAc,CAAC;AACzC,OAAO,EAAE,WAAW,EAAE,SAAS,EAA4B,oBAAoB,EAAE,MAAM,UAAU,CAAC;AAElG;;;;;;;GAOG;AACH,wBAAsB,YAAY,CAAC,KAAK,EAAE,SAAS,EAAE,QAAQ,EAAE,MAAM,EAAE,WAAW,EAAE,MAAM,GAAG,OAAO,CAAC,SAAS,CAAC,CAW9G;AAED;;;;;;;;;;;;GAYG;AACH,wBAAsB,kBAAkB,CACtC,KAAK,EAAE,SAAS,EAChB,QAAQ,EAAE,MAAM,EAChB,WAAW,EAAE,MAAM,EACnB,cAAc,EAAE,oBAAoB,EACpC,WAAW,EAAE,WAAW,EACxB,WAAW,CAAC,EAAE,MAAM,EACpB,YAAY,GAAE,OAAO,GAAG,OAAiB,EACzC,OAAO,GAAE,MAAM,GAAG,MAAe,EACjC,gBAAgB,CAAC,EAAE,MAAM,GACxB,OAAO,CAAC,oBAAoB,CAAC,CAuB/B;AAED;;;GAGG;AACH,wBAAsB,2BAA2B,CAAC,MAAM,EAAE;IACxD,eAAe,EAAE,OAAO,CAAC,GAAG,CAAC;IAC7B,QAAQ,EAAE,OAAO,CAAC,GAAG,CAAC;IACtB,cAAc,EAAE,MAAM,CAAC;IACvB,SAAS,EAAE,MAAM,CAAC;IAClB,WAAW,EAAE,MAAM,CAAC;CACrB,GAAG,OAAO,CAAC;IAAE,KAAK,EAAE,WAAW,CAAA;CAAE,EAAE,CAAC,CAkCpC;AAED;;;;;;;;;GASG;AACH,wBAAsB,qBAAqB,CACzC,KAAK,EAAE,SAAS,EAChB,QAAQ,EAAE,MAAM,EAChB,WAAW,EAAE,MAAM,EACnB,KAAK,EAAE,MAAM,EACb,WAAW,EAAE,WAAW,EACxB,YAAY,GAAE,OAAO,GAAG,OAAiB,GACxC,OAAO,CAAC,UAAU,CAAC,gBAAgB,CAAC,CAgBtC"}
|
|
@@ -119,4 +119,4 @@ async function getTxRequestChallenge(bitgo, walletId, txRequestId, index, reques
|
|
|
119
119
|
return await bitgo.post(bitgo.url(urlPath, 2)).send({}).result();
|
|
120
120
|
}
|
|
121
121
|
exports.getTxRequestChallenge = getTxRequestChallenge;
|
|
122
|
-
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"common.js","sourceRoot":"","sources":["../../../../src/bitgo/tss/common.ts"],"names":[],"mappings":"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","sourcesContent":["import assert from 'assert';\n\nimport { BitGoBase } from '../bitgoBase';\nimport { RequestType, TxRequest, verifyPrimaryUserWrapper } from '../utils';\nimport { SignatureShareRecord } from '../utils/tss/baseTypes';\nimport openpgp from 'openpgp';\nimport { SerializedNtilde } from '../../account-lib/mpc/tss/ecdsa/types';\n\n/**\n * Gets the latest Tx Request by id\n *\n * @param {BitGoBase} bitgo - the bitgo instance\n * @param {String} walletId - the wallet id\n * @param {String} txRequestId - the txRequest Id\n * @returns {Promise<TxRequest>}\n */\nexport async function getTxRequest(bitgo: BitGoBase, walletId: string, txRequestId: string): Promise<TxRequest> {\n  const txRequestRes = await bitgo\n    .get(bitgo.url('/wallet/' + walletId + '/txrequests', 2))\n    .query({ txRequestIds: txRequestId, latest: 'true' })\n    .result();\n\n  if (txRequestRes.txRequests.length <= 0) {\n    throw new Error(`Unable to find TxRequest with id ${txRequestId}`);\n  }\n\n  return txRequestRes.txRequests[0];\n}\n\n/**\n * Sends a Signature Share\n *\n * @param {BitGoBase} bitgo - the bitgo instance\n * @param {String} walletId - the wallet id  *\n * @param {String} txRequestId - the txRequest Id\n * @param {SignatureShareRecord} signatureShare - a Signature Share\n * @param requestType - The type of request being submitted (either tx or message for signing)\n * @param signerShare\n * @param mpcAlgorithm\n * @param apiMode\n * @returns {Promise<SignatureShareRecord>} - a Signature Share\n */\nexport async function sendSignatureShare(\n  bitgo: BitGoBase,\n  walletId: string,\n  txRequestId: string,\n  signatureShare: SignatureShareRecord,\n  requestType: RequestType,\n  signerShare?: string,\n  mpcAlgorithm: 'eddsa' | 'ecdsa' = 'eddsa',\n  apiMode: 'full' | 'lite' = 'lite',\n  userPublicGpgKey?: string\n): Promise<SignatureShareRecord> {\n  let addendum = '';\n  switch (requestType) {\n    case RequestType.tx:\n      if (mpcAlgorithm === 'ecdsa' || apiMode === 'full') {\n        addendum = '/transactions/0';\n      }\n      break;\n    case RequestType.message:\n      if (mpcAlgorithm === 'ecdsa' || apiMode === 'full') {\n        addendum = '/messages/0';\n      }\n      break;\n  }\n  const urlPath = '/wallet/' + walletId + '/txrequests/' + txRequestId + addendum + '/signatureshares';\n  return bitgo\n    .post(bitgo.url(urlPath, 2))\n    .send({\n      signatureShare,\n      signerShare,\n      userPublicGpgKey,\n    })\n    .result();\n}\n\n/**\n * Verifies that a TSS wallet signature was produced with the expected key and that the signed data contains the\n * expected common keychain as well as the expected user and backup key ids\n */\nexport async function commonVerifyWalletSignature(params: {\n  walletSignature: openpgp.Key;\n  bitgoPub: openpgp.Key;\n  commonKeychain: string;\n  userKeyId: string;\n  backupKeyId: string;\n}): Promise<{ value: ArrayBuffer }[]> {\n  const { walletSignature, bitgoPub, commonKeychain, userKeyId, backupKeyId } = params;\n\n  // By ensuring that the fingerprints of the walletSignature and the bitgoPub are different and that any of the results\n  // from calling verifyPrimaryUser is valid we know that the signature was actually produced by the private key\n  // belonging to the bitgoPub.\n  if (walletSignature.keyPacket.getFingerprint() === bitgoPub.keyPacket.getFingerprint()) {\n    throw new Error('Invalid HSM GPG signature');\n  }\n\n  const verificationResult = await verifyPrimaryUserWrapper(walletSignature, bitgoPub, false);\n  const isValid = verificationResult.some((result) => result.valid);\n  if (!isValid) {\n    throw new Error('Invalid HSM GPG signature');\n  }\n  const primaryUser = await walletSignature.getPrimaryUser();\n\n  // eslint-disable-next-line @typescript-eslint/ban-ts-comment\n  // @ts-ignore the rawNotations property is missing from the type but it actually exists\n  const rawNotations: { value: Uint8Array }[] = primaryUser.user.otherCertifications[0].rawNotations;\n\n  assert(rawNotations.length === 5, 'invalid wallet signatures');\n\n  assert(\n    commonKeychain === Buffer.from(rawNotations[0].value).toString(),\n    'wallet signature does not match common keychain'\n  );\n  assert(userKeyId === Buffer.from(rawNotations[1].value).toString(), `wallet signature does not match user key id`);\n  assert(\n    backupKeyId === Buffer.from(rawNotations[2].value).toString(),\n    'wallet signature does not match backup key id'\n  );\n\n  return rawNotations;\n}\n\n/**\n * Gets challenge for a tx request from BitGo\n * supports Message and regular Transaction\n * @param bitgo\n * @param walletId\n * @param txRequestId\n * @param index\n * @param requestType\n * @param mpcAlgorithm\n */\nexport async function getTxRequestChallenge(\n  bitgo: BitGoBase,\n  walletId: string,\n  txRequestId: string,\n  index: string,\n  requestType: RequestType,\n  mpcAlgorithm: 'eddsa' | 'ecdsa' = 'ecdsa'\n): Promise<SerializedNtilde> {\n  let addendum = '';\n  switch (requestType) {\n    case RequestType.tx:\n      if (mpcAlgorithm === 'ecdsa') {\n        addendum = '/transactions/' + index;\n      }\n      break;\n    case RequestType.message:\n      if (mpcAlgorithm === 'ecdsa') {\n        addendum = '/messages/' + index;\n      }\n      break;\n  }\n  const urlPath = '/wallet/' + walletId + '/txrequests/' + txRequestId + addendum + '/challenge';\n  return await bitgo.post(bitgo.url(urlPath, 2)).send({}).result();\n}\n"]}
|
|
122
|
+
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"common.js","sourceRoot":"","sources":["../../../../src/bitgo/tss/common.ts"],"names":[],"mappings":"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","sourcesContent":["import assert from 'assert';\nimport openpgp from 'openpgp';\n\nimport { EcdsaTypes } from '@bitgo-beta/sdk-lib-mpc';\n\nimport { BitGoBase } from '../bitgoBase';\nimport { RequestType, TxRequest, verifyPrimaryUserWrapper, SignatureShareRecord } from '../utils';\n\n/**\n * Gets the latest Tx Request by id\n *\n * @param {BitGoBase} bitgo - the bitgo instance\n * @param {String} walletId - the wallet id\n * @param {String} txRequestId - the txRequest Id\n * @returns {Promise<TxRequest>}\n */\nexport async function getTxRequest(bitgo: BitGoBase, walletId: string, txRequestId: string): Promise<TxRequest> {\n  const txRequestRes = await bitgo\n    .get(bitgo.url('/wallet/' + walletId + '/txrequests', 2))\n    .query({ txRequestIds: txRequestId, latest: 'true' })\n    .result();\n\n  if (txRequestRes.txRequests.length <= 0) {\n    throw new Error(`Unable to find TxRequest with id ${txRequestId}`);\n  }\n\n  return txRequestRes.txRequests[0];\n}\n\n/**\n * Sends a Signature Share\n *\n * @param {BitGoBase} bitgo - the bitgo instance\n * @param {String} walletId - the wallet id  *\n * @param {String} txRequestId - the txRequest Id\n * @param {SignatureShareRecord} signatureShare - a Signature Share\n * @param requestType - The type of request being submitted (either tx or message for signing)\n * @param signerShare\n * @param mpcAlgorithm\n * @param apiMode\n * @returns {Promise<SignatureShareRecord>} - a Signature Share\n */\nexport async function sendSignatureShare(\n  bitgo: BitGoBase,\n  walletId: string,\n  txRequestId: string,\n  signatureShare: SignatureShareRecord,\n  requestType: RequestType,\n  signerShare?: string,\n  mpcAlgorithm: 'eddsa' | 'ecdsa' = 'eddsa',\n  apiMode: 'full' | 'lite' = 'lite',\n  userPublicGpgKey?: string\n): Promise<SignatureShareRecord> {\n  let addendum = '';\n  switch (requestType) {\n    case RequestType.tx:\n      if (mpcAlgorithm === 'ecdsa' || apiMode === 'full') {\n        addendum = '/transactions/0';\n      }\n      break;\n    case RequestType.message:\n      if (mpcAlgorithm === 'ecdsa' || apiMode === 'full') {\n        addendum = '/messages/0';\n      }\n      break;\n  }\n  const urlPath = '/wallet/' + walletId + '/txrequests/' + txRequestId + addendum + '/signatureshares';\n  return bitgo\n    .post(bitgo.url(urlPath, 2))\n    .send({\n      signatureShare,\n      signerShare,\n      userPublicGpgKey,\n    })\n    .result();\n}\n\n/**\n * Verifies that a TSS wallet signature was produced with the expected key and that the signed data contains the\n * expected common keychain as well as the expected user and backup key ids\n */\nexport async function commonVerifyWalletSignature(params: {\n  walletSignature: openpgp.Key;\n  bitgoPub: openpgp.Key;\n  commonKeychain: string;\n  userKeyId: string;\n  backupKeyId: string;\n}): Promise<{ value: ArrayBuffer }[]> {\n  const { walletSignature, bitgoPub, commonKeychain, userKeyId, backupKeyId } = params;\n\n  // By ensuring that the fingerprints of the walletSignature and the bitgoPub are different and that any of the results\n  // from calling verifyPrimaryUser is valid we know that the signature was actually produced by the private key\n  // belonging to the bitgoPub.\n  if (walletSignature.keyPacket.getFingerprint() === bitgoPub.keyPacket.getFingerprint()) {\n    throw new Error('Invalid HSM GPG signature');\n  }\n\n  const verificationResult = await verifyPrimaryUserWrapper(walletSignature, bitgoPub, false);\n  const isValid = verificationResult.some((result) => result.valid);\n  if (!isValid) {\n    throw new Error('Invalid HSM GPG signature');\n  }\n  const primaryUser = await walletSignature.getPrimaryUser();\n\n  // eslint-disable-next-line @typescript-eslint/ban-ts-comment\n  // @ts-ignore the rawNotations property is missing from the type but it actually exists\n  const rawNotations: { value: Uint8Array }[] = primaryUser.user.otherCertifications[0].rawNotations;\n\n  assert(rawNotations.length === 5, 'invalid wallet signatures');\n\n  assert(\n    commonKeychain === Buffer.from(rawNotations[0].value).toString(),\n    'wallet signature does not match common keychain'\n  );\n  assert(userKeyId === Buffer.from(rawNotations[1].value).toString(), `wallet signature does not match user key id`);\n  assert(\n    backupKeyId === Buffer.from(rawNotations[2].value).toString(),\n    'wallet signature does not match backup key id'\n  );\n\n  return rawNotations;\n}\n\n/**\n * Gets challenge for a tx request from BitGo\n * supports Message and regular Transaction\n * @param bitgo\n * @param walletId\n * @param txRequestId\n * @param index\n * @param requestType\n * @param mpcAlgorithm\n */\nexport async function getTxRequestChallenge(\n  bitgo: BitGoBase,\n  walletId: string,\n  txRequestId: string,\n  index: string,\n  requestType: RequestType,\n  mpcAlgorithm: 'eddsa' | 'ecdsa' = 'ecdsa'\n): Promise<EcdsaTypes.SerializedNtilde> {\n  let addendum = '';\n  switch (requestType) {\n    case RequestType.tx:\n      if (mpcAlgorithm === 'ecdsa') {\n        addendum = '/transactions/' + index;\n      }\n      break;\n    case RequestType.message:\n      if (mpcAlgorithm === 'ecdsa') {\n        addendum = '/messages/' + index;\n      }\n      break;\n  }\n  const urlPath = '/wallet/' + walletId + '/txrequests/' + txRequestId + addendum + '/challenge';\n  return await bitgo.post(bitgo.url(urlPath, 2)).send({}).result();\n}\n"]}
|
|
@@ -1,6 +1,7 @@
|
|
|
1
1
|
/// <reference types="node" />
|
|
2
|
-
import * as openpgp from 'openpgp';
|
|
3
2
|
import { Key, SerializedKeyPair } from 'openpgp';
|
|
3
|
+
import * as openpgp from 'openpgp';
|
|
4
|
+
import { EcdsaTypes } from '@bitgo-beta/sdk-lib-mpc';
|
|
4
5
|
import { ApiKeyShare, Keychain } from '../../../keychain';
|
|
5
6
|
import { IBaseCoin, KeychainsTriplet } from '../../../baseCoin';
|
|
6
7
|
import baseTSSUtils from '../baseTSSUtils';
|
|
@@ -9,7 +10,6 @@ import { BackupGpgKey, BackupKeyShare, BitgoHeldBackupKeyShare, RequestType, TSS
|
|
|
9
10
|
import { EncryptedNShare } from '../../../tss/ecdsa/types';
|
|
10
11
|
import { BitGoBase } from '../../../bitgoBase';
|
|
11
12
|
import { BackupProvider, IWallet } from '../../../wallet';
|
|
12
|
-
import { EcdsaTypes } from '@bitgo-beta/sdk-lib-mpc';
|
|
13
13
|
/** @inheritdoc */
|
|
14
14
|
export declare class EcdsaUtils extends baseTSSUtils<KeyShare> {
|
|
15
15
|
private bitgoPublicGpgKey;
|
|
@@ -128,7 +128,7 @@ export declare class EcdsaUtils extends baseTSSUtils<KeyShare> {
|
|
|
128
128
|
* Verifies ZK proof for a single BitGo challenge
|
|
129
129
|
* @param bitgoChallenge
|
|
130
130
|
*/
|
|
131
|
-
static verifyBitGoChallenge(bitgoChallenge: EcdsaTypes.
|
|
131
|
+
static verifyBitGoChallenge(bitgoChallenge: EcdsaTypes.SerializedNtildeWithProofs): Promise<boolean>;
|
|
132
132
|
/**
|
|
133
133
|
* Gets the bitgo challenges for both nitro and institutional HSMs from WP API.
|
|
134
134
|
* @param bitgo
|
|
@@ -160,7 +160,7 @@ export declare class EcdsaUtils extends baseTSSUtils<KeyShare> {
|
|
|
160
160
|
* @param bitgoNitroChallengeProofSignature - signature on bitgo's nitro HSM challenge after verification
|
|
161
161
|
* @param challenge - optionally use the challenge for enterprise challenge
|
|
162
162
|
*/
|
|
163
|
-
static initiateChallengesForEnterprise(bitgo: BitGoBase, entId: string, userPassword: string, bitgoInstChallengeProofSignature: Buffer, bitgoNitroChallengeProofSignature: Buffer, challenge?: EcdsaTypes.
|
|
163
|
+
static initiateChallengesForEnterprise(bitgo: BitGoBase, entId: string, userPassword: string, bitgoInstChallengeProofSignature: Buffer, bitgoNitroChallengeProofSignature: Buffer, challenge?: EcdsaTypes.DeserializedNtildeWithProofs): Promise<void>;
|
|
164
164
|
/**
|
|
165
165
|
* Uploads the signed challenges and their proofs on the enterprise.
|
|
166
166
|
* This initiates ecdsa signing for the enterprise users.
|
|
@@ -171,6 +171,6 @@ export declare class EcdsaUtils extends baseTSSUtils<KeyShare> {
|
|
|
171
171
|
* @param bitgoIntChallengeSignature - signature on BitGo's institutional HSM challenge
|
|
172
172
|
* @param bitgoNitroChallengeSignature - signature on BitGo's nitro HSM challenge
|
|
173
173
|
*/
|
|
174
|
-
static uploadChallengesToEnterprise(bitgo: BitGoBase, entId: string, entChallengeWithProofs: EcdsaTypes.
|
|
174
|
+
static uploadChallengesToEnterprise(bitgo: BitGoBase, entId: string, entChallengeWithProofs: EcdsaTypes.SerializedNtildeWithProofs, entChallengeSignature: string, bitgoIntChallengeSignature: string, bitgoNitroChallengeSignature: string): Promise<void>;
|
|
175
175
|
}
|
|
176
176
|
//# sourceMappingURL=ecdsa.d.ts.map
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"ecdsa.d.ts","sourceRoot":"","sources":["../../../../../../src/bitgo/utils/tss/ecdsa/ecdsa.ts"],"names":[],"mappings":";
|
|
1
|
+
{"version":3,"file":"ecdsa.d.ts","sourceRoot":"","sources":["../../../../../../src/bitgo/utils/tss/ecdsa/ecdsa.ts"],"names":[],"mappings":";AAEA,OAAO,EAAE,GAAG,EAAE,iBAAiB,EAAE,MAAM,SAAS,CAAC;AACjD,OAAO,KAAK,OAAO,MAAM,SAAS,CAAC;AAEnC,OAAO,EAAmB,UAAU,EAAE,MAAM,yBAAyB,CAAC;AAItE,OAAO,EAAsB,WAAW,EAAuB,QAAQ,EAAW,MAAM,mBAAmB,CAAC;AAE5G,OAAO,EAAE,SAAS,EAAE,gBAAgB,EAAE,MAAM,mBAAmB,CAAC;AAChE,OAAO,YAAY,MAAM,iBAAiB,CAAC;AAC3C,OAAO,EACL,oBAAoB,EACpB,8BAA8B,EAC9B,yBAAyB,EAEzB,qBAAqB,EACrB,QAAQ,EACT,MAAM,SAAS,CAAC;AACjB,OAAO,EACL,YAAY,EACZ,cAAc,EACd,uBAAuB,EACvB,WAAW,EACX,SAAS,EACT,mBAAmB,EACnB,SAAS,EACV,MAAM,cAAc,CAAC;AAEtB,OAAO,EAAkB,eAAe,EAAiB,MAAM,0BAA0B,CAAC;AAE1F,OAAO,EAAE,SAAS,EAAE,MAAM,oBAAoB,CAAC;AAC/C,OAAO,EAAE,cAAc,EAAE,OAAO,EAAE,MAAM,iBAAiB,CAAC;AAQ1D,kBAAkB;AAClB,qBAAa,UAAW,SAAQ,YAAY,CAAC,QAAQ,CAAC;IAEpD,OAAO,CAAC,iBAAiB,CAAsC;gBAEnD,KAAK,EAAE,SAAS,EAAE,QAAQ,EAAE,SAAS,EAAE,MAAM,CAAC,EAAE,OAAO;YAKrD,iBAAiB;IAIzB,oBAAoB,IAAI,OAAO,CAAC,OAAO,CAAC,GAAG,CAAC;IAYlD;;;;;OAKG;IACH,MAAM,CAAC,8BAA8B,CAAC,cAAc,EAAE,MAAM,GAAG,MAAM;IAQ/D,+BAA+B,CACnC,KAAK,EAAE,MAAM,EACb,cAAc,EAAE,MAAM,EACtB,YAAY,EAAE,QAAQ,EACtB,aAAa,EAAE,QAAQ,EACvB,UAAU,EAAE,iBAAiB,CAAC,MAAM,CAAC,EACrC,4BAA4B,EAAE,GAAG,GAChC,OAAO,CAAC,uBAAuB,CAAC;IA0CnC,kBAAkB;IACZ,eAAe,CAAC,MAAM,EAAE;QAC5B,UAAU,EAAE,MAAM,CAAC;QACnB,UAAU,CAAC,EAAE,MAAM,GAAG,SAAS,CAAC;QAChC,8BAA8B,CAAC,EAAE,MAAM,GAAG,SAAS,CAAC;QACpD,cAAc,CAAC,EAAE,cAAc,CAAC;KACjC,GAAG,OAAO,CAAC,gBAAgB,CAAC;IAwD7B;;;OAGG;IACG,qBAAqB,CACzB,kBAAkB,qBAAQ,EAC1B,aAAa,EAAE,iBAAiB,CAAC,MAAM,CAAC,EACxC,UAAU,EAAE,MAAM,GAAG,SAAS,GAC7B,OAAO,CAAC,cAAc,CAAC;IAkB1B;;;;OAIG;IACG,kBAAkB,CAAC,kBAAkB,UAAQ,GAAG,OAAO,CAAC,YAAY,CAAC;IAI3E,kBAAkB,CAAC,EACjB,UAAU,EACV,YAAY,EACZ,iBAAiB,EACjB,YAAY,EACZ,cAAc,EACd,aAAa,EACb,UAAU,EACV,8BAA8B,EAC9B,kBAA0B,GAC3B,EAAE,yBAAyB,GAAG,OAAO,CAAC,QAAQ,CAAC;IA8B1C,oBAAoB,CAAC,EACzB,UAAU,EACV,YAAY,EACZ,YAAY,EACZ,cAAc,EACd,aAAa,EACb,iBAAiB,EACjB,UAAU,EACV,cAAc,GACf,EAAE,yBAAyB,GAAG,OAAO,CAAC,QAAQ,CAAC;IAsChD,kBAAkB;IACZ,mBAAmB,CAAC,EACxB,UAAU,EACV,YAAY,EACZ,YAAY,EACZ,cAAc,EACd,UAAU,EACV,iBAAiB,EACjB,kBAA0B,GAC3B,EAAE,8BAA8B,GAAG,OAAO,CAAC,QAAQ,CAAC;IA8CrD;;;;;;;;OAQG;IACG,wBAAwB,CAC5B,WAAW,EAAE,cAAc,EAC3B,cAAc,EAAE,MAAM,EACtB,uBAAuB,EAAE,MAAM,EAC/B,YAAY,EAAE,iBAAiB,CAAC,MAAM,CAAC,EACvC,kBAAkB,UAAQ,GACzB,OAAO,CAAC,eAAe,CAAC;IA0B3B;;;OAGG;IACG,sCAAsC,CAC1C,UAAU,EAAE,OAAO,CAAC,iBAAiB,CAAC,MAAM,CAAC,EAC7C,iBAAiB,EAAE,GAAG,EACtB,4BAA4B,EAAE,GAAG,EACjC,YAAY,EAAE,QAAQ,EACtB,yBAAyB,EAAE,WAAW,EAAE,EACxC,aAAa,EAAE,QAAQ,EACvB,UAAU,EAAE,MAAM,EAClB,8BAA8B,CAAC,EAAE,MAAM,GACtC,OAAO,CAAC,QAAQ,CAAC;IAgEpB,kBAAkB;IACZ,yBAAyB,CAC7B,UAAU,EAAE,OAAO,CAAC,iBAAiB,CAAC,MAAM,CAAC,EAC7C,qBAAqB,EAAE,OAAO,CAAC,iBAAiB,CAAC,MAAM,CAAC,EACxD,iBAAiB,EAAE,GAAG,EACtB,cAAc,EAAE,MAAM,EACtB,YAAY,EAAE,QAAQ,EACtB,cAAc,EAAE,QAAQ,EACxB,aAAa,EAAE,QAAQ,EACvB,UAAU,EAAE,MAAM,EAClB,8BAA8B,CAAC,EAAE,MAAM,GACtC,OAAO,CAAC,QAAQ,CAAC;IAsGpB;;;;;;OAMG;YACW,eAAe;IAqJ7B;;;;;;OAMG;IACG,aAAa,CAAC,MAAM,EAAE,SAAS,GAAG,OAAO,CAAC,SAAS,CAAC;IAI1D;;;;;;OAMG;IACG,uBAAuB,CAAC,MAAM,EAAE,mBAAmB,GAAG,OAAO,CAAC,SAAS,CAAC;IAO9E;;;;;;OAMG;IACG,yBAAyB,CAC7B,WAAW,EAAE,MAAM,EACnB,WAAW,EAAE,WAAW,EACxB,KAAK,SAAI,GACR,OAAO,CAAC;QACT,mBAAmB,EAAE,UAAU,CAAC,gBAAgB,CAAC;QACjD,cAAc,EAAE,UAAU,CAAC,gBAAgB,CAAC;KAC7C,CAAC;IAyEF;;;;;;;OAOG;IACG,sBAAsB,CAC1B,UAAU,EAAE,MAAM,EAClB,YAAY,EAAE,MAAM,EACpB,aAAa,EAAE,QAAQ,EACvB,cAAc,EAAE,MAAM,EACtB,aAAa,EAAE,CAAC,GAAG,CAAC,GACnB,OAAO,CAAC,IAAI,CAAC;IA0ChB;;;;;OAKG;IACH,MAAM,CAAC,aAAa,CAAC,SAAS,EAAE,UAAU,CAAC,gBAAgB,EAAE,QAAQ,EAAE,MAAM,EAAE,cAAc,EAAE,MAAM,GAAG,MAAM;IAK9G;;;OAGG;IACH,MAAM,CAAC,6BAA6B,CAAC,SAAS,EAAE,UAAU,CAAC,gBAAgB,GAAG,MAAM;IAIpF;;;OAGG;WACU,qBAAqB,CAAC,eAAe,EAAE,qBAAqB,GAAG,OAAO,CAAC,OAAO,CAAC;IAoB5F;;;OAGG;WACU,oBAAoB,CAAC,cAAc,EAAE,UAAU,CAAC,0BAA0B,GAAG,OAAO,CAAC,OAAO,CAAC;IAqB1G;;;OAGG;WACU,kBAAkB,CAAC,KAAK,EAAE,SAAS,GAAG,OAAO,CAAC,qBAAqB,CAAC;IAmBjF;;;;;OAKG;WACU,+BAA+B,CAC1C,KAAK,EAAE,SAAS,EAChB,YAAY,EAAE,MAAM,EACpB,YAAY,EAAE,MAAM,GACnB,OAAO,CAAC,oBAAoB,CAAC;IAWhC;;;;;;OAMG;WACU,mBAAmB,CAC9B,KAAK,EAAE,SAAS,EAChB,YAAY,EAAE,MAAM,EACpB,YAAY,EAAE,MAAM,EACpB,yBAAyB,CAAC,EAAE,qBAAqB,GAChD,OAAO,CAAC,oBAAoB,CAAC;IAoChC;;;;;;;;;;OAUG;WACU,+BAA+B,CAC1C,KAAK,EAAE,SAAS,EAChB,KAAK,EAAE,MAAM,EACb,YAAY,EAAE,MAAM,EACpB,gCAAgC,EAAE,MAAM,EACxC,iCAAiC,EAAE,MAAM,EACzC,SAAS,CAAC,EAAE,UAAU,CAAC,4BAA4B,GAClD,OAAO,CAAC,IAAI,CAAC;IAoChB;;;;;;;;;OASG;WACU,4BAA4B,CACvC,KAAK,EAAE,SAAS,EAChB,KAAK,EAAE,MAAM,EACb,sBAAsB,EAAE,UAAU,CAAC,0BAA0B,EAC7D,qBAAqB,EAAE,MAAM,EAC7B,0BAA0B,EAAE,MAAM,EAClC,4BAA4B,EAAE,MAAM,GACnC,OAAO,CAAC,IAAI,CAAC;CA8BjB"}
|