@bitgo-beta/sdk-coin-hbar 2.0.73-alpha.11 → 2.0.73-alpha.110

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 (60) hide show
  1. package/.mocharc.yml +1 -1
  2. package/CHANGELOG.md +139 -0
  3. package/package.json +9 -9
  4. package/dist/src/hbar.d.ts +0 -168
  5. package/dist/src/hbar.d.ts.map +0 -1
  6. package/dist/src/hbar.js +0 -483
  7. package/dist/src/hbarToken.d.ts +0 -21
  8. package/dist/src/hbarToken.d.ts.map +0 -1
  9. package/dist/src/hbarToken.js +0 -58
  10. package/dist/src/index.d.ts +0 -6
  11. package/dist/src/index.d.ts.map +0 -1
  12. package/dist/src/index.js +0 -22
  13. package/dist/src/lib/coinTransferBuilder.d.ts +0 -47
  14. package/dist/src/lib/coinTransferBuilder.d.ts.map +0 -1
  15. package/dist/src/lib/coinTransferBuilder.js +0 -159
  16. package/dist/src/lib/constants.d.ts +0 -8
  17. package/dist/src/lib/constants.d.ts.map +0 -1
  18. package/dist/src/lib/constants.js +0 -12
  19. package/dist/src/lib/iface.d.ts +0 -50
  20. package/dist/src/lib/iface.d.ts.map +0 -1
  21. package/dist/src/lib/iface.js +0 -3
  22. package/dist/src/lib/index.d.ts +0 -10
  23. package/dist/src/lib/index.d.ts.map +0 -1
  24. package/dist/src/lib/index.js +0 -53
  25. package/dist/src/lib/keyPair.d.ts +0 -24
  26. package/dist/src/lib/keyPair.d.ts.map +0 -1
  27. package/dist/src/lib/keyPair.js +0 -70
  28. package/dist/src/lib/tokenAssociateBuilder.d.ts +0 -38
  29. package/dist/src/lib/tokenAssociateBuilder.d.ts.map +0 -1
  30. package/dist/src/lib/tokenAssociateBuilder.js +0 -107
  31. package/dist/src/lib/tokenTransferBuilder.d.ts +0 -25
  32. package/dist/src/lib/tokenTransferBuilder.d.ts.map +0 -1
  33. package/dist/src/lib/tokenTransferBuilder.js +0 -130
  34. package/dist/src/lib/transaction.d.ts +0 -106
  35. package/dist/src/lib/transaction.d.ts.map +0 -1
  36. package/dist/src/lib/transaction.js +0 -330
  37. package/dist/src/lib/transactionBuilder.d.ts +0 -111
  38. package/dist/src/lib/transactionBuilder.d.ts.map +0 -1
  39. package/dist/src/lib/transactionBuilder.js +0 -284
  40. package/dist/src/lib/transactionBuilderFactory.d.ts +0 -47
  41. package/dist/src/lib/transactionBuilderFactory.d.ts.map +0 -1
  42. package/dist/src/lib/transactionBuilderFactory.js +0 -88
  43. package/dist/src/lib/transferBuilder.d.ts +0 -24
  44. package/dist/src/lib/transferBuilder.d.ts.map +0 -1
  45. package/dist/src/lib/transferBuilder.js +0 -55
  46. package/dist/src/lib/utils.d.ts +0 -210
  47. package/dist/src/lib/utils.d.ts.map +0 -1
  48. package/dist/src/lib/utils.js +0 -481
  49. package/dist/src/lib/walletInitializationBuilder.d.ts +0 -28
  50. package/dist/src/lib/walletInitializationBuilder.d.ts.map +0 -1
  51. package/dist/src/lib/walletInitializationBuilder.js +0 -124
  52. package/dist/src/register.d.ts +0 -3
  53. package/dist/src/register.d.ts.map +0 -1
  54. package/dist/src/register.js +0 -15
  55. package/dist/src/seedValidator.d.ts +0 -31
  56. package/dist/src/seedValidator.d.ts.map +0 -1
  57. package/dist/src/seedValidator.js +0 -103
  58. package/dist/src/thbar.d.ts +0 -14
  59. package/dist/src/thbar.d.ts.map +0 -1
  60. package/dist/src/thbar.js +0 -17
