@bitgo-beta/abstract-cosmos 1.0.1-beta.13 → 1.0.1-beta.15

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,7 +1,8 @@
1
1
  /// <reference types="node" />
2
- import { BaseCoin, BitGoBase, KeyPair, MPCAlgorithm, ParsedTransaction, ParseTransactionOptions, SignedTransaction, SignTransactionOptions, VerifyAddressOptions, VerifyTransactionOptions } from '@bitgo-beta/sdk-core';
3
- import { BaseCoin as StaticsBaseCoin, CoinFamily } from '@bitgo-beta/statics';
2
+ import { BaseCoin, BitGoBase, ExplanationResult, KeyPair, MPCAlgorithm, ParsedTransaction, ParseTransactionOptions, SignedTransaction, SignTransactionOptions, VerifyAddressOptions, VerifyTransactionOptions } from '@bitgo-beta/sdk-core';
3
+ import { CoinFamily, BaseCoin as StaticsBaseCoin } from '@bitgo-beta/statics';
4
4
  import { Hash } from 'crypto';
5
+ import * as request from 'superagent';
5
6
  /**
6
7
  * Cosmos accounts support memo Id based addresses
7
8
  */
@@ -13,6 +14,10 @@ export declare class CosmosCoin extends BaseCoin {
13
14
  protected readonly _staticsCoin: Readonly<StaticsBaseCoin>;
14
15
  protected constructor(bitgo: BitGoBase, staticsCoin?: Readonly<StaticsBaseCoin>);
15
16
  static createInstance(bitgo: BitGoBase, staticsCoin?: Readonly<StaticsBaseCoin>): BaseCoin;
17
+ /**
18
+ * Creates an instance of TransactionBuilderFactory for the coin specific sdk
19
+ */
20
+ getBuilder(): any;
16
21
  /** @inheritDoc **/
17
22
  getBaseFactor(): string | number;
18
23
  /** @inheritDoc **/
@@ -29,18 +34,70 @@ export declare class CosmosCoin extends BaseCoin {
29
34
  isValidPub(pub: string): boolean;
30
35
  /** @inheritDoc **/
31
36
  isValidPrv(prv: string): boolean;
32
- verifyTransaction(params: VerifyTransactionOptions): Promise<boolean>;
33
37
  isValidAddress(address: string): boolean;
34
- signTransaction(params: SignTransactionOptions): Promise<SignedTransaction>;
38
+ /** @inheritDoc **/
39
+ verifyTransaction(params: VerifyTransactionOptions): Promise<boolean>;
40
+ /** @inheritDoc **/
41
+ explainTransaction(options: {
42
+ txHex: string;
43
+ }): Promise<ExplanationResult>;
44
+ /**
45
+ * Sign a transaction with a single private key
46
+ * @param params parameters in the form of { txPrebuild: {txHex}, prv }
47
+ * @returns signed transaction in the form of { txHex }
48
+ */
49
+ signTransaction(params: SignTransactionOptions & {
50
+ txPrebuild: {
51
+ txHex: string;
52
+ };
53
+ prv: string;
54
+ }): Promise<SignedTransaction>;
35
55
  /** @inheritDoc **/
36
56
  parseTransaction(params: ParseTransactionOptions & {
37
57
  txHex: string;
38
58
  }): Promise<ParsedTransaction>;
59
+ /**
60
+ * Get the public node url from the Environments constant we have defined
61
+ */
62
+ protected getPublicNodeUrl(): string;
63
+ /**
64
+ * Get account number from public node
65
+ */
66
+ protected getAccountFromNode(senderAddress: string): Promise<request.Response>;
67
+ /**
68
+ * Get balance from public node
69
+ */
70
+ protected getBalanceFromNode(senderAddress: string): Promise<request.Response>;
71
+ /**
72
+ * Get chain id from public node
73
+ */
74
+ protected getChainIdFromNode(): Promise<request.Response>;
75
+ /**
76
+ * Helper to fetch account balance
77
+ */
78
+ protected getAccountBalance(senderAddress: string): Promise<string>;
79
+ /**
80
+ * Helper to fetch chainId
81
+ */
82
+ protected getChainId(): Promise<string>;
83
+ /**
84
+ * Helper to fetch account number
85
+ */
86
+ protected getAccountDetails(senderAddress: string): Promise<string[]>;
39
87
  /** @inheritDoc **/
40
88
  generateKeyPair(seed?: Buffer): KeyPair;
89
+ /**
90
+ * Retrieves the address from a public key.
91
+ * @param {string} pubKey - The public key.
92
+ * @returns {string} The corresponding address.
93
+ */
41
94
  getAddressFromPublicKey(pubKey: string): string;
42
95
  /** @inheritDoc **/
43
96
  isWalletAddress(params: VerifyAddressOptions): Promise<boolean>;
97
+ /**
98
+ * Retrieves the SHA256 hash function.
99
+ * @returns {Hash} The SHA256 hash function.
100
+ */
44
101
  getHashFunction(): Hash;
45
102
  /**
46
103
  * Process address into address and memo id
@@ -56,8 +113,6 @@ export declare class CosmosCoin extends BaseCoin {
56
113
  * @returns true if memo id is valid
57
114
  */
58
115
  isValidMemoId(memoId: string): boolean;
59
- private getKeyCombinedFromTssKeyShares;
60
- private signRecoveryTSS;
61
116
  }
62
117
  export {};
63
118
  //# sourceMappingURL=cosmosCoin.d.ts.map
@@ -1 +1 @@
1
- {"version":3,"file":"cosmosCoin.d.ts","sourceRoot":"","sources":["../../src/cosmosCoin.ts"],"names":[],"mappings":";AAAA,OAAO,EACL,QAAQ,EACR,SAAS,EAOT,OAAO,EACP,YAAY,EACZ,iBAAiB,EACjB,uBAAuB,EACvB,iBAAiB,EACjB,sBAAsB,EAEtB,oBAAoB,EACpB,wBAAwB,EACzB,MAAM,sBAAsB,CAAC;AAE9B,OAAO,EAAE,QAAQ,IAAI,eAAe,EAAE,UAAU,EAAE,MAAM,qBAAqB,CAAC;AAG9E,OAAO,EAAc,IAAI,EAAe,MAAM,QAAQ,CAAC;AAQvD;;GAEG;AACH,UAAU,cAAc;IACtB,OAAO,EAAE,MAAM,CAAC;IAChB,MAAM,CAAC,EAAE,MAAM,GAAG,SAAS,CAAC;CAC7B;AASD,qBAAa,UAAW,SAAQ,QAAQ;IACtC,SAAS,CAAC,QAAQ,CAAC,YAAY,EAAE,QAAQ,CAAC,eAAe,CAAC,CAAC;IAC3D,SAAS,aAAa,KAAK,EAAE,SAAS,EAAE,WAAW,CAAC,EAAE,QAAQ,CAAC,eAAe,CAAC;IAU/E,MAAM,CAAC,cAAc,CAAC,KAAK,EAAE,SAAS,EAAE,WAAW,CAAC,EAAE,QAAQ,CAAC,eAAe,CAAC,GAAG,QAAQ;IAI1F,mBAAmB;IACnB,aAAa,IAAI,MAAM,GAAG,MAAM;IAIhC,mBAAmB;IACnB,QAAQ,IAAI,MAAM;IAIlB,mBAAmB;IACnB,SAAS,IAAI,UAAU;IAIvB,mBAAmB;IACnB,WAAW,IAAI,MAAM;IAIrB,kBAAkB;IAClB,WAAW,IAAI,OAAO;IAItB,mBAAmB;IACnB,eAAe,IAAI,YAAY;IAI/B,mBAAmB;IACnB,UAAU,CAAC,GAAG,EAAE,MAAM,GAAG,OAAO;IAIhC,mBAAmB;IACnB,UAAU,CAAC,GAAG,EAAE,MAAM,GAAG,OAAO;IAIhC,iBAAiB,CAAC,MAAM,EAAE,wBAAwB,GAAG,OAAO,CAAC,OAAO,CAAC;IAIrE,cAAc,CAAC,OAAO,EAAE,MAAM,GAAG,OAAO;IAIxC,eAAe,CAAC,MAAM,EAAE,sBAAsB,GAAG,OAAO,CAAC,iBAAiB,CAAC;IAI3E,mBAAmB;IACb,gBAAgB,CAAC,MAAM,EAAE,uBAAuB,GAAG;QAAE,KAAK,EAAE,MAAM,CAAA;KAAE,GAAG,OAAO,CAAC,iBAAiB,CAAC;IAgCvG,mBAAmB;IACnB,eAAe,CAAC,IAAI,CAAC,EAAE,MAAM,GAAG,OAAO;IAcvC,uBAAuB,CAAC,MAAM,EAAE,MAAM,GAAG,MAAM;IAI/C,mBAAmB;IACb,eAAe,CAAC,MAAM,EAAE,oBAAoB,GAAG,OAAO,CAAC,OAAO,CAAC;IAarE,eAAe,IAAI,IAAI;IAIvB;;;;;OAKG;IACH,iBAAiB,CAAC,OAAO,EAAE,MAAM,GAAG,cAAc;IA4ClD;;;;;OAKG;IACH,aAAa,CAAC,MAAM,EAAE,MAAM,GAAG,OAAO;IAUtC,OAAO,CAAC,8BAA8B;YAiExB,eAAe;CAwF9B"}
1
+ {"version":3,"file":"cosmosCoin.d.ts","sourceRoot":"","sources":["../../src/cosmosCoin.ts"],"names":[],"mappings":"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"}
@@ -2,16 +2,15 @@
2
2
  Object.defineProperty(exports, "__esModule", { value: true });
3
3
  exports.CosmosCoin = void 0;
4
4
  const sdk_core_1 = require("@bitgo-beta/sdk-core");
5
- const sdk_lib_mpc_1 = require("@bitgo-beta/sdk-lib-mpc");
6
5
  const utxo_lib_1 = require("@bitgo-beta/utxo-lib");
7
6
  const bignumber_js_1 = require("bignumber.js");
8
7
  const crypto_1 = require("crypto");
9
8
  const _ = require("lodash");
10
- const utils_1 = require("./lib/utils");
11
- const url = require("url");
12
9
  const querystring = require("querystring");
10
+ const request = require("superagent");
11
+ const url = require("url");
13
12
  const lib_1 = require("./lib");
14
- const buffer_1 = require("buffer");
13
+ const utils_1 = require("./lib/utils");
15
14
  class CosmosCoin extends sdk_core_1.BaseCoin {
16
15
  constructor(bitgo, staticsCoin) {
17
16
  super(bitgo);
@@ -23,6 +22,12 @@ class CosmosCoin extends sdk_core_1.BaseCoin {
23
22
  static createInstance(bitgo, staticsCoin) {
24
23
  return new CosmosCoin(bitgo, staticsCoin);
25
24
  }
25
+ /**
26
+ * Creates an instance of TransactionBuilderFactory for the coin specific sdk
27
+ */
28
+ getBuilder() {
29
+ throw new Error('Method not implemented.');
30
+ }
26
31
  /** @inheritDoc **/
27
32
  getBaseFactor() {
28
33
  return 1e6;
@@ -55,14 +60,77 @@ class CosmosCoin extends sdk_core_1.BaseCoin {
55
60
  isValidPrv(prv) {
56
61
  return utils_1.default.isValidPrivateKey(prv);
57
62
  }
58
- verifyTransaction(params) {
59
- throw new Error('Method not implemented.');
60
- }
61
63
  isValidAddress(address) {
62
64
  throw new Error('Method not implemented.');
63
65
  }
64
- signTransaction(params) {
65
- throw new Error('Method not implemented.');
66
+ /** @inheritDoc **/
67
+ async verifyTransaction(params) {
68
+ var _a;
69
+ let totalAmount = new bignumber_js_1.BigNumber(0);
70
+ const { txPrebuild, txParams } = params;
71
+ const rawTx = txPrebuild.txHex;
72
+ if (!rawTx) {
73
+ throw new Error('missing required tx prebuild property txHex');
74
+ }
75
+ const transaction = await this.getBuilder().from(rawTx).build();
76
+ const explainedTx = transaction.explainTransaction();
77
+ if (txParams.recipients && txParams.recipients.length > 0) {
78
+ const filteredRecipients = (_a = txParams.recipients) === null || _a === void 0 ? void 0 : _a.map((recipient) => _.pick(recipient, ['address', 'amount']));
79
+ const filteredOutputs = explainedTx.outputs.map((output) => _.pick(output, ['address', 'amount']));
80
+ if (!_.isEqual(filteredOutputs, filteredRecipients)) {
81
+ throw new Error('Tx outputs does not match with expected txParams recipients');
82
+ }
83
+ // WithdrawDelegatorRewards transaction doesn't have amount
84
+ if (transaction.type !== sdk_core_1.TransactionType.StakingWithdraw) {
85
+ for (const recipients of txParams.recipients) {
86
+ totalAmount = totalAmount.plus(recipients.amount);
87
+ }
88
+ if (!totalAmount.isEqualTo(explainedTx.outputAmount)) {
89
+ throw new Error('Tx total amount does not match with expected total amount field');
90
+ }
91
+ }
92
+ }
93
+ return true;
94
+ }
95
+ /** @inheritDoc **/
96
+ async explainTransaction(options) {
97
+ if (!options.txHex) {
98
+ throw new Error('missing required txHex parameter');
99
+ }
100
+ try {
101
+ const transactionBuilder = this.getBuilder().from(options.txHex);
102
+ const transaction = await transactionBuilder.build();
103
+ return transaction.explainTransaction();
104
+ }
105
+ catch (e) {
106
+ throw new Error('Invalid transaction: ' + e.message);
107
+ }
108
+ }
109
+ /**
110
+ * Sign a transaction with a single private key
111
+ * @param params parameters in the form of { txPrebuild: {txHex}, prv }
112
+ * @returns signed transaction in the form of { txHex }
113
+ */
114
+ async signTransaction(params) {
115
+ var _a;
116
+ const txHex = (_a = params === null || params === void 0 ? void 0 : params.txPrebuild) === null || _a === void 0 ? void 0 : _a.txHex;
117
+ const privateKey = params === null || params === void 0 ? void 0 : params.prv;
118
+ if (!txHex) {
119
+ throw new sdk_core_1.SigningError('missing required txPrebuild parameter: params.txPrebuild.txHex');
120
+ }
121
+ if (!privateKey) {
122
+ throw new sdk_core_1.SigningError('missing required prv parameter: params.prv');
123
+ }
124
+ const txBuilder = this.getBuilder().from(params.txPrebuild.txHex);
125
+ txBuilder.sign({ key: params.prv });
126
+ const transaction = await txBuilder.build();
127
+ if (!transaction) {
128
+ throw new sdk_core_1.SigningError('Failed to build signed transaction');
129
+ }
130
+ const serializedTx = transaction.toBroadcastFormat();
131
+ return {
132
+ txHex: serializedTx,
133
+ };
66
134
  }
67
135
  /** @inheritDoc **/
68
136
  async parseTransaction(params) {
@@ -95,6 +163,87 @@ class CosmosCoin extends sdk_core_1.BaseCoin {
95
163
  outputs,
96
164
  };
97
165
  }
166
+ /**
167
+ * Get the public node url from the Environments constant we have defined
168
+ */
169
+ getPublicNodeUrl() {
170
+ throw new Error('Method not implemented.');
171
+ }
172
+ /**
173
+ * Get account number from public node
174
+ */
175
+ async getAccountFromNode(senderAddress) {
176
+ const nodeUrl = this.getPublicNodeUrl();
177
+ const getAccountPath = 'cosmos/auth/v1beta1/accounts/';
178
+ const fullEndpoint = nodeUrl + getAccountPath + senderAddress;
179
+ try {
180
+ return await request.get(fullEndpoint).send();
181
+ }
182
+ catch (e) {
183
+ console.debug(e);
184
+ }
185
+ throw new Error(`Unable to call endpoint ${getAccountPath + senderAddress} from node: ${nodeUrl}`);
186
+ }
187
+ /**
188
+ * Get balance from public node
189
+ */
190
+ async getBalanceFromNode(senderAddress) {
191
+ const nodeUrl = this.getPublicNodeUrl();
192
+ const getBalancePath = 'cosmos/bank/v1beta1/balances/';
193
+ const fullEndpoint = nodeUrl + getBalancePath + senderAddress;
194
+ try {
195
+ return await request.get(fullEndpoint).send();
196
+ }
197
+ catch (e) {
198
+ console.debug(e);
199
+ }
200
+ throw new Error(`Unable to call endpoint ${getBalancePath + senderAddress} from node: ${nodeUrl}`);
201
+ }
202
+ /**
203
+ * Get chain id from public node
204
+ */
205
+ async getChainIdFromNode() {
206
+ const nodeUrl = this.getPublicNodeUrl();
207
+ const getLatestBlockPath = 'cosmos/base/tendermint/v1beta1/blocks/latest';
208
+ const fullEndpoint = nodeUrl + getLatestBlockPath;
209
+ try {
210
+ return await request.get(fullEndpoint).send();
211
+ }
212
+ catch (e) {
213
+ console.debug(e);
214
+ }
215
+ throw new Error(`Unable to call endpoint ${getLatestBlockPath} from node: ${nodeUrl}`);
216
+ }
217
+ /**
218
+ * Helper to fetch account balance
219
+ */
220
+ async getAccountBalance(senderAddress) {
221
+ const response = await this.getBalanceFromNode(senderAddress);
222
+ if (response.status !== 200) {
223
+ throw new Error('Account not found');
224
+ }
225
+ return response.body.balances[0].amount;
226
+ }
227
+ /**
228
+ * Helper to fetch chainId
229
+ */
230
+ async getChainId() {
231
+ const response = await this.getChainIdFromNode();
232
+ if (response.status !== 200) {
233
+ throw new Error('Account not found');
234
+ }
235
+ return response.body.block.header.chain_id;
236
+ }
237
+ /**
238
+ * Helper to fetch account number
239
+ */
240
+ async getAccountDetails(senderAddress) {
241
+ const response = await this.getAccountFromNode(senderAddress);
242
+ if (response.status !== 200) {
243
+ throw new Error('Account not found');
244
+ }
245
+ return [response.body.account.account_number, response.body.account.sequence];
246
+ }
98
247
  /** @inheritDoc **/
99
248
  generateKeyPair(seed) {
100
249
  if (!seed) {
@@ -109,6 +258,11 @@ class CosmosCoin extends sdk_core_1.BaseCoin {
109
258
  prv: extendedKey.toBase58(),
110
259
  };
111
260
  }
261
+ /**
262
+ * Retrieves the address from a public key.
263
+ * @param {string} pubKey - The public key.
264
+ * @returns {string} The corresponding address.
265
+ */
112
266
  getAddressFromPublicKey(pubKey) {
113
267
  return new lib_1.CosmosKeyPair({ pub: pubKey }).getAddress();
114
268
  }
@@ -124,6 +278,10 @@ class CosmosCoin extends sdk_core_1.BaseCoin {
124
278
  }
125
279
  return true;
126
280
  }
281
+ /**
282
+ * Retrieves the SHA256 hash function.
283
+ * @returns {Hash} The SHA256 hash function.
284
+ */
127
285
  getHashFunction() {
128
286
  return crypto_1.createHash('sha256');
129
287
  }
@@ -183,101 +341,6 @@ class CosmosCoin extends sdk_core_1.BaseCoin {
183
341
  }
184
342
  return memoIdNumber.gte(0);
185
343
  }
186
- getKeyCombinedFromTssKeyShares(userPublicOrPrivateKeyShare, backupPrivateOrPublicKeyShare, walletPassphrase) {
187
- let backupPrv;
188
- let userPrv;
189
- try {
190
- backupPrv = this.bitgo.decrypt({
191
- input: backupPrivateOrPublicKeyShare,
192
- password: walletPassphrase,
193
- });
194
- userPrv = this.bitgo.decrypt({
195
- input: userPublicOrPrivateKeyShare,
196
- password: walletPassphrase,
197
- });
198
- }
199
- catch (e) {
200
- throw new Error(`Error decrypting backup keychain: ${e.message}`);
201
- }
202
- const userSigningMaterial = JSON.parse(userPrv);
203
- const backupSigningMaterial = JSON.parse(backupPrv);
204
- if (!userSigningMaterial.backupNShare) {
205
- throw new Error('Invalid user key - missing backupNShare');
206
- }
207
- if (!backupSigningMaterial.userNShare) {
208
- throw new Error('Invalid backup key - missing userNShare');
209
- }
210
- const MPC = new sdk_core_1.Ecdsa();
211
- const userKeyCombined = MPC.keyCombine(userSigningMaterial.pShare, [
212
- userSigningMaterial.bitgoNShare,
213
- userSigningMaterial.backupNShare,
214
- ]);
215
- const userSigningKeyDerived = MPC.keyDerive(userSigningMaterial.pShare, [userSigningMaterial.bitgoNShare, userSigningMaterial.backupNShare], 'm/0');
216
- const userKeyDerivedCombined = {
217
- xShare: userSigningKeyDerived.xShare,
218
- yShares: userKeyCombined.yShares,
219
- };
220
- const backupKeyCombined = MPC.keyCombine(backupSigningMaterial.pShare, [
221
- userSigningKeyDerived.nShares[2],
222
- backupSigningMaterial.bitgoNShare,
223
- ]);
224
- if (userKeyDerivedCombined.xShare.y !== backupKeyCombined.xShare.y ||
225
- userKeyDerivedCombined.xShare.chaincode !== backupKeyCombined.xShare.chaincode) {
226
- throw new Error('Common keychains do not match');
227
- }
228
- return [userKeyDerivedCombined, backupKeyCombined];
229
- }
230
- // TODO(BG-78714): Reduce code duplication between this and eth.ts
231
- async signRecoveryTSS(userKeyCombined, backupKeyCombined, txHex, { rangeProofChallenge, } = {}) {
232
- const MPC = new sdk_core_1.Ecdsa();
233
- const signerOneIndex = userKeyCombined.xShare.i;
234
- const signerTwoIndex = backupKeyCombined.xShare.i;
235
- // Since this is a user <> backup signing, we will reuse the same range proof challenge
236
- rangeProofChallenge =
237
- rangeProofChallenge !== null && rangeProofChallenge !== void 0 ? rangeProofChallenge : sdk_lib_mpc_1.EcdsaTypes.serializeNtildeWithProofs(await sdk_lib_mpc_1.EcdsaRangeProof.generateNtilde());
238
- const userToBackupPaillierChallenge = await sdk_lib_mpc_1.EcdsaPaillierProof.generateP(sdk_core_1.hexToBigInt(userKeyCombined.yShares[signerTwoIndex].n));
239
- const backupToUserPaillierChallenge = await sdk_lib_mpc_1.EcdsaPaillierProof.generateP(sdk_core_1.hexToBigInt(backupKeyCombined.yShares[signerOneIndex].n));
240
- const userXShare = MPC.appendChallenge(userKeyCombined.xShare, rangeProofChallenge, sdk_lib_mpc_1.EcdsaTypes.serializePaillierChallenge({ p: userToBackupPaillierChallenge }));
241
- const userYShare = MPC.appendChallenge(userKeyCombined.yShares[signerTwoIndex], rangeProofChallenge, sdk_lib_mpc_1.EcdsaTypes.serializePaillierChallenge({ p: backupToUserPaillierChallenge }));
242
- const backupXShare = MPC.appendChallenge(backupKeyCombined.xShare, rangeProofChallenge, sdk_lib_mpc_1.EcdsaTypes.serializePaillierChallenge({ p: backupToUserPaillierChallenge }));
243
- const backupYShare = MPC.appendChallenge(backupKeyCombined.yShares[signerOneIndex], rangeProofChallenge, sdk_lib_mpc_1.EcdsaTypes.serializePaillierChallenge({ p: userToBackupPaillierChallenge }));
244
- const signShares = await MPC.signShare(userXShare, userYShare);
245
- const signConvertS21 = await MPC.signConvertStep1({
246
- xShare: backupXShare,
247
- yShare: backupYShare,
248
- kShare: signShares.kShare,
249
- });
250
- const signConvertS12 = await MPC.signConvertStep2({
251
- aShare: signConvertS21.aShare,
252
- wShare: signShares.wShare,
253
- });
254
- const signConvertS21_2 = await MPC.signConvertStep3({
255
- muShare: signConvertS12.muShare,
256
- bShare: signConvertS21.bShare,
257
- });
258
- const [signCombineOne, signCombineTwo] = [
259
- MPC.signCombine({
260
- gShare: signConvertS12.gShare,
261
- signIndex: {
262
- i: signConvertS12.muShare.i,
263
- j: signConvertS12.muShare.j,
264
- },
265
- }),
266
- MPC.signCombine({
267
- gShare: signConvertS21_2.gShare,
268
- signIndex: {
269
- i: signConvertS21_2.signIndex.i,
270
- j: signConvertS21_2.signIndex.j,
271
- },
272
- }),
273
- ];
274
- const MESSAGE = buffer_1.Buffer.from(txHex, 'hex');
275
- const [signA, signB] = [
276
- MPC.sign(MESSAGE, signCombineOne.oShare, signCombineTwo.dShare, crypto_1.createHash('sha256')),
277
- MPC.sign(MESSAGE, signCombineTwo.oShare, signCombineOne.dShare, crypto_1.createHash('sha256')),
278
- ];
279
- return MPC.constructSignature([signA, signB]);
280
- }
281
344
  }
282
345
  exports.CosmosCoin = CosmosCoin;
283
- //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"cosmosCoin.js","sourceRoot":"","sources":["../../src/cosmosCoin.ts"],"names":[],"mappings":"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","sourcesContent":["import {\n  BaseCoin,\n  BitGoBase,\n  Ecdsa,\n  ECDSA,\n  ECDSAMethodTypes,\n  hexToBigInt,\n  InvalidAddressError,\n  InvalidMemoIdError,\n  KeyPair,\n  MPCAlgorithm,\n  ParsedTransaction,\n  ParseTransactionOptions,\n  SignedTransaction,\n  SignTransactionOptions,\n  UnexpectedAddressError,\n  VerifyAddressOptions,\n  VerifyTransactionOptions,\n} from '@bitgo-beta/sdk-core';\nimport { EcdsaPaillierProof, EcdsaRangeProof, EcdsaTypes } from '@bitgo-beta/sdk-lib-mpc';\nimport { BaseCoin as StaticsBaseCoin, CoinFamily } from '@bitgo-beta/statics';\nimport { bip32 } from '@bitgo-beta/utxo-lib';\nimport { BigNumber } from 'bignumber.js';\nimport { createHash, Hash, randomBytes } from 'crypto';\nimport * as _ from 'lodash';\nimport utils from './lib/utils';\nimport * as url from 'url';\nimport * as querystring from 'querystring';\nimport { CosmosKeyPair } from './lib';\nimport { Buffer } from 'buffer';\n\n/**\n * Cosmos accounts support memo Id based addresses\n */\ninterface AddressDetails {\n  address: string;\n  memoId?: string | undefined;\n}\n\n/**\n * Cosmos accounts support memo Id based addresses\n */\ninterface CosmosCoinSpecific {\n  rootAddress: string;\n}\n\nexport class CosmosCoin extends BaseCoin {\n  protected readonly _staticsCoin: Readonly<StaticsBaseCoin>;\n  protected constructor(bitgo: BitGoBase, staticsCoin?: Readonly<StaticsBaseCoin>) {\n    super(bitgo);\n\n    if (!staticsCoin) {\n      throw new Error('missing required constructor parameter staticsCoin');\n    }\n\n    this._staticsCoin = staticsCoin;\n  }\n\n  static createInstance(bitgo: BitGoBase, staticsCoin?: Readonly<StaticsBaseCoin>): BaseCoin {\n    return new CosmosCoin(bitgo, staticsCoin);\n  }\n\n  /** @inheritDoc **/\n  getBaseFactor(): string | number {\n    return 1e6;\n  }\n\n  /** @inheritDoc **/\n  getChain(): string {\n    return this._staticsCoin.name;\n  }\n\n  /** @inheritDoc **/\n  getFamily(): CoinFamily {\n    return this._staticsCoin.family;\n  }\n\n  /** @inheritDoc **/\n  getFullName(): string {\n    return this._staticsCoin.fullName;\n  }\n\n  /** @inheritDoc */\n  supportsTss(): boolean {\n    return true;\n  }\n\n  /** @inheritDoc **/\n  getMPCAlgorithm(): MPCAlgorithm {\n    return 'ecdsa';\n  }\n\n  /** @inheritDoc **/\n  isValidPub(pub: string): boolean {\n    return utils.isValidPublicKey(pub);\n  }\n\n  /** @inheritDoc **/\n  isValidPrv(prv: string): boolean {\n    return utils.isValidPrivateKey(prv);\n  }\n\n  verifyTransaction(params: VerifyTransactionOptions): Promise<boolean> {\n    throw new Error('Method not implemented.');\n  }\n\n  isValidAddress(address: string): boolean {\n    throw new Error('Method not implemented.');\n  }\n\n  signTransaction(params: SignTransactionOptions): Promise<SignedTransaction> {\n    throw new Error('Method not implemented.');\n  }\n\n  /** @inheritDoc **/\n  async parseTransaction(params: ParseTransactionOptions & { txHex: string }): Promise<ParsedTransaction> {\n    const transactionExplanation = await this.explainTransaction({ txHex: params.txHex });\n    if (!transactionExplanation) {\n      throw new Error('Invalid transaction');\n    }\n\n    if (transactionExplanation.outputs.length <= 0) {\n      return {\n        inputs: [],\n        outputs: [],\n      };\n    }\n    const senderAddress = transactionExplanation.outputs[0].address;\n    const feeAmount = new BigNumber(transactionExplanation.fee.fee === '' ? '0' : transactionExplanation.fee.fee);\n    const inputs = [\n      {\n        address: senderAddress,\n        amount: new BigNumber(transactionExplanation.outputAmount).plus(feeAmount).toFixed(),\n      },\n    ];\n    const outputs = transactionExplanation.outputs.map((output) => {\n      return {\n        address: output.address,\n        amount: new BigNumber(output.amount).toFixed(),\n      };\n    });\n    return {\n      inputs,\n      outputs,\n    };\n  }\n\n  /** @inheritDoc **/\n  generateKeyPair(seed?: Buffer): KeyPair {\n    if (!seed) {\n      // An extended private key has both a normal 256 bit private key and a 256\n      // bit chain code, both of which must be random. 512 bits is therefore the\n      // maximum entropy and gives us maximum security against cracking.\n      seed = randomBytes(512 / 8);\n    }\n    const extendedKey = bip32.fromSeed(seed);\n    return {\n      pub: extendedKey.neutered().toBase58(),\n      prv: extendedKey.toBase58(),\n    };\n  }\n\n  getAddressFromPublicKey(pubKey: string): string {\n    return new CosmosKeyPair({ pub: pubKey }).getAddress();\n  }\n\n  /** @inheritDoc **/\n  async isWalletAddress(params: VerifyAddressOptions): Promise<boolean> {\n    const addressDetails = this.getAddressDetails(params.address);\n\n    if (!this.isValidAddress(addressDetails.address)) {\n      throw new InvalidAddressError(`invalid address: ${addressDetails.address}`);\n    }\n    const rootAddress = (params.coinSpecific as CosmosCoinSpecific).rootAddress;\n    if (addressDetails.address !== rootAddress) {\n      throw new UnexpectedAddressError(`address validation failure: ${addressDetails.address} vs ${rootAddress}`);\n    }\n    return true;\n  }\n\n  getHashFunction(): Hash {\n    return createHash('sha256');\n  }\n\n  /**\n   * Process address into address and memo id\n   *\n   * @param address the address\n   * @returns object containing address and memo id\n   */\n  getAddressDetails(address: string): AddressDetails {\n    const destinationDetails = url.parse(address);\n    const destinationAddress = destinationDetails.pathname || '';\n\n    // address doesn't have a memo id\n    if (destinationDetails.pathname === address) {\n      return {\n        address: address,\n        memoId: undefined,\n      };\n    }\n\n    if (!destinationDetails.query) {\n      throw new InvalidAddressError(`invalid address: ${address}`);\n    }\n\n    const queryDetails = querystring.parse(destinationDetails.query);\n    if (!queryDetails.memoId) {\n      // if there are more properties, the query details need to contain the memo id property\n      throw new InvalidAddressError(`invalid address: ${address}`);\n    }\n\n    if (Array.isArray(queryDetails.memoId)) {\n      throw new InvalidAddressError(\n        `memoId may only be given at most once, but found ${queryDetails.memoId.length} instances in address ${address}`\n      );\n    }\n\n    if (Array.isArray(queryDetails.memoId) && queryDetails.memoId.length !== 1) {\n      // valid addresses can only contain one memo id\n      throw new InvalidAddressError(`invalid address '${address}', must contain exactly one memoId`);\n    }\n\n    const [memoId] = _.castArray(queryDetails.memoId) || undefined;\n    if (!this.isValidMemoId(memoId)) {\n      throw new InvalidMemoIdError(`invalid address: '${address}', memoId is not valid`);\n    }\n\n    return {\n      address: destinationAddress,\n      memoId,\n    };\n  }\n\n  /**\n   * Return boolean indicating whether a memo id is valid\n   *\n   * @param memoId memo id\n   * @returns true if memo id is valid\n   */\n  isValidMemoId(memoId: string): boolean {\n    let memoIdNumber;\n    try {\n      memoIdNumber = new BigNumber(memoId);\n    } catch (e) {\n      return false;\n    }\n    return memoIdNumber.gte(0);\n  }\n\n  private getKeyCombinedFromTssKeyShares(\n    userPublicOrPrivateKeyShare: string,\n    backupPrivateOrPublicKeyShare: string,\n    walletPassphrase?: string\n  ): [ECDSAMethodTypes.KeyCombined, ECDSAMethodTypes.KeyCombined] {\n    let backupPrv;\n    let userPrv;\n    try {\n      backupPrv = this.bitgo.decrypt({\n        input: backupPrivateOrPublicKeyShare,\n        password: walletPassphrase,\n      });\n      userPrv = this.bitgo.decrypt({\n        input: userPublicOrPrivateKeyShare,\n        password: walletPassphrase,\n      });\n    } catch (e) {\n      throw new Error(`Error decrypting backup keychain: ${e.message}`);\n    }\n\n    const userSigningMaterial = JSON.parse(userPrv) as ECDSAMethodTypes.SigningMaterial;\n    const backupSigningMaterial = JSON.parse(backupPrv) as ECDSAMethodTypes.SigningMaterial;\n\n    if (!userSigningMaterial.backupNShare) {\n      throw new Error('Invalid user key - missing backupNShare');\n    }\n\n    if (!backupSigningMaterial.userNShare) {\n      throw new Error('Invalid backup key - missing userNShare');\n    }\n\n    const MPC = new Ecdsa();\n\n    const userKeyCombined = MPC.keyCombine(userSigningMaterial.pShare, [\n      userSigningMaterial.bitgoNShare,\n      userSigningMaterial.backupNShare,\n    ]);\n\n    const userSigningKeyDerived = MPC.keyDerive(\n      userSigningMaterial.pShare,\n      [userSigningMaterial.bitgoNShare, userSigningMaterial.backupNShare],\n      'm/0'\n    );\n\n    const userKeyDerivedCombined = {\n      xShare: userSigningKeyDerived.xShare,\n      yShares: userKeyCombined.yShares,\n    };\n\n    const backupKeyCombined = MPC.keyCombine(backupSigningMaterial.pShare, [\n      userSigningKeyDerived.nShares[2],\n      backupSigningMaterial.bitgoNShare,\n    ]);\n\n    if (\n      userKeyDerivedCombined.xShare.y !== backupKeyCombined.xShare.y ||\n      userKeyDerivedCombined.xShare.chaincode !== backupKeyCombined.xShare.chaincode\n    ) {\n      throw new Error('Common keychains do not match');\n    }\n\n    return [userKeyDerivedCombined, backupKeyCombined];\n  }\n\n  // TODO(BG-78714): Reduce code duplication between this and eth.ts\n  private async signRecoveryTSS(\n    userKeyCombined: ECDSA.KeyCombined,\n    backupKeyCombined: ECDSA.KeyCombined,\n    txHex: string,\n    {\n      rangeProofChallenge,\n    }: {\n      rangeProofChallenge?: EcdsaTypes.SerializedNtilde;\n    } = {}\n  ): Promise<ECDSAMethodTypes.Signature> {\n    const MPC = new Ecdsa();\n    const signerOneIndex = userKeyCombined.xShare.i;\n    const signerTwoIndex = backupKeyCombined.xShare.i;\n\n    // Since this is a user <> backup signing, we will reuse the same range proof challenge\n    rangeProofChallenge =\n      rangeProofChallenge ?? EcdsaTypes.serializeNtildeWithProofs(await EcdsaRangeProof.generateNtilde());\n\n    const userToBackupPaillierChallenge = await EcdsaPaillierProof.generateP(\n      hexToBigInt(userKeyCombined.yShares[signerTwoIndex].n)\n    );\n    const backupToUserPaillierChallenge = await EcdsaPaillierProof.generateP(\n      hexToBigInt(backupKeyCombined.yShares[signerOneIndex].n)\n    );\n\n    const userXShare = MPC.appendChallenge(\n      userKeyCombined.xShare,\n      rangeProofChallenge,\n      EcdsaTypes.serializePaillierChallenge({ p: userToBackupPaillierChallenge })\n    );\n    const userYShare = MPC.appendChallenge(\n      userKeyCombined.yShares[signerTwoIndex],\n      rangeProofChallenge,\n      EcdsaTypes.serializePaillierChallenge({ p: backupToUserPaillierChallenge })\n    );\n    const backupXShare = MPC.appendChallenge(\n      backupKeyCombined.xShare,\n      rangeProofChallenge,\n      EcdsaTypes.serializePaillierChallenge({ p: backupToUserPaillierChallenge })\n    );\n    const backupYShare = MPC.appendChallenge(\n      backupKeyCombined.yShares[signerOneIndex],\n      rangeProofChallenge,\n      EcdsaTypes.serializePaillierChallenge({ p: userToBackupPaillierChallenge })\n    );\n\n    const signShares: ECDSA.SignShareRT = await MPC.signShare(userXShare, userYShare);\n\n    const signConvertS21 = await MPC.signConvertStep1({\n      xShare: backupXShare,\n      yShare: backupYShare, // YShare corresponding to the other participant signerOne\n      kShare: signShares.kShare,\n    });\n    const signConvertS12 = await MPC.signConvertStep2({\n      aShare: signConvertS21.aShare,\n      wShare: signShares.wShare,\n    });\n    const signConvertS21_2 = await MPC.signConvertStep3({\n      muShare: signConvertS12.muShare,\n      bShare: signConvertS21.bShare,\n    });\n\n    const [signCombineOne, signCombineTwo] = [\n      MPC.signCombine({\n        gShare: signConvertS12.gShare,\n        signIndex: {\n          i: signConvertS12.muShare.i,\n          j: signConvertS12.muShare.j,\n        },\n      }),\n      MPC.signCombine({\n        gShare: signConvertS21_2.gShare,\n        signIndex: {\n          i: signConvertS21_2.signIndex.i,\n          j: signConvertS21_2.signIndex.j,\n        },\n      }),\n    ];\n\n    const MESSAGE = Buffer.from(txHex, 'hex');\n\n    const [signA, signB] = [\n      MPC.sign(MESSAGE, signCombineOne.oShare, signCombineTwo.dShare, createHash('sha256')),\n      MPC.sign(MESSAGE, signCombineTwo.oShare, signCombineOne.dShare, createHash('sha256')),\n    ];\n\n    return MPC.constructSignature([signA, signB]);\n  }\n}\n"]}
346
+ //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"cosmosCoin.js","sourceRoot":"","sources":["../../src/cosmosCoin.ts"],"names":[],"mappings":"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","sourcesContent":["import {\n  BaseCoin,\n  BaseTransaction,\n  BitGoBase,\n  ExplanationResult,\n  InvalidAddressError,\n  InvalidMemoIdError,\n  KeyPair,\n  MPCAlgorithm,\n  ParsedTransaction,\n  ParseTransactionOptions,\n  SignedTransaction,\n  SigningError,\n  SignTransactionOptions,\n  TransactionType,\n  UnexpectedAddressError,\n  VerifyAddressOptions,\n  VerifyTransactionOptions,\n} from '@bitgo-beta/sdk-core';\nimport { CoinFamily, BaseCoin as StaticsBaseCoin } from '@bitgo-beta/statics';\nimport { bip32 } from '@bitgo-beta/utxo-lib';\nimport { BigNumber } from 'bignumber.js';\nimport { createHash, Hash, randomBytes } from 'crypto';\nimport * as _ from 'lodash';\nimport * as querystring from 'querystring';\nimport * as request from 'superagent';\nimport * as url from 'url';\nimport { CosmosKeyPair } from './lib';\nimport utils from './lib/utils';\n\n/**\n * Cosmos accounts support memo Id based addresses\n */\ninterface AddressDetails {\n  address: string;\n  memoId?: string | undefined;\n}\n\n/**\n * Cosmos accounts support memo Id based addresses\n */\ninterface CosmosCoinSpecific {\n  rootAddress: string;\n}\n\nexport class CosmosCoin extends BaseCoin {\n  protected readonly _staticsCoin: Readonly<StaticsBaseCoin>;\n  protected constructor(bitgo: BitGoBase, staticsCoin?: Readonly<StaticsBaseCoin>) {\n    super(bitgo);\n\n    if (!staticsCoin) {\n      throw new Error('missing required constructor parameter staticsCoin');\n    }\n\n    this._staticsCoin = staticsCoin;\n  }\n\n  static createInstance(bitgo: BitGoBase, staticsCoin?: Readonly<StaticsBaseCoin>): BaseCoin {\n    return new CosmosCoin(bitgo, staticsCoin);\n  }\n\n  /**\n   * Creates an instance of TransactionBuilderFactory for the coin specific sdk\n   */\n  getBuilder(): any {\n    throw new Error('Method not implemented.');\n  }\n\n  /** @inheritDoc **/\n  getBaseFactor(): string | number {\n    return 1e6;\n  }\n\n  /** @inheritDoc **/\n  getChain(): string {\n    return this._staticsCoin.name;\n  }\n\n  /** @inheritDoc **/\n  getFamily(): CoinFamily {\n    return this._staticsCoin.family;\n  }\n\n  /** @inheritDoc **/\n  getFullName(): string {\n    return this._staticsCoin.fullName;\n  }\n\n  /** @inheritDoc */\n  supportsTss(): boolean {\n    return true;\n  }\n\n  /** @inheritDoc **/\n  getMPCAlgorithm(): MPCAlgorithm {\n    return 'ecdsa';\n  }\n\n  /** @inheritDoc **/\n  isValidPub(pub: string): boolean {\n    return utils.isValidPublicKey(pub);\n  }\n\n  /** @inheritDoc **/\n  isValidPrv(prv: string): boolean {\n    return utils.isValidPrivateKey(prv);\n  }\n\n  isValidAddress(address: string): boolean {\n    throw new Error('Method not implemented.');\n  }\n\n  /** @inheritDoc **/\n  async verifyTransaction(params: VerifyTransactionOptions): Promise<boolean> {\n    let totalAmount = new BigNumber(0);\n    const { txPrebuild, txParams } = params;\n    const rawTx = txPrebuild.txHex;\n    if (!rawTx) {\n      throw new Error('missing required tx prebuild property txHex');\n    }\n    const transaction = await this.getBuilder().from(rawTx).build();\n    const explainedTx = transaction.explainTransaction();\n\n    if (txParams.recipients && txParams.recipients.length > 0) {\n      const filteredRecipients = txParams.recipients?.map((recipient) => _.pick(recipient, ['address', 'amount']));\n      const filteredOutputs = explainedTx.outputs.map((output) => _.pick(output, ['address', 'amount']));\n\n      if (!_.isEqual(filteredOutputs, filteredRecipients)) {\n        throw new Error('Tx outputs does not match with expected txParams recipients');\n      }\n      // WithdrawDelegatorRewards transaction doesn't have amount\n      if (transaction.type !== TransactionType.StakingWithdraw) {\n        for (const recipients of txParams.recipients) {\n          totalAmount = totalAmount.plus(recipients.amount);\n        }\n        if (!totalAmount.isEqualTo(explainedTx.outputAmount)) {\n          throw new Error('Tx total amount does not match with expected total amount field');\n        }\n      }\n    }\n    return true;\n  }\n\n  /** @inheritDoc **/\n  async explainTransaction(options: { txHex: string }): Promise<ExplanationResult> {\n    if (!options.txHex) {\n      throw new Error('missing required txHex parameter');\n    }\n    try {\n      const transactionBuilder = this.getBuilder().from(options.txHex);\n      const transaction = await transactionBuilder.build();\n      return transaction.explainTransaction();\n    } catch (e) {\n      throw new Error('Invalid transaction: ' + e.message);\n    }\n  }\n\n  /**\n   * Sign a transaction with a single private key\n   * @param params parameters in the form of { txPrebuild: {txHex}, prv }\n   * @returns signed transaction in the form of { txHex }\n   */\n  async signTransaction(\n    params: SignTransactionOptions & { txPrebuild: { txHex: string }; prv: string }\n  ): Promise<SignedTransaction> {\n    const txHex = params?.txPrebuild?.txHex;\n    const privateKey = params?.prv;\n    if (!txHex) {\n      throw new SigningError('missing required txPrebuild parameter: params.txPrebuild.txHex');\n    }\n    if (!privateKey) {\n      throw new SigningError('missing required prv parameter: params.prv');\n    }\n    const txBuilder = this.getBuilder().from(params.txPrebuild.txHex);\n    txBuilder.sign({ key: params.prv });\n    const transaction: BaseTransaction = await txBuilder.build();\n    if (!transaction) {\n      throw new SigningError('Failed to build signed transaction');\n    }\n    const serializedTx = transaction.toBroadcastFormat();\n    return {\n      txHex: serializedTx,\n    };\n  }\n\n  /** @inheritDoc **/\n  async parseTransaction(params: ParseTransactionOptions & { txHex: string }): Promise<ParsedTransaction> {\n    const transactionExplanation = await this.explainTransaction({ txHex: params.txHex });\n    if (!transactionExplanation) {\n      throw new Error('Invalid transaction');\n    }\n\n    if (transactionExplanation.outputs.length <= 0) {\n      return {\n        inputs: [],\n        outputs: [],\n      };\n    }\n    const senderAddress = transactionExplanation.outputs[0].address;\n    const feeAmount = new BigNumber(transactionExplanation.fee.fee === '' ? '0' : transactionExplanation.fee.fee);\n    const inputs = [\n      {\n        address: senderAddress,\n        amount: new BigNumber(transactionExplanation.outputAmount).plus(feeAmount).toFixed(),\n      },\n    ];\n    const outputs = transactionExplanation.outputs.map((output) => {\n      return {\n        address: output.address,\n        amount: new BigNumber(output.amount).toFixed(),\n      };\n    });\n    return {\n      inputs,\n      outputs,\n    };\n  }\n\n  /**\n   * Get the public node url from the Environments constant we have defined\n   */\n  protected getPublicNodeUrl(): string {\n    throw new Error('Method not implemented.');\n  }\n\n  /**\n   * Get account number from public node\n   */\n  protected async getAccountFromNode(senderAddress: string): Promise<request.Response> {\n    const nodeUrl = this.getPublicNodeUrl();\n    const getAccountPath = 'cosmos/auth/v1beta1/accounts/';\n    const fullEndpoint = nodeUrl + getAccountPath + senderAddress;\n    try {\n      return await request.get(fullEndpoint).send();\n    } catch (e) {\n      console.debug(e);\n    }\n    throw new Error(`Unable to call endpoint ${getAccountPath + senderAddress} from node: ${nodeUrl}`);\n  }\n\n  /**\n   * Get balance from public node\n   */\n  protected async getBalanceFromNode(senderAddress: string): Promise<request.Response> {\n    const nodeUrl = this.getPublicNodeUrl();\n    const getBalancePath = 'cosmos/bank/v1beta1/balances/';\n    const fullEndpoint = nodeUrl + getBalancePath + senderAddress;\n    try {\n      return await request.get(fullEndpoint).send();\n    } catch (e) {\n      console.debug(e);\n    }\n    throw new Error(`Unable to call endpoint ${getBalancePath + senderAddress} from node: ${nodeUrl}`);\n  }\n\n  /**\n   * Get chain id from public node\n   */\n  protected async getChainIdFromNode(): Promise<request.Response> {\n    const nodeUrl = this.getPublicNodeUrl();\n    const getLatestBlockPath = 'cosmos/base/tendermint/v1beta1/blocks/latest';\n    const fullEndpoint = nodeUrl + getLatestBlockPath;\n    try {\n      return await request.get(fullEndpoint).send();\n    } catch (e) {\n      console.debug(e);\n    }\n    throw new Error(`Unable to call endpoint ${getLatestBlockPath} from node: ${nodeUrl}`);\n  }\n\n  /**\n   * Helper to fetch account balance\n   */\n  protected async getAccountBalance(senderAddress: string): Promise<string> {\n    const response = await this.getBalanceFromNode(senderAddress);\n    if (response.status !== 200) {\n      throw new Error('Account not found');\n    }\n    return response.body.balances[0].amount;\n  }\n\n  /**\n   * Helper to fetch chainId\n   */\n  protected async getChainId(): Promise<string> {\n    const response = await this.getChainIdFromNode();\n    if (response.status !== 200) {\n      throw new Error('Account not found');\n    }\n    return response.body.block.header.chain_id;\n  }\n\n  /**\n   * Helper to fetch account number\n   */\n  protected async getAccountDetails(senderAddress: string): Promise<string[]> {\n    const response = await this.getAccountFromNode(senderAddress);\n    if (response.status !== 200) {\n      throw new Error('Account not found');\n    }\n    return [response.body.account.account_number, response.body.account.sequence];\n  }\n\n  /** @inheritDoc **/\n  generateKeyPair(seed?: Buffer): KeyPair {\n    if (!seed) {\n      // An extended private key has both a normal 256 bit private key and a 256\n      // bit chain code, both of which must be random. 512 bits is therefore the\n      // maximum entropy and gives us maximum security against cracking.\n      seed = randomBytes(512 / 8);\n    }\n    const extendedKey = bip32.fromSeed(seed);\n    return {\n      pub: extendedKey.neutered().toBase58(),\n      prv: extendedKey.toBase58(),\n    };\n  }\n\n  /**\n   * Retrieves the address from a public key.\n   * @param {string} pubKey - The public key.\n   * @returns {string} The corresponding address.\n   */\n  getAddressFromPublicKey(pubKey: string): string {\n    return new CosmosKeyPair({ pub: pubKey }).getAddress();\n  }\n\n  /** @inheritDoc **/\n  async isWalletAddress(params: VerifyAddressOptions): Promise<boolean> {\n    const addressDetails = this.getAddressDetails(params.address);\n\n    if (!this.isValidAddress(addressDetails.address)) {\n      throw new InvalidAddressError(`invalid address: ${addressDetails.address}`);\n    }\n    const rootAddress = (params.coinSpecific as CosmosCoinSpecific).rootAddress;\n    if (addressDetails.address !== rootAddress) {\n      throw new UnexpectedAddressError(`address validation failure: ${addressDetails.address} vs ${rootAddress}`);\n    }\n    return true;\n  }\n\n  /**\n   * Retrieves the SHA256 hash function.\n   * @returns {Hash} The SHA256 hash function.\n   */\n  getHashFunction(): Hash {\n    return createHash('sha256');\n  }\n\n  /**\n   * Process address into address and memo id\n   *\n   * @param address the address\n   * @returns object containing address and memo id\n   */\n  getAddressDetails(address: string): AddressDetails {\n    const destinationDetails = url.parse(address);\n    const destinationAddress = destinationDetails.pathname || '';\n\n    // address doesn't have a memo id\n    if (destinationDetails.pathname === address) {\n      return {\n        address: address,\n        memoId: undefined,\n      };\n    }\n\n    if (!destinationDetails.query) {\n      throw new InvalidAddressError(`invalid address: ${address}`);\n    }\n\n    const queryDetails = querystring.parse(destinationDetails.query);\n    if (!queryDetails.memoId) {\n      // if there are more properties, the query details need to contain the memo id property\n      throw new InvalidAddressError(`invalid address: ${address}`);\n    }\n\n    if (Array.isArray(queryDetails.memoId)) {\n      throw new InvalidAddressError(\n        `memoId may only be given at most once, but found ${queryDetails.memoId.length} instances in address ${address}`\n      );\n    }\n\n    if (Array.isArray(queryDetails.memoId) && queryDetails.memoId.length !== 1) {\n      // valid addresses can only contain one memo id\n      throw new InvalidAddressError(`invalid address '${address}', must contain exactly one memoId`);\n    }\n\n    const [memoId] = _.castArray(queryDetails.memoId) || undefined;\n    if (!this.isValidMemoId(memoId)) {\n      throw new InvalidMemoIdError(`invalid address: '${address}', memoId is not valid`);\n    }\n\n    return {\n      address: destinationAddress,\n      memoId,\n    };\n  }\n\n  /**\n   * Return boolean indicating whether a memo id is valid\n   *\n   * @param memoId memo id\n   * @returns true if memo id is valid\n   */\n  isValidMemoId(memoId: string): boolean {\n    let memoIdNumber;\n    try {\n      memoIdNumber = new BigNumber(memoId);\n    } catch (e) {\n      return false;\n    }\n    return memoIdNumber.gte(0);\n  }\n}\n"]}
@@ -0,0 +1,13 @@
1
+ import { TransactionType } from '@bitgo-beta/sdk-core';
2
+ import { BaseCoin as CoinConfig } from '@bitgo-beta/statics';
3
+ import { DelegateOrUndelegeteMessage } from './iface';
4
+ import { CosmosTransactionBuilder } from './transactionBuilder';
5
+ import { CosmosUtils } from './utils';
6
+ export declare class StakingActivateBuilder extends CosmosTransactionBuilder {
7
+ protected _utils: CosmosUtils;
8
+ constructor(_coinConfig: Readonly<CoinConfig>, utils: CosmosUtils);
9
+ protected get transactionType(): TransactionType;
10
+ /** @inheritdoc */
11
+ messages(delegateMessages: DelegateOrUndelegeteMessage[]): this;
12
+ }
13
+ //# sourceMappingURL=StakingActivateBuilder.d.ts.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"StakingActivateBuilder.d.ts","sourceRoot":"","sources":["../../../src/lib/StakingActivateBuilder.ts"],"names":[],"mappings":"AAAA,OAAO,EAAE,eAAe,EAAE,MAAM,sBAAsB,CAAC;AACvD,OAAO,EAAE,QAAQ,IAAI,UAAU,EAAE,MAAM,qBAAqB,CAAC;AAG7D,OAAO,EAAE,2BAA2B,EAAE,MAAM,SAAS,CAAC;AACtD,OAAO,EAAE,wBAAwB,EAAE,MAAM,sBAAsB,CAAC;AAChE,OAAO,EAAE,WAAW,EAAE,MAAM,SAAS,CAAC;AAEtC,qBAAa,sBAAuB,SAAQ,wBAAwB;IAClE,SAAS,CAAC,MAAM,EAAE,WAAW,CAAC;gBAElB,WAAW,EAAE,QAAQ,CAAC,UAAU,CAAC,EAAE,KAAK,EAAE,WAAW;IAKjE,SAAS,KAAK,eAAe,IAAI,eAAe,CAE/C;IAED,kBAAkB;IAClB,QAAQ,CAAC,gBAAgB,EAAE,2BAA2B,EAAE,GAAG,IAAI;CAUhE"}
@@ -0,0 +1,28 @@
1
+ "use strict";
2
+ Object.defineProperty(exports, "__esModule", { value: true });
3
+ exports.StakingActivateBuilder = void 0;
4
+ const sdk_core_1 = require("@bitgo-beta/sdk-core");
5
+ const constants = require("./constants");
6
+ const transactionBuilder_1 = require("./transactionBuilder");
7
+ class StakingActivateBuilder extends transactionBuilder_1.CosmosTransactionBuilder {
8
+ constructor(_coinConfig, utils) {
9
+ super(_coinConfig, utils);
10
+ this._utils = utils;
11
+ }
12
+ get transactionType() {
13
+ return sdk_core_1.TransactionType.StakingActivate;
14
+ }
15
+ /** @inheritdoc */
16
+ messages(delegateMessages) {
17
+ this._messages = delegateMessages.map((delegateMessage) => {
18
+ this._utils.validateDelegateOrUndelegateMessage(delegateMessage);
19
+ return {
20
+ typeUrl: constants.delegateMsgTypeUrl,
21
+ value: delegateMessage,
22
+ };
23
+ });
24
+ return this;
25
+ }
26
+ }
27
+ exports.StakingActivateBuilder = StakingActivateBuilder;
28
+ //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiU3Rha2luZ0FjdGl2YXRlQnVpbGRlci5qcyIsInNvdXJjZVJvb3QiOiIiLCJzb3VyY2VzIjpbIi4uLy4uLy4uL3NyYy9saWIvU3Rha2luZ0FjdGl2YXRlQnVpbGRlci50cyJdLCJuYW1lcyI6W10sIm1hcHBpbmdzIjoiOzs7QUFBQSxtREFBdUQ7QUFHdkQseUNBQXlDO0FBRXpDLDZEQUFnRTtBQUdoRSxNQUFhLHNCQUF1QixTQUFRLDZDQUF3QjtJQUdsRSxZQUFZLFdBQWlDLEVBQUUsS0FBa0I7UUFDL0QsS0FBSyxDQUFDLFdBQVcsRUFBRSxLQUFLLENBQUMsQ0FBQztRQUMxQixJQUFJLENBQUMsTUFBTSxHQUFHLEtBQUssQ0FBQztJQUN0QixDQUFDO0lBRUQsSUFBYyxlQUFlO1FBQzNCLE9BQU8sMEJBQWUsQ0FBQyxlQUFlLENBQUM7SUFDekMsQ0FBQztJQUVELGtCQUFrQjtJQUNsQixRQUFRLENBQUMsZ0JBQStDO1FBQ3RELElBQUksQ0FBQyxTQUFTLEdBQUcsZ0JBQWdCLENBQUMsR0FBRyxDQUFDLENBQUMsZUFBZSxFQUFFLEVBQUU7WUFDeEQsSUFBSSxDQUFDLE1BQU0sQ0FBQyxtQ0FBbUMsQ0FBQyxlQUFlLENBQUMsQ0FBQztZQUNqRSxPQUFPO2dCQUNMLE9BQU8sRUFBRSxTQUFTLENBQUMsa0JBQWtCO2dCQUNyQyxLQUFLLEVBQUUsZUFBZTthQUN2QixDQUFDO1FBQ0osQ0FBQyxDQUFDLENBQUM7UUFDSCxPQUFPLElBQUksQ0FBQztJQUNkLENBQUM7Q0FDRjtBQXZCRCx3REF1QkMiLCJzb3VyY2VzQ29udGVudCI6WyJpbXBvcnQgeyBUcmFuc2FjdGlvblR5cGUgfSBmcm9tICdAYml0Z28tYmV0YS9zZGstY29yZSc7XG5pbXBvcnQgeyBCYXNlQ29pbiBhcyBDb2luQ29uZmlnIH0gZnJvbSAnQGJpdGdvLWJldGEvc3RhdGljcyc7XG5cbmltcG9ydCAqIGFzIGNvbnN0YW50cyBmcm9tICcuL2NvbnN0YW50cyc7XG5pbXBvcnQgeyBEZWxlZ2F0ZU9yVW5kZWxlZ2V0ZU1lc3NhZ2UgfSBmcm9tICcuL2lmYWNlJztcbmltcG9ydCB7IENvc21vc1RyYW5zYWN0aW9uQnVpbGRlciB9IGZyb20gJy4vdHJhbnNhY3Rpb25CdWlsZGVyJztcbmltcG9ydCB7IENvc21vc1V0aWxzIH0gZnJvbSAnLi91dGlscyc7XG5cbmV4cG9ydCBjbGFzcyBTdGFraW5nQWN0aXZhdGVCdWlsZGVyIGV4dGVuZHMgQ29zbW9zVHJhbnNhY3Rpb25CdWlsZGVyIHtcbiAgcHJvdGVjdGVkIF91dGlsczogQ29zbW9zVXRpbHM7XG5cbiAgY29uc3RydWN0b3IoX2NvaW5Db25maWc6IFJlYWRvbmx5PENvaW5Db25maWc+LCB1dGlsczogQ29zbW9zVXRpbHMpIHtcbiAgICBzdXBlcihfY29pbkNvbmZpZywgdXRpbHMpO1xuICAgIHRoaXMuX3V0aWxzID0gdXRpbHM7XG4gIH1cblxuICBwcm90ZWN0ZWQgZ2V0IHRyYW5zYWN0aW9uVHlwZSgpOiBUcmFuc2FjdGlvblR5cGUge1xuICAgIHJldHVybiBUcmFuc2FjdGlvblR5cGUuU3Rha2luZ0FjdGl2YXRlO1xuICB9XG5cbiAgLyoqIEBpbmhlcml0ZG9jICovXG4gIG1lc3NhZ2VzKGRlbGVnYXRlTWVzc2FnZXM6IERlbGVnYXRlT3JVbmRlbGVnZXRlTWVzc2FnZVtdKTogdGhpcyB7XG4gICAgdGhpcy5fbWVzc2FnZXMgPSBkZWxlZ2F0ZU1lc3NhZ2VzLm1hcCgoZGVsZWdhdGVNZXNzYWdlKSA9PiB7XG4gICAgICB0aGlzLl91dGlscy52YWxpZGF0ZURlbGVnYXRlT3JVbmRlbGVnYXRlTWVzc2FnZShkZWxlZ2F0ZU1lc3NhZ2UpO1xuICAgICAgcmV0dXJuIHtcbiAgICAgICAgdHlwZVVybDogY29uc3RhbnRzLmRlbGVnYXRlTXNnVHlwZVVybCxcbiAgICAgICAgdmFsdWU6IGRlbGVnYXRlTWVzc2FnZSxcbiAgICAgIH07XG4gICAgfSk7XG4gICAgcmV0dXJuIHRoaXM7XG4gIH1cbn1cbiJdfQ==
@@ -0,0 +1,13 @@
1
+ import { TransactionType } from '@bitgo-beta/sdk-core';
2
+ import { BaseCoin as CoinConfig } from '@bitgo-beta/statics';
3
+ import { DelegateOrUndelegeteMessage } from './iface';
4
+ import { CosmosTransactionBuilder } from './transactionBuilder';
5
+ import { CosmosUtils } from './utils';
6
+ export declare class StakingDeactivateBuilder extends CosmosTransactionBuilder {
7
+ protected _utils: CosmosUtils;
8
+ constructor(_coinConfig: Readonly<CoinConfig>, utils: CosmosUtils);
9
+ protected get transactionType(): TransactionType;
10
+ /** @inheritdoc */
11
+ messages(undelegateMessages: DelegateOrUndelegeteMessage[]): this;
12
+ }
13
+ //# sourceMappingURL=StakingDeactivateBuilder.d.ts.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"StakingDeactivateBuilder.d.ts","sourceRoot":"","sources":["../../../src/lib/StakingDeactivateBuilder.ts"],"names":[],"mappings":"AAAA,OAAO,EAAE,eAAe,EAAE,MAAM,sBAAsB,CAAC;AACvD,OAAO,EAAE,QAAQ,IAAI,UAAU,EAAE,MAAM,qBAAqB,CAAC;AAG7D,OAAO,EAAE,2BAA2B,EAAE,MAAM,SAAS,CAAC;AACtD,OAAO,EAAE,wBAAwB,EAAE,MAAM,sBAAsB,CAAC;AAChE,OAAO,EAAE,WAAW,EAAE,MAAM,SAAS,CAAC;AAEtC,qBAAa,wBAAyB,SAAQ,wBAAwB;IACpE,SAAS,CAAC,MAAM,EAAE,WAAW,CAAC;gBAElB,WAAW,EAAE,QAAQ,CAAC,UAAU,CAAC,EAAE,KAAK,EAAE,WAAW;IAKjE,SAAS,KAAK,eAAe,IAAI,eAAe,CAE/C;IAED,kBAAkB;IAClB,QAAQ,CAAC,kBAAkB,EAAE,2BAA2B,EAAE,GAAG,IAAI;CAUlE"}