@bitgo-beta/sdk-core 8.2.1-beta.729 → 8.2.1-beta.730

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.
@@ -1,4 +1,4 @@
1
- import { BIP32Interface, ECPairInterface } from '@bitgo-beta/utxo-lib';
1
+ import { BIP32Interface, ECPairInterface } from '@bitgo-beta/secp256k1';
2
2
  import { KeyPairOptions, ExtendedKeys } from './iface';
3
3
  import { BaseKeyPair } from './baseKeyPair';
4
4
  import { AddressFormat } from './enum';
@@ -1 +1 @@
1
- {"version":3,"file":"secp256k1ExtendedKeyPair.d.ts","sourceRoot":"","sources":["../../../../src/account-lib/baseCoin/secp256k1ExtendedKeyPair.ts"],"names":[],"mappings":"AAAA,OAAO,EAAS,cAAc,EAAU,eAAe,EAAE,MAAM,sBAAsB,CAAC;AAEtF,OAAO,EAAE,cAAc,EAAE,YAAY,EAAE,MAAM,SAAS,CAAC;AACvD,OAAO,EAAE,WAAW,EAAE,MAAM,eAAe,CAAC;AAC5C,OAAO,EAAE,aAAa,EAAE,MAAM,QAAQ,CAAC;AAGvC;;GAEG;AACH,8BAAsB,wBAAyB,YAAW,WAAW;IACnE,MAAM,CAAC,SAAS,CAAC,MAAM,EAAE,cAAc,GAAG,eAAe;IAUzD,SAAS,CAAC,MAAM,CAAC,EAAE,cAAc,CAAC;IAClC,SAAS,CAAC,OAAO,EAAE,eAAe,CAAC;IACnC,SAAS,CAAC,MAAM,CAAC,EAAE,cAAc,CAAC;IAClC;;;;;OAKG;IACH,SAAS,aAAa,MAAM,CAAC,EAAE,cAAc;IAI7C;;;OAGG;IACH,YAAY,CAAC,EAAE,UAAU,EAAE,EAAE;QAAE,UAAU,EAAE,OAAO,CAAA;KAAE,GAAG,MAAM;IAI7D;;OAEG;IACH,aAAa,IAAI,MAAM,GAAG,SAAS;IAInC;;;;OAIG;IACH,wBAAwB,CAAC,GAAG,EAAE,MAAM,GAAG,IAAI;IAW3C;;;;OAIG;IACH,uBAAuB,CAAC,GAAG,EAAE,MAAM,GAAG,IAAI;IAW1C;;;;;OAKG;IACH,eAAe,IAAI,YAAY;IAc/B,UAAU,CAAC,MAAM,CAAC,EAAE,aAAa,GAAG,MAAM;IAI1C,OAAO,IAAI,GAAG;CAGf"}
1
+ {"version":3,"file":"secp256k1ExtendedKeyPair.d.ts","sourceRoot":"","sources":["../../../../src/account-lib/baseCoin/secp256k1ExtendedKeyPair.ts"],"names":[],"mappings":"AAAA,OAAO,EAAS,cAAc,EAAU,eAAe,EAAE,MAAM,uBAAuB,CAAC;AAEvF,OAAO,EAAE,cAAc,EAAE,YAAY,EAAE,MAAM,SAAS,CAAC;AACvD,OAAO,EAAE,WAAW,EAAE,MAAM,eAAe,CAAC;AAC5C,OAAO,EAAE,aAAa,EAAE,MAAM,QAAQ,CAAC;AAGvC;;GAEG;AACH,8BAAsB,wBAAyB,YAAW,WAAW;IACnE,MAAM,CAAC,SAAS,CAAC,MAAM,EAAE,cAAc,GAAG,eAAe;IAUzD,SAAS,CAAC,MAAM,CAAC,EAAE,cAAc,CAAC;IAClC,SAAS,CAAC,OAAO,EAAE,eAAe,CAAC;IACnC,SAAS,CAAC,MAAM,CAAC,EAAE,cAAc,CAAC;IAClC;;;;;OAKG;IACH,SAAS,aAAa,MAAM,CAAC,EAAE,cAAc;IAI7C;;;OAGG;IACH,YAAY,CAAC,EAAE,UAAU,EAAE,EAAE;QAAE,UAAU,EAAE,OAAO,CAAA;KAAE,GAAG,MAAM;IAI7D;;OAEG;IACH,aAAa,IAAI,MAAM,GAAG,SAAS;IAInC;;;;OAIG;IACH,wBAAwB,CAAC,GAAG,EAAE,MAAM,GAAG,IAAI;IAW3C;;;;OAIG;IACH,uBAAuB,CAAC,GAAG,EAAE,MAAM,GAAG,IAAI;IAW1C;;;;;OAKG;IACH,eAAe,IAAI,YAAY;IAc/B,UAAU,CAAC,MAAM,CAAC,EAAE,aAAa,GAAG,MAAM;IAI1C,OAAO,IAAI,GAAG;CAGf"}
@@ -34,7 +34,7 @@ var __importStar = (this && this.__importStar) || (function () {
34
34
  })();
35
35
  Object.defineProperty(exports, "__esModule", { value: true });
36
36
  exports.Secp256k1ExtendedKeyPair = void 0;
37
- const utxo_lib_1 = require("@bitgo-beta/utxo-lib");
37
+ const secp256k1_1 = require("@bitgo-beta/secp256k1");
38
38
  const Crypto = __importStar(require("../util/crypto"));
39
39
  const errors_1 = require("./errors");
40
40
  /**
@@ -43,10 +43,10 @@ const errors_1 = require("./errors");
43
43
  class Secp256k1ExtendedKeyPair {
44
44
  static toKeyPair(hdNode) {
45
45
  if (hdNode.privateKey) {
46
- return utxo_lib_1.ECPair.fromPrivateKey(hdNode.privateKey);
46
+ return secp256k1_1.ECPair.fromPrivateKey(hdNode.privateKey);
47
47
  }
48
48
  else {
49
- return utxo_lib_1.ECPair.fromPublicKey(hdNode.publicKey);
49
+ return secp256k1_1.ECPair.fromPublicKey(hdNode.publicKey);
50
50
  }
51
51
  }
52
52
  /**
@@ -63,7 +63,7 @@ class Secp256k1ExtendedKeyPair {
63
63
  * @return Buffer 33 bytes if `compressed` is set, 65 bytes otherwise. Standard libsecp256k1 format.
64
64
  */
65
65
  getPublicKey({ compressed }) {
66
- return utxo_lib_1.ECPair.fromPublicKey(this.keyPair?.publicKey, { compressed }).publicKey;
66
+ return secp256k1_1.ECPair.fromPublicKey(this.keyPair?.publicKey, { compressed }).publicKey;
67
67
  }
68
68
  /**
69
69
  * @return Buffer 32 bytes in standard libsecp256k1 format
@@ -78,11 +78,11 @@ class Secp256k1ExtendedKeyPair {
78
78
  */