package/dist/src/hbar.js DELETED
@@ -1,483 +0,0 @@
1
- "use strict";
2
- var __createBinding = (this && this.__createBinding) || (Object.create ? (function(o, m, k, k2) {
3
- if (k2 === undefined) k2 = k;
4
- var desc = Object.getOwnPropertyDescriptor(m, k);
5
- if (!desc || ("get" in desc ? !m.__esModule : desc.writable || desc.configurable)) {
6
- desc = { enumerable: true, get: function() { return m[k]; } };
7
- }
8
- Object.defineProperty(o, k2, desc);
9
- }) : (function(o, m, k, k2) {
10
- if (k2 === undefined) k2 = k;
11
- o[k2] = m[k];
12
- }));
13
- var __setModuleDefault = (this && this.__setModuleDefault) || (Object.create ? (function(o, v) {
14
- Object.defineProperty(o, "default", { enumerable: true, value: v });
15
- }) : function(o, v) {
16
- o["default"] = v;
17
- });
18
- var __importStar = (this && this.__importStar) || (function () {
19
- var ownKeys = function(o) {
20
- ownKeys = Object.getOwnPropertyNames || function (o) {
21
- var ar = [];
22
- for (var k in o) if (Object.prototype.hasOwnProperty.call(o, k)) ar[ar.length] = k;
23
- return ar;
24
- };
25
- return ownKeys(o);
26
- };
27
- return function (mod) {
28
- if (mod && mod.__esModule) return mod;
29
- var result = {};
30
- if (mod != null) for (var k = ownKeys(mod), i = 0; i < k.length; i++) if (k[i] !== "default") __createBinding(result, mod, k[i]);
31
- __setModuleDefault(result, mod);
32
- return result;
33
- };
34
- })();
35
- Object.defineProperty(exports, "__esModule", { value: true });
36
- exports.Hbar = void 0;
37
- /**
38
- * @prettier
39
- */
40
- const statics_1 = require("@bitgo-beta/statics");
41
- const sdk_core_1 = require("@bitgo-beta/sdk-core");
42
- const bignumber_js_1 = require("bignumber.js");
43
- const stellar = __importStar(require("stellar-sdk"));
44
- const seedValidator_1 = require("./seedValidator");
45
- const lib_1 = require("./lib");
46
- const Utils = __importStar(require("./lib/utils"));
47
- const _ = __importStar(require("lodash"));
48
- const sdk_1 = require("@hashgraph/sdk");
49
- const keyPair_1 = require("./lib/keyPair");
50
- class Hbar extends sdk_core_1.BaseCoin {
51
- constructor(bitgo, staticsCoin) {
52
- super(bitgo);
53
- if (!staticsCoin) {
54
- throw new Error('missing required constructor parameter staticsCoin');
55
- }
56
- this._staticsCoin = staticsCoin;
57
- }
58
- getChain() {
59
- return this._staticsCoin.name;
60
- }
61
- getFamily() {
62
- return this._staticsCoin.family;
63
- }
64
- getFullName() {
65
- return this._staticsCoin.fullName;
66
- }
67
- getBaseFactor() {
68
- return Math.pow(10, this._staticsCoin.decimalPlaces);
69
- }
70
- static createInstance(bitgo, staticsCoin) {
71
- return new Hbar(bitgo, staticsCoin);
72
- }
73
- /**
74
- * Flag for sending value of 0
75
- * @returns {boolean} True if okay to send 0 value, false otherwise
76
- */
77
- valuelessTransferAllowed() {
78
- return false;
79
- }
80
- /**
81
- * Checks if this is a valid base58 or hex address
82
- * @param address
83
- */
84
- isValidAddress(address) {
85
- try {
86
- return Utils.isValidAddressWithPaymentId(address);
87
- }
88
- catch (e) {
89
- return false;
90
- }
91
- }
92
- /** inheritdoc */
93
- deriveKeyWithSeed() {
94
- throw new sdk_core_1.NotSupported('method deriveKeyWithSeed not supported for eddsa curve');
95
- }
96
- /** inheritdoc */
97
- generateKeyPair(seed) {
98
- const keyPair = seed ? new lib_1.KeyPair({ seed }) : new lib_1.KeyPair();
99
- const keys = keyPair.getKeys();
100
- if (!keys.prv) {
101
- throw new Error('Keypair generation failed to generate a prv');
102
- }
103
- return {
104
- pub: keys.pub,
105
- prv: keys.prv,
106
- };
107
- }
108
- /** inheritdoc */
109
- generateRootKeyPair(seed) {
110
- const keyPair = seed ? new lib_1.KeyPair({ seed }) : new lib_1.KeyPair();
111
- const keys = keyPair.getKeys(true);
112
- if (!keys.prv) {
113
- throw new Error('Missing prv in key generation.');
114
- }
115
- return { prv: keys.prv + keys.pub, pub: keys.pub };
116
- }
117
- async parseTransaction(params) {
118
- return {};
119
- }
120
- /**
121
- * Check if address is valid, then make sure it matches the base address.
122
- *
123
- * @param {VerifyAddressOptions} params
124
- * @param {String} params.address - the address to verify
125
- * @param {String} params.baseAddress - the base address from the wallet
126
- */
127
- async isWalletAddress(params) {
128
- const { address, baseAddress } = params;
129
- return Utils.isSameBaseAddress(address, baseAddress);
130
- }
131
- async verifyTransaction(params) {
132
- // asset name to transfer amount map
133
- const coinConfig = statics_1.coins.get(this.getChain());
134
- const { txParams: txParams, txPrebuild: txPrebuild, memo: memo } = params;
135
- const transaction = new lib_1.Transaction(coinConfig);
136
- if (!txPrebuild.txHex) {
137
- throw new Error('missing required tx prebuild property txHex');
138
- }
139
- transaction.fromRawTransaction(txPrebuild.txHex);
140
- const explainTxParams = {
141
- txHex: txPrebuild.txHex,
142
- feeInfo: txPrebuild.feeInfo,
143
- memo: memo,
144
- };
145
- const explainedTx = await this.explainTransaction(explainTxParams);
146
- if (!txParams.recipients) {
147
- throw new Error('missing required tx params property recipients');
148
- }
149
- // for enabletoken, recipient output amount is 0
150
- const recipients = txParams.recipients.map((recipient) => ({
151
- ...recipient,
152
- amount: txParams.type === 'enabletoken' ? '0' : recipient.amount,
153
- }));
154
- if (coinConfig.isToken) {
155
- recipients.forEach((recipient) => {
156
- if (recipient.tokenName !== undefined && recipient.tokenName !== coinConfig.name) {
157
- throw new Error('Incorrect token name specified in recipients');
158
- }
159
- recipient.tokenName = coinConfig.name;
160
- });
161
- }
162
- // verify recipients from params and explainedTx
163
- const filteredRecipients = recipients?.map((recipient) => _.pick(recipient, ['address', 'amount', 'tokenName']));
164
- const filteredOutputs = explainedTx.outputs.map((output) => _.pick(output, ['address', 'amount', 'tokenName']));
165
- if (!_.isEqual(filteredOutputs, filteredRecipients)) {
166
- throw new Error('Tx outputs does not match with expected txParams recipients');
167
- }
168
- return true;
169
- }
170
- /**
171
- * Assemble keychain and half-sign prebuilt transaction
172
- *
173
- * @param params
174
- * @param params.txPrebuild {Object} prebuild object returned by platform
175
- * @param params.prv {String} user prv
176
- * @returns Promise<SignedTransaction>
177
- */
178
- async signTransaction(params) {
179
- const factory = this.getBuilderFactory();
180
- const txBuilder = factory.from(params.txPrebuild.txHex);
181
- txBuilder.sign({ key: params.prv });
182
- const transaction = await txBuilder.build();
183
- if (!transaction) {
184
- throw new Error('Invalid messaged passed to signMessage');
185
- }
186
- const response = {
187
- txHex: transaction.toBroadcastFormat(),
188
- };
189
- return transaction.signature.length >= 2 ? response : { halfSigned: response };
190
- }
191
- /**
192
- * Sign message with private key
193
- *
194
- * @param key
195
- * @param message
196
- * @return {Buffer} A signature over the given message using the given key
197
- */
198
- async signMessage(key, message) {
199
- const msg = Buffer.isBuffer(message) ? message.toString('utf8') : message;
200
- // reconstitute keys and sign
201
- return Buffer.from(new lib_1.KeyPair({ prv: key.prv }).signMessage(msg));
202
- }
203
- /**
204
- * Builds a funds recovery transaction without BitGo.
205
- * We need to do three queries during this:
206
- * 1) Node query - how much money is in the account
207
- * 2) Build transaction - build our transaction for the amount
208
- * 3) Send signed build - send our signed build to a public node
209
- * @param params
210
- */
211
- async recover(params) {
212
- const isUnsignedSweep = (params.backupKey.startsWith(keyPair_1.PUBLIC_KEY_PREFIX) && params.userKey.startsWith(keyPair_1.PUBLIC_KEY_PREFIX)) ||
213
- (Utils.isValidPublicKey(params.userKey) && Utils.isValidPublicKey(params.backupKey));
214
- // Validate the root address
215
- if (!this.isValidAddress(params.rootAddress)) {
216
- throw new Error('invalid rootAddress, got: ' + params.rootAddress);
217
- }
218
- // Validate the destination address
219
- if (!this.isValidAddress(params.recoveryDestination)) {
220
- throw new Error('invalid recoveryDestination, got: ' + params.recoveryDestination);
221
- }
222
- // Validate nodeId
223
- if (params.nodeId && !Utils.isValidAddress(params.nodeId)) {
224
- throw new Error('invalid nodeId, got: ' + params.nodeId);
225
- }
226
- // validate fee
227
- if (params.maxFee && !Utils.isValidAmount(params.maxFee)) {
228
- throw new Error('invalid maxFee, got: ' + params.maxFee);
229
- }
230
- // validate startTime
231
- if (params.startTime) {
232
- Utils.validateStartTime(params.startTime);
233
- }
234
- if (isUnsignedSweep && !params.startTime) {
235
- throw new Error('start time is required for unsigned sweep');
236
- }
237
- if (!isUnsignedSweep && !params.walletPassphrase) {
238
- throw new Error('walletPassphrase is required for non-bitgo recovery');
239
- }
240
- let userPrv;
241
- let backUp;
242
- if (!isUnsignedSweep) {
243
- try {
244
- userPrv = this.bitgo.decrypt({ input: params.userKey, password: params.walletPassphrase });
245
- backUp = this.bitgo.decrypt({ input: params.backupKey, password: params.walletPassphrase });
246
- }
247
- catch (e) {
248
- throw new Error('unable to decrypt userKey or backupKey with the walletPassphrase provided, got error: ' + e.message);
249
- }
250
- }
251
- // validate userKey for unsigned sweep
252
- if (isUnsignedSweep && !Utils.isValidPublicKey(params.userKey)) {
253
- throw new Error('invalid userKey, got: ' + params.userKey);
254
- }
255
- // validate backupKey for unsigned sweep
256
- if (isUnsignedSweep && !Utils.isValidPublicKey(params.backupKey)) {
257
- throw new Error('invalid backupKey, got: ' + params.backupKey);
258
- }
259
- const { address: destinationAddress, memoId } = Utils.getAddressDetails(params.recoveryDestination);
260
- const nodeId = params.nodeId ? params.nodeId : '0.0.3';
261
- const client = this.getHbarClient();
262
- const balance = await this.getAccountBalance(params.rootAddress, client);
263
- const fee = params.maxFee ? params.maxFee : '10000000'; // default fee to 1 hbar
264
- const nativeBalance = sdk_1.Hbar.fromString(balance.hbars).toTinybars().toString();
265
- const spendableAmount = new bignumber_js_1.BigNumber(nativeBalance).minus(fee);
266
- let txBuilder;
267
- if (!params.tokenId) {
268
- if (spendableAmount.isZero() || spendableAmount.isNegative()) {
269
- throw new Error(`Insufficient balance to recover, got balance: ${nativeBalance} fee: ${fee}`);
270
- }
271
- txBuilder = this.getBuilderFactory().getTransferBuilder();
272
- txBuilder.send({ address: destinationAddress, amount: spendableAmount.toString() });
273
- }
274
- else {
275
- if (spendableAmount.isNegative()) {
276
- throw new Error(`Insufficient native balance to recover tokens, got native balance: ${nativeBalance} fee: ${fee}`);
277
- }
278
- const tokenBalance = balance.tokens.find((token) => token.tokenId === params.tokenId);
279
- const token = Utils.getHederaTokenNameFromId(params.tokenId);
280
- if (!token) {
281
- throw new Error(`Unsupported token: ${params.tokenId}`);
282
- }
283
- if (!tokenBalance || new bignumber_js_1.BigNumber(tokenBalance.balance).isZero()) {
284
- throw new Error(`Insufficient balance to recover token: ${params.tokenId} for account: ${params.rootAddress}`);
285
- }
286
- txBuilder = this.getBuilderFactory().getTokenTransferBuilder();
287
- txBuilder.send({ address: destinationAddress, amount: tokenBalance.balance, tokenName: token.name });
288
- }
289
- txBuilder.node({ nodeId });
290
- txBuilder.fee({ fee });
291
- txBuilder.source({ address: params.rootAddress });
292
- txBuilder.validDuration(180);
293
- if (memoId) {
294
- txBuilder.memo(memoId);
295
- }
296
- if (params.startTime) {
297
- txBuilder.startTime(Utils.normalizeStarttime(params.startTime));
298
- }
299
- if (isUnsignedSweep) {
300
- const tx = await txBuilder.build();
301
- const txJson = tx.toJson();
302
- return {
303
- txHex: tx.toBroadcastFormat(),
304
- coin: this.getChain(),
305
- id: txJson.id,
306
- startTime: txJson.startTime,
307
- validDuration: txJson.validDuration,
308
- nodeId: txJson.node,
309
- memo: txJson.memo,
310
- userKey: params.userKey,
311
- backupKey: params.backupKey,
312
- bitgoKey: params.bitgoKey,
313
- maxFee: fee,
314
- address: params.rootAddress,
315
- recipients: txJson.instructionsData.params.recipients,
316
- amount: txJson.amount,
317
- json: txJson,
318
- };
319
- }
320
- txBuilder.sign({ key: userPrv });
321
- txBuilder.sign({ key: backUp });
322
- const tx = await txBuilder.build();
323
- return {
324
- tx: tx.toBroadcastFormat(),
325
- id: tx.toJson().id,
326
- coin: this.getChain(),
327
- startTime: tx.toJson().startTime,
328
- nodeId: tx.toJson().node,
329
- };
330
- }
331
- /**
332
- * Explain a Hedera transaction from txHex
333
- * @param params
334
- */
335
- async explainTransaction(params) {
336
- const txHex = params.txHex || (params.halfSigned && params.halfSigned.txHex);
337
- if (!txHex) {
338
- throw new Error('missing explain tx parameters');
339
- }
340
- const factory = this.getBuilderFactory();
341
- const txBuilder = factory.from(txHex);
342
- const tx = await txBuilder.build();
343
- const txJson = tx.toJson();
344
- let outputAmount = new bignumber_js_1.BigNumber(0);
345
- const outputs = [];
346
- // TODO(BG-24809): get the memo from the toJson
347
- let memo = '';
348
- if (params.memo) {
349
- memo = params.memo.value;
350
- }
351
- switch (txJson.instructionsData.type) {
352
- case 'cryptoTransfer':
353
- const recipients = txJson.instructionsData.params.recipients || [];
354
- recipients.forEach((recipient) => {
355
- if (!recipient.tokenName) {
356
- // token transfer doesn't change outputAmount
357
- outputAmount = outputAmount.plus(recipient.amount);
358
- }
359
- outputs.push({
360
- address: recipient.address,
361
- amount: recipient.amount.toString(),
362
- memo,
363
- ...(recipient.tokenName && {
364
- tokenName: recipient.tokenName,
365
- }),
366
- });
367
- });
368
- break;
369
- case 'tokenAssociate':
370
- const tokens = txJson.instructionsData.params.tokenNames || [];
371
- const accountId = txJson.instructionsData.params.accountId;
372
- tokens.forEach((token) => {
373
- outputs.push({
374
- address: accountId,
375
- amount: '0',
376
- memo,
377
- tokenName: token,
378
- });
379
- });
380
- break;
381
- default:
382
- throw new Error('Transaction format outside of cryptoTransfer not supported for explanation.');
383
- }
384
- const displayOrder = [
385
- 'id',
386
- 'outputAmount',
387
- 'changeAmount',
388
- 'outputs',
389
- 'changeOutputs',
390
- 'fee',
391
- 'timestamp',
392
- 'expiration',
393
- 'memo',
394
- ];
395
- return {
396
- displayOrder,
397
- id: txJson.id,
398
- outputs,
399
- outputAmount: outputAmount.toString(),
400
- changeOutputs: [], // account based does not use change outputs
401
- changeAmount: '0', // account base does not make change
402
- fee: params.feeInfo?.fee || txJson.fee, // in the instance no feeInfo is passed in as a param, show the fee given by the txJSON
403
- timestamp: txJson.startTime,
404
- expiration: txJson.validDuration,
405
- };
406
- }
407
- isStellarSeed(seed) {
408
- return seedValidator_1.SeedValidator.isValidEd25519SeedForCoin(seed, statics_1.CoinFamily.XLM);
409
- }
410
- convertFromStellarSeed(seed) {
411
- // assume this is a trust custodial seed if its a valid ed25519 prv
412
- if (!this.isStellarSeed(seed) || seedValidator_1.SeedValidator.hasCompetingSeedFormats(seed)) {
413
- return null;
414
- }
415
- if (seedValidator_1.SeedValidator.isValidEd25519SeedForCoin(seed, statics_1.CoinFamily.XLM)) {
416
- const keyFromSeed = new lib_1.KeyPair({ seed: stellar.StrKey.decodeEd25519SecretSeed(seed) });
417
- const keys = keyFromSeed.getKeys();
418
- if (keys !== undefined && keys.prv) {
419
- return keys.prv;
420
- }
421
- }
422
- return null;
423
- }
424
- isValidPub(pub) {
425
- return Utils.isValidPublicKey(pub);
426
- }
427
- supportsDeriveKeyWithSeed() {
428
- return false;
429
- }
430
- /** {@inheritDoc } **/
431
- supportsMultisig() {
432
- return true;
433
- }
434
- /** inherited doc */
435
- getDefaultMultisigType() {
436
- return sdk_core_1.multisigTypes.onchain;
437
- }
438
- getTokenEnablementConfig() {
439
- return {
440
- requiresTokenEnablement: true,
441
- supportsMultipleTokenEnablements: true,
442
- };
443
- }
444
- getBuilderFactory() {
445
- return new lib_1.TransactionBuilderFactory(statics_1.coins.get(this.getChain()));
446
- }
447
- getHbarClient() {
448
- const client = this.bitgo.getEnv() === 'prod' ? sdk_1.Client.forMainnet() : sdk_1.Client.forTestnet();
449
- return client;
450
- }
451
- async getAccountBalance(accountId, client) {
452
- try {
453
- const balance = await new sdk_1.AccountBalanceQuery().setAccountId(accountId).execute(client);
454
- return balance.toJSON();
455
- }
456
- catch (e) {
457
- throw new Error('Failed to get account balance, error: ' + e.message);
458
- }
459
- }
460
- async broadcastTransaction({ serializedSignedTransaction, startTime, }) {
461
- try {
462
- const hbarTx = sdk_1.Transaction.fromBytes(Utils.toUint8Array(serializedSignedTransaction));
463
- if (startTime) {
464
- Utils.isValidTimeString(startTime);
465
- while (!Utils.shouldBroadcastNow(startTime)) {
466
- await Utils.sleep(1000);
467
- }
468
- }
469
- return this.clientBroadcastTransaction(hbarTx);
470
- }
471
- catch (e) {
472
- throw new Error('Failed to broadcast transaction, error: ' + e.message);
473
- }
474
- }
475
- async clientBroadcastTransaction(hbarTx) {
476
- const client = this.getHbarClient();
477
- const transactionResponse = await hbarTx.execute(client);
478
- const transactionReceipt = await transactionResponse.getReceipt(client);
479
- return { txId: transactionResponse.transactionId.toString(), status: transactionReceipt.status.toString() };
480
- }
481
- }
482
- exports.Hbar = Hbar;
483
- //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"hbar.js","sourceRoot":"","sources":["../../src/hbar.ts"],"names":[],"mappings":"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","sourcesContent":["/**\n * @prettier\n */\nimport { CoinFamily, BaseCoin as StaticsBaseCoin, coins } from '@bitgo-beta/statics';\nimport {\n  BaseCoin,\n  BitGoBase,\n  KeyPair,\n  ParsedTransaction,\n  ParseTransactionOptions,\n  SignedTransaction,\n  SignTransactionOptions,\n  VerifyAddressOptions as BaseVerifyAddressOptions,\n  VerifyTransactionOptions,\n  TransactionFee,\n  TransactionRecipient as Recipient,\n  TransactionPrebuild as BaseTransactionPrebuild,\n  TransactionExplanation,\n  Memo,\n  TokenEnablementConfig,\n  BaseBroadcastTransactionOptions,\n  BaseBroadcastTransactionResult,\n  NotSupported,\n  MultisigType,\n  multisigTypes,\n} from '@bitgo-beta/sdk-core';\nimport { BigNumber } from 'bignumber.js';\nimport * as stellar from 'stellar-sdk';\nimport { SeedValidator } from './seedValidator';\nimport { KeyPair as HbarKeyPair, TransactionBuilderFactory, Transaction } from './lib';\nimport * as Utils from './lib/utils';\nimport * as _ from 'lodash';\nimport {\n  Client,\n  Transaction as HbarTransaction,\n  AccountBalanceQuery,\n  AccountBalanceJson,\n  Hbar as HbarUnit,\n} from '@hashgraph/sdk';\nimport { PUBLIC_KEY_PREFIX } from './lib/keyPair';\nexport interface HbarSignTransactionOptions extends SignTransactionOptions {\n  txPrebuild: TransactionPrebuild;\n  prv: string;\n}\n\nexport interface TxInfo {\n  recipients: Recipient[];\n  from: string;\n  txid: string;\n}\n\nexport interface TransactionPrebuild extends BaseTransactionPrebuild {\n  txHex: string;\n  txInfo: TxInfo;\n  feeInfo: TransactionFee;\n  source: string;\n}\n\nexport interface ExplainTransactionOptions {\n  txHex?: string;\n  halfSigned?: {\n    txHex: string;\n  };\n  feeInfo?: TransactionFee;\n  // TODO(BG-24809): get the memo from the toJson\n  memo?: {\n    type: string;\n    value: string;\n  };\n}\n\nexport interface HbarVerifyTransactionOptions extends VerifyTransactionOptions {\n  txPrebuild: TransactionPrebuild;\n  memo?: Memo;\n}\n\ninterface VerifyAddressOptions extends BaseVerifyAddressOptions {\n  baseAddress: string;\n}\n\nexport interface RecoveryOptions {\n  backupKey: string;\n  userKey: string;\n  rootAddress: string;\n  recoveryDestination: string;\n  bitgoKey?: string;\n  walletPassphrase?: string;\n  maxFee?: string;\n  nodeId?: string;\n  startTime?: string;\n  tokenId?: string;\n}\n\nexport interface RecoveryInfo {\n  id: string;\n  tx: string;\n  coin: string;\n  startTime: string;\n  nodeId: string;\n}\n\nexport interface OfflineVaultTxInfo {\n  txHex: string;\n  userKey: string;\n  backupKey: string;\n  bitgoKey?: string;\n  address: string;\n  coin: string;\n  maxFee: string;\n  recipients: Recipient[];\n  amount: string;\n  startTime: string;\n  validDuration: string;\n  nodeId: string;\n  memo: string;\n  json?: any;\n}\n\nexport interface BroadcastTransactionOptions extends BaseBroadcastTransactionOptions {\n  startTime?: string;\n}\n\nexport interface BroadcastTransactionResult extends BaseBroadcastTransactionResult {\n  status?: string;\n}\n\nexport class Hbar extends BaseCoin {\n  protected readonly _staticsCoin: Readonly<StaticsBaseCoin>;\n\n  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  getChain() {\n    return this._staticsCoin.name;\n  }\n\n  getFamily(): CoinFamily {\n    return this._staticsCoin.family;\n  }\n\n  getFullName() {\n    return this._staticsCoin.fullName;\n  }\n\n  getBaseFactor() {\n    return Math.pow(10, this._staticsCoin.decimalPlaces);\n  }\n\n  static createInstance(bitgo: BitGoBase, staticsCoin?: Readonly<StaticsBaseCoin>): BaseCoin {\n    return new Hbar(bitgo, staticsCoin);\n  }\n\n  /**\n   * Flag for sending value of 0\n   * @returns {boolean} True if okay to send 0 value, false otherwise\n   */\n  valuelessTransferAllowed(): boolean {\n    return false;\n  }\n\n  /**\n   * Checks if this is a valid base58 or hex address\n   * @param address\n   */\n  isValidAddress(address: string): boolean {\n    try {\n      return Utils.isValidAddressWithPaymentId(address);\n    } catch (e) {\n      return false;\n    }\n  }\n\n  /** inheritdoc */\n  deriveKeyWithSeed(): { derivationPath: string; key: string } {\n    throw new NotSupported('method deriveKeyWithSeed not supported for eddsa curve');\n  }\n\n  /** inheritdoc */\n  generateKeyPair(seed?: Buffer): KeyPair {\n    const keyPair = seed ? new HbarKeyPair({ seed }) : new HbarKeyPair();\n    const keys = keyPair.getKeys();\n\n    if (!keys.prv) {\n      throw new Error('Keypair generation failed to generate a prv');\n    }\n\n    return {\n      pub: keys.pub,\n      prv: keys.prv,\n    };\n  }\n\n  /** inheritdoc */\n  generateRootKeyPair(seed?: Buffer): KeyPair {\n    const keyPair = seed ? new HbarKeyPair({ seed }) : new HbarKeyPair();\n    const keys = keyPair.getKeys(true);\n    if (!keys.prv) {\n      throw new Error('Missing prv in key generation.');\n    }\n    return { prv: keys.prv + keys.pub, pub: keys.pub };\n  }\n\n  async parseTransaction(params: ParseTransactionOptions): Promise<ParsedTransaction> {\n    return {};\n  }\n\n  /**\n   * Check if address is valid, then make sure it matches the base address.\n   *\n   * @param {VerifyAddressOptions} params\n   * @param {String} params.address - the address to verify\n   * @param {String} params.baseAddress - the base address from the wallet\n   */\n  async isWalletAddress(params: VerifyAddressOptions): Promise<boolean> {\n    const { address, baseAddress } = params;\n    return Utils.isSameBaseAddress(address, baseAddress);\n  }\n\n  async verifyTransaction(params: HbarVerifyTransactionOptions): Promise<boolean> {\n    // asset name to transfer amount map\n    const coinConfig = coins.get(this.getChain());\n    const { txParams: txParams, txPrebuild: txPrebuild, memo: memo } = params;\n    const transaction = new Transaction(coinConfig);\n    if (!txPrebuild.txHex) {\n      throw new Error('missing required tx prebuild property txHex');\n    }\n\n    transaction.fromRawTransaction(txPrebuild.txHex);\n    const explainTxParams: ExplainTransactionOptions = {\n      txHex: txPrebuild.txHex,\n      feeInfo: txPrebuild.feeInfo,\n      memo: memo,\n    };\n    const explainedTx = await this.explainTransaction(explainTxParams);\n\n    if (!txParams.recipients) {\n      throw new Error('missing required tx params property recipients');\n    }\n\n    // for enabletoken, recipient output amount is 0\n    const recipients = txParams.recipients.map((recipient) => ({\n      ...recipient,\n      amount: txParams.type === 'enabletoken' ? '0' : recipient.amount,\n    }));\n    if (coinConfig.isToken) {\n      recipients.forEach((recipient) => {\n        if (recipient.tokenName !== undefined && recipient.tokenName !== coinConfig.name) {\n          throw new Error('Incorrect token name specified in recipients');\n        }\n        recipient.tokenName = coinConfig.name;\n      });\n    }\n\n    // verify recipients from params and explainedTx\n    const filteredRecipients = recipients?.map((recipient) => _.pick(recipient, ['address', 'amount', 'tokenName']));\n    const filteredOutputs = explainedTx.outputs.map((output) => _.pick(output, ['address', 'amount', 'tokenName']));\n\n    if (!_.isEqual(filteredOutputs, filteredRecipients)) {\n      throw new Error('Tx outputs does not match with expected txParams recipients');\n    }\n\n    return true;\n  }\n\n  /**\n   * Assemble keychain and half-sign prebuilt transaction\n   *\n   * @param params\n   * @param params.txPrebuild {Object} prebuild object returned by platform\n   * @param params.prv {String} user prv\n   * @returns Promise<SignedTransaction>\n   */\n  async signTransaction(params: HbarSignTransactionOptions): Promise<SignedTransaction> {\n    const factory = this.getBuilderFactory();\n    const txBuilder = factory.from(params.txPrebuild.txHex);\n    txBuilder.sign({ key: params.prv });\n\n    const transaction = await txBuilder.build();\n\n    if (!transaction) {\n      throw new Error('Invalid messaged passed to signMessage');\n    }\n\n    const response = {\n      txHex: transaction.toBroadcastFormat(),\n    };\n    return transaction.signature.length >= 2 ? response : { halfSigned: response };\n  }\n\n  /**\n   * Sign message with private key\n   *\n   * @param key\n   * @param message\n   * @return {Buffer} A signature over the given message using the given key\n   */\n  async signMessage(key: KeyPair, message: string | Buffer): Promise<Buffer> {\n    const msg = Buffer.isBuffer(message) ? message.toString('utf8') : message;\n    // reconstitute keys and sign\n    return Buffer.from(new HbarKeyPair({ prv: key.prv }).signMessage(msg));\n  }\n\n  /**\n   * Builds a funds recovery transaction without BitGo.\n   * We need to do three queries during this:\n   * 1) Node query - how much money is in the account\n   * 2) Build transaction - build our transaction for the amount\n   * 3) Send signed build - send our signed build to a public node\n   * @param params\n   */\n  public async recover(params: RecoveryOptions): Promise<RecoveryInfo | OfflineVaultTxInfo> {\n    const isUnsignedSweep =\n      (params.backupKey.startsWith(PUBLIC_KEY_PREFIX) && params.userKey.startsWith(PUBLIC_KEY_PREFIX)) ||\n      (Utils.isValidPublicKey(params.userKey) && Utils.isValidPublicKey(params.backupKey));\n\n    // Validate the root address\n    if (!this.isValidAddress(params.rootAddress)) {\n      throw new Error('invalid rootAddress, got: ' + params.rootAddress);\n    }\n\n    // Validate the destination address\n    if (!this.isValidAddress(params.recoveryDestination)) {\n      throw new Error('invalid recoveryDestination, got: ' + params.recoveryDestination);\n    }\n\n    // Validate nodeId\n    if (params.nodeId && !Utils.isValidAddress(params.nodeId)) {\n      throw new Error('invalid nodeId, got: ' + params.nodeId);\n    }\n\n    // validate fee\n    if (params.maxFee && !Utils.isValidAmount(params.maxFee)) {\n      throw new Error('invalid maxFee, got: ' + params.maxFee);\n    }\n\n    // validate startTime\n\n    if (params.startTime) {\n      Utils.validateStartTime(params.startTime);\n    }\n\n    if (isUnsignedSweep && !params.startTime) {\n      throw new Error('start time is required for unsigned sweep');\n    }\n\n    if (!isUnsignedSweep && !params.walletPassphrase) {\n      throw new Error('walletPassphrase is required for non-bitgo recovery');\n    }\n\n    let userPrv: string | undefined;\n    let backUp: string | undefined;\n    if (!isUnsignedSweep) {\n      try {\n        userPrv = this.bitgo.decrypt({ input: params.userKey, password: params.walletPassphrase });\n        backUp = this.bitgo.decrypt({ input: params.backupKey, password: params.walletPassphrase });\n      } catch (e) {\n        throw new Error(\n          'unable to decrypt userKey or backupKey with the walletPassphrase provided, got error: ' + e.message\n        );\n      }\n    }\n\n    // validate userKey for unsigned sweep\n    if (isUnsignedSweep && !Utils.isValidPublicKey(params.userKey)) {\n      throw new Error('invalid userKey, got: ' + params.userKey);\n    }\n\n    // validate backupKey for unsigned sweep\n    if (isUnsignedSweep && !Utils.isValidPublicKey(params.backupKey)) {\n      throw new Error('invalid backupKey, got: ' + params.backupKey);\n    }\n\n    const { address: destinationAddress, memoId } = Utils.getAddressDetails(params.recoveryDestination);\n    const nodeId = params.nodeId ? params.nodeId : '0.0.3';\n    const client = this.getHbarClient();\n    const balance = await this.getAccountBalance(params.rootAddress, client);\n    const fee = params.maxFee ? params.maxFee : '10000000'; // default fee to 1 hbar\n    const nativeBalance = HbarUnit.fromString(balance.hbars).toTinybars().toString();\n    const spendableAmount = new BigNumber(nativeBalance).minus(fee);\n\n    let txBuilder;\n    if (!params.tokenId) {\n      if (spendableAmount.isZero() || spendableAmount.isNegative()) {\n        throw new Error(`Insufficient balance to recover, got balance: ${nativeBalance} fee: ${fee}`);\n      }\n      txBuilder = this.getBuilderFactory().getTransferBuilder();\n      txBuilder.send({ address: destinationAddress, amount: spendableAmount.toString() });\n    } else {\n      if (spendableAmount.isNegative()) {\n        throw new Error(\n          `Insufficient native balance to recover tokens, got native balance: ${nativeBalance} fee: ${fee}`\n        );\n      }\n      const tokenBalance = balance.tokens.find((token) => token.tokenId === params.tokenId);\n      const token = Utils.getHederaTokenNameFromId(params.tokenId);\n      if (!token) {\n        throw new Error(`Unsupported token: ${params.tokenId}`);\n      }\n      if (!tokenBalance || new BigNumber(tokenBalance.balance).isZero()) {\n        throw new Error(`Insufficient balance to recover token: ${params.tokenId} for account: ${params.rootAddress}`);\n      }\n      txBuilder = this.getBuilderFactory().getTokenTransferBuilder();\n      txBuilder.send({ address: destinationAddress, amount: tokenBalance.balance, tokenName: token.name });\n    }\n\n    txBuilder.node({ nodeId });\n    txBuilder.fee({ fee });\n    txBuilder.source({ address: params.rootAddress });\n    txBuilder.validDuration(180);\n    if (memoId) {\n      txBuilder.memo(memoId);\n    }\n\n    if (params.startTime) {\n      txBuilder.startTime(Utils.normalizeStarttime(params.startTime));\n    }\n    if (isUnsignedSweep) {\n      const tx = await txBuilder.build();\n      const txJson = tx.toJson();\n      return {\n        txHex: tx.toBroadcastFormat(),\n        coin: this.getChain(),\n        id: txJson.id,\n        startTime: txJson.startTime,\n        validDuration: txJson.validDuration,\n        nodeId: txJson.node,\n        memo: txJson.memo,\n        userKey: params.userKey,\n        backupKey: params.backupKey,\n        bitgoKey: params.bitgoKey,\n        maxFee: fee,\n        address: params.rootAddress,\n        recipients: txJson.instructionsData.params.recipients,\n        amount: txJson.amount,\n        json: txJson,\n      };\n    }\n\n    txBuilder.sign({ key: userPrv });\n    txBuilder.sign({ key: backUp });\n\n    const tx = await txBuilder.build();\n\n    return {\n      tx: tx.toBroadcastFormat(),\n      id: tx.toJson().id,\n      coin: this.getChain(),\n      startTime: tx.toJson().startTime,\n      nodeId: tx.toJson().node,\n    };\n  }\n\n  /**\n   * Explain a Hedera transaction from txHex\n   * @param params\n   */\n  async explainTransaction(params: ExplainTransactionOptions): Promise<TransactionExplanation> {\n    const txHex = params.txHex || (params.halfSigned && params.halfSigned.txHex);\n    if (!txHex) {\n      throw new Error('missing explain tx parameters');\n    }\n\n    const factory = this.getBuilderFactory();\n    const txBuilder = factory.from(txHex);\n    const tx = await txBuilder.build();\n    const txJson = tx.toJson();\n\n    let outputAmount = new BigNumber(0);\n    const outputs: { address: string; amount: string; memo: string; tokenName?: string }[] = [];\n    // TODO(BG-24809): get the memo from the toJson\n    let memo = '';\n    if (params.memo) {\n      memo = params.memo.value;\n    }\n\n    switch (txJson.instructionsData.type) {\n      case 'cryptoTransfer':\n        const recipients = txJson.instructionsData.params.recipients || [];\n        recipients.forEach((recipient) => {\n          if (!recipient.tokenName) {\n            // token transfer doesn't change outputAmount\n            outputAmount = outputAmount.plus(recipient.amount);\n          }\n          outputs.push({\n            address: recipient.address,\n            amount: recipient.amount.toString(),\n            memo,\n            ...(recipient.tokenName && {\n              tokenName: recipient.tokenName,\n            }),\n          });\n        });\n        break;\n\n      case 'tokenAssociate':\n        const tokens = txJson.instructionsData.params.tokenNames || [];\n        const accountId = txJson.instructionsData.params.accountId;\n        tokens.forEach((token) => {\n          outputs.push({\n            address: accountId,\n            amount: '0',\n            memo,\n            tokenName: token,\n          });\n        });\n        break;\n\n      default:\n        throw new Error('Transaction format outside of cryptoTransfer not supported for explanation.');\n    }\n\n    const displayOrder = [\n      'id',\n      'outputAmount',\n      'changeAmount',\n      'outputs',\n      'changeOutputs',\n      'fee',\n      'timestamp',\n      'expiration',\n      'memo',\n    ];\n\n    return {\n      displayOrder,\n      id: txJson.id,\n      outputs,\n      outputAmount: outputAmount.toString(),\n      changeOutputs: [], // account based does not use change outputs\n      changeAmount: '0', // account base does not make change\n      fee: params.feeInfo?.fee || txJson.fee, // in the instance no feeInfo is passed in as a param, show the fee given by the txJSON\n      timestamp: txJson.startTime,\n      expiration: txJson.validDuration,\n    } as any;\n  }\n\n  isStellarSeed(seed: string): boolean {\n    return SeedValidator.isValidEd25519SeedForCoin(seed, CoinFamily.XLM);\n  }\n\n  convertFromStellarSeed(seed: string): string | null {\n    // assume this is a trust custodial seed if its a valid ed25519 prv\n    if (!this.isStellarSeed(seed) || SeedValidator.hasCompetingSeedFormats(seed)) {\n      return null;\n    }\n\n    if (SeedValidator.isValidEd25519SeedForCoin(seed, CoinFamily.XLM)) {\n      const keyFromSeed = new HbarKeyPair({ seed: stellar.StrKey.decodeEd25519SecretSeed(seed) });\n      const keys = keyFromSeed.getKeys();\n      if (keys !== undefined && keys.prv) {\n        return keys.prv;\n      }\n    }\n\n    return null;\n  }\n\n  isValidPub(pub: string): boolean {\n    return Utils.isValidPublicKey(pub);\n  }\n\n  supportsDeriveKeyWithSeed(): boolean {\n    return false;\n  }\n\n  /** {@inheritDoc } **/\n  supportsMultisig(): boolean {\n    return true;\n  }\n\n  /** inherited doc */\n  getDefaultMultisigType(): MultisigType {\n    return multisigTypes.onchain;\n  }\n\n  public getTokenEnablementConfig(): TokenEnablementConfig {\n    return {\n      requiresTokenEnablement: true,\n      supportsMultipleTokenEnablements: true,\n    };\n  }\n\n  private getBuilderFactory(): TransactionBuilderFactory {\n    return new TransactionBuilderFactory(coins.get(this.getChain()));\n  }\n\n  private getHbarClient(): Client {\n    const client = this.bitgo.getEnv() === 'prod' ? Client.forMainnet() : Client.forTestnet();\n    return client;\n  }\n\n  async getAccountBalance(accountId: string, client: Client): Promise<AccountBalanceJson> {\n    try {\n      const balance = await new AccountBalanceQuery().setAccountId(accountId).execute(client);\n\n      return balance.toJSON();\n    } catch (e) {\n      throw new Error('Failed to get account balance, error: ' + e.message);\n    }\n  }\n\n  async broadcastTransaction({\n    serializedSignedTransaction,\n    startTime,\n  }: BroadcastTransactionOptions): Promise<BroadcastTransactionResult> {\n    try {\n      const hbarTx = HbarTransaction.fromBytes(Utils.toUint8Array(serializedSignedTransaction));\n\n      if (startTime) {\n        Utils.isValidTimeString(startTime);\n        while (!Utils.shouldBroadcastNow(startTime)) {\n          await Utils.sleep(1000);\n        }\n      }\n\n      return this.clientBroadcastTransaction(hbarTx);\n    } catch (e) {\n      throw new Error('Failed to broadcast transaction, error: ' + e.message);\n    }\n  }\n\n  async clientBroadcastTransaction(hbarTx: HbarTransaction) {\n    const client = this.getHbarClient();\n    const transactionResponse = await hbarTx.execute(client);\n    const transactionReceipt = await transactionResponse.getReceipt(client);\n\n    return { txId: transactionResponse.transactionId.toString(), status: transactionReceipt.status.toString() };\n  }\n}\n"]}
@@ -1,21 +0,0 @@
1
- import { BitGoBase, CoinConstructor, NamedCoinConstructor } from '@bitgo-beta/sdk-core';
2
- import { HbarTokenConfig } from '@bitgo-beta/statics';
3
- import { Hbar } from './hbar';
4
- export declare class HbarToken extends Hbar {
5
- readonly tokenConfig: HbarTokenConfig;
6
- constructor(bitgo: BitGoBase, tokenConfig: HbarTokenConfig);
7
- static createTokenConstructor(config: HbarTokenConfig): CoinConstructor;
8
- static createTokenConstructors(tokenConfigs?: HbarTokenConfig[]): NamedCoinConstructor[];
9
- get name(): string;
10
- get coin(): string;
11
- get network(): string;
12
- get decimalPlaces(): number;
13
- get nodeAccountId(): string;
14
- get tokenId(): string;
15
- get contractAddress(): string;
16
- getChain(): string;
17
- getBaseChain(): string;
18
- getFullName(): string;
19
- getBaseFactor(): number;
20
- }
21
- //# sourceMappingURL=hbarToken.d.ts.map
@@ -1 +0,0 @@
1
- {"version":3,"file":"hbarToken.d.ts","sourceRoot":"","sources":["../../src/hbarToken.ts"],"names":[],"mappings":"AAAA,OAAO,EAAE,SAAS,EAAE,eAAe,EAAE,oBAAoB,EAAE,MAAM,sBAAsB,CAAC;AACxF,OAAO,EAAS,eAAe,EAAU,MAAM,qBAAqB,CAAC;AACrE,OAAO,EAAE,IAAI,EAAE,MAAM,QAAQ,CAAC;AAE9B,qBAAa,SAAU,SAAQ,IAAI;IACjC,SAAgB,WAAW,EAAE,eAAe,CAAC;gBAEjC,KAAK,EAAE,SAAS,EAAE,WAAW,EAAE,eAAe;IAM1D,MAAM,CAAC,sBAAsB,CAAC,MAAM,EAAE,eAAe,GAAG,eAAe;IAIvE,MAAM,CAAC,uBAAuB,CAC5B,YAAY,GAAE,eAAe,EAAmE,GAC/F,oBAAoB,EAAE;IASzB,IAAI,IAAI,IAAI,MAAM,CAEjB;IAED,IAAI,IAAI,IAAI,MAAM,CAEjB;IAED,IAAI,OAAO,IAAI,MAAM,CAEpB;IAED,IAAI,aAAa,IAAI,MAAM,CAE1B;IAED,IAAI,aAAa,IAAI,MAAM,CAE1B;IAED,IAAI,OAAO,IAAI,MAAM,CAEpB;IAED,IAAI,eAAe,IAAI,MAAM,CAE5B;IAED,QAAQ,IAAI,MAAM;IAIlB,YAAY,IAAI,MAAM;IAItB,WAAW,IAAI,MAAM;IAIrB,aAAa,IAAI,MAAM;CAGxB"}