@bitgo-beta/sdk-core 8.2.1-beta.627 → 8.2.1-beta.629

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.
@@ -100,10 +100,10 @@ export declare class Keychains implements IKeychains {
100
100
  */
101
101
  createTssBitGoKeyFromOvcShares(ovcOutputJson: unknown): Promise<BitGoKeyFromOvcShares>;
102
102
  /**
103
- * Create keychain for ofc wallet using the password
104
- * @param userPassword
105
- * @returns
103
+ * Create user keychain, encrypt the private key with the wallet passphrase and store it in BitGo.
104
+ * @param walletPassphrase
105
+ * @returns Keychain including the decrypted private key
106
106
  */
107
- createUserKeychain(userPassword: string): Promise<Keychain>;
107
+ createUserKeychain(walletPassphrase: string): Promise<Keychain>;
108
108
  }
109
109
  //# sourceMappingURL=keychains.d.ts.map
@@ -1 +1 @@
1
- {"version":3,"file":"keychains.d.ts","sourceRoot":"","sources":["../../../../src/bitgo/keychain/keychains.ts"],"names":[],"mappings":"AAIA,OAAO,EAAE,SAAS,EAAE,gBAAgB,EAAE,OAAO,EAAE,MAAM,aAAa,CAAC;AACnE,OAAO,EAAE,SAAS,EAAE,MAAM,cAAc,CAAC;AAEzC,OAAO,EACL,kBAAkB,EAElB,gBAAgB,EAChB,mBAAmB,EACnB,kBAAkB,EAClB,gBAAgB,EAChB,kBAAkB,EAClB,wBAAwB,EACxB,UAAU,EACV,QAAQ,EACR,mBAAmB,EACnB,mBAAmB,EACnB,kBAAkB,EAClB,qBAAqB,EACrB,mCAAmC,EACpC,MAAM,cAAc,CAAC;AACtB,OAAO,EAAE,qBAAqB,EAAkC,MAAM,gBAAgB,CAAC;AAEvF,qBAAa,SAAU,YAAW,UAAU;IAC1C,OAAO,CAAC,QAAQ,CAAC,KAAK,CAAY;IAClC,OAAO,CAAC,QAAQ,CAAC,QAAQ,CAAY;gBAEzB,KAAK,EAAE,SAAS,EAAE,QAAQ,EAAE,SAAS;IAKjD;;;;;;;OAOG;IACG,GAAG,CAAC,MAAM,EAAE,kBAAkB,GAAG,OAAO,CAAC,QAAQ,CAAC;IAcxD;;;;;;OAMG;IACG,IAAI,CAAC,MAAM,GAAE,mBAAwB,GAAG,OAAO,CAAC,mBAAmB,CAAC;IAmB1E;;;;;;;;;;;;;;;;;OAiBG;IACG,cAAc,CAAC,MAAM,EAAE,qBAAqB,GAAG,OAAO,CAAC,gBAAgB,CAAC;IAwC9E;;;;;;;OAOG;IACH,4BAA4B,CAAC,MAAM,GAAE,mCAAwC,GAAG,QAAQ;IAwBxF;;;;;;OAMG;IACH,MAAM,CAAC,MAAM,GAAE;QAAE,IAAI,CAAC,EAAE,MAAM,CAAC;QAAC,SAAS,CAAC,EAAE,OAAO,CAAA;KAAO,GAAG,OAAO;IAOpE;;;OAGG;IACG,GAAG,CAAC,MAAM,GAAE,kBAAuB,GAAG,OAAO,CAAC,QAAQ,CAAC;IAsD7D;;;OAGG;IACG,WAAW,CAAC,MAAM,GAAE,kBAAuB,GAAG,OAAO,CAAC,QAAQ,CAAC;IAOrE;;;;OAIG;IACG,YAAY,CAAC,MAAM,GAAE,mBAAwB,GAAG,OAAO,CAAC,QAAQ,CAAC;IAkBvE;;;;OAIG;IACG,iBAAiB,CAAC,MAAM,GAAE,wBAA6B,GAAG,OAAO,CAAC,QAAQ,EAAE,CAAC;IAWnF;;;;OAIG;IACG,SAAS,CAAC,MAAM,EAAE,gBAAgB,GAAG,OAAO,CAAC,gBAAgB,CAAC;IAuC9D,WAAW,CAAC,MAAM,EAAE,kBAAkB,GAAG,OAAO,CAAC,gBAAgB,CAAC;IAgDxE;;;;;;OAMG;IACG,8BAA8B,CAAC,aAAa,EAAE,OAAO,GAAG,OAAO,CAAC,qBAAqB,CAAC;IAyG5F;;;;OAIG;IACG,kBAAkB,CAAC,YAAY,EAAE,MAAM,GAAG,OAAO,CAAC,QAAQ,CAAC;CAiBlE"}
1
+ {"version":3,"file":"keychains.d.ts","sourceRoot":"","sources":["../../../../src/bitgo/keychain/keychains.ts"],"names":[],"mappings":"AAIA,OAAO,EAAE,SAAS,EAAE,gBAAgB,EAAE,OAAO,EAAE,MAAM,aAAa,CAAC;AACnE,OAAO,EAAE,SAAS,EAAE,MAAM,cAAc,CAAC;AAEzC,OAAO,EACL,kBAAkB,EAElB,gBAAgB,EAChB,mBAAmB,EACnB,kBAAkB,EAClB,gBAAgB,EAChB,kBAAkB,EAClB,wBAAwB,EACxB,UAAU,EACV,QAAQ,EACR,mBAAmB,EACnB,mBAAmB,EACnB,kBAAkB,EAClB,qBAAqB,EACrB,mCAAmC,EACpC,MAAM,cAAc,CAAC;AACtB,OAAO,EAAE,qBAAqB,EAAkC,MAAM,gBAAgB,CAAC;AAEvF,qBAAa,SAAU,YAAW,UAAU;IAC1C,OAAO,CAAC,QAAQ,CAAC,KAAK,CAAY;IAClC,OAAO,CAAC,QAAQ,CAAC,QAAQ,CAAY;gBAEzB,KAAK,EAAE,SAAS,EAAE,QAAQ,EAAE,SAAS;IAKjD;;;;;;;OAOG;IACG,GAAG,CAAC,MAAM,EAAE,kBAAkB,GAAG,OAAO,CAAC,QAAQ,CAAC;IAcxD;;;;;;OAMG;IACG,IAAI,CAAC,MAAM,GAAE,mBAAwB,GAAG,OAAO,CAAC,mBAAmB,CAAC;IAmB1E;;;;;;;;;;;;;;;;;OAiBG;IACG,cAAc,CAAC,MAAM,EAAE,qBAAqB,GAAG,OAAO,CAAC,gBAAgB,CAAC;IAwC9E;;;;;;;OAOG;IACH,4BAA4B,CAAC,MAAM,GAAE,mCAAwC,GAAG,QAAQ;IAwBxF;;;;;;OAMG;IACH,MAAM,CAAC,MAAM,GAAE;QAAE,IAAI,CAAC,EAAE,MAAM,CAAC;QAAC,SAAS,CAAC,EAAE,OAAO,CAAA;KAAO,GAAG,OAAO;IAOpE;;;OAGG;IACG,GAAG,CAAC,MAAM,GAAE,kBAAuB,GAAG,OAAO,CAAC,QAAQ,CAAC;IAsD7D;;;OAGG;IACG,WAAW,CAAC,MAAM,GAAE,kBAAuB,GAAG,OAAO,CAAC,QAAQ,CAAC;IAOrE;;;;OAIG;IACG,YAAY,CAAC,MAAM,GAAE,mBAAwB,GAAG,OAAO,CAAC,QAAQ,CAAC;IAkBvE;;;;OAIG;IACG,iBAAiB,CAAC,MAAM,GAAE,wBAA6B,GAAG,OAAO,CAAC,QAAQ,EAAE,CAAC;IAWnF;;;;OAIG;IACG,SAAS,CAAC,MAAM,EAAE,gBAAgB,GAAG,OAAO,CAAC,gBAAgB,CAAC;IAuC9D,WAAW,CAAC,MAAM,EAAE,kBAAkB,GAAG,OAAO,CAAC,gBAAgB,CAAC;IAgDxE;;;;;;OAMG;IACG,8BAA8B,CAAC,aAAa,EAAE,OAAO,GAAG,OAAO,CAAC,qBAAqB,CAAC;IAyG5F;;;;OAIG;IACG,kBAAkB,CAAC,gBAAgB,EAAE,MAAM,GAAG,OAAO,CAAC,QAAQ,CAAC;CAoBtE"}
@@ -461,25 +461,28 @@ class Keychains {
461
461
  });
462
462
  }
463
463
  /**
464
- * Create keychain for ofc wallet using the password
465
- * @param userPassword
466
- * @returns
464
+ * Create user keychain, encrypt the private key with the wallet passphrase and store it in BitGo.
465
+ * @param walletPassphrase
466
+ * @returns Keychain including the decrypted private key
467
467
  */
468
- async createUserKeychain(userPassword) {
468
+ async createUserKeychain(walletPassphrase) {
469
469
  const keychains = this.baseCoin.keychains();
470
470
  const newKeychain = keychains.create();
471
471
  const originalPasscodeEncryptionCode = (0, utils_1.generateRandomPassword)(5);
472
472
  const encryptedPrv = this.bitgo.encrypt({
473
- password: userPassword,
473
+ password: walletPassphrase,
474
474
  input: newKeychain.prv,
475
475
  });
476
- return await keychains.add({
477
- encryptedPrv,
478
- originalPasscodeEncryptionCode,
479
- pub: newKeychain.pub,
480
- source: 'user',
481
- });
476
+ return {
477
+ ...(await keychains.add({
478
+ encryptedPrv,
479
+ originalPasscodeEncryptionCode,
480
+ pub: newKeychain.pub,
481
+ source: 'user',
482
+ })),
483
+ prv: newKeychain.prv,
484
+ };
482
485
  }
483
486
  }
484
487
  exports.Keychains = Keychains;
