@bitgo-beta/abstract-eth 1.0.2-beta.57 → 1.0.2-beta.570

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.
Files changed (57) hide show
  1. package/CHANGELOG.md +1307 -0
  2. package/dist/src/abstractEthLikeCoin.d.ts +10 -5
  3. package/dist/src/abstractEthLikeCoin.d.ts.map +1 -1
  4. package/dist/src/abstractEthLikeCoin.js +14 -11
  5. package/dist/src/abstractEthLikeNewCoins.d.ts +626 -0
  6. package/dist/src/abstractEthLikeNewCoins.d.ts.map +1 -0
  7. package/dist/src/abstractEthLikeNewCoins.js +1843 -0
  8. package/dist/src/ethLikeToken.d.ts +34 -4
  9. package/dist/src/ethLikeToken.d.ts.map +1 -1
  10. package/dist/src/ethLikeToken.js +281 -7
  11. package/dist/src/index.d.ts +2 -0
  12. package/dist/src/index.d.ts.map +1 -1
  13. package/dist/src/index.js +8 -2
  14. package/dist/src/lib/contractCall.d.ts +8 -0
  15. package/dist/src/lib/contractCall.d.ts.map +1 -0
  16. package/dist/src/lib/contractCall.js +17 -0
  17. package/dist/src/lib/iface.d.ts +132 -0
  18. package/dist/src/lib/iface.d.ts.map +1 -0
  19. package/dist/src/lib/iface.js +8 -0
  20. package/dist/src/lib/index.d.ts +15 -0
  21. package/dist/src/lib/index.d.ts.map +1 -0
  22. package/dist/src/lib/index.js +46 -0
  23. package/dist/src/lib/keyPair.d.ts +26 -0
  24. package/dist/src/lib/keyPair.d.ts.map +1 -0
  25. package/dist/src/lib/keyPair.js +66 -0
  26. package/dist/src/lib/transaction.d.ts +64 -0
  27. package/dist/src/lib/transaction.d.ts.map +1 -0
  28. package/dist/src/lib/transaction.js +137 -0
  29. package/dist/src/lib/transactionBuilder.d.ts +245 -0
  30. package/dist/src/lib/transactionBuilder.d.ts.map +1 -0
  31. package/dist/src/lib/transactionBuilder.js +726 -0
  32. package/dist/src/lib/transferBuilder.d.ts +70 -0
  33. package/dist/src/lib/transferBuilder.d.ts.map +1 -0
  34. package/dist/src/lib/transferBuilder.js +257 -0
  35. package/dist/src/lib/transferBuilders/baseNFTTransferBuilder.d.ts +54 -0
  36. package/dist/src/lib/transferBuilders/baseNFTTransferBuilder.d.ts.map +1 -0
  37. package/dist/src/lib/transferBuilders/baseNFTTransferBuilder.js +121 -0
  38. package/dist/src/lib/transferBuilders/index.d.ts +4 -0
  39. package/dist/src/lib/transferBuilders/index.d.ts.map +1 -0
  40. package/dist/src/lib/transferBuilders/index.js +20 -0
  41. package/dist/src/lib/transferBuilders/transferBuilderERC1155.d.ts +16 -0
  42. package/dist/src/lib/transferBuilders/transferBuilderERC1155.d.ts.map +1 -0
  43. package/dist/src/lib/transferBuilders/transferBuilderERC1155.js +93 -0
  44. package/dist/src/lib/transferBuilders/transferBuilderERC721.d.ts +15 -0
  45. package/dist/src/lib/transferBuilders/transferBuilderERC721.d.ts.map +1 -0
  46. package/dist/src/lib/transferBuilders/transferBuilderERC721.js +78 -0
  47. package/dist/src/lib/types.d.ts +39 -0
  48. package/dist/src/lib/types.d.ts.map +1 -0
  49. package/dist/src/lib/types.js +137 -0
  50. package/dist/src/lib/utils.d.ts +263 -0
  51. package/dist/src/lib/utils.d.ts.map +1 -0
  52. package/dist/src/lib/utils.js +681 -0
  53. package/dist/src/lib/walletUtil.d.ts +30 -0
  54. package/dist/src/lib/walletUtil.d.ts.map +1 -0
  55. package/dist/src/lib/walletUtil.js +33 -0
  56. package/dist/tsconfig.tsbuildinfo +1 -7924
  57. package/package.json +24 -9