79
79
  recordKeysFromPrivateKey(prv) {
80
80
  if (Crypto.isValidXprv(prv)) {
81
- this.hdNode = utxo_lib_1.bip32.fromBase58(prv);
81
+ this.hdNode = secp256k1_1.bip32.fromBase58(prv);
82
82
  }
83
83
  else if (Crypto.isValidPrv(prv)) {
84
84
  // Cannot create the HD node without the chain code, so create a regular Key Chain
85
- this.keyPair = utxo_lib_1.ECPair.fromPrivateKey(Buffer.from(prv, 'hex'));
85
+ this.keyPair = secp256k1_1.ECPair.fromPrivateKey(Buffer.from(prv, 'hex'));
86
86
  }
87
87
  else {
88
88
  throw new Error('Unsupported private key');
@@ -95,11 +95,11 @@ class Secp256k1ExtendedKeyPair {
95
95
  */
96
96
  recordKeysFromPublicKey(pub) {
97
97
  if (Crypto.isValidXpub(pub)) {
98
- this.hdNode = utxo_lib_1.bip32.fromBase58(pub);
98
+ this.hdNode = secp256k1_1.bip32.fromBase58(pub);
99
99
  }
100
100
  else if (Crypto.isValidPub(pub)) {
101
101
  // Cannot create an HD node without the chain code, so create a regular Key Chain
102
- this.keyPair = utxo_lib_1.ECPair.fromPublicKey(Buffer.from(pub, 'hex'));
102
+ this.keyPair = secp256k1_1.ECPair.fromPublicKey(Buffer.from(pub, 'hex'));
103
103
  }
104
104
  else {
105
105
  throw new Error('Unsupported public key: ' + pub);
@@ -132,4 +132,4 @@ class Secp256k1ExtendedKeyPair {
132
132
  }
133
133
  }
134
134
  exports.Secp256k1ExtendedKeyPair = Secp256k1ExtendedKeyPair;
135
- //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoic2VjcDI1NmsxRXh0ZW5kZWRLZXlQYWlyLmpzIiwic291cmNlUm9vdCI6IiIsInNvdXJjZXMiOlsiLi4vLi4vLi4vLi4vc3JjL2FjY291bnQtbGliL2Jhc2VDb2luL3NlY3AyNTZrMUV4dGVuZGVkS2V5UGFpci50cyJdLCJuYW1lcyI6W10sIm1hcHBpbmdzIjoiOzs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7QUFBQSxtREFBc0Y7QUFDdEYsdURBQXlDO0FBSXpDLHFDQUErQztBQUUvQzs7R0FFRztBQUNILE1BQXNCLHdCQUF3QjtJQUM1QyxNQUFNLENBQUMsU0FBUyxDQUFDLE1BQXNCO1FBQ3JDLElBQUksTUFBTSxDQUFDLFVBQVUsRUFBRSxDQUFDO1lBQ3RCLE9BQU8saUJBQU0sQ0FBQyxjQUFjLENBQUMsTUFBTSxDQUFDLFVBQVUsQ0FBQyxDQUFDO1FBQ2xELENBQUM7YUFBTSxDQUFDO1lBQ04sT0FBTyxpQkFBTSxDQUFDLGFBQWEsQ0FBQyxNQUFNLENBQUMsU0FBUyxDQUFDLENBQUM7UUFDaEQsQ0FBQztJQUNILENBQUM7SUFPRDs7Ozs7T0FLRztJQUNILFlBQXNCLE1BQXVCO1FBQzNDLElBQUksQ0FBQyxNQUFNLEdBQUcsTUFBTSxDQUFDO0lBQ3ZCLENBQUM7SUFFRDs7O09BR0c7SUFDSCxZQUFZLENBQUMsRUFBRSxVQUFVLEVBQTJCO1FBQ2xELE9BQU8saUJBQU0sQ0FBQyxhQUFhLENBQUMsSUFBSSxDQUFDLE9BQU8sRUFBRSxTQUFTLEVBQUUsRUFBRSxVQUFVLEVBQUUsQ0FBQyxDQUFDLFNBQVMsQ0FBQztJQUNqRixDQUFDO0lBRUQ7O09BRUc7SUFDSCxhQUFhO1FBQ1gsT0FBTyxJQUFJLENBQUMsT0FBTyxFQUFFLFVBQVUsQ0FBQztJQUNsQyxDQUFDO0lBRUQ7Ozs7T0FJRztJQUNILHdCQUF3QixDQUFDLEdBQVc7UUFDbEMsSUFBSSxNQUFNLENBQUMsV0FBVyxDQUFDLEdBQUcsQ0FBQyxFQUFFLENBQUM7WUFDNUIsSUFBSSxDQUFDLE1BQU0sR0FBRyxnQkFBSyxDQUFDLFVBQVUsQ0FBQyxHQUFHLENBQUMsQ0FBQztRQUN0QyxDQUFDO2FBQU0sSUFBSSxNQUFNLENBQUMsVUFBVSxDQUFDLEdBQUcsQ0FBQyxFQUFFLENBQUM7WUFDbEMsa0ZBQWtGO1lBQ2xGLElBQUksQ0FBQyxPQUFPLEdBQUcsaUJBQU0sQ0FBQyxjQUFjLENBQUMsTUFBTSxDQUFDLElBQUksQ0FBQyxHQUFHLEVBQUUsS0FBSyxDQUFDLENBQUMsQ0FBQztRQUNoRSxDQUFDO2FBQU0sQ0FBQztZQUNOLE1BQU0sSUFBSSxLQUFLLENBQUMseUJBQXlCLENBQUMsQ0FBQztRQUM3QyxDQUFDO0lBQ0gsQ0FBQztJQUVEOzs7O09BSUc7SUFDSCx1QkFBdUIsQ0FBQyxHQUFXO1FBQ2pDLElBQUksTUFBTSxDQUFDLFdBQVcsQ0FBQyxHQUFHLENBQUMsRUFBRSxDQUFDO1lBQzVCLElBQUksQ0FBQyxNQUFNLEdBQUcsZ0JBQUssQ0FBQyxVQUFVLENBQUMsR0FBRyxDQUFDLENBQUM7UUFDdEMsQ0FBQzthQUFNLElBQUksTUFBTSxDQUFDLFVBQVUsQ0FBQyxHQUFHLENBQUMsRUFBRSxDQUFDO1lBQ2xDLGlGQUFpRjtZQUNqRixJQUFJLENBQUMsT0FBTyxHQUFHLGlCQUFNLENBQUMsYUFBYSxDQUFDLE1BQU0sQ0FBQyxJQUFJLENBQUMsR0FBRyxFQUFFLEtBQUssQ0FBQyxDQUFDLENBQUM7UUFDL0QsQ0FBQzthQUFNLENBQUM7WUFDTixNQUFNLElBQUksS0FBSyxDQUFDLDBCQUEwQixHQUFHLEdBQUcsQ0FBQyxDQUFDO1FBQ3BELENBQUM7SUFDSCxDQUFDO0lBRUQ7Ozs7O09BS0c7SUFDSCxlQUFlO1FBQ2IsSUFBSSxDQUFDLElBQUksQ0FBQyxNQUFNLEVBQUUsQ0FBQztZQUNqQixNQUFNLElBQUksS0FBSyxDQUFDLDBCQUEwQixDQUFDLENBQUM7UUFDOUMsQ0FBQztRQUNELE1BQU0sTUFBTSxHQUFpQjtZQUMzQixJQUFJLEVBQUUsSUFBSSxDQUFDLE1BQU0sQ0FBQyxRQUFRLEVBQUUsQ0FBQyxRQUFRLEVBQUU7U0FDeEMsQ0FBQztRQUNGLHVFQUF1RTtRQUN2RSxJQUFJLENBQUMsSUFBSSxDQUFDLE1BQU0sQ0FBQyxVQUFVLEVBQUUsRUFBRSxDQUFDO1lBQzlCLE1BQU0sQ0FBQyxJQUFJLEdBQUcsSUFBSSxDQUFDLE1BQU0sQ0FBQyxRQUFRLEVBQUUsQ0FBQztRQUN2QyxDQUFDO1FBQ0QsT0FBTyxNQUFNLENBQUM7SUFDaEIsQ0FBQztJQUVELFVBQVUsQ0FBQyxNQUFzQjtRQUMvQixNQUFNLElBQUksNEJBQW1CLENBQUMsNEJBQTRCLENBQUMsQ0FBQztJQUM5RCxDQUFDO0lBRUQsT0FBTztRQUNMLE1BQU0sSUFBSSw0QkFBbUIsQ0FBQyx5QkFBeUIsQ0FBQyxDQUFDO0lBQzNELENBQUM7Q0FDRjtBQWxHRCw0REFrR0MiLCJzb3VyY2VzQ29udGVudCI6WyJpbXBvcnQgeyBiaXAzMiwgQklQMzJJbnRlcmZhY2UsIEVDUGFpciwgRUNQYWlySW50ZXJmYWNlIH0gZnJvbSAnQGJpdGdvLWJldGEvdXR4by1saWInO1xuaW1wb3J0ICogYXMgQ3J5cHRvIGZyb20gJy4uL3V0aWwvY3J5cHRvJztcbmltcG9ydCB7IEtleVBhaXJPcHRpb25zLCBFeHRlbmRlZEtleXMgfSBmcm9tICcuL2lmYWNlJztcbmltcG9ydCB7IEJhc2VLZXlQYWlyIH0gZnJvbSAnLi9iYXNlS2V5UGFpcic7XG5pbXBvcnQgeyBBZGRyZXNzRm9ybWF0IH0gZnJvbSAnLi9lbnVtJztcbmltcG9ydCB7IE5vdEltcGxlbWVudGVkRXJyb3IgfSBmcm9tICcuL2Vycm9ycyc7XG5cbi8qKlxuICogQmFzZSBjbGFzcyBmb3IgU0VDUDI1NksxIGV4dGVuZGVkIGtleXBhaXJzLlxuICovXG5leHBvcnQgYWJzdHJhY3QgY2xhc3MgU2VjcDI1NmsxRXh0ZW5kZWRLZXlQYWlyIGltcGxlbWVudHMgQmFzZUtleVBhaXIge1xuICBzdGF0aWMgdG9LZXlQYWlyKGhkTm9kZTogQklQMzJJbnRlcmZhY2UpOiBFQ1BhaXJJbnRlcmZhY2Uge1xuICAgIGlmIChoZE5vZGUucHJpdmF0ZUtleSkge1xuICAgICAgcmV0dXJuIEVDUGFpci5mcm9tUHJpdmF0ZUtleShoZE5vZGUucHJpdmF0ZUtleSk7XG4gICAgfSBlbHNlIHtcbiAgICAgIHJldHVybiBFQ1BhaXIuZnJvbVB1YmxpY0tleShoZE5vZGUucHVibGljS2V5KTtcbiAgICB9XG4gIH1cblxuICAvLyBJbXBsZW1lbnRhdGlvbiBvZiB0aGUgSEQgcHJvdG9jb2wgKEJJUDMyKS4gT25seSBhdmFpbGFibGUgd2hlbiBjcmVhdGluZyBhIEtleVBhaXIgZnJvbSBhIHNlZWQsXG4gIC8vIG9yIGV4dGVuZGVkIGtleXNcbiAgcHJvdGVjdGVkIGhkTm9kZT86IEJJUDMySW50ZXJmYWNlO1xuICBwcm90ZWN0ZWQga2V5UGFpcjogRUNQYWlySW50ZXJmYWNlO1xuICBwcm90ZWN0ZWQgc291cmNlPzogS2V5UGFpck9wdGlvbnM7XG4gIC8qKlxuICAgKiBQdWJsaWMgY29uc3RydWN0b3IuIEJ5IGRlZmF1bHQsIGNyZWF0ZXMgYSBrZXkgcGFpciB3aXRoIGEgcmFuZG9tIG1hc3RlciBzZWVkLlxuICAgKlxuICAgKiBAcGFyYW0ge0tleVBhaXJPcHRpb25zfSBzb3VyY2UgRWl0aGVyIGEgbWFzdGVyIHNlZWQsIGEgcHJpdmF0ZSBrZXkgKGV4dGVuZGVkIG9yIHJhdyksIG9yIGEgcHVibGljIGtleVxuICAgKiAgICAgKGV4dGVuZGVkLCBjb21wcmVzc2VkLCBvciB1bmNvbXByZXNzZWQpXG4gICAqL1xuICBwcm90ZWN0ZWQgY29uc3RydWN0b3Ioc291cmNlPzogS2V5UGFpck9wdGlvbnMpIHtcbiAgICB0aGlzLnNvdXJjZSA9IHNvdXJjZTtcbiAgfVxuXG4gIC8qKlxuICAgKiBAcGFyYW0gY29tcHJlc3NlZFxuICAgKiBAcmV0dXJuIEJ1ZmZlciAzMyBieXRlcyBpZiBgY29tcHJlc3NlZGAgaXMgc2V0LCA2NSBieXRlcyBvdGhlcndpc2UuIFN0YW5kYXJkIGxpYnNlY3AyNTZrMSBmb3JtYXQuXG4gICAqL1xuICBnZXRQdWJsaWNLZXkoeyBjb21wcmVzc2VkIH06IHsgY29tcHJlc3NlZDogYm9vbGVhbiB9KTogQnVmZmVyIHtcbiAgICByZXR1cm4gRUNQYWlyLmZyb21QdWJsaWNLZXkodGhpcy5rZXlQYWlyPy5wdWJsaWNLZXksIHsgY29tcHJlc3NlZCB9KS5wdWJsaWNLZXk7XG4gIH1cblxuICAvKipcbiAgICogQHJldHVybiBCdWZmZXIgMzIgYnl0ZXMgaW4gc3RhbmRhcmQgbGlic2VjcDI1NmsxIGZvcm1hdFxuICAgKi9cbiAgZ2V0UHJpdmF0ZUtleSgpOiBCdWZmZXIgfCB1bmRlZmluZWQge1xuICAgIHJldHVybiB0aGlzLmtleVBhaXI/LnByaXZhdGVLZXk7XG4gIH1cblxuICAvKipcbiAgICogQnVpbGQgYSBIaWVyYXJjaGljYWwgRGV0ZXJtaW5pc3RpYyBub2RlIG9yIGFuIEVDUGFpciBmcm9tIGEgcHJpdmF0ZSBrZXkuXG4gICAqXG4gICAqIEBwYXJhbSB7c3RyaW5nfSBwcnYgQW4gZXh0ZW5kZWQgb3IgcmF3IHByaXZhdGUga2V5XG4gICAqL1xuICByZWNvcmRLZXlzRnJvbVByaXZhdGVLZXkocHJ2OiBzdHJpbmcpOiB2b2lkIHtcbiAgICBpZiAoQ3J5cHRvLmlzVmFsaWRYcHJ2KHBydikpIHtcbiAgICAgIHRoaXMuaGROb2RlID0gYmlwMzIuZnJvbUJhc2U1OChwcnYpO1xuICAgIH0gZWxzZSBpZiAoQ3J5cHRvLmlzVmFsaWRQcnYocHJ2KSkge1xuICAgICAgLy8gQ2Fubm90IGNyZWF0ZSB0aGUgSEQgbm9kZSB3aXRob3V0IHRoZSBjaGFpbiBjb2RlLCBzbyBjcmVhdGUgYSByZWd1bGFyIEtleSBDaGFpblxuICAgICAgdGhpcy5rZXlQYWlyID0gRUNQYWlyLmZyb21Qcml2YXRlS2V5KEJ1ZmZlci5mcm9tKHBydiwgJ2hleCcpKTtcbiAgICB9IGVsc2Uge1xuICAgICAgdGhyb3cgbmV3IEVycm9yKCdVbnN1cHBvcnRlZCBwcml2YXRlIGtleScpO1xuICAgIH1cbiAgfVxuXG4gIC8qKlxuICAgKiBCdWlsZCBhIEhpZXJhcmNoaWNhbCBEZXRlcm1pbmlzdGljIG5vZGUgb3IgYW4gRUNQYWlyIGZyb20gYSBwdWJsaWMga2V5LlxuICAgKlxuICAgKiBAcGFyYW0ge3N0cmluZ30gcHViIC0gQW4gZXh0ZW5kZWQsIGNvbXByZXNzZWQsIG9yIHVuY29tcHJlc3NlZCBwdWJsaWMga2V5XG4gICAqL1xuICByZWNvcmRLZXlzRnJvbVB1YmxpY0tleShwdWI6IHN0cmluZyk6IHZvaWQge1xuICAgIGlmIChDcnlwdG8uaXNWYWxpZFhwdWIocHViKSkge1xuICAgICAgdGhpcy5oZE5vZGUgPSBiaXAzMi5mcm9tQmFzZTU4KHB1Yik7XG4gICAgfSBlbHNlIGlmIChDcnlwdG8uaXNWYWxpZFB1YihwdWIpKSB7XG4gICAgICAvLyBDYW5ub3QgY3JlYXRlIGFuIEhEIG5vZGUgd2l0aG91dCB0aGUgY2hhaW4gY29kZSwgc28gY3JlYXRlIGEgcmVndWxhciBLZXkgQ2hhaW5cbiAgICAgIHRoaXMua2V5UGFpciA9IEVDUGFpci5mcm9tUHVibGljS2V5KEJ1ZmZlci5mcm9tKHB1YiwgJ2hleCcpKTtcbiAgICB9IGVsc2Uge1xuICAgICAgdGhyb3cgbmV3IEVycm9yKCdVbnN1cHBvcnRlZCBwdWJsaWMga2V5OiAnICsgcHViKTtcbiAgICB9XG4gIH1cblxuICAvKipcbiAgICogR2V0IHRoZSBleHRlbmRlZCBwdWJsaWMga2V5LCBhbmQgdGhlIHByaXZhdGUga2V5IGlmIG9uZSBpcyBhdmFpbGFibGUuIFRoaXMgaXMgb25seSBwb3NzaWJsZVxuICAgKiB3aGVuIHRoZSBrZXkgcGFpciB3YXMgY3JlYXRlZCBmcm9tIGEgc2VlZCBvciBleHRlbmRlZCBrZXlzLlxuICAgKlxuICAgKiBAcmV0dXJucyB7RXh0ZW5kZWRLZXlzfSBUaGUgRXh0ZW5kZWQga2V5cyBvYmplY3RcbiAgICovXG4gIGdldEV4dGVuZGVkS2V5cygpOiBFeHRlbmRlZEtleXMge1xuICAgIGlmICghdGhpcy5oZE5vZGUpIHtcbiAgICAgIHRocm93IG5ldyBFcnJvcignQ2Fubm90IGdldCBleHRlbmRlZCBrZXlzJyk7XG4gICAgfVxuICAgIGNvbnN0IHJlc3VsdDogRXh0ZW5kZWRLZXlzID0ge1xuICAgICAgeHB1YjogdGhpcy5oZE5vZGUubmV1dGVyZWQoKS50b0Jhc2U1OCgpLFxuICAgIH07XG4gICAgLy8gQSBuZXV0ZXJlZCBIRCBub2RlIG1lYW5zIGl0IG9ubHkgY29udGFpbnMgdGhlIHB1YmxpYyBrZXkgaW5mb3JtYXRpb25cbiAgICBpZiAoIXRoaXMuaGROb2RlLmlzTmV1dGVyZWQoKSkge1xuICAgICAgcmVzdWx0LnhwcnYgPSB0aGlzLmhkTm9kZS50b0Jhc2U1OCgpO1xuICAgIH1cbiAgICByZXR1cm4gcmVzdWx0O1xuICB9XG5cbiAgZ2V0QWRkcmVzcyhmb3JtYXQ/OiBBZGRyZXNzRm9ybWF0KTogc3RyaW5nIHtcbiAgICB0aHJvdyBuZXcgTm90SW1wbGVtZW50ZWRFcnJvcignZ2V0QWRkcmVzcyBub3QgaW1wbGVtZW50ZWQnKTtcbiAgfVxuXG4gIGdldEtleXMoKTogYW55IHtcbiAgICB0aHJvdyBuZXcgTm90SW1wbGVtZW50ZWRFcnJvcignZ2V0S2V5cyBub3QgaW1wbGVtZW50ZWQnKTtcbiAgfVxufVxuIl19
135
+ //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoic2VjcDI1NmsxRXh0ZW5kZWRLZXlQYWlyLmpzIiwic291cmNlUm9vdCI6IiIsInNvdXJjZXMiOlsiLi4vLi4vLi4vLi4vc3JjL2FjY291bnQtbGliL2Jhc2VDb2luL3NlY3AyNTZrMUV4dGVuZGVkS2V5UGFpci50cyJdLCJuYW1lcyI6W10sIm1hcHBpbmdzIjoiOzs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7QUFBQSxxREFBdUY7QUFDdkYsdURBQXlDO0FBSXpDLHFDQUErQztBQUUvQzs7R0FFRztBQUNILE1BQXNCLHdCQUF3QjtJQUM1QyxNQUFNLENBQUMsU0FBUyxDQUFDLE1BQXNCO1FBQ3JDLElBQUksTUFBTSxDQUFDLFVBQVUsRUFBRSxDQUFDO1lBQ3RCLE9BQU8sa0JBQU0sQ0FBQyxjQUFjLENBQUMsTUFBTSxDQUFDLFVBQVUsQ0FBQyxDQUFDO1FBQ2xELENBQUM7YUFBTSxDQUFDO1lBQ04sT0FBTyxrQkFBTSxDQUFDLGFBQWEsQ0FBQyxNQUFNLENBQUMsU0FBUyxDQUFDLENBQUM7UUFDaEQsQ0FBQztJQUNILENBQUM7SUFPRDs7Ozs7T0FLRztJQUNILFlBQXNCLE1BQXVCO1FBQzNDLElBQUksQ0FBQyxNQUFNLEdBQUcsTUFBTSxDQUFDO0lBQ3ZCLENBQUM7SUFFRDs7O09BR0c7SUFDSCxZQUFZLENBQUMsRUFBRSxVQUFVLEVBQTJCO1FBQ2xELE9BQU8sa0JBQU0sQ0FBQyxhQUFhLENBQUMsSUFBSSxDQUFDLE9BQU8sRUFBRSxTQUFTLEVBQUUsRUFBRSxVQUFVLEVBQUUsQ0FBQyxDQUFDLFNBQVMsQ0FBQztJQUNqRixDQUFDO0lBRUQ7O09BRUc7SUFDSCxhQUFhO1FBQ1gsT0FBTyxJQUFJLENBQUMsT0FBTyxFQUFFLFVBQVUsQ0FBQztJQUNsQyxDQUFDO0lBRUQ7Ozs7T0FJRztJQUNILHdCQUF3QixDQUFDLEdBQVc7UUFDbEMsSUFBSSxNQUFNLENBQUMsV0FBVyxDQUFDLEdBQUcsQ0FBQyxFQUFFLENBQUM7WUFDNUIsSUFBSSxDQUFDLE1BQU0sR0FBRyxpQkFBSyxDQUFDLFVBQVUsQ0FBQyxHQUFHLENBQUMsQ0FBQztRQUN0QyxDQUFDO2FBQU0sSUFBSSxNQUFNLENBQUMsVUFBVSxDQUFDLEdBQUcsQ0FBQyxFQUFFLENBQUM7WUFDbEMsa0ZBQWtGO1lBQ2xGLElBQUksQ0FBQyxPQUFPLEdBQUcsa0JBQU0sQ0FBQyxjQUFjLENBQUMsTUFBTSxDQUFDLElBQUksQ0FBQyxHQUFHLEVBQUUsS0FBSyxDQUFDLENBQUMsQ0FBQztRQUNoRSxDQUFDO2FBQU0sQ0FBQztZQUNOLE1BQU0sSUFBSSxLQUFLLENBQUMseUJBQXlCLENBQUMsQ0FBQztRQUM3QyxDQUFDO0lBQ0gsQ0FBQztJQUVEOzs7O09BSUc7SUFDSCx1QkFBdUIsQ0FBQyxHQUFXO1FBQ2pDLElBQUksTUFBTSxDQUFDLFdBQVcsQ0FBQyxHQUFHLENBQUMsRUFBRSxDQUFDO1lBQzVCLElBQUksQ0FBQyxNQUFNLEdBQUcsaUJBQUssQ0FBQyxVQUFVLENBQUMsR0FBRyxDQUFDLENBQUM7UUFDdEMsQ0FBQzthQUFNLElBQUksTUFBTSxDQUFDLFVBQVUsQ0FBQyxHQUFHLENBQUMsRUFBRSxDQUFDO1lBQ2xDLGlGQUFpRjtZQUNqRixJQUFJLENBQUMsT0FBTyxHQUFHLGtCQUFNLENBQUMsYUFBYSxDQUFDLE1BQU0sQ0FBQyxJQUFJLENBQUMsR0FBRyxFQUFFLEtBQUssQ0FBQyxDQUFDLENBQUM7UUFDL0QsQ0FBQzthQUFNLENBQUM7WUFDTixNQUFNLElBQUksS0FBSyxDQUFDLDBCQUEwQixHQUFHLEdBQUcsQ0FBQyxDQUFDO1FBQ3BELENBQUM7SUFDSCxDQUFDO0lBRUQ7Ozs7O09BS0c7SUFDSCxlQUFlO1FBQ2IsSUFBSSxDQUFDLElBQUksQ0FBQyxNQUFNLEVBQUUsQ0FBQztZQUNqQixNQUFNLElBQUksS0FBSyxDQUFDLDBCQUEwQixDQUFDLENBQUM7UUFDOUMsQ0FBQztRQUNELE1BQU0sTUFBTSxHQUFpQjtZQUMzQixJQUFJLEVBQUUsSUFBSSxDQUFDLE1BQU0sQ0FBQyxRQUFRLEVBQUUsQ0FBQyxRQUFRLEVBQUU7U0FDeEMsQ0FBQztRQUNGLHVFQUF1RTtRQUN2RSxJQUFJLENBQUMsSUFBSSxDQUFDLE1BQU0sQ0FBQyxVQUFVLEVBQUUsRUFBRSxDQUFDO1lBQzlCLE1BQU0sQ0FBQyxJQUFJLEdBQUcsSUFBSSxDQUFDLE1BQU0sQ0FBQyxRQUFRLEVBQUUsQ0FBQztRQUN2QyxDQUFDO1FBQ0QsT0FBTyxNQUFNLENBQUM7SUFDaEIsQ0FBQztJQUVELFVBQVUsQ0FBQyxNQUFzQjtRQUMvQixNQUFNLElBQUksNEJBQW1CLENBQUMsNEJBQTRCLENBQUMsQ0FBQztJQUM5RCxDQUFDO0lBRUQsT0FBTztRQUNMLE1BQU0sSUFBSSw0QkFBbUIsQ0FBQyx5QkFBeUIsQ0FBQyxDQUFDO0lBQzNELENBQUM7Q0FDRjtBQWxHRCw0REFrR0MiLCJzb3VyY2VzQ29udGVudCI6WyJpbXBvcnQgeyBiaXAzMiwgQklQMzJJbnRlcmZhY2UsIEVDUGFpciwgRUNQYWlySW50ZXJmYWNlIH0gZnJvbSAnQGJpdGdvLWJldGEvc2VjcDI1NmsxJztcbmltcG9ydCAqIGFzIENyeXB0byBmcm9tICcuLi91dGlsL2NyeXB0byc7XG5pbXBvcnQgeyBLZXlQYWlyT3B0aW9ucywgRXh0ZW5kZWRLZXlzIH0gZnJvbSAnLi9pZmFjZSc7XG5pbXBvcnQgeyBCYXNlS2V5UGFpciB9IGZyb20gJy4vYmFzZUtleVBhaXInO1xuaW1wb3J0IHsgQWRkcmVzc0Zvcm1hdCB9IGZyb20gJy4vZW51bSc7XG5pbXBvcnQgeyBOb3RJbXBsZW1lbnRlZEVycm9yIH0gZnJvbSAnLi9lcnJvcnMnO1xuXG4vKipcbiAqIEJhc2UgY2xhc3MgZm9yIFNFQ1AyNTZLMSBleHRlbmRlZCBrZXlwYWlycy5cbiAqL1xuZXhwb3J0IGFic3RyYWN0IGNsYXNzIFNlY3AyNTZrMUV4dGVuZGVkS2V5UGFpciBpbXBsZW1lbnRzIEJhc2VLZXlQYWlyIHtcbiAgc3RhdGljIHRvS2V5UGFpcihoZE5vZGU6IEJJUDMySW50ZXJmYWNlKTogRUNQYWlySW50ZXJmYWNlIHtcbiAgICBpZiAoaGROb2RlLnByaXZhdGVLZXkpIHtcbiAgICAgIHJldHVybiBFQ1BhaXIuZnJvbVByaXZhdGVLZXkoaGROb2RlLnByaXZhdGVLZXkpO1xuICAgIH0gZWxzZSB7XG4gICAgICByZXR1cm4gRUNQYWlyLmZyb21QdWJsaWNLZXkoaGROb2RlLnB1YmxpY0tleSk7XG4gICAgfVxuICB9XG5cbiAgLy8gSW1wbGVtZW50YXRpb24gb2YgdGhlIEhEIHByb3RvY29sIChCSVAzMikuIE9ubHkgYXZhaWxhYmxlIHdoZW4gY3JlYXRpbmcgYSBLZXlQYWlyIGZyb20gYSBzZWVkLFxuICAvLyBvciBleHRlbmRlZCBrZXlzXG4gIHByb3RlY3RlZCBoZE5vZGU/OiBCSVAzMkludGVyZmFjZTtcbiAgcHJvdGVjdGVkIGtleVBhaXI6IEVDUGFpckludGVyZmFjZTtcbiAgcHJvdGVjdGVkIHNvdXJjZT86IEtleVBhaXJPcHRpb25zO1xuICAvKipcbiAgICogUHVibGljIGNvbnN0cnVjdG9yLiBCeSBkZWZhdWx0LCBjcmVhdGVzIGEga2V5IHBhaXIgd2l0aCBhIHJhbmRvbSBtYXN0ZXIgc2VlZC5cbiAgICpcbiAgICogQHBhcmFtIHtLZXlQYWlyT3B0aW9uc30gc291cmNlIEVpdGhlciBhIG1hc3RlciBzZWVkLCBhIHByaXZhdGUga2V5IChleHRlbmRlZCBvciByYXcpLCBvciBhIHB1YmxpYyBrZXlcbiAgICogICAgIChleHRlbmRlZCwgY29tcHJlc3NlZCwgb3IgdW5jb21wcmVzc2VkKVxuICAgKi9cbiAgcHJvdGVjdGVkIGNvbnN0cnVjdG9yKHNvdXJjZT86IEtleVBhaXJPcHRpb25zKSB7XG4gICAgdGhpcy5zb3VyY2UgPSBzb3VyY2U7XG4gIH1cblxuICAvKipcbiAgICogQHBhcmFtIGNvbXByZXNzZWRcbiAgICogQHJldHVybiBCdWZmZXIgMzMgYnl0ZXMgaWYgYGNvbXByZXNzZWRgIGlzIHNldCwgNjUgYnl0ZXMgb3RoZXJ3aXNlLiBTdGFuZGFyZCBsaWJzZWNwMjU2azEgZm9ybWF0LlxuICAgKi9cbiAgZ2V0UHVibGljS2V5KHsgY29tcHJlc3NlZCB9OiB7IGNvbXByZXNzZWQ6IGJvb2xlYW4gfSk6IEJ1ZmZlciB7XG4gICAgcmV0dXJuIEVDUGFpci5mcm9tUHVibGljS2V5KHRoaXMua2V5UGFpcj8ucHVibGljS2V5LCB7IGNvbXByZXNzZWQgfSkucHVibGljS2V5O1xuICB9XG5cbiAgLyoqXG4gICAqIEByZXR1cm4gQnVmZmVyIDMyIGJ5dGVzIGluIHN0YW5kYXJkIGxpYnNlY3AyNTZrMSBmb3JtYXRcbiAgICovXG4gIGdldFByaXZhdGVLZXkoKTogQnVmZmVyIHwgdW5kZWZpbmVkIHtcbiAgICByZXR1cm4gdGhpcy5rZXlQYWlyPy5wcml2YXRlS2V5O1xuICB9XG5cbiAgLyoqXG4gICAqIEJ1aWxkIGEgSGllcmFyY2hpY2FsIERldGVybWluaXN0aWMgbm9kZSBvciBhbiBFQ1BhaXIgZnJvbSBhIHByaXZhdGUga2V5LlxuICAgKlxuICAgKiBAcGFyYW0ge3N0cmluZ30gcHJ2IEFuIGV4dGVuZGVkIG9yIHJhdyBwcml2YXRlIGtleVxuICAgKi9cbiAgcmVjb3JkS2V5c0Zyb21Qcml2YXRlS2V5KHBydjogc3RyaW5nKTogdm9pZCB7XG4gICAgaWYgKENyeXB0by5pc1ZhbGlkWHBydihwcnYpKSB7XG4gICAgICB0aGlzLmhkTm9kZSA9IGJpcDMyLmZyb21CYXNlNTgocHJ2KTtcbiAgICB9IGVsc2UgaWYgKENyeXB0by5pc1ZhbGlkUHJ2KHBydikpIHtcbiAgICAgIC8vIENhbm5vdCBjcmVhdGUgdGhlIEhEIG5vZGUgd2l0aG91dCB0aGUgY2hhaW4gY29kZSwgc28gY3JlYXRlIGEgcmVndWxhciBLZXkgQ2hhaW5cbiAgICAgIHRoaXMua2V5UGFpciA9IEVDUGFpci5mcm9tUHJpdmF0ZUtleShCdWZmZXIuZnJvbShwcnYsICdoZXgnKSk7XG4gICAgfSBlbHNlIHtcbiAgICAgIHRocm93IG5ldyBFcnJvcignVW5zdXBwb3J0ZWQgcHJpdmF0ZSBrZXknKTtcbiAgICB9XG4gIH1cblxuICAvKipcbiAgICogQnVpbGQgYSBIaWVyYXJjaGljYWwgRGV0ZXJtaW5pc3RpYyBub2RlIG9yIGFuIEVDUGFpciBmcm9tIGEgcHVibGljIGtleS5cbiAgICpcbiAgICogQHBhcmFtIHtzdHJpbmd9IHB1YiAtIEFuIGV4dGVuZGVkLCBjb21wcmVzc2VkLCBvciB1bmNvbXByZXNzZWQgcHVibGljIGtleVxuICAgKi9cbiAgcmVjb3JkS2V5c0Zyb21QdWJsaWNLZXkocHViOiBzdHJpbmcpOiB2b2lkIHtcbiAgICBpZiAoQ3J5cHRvLmlzVmFsaWRYcHViKHB1YikpIHtcbiAgICAgIHRoaXMuaGROb2RlID0gYmlwMzIuZnJvbUJhc2U1OChwdWIpO1xuICAgIH0gZWxzZSBpZiAoQ3J5cHRvLmlzVmFsaWRQdWIocHViKSkge1xuICAgICAgLy8gQ2Fubm90IGNyZWF0ZSBhbiBIRCBub2RlIHdpdGhvdXQgdGhlIGNoYWluIGNvZGUsIHNvIGNyZWF0ZSBhIHJlZ3VsYXIgS2V5IENoYWluXG4gICAgICB0aGlzLmtleVBhaXIgPSBFQ1BhaXIuZnJvbVB1YmxpY0tleShCdWZmZXIuZnJvbShwdWIsICdoZXgnKSk7XG4gICAgfSBlbHNlIHtcbiAgICAgIHRocm93IG5ldyBFcnJvcignVW5zdXBwb3J0ZWQgcHVibGljIGtleTogJyArIHB1Yik7XG4gICAgfVxuICB9XG5cbiAgLyoqXG4gICAqIEdldCB0aGUgZXh0ZW5kZWQgcHVibGljIGtleSwgYW5kIHRoZSBwcml2YXRlIGtleSBpZiBvbmUgaXMgYXZhaWxhYmxlLiBUaGlzIGlzIG9ubHkgcG9zc2libGVcbiAgICogd2hlbiB0aGUga2V5IHBhaXIgd2FzIGNyZWF0ZWQgZnJvbSBhIHNlZWQgb3IgZXh0ZW5kZWQga2V5cy5cbiAgICpcbiAgICogQHJldHVybnMge0V4dGVuZGVkS2V5c30gVGhlIEV4dGVuZGVkIGtleXMgb2JqZWN0XG4gICAqL1xuICBnZXRFeHRlbmRlZEtleXMoKTogRXh0ZW5kZWRLZXlzIHtcbiAgICBpZiAoIXRoaXMuaGROb2RlKSB7XG4gICAgICB0aHJvdyBuZXcgRXJyb3IoJ0Nhbm5vdCBnZXQgZXh0ZW5kZWQga2V5cycpO1xuICAgIH1cbiAgICBjb25zdCByZXN1bHQ6IEV4dGVuZGVkS2V5cyA9IHtcbiAgICAgIHhwdWI6IHRoaXMuaGROb2RlLm5ldXRlcmVkKCkudG9CYXNlNTgoKSxcbiAgICB9O1xuICAgIC8vIEEgbmV1dGVyZWQgSEQgbm9kZSBtZWFucyBpdCBvbmx5IGNvbnRhaW5zIHRoZSBwdWJsaWMga2V5IGluZm9ybWF0aW9uXG4gICAgaWYgKCF0aGlzLmhkTm9kZS5pc05ldXRlcmVkKCkpIHtcbiAgICAgIHJlc3VsdC54cHJ2ID0gdGhpcy5oZE5vZGUudG9CYXNlNTgoKTtcbiAgICB9XG4gICAgcmV0dXJuIHJlc3VsdDtcbiAgfVxuXG4gIGdldEFkZHJlc3MoZm9ybWF0PzogQWRkcmVzc0Zvcm1hdCk6IHN0cmluZyB7XG4gICAgdGhyb3cgbmV3IE5vdEltcGxlbWVudGVkRXJyb3IoJ2dldEFkZHJlc3Mgbm90IGltcGxlbWVudGVkJyk7XG4gIH1cblxuICBnZXRLZXlzKCk6IGFueSB7XG4gICAgdGhyb3cgbmV3IE5vdEltcGxlbWVudGVkRXJyb3IoJ2dldEtleXMgbm90IGltcGxlbWVudGVkJyk7XG4gIH1cbn1cbiJdfQ==
@@ -21,6 +21,7 @@ export * from './recovery';
21
21
  export * from './staking';
22
22
  export * from './trading';
23
23
  export * from './tss';
24
+ export { sendSignatureShare } from './tss';
24
25
  export * from './types';
25
26
  export * from './utils';
26
27
  export * from './wallet';
@@ -1 +1 @@
1
- {"version":3,"file":"index.d.ts","sourceRoot":"","sources":["../../../src/bitgo/index.ts"],"names":[],"mappings":"AAAA,OAAO,KAAK,WAAW,MAAM,WAAW,CAAC;AACzC,OAAO,KAAK,GAAG,MAAM,OAAO,CAAC;AAE7B,cAAc,YAAY,CAAC;AAC3B,cAAc,aAAa,CAAC;AAC5B,cAAc,WAAW,CAAC;AAC1B,cAAc,aAAa,CAAC;AAC5B,cAAc,UAAU,CAAC;AACzB,cAAc,eAAe,CAAC;AAC9B,cAAc,QAAQ,CAAC;AACvB,cAAc,cAAc,CAAC;AAC7B,cAAc,gBAAgB,CAAC;AAC/B,cAAc,UAAU,CAAC;AACzB,cAAc,sBAAsB,CAAC;AACrC,cAAc,YAAY,CAAC;AAC3B,cAAc,YAAY,CAAC;AAC3B,OAAO,KAAK,OAAO,MAAM,iBAAiB,CAAC;AAC3C,cAAc,uBAAuB,CAAC;AACtC,cAAc,UAAU,CAAC;AACzB,cAAc,mBAAmB,CAAC;AAClC,cAAc,YAAY,CAAC;AAC3B,cAAc,WAAW,CAAC;AAC1B,cAAc,WAAW,CAAC;AAC1B,cAAc,OAAO,CAAC;AACtB,cAAc,SAAS,CAAC;AACxB,cAAc,SAAS,CAAC;AACxB,cAAc,UAAU,CAAC;AACzB,cAAc,WAAW,CAAC;AAC1B,OAAO,EAAE,WAAW,EAAE,CAAC;AACvB,OAAO,EAAE,GAAG,EAAE,CAAC"}
1
+ {"version":3,"file":"index.d.ts","sourceRoot":"","sources":["../../../src/bitgo/index.ts"],"names":[],"mappings":"AAAA,OAAO,KAAK,WAAW,MAAM,WAAW,CAAC;AACzC,OAAO,KAAK,GAAG,MAAM,OAAO,CAAC;AAE7B,cAAc,YAAY,CAAC;AAC3B,cAAc,aAAa,CAAC;AAC5B,cAAc,WAAW,CAAC;AAC1B,cAAc,aAAa,CAAC;AAC5B,cAAc,UAAU,CAAC;AACzB,cAAc,eAAe,CAAC;AAC9B,cAAc,QAAQ,CAAC;AACvB,cAAc,cAAc,CAAC;AAC7B,cAAc,gBAAgB,CAAC;AAC/B,cAAc,UAAU,CAAC;AACzB,cAAc,sBAAsB,CAAC;AACrC,cAAc,YAAY,CAAC;AAC3B,cAAc,YAAY,CAAC;AAC3B,OAAO,KAAK,OAAO,MAAM,iBAAiB,CAAC;AAC3C,cAAc,uBAAuB,CAAC;AACtC,cAAc,UAAU,CAAC;AACzB,cAAc,mBAAmB,CAAC;AAClC,cAAc,YAAY,CAAC;AAC3B,cAAc,WAAW,CAAC;AAC1B,cAAc,WAAW,CAAC;AAC1B,cAAc,OAAO,CAAC;AACtB,OAAO,EAAE,kBAAkB,EAAE,MAAM,OAAO,CAAC;AAC3C,cAAc,SAAS,CAAC;AACxB,cAAc,SAAS,CAAC;AACxB,cAAc,UAAU,CAAC;AACzB,cAAc,WAAW,CAAC;AAC1B,OAAO,EAAE,WAAW,EAAE,CAAC;AACvB,OAAO,EAAE,GAAG,EAAE,CAAC"}
@@ -36,7 +36,7 @@ var __exportStar = (this && this.__exportStar) || function(m, exports) {
36
36
  for (var p in m) if (p !== "default" && !Object.prototype.hasOwnProperty.call(exports, p)) __createBinding(exports, m, p);
37
37
  };
38
38
  Object.defineProperty(exports, "__esModule", { value: true });
39
- exports.tss = exports.bitcoinUtil = exports.bitcoin = void 0;
39
+ exports.tss = exports.bitcoinUtil = exports.sendSignatureShare = exports.bitcoin = void 0;
40
40
  const bitcoinUtil = __importStar(require("./bitcoin"));
41
41
  exports.bitcoinUtil = bitcoinUtil;
42
42
  const tss = __importStar(require("./tss"));
@@ -62,8 +62,10 @@ __exportStar(require("./recovery"), exports);
62
62
  __exportStar(require("./staking"), exports);
63
63
  __exportStar(require("./trading"), exports);
64
64
  __exportStar(require("./tss"), exports);
65
+ var tss_1 = require("./tss");
66
+ Object.defineProperty(exports, "sendSignatureShare", { enumerable: true, get: function () { return tss_1.sendSignatureShare; } });
65
67
  __exportStar(require("./types"), exports);
66
68
  __exportStar(require("./utils"), exports);
67
69
  __exportStar(require("./wallet"), exports);
68
70
  __exportStar(require("./webhook"), exports);
69
- //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiaW5kZXguanMiLCJzb3VyY2VSb290IjoiIiwic291cmNlcyI6WyIuLi8uLi8uLi9zcmMvYml0Z28vaW5kZXgudHMiXSwibmFtZXMiOltdLCJtYXBwaW5ncyI6Ijs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7O0FBQUEsdURBQXlDO0FBNEJoQyxrQ0FBVztBQTNCcEIsMkNBQTZCO0FBNEJwQixrQkFBRztBQTFCWiw2Q0FBMkI7QUFDM0IsOENBQTRCO0FBQzVCLDRDQUEwQjtBQUMxQiw4Q0FBNEI7QUFDNUIsMkNBQXlCO0FBQ3pCLGdEQUE4QjtBQUM5Qix5Q0FBdUI7QUFDdkIsK0NBQTZCO0FBQzdCLGlEQUErQjtBQUMvQiwyQ0FBeUI7QUFDekIsdURBQXFDO0FBQ3JDLDZDQUEyQjtBQUMzQiw2Q0FBMkI7QUFDM0IsMkRBQTJDO0FBQzNDLHdEQUFzQztBQUN0QywyQ0FBeUI7QUFDekIsb0RBQWtDO0FBQ2xDLDZDQUEyQjtBQUMzQiw0Q0FBMEI7QUFDMUIsNENBQTBCO0FBQzFCLHdDQUFzQjtBQUN0QiwwQ0FBd0I7QUFDeEIsMENBQXdCO0FBQ3hCLDJDQUF5QjtBQUN6Qiw0Q0FBMEIiLCJzb3VyY2VzQ29udGVudCI6WyJpbXBvcnQgKiBhcyBiaXRjb2luVXRpbCBmcm9tICcuL2JpdGNvaW4nO1xuaW1wb3J0ICogYXMgdHNzIGZyb20gJy4vdHNzJztcblxuZXhwb3J0ICogZnJvbSAnLi9iYXNlQ29pbic7XG5leHBvcnQgKiBmcm9tICcuL2JpcDMydXRpbCc7XG5leHBvcnQgKiBmcm9tICcuL2JpdGNvaW4nO1xuZXhwb3J0ICogZnJvbSAnLi9iaXRnb0Jhc2UnO1xuZXhwb3J0ICogZnJvbSAnLi9jb25maWcnO1xuZXhwb3J0ICogZnJvbSAnLi9jb2luRmFjdG9yeSc7XG5leHBvcnQgKiBmcm9tICcuL2VjZGgnO1xuZXhwb3J0ICogZnJvbSAnLi9lbnRlcnByaXNlJztcbmV4cG9ydCAqIGZyb20gJy4vZW52aXJvbm1lbnRzJztcbmV4cG9ydCAqIGZyb20gJy4vZXJyb3JzJztcbmV4cG9ydCAqIGZyb20gJy4vaW5zY3JpcHRpb25CdWlsZGVyJztcbmV4cG9ydCAqIGZyb20gJy4vaW50ZXJuYWwnO1xuZXhwb3J0ICogZnJvbSAnLi9rZXljaGFpbic7XG5leHBvcnQgKiBhcyBiaXRjb2luIGZyb20gJy4vbGVnYWN5Qml0Y29pbic7XG5leHBvcnQgKiBmcm9tICcuL2xpZ2h0bmluZy9jdXN0b2RpYWwnO1xuZXhwb3J0ICogZnJvbSAnLi9tYXJrZXQnO1xuZXhwb3J0ICogZnJvbSAnLi9wZW5kaW5nQXBwcm92YWwnO1xuZXhwb3J0ICogZnJvbSAnLi9yZWNvdmVyeSc7XG5leHBvcnQgKiBmcm9tICcuL3N0YWtpbmcnO1xuZXhwb3J0ICogZnJvbSAnLi90cmFkaW5nJztcbmV4cG9ydCAqIGZyb20gJy4vdHNzJztcbmV4cG9ydCAqIGZyb20gJy4vdHlwZXMnO1xuZXhwb3J0ICogZnJvbSAnLi91dGlscyc7XG5leHBvcnQgKiBmcm9tICcuL3dhbGxldCc7XG5leHBvcnQgKiBmcm9tICcuL3dlYmhvb2snO1xuZXhwb3J0IHsgYml0Y29pblV0aWwgfTtcbmV4cG9ydCB7IHRzcyB9O1xuIl19
71
+ //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiaW5kZXguanMiLCJzb3VyY2VSb290IjoiIiwic291cmNlcyI6WyIuLi8uLi8uLi9zcmMvYml0Z28vaW5kZXgudHMiXSwibmFtZXMiOltdLCJtYXBwaW5ncyI6Ijs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7O0FBQUEsdURBQXlDO0FBNkJoQyxrQ0FBVztBQTVCcEIsMkNBQTZCO0FBNkJwQixrQkFBRztBQTNCWiw2Q0FBMkI7QUFDM0IsOENBQTRCO0FBQzVCLDRDQUEwQjtBQUMxQiw4Q0FBNEI7QUFDNUIsMkNBQXlCO0FBQ3pCLGdEQUE4QjtBQUM5Qix5Q0FBdUI7QUFDdkIsK0NBQTZCO0FBQzdCLGlEQUErQjtBQUMvQiwyQ0FBeUI7QUFDekIsdURBQXFDO0FBQ3JDLDZDQUEyQjtBQUMzQiw2Q0FBMkI7QUFDM0IsMkRBQTJDO0FBQzNDLHdEQUFzQztBQUN0QywyQ0FBeUI7QUFDekIsb0RBQWtDO0FBQ2xDLDZDQUEyQjtBQUMzQiw0Q0FBMEI7QUFDMUIsNENBQTBCO0FBQzFCLHdDQUFzQjtBQUN0Qiw2QkFBMkM7QUFBbEMseUdBQUEsa0JBQWtCLE9BQUE7QUFDM0IsMENBQXdCO0FBQ3hCLDBDQUF3QjtBQUN4QiwyQ0FBeUI7QUFDekIsNENBQTBCIiwic291cmNlc0NvbnRlbnQiOlsiaW1wb3J0ICogYXMgYml0Y29pblV0aWwgZnJvbSAnLi9iaXRjb2luJztcbmltcG9ydCAqIGFzIHRzcyBmcm9tICcuL3Rzcyc7XG5cbmV4cG9ydCAqIGZyb20gJy4vYmFzZUNvaW4nO1xuZXhwb3J0ICogZnJvbSAnLi9iaXAzMnV0aWwnO1xuZXhwb3J0ICogZnJvbSAnLi9iaXRjb2luJztcbmV4cG9ydCAqIGZyb20gJy4vYml0Z29CYXNlJztcbmV4cG9ydCAqIGZyb20gJy4vY29uZmlnJztcbmV4cG9ydCAqIGZyb20gJy4vY29pbkZhY3RvcnknO1xuZXhwb3J0ICogZnJvbSAnLi9lY2RoJztcbmV4cG9ydCAqIGZyb20gJy4vZW50ZXJwcmlzZSc7XG5leHBvcnQgKiBmcm9tICcuL2Vudmlyb25tZW50cyc7XG5leHBvcnQgKiBmcm9tICcuL2Vycm9ycyc7XG5leHBvcnQgKiBmcm9tICcuL2luc2NyaXB0aW9uQnVpbGRlcic7XG5leHBvcnQgKiBmcm9tICcuL2ludGVybmFsJztcbmV4cG9ydCAqIGZyb20gJy4va2V5Y2hhaW4nO1xuZXhwb3J0ICogYXMgYml0Y29pbiBmcm9tICcuL2xlZ2FjeUJpdGNvaW4nO1xuZXhwb3J0ICogZnJvbSAnLi9saWdodG5pbmcvY3VzdG9kaWFsJztcbmV4cG9ydCAqIGZyb20gJy4vbWFya2V0JztcbmV4cG9ydCAqIGZyb20gJy4vcGVuZGluZ0FwcHJvdmFsJztcbmV4cG9ydCAqIGZyb20gJy4vcmVjb3ZlcnknO1xuZXhwb3J0ICogZnJvbSAnLi9zdGFraW5nJztcbmV4cG9ydCAqIGZyb20gJy4vdHJhZGluZyc7XG5leHBvcnQgKiBmcm9tICcuL3Rzcyc7XG5leHBvcnQgeyBzZW5kU2lnbmF0dXJlU2hhcmUgfSBmcm9tICcuL3Rzcyc7XG5leHBvcnQgKiBmcm9tICcuL3R5cGVzJztcbmV4cG9ydCAqIGZyb20gJy4vdXRpbHMnO1xuZXhwb3J0ICogZnJvbSAnLi93YWxsZXQnO1xuZXhwb3J0ICogZnJvbSAnLi93ZWJob29rJztcbmV4cG9ydCB7IGJpdGNvaW5VdGlsIH07XG5leHBvcnQgeyB0c3MgfTtcbiJdfQ==
@@ -53,7 +53,7 @@ exports.generateGPGKeyPair = generateGPGKeyPair;
53
53
  const pgp = __importStar(require("openpgp"));
54
54
  const openpgp_1 = require("openpgp");
55
55
  const _ = __importStar(require("lodash"));
56
- const utxo_lib_1 = require("@bitgo-beta/utxo-lib");
56
+ const secp256k1_1 = require("@bitgo-beta/secp256k1");
57
57
  const crypto_1 = __importDefault(require("crypto"));
58
58
  const sodium = require('libsodium-wrappers-sumo');
59
59
  /**
@@ -122,7 +122,7 @@ async function verifyShareProof(senderPubKey, privateShareProof, uValue, algo) {
122
122
  }
123
123
  else if (algo === 'ecdsa') {
124
124
  const decodedUValueProof = Buffer.from(proofSubkeys.keyPacket.publicParams['Q']).toString('hex');
125
- const rawUValueProof = utxo_lib_1.ecc.pointFromScalar(Buffer.from(uValue, 'hex'), false);
125
+ const rawUValueProof = secp256k1_1.ecc.pointFromScalar(Buffer.from(uValue, 'hex'), false);
126
126
  return rawUValueProof !== null && decodedUValueProof === Buffer.from(rawUValueProof).toString('hex');
127
127
  }
128
128
  else {
@@ -240,7 +240,7 @@ async function createShareProof(privateArmor, uValue, algo) {
240
240
  oid = [0x2b, 0x81, 0x04, 0x00, 0x0a];
241
241
  // @ts-ignore - same as above
242
242
  oid.write = () => new Uint8Array(Buffer.from('052b8104000a', 'hex'));
243
- Q = utxo_lib_1.ecc.pointFromScalar(new Uint8Array(Buffer.from(uValue, 'hex')), false);
243
+ Q = secp256k1_1.ecc.pointFromScalar(new Uint8Array(Buffer.from(uValue, 'hex')), false);
244
244
  }
245
245
  secretSubkeyPacket.publicParams = {
246
246
  oid,
@@ -410,4 +410,4 @@ async function generateGPGKeyPair(keyCurve, username, email) {
410
410
  });
411
411
  return gpgKey;
412
412
  }
413
- //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"opengpgUtils.js","sourceRoot":"","sources":["../../../../src/bitgo/utils/opengpgUtils.ts"],"names":[],"mappings":"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","sourcesContent":["/* eslint-disable @typescript-eslint/ban-ts-comment */\n\nimport * as pgp from 'openpgp';\nimport {\n  createMessage,\n  decrypt,\n  encrypt,\n  Key,\n  readKey,\n  readMessage,\n  readPrivateKey,\n  readSignature,\n  sign,\n  verify,\n} from 'openpgp';\nimport * as _ from 'lodash';\nimport { ecc as secp256k1 } from '@bitgo-beta/utxo-lib';\nimport { BitGoBase } from '../bitgoBase';\nimport crypto from 'crypto';\n\nconst sodium = require('libsodium-wrappers-sumo');\n\nexport type KeyValidityDict = {\n  keyID: pgp.KeyID;\n  valid: boolean | null;\n}[];\n\nexport type AuthEncMessage = {\n  encryptedMessage: string;\n  signature: string;\n};\n\n/**\n * Fetches BitGo's public gpg key used in MPC flows\n * @param {BitGoBase} bitgo BitGo object\n * @return {Key} public gpg key\n */\nexport async function getBitgoGpgPubKey(bitgo: BitGoBase): Promise<{ mpcV1: Key; mpcV2: Key | undefined }> {\n  const constants = await bitgo.fetchConstants();\n  if (!constants.mpc || !constants.mpc.bitgoPublicKey) {\n    throw new Error('Unable to create MPC keys - bitgoPublicKey is missing from constants');\n  }\n\n  const bitgoPublicKeyStr = constants.mpc.bitgoPublicKey as string;\n  const bitgoMPCv2PublicKeyStr = constants.mpc.bitgoMPCv2PublicKey\n    ? await readKey({ armoredKey: constants.mpc.bitgoMPCv2PublicKey as string })\n    : undefined;\n  return { mpcV1: await readKey({ armoredKey: bitgoPublicKeyStr }), mpcV2: bitgoMPCv2PublicKeyStr };\n}\n\n/**\n * Verifies the primary user on a GPG key using a reference key representing the user to be checked.\n * Allows a verification without a date check by wrapping verifyPrimaryUser of openpgp.\n * @param {Key} pubKey gpg key to check the primary user of.\n * @param {Key} primaryUser gpg key of the user to check.\n * @param {boolean} checkDates If false, disable date checks in the openpgp call to check the primary user.\n * @return {KeyValidityDict} list of users checked and whether each passed as a primary user in pubKey or not.\n */\nexport async function verifyPrimaryUserWrapper(\n  pubKey: Key,\n  primaryUser: Key,\n  checkDates: boolean\n): Promise<KeyValidityDict> {\n  if (checkDates) {\n    return await pubKey.verifyPrimaryUser([primaryUser]);\n  } else {\n    return await pubKey.verifyPrimaryUser([primaryUser], null as unknown as undefined);\n  }\n}\n\n/**\n * Fetches Trust pub key string\n * @param bitgo\n */\nexport async function getTrustGpgPubKey(bitgo: BitGoBase): Promise<Key> {\n  const constants = await bitgo.fetchConstants();\n  if (!constants.trustPubKey) {\n    throw new Error('Unable to get trustPubKey');\n  }\n  return readKey({ armoredKey: constants.trustPubKey });\n}\n\n/**\n * Verify an Eddsa or Ecdsa KeyShare Proof.\n *\n * @param senderPubKey public key of the sender of the privateShareProof\n * @param privateShareProof u value proof\n * @param uValue u value from an Eddsa keyshare\n * @param algo\n * @return {boolean} whether uValue proof actually was signed by sender as part of their subkeys\n */\nexport async function verifyShareProof(\n  senderPubKey: string,\n  privateShareProof: string,\n  uValue: string,\n  algo: 'eddsa' | 'ecdsa'\n): Promise<boolean> {\n  const decodedProof = await pgp.readKey({ armoredKey: privateShareProof });\n  const senderGpgKey = await pgp.readKey({ armoredKey: senderPubKey });\n  if (!(await verifyPrimaryUserWrapper(decodedProof, senderGpgKey, true))[0].valid) {\n    return false;\n  }\n  const proofSubkeys = decodedProof.getSubkeys()[1];\n  if (algo === 'eddsa') {\n    const decodedUValueProof = Buffer.from(proofSubkeys.keyPacket.publicParams['Q'].slice(1)).toString('hex');\n    const rawUValueProof = Buffer.from(\n      sodium.crypto_scalarmult_ed25519_base_noclamp(Buffer.from(uValue, 'hex'))\n    ).toString('hex');\n    return decodedUValueProof === rawUValueProof;\n  } else if (algo === 'ecdsa') {\n    const decodedUValueProof = Buffer.from(proofSubkeys.keyPacket.publicParams['Q']).toString('hex');\n    const rawUValueProof = secp256k1.pointFromScalar(Buffer.from(uValue, 'hex'), false);\n    return rawUValueProof !== null && decodedUValueProof === Buffer.from(rawUValueProof).toString('hex');\n  } else {\n    throw new Error('Invalid algorithm provided');\n  }\n}\n\n/**\n * Verify a shared data proof.\n *\n * @param senderPubKeyArm public key of the signer of the key with proof data\n * @param keyWithNotation signed reciever key with notation data\n * @param dataToVerify data to be checked against notation data in the signed key\n * @return {boolean} whether proof is valid\n */\nexport async function verifySharedDataProof(\n  senderPubKeyArm: string,\n  keyWithNotation: string,\n  dataToVerify: { name: string; value: string }[]\n): Promise<boolean> {\n  const senderPubKey = await pgp.readKey({ armoredKey: senderPubKeyArm });\n  const signedKey = await pgp.readKey({ armoredKey: keyWithNotation });\n  if (\n    !(await verifyPrimaryUserWrapper(signedKey, senderPubKey, false).then((values) =>\n      _.some(values, (value) => value.valid)\n    ))\n  ) {\n    return false;\n  }\n  const primaryUser = await signedKey.getPrimaryUser(null as unknown as undefined);\n  const anyInvalidProof = _.some(\n    // @ts-ignore\n    primaryUser.user.otherCertifications[0].rawNotations,\n    (notation) => dataToVerify.find((i) => i.name === notation.name)?.value !== Buffer.from(notation.value).toString()\n  );\n  return !anyInvalidProof;\n}\n\n/**\n * Creates a proof through adding notation data to a GPG ceritifying signature.\n *\n * @param privateKeyArmored gpg private key in armor format of the sender\n * @param publicKeyToCertArmored gpg public key in armor fomrat of the reciever\n * @param notations data to be proofed\n * @return {string} keyshare proof\n */\nexport async function createSharedDataProof(\n  privateKeyArmored: string,\n  publicKeyToCertArmored: string,\n  notations: { name: string; value: string }[]\n): Promise<string> {\n  const certifyingKey = await pgp.readKey({ armoredKey: privateKeyArmored });\n  const publicKeyToCert = await pgp.readKey({ armoredKey: publicKeyToCertArmored });\n  const dateTime = new Date();\n  // UserId Packet.\n  const userIdPkt = new pgp.UserIDPacket();\n  const primaryUser = await publicKeyToCert.getPrimaryUser(null as unknown as undefined);\n  // @ts-ignore\n  userIdPkt.userID = primaryUser.user.userID.userID;\n  // Signature packet.\n  const signaturePacket = new pgp.SignaturePacket();\n  signaturePacket.signatureType = pgp.enums.signature.certPositive;\n  signaturePacket.publicKeyAlgorithm = pgp.enums.publicKey.ecdsa;\n  signaturePacket.hashAlgorithm = pgp.enums.hash.sha256;\n  // @ts-ignore\n  signaturePacket.issuerFingerprint = await primaryUser.user.mainKey.keyPacket.getFingerprintBytes();\n  // @ts-ignore\n  signaturePacket.issuerKeyID = primaryUser.user.mainKey.keyPacket.keyID;\n  // @ts-ignore\n  signaturePacket.signingKeyID = primaryUser.user.mainKey.keyPacket.keyID;\n  // @ts-ignore\n  signaturePacket.signersUserID = primaryUser.user.userID.userID;\n  // @ts-ignore\n  signaturePacket.features = [1];\n  notations.forEach(({ name, value }) => {\n    signaturePacket.rawNotations.push({\n      name: name,\n      value: new Uint8Array(Buffer.from(value)),\n      humanReadable: true,\n      critical: false,\n    });\n  });\n\n  // Prepare signing data.\n  const keydataToSign = {};\n  // @ts-ignore\n  keydataToSign.key = publicKeyToCert.keyPacket;\n  // @ts-ignore\n  keydataToSign.userID = userIdPkt;\n\n  // Sign the data (create certification).\n  // @ts-ignore\n  await signaturePacket.sign(certifyingKey.keyPacket, keydataToSign, dateTime);\n\n  // Assemble packets together.\n  const publicKeyToCertPkts = publicKeyToCert.toPacketList();\n  const newKeyPktList = new pgp.PacketList();\n  newKeyPktList.push(...publicKeyToCertPkts.slice(0, 3), signaturePacket, ...publicKeyToCertPkts.slice(3));\n  // @ts-ignore\n  const newPubKey = new pgp.PublicKey(newKeyPktList);\n  return newPubKey.armor().replace(/\\r\\n/g, '\\n');\n}\n\n/**\n * Creates a KeyShare Proof based on given algo.\n *\n * Creates an EdDSA KeyShare Proof by appending an ed25519 subkey (auth) to an armored gpg private key.\n * Creates an ECDSA KeyShare Proof by Append a secp256k1 subkey (auth) to a PGP keychain.\n *\n * @param privateArmor gpg private key in armor format\n * @param uValue u value from an Eddsa keyshare\n * @param algo algo to use, eddsa or ecdsa\n * @return {string} keyshare proof\n */\nexport async function createShareProof(privateArmor: string, uValue: string, algo: string): Promise<string> {\n  const privateKey = await readKey({ armoredKey: privateArmor });\n  const dateTime = new Date();\n  // @ts-ignore - type inconsistency, this ctor supports a date param: https://docs.openpgpjs.org/SecretSubkeyPacket.html\n  const secretSubkeyPacket = new pgp.SecretSubkeyPacket(dateTime);\n  secretSubkeyPacket.algorithm = pgp.enums.publicKey[algo];\n  // @ts-ignore - same as above\n  secretSubkeyPacket.isEncrypted = false;\n  let oid;\n  let Q;\n  if (algo === 'eddsa') {\n    await sodium.ready;\n    const subKeyVal = Buffer.from(\n      sodium.crypto_scalarmult_ed25519_base_noclamp(Buffer.from(uValue, 'hex'), 'uint8array')\n    );\n    // Sub-key (encryption key) packet.\n    oid = [0x2b, 0x06, 0x01, 0x04, 0x01, 0xda, 0x47, 0x0f, 0x01];\n    // @ts-ignore\n    oid.write = () => new Uint8Array(Buffer.from('092b06010401da470f01', 'hex'));\n    Q = new Uint8Array([0x40, ...subKeyVal]);\n  } else if (algo === 'ecdsa') {\n    oid = [0x2b, 0x81, 0x04, 0x00, 0x0a];\n    // @ts-ignore - same as above\n    oid.write = () => new Uint8Array(Buffer.from('052b8104000a', 'hex'));\n    Q = secp256k1.pointFromScalar(new Uint8Array(Buffer.from(uValue, 'hex')), false);\n  }\n  secretSubkeyPacket.publicParams = {\n    oid,\n    Q,\n  };\n  // @ts-ignore - same as above\n  await secretSubkeyPacket.computeFingerprintAndKeyID();\n\n  // Sub-key signature packet.\n  const subKeydataToSign = {\n    key: privateKey.keyPacket,\n    bind: secretSubkeyPacket,\n  };\n  const subkeySignaturePacket = new pgp.SignaturePacket();\n  subkeySignaturePacket.signatureType = pgp.enums.signature.subkeyBinding;\n  subkeySignaturePacket.publicKeyAlgorithm = pgp.enums.publicKey.ecdsa;\n  subkeySignaturePacket.hashAlgorithm = pgp.enums.hash.sha256;\n  subkeySignaturePacket.keyFlags = new Uint8Array([pgp.enums.keyFlags.authentication]);\n\n  // Sign the subkey\n  // @ts-ignore - sign supports arbitrary data for 2nd param: https://docs.openpgpjs.org/SignaturePacket.html\n  await subkeySignaturePacket.sign(privateKey.keyPacket, subKeydataToSign, dateTime);\n\n  // Assemble packets together.\n  const newKeyPktList = new pgp.PacketList();\n  const privateKeyPkts = privateKey.toPacketList();\n  privateKeyPkts.forEach((packet) => newKeyPktList.push(packet));\n  newKeyPktList.push(secretSubkeyPacket, subkeySignaturePacket);\n  // @ts-ignore - supports packet list as ctor param: https://docs.openpgpjs.org/PrivateKey.html\n  const newPubKey = new pgp.PrivateKey(newKeyPktList).toPublic();\n\n  if (!(await verifyPrimaryUserWrapper(newPubKey, privateKey, true))[0].valid) {\n    throw new Error('Incorrect signature');\n  }\n\n  return newPubKey.armor().replace(/\\r\\n/g, '\\n');\n}\n\n/**\n * Encrypts string using gpg key\n * @DEPRECATED - should use encryptAndSignText instead for added security\n *\n * @param text string to encrypt\n * @param key encryption key\n * @return {string} encrypted string\n *\n * TODO(BG-47170): Delete once gpg signatures are fully supported\n */\nexport async function encryptText(text: string, key: Key): Promise<string> {\n  const messageToEncrypt = await createMessage({\n    text,\n  });\n  return await encrypt({\n    message: messageToEncrypt,\n    encryptionKeys: [key],\n    format: 'armored',\n    config: {\n      rejectCurves: new Set(),\n      showVersion: false,\n      showComment: false,\n    },\n  });\n}\n\n/**\n * Encrypts and signs a string\n * @param text string to encrypt and sign\n * @param publicArmor public key to encrypt with\n * @param privateArmor private key to sign with\n */\nexport async function encryptAndSignText(text: string, publicArmor: string, privateArmor: string): Promise<string> {\n  const publicKey = await readKey({ armoredKey: publicArmor });\n  const privateKey = await readPrivateKey({ armoredKey: privateArmor });\n\n  const message = await createMessage({ text });\n\n  const signedMessage = await encrypt({\n    message,\n    encryptionKeys: publicKey,\n    signingKeys: privateKey,\n    format: 'armored',\n    config: {\n      rejectCurves: new Set(),\n      showVersion: false,\n      showComment: false,\n    },\n  });\n\n  return signedMessage;\n}\n\n/**\n * Reads a signed and encrypted message\n *\n * @param signed signed and encrypted message\n * @param publicArmor public key to verify signature\n * @param privateArmor private key to decrypt message\n */\nexport async function readSignedMessage(signed: string, publicArmor: string, privateArmor: string): Promise<string> {\n  const publicKey = await readKey({ armoredKey: publicArmor });\n  const privateKey = await readPrivateKey({ armoredKey: privateArmor });\n\n  const message = await readMessage({ armoredMessage: signed });\n  const decrypted = await decrypt({\n    message,\n    verificationKeys: publicKey,\n    decryptionKeys: privateKey,\n    expectSigned: true,\n    config: { rejectCurves: new Set() },\n  });\n\n  return decrypted.data;\n}\n\n/**\n * Generates a signature\n *\n * @param text string to generate a signature for\n * @param privateArmor private key as armored string\n * @return {string} armored signature string\n */\nexport async function signText(text: string, privateArmor: string): Promise<string> {\n  const privateKey = await readPrivateKey({ armoredKey: privateArmor });\n  const message = await createMessage({ text });\n  const signature = await sign({\n    message,\n    signingKeys: privateKey,\n    format: 'armored',\n    detached: true,\n  });\n\n  return signature;\n}\n\n/**\n * Verifies signature was generated by the public key and matches the expected text\n *\n * @param text text that the signature was for\n * @param armoredSignature signed message as an armored string\n * @param publicArmor public key that generated the signature\n */\nexport async function verifySignature(text: string, armoredSignature: string, publicArmor: string): Promise<boolean> {\n  const publicKey = await readKey({ armoredKey: publicArmor });\n  const signature = await readSignature({ armoredSignature });\n  const message = await createMessage({ text });\n  const verificationResult = await verify({\n    message,\n    signature,\n    verificationKeys: publicKey,\n  });\n\n  if (verificationResult.signatures.length !== 1) {\n    throw new Error('Invalid number of signatures');\n  }\n\n  try {\n    await verificationResult.signatures[0].verified;\n    return text === verificationResult.data;\n  } catch {\n    return false;\n  }\n}\n\n/**\n * Generate a GPG key pair\n *\n * @param: keyCurve the curve to create a key with\n * @param: username name of the user (optional)\n * @param: email email of the user (optional)\n */\nexport async function generateGPGKeyPair(\n  keyCurve: pgp.EllipticCurveName,\n  username?: string | undefined,\n  email?: string | undefined\n): Promise<pgp.SerializedKeyPair<string>> {\n  const randomHexString = crypto.randomBytes(12).toString('hex');\n  username = username ?? randomHexString;\n  email = email ?? `user-${randomHexString}@${randomHexString}.com`;\n\n  // Allow generating secp256k1 key pairs\n  pgp.config.rejectCurves = new Set();\n  const gpgKey = await pgp.generateKey({\n    userIDs: [\n      {\n        name: username,\n        email,\n      },\n    ],\n    curve: keyCurve,\n  });\n\n  return gpgKey;\n}\n"]}
413
+ //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"opengpgUtils.js","sourceRoot":"","sources":["../../../../src/bitgo/utils/opengpgUtils.ts"],"names":[],"mappings":"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","sourcesContent":["/* eslint-disable @typescript-eslint/ban-ts-comment */\n\nimport * as pgp from 'openpgp';\nimport {\n  createMessage,\n  decrypt,\n  encrypt,\n  Key,\n  readKey,\n  readMessage,\n  readPrivateKey,\n  readSignature,\n  sign,\n  verify,\n} from 'openpgp';\nimport * as _ from 'lodash';\nimport { ecc as secp256k1 } from '@bitgo-beta/secp256k1';\nimport { BitGoBase } from '../bitgoBase';\nimport crypto from 'crypto';\n\nconst sodium = require('libsodium-wrappers-sumo');\n\nexport type KeyValidityDict = {\n  keyID: pgp.KeyID;\n  valid: boolean | null;\n}[];\n\nexport type AuthEncMessage = {\n  encryptedMessage: string;\n  signature: string;\n};\n\n/**\n * Fetches BitGo's public gpg key used in MPC flows\n * @param {BitGoBase} bitgo BitGo object\n * @return {Key} public gpg key\n */\nexport async function getBitgoGpgPubKey(bitgo: BitGoBase): Promise<{ mpcV1: Key; mpcV2: Key | undefined }> {\n  const constants = await bitgo.fetchConstants();\n  if (!constants.mpc || !constants.mpc.bitgoPublicKey) {\n    throw new Error('Unable to create MPC keys - bitgoPublicKey is missing from constants');\n  }\n\n  const bitgoPublicKeyStr = constants.mpc.bitgoPublicKey as string;\n  const bitgoMPCv2PublicKeyStr = constants.mpc.bitgoMPCv2PublicKey\n    ? await readKey({ armoredKey: constants.mpc.bitgoMPCv2PublicKey as string })\n    : undefined;\n  return { mpcV1: await readKey({ armoredKey: bitgoPublicKeyStr }), mpcV2: bitgoMPCv2PublicKeyStr };\n}\n\n/**\n * Verifies the primary user on a GPG key using a reference key representing the user to be checked.\n * Allows a verification without a date check by wrapping verifyPrimaryUser of openpgp.\n * @param {Key} pubKey gpg key to check the primary user of.\n * @param {Key} primaryUser gpg key of the user to check.\n * @param {boolean} checkDates If false, disable date checks in the openpgp call to check the primary user.\n * @return {KeyValidityDict} list of users checked and whether each passed as a primary user in pubKey or not.\n */\nexport async function verifyPrimaryUserWrapper(\n  pubKey: Key,\n  primaryUser: Key,\n  checkDates: boolean\n): Promise<KeyValidityDict> {\n  if (checkDates) {\n    return await pubKey.verifyPrimaryUser([primaryUser]);\n  } else {\n    return await pubKey.verifyPrimaryUser([primaryUser], null as unknown as undefined);\n  }\n}\n\n/**\n * Fetches Trust pub key string\n * @param bitgo\n */\nexport async function getTrustGpgPubKey(bitgo: BitGoBase): Promise<Key> {\n  const constants = await bitgo.fetchConstants();\n  if (!constants.trustPubKey) {\n    throw new Error('Unable to get trustPubKey');\n  }\n  return readKey({ armoredKey: constants.trustPubKey });\n}\n\n/**\n * Verify an Eddsa or Ecdsa KeyShare Proof.\n *\n * @param senderPubKey public key of the sender of the privateShareProof\n * @param privateShareProof u value proof\n * @param uValue u value from an Eddsa keyshare\n * @param algo\n * @return {boolean} whether uValue proof actually was signed by sender as part of their subkeys\n */\nexport async function verifyShareProof(\n  senderPubKey: string,\n  privateShareProof: string,\n  uValue: string,\n  algo: 'eddsa' | 'ecdsa'\n): Promise<boolean> {\n  const decodedProof = await pgp.readKey({ armoredKey: privateShareProof });\n  const senderGpgKey = await pgp.readKey({ armoredKey: senderPubKey });\n  if (!(await verifyPrimaryUserWrapper(decodedProof, senderGpgKey, true))[0].valid) {\n    return false;\n  }\n  const proofSubkeys = decodedProof.getSubkeys()[1];\n  if (algo === 'eddsa') {\n    const decodedUValueProof = Buffer.from(proofSubkeys.keyPacket.publicParams['Q'].slice(1)).toString('hex');\n    const rawUValueProof = Buffer.from(\n      sodium.crypto_scalarmult_ed25519_base_noclamp(Buffer.from(uValue, 'hex'))\n    ).toString('hex');\n    return decodedUValueProof === rawUValueProof;\n  } else if (algo === 'ecdsa') {\n    const decodedUValueProof = Buffer.from(proofSubkeys.keyPacket.publicParams['Q']).toString('hex');\n    const rawUValueProof = secp256k1.pointFromScalar(Buffer.from(uValue, 'hex'), false);\n    return rawUValueProof !== null && decodedUValueProof === Buffer.from(rawUValueProof).toString('hex');\n  } else {\n    throw new Error('Invalid algorithm provided');\n  }\n}\n\n/**\n * Verify a shared data proof.\n *\n * @param senderPubKeyArm public key of the signer of the key with proof data\n * @param keyWithNotation signed reciever key with notation data\n * @param dataToVerify data to be checked against notation data in the signed key\n * @return {boolean} whether proof is valid\n */\nexport async function verifySharedDataProof(\n  senderPubKeyArm: string,\n  keyWithNotation: string,\n  dataToVerify: { name: string; value: string }[]\n): Promise<boolean> {\n  const senderPubKey = await pgp.readKey({ armoredKey: senderPubKeyArm });\n  const signedKey = await pgp.readKey({ armoredKey: keyWithNotation });\n  if (\n    !(await verifyPrimaryUserWrapper(signedKey, senderPubKey, false).then((values) =>\n      _.some(values, (value) => value.valid)\n    ))\n  ) {\n    return false;\n  }\n  const primaryUser = await signedKey.getPrimaryUser(null as unknown as undefined);\n  const anyInvalidProof = _.some(\n    // @ts-ignore\n    primaryUser.user.otherCertifications[0].rawNotations,\n    (notation) => dataToVerify.find((i) => i.name === notation.name)?.value !== Buffer.from(notation.value).toString()\n  );\n  return !anyInvalidProof;\n}\n\n/**\n * Creates a proof through adding notation data to a GPG ceritifying signature.\n *\n * @param privateKeyArmored gpg private key in armor format of the sender\n * @param publicKeyToCertArmored gpg public key in armor fomrat of the reciever\n * @param notations data to be proofed\n * @return {string} keyshare proof\n */\nexport async function createSharedDataProof(\n  privateKeyArmored: string,\n  publicKeyToCertArmored: string,\n  notations: { name: string; value: string }[]\n): Promise<string> {\n  const certifyingKey = await pgp.readKey({ armoredKey: privateKeyArmored });\n  const publicKeyToCert = await pgp.readKey({ armoredKey: publicKeyToCertArmored });\n  const dateTime = new Date();\n  // UserId Packet.\n  const userIdPkt = new pgp.UserIDPacket();\n  const primaryUser = await publicKeyToCert.getPrimaryUser(null as unknown as undefined);\n  // @ts-ignore\n  userIdPkt.userID = primaryUser.user.userID.userID;\n  // Signature packet.\n  const signaturePacket = new pgp.SignaturePacket();\n  signaturePacket.signatureType = pgp.enums.signature.certPositive;\n  signaturePacket.publicKeyAlgorithm = pgp.enums.publicKey.ecdsa;\n  signaturePacket.hashAlgorithm = pgp.enums.hash.sha256;\n  // @ts-ignore\n  signaturePacket.issuerFingerprint = await primaryUser.user.mainKey.keyPacket.getFingerprintBytes();\n  // @ts-ignore\n  signaturePacket.issuerKeyID = primaryUser.user.mainKey.keyPacket.keyID;\n  // @ts-ignore\n  signaturePacket.signingKeyID = primaryUser.user.mainKey.keyPacket.keyID;\n  // @ts-ignore\n  signaturePacket.signersUserID = primaryUser.user.userID.userID;\n  // @ts-ignore\n  signaturePacket.features = [1];\n  notations.forEach(({ name, value }) => {\n    signaturePacket.rawNotations.push({\n      name: name,\n      value: new Uint8Array(Buffer.from(value)),\n      humanReadable: true,\n      critical: false,\n    });\n  });\n\n  // Prepare signing data.\n  const keydataToSign = {};\n  // @ts-ignore\n  keydataToSign.key = publicKeyToCert.keyPacket;\n  // @ts-ignore\n  keydataToSign.userID = userIdPkt;\n\n  // Sign the data (create certification).\n  // @ts-ignore\n  await signaturePacket.sign(certifyingKey.keyPacket, keydataToSign, dateTime);\n\n  // Assemble packets together.\n  const publicKeyToCertPkts = publicKeyToCert.toPacketList();\n  const newKeyPktList = new pgp.PacketList();\n  newKeyPktList.push(...publicKeyToCertPkts.slice(0, 3), signaturePacket, ...publicKeyToCertPkts.slice(3));\n  // @ts-ignore\n  const newPubKey = new pgp.PublicKey(newKeyPktList);\n  return newPubKey.armor().replace(/\\r\\n/g, '\\n');\n}\n\n/**\n * Creates a KeyShare Proof based on given algo.\n *\n * Creates an EdDSA KeyShare Proof by appending an ed25519 subkey (auth) to an armored gpg private key.\n * Creates an ECDSA KeyShare Proof by Append a secp256k1 subkey (auth) to a PGP keychain.\n *\n * @param privateArmor gpg private key in armor format\n * @param uValue u value from an Eddsa keyshare\n * @param algo algo to use, eddsa or ecdsa\n * @return {string} keyshare proof\n */\nexport async function createShareProof(privateArmor: string, uValue: string, algo: string): Promise<string> {\n  const privateKey = await readKey({ armoredKey: privateArmor });\n  const dateTime = new Date();\n  // @ts-ignore - type inconsistency, this ctor supports a date param: https://docs.openpgpjs.org/SecretSubkeyPacket.html\n  const secretSubkeyPacket = new pgp.SecretSubkeyPacket(dateTime);\n  secretSubkeyPacket.algorithm = pgp.enums.publicKey[algo];\n  // @ts-ignore - same as above\n  secretSubkeyPacket.isEncrypted = false;\n  let oid;\n  let Q;\n  if (algo === 'eddsa') {\n    await sodium.ready;\n    const subKeyVal = Buffer.from(\n      sodium.crypto_scalarmult_ed25519_base_noclamp(Buffer.from(uValue, 'hex'), 'uint8array')\n    );\n    // Sub-key (encryption key) packet.\n    oid = [0x2b, 0x06, 0x01, 0x04, 0x01, 0xda, 0x47, 0x0f, 0x01];\n    // @ts-ignore\n    oid.write = () => new Uint8Array(Buffer.from('092b06010401da470f01', 'hex'));\n    Q = new Uint8Array([0x40, ...subKeyVal]);\n  } else if (algo === 'ecdsa') {\n    oid = [0x2b, 0x81, 0x04, 0x00, 0x0a];\n    // @ts-ignore - same as above\n    oid.write = () => new Uint8Array(Buffer.from('052b8104000a', 'hex'));\n    Q = secp256k1.pointFromScalar(new Uint8Array(Buffer.from(uValue, 'hex')), false);\n  }\n  secretSubkeyPacket.publicParams = {\n    oid,\n    Q,\n  };\n  // @ts-ignore - same as above\n  await secretSubkeyPacket.computeFingerprintAndKeyID();\n\n  // Sub-key signature packet.\n  const subKeydataToSign = {\n    key: privateKey.keyPacket,\n    bind: secretSubkeyPacket,\n  };\n  const subkeySignaturePacket = new pgp.SignaturePacket();\n  subkeySignaturePacket.signatureType = pgp.enums.signature.subkeyBinding;\n  subkeySignaturePacket.publicKeyAlgorithm = pgp.enums.publicKey.ecdsa;\n  subkeySignaturePacket.hashAlgorithm = pgp.enums.hash.sha256;\n  subkeySignaturePacket.keyFlags = new Uint8Array([pgp.enums.keyFlags.authentication]);\n\n  // Sign the subkey\n  // @ts-ignore - sign supports arbitrary data for 2nd param: https://docs.openpgpjs.org/SignaturePacket.html\n  await subkeySignaturePacket.sign(privateKey.keyPacket, subKeydataToSign, dateTime);\n\n  // Assemble packets together.\n  const newKeyPktList = new pgp.PacketList();\n  const privateKeyPkts = privateKey.toPacketList();\n  privateKeyPkts.forEach((packet) => newKeyPktList.push(packet));\n  newKeyPktList.push(secretSubkeyPacket, subkeySignaturePacket);\n  // @ts-ignore - supports packet list as ctor param: https://docs.openpgpjs.org/PrivateKey.html\n  const newPubKey = new pgp.PrivateKey(newKeyPktList).toPublic();\n\n  if (!(await verifyPrimaryUserWrapper(newPubKey, privateKey, true))[0].valid) {\n    throw new Error('Incorrect signature');\n  }\n\n  return newPubKey.armor().replace(/\\r\\n/g, '\\n');\n}\n\n/**\n * Encrypts string using gpg key\n * @DEPRECATED - should use encryptAndSignText instead for added security\n *\n * @param text string to encrypt\n * @param key encryption key\n * @return {string} encrypted string\n *\n * TODO(BG-47170): Delete once gpg signatures are fully supported\n */\nexport async function encryptText(text: string, key: Key): Promise<string> {\n  const messageToEncrypt = await createMessage({\n    text,\n  });\n  return await encrypt({\n    message: messageToEncrypt,\n    encryptionKeys: [key],\n    format: 'armored',\n    config: {\n      rejectCurves: new Set(),\n      showVersion: false,\n      showComment: false,\n    },\n  });\n}\n\n/**\n * Encrypts and signs a string\n * @param text string to encrypt and sign\n * @param publicArmor public key to encrypt with\n * @param privateArmor private key to sign with\n */\nexport async function encryptAndSignText(text: string, publicArmor: string, privateArmor: string): Promise<string> {\n  const publicKey = await readKey({ armoredKey: publicArmor });\n  const privateKey = await readPrivateKey({ armoredKey: privateArmor });\n\n  const message = await createMessage({ text });\n\n  const signedMessage = await encrypt({\n    message,\n    encryptionKeys: publicKey,\n    signingKeys: privateKey,\n    format: 'armored',\n    config: {\n      rejectCurves: new Set(),\n      showVersion: false,\n      showComment: false,\n    },\n  });\n\n  return signedMessage;\n}\n\n/**\n * Reads a signed and encrypted message\n *\n * @param signed signed and encrypted message\n * @param publicArmor public key to verify signature\n * @param privateArmor private key to decrypt message\n */\nexport async function readSignedMessage(signed: string, publicArmor: string, privateArmor: string): Promise<string> {\n  const publicKey = await readKey({ armoredKey: publicArmor });\n  const privateKey = await readPrivateKey({ armoredKey: privateArmor });\n\n  const message = await readMessage({ armoredMessage: signed });\n  const decrypted = await decrypt({\n    message,\n    verificationKeys: publicKey,\n    decryptionKeys: privateKey,\n    expectSigned: true,\n    config: { rejectCurves: new Set() },\n  });\n\n  return decrypted.data;\n}\n\n/**\n * Generates a signature\n *\n * @param text string to generate a signature for\n * @param privateArmor private key as armored string\n * @return {string} armored signature string\n */\nexport async function signText(text: string, privateArmor: string): Promise<string> {\n  const privateKey = await readPrivateKey({ armoredKey: privateArmor });\n  const message = await createMessage({ text });\n  const signature = await sign({\n    message,\n    signingKeys: privateKey,\n    format: 'armored',\n    detached: true,\n  });\n\n  return signature;\n}\n\n/**\n * Verifies signature was generated by the public key and matches the expected text\n *\n * @param text text that the signature was for\n * @param armoredSignature signed message as an armored string\n * @param publicArmor public key that generated the signature\n */\nexport async function verifySignature(text: string, armoredSignature: string, publicArmor: string): Promise<boolean> {\n  const publicKey = await readKey({ armoredKey: publicArmor });\n  const signature = await readSignature({ armoredSignature });\n  const message = await createMessage({ text });\n  const verificationResult = await verify({\n    message,\n    signature,\n    verificationKeys: publicKey,\n  });\n\n  if (verificationResult.signatures.length !== 1) {\n    throw new Error('Invalid number of signatures');\n  }\n\n  try {\n    await verificationResult.signatures[0].verified;\n    return text === verificationResult.data;\n  } catch {\n    return false;\n  }\n}\n\n/**\n * Generate a GPG key pair\n *\n * @param: keyCurve the curve to create a key with\n * @param: username name of the user (optional)\n * @param: email email of the user (optional)\n */\nexport async function generateGPGKeyPair(\n  keyCurve: pgp.EllipticCurveName,\n  username?: string | undefined,\n  email?: string | undefined\n): Promise<pgp.SerializedKeyPair<string>> {\n  const randomHexString = crypto.randomBytes(12).toString('hex');\n  username = username ?? randomHexString;\n  email = email ?? `user-${randomHexString}@${randomHexString}.com`;\n\n  // Allow generating secp256k1 key pairs\n  pgp.config.rejectCurves = new Set();\n  const gpgKey = await pgp.generateKey({\n    userIDs: [\n      {\n        name: username,\n        email,\n      },\n    ],\n    curve: keyCurve,\n  });\n\n  return gpgKey;\n}\n"]}