485
- //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"keychains.js","sourceRoot":"","sources":["../../../../src/bitgo/keychain/keychains.ts"],"names":[],"mappings":"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","sourcesContent":["import { TssSettings } from '@bitgo/public-types';\nimport assert from 'assert';\nimport * as _ from 'lodash';\nimport * as common from '../../common';\nimport { IBaseCoin, KeychainsTriplet, KeyPair } from '../baseCoin';\nimport { BitGoBase } from '../bitgoBase';\nimport { BlsUtils, decodeOrElse, ECDSAUtils, EDDSAUtils, generateRandomPassword, RequestTracer } from '../utils';\nimport {\n  AddKeychainOptions,\n  ApiKeyShare,\n  ChangedKeychains,\n  CreateBackupOptions,\n  CreateBitGoOptions,\n  CreateMpcOptions,\n  GetKeychainOptions,\n  GetKeysForSigningOptions,\n  IKeychains,\n  Keychain,\n  ListKeychainOptions,\n  ListKeychainsResult,\n  RecreateMpcOptions,\n  UpdatePasswordOptions,\n  UpdateSingleKeychainPasswordOptions,\n} from './iKeychains';\nimport { BitGoKeyFromOvcShares, BitGoToOvcJSON, OvcToBitGoJSON } from './ovcJsonCodec';\n\nexport class Keychains implements IKeychains {\n  private readonly bitgo: BitGoBase;\n  private readonly baseCoin: IBaseCoin;\n\n  constructor(bitgo: BitGoBase, baseCoin: IBaseCoin) {\n    this.bitgo = bitgo;\n    this.baseCoin = baseCoin;\n  }\n\n  /**\n   * Get a keychain by ID\n   * @param params\n   * @param params.id\n   * @param params.xpub (optional)\n   * @param params.ethAddress (optional)\n   * @param params.reqId (optional)\n   */\n  async get(params: GetKeychainOptions): Promise<Keychain> {\n    common.validateParams(params, [], ['xpub', 'ethAddress']);\n\n    if (_.isUndefined(params.id)) {\n      throw new Error('id must be defined');\n    }\n\n    const id = params.id;\n    if (params.reqId) {\n      this.bitgo.setRequestTracer(params.reqId);\n    }\n    return await this.bitgo.get(this.baseCoin.url('/key/' + encodeURIComponent(id))).result();\n  }\n\n  /**\n   * list the users keychains\n   * @param params\n   * @param params.limit - Max number of results in a single call.\n   * @param params.prevId - Continue iterating (provided by nextBatchPrevId in the previous list)\n   * @returns {*}\n   */\n  async list(params: ListKeychainOptions = {}): Promise<ListKeychainsResult> {\n    const queryObject: any = {};\n\n    if (!_.isUndefined(params.limit)) {\n      if (!_.isNumber(params.limit)) {\n        throw new Error('invalid limit argument, expecting number');\n      }\n      queryObject.limit = params.limit;\n    }\n    if (!_.isUndefined(params.prevId)) {\n      if (!_.isString(params.prevId)) {\n        throw new Error('invalid prevId argument, expecting string');\n      }\n      queryObject.prevId = params.prevId;\n    }\n\n    return this.bitgo.get(this.baseCoin.url('/key')).query(queryObject).result();\n  }\n\n  /**\n   * Change the decryption password for all possible keychains associated with a user.\n   *\n   * This function iterates through all keys associated with the user, decrypts\n   * them with the old password and re-encrypts them with the new password.\n   *\n   * This should be called when a user changes their login password, and are expecting\n   * that their wallet passwords are changed to match the new login password.\n   *\n   * @param params\n   * @param params.oldPassword - The old password used for encrypting the key\n   * @param params.newPassword - The new password to be used for encrypting the key\n   * @returns changedKeys Object - e.g.:\n   *  {\n   *    xpub1: encryptedPrv,\n   *    ...\n   *  }\n   */\n  async updatePassword(params: UpdatePasswordOptions): Promise<ChangedKeychains> {\n    common.validateParams(params, ['oldPassword', 'newPassword'], []);\n    const changedKeys: ChangedKeychains = {};\n    let prevId;\n    let keysLeft = true;\n    while (keysLeft) {\n      const result: ListKeychainsResult = await this.list({ limit: 500, prevId });\n      for (const key of result.keys) {\n        const oldEncryptedPrv = key.encryptedPrv;\n        if (_.isUndefined(oldEncryptedPrv)) {\n          continue;\n        }\n        try {\n          const updatedKeychain = this.updateSingleKeychainPassword({\n            keychain: key,\n            oldPassword: params.oldPassword,\n            newPassword: params.newPassword,\n          });\n          if (updatedKeychain.encryptedPrv) {\n            const changedKeyIdentifier = updatedKeychain.type === 'tss' ? updatedKeychain.id : updatedKeychain.pub;\n            if (changedKeyIdentifier) {\n              changedKeys[changedKeyIdentifier] = updatedKeychain.encryptedPrv;\n            }\n          }\n        } catch (e) {\n          // if the password was incorrect, silence the error, throw otherwise\n          if (!e.message.includes('private key is incorrect')) {\n            throw e;\n          }\n        }\n      }\n      if (result.nextBatchPrevId) {\n        prevId = result.nextBatchPrevId;\n      } else {\n        keysLeft = false;\n      }\n    }\n    return changedKeys;\n  }\n\n  /**\n   * Update the password used to decrypt a single keychain\n   * @param params\n   * @param params.keychain - The keychain whose password should be updated\n   * @param params.oldPassword - The old password used for encrypting the key\n   * @param params.newPassword - The new password to be used for encrypting the key\n   * @returns {object}\n   */\n  updateSingleKeychainPassword(params: UpdateSingleKeychainPasswordOptions = {}): Keychain {\n    if (!_.isString(params.oldPassword)) {\n      throw new Error('expected old password to be a string');\n    }\n\n    if (!_.isString(params.newPassword)) {\n      throw new Error('expected new password to be a string');\n    }\n\n    if (!_.isObject(params.keychain) || !_.isString(params.keychain.encryptedPrv)) {\n      throw new Error('expected keychain to be an object with an encryptedPrv property');\n    }\n\n    const oldEncryptedPrv = params.keychain.encryptedPrv;\n    try {\n      const decryptedPrv = this.bitgo.decrypt({ input: oldEncryptedPrv, password: params.oldPassword });\n      const newEncryptedPrv = this.bitgo.encrypt({ input: decryptedPrv, password: params.newPassword });\n      return _.assign({}, params.keychain, { encryptedPrv: newEncryptedPrv });\n    } catch (e) {\n      // catching an error here means that the password was incorrect or, less likely, the input to decrypt is corrupted\n      throw new Error('password used to decrypt keychain private key is incorrect');\n    }\n  }\n\n  /**\n   * Create a public/private key pair\n   * @param params - optional params\n   * @param params.seed optional - seed to use for keypair generation\n   * @param params.isRootKey optional - whether the resulting keypair should be a root key\n   * @returns {KeyPair} - the generated keypair\n   */\n  create(params: { seed?: Buffer; isRootKey?: boolean } = {}): KeyPair {\n    if (params?.isRootKey) {\n      return this.baseCoin.generateRootKeyPair(params.seed);\n    }\n    return this.baseCoin.generateKeyPair(params.seed);\n  }\n\n  /**\n   * Add a keychain to BitGo's records\n   * @param params\n   */\n  async add(params: AddKeychainOptions = {}): Promise<Keychain> {\n    params = params || {};\n    common.validateParams(\n      params,\n      [],\n      [\n        'pub',\n        'encryptedPrv',\n        'keyType',\n        'type',\n        'source',\n        'originalPasscodeEncryptionCode',\n        'enterprise',\n        'derivedFromParentWithSeed',\n      ]\n    );\n\n    if (!_.isUndefined(params.disableKRSEmail)) {\n      if (!_.isBoolean(params.disableKRSEmail)) {\n        throw new Error('invalid disableKRSEmail argument, expecting boolean');\n      }\n    }\n\n    if (params.reqId) {\n      this.bitgo.setRequestTracer(params.reqId);\n    }\n\n    return await this.bitgo\n      .post(this.baseCoin.url('/key'))\n      .send({\n        pub: params.pub,\n        commonPub: params.commonPub,\n        commonKeychain: params.commonKeychain,\n        encryptedPrv: params.encryptedPrv,\n        type: params.type,\n        keyType: params.keyType,\n        source: params.source,\n        provider: params.provider,\n        originalPasscodeEncryptionCode: params.originalPasscodeEncryptionCode,\n        enterprise: params.enterprise,\n        derivedFromParentWithSeed: params.derivedFromParentWithSeed,\n        disableKRSEmail: params.disableKRSEmail,\n        krsSpecific: params.krsSpecific,\n        keyShares: params.keyShares,\n        userGPGPublicKey: params.userGPGPublicKey,\n        backupGPGPublicKey: params.backupGPGPublicKey,\n        algoUsed: params.algoUsed,\n        isDistributedCustody: params.isDistributedCustody,\n        isMPCv2: params.isMPCv2,\n        coinSpecific: params.coinSpecific,\n      })\n      .result();\n  }\n\n  /**\n   * Create a BitGo key\n   * @param params (empty)\n   */\n  async createBitGo(params: CreateBitGoOptions = {}): Promise<Keychain> {\n    params.source = 'bitgo';\n\n    this.baseCoin.preCreateBitGo(params as any);\n    return await this.add(params);\n  }\n\n  /**\n   * Create a backup key\n   * @param params\n   * @param params.provider (optional)\n   */\n  async createBackup(params: CreateBackupOptions = {}): Promise<Keychain> {\n    params.source = 'backup';\n\n    const isTssBackupKey = params.prv && (params.commonKeychain || params.commonPub);\n\n    if (_.isUndefined(params.provider) && !isTssBackupKey) {\n      // if the provider is undefined, we generate a local key and add the source details\n      const key = this.create();\n      _.extend(params, key);\n      if (params.passphrase !== undefined) {\n        _.extend(params, { encryptedPrv: this.bitgo.encrypt({ input: key.prv, password: params.passphrase }) });\n      }\n    }\n\n    const serverResponse = await this.add(params);\n    return _.extend({}, serverResponse, _.pick(params, ['prv', 'encryptedPrv', 'provider', 'source']));\n  }\n\n  /**\n   * Gets keys for signing from a wallet\n   * @param params\n   * @returns {Promise<Keychain[]>}\n   */\n  async getKeysForSigning(params: GetKeysForSigningOptions = {}): Promise<Keychain[]> {\n    if (!_.isObject(params.wallet)) {\n      throw new Error('missing required param wallet');\n    }\n    const wallet = params.wallet;\n    const reqId = params.reqId || new RequestTracer();\n    const ids = wallet.baseCoin.keyIdsForSigning();\n    const keychainQueriesBluebirds = ids.map((id) => this.get({ id: wallet.keyIds()[id], reqId }));\n    return Promise.all(keychainQueriesBluebirds);\n  }\n\n  /**\n   * Convenience function to create and store MPC keychains with BitGo.\n   * @param params passphrase used to encrypt secret materials\n   * @return {Promise<KeychainsTriplet>} newly created User, Backup, and BitGo keys\n   */\n  async createMpc(params: CreateMpcOptions): Promise<KeychainsTriplet> {\n    let MpcUtils;\n    let multisigTypeVersion: 'MPCv2' | undefined = undefined;\n    if (params.multisigType === 'tss' && this.baseCoin.getMPCAlgorithm() === 'ecdsa') {\n      const tssSettings: TssSettings = await this.bitgo\n        .get(this.bitgo.microservicesUrl('/api/v2/tss/settings'))\n        .result();\n      multisigTypeVersion =\n        tssSettings.coinSettings[this.baseCoin.getFamily()]?.walletCreationSettings?.multiSigTypeVersion;\n    }\n\n    switch (params.multisigType) {\n      case 'tss':\n        MpcUtils =\n          this.baseCoin.getMPCAlgorithm() === 'eddsa'\n            ? EDDSAUtils.default\n            : multisigTypeVersion === 'MPCv2'\n            ? ECDSAUtils.EcdsaMPCv2Utils\n            : ECDSAUtils.EcdsaUtils;\n        break;\n      case 'blsdkg':\n        if (_.isUndefined(params.passphrase)) {\n          throw new Error('missing required param passphrase');\n        }\n        MpcUtils = BlsUtils;\n        break;\n      default:\n        throw new Error('Unsupported multi-sig type');\n    }\n    const mpcUtils = new MpcUtils(this.bitgo, this.baseCoin);\n    return await mpcUtils.createKeychains({\n      passphrase: params.passphrase,\n      enterprise: params.enterprise,\n      originalPasscodeEncryptionCode: params.originalPasscodeEncryptionCode,\n      backupProvider: params.backupProvider,\n      retrofit: params.retrofit,\n    });\n  }\n\n  async recreateMpc(params: RecreateMpcOptions): Promise<KeychainsTriplet> {\n    assert(params.coin, new Error('missing required param coin'));\n    assert(params.walletId, new Error('missing required param walletId'));\n    assert(params.otp, new Error('missing required param otp'));\n    assert(params.passphrase, new Error('missing required param passphrase'));\n\n    assert(\n      params.encryptedMaterial.encryptedWalletPassphrase,\n      new Error('missing required param encryptedWalletPassphrase')\n    );\n    assert(params.encryptedMaterial.encryptedUserKey, new Error('missing required param encryptedUserKey'));\n    assert(params.encryptedMaterial.encryptedBackupKey, new Error('missing required param encryptedBackupKey'));\n\n    await this.bitgo.post(this.bitgo.microservicesUrl('/api/v1/user/unlock')).send({ otp: params.otp }).result();\n    const { recoveryInfo } = await this.bitgo\n      .post(this.bitgo.microservicesUrl(`/api/v2/${params.coin}/wallet/${params.walletId}/passcoderecovery`))\n      .result();\n\n    if (!recoveryInfo || !('passcodeEncryptionCode' in recoveryInfo)) {\n      throw new Error('failed to get recovery info');\n    }\n\n    const decryptedWalletPassphrase = this.bitgo.decrypt({\n      input: params.encryptedMaterial.encryptedWalletPassphrase,\n      password: recoveryInfo.passcodeEncryptionCode,\n    });\n\n    const decryptedUserKey = this.bitgo.decrypt({\n      input: params.encryptedMaterial.encryptedUserKey,\n      password: decryptedWalletPassphrase,\n    });\n\n    const decryptedBackupKey = this.bitgo.decrypt({\n      input: params.encryptedMaterial.encryptedBackupKey,\n      password: decryptedWalletPassphrase,\n    });\n\n    return this.createMpc({\n      ...params,\n      multisigType: 'tss',\n      retrofit: {\n        decryptedUserKey,\n        decryptedBackupKey,\n        walletId: params.walletId,\n      },\n    });\n  }\n\n  /**\n   * It parses the JSON downloaded from the OVC for platform (BitGo),\n   * and creates a corresponding TSS BitGo key. It also returns the JSON that needs\n   * to be uploaded back to the OVCs containing the BitGo -> OVC shares.\n   * @param ovcOutputJson JSON format of the file downloaded from the OVC for platform\n   * @returns {BitGoKeyFromOvcShares}\n   */\n  async createTssBitGoKeyFromOvcShares(ovcOutputJson: unknown): Promise<BitGoKeyFromOvcShares> {\n    const decodedOvcOutput = decodeOrElse(OvcToBitGoJSON.name, OvcToBitGoJSON, ovcOutputJson, (errors) => {\n      throw new Error(`Error(s) parsing OVC JSON: ${errors}`);\n    });\n\n    if (decodedOvcOutput.state !== 1) {\n      throw new Error('State expected to be \"1\". Please complete the first two OVC operations');\n    }\n\n    // OVC-1 is responsible for the User key\n    const ovc1 = decodedOvcOutput.ovc[1];\n    // OVC-2 is responsible for the Backup key\n    const ovc2 = decodedOvcOutput.ovc[2];\n\n    const keyShares: ApiKeyShare[] = [\n      {\n        from: 'user',\n        to: 'bitgo',\n        publicShare: ovc1.ovcToBitgoShare.publicShare,\n        privateShare: ovc1.ovcToBitgoShare.privateShare,\n        privateShareProof: ovc1.ovcToBitgoShare.uSig.toString() ?? '',\n        vssProof: ovc1.ovcToBitgoShare.vssProof ?? '',\n      },\n      {\n        from: 'backup',\n        to: 'bitgo',\n        publicShare: ovc2.ovcToBitgoShare.publicShare,\n        privateShare: ovc2.ovcToBitgoShare.privateShare,\n        privateShareProof: ovc2.ovcToBitgoShare.uSig.toString() ?? '',\n        vssProof: ovc2.ovcToBitgoShare.vssProof ?? '',\n      },\n    ];\n\n    const key = await this.baseCoin.keychains().add({\n      source: 'bitgo',\n      keyShares,\n      keyType: 'tss',\n      userGPGPublicKey: ovc1.gpgPubKey,\n      backupGPGPublicKey: ovc2.gpgPubKey,\n    });\n    assert(key.keyShares);\n    assert(key.commonKeychain);\n    assert(key.walletHSMGPGPublicKeySigs);\n\n    const bitgoToUserShare = key.keyShares.find(\n      (value: { from: string; to: string }) => value.from === 'bitgo' && value.to === 'user'\n    );\n    assert(bitgoToUserShare);\n    assert(bitgoToUserShare.vssProof);\n    assert(bitgoToUserShare.paillierPublicKey);\n    const bitgoToBackupShare = key.keyShares.find(\n      (value: { from: string; to: string }) => value.from === 'bitgo' && value.to === 'backup'\n    );\n    assert(bitgoToBackupShare);\n    assert(bitgoToBackupShare.vssProof);\n    assert(bitgoToBackupShare.paillierPublicKey);\n\n    // Create JSON data with platform shares for OVC-1 and OVC-2\n    const bitgoToOvcOutput: BitGoToOvcJSON = {\n      wallet: {\n        ...decodedOvcOutput,\n        platform: {\n          commonKeychain: key.commonKeychain,\n          walletGpgPubKeySigs: key.walletHSMGPGPublicKeySigs,\n          ovc: {\n            // BitGo to User (OVC-1)\n            1: {\n              bitgoToOvcShare: {\n                i: 1,\n                j: 3,\n                publicShare: bitgoToUserShare.publicShare,\n                privateShare: bitgoToUserShare.privateShare,\n                paillierPublicKey: bitgoToUserShare.paillierPublicKey,\n                vssProof: bitgoToUserShare.vssProof,\n              },\n            },\n            // BitGo to Backup (OVC-2)\n            2: {\n              bitgoToOvcShare: {\n                i: 2,\n                j: 3,\n                publicShare: bitgoToBackupShare.publicShare,\n                privateShare: bitgoToBackupShare.privateShare,\n                paillierPublicKey: bitgoToBackupShare.paillierPublicKey,\n                vssProof: bitgoToBackupShare.vssProof,\n              },\n            },\n          },\n        },\n      },\n    };\n\n    // Mark it ready for next operation, should be 2\n    bitgoToOvcOutput.wallet.state += 1;\n\n    const output: BitGoKeyFromOvcShares = {\n      bitGoKeyId: key.id,\n      bitGoOutputJsonForOvc: bitgoToOvcOutput,\n    };\n\n    return decodeOrElse(BitGoKeyFromOvcShares.name, BitGoKeyFromOvcShares, output, (errors) => {\n      throw new Error(`Error producing the output: ${errors}`);\n    });\n  }\n\n  /**\n   * Create keychain for ofc wallet using the password\n   * @param userPassword\n   * @returns\n   */\n  async createUserKeychain(userPassword: string): Promise<Keychain> {\n    const keychains = this.baseCoin.keychains();\n    const newKeychain = keychains.create();\n    const originalPasscodeEncryptionCode = generateRandomPassword(5);\n\n    const encryptedPrv = this.bitgo.encrypt({\n      password: userPassword,\n      input: newKeychain.prv,\n    });\n\n    return await keychains.add({\n      encryptedPrv,\n      originalPasscodeEncryptionCode,\n      pub: newKeychain.pub,\n      source: 'user',\n    });\n  }\n}\n"]}
488
+ //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"keychains.js","sourceRoot":"","sources":["../../../../src/bitgo/keychain/keychains.ts"],"names":[],"mappings":"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","sourcesContent":["import { TssSettings } from '@bitgo/public-types';\nimport assert from 'assert';\nimport * as _ from 'lodash';\nimport * as common from '../../common';\nimport { IBaseCoin, KeychainsTriplet, KeyPair } from '../baseCoin';\nimport { BitGoBase } from '../bitgoBase';\nimport { BlsUtils, decodeOrElse, ECDSAUtils, EDDSAUtils, generateRandomPassword, RequestTracer } from '../utils';\nimport {\n  AddKeychainOptions,\n  ApiKeyShare,\n  ChangedKeychains,\n  CreateBackupOptions,\n  CreateBitGoOptions,\n  CreateMpcOptions,\n  GetKeychainOptions,\n  GetKeysForSigningOptions,\n  IKeychains,\n  Keychain,\n  ListKeychainOptions,\n  ListKeychainsResult,\n  RecreateMpcOptions,\n  UpdatePasswordOptions,\n  UpdateSingleKeychainPasswordOptions,\n} from './iKeychains';\nimport { BitGoKeyFromOvcShares, BitGoToOvcJSON, OvcToBitGoJSON } from './ovcJsonCodec';\n\nexport class Keychains implements IKeychains {\n  private readonly bitgo: BitGoBase;\n  private readonly baseCoin: IBaseCoin;\n\n  constructor(bitgo: BitGoBase, baseCoin: IBaseCoin) {\n    this.bitgo = bitgo;\n    this.baseCoin = baseCoin;\n  }\n\n  /**\n   * Get a keychain by ID\n   * @param params\n   * @param params.id\n   * @param params.xpub (optional)\n   * @param params.ethAddress (optional)\n   * @param params.reqId (optional)\n   */\n  async get(params: GetKeychainOptions): Promise<Keychain> {\n    common.validateParams(params, [], ['xpub', 'ethAddress']);\n\n    if (_.isUndefined(params.id)) {\n      throw new Error('id must be defined');\n    }\n\n    const id = params.id;\n    if (params.reqId) {\n      this.bitgo.setRequestTracer(params.reqId);\n    }\n    return await this.bitgo.get(this.baseCoin.url('/key/' + encodeURIComponent(id))).result();\n  }\n\n  /**\n   * list the users keychains\n   * @param params\n   * @param params.limit - Max number of results in a single call.\n   * @param params.prevId - Continue iterating (provided by nextBatchPrevId in the previous list)\n   * @returns {*}\n   */\n  async list(params: ListKeychainOptions = {}): Promise<ListKeychainsResult> {\n    const queryObject: any = {};\n\n    if (!_.isUndefined(params.limit)) {\n      if (!_.isNumber(params.limit)) {\n        throw new Error('invalid limit argument, expecting number');\n      }\n      queryObject.limit = params.limit;\n    }\n    if (!_.isUndefined(params.prevId)) {\n      if (!_.isString(params.prevId)) {\n        throw new Error('invalid prevId argument, expecting string');\n      }\n      queryObject.prevId = params.prevId;\n    }\n\n    return this.bitgo.get(this.baseCoin.url('/key')).query(queryObject).result();\n  }\n\n  /**\n   * Change the decryption password for all possible keychains associated with a user.\n   *\n   * This function iterates through all keys associated with the user, decrypts\n   * them with the old password and re-encrypts them with the new password.\n   *\n   * This should be called when a user changes their login password, and are expecting\n   * that their wallet passwords are changed to match the new login password.\n   *\n   * @param params\n   * @param params.oldPassword - The old password used for encrypting the key\n   * @param params.newPassword - The new password to be used for encrypting the key\n   * @returns changedKeys Object - e.g.:\n   *  {\n   *    xpub1: encryptedPrv,\n   *    ...\n   *  }\n   */\n  async updatePassword(params: UpdatePasswordOptions): Promise<ChangedKeychains> {\n    common.validateParams(params, ['oldPassword', 'newPassword'], []);\n    const changedKeys: ChangedKeychains = {};\n    let prevId;\n    let keysLeft = true;\n    while (keysLeft) {\n      const result: ListKeychainsResult = await this.list({ limit: 500, prevId });\n      for (const key of result.keys) {\n        const oldEncryptedPrv = key.encryptedPrv;\n        if (_.isUndefined(oldEncryptedPrv)) {\n          continue;\n        }\n        try {\n          const updatedKeychain = this.updateSingleKeychainPassword({\n            keychain: key,\n            oldPassword: params.oldPassword,\n            newPassword: params.newPassword,\n          });\n          if (updatedKeychain.encryptedPrv) {\n            const changedKeyIdentifier = updatedKeychain.type === 'tss' ? updatedKeychain.id : updatedKeychain.pub;\n            if (changedKeyIdentifier) {\n              changedKeys[changedKeyIdentifier] = updatedKeychain.encryptedPrv;\n            }\n          }\n        } catch (e) {\n          // if the password was incorrect, silence the error, throw otherwise\n          if (!e.message.includes('private key is incorrect')) {\n            throw e;\n          }\n        }\n      }\n      if (result.nextBatchPrevId) {\n        prevId = result.nextBatchPrevId;\n      } else {\n        keysLeft = false;\n      }\n    }\n    return changedKeys;\n  }\n\n  /**\n   * Update the password used to decrypt a single keychain\n   * @param params\n   * @param params.keychain - The keychain whose password should be updated\n   * @param params.oldPassword - The old password used for encrypting the key\n   * @param params.newPassword - The new password to be used for encrypting the key\n   * @returns {object}\n   */\n  updateSingleKeychainPassword(params: UpdateSingleKeychainPasswordOptions = {}): Keychain {\n    if (!_.isString(params.oldPassword)) {\n      throw new Error('expected old password to be a string');\n    }\n\n    if (!_.isString(params.newPassword)) {\n      throw new Error('expected new password to be a string');\n    }\n\n    if (!_.isObject(params.keychain) || !_.isString(params.keychain.encryptedPrv)) {\n      throw new Error('expected keychain to be an object with an encryptedPrv property');\n    }\n\n    const oldEncryptedPrv = params.keychain.encryptedPrv;\n    try {\n      const decryptedPrv = this.bitgo.decrypt({ input: oldEncryptedPrv, password: params.oldPassword });\n      const newEncryptedPrv = this.bitgo.encrypt({ input: decryptedPrv, password: params.newPassword });\n      return _.assign({}, params.keychain, { encryptedPrv: newEncryptedPrv });\n    } catch (e) {\n      // catching an error here means that the password was incorrect or, less likely, the input to decrypt is corrupted\n      throw new Error('password used to decrypt keychain private key is incorrect');\n    }\n  }\n\n  /**\n   * Create a public/private key pair\n   * @param params - optional params\n   * @param params.seed optional - seed to use for keypair generation\n   * @param params.isRootKey optional - whether the resulting keypair should be a root key\n   * @returns {KeyPair} - the generated keypair\n   */\n  create(params: { seed?: Buffer; isRootKey?: boolean } = {}): KeyPair {\n    if (params?.isRootKey) {\n      return this.baseCoin.generateRootKeyPair(params.seed);\n    }\n    return this.baseCoin.generateKeyPair(params.seed);\n  }\n\n  /**\n   * Add a keychain to BitGo's records\n   * @param params\n   */\n  async add(params: AddKeychainOptions = {}): Promise<Keychain> {\n    params = params || {};\n    common.validateParams(\n      params,\n      [],\n      [\n        'pub',\n        'encryptedPrv',\n        'keyType',\n        'type',\n        'source',\n        'originalPasscodeEncryptionCode',\n        'enterprise',\n        'derivedFromParentWithSeed',\n      ]\n    );\n\n    if (!_.isUndefined(params.disableKRSEmail)) {\n      if (!_.isBoolean(params.disableKRSEmail)) {\n        throw new Error('invalid disableKRSEmail argument, expecting boolean');\n      }\n    }\n\n    if (params.reqId) {\n      this.bitgo.setRequestTracer(params.reqId);\n    }\n\n    return await this.bitgo\n      .post(this.baseCoin.url('/key'))\n      .send({\n        pub: params.pub,\n        commonPub: params.commonPub,\n        commonKeychain: params.commonKeychain,\n        encryptedPrv: params.encryptedPrv,\n        type: params.type,\n        keyType: params.keyType,\n        source: params.source,\n        provider: params.provider,\n        originalPasscodeEncryptionCode: params.originalPasscodeEncryptionCode,\n        enterprise: params.enterprise,\n        derivedFromParentWithSeed: params.derivedFromParentWithSeed,\n        disableKRSEmail: params.disableKRSEmail,\n        krsSpecific: params.krsSpecific,\n        keyShares: params.keyShares,\n        userGPGPublicKey: params.userGPGPublicKey,\n        backupGPGPublicKey: params.backupGPGPublicKey,\n        algoUsed: params.algoUsed,\n        isDistributedCustody: params.isDistributedCustody,\n        isMPCv2: params.isMPCv2,\n        coinSpecific: params.coinSpecific,\n      })\n      .result();\n  }\n\n  /**\n   * Create a BitGo key\n   * @param params (empty)\n   */\n  async createBitGo(params: CreateBitGoOptions = {}): Promise<Keychain> {\n    params.source = 'bitgo';\n\n    this.baseCoin.preCreateBitGo(params as any);\n    return await this.add(params);\n  }\n\n  /**\n   * Create a backup key\n   * @param params\n   * @param params.provider (optional)\n   */\n  async createBackup(params: CreateBackupOptions = {}): Promise<Keychain> {\n    params.source = 'backup';\n\n    const isTssBackupKey = params.prv && (params.commonKeychain || params.commonPub);\n\n    if (_.isUndefined(params.provider) && !isTssBackupKey) {\n      // if the provider is undefined, we generate a local key and add the source details\n      const key = this.create();\n      _.extend(params, key);\n      if (params.passphrase !== undefined) {\n        _.extend(params, { encryptedPrv: this.bitgo.encrypt({ input: key.prv, password: params.passphrase }) });\n      }\n    }\n\n    const serverResponse = await this.add(params);\n    return _.extend({}, serverResponse, _.pick(params, ['prv', 'encryptedPrv', 'provider', 'source']));\n  }\n\n  /**\n   * Gets keys for signing from a wallet\n   * @param params\n   * @returns {Promise<Keychain[]>}\n   */\n  async getKeysForSigning(params: GetKeysForSigningOptions = {}): Promise<Keychain[]> {\n    if (!_.isObject(params.wallet)) {\n      throw new Error('missing required param wallet');\n    }\n    const wallet = params.wallet;\n    const reqId = params.reqId || new RequestTracer();\n    const ids = wallet.baseCoin.keyIdsForSigning();\n    const keychainQueriesBluebirds = ids.map((id) => this.get({ id: wallet.keyIds()[id], reqId }));\n    return Promise.all(keychainQueriesBluebirds);\n  }\n\n  /**\n   * Convenience function to create and store MPC keychains with BitGo.\n   * @param params passphrase used to encrypt secret materials\n   * @return {Promise<KeychainsTriplet>} newly created User, Backup, and BitGo keys\n   */\n  async createMpc(params: CreateMpcOptions): Promise<KeychainsTriplet> {\n    let MpcUtils;\n    let multisigTypeVersion: 'MPCv2' | undefined = undefined;\n    if (params.multisigType === 'tss' && this.baseCoin.getMPCAlgorithm() === 'ecdsa') {\n      const tssSettings: TssSettings = await this.bitgo\n        .get(this.bitgo.microservicesUrl('/api/v2/tss/settings'))\n        .result();\n      multisigTypeVersion =\n        tssSettings.coinSettings[this.baseCoin.getFamily()]?.walletCreationSettings?.multiSigTypeVersion;\n    }\n\n    switch (params.multisigType) {\n      case 'tss':\n        MpcUtils =\n          this.baseCoin.getMPCAlgorithm() === 'eddsa'\n            ? EDDSAUtils.default\n            : multisigTypeVersion === 'MPCv2'\n            ? ECDSAUtils.EcdsaMPCv2Utils\n            : ECDSAUtils.EcdsaUtils;\n        break;\n      case 'blsdkg':\n        if (_.isUndefined(params.passphrase)) {\n          throw new Error('missing required param passphrase');\n        }\n        MpcUtils = BlsUtils;\n        break;\n      default:\n        throw new Error('Unsupported multi-sig type');\n    }\n    const mpcUtils = new MpcUtils(this.bitgo, this.baseCoin);\n    return await mpcUtils.createKeychains({\n      passphrase: params.passphrase,\n      enterprise: params.enterprise,\n      originalPasscodeEncryptionCode: params.originalPasscodeEncryptionCode,\n      backupProvider: params.backupProvider,\n      retrofit: params.retrofit,\n    });\n  }\n\n  async recreateMpc(params: RecreateMpcOptions): Promise<KeychainsTriplet> {\n    assert(params.coin, new Error('missing required param coin'));\n    assert(params.walletId, new Error('missing required param walletId'));\n    assert(params.otp, new Error('missing required param otp'));\n    assert(params.passphrase, new Error('missing required param passphrase'));\n\n    assert(\n      params.encryptedMaterial.encryptedWalletPassphrase,\n      new Error('missing required param encryptedWalletPassphrase')\n    );\n    assert(params.encryptedMaterial.encryptedUserKey, new Error('missing required param encryptedUserKey'));\n    assert(params.encryptedMaterial.encryptedBackupKey, new Error('missing required param encryptedBackupKey'));\n\n    await this.bitgo.post(this.bitgo.microservicesUrl('/api/v1/user/unlock')).send({ otp: params.otp }).result();\n    const { recoveryInfo } = await this.bitgo\n      .post(this.bitgo.microservicesUrl(`/api/v2/${params.coin}/wallet/${params.walletId}/passcoderecovery`))\n      .result();\n\n    if (!recoveryInfo || !('passcodeEncryptionCode' in recoveryInfo)) {\n      throw new Error('failed to get recovery info');\n    }\n\n    const decryptedWalletPassphrase = this.bitgo.decrypt({\n      input: params.encryptedMaterial.encryptedWalletPassphrase,\n      password: recoveryInfo.passcodeEncryptionCode,\n    });\n\n    const decryptedUserKey = this.bitgo.decrypt({\n      input: params.encryptedMaterial.encryptedUserKey,\n      password: decryptedWalletPassphrase,\n    });\n\n    const decryptedBackupKey = this.bitgo.decrypt({\n      input: params.encryptedMaterial.encryptedBackupKey,\n      password: decryptedWalletPassphrase,\n    });\n\n    return this.createMpc({\n      ...params,\n      multisigType: 'tss',\n      retrofit: {\n        decryptedUserKey,\n        decryptedBackupKey,\n        walletId: params.walletId,\n      },\n    });\n  }\n\n  /**\n   * It parses the JSON downloaded from the OVC for platform (BitGo),\n   * and creates a corresponding TSS BitGo key. It also returns the JSON that needs\n   * to be uploaded back to the OVCs containing the BitGo -> OVC shares.\n   * @param ovcOutputJson JSON format of the file downloaded from the OVC for platform\n   * @returns {BitGoKeyFromOvcShares}\n   */\n  async createTssBitGoKeyFromOvcShares(ovcOutputJson: unknown): Promise<BitGoKeyFromOvcShares> {\n    const decodedOvcOutput = decodeOrElse(OvcToBitGoJSON.name, OvcToBitGoJSON, ovcOutputJson, (errors) => {\n      throw new Error(`Error(s) parsing OVC JSON: ${errors}`);\n    });\n\n    if (decodedOvcOutput.state !== 1) {\n      throw new Error('State expected to be \"1\". Please complete the first two OVC operations');\n    }\n\n    // OVC-1 is responsible for the User key\n    const ovc1 = decodedOvcOutput.ovc[1];\n    // OVC-2 is responsible for the Backup key\n    const ovc2 = decodedOvcOutput.ovc[2];\n\n    const keyShares: ApiKeyShare[] = [\n      {\n        from: 'user',\n        to: 'bitgo',\n        publicShare: ovc1.ovcToBitgoShare.publicShare,\n        privateShare: ovc1.ovcToBitgoShare.privateShare,\n        privateShareProof: ovc1.ovcToBitgoShare.uSig.toString() ?? '',\n        vssProof: ovc1.ovcToBitgoShare.vssProof ?? '',\n      },\n      {\n        from: 'backup',\n        to: 'bitgo',\n        publicShare: ovc2.ovcToBitgoShare.publicShare,\n        privateShare: ovc2.ovcToBitgoShare.privateShare,\n        privateShareProof: ovc2.ovcToBitgoShare.uSig.toString() ?? '',\n        vssProof: ovc2.ovcToBitgoShare.vssProof ?? '',\n      },\n    ];\n\n    const key = await this.baseCoin.keychains().add({\n      source: 'bitgo',\n      keyShares,\n      keyType: 'tss',\n      userGPGPublicKey: ovc1.gpgPubKey,\n      backupGPGPublicKey: ovc2.gpgPubKey,\n    });\n    assert(key.keyShares);\n    assert(key.commonKeychain);\n    assert(key.walletHSMGPGPublicKeySigs);\n\n    const bitgoToUserShare = key.keyShares.find(\n      (value: { from: string; to: string }) => value.from === 'bitgo' && value.to === 'user'\n    );\n    assert(bitgoToUserShare);\n    assert(bitgoToUserShare.vssProof);\n    assert(bitgoToUserShare.paillierPublicKey);\n    const bitgoToBackupShare = key.keyShares.find(\n      (value: { from: string; to: string }) => value.from === 'bitgo' && value.to === 'backup'\n    );\n    assert(bitgoToBackupShare);\n    assert(bitgoToBackupShare.vssProof);\n    assert(bitgoToBackupShare.paillierPublicKey);\n\n    // Create JSON data with platform shares for OVC-1 and OVC-2\n    const bitgoToOvcOutput: BitGoToOvcJSON = {\n      wallet: {\n        ...decodedOvcOutput,\n        platform: {\n          commonKeychain: key.commonKeychain,\n          walletGpgPubKeySigs: key.walletHSMGPGPublicKeySigs,\n          ovc: {\n            // BitGo to User (OVC-1)\n            1: {\n              bitgoToOvcShare: {\n                i: 1,\n                j: 3,\n                publicShare: bitgoToUserShare.publicShare,\n                privateShare: bitgoToUserShare.privateShare,\n                paillierPublicKey: bitgoToUserShare.paillierPublicKey,\n                vssProof: bitgoToUserShare.vssProof,\n              },\n            },\n            // BitGo to Backup (OVC-2)\n            2: {\n              bitgoToOvcShare: {\n                i: 2,\n                j: 3,\n                publicShare: bitgoToBackupShare.publicShare,\n                privateShare: bitgoToBackupShare.privateShare,\n                paillierPublicKey: bitgoToBackupShare.paillierPublicKey,\n                vssProof: bitgoToBackupShare.vssProof,\n              },\n            },\n          },\n        },\n      },\n    };\n\n    // Mark it ready for next operation, should be 2\n    bitgoToOvcOutput.wallet.state += 1;\n\n    const output: BitGoKeyFromOvcShares = {\n      bitGoKeyId: key.id,\n      bitGoOutputJsonForOvc: bitgoToOvcOutput,\n    };\n\n    return decodeOrElse(BitGoKeyFromOvcShares.name, BitGoKeyFromOvcShares, output, (errors) => {\n      throw new Error(`Error producing the output: ${errors}`);\n    });\n  }\n\n  /**\n   * Create user keychain, encrypt the private key with the wallet passphrase and store it in BitGo.\n   * @param walletPassphrase\n   * @returns Keychain including the decrypted private key\n   */\n  async createUserKeychain(walletPassphrase: string): Promise<Keychain> {\n    const keychains = this.baseCoin.keychains();\n    const newKeychain = keychains.create();\n    const originalPasscodeEncryptionCode = generateRandomPassword(5);\n\n    const encryptedPrv = this.bitgo.encrypt({\n      password: walletPassphrase,\n      input: newKeychain.prv,\n    });\n\n    return {\n      ...(await keychains.add({\n        encryptedPrv,\n        originalPasscodeEncryptionCode,\n        pub: newKeychain.pub,\n        source: 'user',\n      })),\n      prv: newKeychain.prv,\n    };\n  }\n}\n"]}
@@ -50,7 +50,7 @@ export declare function createUserToBitGoGShare(userSignShare: SignShare, bitgoT
50
50
  * @returns {Promise<void>}
51
51
  * @param {IRequestTracer} reqId - the request tracer request id
52
52
  */
53
- export declare function offerUserToBitgoRShare(bitgo: BitGoBase, walletId: string, txRequestId: string, userSignShare: SignShare, encryptedSignerShare: string, apiMode?: 'full' | 'lite', vssProof?: string, privateShareProof?: string, userPublicGpgKey?: string, publicShare?: string, reqId?: IRequestTracer): Promise<void>;
53
+ export declare function offerUserToBitgoRShare(bitgo: BitGoBase, walletId: string, txRequestId: string, userSignShare: SignShare, encryptedSignerShare: string, apiMode?: 'full' | 'lite', reqId?: IRequestTracer): Promise<void>;
54
54
  /**
55
55
  * Gets the Bitgo to User RShare from Bitgo
56
56
  *
@@ -1 +1 @@
1
- {"version":3,"file":"eddsa.d.ts","sourceRoot":"","sources":["../../../../../src/bitgo/tss/eddsa/eddsa.ts"],"names":[],"mappings":"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"}
1
+ {"version":3,"file":"eddsa.d.ts","sourceRoot":"","sources":["../../../../../src/bitgo/tss/eddsa/eddsa.ts"],"names":[],"mappings":"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"}
@@ -160,7 +160,7 @@ async function createUserToBitGoGShare(userSignShare, bitgoToUserRShare, backupT
160
160
  * @returns {Promise<void>}
161
161
  * @param {IRequestTracer} reqId - the request tracer request id
162
162
  */
163
- async function offerUserToBitgoRShare(bitgo, walletId, txRequestId, userSignShare, encryptedSignerShare, apiMode = 'lite', vssProof, privateShareProof, userPublicGpgKey, publicShare, reqId) {
163
+ async function offerUserToBitgoRShare(bitgo, walletId, txRequestId, userSignShare, encryptedSignerShare, apiMode = 'lite', reqId) {
164
164
  const rShare = userSignShare.rShares[types_1.ShareKeyPosition.BITGO];
165
165
  if (_.isNil(rShare)) {
166
166
  throw new Error('userToBitgo RShare not found');
@@ -172,12 +172,9 @@ async function offerUserToBitgoRShare(bitgo, walletId, txRequestId, userSignShar
172
172
  from: utils_1.SignatureShareType.USER,
173
173
  to: utils_1.SignatureShareType.BITGO,
174
174
  share: rShare.r + rShare.R,
175
- vssProof,
176
- privateShareProof,
177
- publicShare,
178
175
  };
179
176
  // TODO (BG-57944): implement message signing for EDDSA
180
- await (0, common_1.sendSignatureShare)(bitgo, walletId, txRequestId, signatureShare, utils_1.RequestType.tx, encryptedSignerShare, 'eddsa', apiMode, userPublicGpgKey, reqId);
177
+ await (0, common_1.sendSignatureShare)(bitgo, walletId, txRequestId, signatureShare, utils_1.RequestType.tx, encryptedSignerShare, 'eddsa', apiMode, undefined, reqId);
181
178
  }
182
179
  /**
183
180
  * Gets the Bitgo to User RShare from Bitgo
@@ -320,4 +317,4 @@ async function verifyWalletSignature(params) {
320
317
  const publicShareRawNotationIndex = 2 + verifierIndex;
321
318
  (0, assert_1.default)(publicShare === Buffer.from(rawNotations[publicShareRawNotationIndex].value).toString(), 'bitgo share mismatch');
322
319
  }
323
- //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"eddsa.js","sourceRoot":"","sources":["../../../../../src/bitgo/tss/eddsa/eddsa.ts"],"names":[],"mappings":"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","sourcesContent":["import assert from 'assert';\nimport openpgp from 'openpgp';\nimport sodium from 'libsodium-wrappers-sumo';\nimport Eddsa, { GShare, JShare, KeyShare, PShare, RShare, SignShare, YShare } from './../../../account-lib/mpc/tss';\nimport { BitGoBase } from '../../bitgoBase';\nimport {\n  DecryptableYShare,\n  CombinedKey,\n  SigningMaterial,\n  EncryptedYShare,\n  UserSigningMaterial,\n  BackupSigningMaterial,\n} from './types';\nimport { ShareKeyPosition } from '../types';\nimport {\n  encryptAndSignText,\n  readSignedMessage,\n  SignatureShareRecord,\n  SignatureShareType,\n  RequestType,\n  CommitmentShareRecord,\n  CommitmentType,\n} from '../../utils';\nimport { BaseTransaction } from '../../../account-lib';\nimport { Ed25519Bip32HdTree } from '@bitgo-beta/sdk-lib-mpc';\nimport _ = require('lodash');\nimport { commonVerifyWalletSignature, getTxRequest, sendSignatureShare } from '../common';\nimport { IRequestTracer } from '../../../api';\n\nexport { getTxRequest, sendSignatureShare };\n\n/**\n * Combines YShares to combine the final TSS key\n * This can only be used to create the User or Backup key since it requires the common keychain from BitGo first\n *\n * @param params.keyShare - TSS key share\n * @param params.encryptedYShares - encrypted YShares with information on how to decrypt\n * @param params.commonKeychain - expected common keychain of the combined key\n * @returns {CombinedKey} combined TSS key\n */\nexport async function createCombinedKey(params: {\n  keyShare: KeyShare;\n  encryptedYShares: DecryptableYShare[];\n  commonKeychain: string;\n}): Promise<CombinedKey> {\n  await Eddsa.initialize();\n  const MPC = new Eddsa();\n\n  const { keyShare, encryptedYShares, commonKeychain } = params;\n  const yShares: YShare[] = [];\n\n  let bitgoYShare: YShare | undefined;\n  let userYShare: YShare | undefined;\n  let backupYShare: YShare | undefined;\n\n  for (const encryptedYShare of encryptedYShares) {\n    const privateShare = await readSignedMessage(\n      encryptedYShare.yShare.encryptedPrivateShare,\n      encryptedYShare.senderPublicArmor,\n      encryptedYShare.recipientPrivateArmor\n    );\n\n    const yShare: YShare = {\n      i: encryptedYShare.yShare.i,\n      j: encryptedYShare.yShare.j,\n      y: encryptedYShare.yShare.publicShare.slice(0, 64),\n      v: encryptedYShare.yShare.publicShare.slice(64, 128),\n      u: privateShare.slice(0, 64),\n      chaincode: privateShare.slice(64),\n    };\n\n    switch (encryptedYShare.yShare.j) {\n      case 1:\n        userYShare = yShare;\n        break;\n      case 2:\n        backupYShare = yShare;\n        break;\n      case 3:\n        bitgoYShare = yShare;\n        break;\n      default:\n        throw new Error('Invalid YShare index');\n    }\n\n    yShares.push(yShare);\n  }\n\n  const combinedKey = MPC.keyCombine(keyShare.uShare, yShares);\n  if (combinedKey.pShare.y + combinedKey.pShare.chaincode !== commonKeychain) {\n    throw new Error('Common keychains do not match');\n  }\n  if (!bitgoYShare) {\n    throw new Error('Missing BitGo Y Share');\n  }\n\n  const signingMaterial: SigningMaterial = {\n    uShare: keyShare.uShare,\n    bitgoYShare,\n    backupYShare,\n    userYShare,\n  };\n\n  return {\n    signingMaterial,\n    commonKeychain,\n  };\n}\n\n/**\n * Creates the User Sign Share containing the User XShare , the User to Bitgo RShare and User to Bitgo commitment\n *\n * @param {Buffer} signablePayload - the signablePayload as a buffer\n * @param {PShare} pShare - User's signing material\n * @returns {Promise<SignShare>} - User Sign Share\n */\nexport async function createUserSignShare(signablePayload: Buffer, pShare: PShare): Promise<SignShare> {\n  const MPC = await Eddsa.initialize();\n\n  if (pShare.i !== ShareKeyPosition.USER) {\n    throw new Error('Invalid PShare, PShare doesnt belong to the User');\n  }\n  const jShare: JShare = { i: ShareKeyPosition.BITGO, j: ShareKeyPosition.USER };\n  return MPC.signShare(signablePayload, pShare, [jShare]);\n}\n\n/**\n * Creates the User to Bitgo GShare\n *\n * @param {SignShare} userSignShare - the User Sign Share\n * @param {SignatureShareRecord} bitgoToUserRShare - the Bitgo to User RShare\n * @param {YShare} backupToUserYShare - the backup key Y share received during wallet creation\n * @param {Buffer} signablePayload - the signable payload from a tx\n * @param {CommitmentShareRecord} [bitgoToUserCommitment] - the Bitgo to User Commitment\n * @returns {Promise<GShare>} - the User to Bitgo GShare\n */\nexport async function createUserToBitGoGShare(\n  userSignShare: SignShare,\n  bitgoToUserRShare: SignatureShareRecord,\n  backupToUserYShare: YShare,\n  bitgoToUserYShare: YShare,\n  signablePayload: Buffer,\n  bitgoToUserCommitment: CommitmentShareRecord\n): Promise<GShare> {\n  if (userSignShare.xShare.i !== ShareKeyPosition.USER) {\n    throw new Error('Invalid XShare, doesnt belong to the User');\n  }\n  if (bitgoToUserRShare.from !== SignatureShareType.BITGO || bitgoToUserRShare.to !== SignatureShareType.USER) {\n    throw new Error('Invalid RShare, is not from Bitgo to User');\n  }\n  if (backupToUserYShare.i !== ShareKeyPosition.USER) {\n    throw new Error('Invalid YShare, doesnt belong to the User');\n  }\n  if (backupToUserYShare.j !== ShareKeyPosition.BACKUP) {\n    throw new Error('Invalid YShare, is not backup key');\n  }\n  if (bitgoToUserCommitment.from !== SignatureShareType.BITGO || bitgoToUserCommitment.to !== SignatureShareType.USER) {\n    throw new Error('Invalid Commitment, is not from Bitgo to User');\n  }\n  if (bitgoToUserCommitment.type !== CommitmentType.COMMITMENT) {\n    throw new Error('Invalid Commitment type, got: ' + bitgoToUserCommitment.type + ' expected: commitment');\n  }\n\n  let v, r, R;\n  if (bitgoToUserRShare.share.length > 128) {\n    v = bitgoToUserRShare.share.substring(0, 64);\n    r = bitgoToUserRShare.share.substring(64, 128);\n    R = bitgoToUserRShare.share.substring(128, 192);\n  } else {\n    r = bitgoToUserRShare.share.substring(0, 64);\n    R = bitgoToUserRShare.share.substring(64, 128);\n  }\n\n  const MPC = await Eddsa.initialize();\n\n  const updatedBitgoToUserRShare: RShare = {\n    i: ShareKeyPosition.USER,\n    j: ShareKeyPosition.BITGO,\n    u: bitgoToUserYShare.u,\n    v,\n    r,\n    R,\n    commitment: bitgoToUserCommitment.share,\n  };\n\n  return MPC.sign(signablePayload, userSignShare.xShare, [updatedBitgoToUserRShare], [backupToUserYShare]);\n}\n\n/**\n * Sends the User to Bitgo RShare to Bitgo\n * @param {BitGoBase} bitgo - the bitgo instance\n * @param {String} walletId - the wallet id\n * @param {String} txRequestId - the txRequest Id\n * @param {SignShare} userSignShare - the user Sign Share\n * @param {String} encryptedSignerShare - signer share encrypted to bitgo key\n * @returns {Promise<void>}\n * @param {IRequestTracer} reqId - the request tracer request id\n */\nexport async function offerUserToBitgoRShare(\n  bitgo: BitGoBase,\n  walletId: string,\n  txRequestId: string,\n  userSignShare: SignShare,\n  encryptedSignerShare: string,\n  apiMode: 'full' | 'lite' = 'lite',\n  vssProof?: string,\n  privateShareProof?: string,\n  userPublicGpgKey?: string,\n  publicShare?: string,\n  reqId?: IRequestTracer\n): Promise<void> {\n  const rShare: RShare = userSignShare.rShares[ShareKeyPosition.BITGO];\n  if (_.isNil(rShare)) {\n    throw new Error('userToBitgo RShare not found');\n  }\n  if (rShare.i !== ShareKeyPosition.BITGO || rShare.j !== ShareKeyPosition.USER) {\n    throw new Error('Invalid RShare, is not from User to Bitgo');\n  }\n  const signatureShare: SignatureShareRecord = {\n    from: SignatureShareType.USER,\n    to: SignatureShareType.BITGO,\n    share: rShare.r + rShare.R,\n    vssProof,\n    privateShareProof,\n    publicShare,\n  };\n\n  // TODO (BG-57944): implement message signing for EDDSA\n  await sendSignatureShare(\n    bitgo,\n    walletId,\n    txRequestId,\n    signatureShare,\n    RequestType.tx,\n    encryptedSignerShare,\n    'eddsa',\n    apiMode,\n    userPublicGpgKey,\n    reqId\n  );\n}\n\n/**\n * Gets the Bitgo to User RShare from Bitgo\n *\n * @param {BitGoBase} bitgo - the bitgo instance\n * @param {String} walletId - the wallet id\n * @param {String} txRequestId - the txRequest Id\n * @param {IRequestTracer} reqId - the request tracer request id\n * @returns {Promise<SignatureShareRecord>} - a Signature Share\n */\nexport async function getBitgoToUserRShare(\n  bitgo: BitGoBase,\n  walletId: string,\n  txRequestId: string,\n  reqId?: IRequestTracer\n): Promise<SignatureShareRecord> {\n  const txRequest = await getTxRequest(bitgo, walletId, txRequestId, reqId);\n  let signatureShares;\n  if (txRequest.apiVersion === 'full') {\n    assert(txRequest.transactions, 'transactions required as part of txRequest');\n    signatureShares = txRequest.transactions[0].signatureShares;\n  } else {\n    signatureShares = txRequest.signatureShares;\n  }\n  if (_.isNil(signatureShares) || _.isEmpty(signatureShares)) {\n    throw new Error(`No signatures shares found for id: ${txRequestId}`);\n  }\n  // at this point we expect the only share to be the RShare\n  const bitgoToUserRShare = signatureShares.find(\n    (sigShare) => sigShare.from === SignatureShareType.BITGO && sigShare.to === SignatureShareType.USER\n  );\n  if (_.isNil(bitgoToUserRShare)) {\n    throw new Error(`Bitgo to User RShare not found for id: ${txRequestId}`);\n  }\n  return bitgoToUserRShare;\n}\n\n/**\n * Sends the User to Bitgo GShare to Bitgo\n *\n * @param {BitGoBase} bitgo - the bitgo instance\n * @param {String} walletId - the wallet id\n * @param {String} txRequestId - the txRequest Id\n * @param {GShare} userToBitgoGShare - the User to Bitgo GShare\n * @param {IRequestTracer} reqId - the request tracer request id\n * @returns {Promise<void>}\n */\nexport async function sendUserToBitgoGShare(\n  bitgo: BitGoBase,\n  walletId: string,\n  txRequestId: string,\n  userToBitgoGShare: GShare,\n  apiMode: 'full' | 'lite' = 'lite',\n  reqId?: IRequestTracer\n): Promise<void> {\n  if (userToBitgoGShare.i !== ShareKeyPosition.USER) {\n    throw new Error('Invalid GShare, doesnt belong to the User');\n  }\n  const signatureShare: SignatureShareRecord = {\n    from: SignatureShareType.USER,\n    to: SignatureShareType.BITGO,\n    share: userToBitgoGShare.R + userToBitgoGShare.gamma,\n  };\n\n  // TODO (BG-57944): implement message signing for EDDSA\n  await sendSignatureShare(\n    bitgo,\n    walletId,\n    txRequestId,\n    signatureShare,\n    RequestType.tx,\n    undefined,\n    'eddsa',\n    apiMode,\n    undefined,\n    reqId\n  );\n}\n\n/**\n * Prepares a YShare to be exchanged with other key holders.\n * Output is in a format that is usable within BitGo's ecosystem.\n *\n * @param params.keyShare - TSS key share of the party preparing exchange materials\n * @param params.recipientIndex - index of the recipient (1, 2, or 3)\n * @param params.recipientGpgPublicArmor - recipient's public gpg key in armor format\n * @param params.senderGpgPrivateArmor - sender's private gpg key in armor format\n * @returns { EncryptedYShare } encrypted Y Share\n */\nexport async function encryptYShare(params: {\n  keyShare: KeyShare;\n  recipientIndex: number;\n  recipientGpgPublicArmor: string;\n  senderGpgPrivateArmor: string;\n}): Promise<EncryptedYShare> {\n  const { keyShare, recipientIndex, recipientGpgPublicArmor, senderGpgPrivateArmor } = params;\n\n  const yShare = keyShare.yShares[recipientIndex];\n  if (!yShare) {\n    throw new Error('Invalid recipient');\n  }\n\n  const publicShare = Buffer.concat([\n    Buffer.from(keyShare.uShare.y, 'hex'),\n    Buffer.from(yShare.v!, 'hex'),\n    Buffer.from(keyShare.uShare.chaincode, 'hex'),\n  ]).toString('hex');\n\n  const privateShare = Buffer.concat([Buffer.from(yShare.u, 'hex'), Buffer.from(yShare.chaincode, 'hex')]).toString(\n    'hex'\n  );\n\n  const encryptedPrivateShare = await encryptAndSignText(privateShare, recipientGpgPublicArmor, senderGpgPrivateArmor);\n\n  return {\n    i: yShare.i,\n    j: yShare.j,\n    publicShare,\n    encryptedPrivateShare,\n  };\n}\n\n/**\n *\n * Initializes Eddsa instance\n *\n * @returns {Promise<Eddsa>} the Eddsa instance\n */\nexport async function getInitializedMpcInstance() {\n  const hdTree = await Ed25519Bip32HdTree.initialize();\n  return await Eddsa.initialize(hdTree);\n}\n\n/**\n *\n * Generates a TSS signature using the user and backup key\n *\n * @param {UserSigningMaterial} userSigningMaterial decrypted user TSS key\n * @param {BackupSigningMaterial} backupSigningMaterial decrypted backup TSS key\n * @param {string} path bip32 derivation path\n * @param {BaseTransaction} transaction the transaction to sign\n * @returns {Buffer} the signature\n */\nexport async function getTSSSignature(\n  userSigningMaterial: UserSigningMaterial,\n  backupSigningMaterial: BackupSigningMaterial,\n  path = 'm/0',\n  transaction: BaseTransaction\n): Promise<Buffer> {\n  const MPC = await getInitializedMpcInstance();\n\n  const userCombine = MPC.keyCombine(userSigningMaterial.uShare, [\n    userSigningMaterial.bitgoYShare,\n    userSigningMaterial.backupYShare,\n  ]);\n  const backupCombine = MPC.keyCombine(backupSigningMaterial.uShare, [\n    backupSigningMaterial.bitgoYShare,\n    backupSigningMaterial.userYShare,\n  ]);\n\n  const userSubkey = MPC.keyDerive(\n    userSigningMaterial.uShare,\n    [userSigningMaterial.bitgoYShare, userSigningMaterial.backupYShare],\n    path\n  );\n\n  const backupSubkey = MPC.keyCombine(backupSigningMaterial.uShare, [\n    userSubkey.yShares[2],\n    backupSigningMaterial.bitgoYShare,\n  ]);\n\n  const messageBuffer = transaction.signablePayload;\n  const userSignShare = MPC.signShare(messageBuffer, userSubkey.pShare, [userCombine.jShares[2]]);\n  const backupSignShare = MPC.signShare(messageBuffer, backupSubkey.pShare, [backupCombine.jShares[1]]);\n  const userSign = MPC.sign(\n    messageBuffer,\n    userSignShare.xShare,\n    [backupSignShare.rShares[1]],\n    [userSigningMaterial.bitgoYShare]\n  );\n  const backupSign = MPC.sign(\n    messageBuffer,\n    backupSignShare.xShare,\n    [userSignShare.rShares[2]],\n    [backupSigningMaterial.bitgoYShare]\n  );\n  const signature = MPC.signCombine([userSign, backupSign]);\n  const result = MPC.verify(messageBuffer, signature);\n  if (!result) {\n    throw new Error('Invalid signature');\n  }\n  const rawSignature = Buffer.concat([Buffer.from(signature.R, 'hex'), Buffer.from(signature.sigma, 'hex')]);\n  return rawSignature;\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, the expected user and backup key ids as well as the public share that is generated from the\n * private share that was passed in.\n */\nexport async function verifyWalletSignature(params: {\n  walletSignature: openpgp.Key;\n  bitgoPub: openpgp.Key;\n  commonKeychain: string;\n  userKeyId: string;\n  backupKeyId: string;\n  decryptedShare: string;\n  verifierIndex: 1 | 2; // the index of the verifier, 1 means user, 2 means backup\n}): Promise<void> {\n  const rawNotations = await commonVerifyWalletSignature(params);\n\n  const { decryptedShare, verifierIndex } = params;\n\n  const publicShare =\n    Buffer.from(\n      await sodium.crypto_scalarmult_ed25519_base_noclamp(Buffer.from(decryptedShare.slice(0, 64), 'hex'))\n    ).toString('hex') + decryptedShare.slice(64);\n  const publicShareRawNotationIndex = 2 + verifierIndex;\n\n  assert(\n    publicShare === Buffer.from(rawNotations[publicShareRawNotationIndex].value).toString(),\n    'bitgo share mismatch'\n  );\n}\n"]}
320
+ //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"eddsa.js","sourceRoot":"","sources":["../../../../../src/bitgo/tss/eddsa/eddsa.ts"],"names":[],"mappings":"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","sourcesContent":["import assert from 'assert';\nimport openpgp from 'openpgp';\nimport sodium from 'libsodium-wrappers-sumo';\nimport Eddsa, { GShare, JShare, KeyShare, PShare, RShare, SignShare, YShare } from './../../../account-lib/mpc/tss';\nimport { BitGoBase } from '../../bitgoBase';\nimport {\n  DecryptableYShare,\n  CombinedKey,\n  SigningMaterial,\n  EncryptedYShare,\n  UserSigningMaterial,\n  BackupSigningMaterial,\n} from './types';\nimport { ShareKeyPosition } from '../types';\nimport {\n  encryptAndSignText,\n  readSignedMessage,\n  SignatureShareRecord,\n  SignatureShareType,\n  RequestType,\n  CommitmentShareRecord,\n  CommitmentType,\n} from '../../utils';\nimport { BaseTransaction } from '../../../account-lib';\nimport { Ed25519Bip32HdTree } from '@bitgo-beta/sdk-lib-mpc';\nimport _ = require('lodash');\nimport { commonVerifyWalletSignature, getTxRequest, sendSignatureShare } from '../common';\nimport { IRequestTracer } from '../../../api';\n\nexport { getTxRequest, sendSignatureShare };\n\n/**\n * Combines YShares to combine the final TSS key\n * This can only be used to create the User or Backup key since it requires the common keychain from BitGo first\n *\n * @param params.keyShare - TSS key share\n * @param params.encryptedYShares - encrypted YShares with information on how to decrypt\n * @param params.commonKeychain - expected common keychain of the combined key\n * @returns {CombinedKey} combined TSS key\n */\nexport async function createCombinedKey(params: {\n  keyShare: KeyShare;\n  encryptedYShares: DecryptableYShare[];\n  commonKeychain: string;\n}): Promise<CombinedKey> {\n  await Eddsa.initialize();\n  const MPC = new Eddsa();\n\n  const { keyShare, encryptedYShares, commonKeychain } = params;\n  const yShares: YShare[] = [];\n\n  let bitgoYShare: YShare | undefined;\n  let userYShare: YShare | undefined;\n  let backupYShare: YShare | undefined;\n\n  for (const encryptedYShare of encryptedYShares) {\n    const privateShare = await readSignedMessage(\n      encryptedYShare.yShare.encryptedPrivateShare,\n      encryptedYShare.senderPublicArmor,\n      encryptedYShare.recipientPrivateArmor\n    );\n\n    const yShare: YShare = {\n      i: encryptedYShare.yShare.i,\n      j: encryptedYShare.yShare.j,\n      y: encryptedYShare.yShare.publicShare.slice(0, 64),\n      v: encryptedYShare.yShare.publicShare.slice(64, 128),\n      u: privateShare.slice(0, 64),\n      chaincode: privateShare.slice(64),\n    };\n\n    switch (encryptedYShare.yShare.j) {\n      case 1:\n        userYShare = yShare;\n        break;\n      case 2:\n        backupYShare = yShare;\n        break;\n      case 3:\n        bitgoYShare = yShare;\n        break;\n      default:\n        throw new Error('Invalid YShare index');\n    }\n\n    yShares.push(yShare);\n  }\n\n  const combinedKey = MPC.keyCombine(keyShare.uShare, yShares);\n  if (combinedKey.pShare.y + combinedKey.pShare.chaincode !== commonKeychain) {\n    throw new Error('Common keychains do not match');\n  }\n  if (!bitgoYShare) {\n    throw new Error('Missing BitGo Y Share');\n  }\n\n  const signingMaterial: SigningMaterial = {\n    uShare: keyShare.uShare,\n    bitgoYShare,\n    backupYShare,\n    userYShare,\n  };\n\n  return {\n    signingMaterial,\n    commonKeychain,\n  };\n}\n\n/**\n * Creates the User Sign Share containing the User XShare , the User to Bitgo RShare and User to Bitgo commitment\n *\n * @param {Buffer} signablePayload - the signablePayload as a buffer\n * @param {PShare} pShare - User's signing material\n * @returns {Promise<SignShare>} - User Sign Share\n */\nexport async function createUserSignShare(signablePayload: Buffer, pShare: PShare): Promise<SignShare> {\n  const MPC = await Eddsa.initialize();\n\n  if (pShare.i !== ShareKeyPosition.USER) {\n    throw new Error('Invalid PShare, PShare doesnt belong to the User');\n  }\n  const jShare: JShare = { i: ShareKeyPosition.BITGO, j: ShareKeyPosition.USER };\n  return MPC.signShare(signablePayload, pShare, [jShare]);\n}\n\n/**\n * Creates the User to Bitgo GShare\n *\n * @param {SignShare} userSignShare - the User Sign Share\n * @param {SignatureShareRecord} bitgoToUserRShare - the Bitgo to User RShare\n * @param {YShare} backupToUserYShare - the backup key Y share received during wallet creation\n * @param {Buffer} signablePayload - the signable payload from a tx\n * @param {CommitmentShareRecord} [bitgoToUserCommitment] - the Bitgo to User Commitment\n * @returns {Promise<GShare>} - the User to Bitgo GShare\n */\nexport async function createUserToBitGoGShare(\n  userSignShare: SignShare,\n  bitgoToUserRShare: SignatureShareRecord,\n  backupToUserYShare: YShare,\n  bitgoToUserYShare: YShare,\n  signablePayload: Buffer,\n  bitgoToUserCommitment: CommitmentShareRecord\n): Promise<GShare> {\n  if (userSignShare.xShare.i !== ShareKeyPosition.USER) {\n    throw new Error('Invalid XShare, doesnt belong to the User');\n  }\n  if (bitgoToUserRShare.from !== SignatureShareType.BITGO || bitgoToUserRShare.to !== SignatureShareType.USER) {\n    throw new Error('Invalid RShare, is not from Bitgo to User');\n  }\n  if (backupToUserYShare.i !== ShareKeyPosition.USER) {\n    throw new Error('Invalid YShare, doesnt belong to the User');\n  }\n  if (backupToUserYShare.j !== ShareKeyPosition.BACKUP) {\n    throw new Error('Invalid YShare, is not backup key');\n  }\n  if (bitgoToUserCommitment.from !== SignatureShareType.BITGO || bitgoToUserCommitment.to !== SignatureShareType.USER) {\n    throw new Error('Invalid Commitment, is not from Bitgo to User');\n  }\n  if (bitgoToUserCommitment.type !== CommitmentType.COMMITMENT) {\n    throw new Error('Invalid Commitment type, got: ' + bitgoToUserCommitment.type + ' expected: commitment');\n  }\n\n  let v, r, R;\n  if (bitgoToUserRShare.share.length > 128) {\n    v = bitgoToUserRShare.share.substring(0, 64);\n    r = bitgoToUserRShare.share.substring(64, 128);\n    R = bitgoToUserRShare.share.substring(128, 192);\n  } else {\n    r = bitgoToUserRShare.share.substring(0, 64);\n    R = bitgoToUserRShare.share.substring(64, 128);\n  }\n\n  const MPC = await Eddsa.initialize();\n\n  const updatedBitgoToUserRShare: RShare = {\n    i: ShareKeyPosition.USER,\n    j: ShareKeyPosition.BITGO,\n    u: bitgoToUserYShare.u,\n    v,\n    r,\n    R,\n    commitment: bitgoToUserCommitment.share,\n  };\n\n  return MPC.sign(signablePayload, userSignShare.xShare, [updatedBitgoToUserRShare], [backupToUserYShare]);\n}\n\n/**\n * Sends the User to Bitgo RShare to Bitgo\n * @param {BitGoBase} bitgo - the bitgo instance\n * @param {String} walletId - the wallet id\n * @param {String} txRequestId - the txRequest Id\n * @param {SignShare} userSignShare - the user Sign Share\n * @param {String} encryptedSignerShare - signer share encrypted to bitgo key\n * @returns {Promise<void>}\n * @param {IRequestTracer} reqId - the request tracer request id\n */\nexport async function offerUserToBitgoRShare(\n  bitgo: BitGoBase,\n  walletId: string,\n  txRequestId: string,\n  userSignShare: SignShare,\n  encryptedSignerShare: string,\n  apiMode: 'full' | 'lite' = 'lite',\n  reqId?: IRequestTracer\n): Promise<void> {\n  const rShare: RShare = userSignShare.rShares[ShareKeyPosition.BITGO];\n  if (_.isNil(rShare)) {\n    throw new Error('userToBitgo RShare not found');\n  }\n  if (rShare.i !== ShareKeyPosition.BITGO || rShare.j !== ShareKeyPosition.USER) {\n    throw new Error('Invalid RShare, is not from User to Bitgo');\n  }\n  const signatureShare: SignatureShareRecord = {\n    from: SignatureShareType.USER,\n    to: SignatureShareType.BITGO,\n    share: rShare.r + rShare.R,\n  };\n\n  // TODO (BG-57944): implement message signing for EDDSA\n  await sendSignatureShare(\n    bitgo,\n    walletId,\n    txRequestId,\n    signatureShare,\n    RequestType.tx,\n    encryptedSignerShare,\n    'eddsa',\n    apiMode,\n    undefined,\n    reqId\n  );\n}\n\n/**\n * Gets the Bitgo to User RShare from Bitgo\n *\n * @param {BitGoBase} bitgo - the bitgo instance\n * @param {String} walletId - the wallet id\n * @param {String} txRequestId - the txRequest Id\n * @param {IRequestTracer} reqId - the request tracer request id\n * @returns {Promise<SignatureShareRecord>} - a Signature Share\n */\nexport async function getBitgoToUserRShare(\n  bitgo: BitGoBase,\n  walletId: string,\n  txRequestId: string,\n  reqId?: IRequestTracer\n): Promise<SignatureShareRecord> {\n  const txRequest = await getTxRequest(bitgo, walletId, txRequestId, reqId);\n  let signatureShares;\n  if (txRequest.apiVersion === 'full') {\n    assert(txRequest.transactions, 'transactions required as part of txRequest');\n    signatureShares = txRequest.transactions[0].signatureShares;\n  } else {\n    signatureShares = txRequest.signatureShares;\n  }\n  if (_.isNil(signatureShares) || _.isEmpty(signatureShares)) {\n    throw new Error(`No signatures shares found for id: ${txRequestId}`);\n  }\n  // at this point we expect the only share to be the RShare\n  const bitgoToUserRShare = signatureShares.find(\n    (sigShare) => sigShare.from === SignatureShareType.BITGO && sigShare.to === SignatureShareType.USER\n  );\n  if (_.isNil(bitgoToUserRShare)) {\n    throw new Error(`Bitgo to User RShare not found for id: ${txRequestId}`);\n  }\n  return bitgoToUserRShare;\n}\n\n/**\n * Sends the User to Bitgo GShare to Bitgo\n *\n * @param {BitGoBase} bitgo - the bitgo instance\n * @param {String} walletId - the wallet id\n * @param {String} txRequestId - the txRequest Id\n * @param {GShare} userToBitgoGShare - the User to Bitgo GShare\n * @param {IRequestTracer} reqId - the request tracer request id\n * @returns {Promise<void>}\n */\nexport async function sendUserToBitgoGShare(\n  bitgo: BitGoBase,\n  walletId: string,\n  txRequestId: string,\n  userToBitgoGShare: GShare,\n  apiMode: 'full' | 'lite' = 'lite',\n  reqId?: IRequestTracer\n): Promise<void> {\n  if (userToBitgoGShare.i !== ShareKeyPosition.USER) {\n    throw new Error('Invalid GShare, doesnt belong to the User');\n  }\n  const signatureShare: SignatureShareRecord = {\n    from: SignatureShareType.USER,\n    to: SignatureShareType.BITGO,\n    share: userToBitgoGShare.R + userToBitgoGShare.gamma,\n  };\n\n  // TODO (BG-57944): implement message signing for EDDSA\n  await sendSignatureShare(\n    bitgo,\n    walletId,\n    txRequestId,\n    signatureShare,\n    RequestType.tx,\n    undefined,\n    'eddsa',\n    apiMode,\n    undefined,\n    reqId\n  );\n}\n\n/**\n * Prepares a YShare to be exchanged with other key holders.\n * Output is in a format that is usable within BitGo's ecosystem.\n *\n * @param params.keyShare - TSS key share of the party preparing exchange materials\n * @param params.recipientIndex - index of the recipient (1, 2, or 3)\n * @param params.recipientGpgPublicArmor - recipient's public gpg key in armor format\n * @param params.senderGpgPrivateArmor - sender's private gpg key in armor format\n * @returns { EncryptedYShare } encrypted Y Share\n */\nexport async function encryptYShare(params: {\n  keyShare: KeyShare;\n  recipientIndex: number;\n  recipientGpgPublicArmor: string;\n  senderGpgPrivateArmor: string;\n}): Promise<EncryptedYShare> {\n  const { keyShare, recipientIndex, recipientGpgPublicArmor, senderGpgPrivateArmor } = params;\n\n  const yShare = keyShare.yShares[recipientIndex];\n  if (!yShare) {\n    throw new Error('Invalid recipient');\n  }\n\n  const publicShare = Buffer.concat([\n    Buffer.from(keyShare.uShare.y, 'hex'),\n    Buffer.from(yShare.v!, 'hex'),\n    Buffer.from(keyShare.uShare.chaincode, 'hex'),\n  ]).toString('hex');\n\n  const privateShare = Buffer.concat([Buffer.from(yShare.u, 'hex'), Buffer.from(yShare.chaincode, 'hex')]).toString(\n    'hex'\n  );\n\n  const encryptedPrivateShare = await encryptAndSignText(privateShare, recipientGpgPublicArmor, senderGpgPrivateArmor);\n\n  return {\n    i: yShare.i,\n    j: yShare.j,\n    publicShare,\n    encryptedPrivateShare,\n  };\n}\n\n/**\n *\n * Initializes Eddsa instance\n *\n * @returns {Promise<Eddsa>} the Eddsa instance\n */\nexport async function getInitializedMpcInstance() {\n  const hdTree = await Ed25519Bip32HdTree.initialize();\n  return await Eddsa.initialize(hdTree);\n}\n\n/**\n *\n * Generates a TSS signature using the user and backup key\n *\n * @param {UserSigningMaterial} userSigningMaterial decrypted user TSS key\n * @param {BackupSigningMaterial} backupSigningMaterial decrypted backup TSS key\n * @param {string} path bip32 derivation path\n * @param {BaseTransaction} transaction the transaction to sign\n * @returns {Buffer} the signature\n */\nexport async function getTSSSignature(\n  userSigningMaterial: UserSigningMaterial,\n  backupSigningMaterial: BackupSigningMaterial,\n  path = 'm/0',\n  transaction: BaseTransaction\n): Promise<Buffer> {\n  const MPC = await getInitializedMpcInstance();\n\n  const userCombine = MPC.keyCombine(userSigningMaterial.uShare, [\n    userSigningMaterial.bitgoYShare,\n    userSigningMaterial.backupYShare,\n  ]);\n  const backupCombine = MPC.keyCombine(backupSigningMaterial.uShare, [\n    backupSigningMaterial.bitgoYShare,\n    backupSigningMaterial.userYShare,\n  ]);\n\n  const userSubkey = MPC.keyDerive(\n    userSigningMaterial.uShare,\n    [userSigningMaterial.bitgoYShare, userSigningMaterial.backupYShare],\n    path\n  );\n\n  const backupSubkey = MPC.keyCombine(backupSigningMaterial.uShare, [\n    userSubkey.yShares[2],\n    backupSigningMaterial.bitgoYShare,\n  ]);\n\n  const messageBuffer = transaction.signablePayload;\n  const userSignShare = MPC.signShare(messageBuffer, userSubkey.pShare, [userCombine.jShares[2]]);\n  const backupSignShare = MPC.signShare(messageBuffer, backupSubkey.pShare, [backupCombine.jShares[1]]);\n  const userSign = MPC.sign(\n    messageBuffer,\n    userSignShare.xShare,\n    [backupSignShare.rShares[1]],\n    [userSigningMaterial.bitgoYShare]\n  );\n  const backupSign = MPC.sign(\n    messageBuffer,\n    backupSignShare.xShare,\n    [userSignShare.rShares[2]],\n    [backupSigningMaterial.bitgoYShare]\n  );\n  const signature = MPC.signCombine([userSign, backupSign]);\n  const result = MPC.verify(messageBuffer, signature);\n  if (!result) {\n    throw new Error('Invalid signature');\n  }\n  const rawSignature = Buffer.concat([Buffer.from(signature.R, 'hex'), Buffer.from(signature.sigma, 'hex')]);\n  return rawSignature;\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, the expected user and backup key ids as well as the public share that is generated from the\n * private share that was passed in.\n */\nexport async function verifyWalletSignature(params: {\n  walletSignature: openpgp.Key;\n  bitgoPub: openpgp.Key;\n  commonKeychain: string;\n  userKeyId: string;\n  backupKeyId: string;\n  decryptedShare: string;\n  verifierIndex: 1 | 2; // the index of the verifier, 1 means user, 2 means backup\n}): Promise<void> {\n  const rawNotations = await commonVerifyWalletSignature(params);\n\n  const { decryptedShare, verifierIndex } = params;\n\n  const publicShare =\n    Buffer.from(\n      await sodium.crypto_scalarmult_ed25519_base_noclamp(Buffer.from(decryptedShare.slice(0, 64), 'hex'))\n    ).toString('hex') + decryptedShare.slice(64);\n  const publicShareRawNotationIndex = 2 + verifierIndex;\n\n  assert(\n    publicShare === Buffer.from(rawNotations[publicShareRawNotationIndex].value).toString(),\n    'bitgo share mismatch'\n  );\n}\n"]}
@@ -1 +1 @@
1
- {"version":3,"file":"eddsa.d.ts","sourceRoot":"","sources":["../../../../../../src/bitgo/utils/tss/eddsa/eddsa.ts"],"names":[],"mappings":"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"}
1
+ {"version":3,"file":"eddsa.d.ts","sourceRoot":"","sources":["../../../../../../src/bitgo/utils/tss/eddsa/eddsa.ts"],"names":[],"mappings":"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"}