@@ -0,0 +1,626 @@
1
+ /// <reference types="node" />
2
+ import { AddressCoinSpecific, BitGoBase, FeeEstimateOptions, FullySignedTransaction, HalfSignedTransaction, IWallet, KeyPair, ParsedTransaction, ParseTransactionOptions, PrebuildTransactionResult, PresignTransactionOptions as BasePresignTransactionOptions, Recipient, SignTransactionOptions as BaseSignTransactionOptions, TransactionParams, TransactionRecipient, TransactionPrebuild as BaseTransactionPrebuild, TypedData, VerifyAddressOptions as BaseVerifyAddressOptions, VerifyTransactionOptions, Wallet, BuildNftTransferDataOptions } from '@bitgo-beta/sdk-core';
3
+ import { BaseCoin as StaticsBaseCoin, EthereumNetwork as EthLikeNetwork } from '@bitgo-beta/statics';
4
+ import type * as EthLikeTxLib from '@ethereumjs/tx';
5
+ import type * as EthLikeCommon from '@ethereumjs/common';
6
+ import { AbstractEthLikeCoin } from './abstractEthLikeCoin';
7
+ /**
8
+ * The prebuilt hop transaction returned from the HSM
9
+ */
10
+ interface HopPrebuild {
11
+ tx: string;
12
+ id: string;
13
+ signature: string;
14
+ paymentId: string;
15
+ gasPrice: number;
16
+ gasLimit: number;
17
+ amount: number;
18
+ recipient: string;
19
+ nonce: number;
20
+ userReqSig: string;
21
+ gasPriceMax: number;
22
+ }
23
+ /**
24
+ * The extra parameters to send to platform build route for hop transactions
25
+ */
26
+ interface HopParams {
27
+ hopParams: {
28
+ gasPriceMax: number;
29
+ userReqSig: string;
30
+ paymentId: string;
31
+ };
32
+ gasLimit: number;
33
+ }
34
+ export interface EIP1559 {
35
+ maxPriorityFeePerGas: number;
36
+ maxFeePerGas: number;
37
+ }
38
+ export interface ReplayProtectionOptions {
39
+ chain: string | number;
40
+ hardfork: string;
41
+ }
42
+ export interface TransactionPrebuild extends BaseTransactionPrebuild {
43
+ hopTransaction?: HopPrebuild;
44
+ buildParams: {
45
+ recipients: Recipient[];
46
+ };
47
+ recipients: TransactionRecipient[];
48
+ nextContractSequenceId: number;
49
+ gasPrice: number;
50
+ gasLimit: number;
51
+ isBatch: boolean;
52
+ coin: string;
53
+ token?: string;
54
+ }
55
+ export interface SignFinalOptions {
56
+ txPrebuild: {
57
+ eip1559?: EIP1559;
58
+ replayProtectionOptions?: ReplayProtectionOptions;
59
+ gasPrice?: string;
60
+ gasLimit?: string;
61
+ recipients?: Recipient[];
62
+ halfSigned?: {
63
+ expireTime: number;
64
+ contractSequenceId: number;
65
+ backupKeyNonce?: number;
66
+ signature: string;
67
+ txHex?: string;
68
+ };
69
+ nextContractSequenceId?: number;
70
+ hopTransaction?: string;
71
+ backupKeyNonce?: number;
72
+ isBatch?: boolean;
73
+ txHex?: string;
74
+ expireTime?: number;
75
+ };
76
+ signingKeyNonce?: number;
77
+ walletContractAddress?: string;
78
+ prv: string;
79
+ recipients?: Recipient[];
80
+ }
81
+ export interface SignTransactionOptions extends BaseSignTransactionOptions, SignFinalOptions {
82
+ isLastSignature?: boolean;
83
+ expireTime?: number;
84
+ sequenceId?: number;
85
+ gasLimit?: number;
86
+ gasPrice?: number;
87
+ custodianTransactionId?: string;
88
+ }
89
+ export declare type SignedTransaction = HalfSignedTransaction | FullySignedTransaction;
90
+ export interface FeesUsed {
91
+ gasPrice: number;
92
+ gasLimit: number;
93
+ }
94
+ interface PrecreateBitGoOptions {
95
+ enterprise?: string;
96
+ newFeeAddress?: string;
97
+ }
98
+ export interface OfflineVaultTxInfo {
99
+ nextContractSequenceId?: string;
100
+ contractSequenceId?: string;
101
+ tx?: string;
102
+ txHex?: string;
103
+ userKey?: string;
104
+ backupKey?: string;
105
+ coin: string;
106
+ gasPrice: number;
107
+ gasLimit: number;
108
+ recipients: Recipient[];
109
+ walletContractAddress: string;
110
+ amount: string;
111
+ backupKeyNonce: number;
112
+ eip1559?: EIP1559;
113
+ replayProtectionOptions?: ReplayProtectionOptions;
114
+ halfSigned?: HalfSignedTransaction;
115
+ feesUsed?: FeesUsed;
116
+ isEvmBasedCrossChainRecovery?: boolean;
117
+ }
118
+ interface UnformattedTxInfo {
119
+ recipient: Recipient;
120
+ }
121
+ export interface RecoverOptions {
122
+ userKey: string;
123
+ backupKey: string;
124
+ walletPassphrase?: string;
125
+ walletContractAddress: string;
126
+ recoveryDestination: string;
127
+ krsProvider?: string;
128
+ gasPrice?: number;
129
+ gasLimit?: number;
130
+ eip1559?: EIP1559;
131
+ replayProtectionOptions?: ReplayProtectionOptions;
132
+ isTss?: boolean;
133
+ bitgoFeeAddress?: string;
134
+ bitgoDestinationAddress?: string;
135
+ tokenContractAddress?: string;
136
+ intendedChain?: string;
137
+ }
138
+ export declare type GetBatchExecutionInfoRT = {
139
+ values: [string[], string[]];
140
+ totalAmount: string;
141
+ };
142
+ export interface BuildTransactionParams {
143
+ to: string;
144
+ nonce?: number;
145
+ value: number;
146
+ data?: Buffer;
147
+ gasPrice?: number;
148
+ gasLimit?: number;
149
+ eip1559?: EIP1559;
150
+ replayProtectionOptions?: ReplayProtectionOptions;
151
+ }
152
+ export interface RecoveryInfo {
153
+ id: string;
154
+ tx: string;
155
+ backupKey?: string;
156
+ coin?: string;
157
+ }
158
+ export interface RecoverTokenTransaction {
159
+ halfSigned: {
160
+ recipient: Recipient;
161
+ expireTime: number;
162
+ contractSequenceId: number;
163
+ operationHash: string;
164
+ signature: string;
165
+ gasLimit: number;
166
+ gasPrice: number;
167
+ tokenContractAddress: string;
168
+ walletId: string;
169
+ };
170
+ }
171
+ export interface RecoverTokenOptions {
172
+ tokenContractAddress: string;
173
+ wallet: Wallet;
174
+ recipient: string;
175
+ broadcast?: boolean;
176
+ walletPassphrase?: string;
177
+ prv?: string;
178
+ }
179
+ export interface GetSendMethodArgsOptions {
180
+ recipient: Recipient;
181
+ expireTime: number;
182
+ contractSequenceId: number;
183
+ signature: string;
184
+ }
185
+ export interface SendMethodArgs {
186
+ name: string;
187
+ type: string;
188
+ value: any;
189
+ }
190
+ interface HopTransactionBuildOptions {
191
+ wallet: Wallet;
192
+ recipients: Recipient[];
193
+ walletPassphrase: string;
194
+ }
195
+ export interface BuildOptions {
196
+ hop?: boolean;
197
+ wallet?: Wallet;
198
+ recipients?: Recipient[];
199
+ walletPassphrase?: string;
200
+ [index: string]: unknown;
201
+ }
202
+ interface FeeEstimate {
203
+ gasLimitEstimate: number;
204
+ feeEstimate: number;
205
+ }
206
+ interface EthTransactionParams extends TransactionParams {
207
+ gasPrice?: number;
208
+ gasLimit?: number;
209
+ hopParams?: HopParams;
210
+ hop?: boolean;
211
+ prebuildTx?: PrebuildTransactionResult;
212
+ }
213
+ interface VerifyEthTransactionOptions extends VerifyTransactionOptions {
214
+ txPrebuild: TransactionPrebuild;
215
+ txParams: EthTransactionParams;
216
+ }
217
+ interface PresignTransactionOptions extends TransactionPrebuild, BasePresignTransactionOptions {
218
+ wallet: Wallet;
219
+ }
220
+ interface EthAddressCoinSpecifics extends AddressCoinSpecific {
221
+ forwarderVersion: number;
222
+ salt?: string;
223
+ }
224
+ export interface VerifyEthAddressOptions extends BaseVerifyAddressOptions {
225
+ baseAddress: string;
226
+ coinSpecific: EthAddressCoinSpecifics;
227
+ forwarderVersion: number;
228
+ }
229
+ export declare const optionalDeps: {
230
+ readonly ethAbi: any;
231
+ readonly ethUtil: any;
232
+ readonly EthTx: typeof EthLikeTxLib;
233
+ readonly EthCommon: typeof EthLikeCommon;
234
+ };
235
+ export declare abstract class AbstractEthLikeNewCoins extends AbstractEthLikeCoin {
236
+ static hopTransactionSalt: string;
237
+ protected readonly sendMethodName: 'sendMultiSig' | 'sendMultiSigToken';
238
+ readonly staticsCoin?: Readonly<StaticsBaseCoin>;
239
+ protected constructor(bitgo: BitGoBase, staticsCoin?: Readonly<StaticsBaseCoin>);
240
+ /**
241
+ * Method to return the coin's network object
242
+ * @returns {EthLikeNetwork | undefined}
243
+ */
244
+ getNetwork(): EthLikeNetwork | undefined;
245
+ /**
246
+ * Evaluates whether an address string is valid for this coin
247
+ * @param {string} address
248
+ * @returns {boolean} True if address is the valid ethlike adderss
249
+ */
250
+ isValidAddress(address: string): boolean;
251
+ /**
252
+ * Flag for sending data along with transactions
253
+ * @returns {boolean} True if okay to send tx data (ETH), false otherwise
254
+ */
255
+ transactionDataAllowed(): boolean;
256
+ /**
257
+ * Default expire time for a contract call (1 week)
258
+ * @returns {number} Time in seconds
259
+ */
260
+ getDefaultExpireTime(): number;
261
+ /**
262
+ * Method to get the custom chain common object based on params from recovery
263
+ * @param {number} chainId - the chain id of the custom chain
264
+ * @returns {EthLikeCommon.default}
265
+ */
266
+ static getCustomChainCommon(chainId: number): EthLikeCommon.default;
267
+ /**
268
+ * Gets correct Eth Common object based on params from either recovery or tx building
269
+ * @param {EIP1559} eip1559 - configs that specify whether we should construct an eip1559 tx
270
+ * @param {ReplayProtectionOptions} replayProtectionOptions - check if chain id supports replay protection
271
+ * @returns {EthLikeCommon.default}
272
+ */
273
+ private static getEthLikeCommon;
274
+ /**
275
+ * Method to build the tx object
276
+ * @param {BuildTransactionParams} params - params to build transaction
277
+ * @returns {EthLikeTxLib.FeeMarketEIP1559Transaction | EthLikeTxLib.Transaction}
278
+ */
279
+ static buildTransaction(params: BuildTransactionParams): EthLikeTxLib.FeeMarketEIP1559Transaction | EthLikeTxLib.Transaction;
280
+ /**
281
+ * Query explorer for the balance of an address
282
+ * @param {String} address - the ETHLike address
283
+ * @returns {BigNumber} address balance
284
+ */
285
+ queryAddressBalance(address: string): Promise<any>;
286
+ /**
287
+ * @param {Recipient[]} recipients - the recipients of the transaction
288
+ * @param {number} expireTime - the expire time of the transaction
289
+ * @param {number} contractSequenceId - the contract sequence id of the transaction
290
+ * @returns {string}
291
+ */
292
+ getOperationSha3ForExecuteAndConfirm(recipients: Recipient[], expireTime: number, contractSequenceId: number): string;
293
+ /**
294
+ * Get transfer operation for coin
295
+ * @param {Recipient} recipient - recipient info
296
+ * @param {number} expireTime - expiry time
297
+ * @param {number} contractSequenceId - sequence id
298
+ * @returns {Array} operation array
299
+ */
300
+ getOperation(recipient: Recipient, expireTime: number, contractSequenceId: number): (string | Buffer)[][];
301
+ /**
302
+ * Queries the contract (via explorer API) for the next sequence ID
303
+ * @param {String} address - address of the contract
304
+ * @returns {Promise<Number>} sequence ID
305
+ */
306
+ querySequenceId(address: string): Promise<number>;
307
+ /**
308
+ * Recover an unsupported token from a BitGo multisig wallet
309
+ * This builds a half-signed transaction, for which there will be an admin route to co-sign and broadcast. Optionally
310
+ * the user can set params.broadcast = true and the half-signed tx will be sent to BitGo for cosigning and broadcasting
311
+ * @param {RecoverTokenOptions} params
312
+ * @param {Wallet} params.wallet - the wallet to recover the token from
313
+ * @param {string} params.tokenContractAddress - the contract address of the unsupported token
314
+ * @param {string} params.recipient - the destination address recovered tokens should be sent to
315
+ * @param {string} params.walletPassphrase - the wallet passphrase
316
+ * @param {string} params.prv - the xprv
317
+ * @param {boolean} params.broadcast - if true, we will automatically submit the half-signed tx to BitGo for cosigning and broadcasting
318
+ * @returns {Promise<RecoverTokenTransaction>}
319
+ */
320
+ recoverToken(params: RecoverTokenOptions): Promise<RecoverTokenTransaction>;
321
+ /**
322
+ * Ensure either enterprise or newFeeAddress is passed, to know whether to create new key or use enterprise key
323
+ * @param {PrecreateBitGoOptions} params
324
+ * @param {string} params.enterprise {String} the enterprise id to associate with this key
325
+ * @param {string} params.newFeeAddress {Boolean} create a new fee address (enterprise not needed in this case)
326
+ * @returns {void}
327
+ */
328
+ preCreateBitGo(params: PrecreateBitGoOptions): void;
329
+ /**
330
+ * Queries public block explorer to get the next ETHLike coin's nonce that should be used for the given ETH address
331
+ * @param {string} address
332
+ * @returns {Promise<number>}
333
+ */
334
+ getAddressNonce(address: string): Promise<number>;
335
+ /**
336
+ * Helper function for recover()
337
+ * This transforms the unsigned transaction information into a format the BitGo offline vault expects
338
+ * @param {UnformattedTxInfo} txInfo - tx info
339
+ * @param {EthLikeTxLib.Transaction | EthLikeTxLib.FeeMarketEIP1559Transaction} ethTx - the ethereumjs tx object
340
+ * @param {string} userKey - the user's key
341
+ * @param {string} backupKey - the backup key
342
+ * @param {Buffer} gasPrice - gas price for the tx
343
+ * @param {number} gasLimit - gas limit for the tx
344
+ * @param {EIP1559} eip1559 - eip1559 params
345
+ * @param {ReplayProtectionOptions} replayProtectionOptions - replay protection options
346
+ * @returns {Promise<OfflineVaultTxInfo>}
347
+ */
348
+ formatForOfflineVault(txInfo: UnformattedTxInfo, ethTx: EthLikeTxLib.Transaction | EthLikeTxLib.FeeMarketEIP1559Transaction, userKey: string, backupKey: string, gasPrice: Buffer, gasLimit: number, eip1559?: EIP1559, replayProtectionOptions?: ReplayProtectionOptions): Promise<OfflineVaultTxInfo>;
349
+ /**
350
+ * Helper function for recover()
351
+ * This transforms the unsigned transaction information into a format the BitGo offline vault expects
352
+ * @param {UnformattedTxInfo} txInfo - tx info
353
+ * @param {EthLikeTxLib.Transaction | EthLikeTxLib.FeeMarketEIP1559Transaction} ethTx - the ethereumjs tx object
354
+ * @param {string} userKey - the user's key
355
+ * @param {string} backupKey - the backup key
356
+ * @param {Buffer} gasPrice - gas price for the tx
357
+ * @param {number} gasLimit - gas limit for the tx
358
+ * @param {number} backupKeyNonce - the nonce of the backup key address
359
+ * @param {EIP1559} eip1559 - eip1559 params
360
+ * @param {ReplayProtectionOptions} replayProtectionOptions - replay protection options
361
+ * @returns {Promise<OfflineVaultTxInfo>}
362
+ */
363
+ formatForOfflineVaultTSS(txInfo: UnformattedTxInfo, ethTx: EthLikeTxLib.Transaction | EthLikeTxLib.FeeMarketEIP1559Transaction, userKey: string, backupKey: string, gasPrice: Buffer, gasLimit: number, backupKeyNonce: number, eip1559?: EIP1559, replayProtectionOptions?: ReplayProtectionOptions): OfflineVaultTxInfo;
364
+ /**
365
+ * Check whether the gas price passed in by user are within our max and min bounds
366
+ * If they are not set, set them to the defaults
367
+ * @param {number} userGasPrice - user defined gas price
368
+ * @returns {number} the gas price to use for this transaction
369
+ */
370
+ setGasPrice(userGasPrice?: number): number;
371
+ /**
372
+ * Check whether gas limit passed in by user are within our max and min bounds
373
+ * If they are not set, set them to the defaults
374
+ * @param {number} userGasLimit user defined gas limit
375
+ * @returns {number} the gas limit to use for this transaction
376
+ */
377
+ setGasLimit(userGasLimit?: number): number;
378
+ /**
379
+ * Helper function for signTransaction for the rare case that SDK is doing the second signature
380
+ * Note: we are expecting this to be called from the offline vault
381
+ * @param {SignFinalOptions.txPrebuild} params.txPrebuild
382
+ * @param {string} params.prv
383
+ * @returns {{txHex: string}}
384
+ */
385
+ signFinalEthLike(params: SignFinalOptions): Promise<FullySignedTransaction>;
386
+ /**
387
+ * Assemble half-sign prebuilt transaction
388
+ * @param {SignTransactionOptions} params
389
+ */
390
+ signTransaction(params: SignTransactionOptions): Promise<SignedTransaction>;
391
+ /**
392
+ * Method to validate recovery params
393
+ * @param {RecoverOptions} params
394
+ * @returns {void}
395
+ */
396
+ validateRecoveryParams(params: RecoverOptions): void;
397
+ /**
398
+ * Method to sign tss recovery transaction
399
+ * @param {ECDSA.KeyCombined} userKeyCombined
400
+ * @param {ECDSA.KeyCombined} backupKeyCombined
401
+ * @param {string} txHex
402
+ * @param {Object} options
403
+ * @param {EcdsaTypes.SerializedNtilde} options.rangeProofChallenge
404
+ * @returns {Promise<ECDSAMethodTypes.Signature>}
405
+ */
406
+ private signRecoveryTSS;
407
+ /**
408
+ * Helper which combines key shares of user and backup
409
+ * @param {string} userPublicOrPrivateKeyShare
410
+ * @param {string} backupPrivateOrPublicKeyShare
411
+ * @param {string} walletPassphrase
412
+ * @returns {[ECDSAMethodTypes.KeyCombined, ECDSAMethodTypes.KeyCombined]}
413
+ */
414
+ private getKeyCombinedFromTssKeyShares;
415
+ /**
416
+ * Helper which Adds signatures to tx object and re-serializes tx
417
+ * @param {EthLikeCommon.default} ethCommon
418
+ * @param {EthLikeTxLib.FeeMarketEIP1559Transaction | EthLikeTxLib.Transaction} tx
419
+ * @param {ECDSAMethodTypes.Signature} signature
420
+ * @returns {EthLikeTxLib.FeeMarketEIP1559Transaction | EthLikeTxLib.Transaction}
421
+ */
422
+ private getSignedTxFromSignature;
423
+ /**
424
+ * Builds a funds recovery transaction without BitGo
425
+ * @param params
426
+ * @param {string} params.userKey - [encrypted] xprv
427
+ * @param {string} params.backupKey - [encrypted] xprv or xpub if the xprv is held by a KRS provider
428
+ * @param {string} params.walletPassphrase - used to decrypt userKey and backupKey
429
+ * @param {string} params.walletContractAddress - the ETH address of the wallet contract
430
+ * @param {string} params.krsProvider - necessary if backup key is held by KRS
431
+ * @param {string} params.recoveryDestination - target address to send recovered funds to
432
+ * @param {string} params.bitgoFeeAddress - wrong chain wallet fee address for evm based cross chain recovery txn
433
+ * @param {string} params.bitgoDestinationAddress - target bitgo address where fee will be sent for evm based cross chain recovery txn
434
+ */
435
+ recover(params: RecoverOptions): Promise<RecoveryInfo | OfflineVaultTxInfo>;
436
+ /**
437
+ * Builds a funds recovery transaction without BitGo for non-TSS transaction
438
+ * @param params
439
+ * @param {string} params.userKey [encrypted] xprv or xpub
440
+ * @param {string} params.backupKey [encrypted] xprv or xpub if the xprv is held by a KRS provider
441
+ * @param {string} params.walletPassphrase used to decrypt userKey and backupKey
442
+ * @param {string} params.walletContractAddress the EthLike address of the wallet contract
443
+ * @param {string} params.krsProvider necessary if backup key is held by KRS
444
+ * @param {string} params.recoveryDestination target address to send recovered funds to
445
+ * @param {string} params.bitgoFeeAddress wrong chain wallet fee address for evm based cross chain recovery txn
446
+ * @param {string} params.bitgoDestinationAddress target bitgo address where fee will be sent for evm based cross chain recovery txn
447
+ * @returns {Promise<RecoveryInfo | OfflineVaultTxInfo>}
448
+ */
449
+ protected recoverEthLike(params: RecoverOptions): Promise<RecoveryInfo | OfflineVaultTxInfo>;
450
+ /**
451
+ * Builds a unsigned (for cold, custody wallet) or
452
+ * half-signed (for hot wallet) evm cross chain recovery transaction with
453
+ * same expected arguments as recover method.
454
+ * This helps recover funds from evm based wrong chain.
455
+ * @param {RecoverOptions} params
456
+ * @returns {Promise<RecoveryInfo | OfflineVaultTxInfo>}
457
+ */
458
+ protected recoverEthLikeforEvmBasedRecovery(params: RecoverOptions): Promise<RecoveryInfo | OfflineVaultTxInfo>;
459
+ /**
460
+ * Query explorer for the balance of an address for a token
461
+ * @param {string} tokenContractAddress - address where the token smart contract is hosted
462
+ * @param {string} walletContractAddress - address of the wallet
463
+ * @returns {BigNumber} token balaance in base units
464
+ */
465
+ queryAddressTokenBalance(tokenContractAddress: string, walletContractAddress: string): Promise<any>;
466
+ recoverEthLikeTokenforEvmBasedRecovery(params: RecoverOptions, bitgoFeeAddressNonce: number, gasLimit: any, gasPrice: any, userKey: any, userSigningKey: any): Promise<OfflineVaultTxInfo>;
467
+ /**
468
+ * Validate evm based cross chain recovery params
469
+ * @param params {RecoverOptions}
470
+ * @returns {void}
471
+ */
472
+ validateEvmBasedRecoveryParams(params: RecoverOptions): void;
473
+ /**
474
+ * Return types, values, and total amount in wei to send in a batch transaction, using the method signature
475
+ * `distributeBatch(address[], uint256[])`
476
+ * @param {Recipient[]} recipients - transaction recipients
477
+ * @returns {GetBatchExecutionInfoRT} information needed to execute the batch transaction
478
+ */
479
+ getBatchExecutionInfo(recipients: Recipient[]): GetBatchExecutionInfoRT;
480
+ /**
481
+ * Get the data required to make an ETH function call defined by the given types and values
482
+ *
483
+ * @param {string} functionName - The name of the function being called, e.g. transfer
484
+ * @param types The types of the function call in order
485
+ * @param values The values of the function call in order
486
+ * @return {Buffer} The combined data for the function call
487
+ */
488
+ getMethodCallData: (functionName: any, types: any, values: any) => Buffer;
489
+ /**
490
+ * Build arguments to call the send method on the wallet contract
491
+ * @param txInfo
492
+ */
493
+ getSendMethodArgs(txInfo: GetSendMethodArgsOptions): SendMethodArgs[];
494
+ /**
495
+ * Recovers a tx with TSS key shares
496
+ * same expected arguments as recover method, but with TSS key shares
497
+ */
498
+ protected recoverTSS(params: RecoverOptions): Promise<RecoveryInfo | OfflineVaultTxInfo>;
499
+ recoveryBlockchainExplorerQuery(query: Record<string, string>): Promise<any>;
500
+ /**
501
+ * Creates the extra parameters needed to build a hop transaction
502
+ * @param buildParams The original build parameters
503
+ * @returns extra parameters object to merge with the original build parameters object and send to the platform
504
+ */
505
+ createHopTransactionParams(buildParams: HopTransactionBuildOptions): Promise<HopParams>;
506
+ /**
507
+ * Validates that the hop prebuild from the HSM is valid and correct
508
+ * @param {IWallet} wallet - The wallet that the prebuild is for
509
+ * @param {HopPrebuild} hopPrebuild - The prebuild to validate
510
+ * @param {Object} originalParams - The original parameters passed to prebuildTransaction
511
+ * @param {Recipient[]} originalParams.recipients - The original recipients array
512
+ * @returns {void}
513
+ * @throws Error if The prebuild is invalid
514
+ */
515
+ validateHopPrebuild(wallet: IWallet, hopPrebuild: HopPrebuild, originalParams?: {
516
+ recipients: Recipient[];
517
+ }): Promise<void>;
518
+ /**
519
+ * Gets the hop digest for the user to sign. This is validated in the HSM to prove that the user requested this tx
520
+ * @param {string[]} paramsArr - The parameters to hash together for the digest
521
+ * @returns {Buffer}
522
+ */
523
+ private static getHopDigest;
524
+ /**
525
+ * Modify prebuild before sending it to the server. Add things like hop transaction params
526
+ * @param {BuildOptions} buildParams - The whitelisted parameters for this prebuild
527
+ * @param {boolean} buildParams.hop - True if this should prebuild a hop tx, else false
528
+ * @param {Recipient[]} buildParams.recipients - The recipients array of this transaction
529
+ * @param {Wallet} buildParams.wallet - The wallet sending this tx
530
+ * @param {string} buildParams.walletPassphrase - the passphrase for this wallet
531
+ * @returns {Promise<BuildOptions>}
532
+ */
533
+ getExtraPrebuildParams(buildParams: BuildOptions): Promise<BuildOptions>;
534
+ /**
535
+ * Modify prebuild after receiving it from the server. Add things like nlocktime
536
+ * @param {TransactionPrebuild} params - The prebuild to modify
537
+ * @returns {TransactionPrebuild} The modified prebuild
538
+ */
539
+ postProcessPrebuild(params: TransactionPrebuild): Promise<TransactionPrebuild>;
540
+ /**
541
+ * Coin-specific things done before signing a transaction, i.e. verification
542
+ * @param {PresignTransactionOptions} params
543
+ * @returns {Promise<PresignTransactionOptions>}
544
+ */
545
+ presignTransaction(params: PresignTransactionOptions): Promise<PresignTransactionOptions>;
546
+ /**
547
+ * Fetch fee estimate information from the server
548
+ * @param {Object} params - The params passed into the function
549
+ * @param {boolean} [params.hop] - True if we should estimate fee for a hop transaction
550
+ * @param {string} [params.recipient] - The recipient of the transaction to estimate a send to
551
+ * @param {string} [params.data] - The ETH tx data to estimate a send for
552
+ * @returns {Object} The fee info returned from the server
553
+ */
554
+ feeEstimate(params: FeeEstimateOptions): Promise<FeeEstimate>;
555
+ /**
556
+ * Generate secp256k1 key pair
557
+ *
558
+ * @param {Buffer} seed
559
+ * @returns {KeyPair} object with generated pub and prv
560
+ */
561
+ generateKeyPair(seed: Buffer): KeyPair;
562
+ parseTransaction(params: ParseTransactionOptions): Promise<ParsedTransaction>;
563
+ /**
564
+ * Make sure an address is a wallet address and throw an error if it's not.
565
+ * @param {Object} params
566
+ * @param {string} params.address - The derived address string on the network
567
+ * @param {Object} params.coinSpecific - Coin-specific details for the address such as a forwarderVersion
568
+ * @param {string} params.baseAddress - The base address of the wallet on the network
569
+ * @throws {InvalidAddressError}
570
+ * @throws {InvalidAddressVerificationObjectPropertyError}
571
+ * @throws {UnexpectedAddressError}
572
+ * @returns {boolean} True iff address is a wallet address
573
+ */
574
+ isWalletAddress(params: VerifyEthAddressOptions): Promise<boolean>;
575
+ /**
576
+ *
577
+ * @param {TransactionPrebuild} txPrebuild
578
+ * @returns {boolean}
579
+ */
580
+ verifyCoin(txPrebuild: TransactionPrebuild): boolean;
581
+ /**
582
+ * Verify if a tss transaction is valid
583
+ *
584
+ * @param {VerifyEthTransactionOptions} params
585
+ * @param {TransactionParams} params.txParams - params object passed to send
586
+ * @param {TransactionPrebuild} params.txPrebuild - prebuild object returned by server
587
+ * @param {Wallet} params.wallet - Wallet object to obtain keys to verify against
588
+ * @returns {boolean}
589
+ */
590
+ verifyTssTransaction(params: VerifyEthTransactionOptions): boolean;
591
+ /**
592
+ * Verify that a transaction prebuild complies with the original intention
593
+ *
594
+ * @param {VerifyEthTransactionOptions} params
595
+ * @param {TransactionParams} params.txParams - params object passed to send
596
+ * @param {TransactionPrebuild} params.txPrebuild - prebuild object returned by server
597
+ * @param {Wallet} params.wallet - Wallet object to obtain keys to verify against
598
+ * @returns {boolean}
599
+ */
600
+ verifyTransaction(params: VerifyEthTransactionOptions): Promise<boolean>;
601
+ /**
602
+ * Check if address is valid eth address
603
+ * @param address
604
+ * @returns {boolean}
605
+ */
606
+ private isETHAddress;
607
+ /**
608
+ * Transform message to accommodate specific blockchain requirements.
609
+ * @param {string} message - the message to prepare
610
+ * @return {string} the prepared message.
611
+ */
612
+ encodeMessage(message: string): string;
613
+ /**
614
+ * Transform the Typed data to accomodate the blockchain requirements (EIP-712)
615
+ * @param {TypedData} typedData - the typed data to prepare
616
+ * @return {Buffer} a buffer of the result
617
+ */
618
+ encodeTypedData(typedData: TypedData): Buffer;
619
+ /**
620
+ * Build the data to transfer an ERC-721 or ERC-1155 token to another address
621
+ * @param params
622
+ */
623
+ buildNftTransferData(params: BuildNftTransferDataOptions): string;
624
+ }
625
+ export {};
626
+ //# sourceMappingURL=abstractEthLikeNewCoins.d.ts.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"abstractEthLikeNewCoins.d.ts","sourceRoot":"","sources":["../../src/abstractEthLikeNewCoins.ts"],"names":[],"mappings":"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"}