@bitgo-beta/sdk-coin-trx 1.2.3-alpha.43 → 1.2.3-alpha.431

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 (132) hide show
  1. package/dist/resources/protobuf/Contract.proto +32 -0
  2. package/dist/resources/protobuf/tron.d.ts +1478 -214
  3. package/dist/resources/protobuf/tron.js +6312 -2600
  4. package/dist/resources/protobuf/tron.proto +6 -0
  5. package/dist/src/index.js +6 -2
  6. package/dist/src/lib/constants.d.ts +3 -0
  7. package/dist/src/lib/constants.d.ts.map +1 -0
  8. package/dist/src/lib/constants.js +6 -0
  9. package/dist/src/lib/contractCallBuilder.d.ts +1 -35
  10. package/dist/src/lib/contractCallBuilder.d.ts.map +1 -1
  11. package/dist/src/lib/contractCallBuilder.js +12 -75
  12. package/dist/src/lib/delegateResourceTxBuilder.d.ts +27 -0
  13. package/dist/src/lib/delegateResourceTxBuilder.d.ts.map +1 -0
  14. package/dist/src/lib/delegateResourceTxBuilder.js +98 -0
  15. package/dist/src/lib/enum.d.ts +36 -1
  16. package/dist/src/lib/enum.d.ts.map +1 -1
  17. package/dist/src/lib/enum.js +40 -4
  18. package/dist/src/lib/freezeBalanceTxBuilder.d.ts +71 -0
  19. package/dist/src/lib/freezeBalanceTxBuilder.d.ts.map +1 -0
  20. package/dist/src/lib/freezeBalanceTxBuilder.js +211 -0
  21. package/dist/src/lib/iface.d.ts +220 -2
  22. package/dist/src/lib/iface.d.ts.map +1 -1
  23. package/dist/src/lib/iface.js +1 -1
  24. package/dist/src/lib/index.js +23 -9
  25. package/dist/src/lib/keyPair.d.ts +0 -1
  26. package/dist/src/lib/keyPair.d.ts.map +1 -1
  27. package/dist/src/lib/keyPair.js +31 -18
  28. package/dist/src/lib/resourceManagementTxBuilder.d.ts +72 -0
  29. package/dist/src/lib/resourceManagementTxBuilder.d.ts.map +1 -0
  30. package/dist/src/lib/resourceManagementTxBuilder.js +150 -0
  31. package/dist/src/lib/tokenTransferBuilder.d.ts +1 -1
  32. package/dist/src/lib/tokenTransferBuilder.js +3 -3
  33. package/dist/src/lib/transaction.d.ts.map +1 -1
  34. package/dist/src/lib/transaction.js +92 -6
  35. package/dist/src/lib/transactionBuilder.d.ts +50 -5
  36. package/dist/src/lib/transactionBuilder.d.ts.map +1 -1
  37. package/dist/src/lib/transactionBuilder.js +110 -21
  38. package/dist/src/lib/undelegateResourceTxBuilder.d.ts +27 -0
  39. package/dist/src/lib/undelegateResourceTxBuilder.d.ts.map +1 -0
  40. package/dist/src/lib/undelegateResourceTxBuilder.js +98 -0
  41. package/dist/src/lib/unfreezeBalanceTxBuilder.d.ts +65 -0
  42. package/dist/src/lib/unfreezeBalanceTxBuilder.d.ts.map +1 -0
  43. package/dist/src/lib/unfreezeBalanceTxBuilder.js +204 -0
  44. package/dist/src/lib/utils.d.ts +85 -4
  45. package/dist/src/lib/utils.d.ts.map +1 -1
  46. package/dist/src/lib/utils.js +445 -47
  47. package/dist/src/lib/voteWitnessTxBuilder.d.ts +62 -0
  48. package/dist/src/lib/voteWitnessTxBuilder.d.ts.map +1 -0
  49. package/dist/src/lib/voteWitnessTxBuilder.js +219 -0
  50. package/dist/src/lib/withdrawBuilder.d.ts +49 -0
  51. package/dist/src/lib/withdrawBuilder.d.ts.map +1 -0
  52. package/dist/src/lib/withdrawBuilder.js +167 -0
  53. package/dist/src/lib/withdrawExpireUnfreezeTxBuilder.d.ts +49 -0
  54. package/dist/src/lib/withdrawExpireUnfreezeTxBuilder.d.ts.map +1 -0
  55. package/dist/src/lib/withdrawExpireUnfreezeTxBuilder.js +167 -0
  56. package/dist/src/lib/wrappedBuilder.d.ts +56 -0
  57. package/dist/src/lib/wrappedBuilder.d.ts.map +1 -1
  58. package/dist/src/lib/wrappedBuilder.js +86 -2
  59. package/dist/src/trx.d.ts +78 -4
  60. package/dist/src/trx.d.ts.map +1 -1
  61. package/dist/src/trx.js +436 -147
  62. package/dist/src/trxToken.d.ts +2 -2
  63. package/dist/src/trxToken.d.ts.map +1 -1
  64. package/dist/src/trxToken.js +5 -5
  65. package/dist/test/fixtures.d.ts +40 -0
  66. package/dist/test/fixtures.d.ts.map +1 -0
  67. package/dist/test/fixtures.js +46 -0
  68. package/dist/test/resources.d.ts +586 -0
  69. package/dist/test/resources.d.ts.map +1 -0
  70. package/dist/test/resources.js +746 -0
  71. package/dist/test/unit/index.d.ts +2 -0
  72. package/dist/test/unit/index.d.ts.map +1 -0
  73. package/dist/test/unit/index.js +19 -0
  74. package/dist/test/unit/keyPair.d.ts +2 -0
  75. package/dist/test/unit/keyPair.d.ts.map +1 -0
  76. package/dist/test/unit/keyPair.js +163 -0
  77. package/dist/test/unit/transaction.d.ts +2 -0
  78. package/dist/test/unit/transaction.d.ts.map +1 -0
  79. package/dist/test/unit/transaction.js +38 -0
  80. package/dist/test/unit/transactionBuilder/contractCallBuilder.d.ts +2 -0
  81. package/dist/test/unit/transactionBuilder/contractCallBuilder.d.ts.map +1 -0
  82. package/dist/test/unit/transactionBuilder/contractCallBuilder.js +315 -0
  83. package/dist/test/unit/transactionBuilder/delegateResourceTxBuilder.d.ts +2 -0
  84. package/dist/test/unit/transactionBuilder/delegateResourceTxBuilder.d.ts.map +1 -0
  85. package/dist/test/unit/transactionBuilder/delegateResourceTxBuilder.js +255 -0
  86. package/dist/test/unit/transactionBuilder/freezeBalanceTxBuilder.d.ts +2 -0
  87. package/dist/test/unit/transactionBuilder/freezeBalanceTxBuilder.d.ts.map +1 -0
  88. package/dist/test/unit/transactionBuilder/freezeBalanceTxBuilder.js +285 -0
  89. package/dist/test/unit/transactionBuilder/tokenTransferBuilder.d.ts +2 -0
  90. package/dist/test/unit/transactionBuilder/tokenTransferBuilder.d.ts.map +1 -0
  91. package/dist/test/unit/transactionBuilder/tokenTransferBuilder.js +42 -0
  92. package/dist/test/unit/transactionBuilder/undelegateResourceTxBuilder.d.ts +2 -0
  93. package/dist/test/unit/transactionBuilder/undelegateResourceTxBuilder.d.ts.map +1 -0
  94. package/dist/test/unit/transactionBuilder/undelegateResourceTxBuilder.js +255 -0
  95. package/dist/test/unit/transactionBuilder/unfreezeBalanceTxBuilder.d.ts +2 -0
  96. package/dist/test/unit/transactionBuilder/unfreezeBalanceTxBuilder.d.ts.map +1 -0
  97. package/dist/test/unit/transactionBuilder/unfreezeBalanceTxBuilder.js +256 -0
  98. package/dist/test/unit/transactionBuilder/voteWitnessTxBuilder.d.ts +2 -0
  99. package/dist/test/unit/transactionBuilder/voteWitnessTxBuilder.d.ts.map +1 -0
  100. package/dist/test/unit/transactionBuilder/voteWitnessTxBuilder.js +277 -0
  101. package/dist/test/unit/transactionBuilder/withdrawBalanceBuilder.d.ts +2 -0
  102. package/dist/test/unit/transactionBuilder/withdrawBalanceBuilder.d.ts.map +1 -0
  103. package/dist/test/unit/transactionBuilder/withdrawBalanceBuilder.js +213 -0
  104. package/dist/test/unit/transactionBuilder/withdrawExpireUnfreezeTxBuilder.d.ts +2 -0
  105. package/dist/test/unit/transactionBuilder/withdrawExpireUnfreezeTxBuilder.d.ts.map +1 -0
  106. package/dist/test/unit/transactionBuilder/withdrawExpireUnfreezeTxBuilder.js +213 -0
  107. package/dist/test/unit/transactionBuilder/wrappedBuilder.d.ts +2 -0
  108. package/dist/test/unit/transactionBuilder/wrappedBuilder.d.ts.map +1 -0
  109. package/dist/test/unit/transactionBuilder/wrappedBuilder.js +50 -0
  110. package/dist/test/unit/transactionBuilder.d.ts +2 -0
  111. package/dist/test/unit/transactionBuilder.d.ts.map +1 -0
  112. package/dist/test/unit/transactionBuilder.js +178 -0
  113. package/dist/test/unit/trx.d.ts +2 -0
  114. package/dist/test/unit/trx.d.ts.map +1 -0
  115. package/dist/test/unit/trx.js +639 -0
  116. package/dist/test/unit/util.d.ts +2 -0
  117. package/dist/test/unit/util.d.ts.map +1 -0
  118. package/dist/test/unit/util.js +141 -0
  119. package/dist/test/unit/verifyTransaction.d.ts +2 -0
  120. package/dist/test/unit/verifyTransaction.d.ts.map +1 -0
  121. package/dist/test/unit/verifyTransaction.js +378 -0
  122. package/dist/tsconfig.tsbuildinfo +1 -0
  123. package/package.json +20 -15
  124. package/.eslintignore +0 -5
  125. package/.mocharc.yml +0 -8
  126. package/CHANGELOG.md +0 -118
  127. package/resources/README.md +0 -31
  128. package/resources/protobuf/Contract.proto +0 -256
  129. package/resources/protobuf/Discover.proto +0 -44
  130. package/resources/protobuf/tron.d.ts +0 -11205
  131. package/resources/protobuf/tron.js +0 -33480
  132. package/resources/protobuf/tron.proto +0 -677
@@ -0,0 +1,639 @@
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
+ var __importDefault = (this && this.__importDefault) || function (mod) {
36
+ return (mod && mod.__esModule) ? mod : { "default": mod };
37
+ };
38
+ Object.defineProperty(exports, "__esModule", { value: true });
39
+ const node_assert_1 = __importDefault(require("node:assert"));
40
+ const node_test_1 = require("node:test");
41
+ const sdk_api_1 = require("@bitgo-beta/sdk-api");
42
+ const sdk_test_1 = require("@bitgo-beta/sdk-test");
43
+ const _ = __importStar(require("lodash"));
44
+ const src_1 = require("../../src");
45
+ const fixtures_1 = require("../fixtures");
46
+ const resources_1 = require("../resources");
47
+ (0, node_test_1.describe)('TRON:', function () {
48
+ const bitgo = sdk_test_1.TestBitGo.decorate(sdk_api_1.BitGoAPI, { env: 'test' });
49
+ bitgo.initializeTestVars();
50
+ bitgo.safeRegister('trx', src_1.Trx.createInstance);
51
+ bitgo.safeRegister('ttrx', src_1.Ttrx.createInstance);
52
+ let basecoin;
53
+ // Test data from wallet 693b011a3ec26986f569b02140c7627e
54
+ const testWalletData = {
55
+ rootAddress: 'TAf36b36eqoMCzJJm3jwSsP81UvkMxrPbi',
56
+ receiveAddress: 'TFaD6DeKFMcBuGuDD7LbbqxTnKunhXfdya',
57
+ receiveAddressIndex: 2,
58
+ keychains: [
59
+ {
60
+ id: '693b0110271fc3f5749754097793bb8d',
61
+ pub: 'xpub661MyMwAqRbcFsVAdZyN2m8p21WHXg8NRNkqKApyS5gwmFsPdRTrmHYCnzR9vYe8DQ4uWGCBcAAsWE3r97HsFS3K2faZ2ejXNhHxdEoAEWC',
62
+ },
63
+ {
64
+ id: '693b011065b9c4674825ce1f849b7bef',
65
+ pub: 'xpub661MyMwAqRbcErKpZr9ztTFJk6fzXWatMFgRnpXfsjybWBfE9847EVGrHHBsGP8fcnzJmJuevAbPUEpjHTjEEWfYUWNMEDahvssQein848o',
66
+ },
67
+ {
68
+ id: '693b01117c41846abb04818815b89b6c',
69
+ pub: 'xpub661MyMwAqRbcFqZd7XU9DFW4f29VJzQt7UCA51ypaWa5ymhQ2pRZDTgViw3vZ56PqZ8dj1cracN3fAWhaiG1QKj9mvyt9Cba4nM2tPibNKw',
70
+ },
71
+ ],
72
+ };
73
+ (0, node_test_1.before)(function () {
74
+ basecoin = bitgo.coin('ttrx');
75
+ });
76
+ (0, node_test_1.it)('should instantiate the coin', function () {
77
+ const basecoin = bitgo.coin('trx');
78
+ node_assert_1.default.ok(basecoin instanceof src_1.Trx);
79
+ });
80
+ (0, node_test_1.it)('explain a txHex', async function () {
81
+ const txHex = JSON.stringify(fixtures_1.mockTx);
82
+ const explainParams = {
83
+ txHex,
84
+ feeInfo: { fee: 1 },
85
+ txID: fixtures_1.mockTx.txID,
86
+ };
87
+ const explanation = await basecoin.explainTransaction(explainParams);
88
+ const toAddress = src_1.Utils.getBase58AddressFromHex(fixtures_1.mockTx.raw_data.contract[0].parameter.value.to_address);
89
+ node_assert_1.default.equal(explanation.id, fixtures_1.mockTx.txID);
90
+ node_assert_1.default.equal(explanation.outputs.length, 1);
91
+ node_assert_1.default.equal(explanation.outputs[0].amount, '10');
92
+ node_assert_1.default.equal(explanation.outputs[0].address, toAddress);
93
+ node_assert_1.default.equal(explanation.outputAmount, '10');
94
+ node_assert_1.default.equal(explanation.changeAmount, '0');
95
+ node_assert_1.default.equal(explanation.changeOutputs.length, 0);
96
+ node_assert_1.default.equal(explanation.fee.fee, 1);
97
+ node_assert_1.default.equal(explanation.expiration, fixtures_1.mockTx.raw_data.expiration);
98
+ node_assert_1.default.equal(explanation.timestamp, fixtures_1.mockTx.raw_data.timestamp);
99
+ });
100
+ (0, node_test_1.it)('should check valid addresses', function () {
101
+ const badAddresses = [
102
+ '',
103
+ null,
104
+ 'xxxx',
105
+ 'YZ09fd-',
106
+ '412C2BA4A9FF6C53207DC5B686BFECF75EA7B805772',
107
+ '412C2BA4A9FF6C53207DC5B686BFECF75EA7B80',
108
+ 'TBChwKYNaTo4a4N68Me1qEiiKsRDspXqLLZ',
109
+ '0x96be113992bdc3be24c11f6017085b605d253649',
110
+ '0x341qg3922b1',
111
+ '41E0C0F581D7D02D40826C1C6CBEE71F625D6344D0',
112
+ '412C2BA4A9FF6C53207DC5B686BFECF75EA7B80577',
113
+ '418840E6C55B9ADA326D211D818C34A994AECED808',
114
+ '412A2B9F7641D0750C1E822D0E49EF765C8106524B',
115
+ '41A614F803B6FD780986A42C78EC9C7F77E6DED13C',
116
+ '418840E6C55B9ADA326D211D818C34A994AECED808',
117
+ ];
118
+ const goodAddresses = ['TBChwKYNaTo4a4N68Me1qEiiKsRDspXqLp', 'TPcf5jtYUhCN1X14tN577zF4NepbDZbxT7'];
119
+ badAddresses.map((addr) => {
120
+ node_assert_1.default.equal(basecoin.isValidAddress(addr), false);
121
+ });
122
+ goodAddresses.map((addr) => {
123
+ node_assert_1.default.equal(basecoin.isValidAddress(addr), true);
124
+ });
125
+ });
126
+ (0, node_test_1.it)('should throw if the params object is missing parameters', async function () {
127
+ const explainParams = {
128
+ feeInfo: { fee: 1 },
129
+ txID: fixtures_1.mockTx.txID,
130
+ txHex: null,
131
+ };
132
+ await node_assert_1.default.rejects(basecoin.explainTransaction(explainParams), {
133
+ message: 'missing explain tx parameters',
134
+ });
135
+ });
136
+ (0, node_test_1.it)('explain an half-signed/fully signed transaction', async function () {
137
+ const txHex = JSON.stringify(fixtures_1.mockTx);
138
+ const explainParams = {
139
+ halfSigned: { txHex },
140
+ feeInfo: { fee: 1 },
141
+ txID: fixtures_1.mockTx.txID,
142
+ };
143
+ const explanation = await basecoin.explainTransaction(explainParams);
144
+ const toAddress = src_1.Utils.getBase58AddressFromHex(fixtures_1.mockTx.raw_data.contract[0].parameter.value.to_address);
145
+ node_assert_1.default.equal(explanation.id, fixtures_1.mockTx.txID);
146
+ node_assert_1.default.equal(explanation.outputs.length, 1);
147
+ node_assert_1.default.equal(explanation.outputs[0].amount, '10');
148
+ node_assert_1.default.equal(explanation.outputs[0].address, toAddress);
149
+ node_assert_1.default.equal(explanation.outputAmount, '10');
150
+ node_assert_1.default.equal(explanation.changeAmount, '0');
151
+ node_assert_1.default.equal(explanation.changeOutputs.length, 0);
152
+ node_assert_1.default.equal(explanation.fee.fee, 1);
153
+ node_assert_1.default.equal(explanation.expiration, fixtures_1.mockTx.raw_data.expiration);
154
+ node_assert_1.default.equal(explanation.timestamp, fixtures_1.mockTx.raw_data.timestamp);
155
+ });
156
+ (0, node_test_1.it)('should sign a half signed tx', async function () {
157
+ const tx = await basecoin.signTransaction(fixtures_1.signTxOptions);
158
+ const unsignedTxJson = JSON.parse(fixtures_1.signTxOptions.txPrebuild.txHex);
159
+ const signedTxJson = JSON.parse(tx.halfSigned.txHex);
160
+ node_assert_1.default.equal(signedTxJson.txID, unsignedTxJson.txID);
161
+ node_assert_1.default.equal(signedTxJson.raw_data_hex, unsignedTxJson.raw_data_hex);
162
+ node_assert_1.default.deepStrictEqual(JSON.stringify(signedTxJson.raw_data), JSON.stringify(unsignedTxJson.raw_data));
163
+ node_assert_1.default.equal(signedTxJson.signature.length, 1);
164
+ node_assert_1.default.equal(signedTxJson.signature[0], '0a9944316924ec7fba4895f1ea1e7cc95f9e2b828ae268a48a8dbeddef40c6f5e127170a95aed9f3f5425b13058d0cb6ef1f5c2213190e482e87043691f22e6800');
165
+ });
166
+ (0, node_test_1.it)('should sign with an Xprv a half signed tx', async function () {
167
+ const p = {
168
+ prv: 'xprv9s21ZrQH143K2sg2Cukk5XqLQdrYnMCDah3y1FFVy6Hz9bQfqMSfmUiHPVHKhcUyft3N1emE5FudJVxgFm5N12MAg5o7DTPsDATTkwNgr73',
169
+ txPrebuild: {
170
+ txHex: fixtures_1.signTxOptions.txPrebuild.txHex,
171
+ },
172
+ };
173
+ const tx = await basecoin.signTransaction(p);
174
+ const unsignedTxJson = JSON.parse(fixtures_1.signTxOptions.txPrebuild.txHex);
175
+ const signedTxJson = JSON.parse(tx.halfSigned.txHex);
176
+ node_assert_1.default.equal(signedTxJson.txID, unsignedTxJson.txID);
177
+ node_assert_1.default.equal(signedTxJson.raw_data_hex, unsignedTxJson.raw_data_hex);
178
+ node_assert_1.default.deepStrictEqual(JSON.stringify(signedTxJson.raw_data), JSON.stringify(unsignedTxJson.raw_data));
179
+ node_assert_1.default.equal(signedTxJson.signature.length, 1);
180
+ node_assert_1.default.equal(signedTxJson.signature[0], '65e56f53a458c6f82d1ef39b2cf5be685a906ad22bb02699f907fcb72ef26f1e91cfc2b6a43bf5432faa0b63bdc5aebf1dc2f49a675d28d23fd7e038b3358b0600');
181
+ });
182
+ (0, node_test_1.it)('should add feeLimit to recipient', async function () {
183
+ const feeLimit = 100;
184
+ const buildParams = {
185
+ recipients: [{ data: 'test' }],
186
+ feeLimit,
187
+ };
188
+ basecoin.getExtraPrebuildParams(buildParams);
189
+ node_assert_1.default.equal(buildParams.recipients[0].feeLimit, feeLimit);
190
+ });
191
+ (0, node_test_1.it)('should`t add any new field', async function () {
192
+ const buildParams = {
193
+ recipients: [{ data: 'test' }],
194
+ };
195
+ const unmodifiedBuildParams = _.cloneDeep(buildParams);
196
+ await basecoin.getExtraPrebuildParams(buildParams);
197
+ node_assert_1.default.deepStrictEqual(buildParams, unmodifiedBuildParams);
198
+ });
199
+ (0, node_test_1.describe)('Keypairs:', () => {
200
+ (0, node_test_1.it)('should generate a keypair from random seed', function () {
201
+ const keyPair = basecoin.generateKeyPair();
202
+ node_assert_1.default.ok(Object.prototype.hasOwnProperty.call(keyPair, 'pub'));
203
+ node_assert_1.default.ok(Object.prototype.hasOwnProperty.call(keyPair, 'prv'));
204
+ node_assert_1.default.equal(basecoin.isValidPub(keyPair.pub), true);
205
+ });
206
+ (0, node_test_1.it)('should generate a keypair from a seed', function () {
207
+ const seedText = '80350b4208d381fbfe2276a326603049fe500731c46d3c9936b5ce036b51377f24bab7dd0c2af7f107416ef858ff79b0670c72406dad064e72bb17fc0a9038bb';
208
+ const seed = Buffer.from(seedText, 'hex');
209
+ const keyPair = basecoin.generateKeyPair(seed);
210
+ node_assert_1.default.equal(keyPair.pub, 'xpub661MyMwAqRbcFAwqvSGbk35kJf7CQqdN1w4CMUBBTqH5e3ivjU6D8ugv9hRSgRbRenC4w3ahXdLVahwjgjXhSuQKMdNdn55Y9TNSagBktws');
211
+ node_assert_1.default.equal(keyPair.prv, 'xprv9s21ZrQH143K2gsNpQjbNu91kdGi1NuWei8bZ5mZuVk6mFPnBvmxb7NSJQdbZW3FGpK3Ycn7jorAXcEzMvviGtbyBz5tBrjfnWyQp3g75FK');
212
+ });
213
+ });
214
+ (0, node_test_1.describe)('Build Unsigned Sweep', () => {
215
+ (0, node_test_1.afterEach)(() => {
216
+ node_test_1.mock.reset();
217
+ });
218
+ (0, node_test_1.it)('should recover trx from base address to recovery address', async function () {
219
+ node_test_1.mock.method(src_1.Trx.prototype, 'getAccountBalancesFromNode', (...args) => {
220
+ if (args.length > 0 && args[0] === resources_1.TestRecoverData.baseAddress) {
221
+ return Promise.resolve((0, resources_1.baseAddressBalance)(3000000));
222
+ }
223
+ return undefined;
224
+ });
225
+ const baseAddrHex = src_1.Utils.getHexAddressFromBase58Address(resources_1.TestRecoverData.baseAddress);
226
+ const destinationHex = src_1.Utils.getHexAddressFromBase58Address(resources_1.TestRecoverData.recoveryDestination);
227
+ node_test_1.mock.method(src_1.Trx.prototype, 'getBuildTransaction', (...args) => {
228
+ if (args.length > 0 && args[0] === destinationHex && args[1] === baseAddrHex && args[2] === 900000) {
229
+ return Promise.resolve((0, resources_1.creationTransaction)(baseAddrHex, destinationHex, 900000));
230
+ }
231
+ return undefined;
232
+ });
233
+ const res = await basecoin.recover({
234
+ userKey: resources_1.TestRecoverData.userKey,
235
+ backupKey: resources_1.TestRecoverData.backupKey,
236
+ bitgoKey: resources_1.TestRecoverData.bitgoKey,
237
+ recoveryDestination: resources_1.TestRecoverData.recoveryDestination,
238
+ });
239
+ node_assert_1.default.notEqual(res.length, 0);
240
+ node_assert_1.default.ok(Object.prototype.hasOwnProperty.call(res, 'txHex'));
241
+ node_assert_1.default.ok(Object.prototype.hasOwnProperty.call(res, 'feeInfo'));
242
+ const rawData = JSON.parse(res.txHex).raw_data;
243
+ node_assert_1.default.ok(Object.prototype.hasOwnProperty.call(rawData, 'contract'));
244
+ const value = rawData.contract[0].parameter.value;
245
+ node_assert_1.default.equal(value.amount, 900000);
246
+ node_assert_1.default.equal(src_1.Utils.getBase58AddressFromHex(value.owner_address), resources_1.TestRecoverData.baseAddress);
247
+ node_assert_1.default.equal(src_1.Utils.getBase58AddressFromHex(value.to_address), resources_1.TestRecoverData.recoveryDestination);
248
+ });
249
+ (0, node_test_1.it)('should recover trx from base address to recovery address with scan passed as valid integer string', async function () {
250
+ node_test_1.mock.method(src_1.Trx.prototype, 'getAccountBalancesFromNode', (...args) => {
251
+ if (args.length > 0 && args[0] === resources_1.TestRecoverData.baseAddress) {
252
+ return Promise.resolve((0, resources_1.baseAddressBalance)(3000000));
253
+ }
254
+ return undefined;
255
+ });
256
+ const baseAddrHex = src_1.Utils.getHexAddressFromBase58Address(resources_1.TestRecoverData.baseAddress);
257
+ const destinationHex = src_1.Utils.getHexAddressFromBase58Address(resources_1.TestRecoverData.recoveryDestination);
258
+ node_test_1.mock.method(src_1.Trx.prototype, 'getBuildTransaction', (...args) => {
259
+ if (args.length > 0 && args[0] === destinationHex && args[1] === baseAddrHex && args[2] === 900000) {
260
+ return Promise.resolve((0, resources_1.creationTransaction)(baseAddrHex, destinationHex, 900000));
261
+ }
262
+ return undefined;
263
+ });
264
+ const res = await basecoin.recover({
265
+ userKey: resources_1.TestRecoverData.userKey,
266
+ backupKey: resources_1.TestRecoverData.backupKey,
267
+ bitgoKey: resources_1.TestRecoverData.bitgoKey,
268
+ recoveryDestination: resources_1.TestRecoverData.recoveryDestination,
269
+ scan: '10',
270
+ });
271
+ node_assert_1.default.notEqual(res.length, 0);
272
+ node_assert_1.default.ok(Object.prototype.hasOwnProperty.call(res, 'txHex'));
273
+ node_assert_1.default.ok(Object.prototype.hasOwnProperty.call(res, 'feeInfo'));
274
+ const rawData = JSON.parse(res.txHex).raw_data;
275
+ node_assert_1.default.ok(Object.prototype.hasOwnProperty.call(rawData, 'contract'));
276
+ const value = rawData.contract[0].parameter.value;
277
+ node_assert_1.default.equal(value.amount, 900000);
278
+ node_assert_1.default.equal(src_1.Utils.getBase58AddressFromHex(value.owner_address), resources_1.TestRecoverData.baseAddress);
279
+ node_assert_1.default.equal(src_1.Utils.getBase58AddressFromHex(value.to_address), resources_1.TestRecoverData.recoveryDestination);
280
+ });
281
+ (0, node_test_1.it)('should fail recover trx from base address to recovery address with scan passed as valid integer string', async function () {
282
+ node_test_1.mock.method(src_1.Trx.prototype, 'getAccountBalancesFromNode', (...args) => {
283
+ if (args.length > 0 && args[0] === resources_1.TestRecoverData.baseAddress) {
284
+ return Promise.resolve((0, resources_1.baseAddressBalance)(3000000));
285
+ }
286
+ return undefined;
287
+ });
288
+ const baseAddrHex = src_1.Utils.getHexAddressFromBase58Address(resources_1.TestRecoverData.baseAddress);
289
+ const destinationHex = src_1.Utils.getHexAddressFromBase58Address(resources_1.TestRecoverData.recoveryDestination);
290
+ node_test_1.mock.method(src_1.Trx.prototype, 'getBuildTransaction', (...args) => {
291
+ if (args.length > 0 && args[0] === destinationHex && args[1] === baseAddrHex && args[2] === 900000) {
292
+ return Promise.resolve((0, resources_1.creationTransaction)(baseAddrHex, destinationHex, 900000));
293
+ }
294
+ return undefined;
295
+ });
296
+ await node_assert_1.default.rejects(basecoin.recover({
297
+ userKey: resources_1.TestRecoverData.userKey,
298
+ backupKey: resources_1.TestRecoverData.backupKey,
299
+ bitgoKey: resources_1.TestRecoverData.bitgoKey,
300
+ recoveryDestination: resources_1.TestRecoverData.recoveryDestination,
301
+ scan: 'abc',
302
+ }), {
303
+ message: 'Invalid scanning factor',
304
+ });
305
+ });
306
+ (0, node_test_1.it)('should recover trx from receive address to base address', async function () {
307
+ node_test_1.mock.method(src_1.Trx.prototype, 'getAccountBalancesFromNode', (...args) => {
308
+ if (args.length > 0 && args[0] === resources_1.TestRecoverData.baseAddress) {
309
+ return Promise.resolve((0, resources_1.baseAddressBalance)(2000000));
310
+ }
311
+ if (args.length > 0 && args[0] === resources_1.TestRecoverData.firstReceiveAddress) {
312
+ return Promise.resolve((0, resources_1.receiveAddressBalance)(102100000, resources_1.TestRecoverData.firstReceiveAddress));
313
+ }
314
+ return undefined;
315
+ });
316
+ const firstReceiveAddressHex = src_1.Utils.getHexAddressFromBase58Address(resources_1.TestRecoverData.firstReceiveAddress);
317
+ const baseAddrHex = src_1.Utils.getHexAddressFromBase58Address(resources_1.TestRecoverData.baseAddress);
318
+ node_test_1.mock.method(src_1.Trx.prototype, 'getBuildTransaction', (...args) => {
319
+ if (args.length > 0 && args[0] === baseAddrHex && args[1] === firstReceiveAddressHex && args[2] === 100000000) {
320
+ return Promise.resolve((0, resources_1.creationTransaction)(firstReceiveAddressHex, baseAddrHex, 100000000));
321
+ }
322
+ return undefined;
323
+ });
324
+ const res = await basecoin.recover({
325
+ userKey: resources_1.TestRecoverData.userKey,
326
+ backupKey: resources_1.TestRecoverData.backupKey,
327
+ bitgoKey: resources_1.TestRecoverData.bitgoKey,
328
+ recoveryDestination: resources_1.TestRecoverData.recoveryDestination,
329
+ });
330
+ node_assert_1.default.notEqual(res.length, 0);
331
+ node_assert_1.default.ok(Object.prototype.hasOwnProperty.call(res, 'txHex'));
332
+ node_assert_1.default.ok(Object.prototype.hasOwnProperty.call(res, 'feeInfo'));
333
+ const rawData = JSON.parse(res.txHex).raw_data;
334
+ node_assert_1.default.ok(Object.prototype.hasOwnProperty.call(rawData, 'contract'));
335
+ const value = rawData.contract[0].parameter.value;
336
+ node_assert_1.default.equal(value.amount, 100000000);
337
+ node_assert_1.default.equal(src_1.Utils.getBase58AddressFromHex(value.owner_address), resources_1.TestRecoverData.firstReceiveAddress);
338
+ node_assert_1.default.equal(src_1.Utils.getBase58AddressFromHex(value.to_address), resources_1.TestRecoverData.baseAddress);
339
+ });
340
+ (0, node_test_1.it)('should recover token from base address to recovery address', async function () {
341
+ node_test_1.mock.method(src_1.Trx.prototype, 'getAccountBalancesFromNode', (...args) => {
342
+ if (args.length > 0 && args[0] === resources_1.TestRecoverData.baseAddress) {
343
+ return Promise.resolve((0, resources_1.baseAddressBalance)(100000000, [
344
+ {
345
+ TSdZwNqpHofzP6BsBKGQUWdBeJphLmF6id: '1000000000',
346
+ },
347
+ {
348
+ TG3XXyExBkPp9nzdajDZsozEu4BkaSJozs: '1100000000',
349
+ },
350
+ ]));
351
+ }
352
+ return undefined;
353
+ });
354
+ node_test_1.mock.method(src_1.Trx.prototype, 'getTriggerSmartContractTransaction', (...args) => {
355
+ return Promise.resolve(resources_1.SampleRawTokenSendTxn);
356
+ });
357
+ const res = await basecoin.recover({
358
+ userKey: resources_1.TestRecoverData.userKey,
359
+ backupKey: resources_1.TestRecoverData.backupKey,
360
+ bitgoKey: resources_1.TestRecoverData.bitgoKey,
361
+ tokenContractAddress: 'TG3XXyExBkPp9nzdajDZsozEu4BkaSJozs',
362
+ recoveryDestination: resources_1.TestRecoverData.recoveryDestination,
363
+ });
364
+ node_assert_1.default.notEqual(res.length, 0);
365
+ node_assert_1.default.equal(res.recoveryAmount, 1100000000);
366
+ node_assert_1.default.equal(res.feeInfo.fee, '100000000');
367
+ const expirationDuration = res.tx.raw_data.expiration - res.tx.raw_data.timestamp;
368
+ node_assert_1.default.ok(expirationDuration >= 86400000);
369
+ node_assert_1.default.equal(res.addressInfo, undefined);
370
+ const rawData = JSON.parse(res.txHex).raw_data;
371
+ node_assert_1.default.ok(Object.prototype.hasOwnProperty.call(rawData, 'contract'));
372
+ const value = rawData.contract[0].parameter.value;
373
+ node_assert_1.default.equal(src_1.Utils.getBase58AddressFromHex(value.owner_address), resources_1.TestRecoverData.baseAddress);
374
+ node_assert_1.default.equal(src_1.Utils.getBase58AddressFromHex(value.contract_address), 'TG3XXyExBkPp9nzdajDZsozEu4BkaSJozs');
375
+ });
376
+ (0, node_test_1.it)('should throw if trx balance at base address is not sufficient to cover token send', async function () {
377
+ node_test_1.mock.method(src_1.Trx.prototype, 'getAccountBalancesFromNode', (...args) => {
378
+ if (args.length > 0 && args[0] === resources_1.TestRecoverData.baseAddress) {
379
+ return Promise.resolve((0, resources_1.baseAddressBalance)(1000000, [
380
+ {
381
+ TG3XXyExBkPp9nzdajDZsozEu4BkaSJozs: '1100000000',
382
+ },
383
+ ]));
384
+ }
385
+ return undefined;
386
+ });
387
+ node_test_1.mock.method(src_1.Trx.prototype, 'getTriggerSmartContractTransaction', (...args) => {
388
+ return Promise.resolve(resources_1.SampleRawTokenSendTxn);
389
+ });
390
+ await node_assert_1.default.rejects(basecoin.recover({
391
+ userKey: resources_1.TestRecoverData.userKey,
392
+ backupKey: resources_1.TestRecoverData.backupKey,
393
+ bitgoKey: resources_1.TestRecoverData.bitgoKey,
394
+ tokenContractAddress: 'TG3XXyExBkPp9nzdajDZsozEu4BkaSJozs',
395
+ recoveryDestination: resources_1.TestRecoverData.recoveryDestination,
396
+ }), {
397
+ message: "Amount of funds to recover 1000000 is less than 100000000 and wouldn't be able to fund a trc20 send",
398
+ });
399
+ });
400
+ });
401
+ (0, node_test_1.describe)('Build Unsigned Consolidation Recoveries', () => {
402
+ (0, node_test_1.afterEach)(() => {
403
+ node_test_1.mock.reset();
404
+ });
405
+ (0, node_test_1.it)('should throw if startingScanIndex is not ge to 1', async () => {
406
+ await node_assert_1.default.rejects(basecoin.recoverConsolidations({
407
+ userKey: resources_1.TestRecoverData.userKey,
408
+ backupKey: resources_1.TestRecoverData.backupKey,
409
+ bitgoKey: resources_1.TestRecoverData.bitgoKey,
410
+ startingScanIndex: -1,
411
+ }), {
412
+ message: 'Invalid starting or ending index to scan for addresses. startingScanIndex: -1, endingScanIndex: 19.',
413
+ });
414
+ });
415
+ (0, node_test_1.it)('should throw if scan factor is too high', async () => {
416
+ await node_assert_1.default.rejects(basecoin.recoverConsolidations({
417
+ userKey: resources_1.TestRecoverData.userKey,
418
+ backupKey: resources_1.TestRecoverData.backupKey,
419
+ bitgoKey: resources_1.TestRecoverData.bitgoKey,
420
+ startingScanIndex: 1,
421
+ endingScanIndex: 300,
422
+ }), {
423
+ message: 'Invalid starting or ending index to scan for addresses. startingScanIndex: 1, endingScanIndex: 300.',
424
+ });
425
+ });
426
+ (0, node_test_1.it)('should build consolidate recoveries', async () => {
427
+ node_test_1.mock.method(src_1.Trx.prototype, 'getAccountBalancesFromNode', (...args) => {
428
+ if (args.length > 0 && args[0] === resources_1.TestRecoverData.firstReceiveAddress) {
429
+ return Promise.resolve((0, resources_1.receiveAddressBalance)(102100000, resources_1.TestRecoverData.firstReceiveAddress));
430
+ }
431
+ if (args.length > 0 && args[0] === resources_1.TestRecoverData.secondReceiveAddress) {
432
+ return Promise.resolve((0, resources_1.receiveAddressBalance)(50000000, resources_1.TestRecoverData.secondReceiveAddress));
433
+ }
434
+ return undefined;
435
+ });
436
+ node_test_1.mock.method(src_1.Trx.prototype, 'getBuildTransaction', (...args) => {
437
+ if (args.length > 0 && args[0] === baseAddrHex && args[1] === firstReceiveAddrHex && args[2] === 100000000) {
438
+ return Promise.resolve((0, resources_1.creationTransaction)(firstReceiveAddrHex, baseAddrHex, 100000000));
439
+ }
440
+ if (args.length > 0 && args[0] === baseAddrHex && args[1] === secondReceiveAddrHex && args[2] === 47900000) {
441
+ return Promise.resolve((0, resources_1.creationTransaction)(secondReceiveAddrHex, baseAddrHex, 47900000));
442
+ }
443
+ return undefined;
444
+ });
445
+ const firstReceiveAddrHex = src_1.Utils.getHexAddressFromBase58Address(resources_1.TestRecoverData.firstReceiveAddress);
446
+ const secondReceiveAddrHex = src_1.Utils.getHexAddressFromBase58Address(resources_1.TestRecoverData.secondReceiveAddress);
447
+ const baseAddrHex = src_1.Utils.getHexAddressFromBase58Address(resources_1.TestRecoverData.baseAddress);
448
+ const res = await basecoin.recoverConsolidations({
449
+ userKey: resources_1.TestRecoverData.userKey,
450
+ backupKey: resources_1.TestRecoverData.backupKey,
451
+ bitgoKey: resources_1.TestRecoverData.bitgoKey,
452
+ startingScanIndex: 1,
453
+ endingScanIndex: 3,
454
+ });
455
+ node_assert_1.default.notEqual(res.length, 0);
456
+ node_assert_1.default.ok(Object.prototype.hasOwnProperty.call(res, 'transactions'));
457
+ node_assert_1.default.equal(res.transactions.length, 2);
458
+ const txn1 = res.transactions[0];
459
+ const rawData1 = JSON.parse(txn1.txHex).raw_data;
460
+ node_assert_1.default.ok(Object.prototype.hasOwnProperty.call(rawData1, 'contract'));
461
+ const value1 = rawData1.contract[0].parameter.value;
462
+ node_assert_1.default.equal(value1.amount, 100000000);
463
+ node_assert_1.default.equal(src_1.Utils.getBase58AddressFromHex(value1.owner_address), resources_1.TestRecoverData.firstReceiveAddress);
464
+ node_assert_1.default.equal(src_1.Utils.getBase58AddressFromHex(value1.to_address), resources_1.TestRecoverData.baseAddress);
465
+ const txn2 = res.transactions[1];
466
+ const rawData2 = JSON.parse(txn2.txHex).raw_data;
467
+ node_assert_1.default.ok(Object.prototype.hasOwnProperty.call(rawData2, 'contract'));
468
+ const value2 = rawData2.contract[0].parameter.value;
469
+ node_assert_1.default.equal(value2.amount, 47900000);
470
+ node_assert_1.default.equal(src_1.Utils.getBase58AddressFromHex(value2.owner_address), resources_1.TestRecoverData.secondReceiveAddress);
471
+ node_assert_1.default.equal(src_1.Utils.getBase58AddressFromHex(value2.to_address), resources_1.TestRecoverData.baseAddress);
472
+ });
473
+ (0, node_test_1.it)('should build consolidate token recoveries', async () => {
474
+ node_test_1.mock.method(src_1.Trx.prototype, 'getAccountBalancesFromNode', (...args) => {
475
+ if (args.length > 0 && args[0] === resources_1.TestRecoverData.firstReceiveAddress) {
476
+ return Promise.resolve((0, resources_1.receiveAddressBalance)(202100000, resources_1.TestRecoverData.firstReceiveAddress, [
477
+ {
478
+ TSdZwNqpHofzP6BsBKGQUWdBeJphLmF6id: '1100000000',
479
+ },
480
+ ]));
481
+ }
482
+ if (args.length > 0 && args[0] === resources_1.TestRecoverData.secondReceiveAddress) {
483
+ return Promise.resolve((0, resources_1.receiveAddressBalance)(500, resources_1.TestRecoverData.secondReceiveAddress));
484
+ }
485
+ return undefined;
486
+ });
487
+ node_test_1.mock.method(src_1.Trx.prototype, 'getBuildTransaction', (...args) => {
488
+ if (args.length > 0 && args[0] === baseAddrHex && args[1] === firstReceiveAddrHex && args[2] === 1100000000) {
489
+ return Promise.resolve((0, resources_1.creationTransaction)(firstReceiveAddrHex, baseAddrHex, 1100000000));
490
+ }
491
+ return undefined;
492
+ });
493
+ const firstReceiveAddrHex = src_1.Utils.getHexAddressFromBase58Address(resources_1.TestRecoverData.firstReceiveAddress);
494
+ const baseAddrHex = src_1.Utils.getHexAddressFromBase58Address(resources_1.TestRecoverData.baseAddress);
495
+ const res = await basecoin.recoverConsolidations({
496
+ userKey: resources_1.TestRecoverData.userKey,
497
+ backupKey: resources_1.TestRecoverData.backupKey,
498
+ bitgoKey: resources_1.TestRecoverData.bitgoKey,
499
+ tokenContractAddress: 'TSdZwNqpHofzP6BsBKGQUWdBeJphLmF6id',
500
+ startingScanIndex: 1,
501
+ endingScanIndex: 3,
502
+ });
503
+ node_assert_1.default.notEqual(res.length, 0);
504
+ node_assert_1.default.ok(Object.prototype.hasOwnProperty.call(res, 'transactions'));
505
+ node_assert_1.default.equal(res.transactions.length, 1);
506
+ const txn = res.transactions[0];
507
+ const rawData = JSON.parse(txn.txHex).raw_data;
508
+ node_assert_1.default.ok(Object.prototype.hasOwnProperty.call(rawData, 'contract'));
509
+ const value = rawData.contract[0].parameter.value;
510
+ node_assert_1.default.equal(value.data, 'a9059cbb000000000000000000000000c25420255c2c5a2dd54ef69f92ef261e6bd4216a000000000000000000000000000000000000000000000000000000004190ab00');
511
+ node_assert_1.default.equal(src_1.Utils.getBase58AddressFromHex(value.owner_address), resources_1.TestRecoverData.firstReceiveAddress);
512
+ node_assert_1.default.equal(src_1.Utils.getBase58AddressFromHex(value.contract_address), 'TSdZwNqpHofzP6BsBKGQUWdBeJphLmF6id');
513
+ });
514
+ (0, node_test_1.it)('should skip building consolidate transaction if balance is lower than reserved fee', async () => {
515
+ node_test_1.mock.method(src_1.Trx.prototype, 'getAccountBalancesFromNode', (...args) => {
516
+ if (args.length > 0 && args[0] === resources_1.TestRecoverData.firstReceiveAddress) {
517
+ return Promise.resolve((0, resources_1.receiveAddressBalance)(102100000, resources_1.TestRecoverData.firstReceiveAddress));
518
+ }
519
+ if (args.length > 0 && args[0] === resources_1.TestRecoverData.secondReceiveAddress) {
520
+ return Promise.resolve((0, resources_1.receiveAddressBalance)(2000000, resources_1.TestRecoverData.secondReceiveAddress));
521
+ }
522
+ return undefined;
523
+ });
524
+ node_test_1.mock.method(src_1.Trx.prototype, 'getBuildTransaction', (...args) => {
525
+ if (args.length > 0 && args[0] === baseAddrHex && args[1] === firstReceiveAddrHex && args[2] === 100000000) {
526
+ return Promise.resolve((0, resources_1.creationTransaction)(firstReceiveAddrHex, baseAddrHex, 100000000));
527
+ }
528
+ return undefined;
529
+ });
530
+ const firstReceiveAddrHex = src_1.Utils.getHexAddressFromBase58Address(resources_1.TestRecoverData.firstReceiveAddress);
531
+ const baseAddrHex = src_1.Utils.getHexAddressFromBase58Address(resources_1.TestRecoverData.baseAddress);
532
+ const res = await basecoin.recoverConsolidations({
533
+ userKey: resources_1.TestRecoverData.userKey,
534
+ backupKey: resources_1.TestRecoverData.backupKey,
535
+ bitgoKey: resources_1.TestRecoverData.bitgoKey,
536
+ startingScanIndex: 1,
537
+ endingScanIndex: 3,
538
+ });
539
+ node_assert_1.default.notEqual(res.length, 0);
540
+ node_assert_1.default.ok(Object.prototype.hasOwnProperty.call(res, 'transactions'));
541
+ node_assert_1.default.equal(res.transactions.length, 1);
542
+ const txn1 = res.transactions[0];
543
+ const rawData1 = JSON.parse(txn1.txHex).raw_data;
544
+ node_assert_1.default.ok(Object.prototype.hasOwnProperty.call(rawData1, 'contract'));
545
+ const value1 = rawData1.contract[0].parameter.value;
546
+ node_assert_1.default.equal(value1.amount, 100000000);
547
+ node_assert_1.default.equal(src_1.Utils.getBase58AddressFromHex(value1.owner_address), resources_1.TestRecoverData.firstReceiveAddress);
548
+ node_assert_1.default.equal(src_1.Utils.getBase58AddressFromHex(value1.to_address), resources_1.TestRecoverData.baseAddress);
549
+ });
550
+ });
551
+ (0, node_test_1.describe)('isWalletAddress', () => {
552
+ (0, node_test_1.it)('should verify root address (index 0)', async function () {
553
+ const result = await basecoin.isWalletAddress({
554
+ address: testWalletData.rootAddress,
555
+ keychains: testWalletData.keychains,
556
+ index: 0,
557
+ });
558
+ node_assert_1.default.equal(result, true);
559
+ });
560
+ (0, node_test_1.it)('should verify receive address (index > 0)', async function () {
561
+ const result = await basecoin.isWalletAddress({
562
+ address: testWalletData.receiveAddress,
563
+ keychains: testWalletData.keychains,
564
+ index: testWalletData.receiveAddressIndex,
565
+ chain: 0,
566
+ });
567
+ node_assert_1.default.equal(result, true);
568
+ });
569
+ (0, node_test_1.it)('should verify address with index in coinSpecific', async function () {
570
+ const result = await basecoin.isWalletAddress({
571
+ address: testWalletData.rootAddress,
572
+ keychains: testWalletData.keychains,
573
+ coinSpecific: { index: 0 },
574
+ });
575
+ node_assert_1.default.equal(result, true);
576
+ });
577
+ (0, node_test_1.it)('should verify address with string index', async function () {
578
+ const result = await basecoin.isWalletAddress({
579
+ address: testWalletData.rootAddress,
580
+ keychains: testWalletData.keychains,
581
+ index: '0',
582
+ });
583
+ node_assert_1.default.equal(result, true);
584
+ });
585
+ (0, node_test_1.it)('should return false for wrong address at index 0', async function () {
586
+ const result = await basecoin.isWalletAddress({
587
+ address: testWalletData.receiveAddress, // wrong address for index 0
588
+ keychains: testWalletData.keychains,
589
+ index: 0,
590
+ });
591
+ node_assert_1.default.equal(result, false);
592
+ });
593
+ (0, node_test_1.it)('should return false for wrong address at receive index', async function () {
594
+ const result = await basecoin.isWalletAddress({
595
+ address: testWalletData.rootAddress, // wrong address for index 1
596
+ keychains: testWalletData.keychains,
597
+ index: testWalletData.receiveAddressIndex,
598
+ chain: 0,
599
+ });
600
+ node_assert_1.default.equal(result, false);
601
+ });
602
+ (0, node_test_1.it)('should throw for invalid address', async function () {
603
+ await node_assert_1.default.rejects(basecoin.isWalletAddress({
604
+ address: 'invalid-address',
605
+ keychains: testWalletData.keychains,
606
+ index: 0,
607
+ }), {
608
+ message: 'Invalid address: invalid-address',
609
+ });
610
+ });
611
+ (0, node_test_1.it)('should throw for missing index', async function () {
612
+ await node_assert_1.default.rejects(basecoin.isWalletAddress({
613
+ address: testWalletData.rootAddress,
614
+ keychains: testWalletData.keychains,
615
+ }), {
616
+ message: 'Invalid or missing index for address verification',
617
+ });
618
+ });
619
+ (0, node_test_1.it)('should throw for missing bitgo key on root address verification', async function () {
620
+ await node_assert_1.default.rejects(basecoin.isWalletAddress({
621
+ address: testWalletData.rootAddress,
622
+ keychains: testWalletData.keychains.slice(0, 2), // only user and backup keys
623
+ index: 0,
624
+ }), {
625
+ message: 'BitGo public key required for root address verification',
626
+ });
627
+ });
628
+ (0, node_test_1.it)('should throw for missing user key on receive address verification', async function () {
629
+ await node_assert_1.default.rejects(basecoin.isWalletAddress({
630
+ address: testWalletData.receiveAddress,
631
+ keychains: [], // no keys
632
+ index: testWalletData.receiveAddressIndex,
633
+ }), {
634
+ message: 'User public key required for receive address verification',
635
+ });
636
+ });
637
+ });
638
+ });
639
+ //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"trx.js","sourceRoot":"","sources":["../../../test/unit/trx.ts"],"names":[],"mappings":"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","sourcesContent":["import assert from 'node:assert';\nimport { afterEach, before, describe, it, mock } from 'node:test';\nimport { BitGoAPI } from '@bitgo-beta/sdk-api';\nimport { TestBitGoAPI, TestBitGo } from '@bitgo-beta/sdk-test';\nimport * as _ from 'lodash';\nimport { Trx, Ttrx, Utils } from '../../src';\nimport { signTxOptions, mockTx } from '../fixtures';\nimport {\n  baseAddressBalance,\n  SampleRawTokenSendTxn,\n  receiveAddressBalance,\n  TestRecoverData,\n  creationTransaction,\n} from '../resources';\n\ndescribe('TRON:', function () {\n  const bitgo: TestBitGoAPI = TestBitGo.decorate(BitGoAPI, { env: 'test' });\n  bitgo.initializeTestVars();\n  bitgo.safeRegister('trx', Trx.createInstance);\n  bitgo.safeRegister('ttrx', Ttrx.createInstance);\n\n  let basecoin;\n\n  // Test data from wallet 693b011a3ec26986f569b02140c7627e\n  const testWalletData = {\n    rootAddress: 'TAf36b36eqoMCzJJm3jwSsP81UvkMxrPbi',\n    receiveAddress: 'TFaD6DeKFMcBuGuDD7LbbqxTnKunhXfdya',\n    receiveAddressIndex: 2,\n    keychains: [\n      {\n        id: '693b0110271fc3f5749754097793bb8d',\n        pub: 'xpub661MyMwAqRbcFsVAdZyN2m8p21WHXg8NRNkqKApyS5gwmFsPdRTrmHYCnzR9vYe8DQ4uWGCBcAAsWE3r97HsFS3K2faZ2ejXNhHxdEoAEWC',\n      },\n      {\n        id: '693b011065b9c4674825ce1f849b7bef',\n        pub: 'xpub661MyMwAqRbcErKpZr9ztTFJk6fzXWatMFgRnpXfsjybWBfE9847EVGrHHBsGP8fcnzJmJuevAbPUEpjHTjEEWfYUWNMEDahvssQein848o',\n      },\n      {\n        id: '693b01117c41846abb04818815b89b6c',\n        pub: 'xpub661MyMwAqRbcFqZd7XU9DFW4f29VJzQt7UCA51ypaWa5ymhQ2pRZDTgViw3vZ56PqZ8dj1cracN3fAWhaiG1QKj9mvyt9Cba4nM2tPibNKw',\n      },\n    ],\n  };\n\n  before(function () {\n    basecoin = bitgo.coin('ttrx');\n  });\n\n  it('should instantiate the coin', function () {\n    const basecoin = bitgo.coin('trx');\n    assert.ok(basecoin instanceof Trx);\n  });\n\n  it('explain a txHex', async function () {\n    const txHex = JSON.stringify(mockTx);\n    const explainParams = {\n      txHex,\n      feeInfo: { fee: 1 },\n      txID: mockTx.txID,\n    };\n    const explanation = await basecoin.explainTransaction(explainParams);\n    const toAddress = Utils.getBase58AddressFromHex(mockTx.raw_data.contract[0].parameter.value.to_address);\n    assert.equal(explanation.id, mockTx.txID);\n    assert.equal(explanation.outputs.length, 1);\n    assert.equal(explanation.outputs[0].amount, '10');\n    assert.equal(explanation.outputs[0].address, toAddress);\n    assert.equal(explanation.outputAmount, '10');\n    assert.equal(explanation.changeAmount, '0');\n    assert.equal(explanation.changeOutputs.length, 0);\n    assert.equal(explanation.fee.fee, 1);\n    assert.equal(explanation.expiration, mockTx.raw_data.expiration);\n    assert.equal(explanation.timestamp, mockTx.raw_data.timestamp);\n  });\n\n  it('should check valid addresses', function () {\n    const badAddresses = [\n      '',\n      null,\n      'xxxx',\n      'YZ09fd-',\n      '412C2BA4A9FF6C53207DC5B686BFECF75EA7B805772',\n      '412C2BA4A9FF6C53207DC5B686BFECF75EA7B80',\n      'TBChwKYNaTo4a4N68Me1qEiiKsRDspXqLLZ',\n      '0x96be113992bdc3be24c11f6017085b605d253649',\n      '0x341qg3922b1',\n      '41E0C0F581D7D02D40826C1C6CBEE71F625D6344D0',\n      '412C2BA4A9FF6C53207DC5B686BFECF75EA7B80577',\n      '418840E6C55B9ADA326D211D818C34A994AECED808',\n      '412A2B9F7641D0750C1E822D0E49EF765C8106524B',\n      '41A614F803B6FD780986A42C78EC9C7F77E6DED13C',\n      '418840E6C55B9ADA326D211D818C34A994AECED808',\n    ];\n    const goodAddresses = ['TBChwKYNaTo4a4N68Me1qEiiKsRDspXqLp', 'TPcf5jtYUhCN1X14tN577zF4NepbDZbxT7'];\n\n    badAddresses.map((addr) => {\n      assert.equal(basecoin.isValidAddress(addr), false);\n    });\n    goodAddresses.map((addr) => {\n      assert.equal(basecoin.isValidAddress(addr), true);\n    });\n  });\n\n  it('should throw if the params object is missing parameters', async function () {\n    const explainParams = {\n      feeInfo: { fee: 1 },\n      txID: mockTx.txID,\n      txHex: null,\n    };\n    await assert.rejects(basecoin.explainTransaction(explainParams), {\n      message: 'missing explain tx parameters',\n    });\n  });\n\n  it('explain an half-signed/fully signed transaction', async function () {\n    const txHex = JSON.stringify(mockTx);\n    const explainParams = {\n      halfSigned: { txHex },\n      feeInfo: { fee: 1 },\n      txID: mockTx.txID,\n    };\n    const explanation = await basecoin.explainTransaction(explainParams);\n    const toAddress = Utils.getBase58AddressFromHex(mockTx.raw_data.contract[0].parameter.value.to_address);\n    assert.equal(explanation.id, mockTx.txID);\n    assert.equal(explanation.outputs.length, 1);\n    assert.equal(explanation.outputs[0].amount, '10');\n    assert.equal(explanation.outputs[0].address, toAddress);\n    assert.equal(explanation.outputAmount, '10');\n    assert.equal(explanation.changeAmount, '0');\n    assert.equal(explanation.changeOutputs.length, 0);\n    assert.equal(explanation.fee.fee, 1);\n    assert.equal(explanation.expiration, mockTx.raw_data.expiration);\n    assert.equal(explanation.timestamp, mockTx.raw_data.timestamp);\n  });\n\n  it('should sign a half signed tx', async function () {\n    const tx = await basecoin.signTransaction(signTxOptions);\n    const unsignedTxJson = JSON.parse(signTxOptions.txPrebuild.txHex);\n    const signedTxJson = JSON.parse(tx.halfSigned.txHex);\n\n    assert.equal(signedTxJson.txID, unsignedTxJson.txID);\n    assert.equal(signedTxJson.raw_data_hex, unsignedTxJson.raw_data_hex);\n    assert.deepStrictEqual(JSON.stringify(signedTxJson.raw_data), JSON.stringify(unsignedTxJson.raw_data));\n    assert.equal(signedTxJson.signature.length, 1);\n    assert.equal(\n      signedTxJson.signature[0],\n      '0a9944316924ec7fba4895f1ea1e7cc95f9e2b828ae268a48a8dbeddef40c6f5e127170a95aed9f3f5425b13058d0cb6ef1f5c2213190e482e87043691f22e6800'\n    );\n  });\n\n  it('should sign with an Xprv a half signed tx', async function () {\n    const p = {\n      prv: 'xprv9s21ZrQH143K2sg2Cukk5XqLQdrYnMCDah3y1FFVy6Hz9bQfqMSfmUiHPVHKhcUyft3N1emE5FudJVxgFm5N12MAg5o7DTPsDATTkwNgr73',\n      txPrebuild: {\n        txHex: signTxOptions.txPrebuild.txHex,\n      },\n    };\n    const tx = await basecoin.signTransaction(p);\n    const unsignedTxJson = JSON.parse(signTxOptions.txPrebuild.txHex);\n    const signedTxJson = JSON.parse(tx.halfSigned.txHex);\n\n    assert.equal(signedTxJson.txID, unsignedTxJson.txID);\n    assert.equal(signedTxJson.raw_data_hex, unsignedTxJson.raw_data_hex);\n    assert.deepStrictEqual(JSON.stringify(signedTxJson.raw_data), JSON.stringify(unsignedTxJson.raw_data));\n    assert.equal(signedTxJson.signature.length, 1);\n    assert.equal(\n      signedTxJson.signature[0],\n      '65e56f53a458c6f82d1ef39b2cf5be685a906ad22bb02699f907fcb72ef26f1e91cfc2b6a43bf5432faa0b63bdc5aebf1dc2f49a675d28d23fd7e038b3358b0600'\n    );\n  });\n\n  it('should add feeLimit to recipient', async function () {\n    const feeLimit = 100;\n    const buildParams = {\n      recipients: [{ data: 'test' }],\n      feeLimit,\n    };\n    basecoin.getExtraPrebuildParams(buildParams);\n    assert.equal((buildParams as any).recipients[0].feeLimit, feeLimit);\n  });\n\n  it('should`t add any new field', async function () {\n    const buildParams = {\n      recipients: [{ data: 'test' }],\n    };\n    const unmodifiedBuildParams = _.cloneDeep(buildParams);\n    await basecoin.getExtraPrebuildParams(buildParams);\n    assert.deepStrictEqual(buildParams, unmodifiedBuildParams);\n  });\n\n  describe('Keypairs:', () => {\n    it('should generate a keypair from random seed', function () {\n      const keyPair = basecoin.generateKeyPair();\n      assert.ok(Object.prototype.hasOwnProperty.call(keyPair, 'pub'));\n      assert.ok(Object.prototype.hasOwnProperty.call(keyPair, 'prv'));\n      assert.equal(basecoin.isValidPub(keyPair.pub), true);\n    });\n\n    it('should generate a keypair from a seed', function () {\n      const seedText =\n        '80350b4208d381fbfe2276a326603049fe500731c46d3c9936b5ce036b51377f24bab7dd0c2af7f107416ef858ff79b0670c72406dad064e72bb17fc0a9038bb';\n      const seed = Buffer.from(seedText, 'hex');\n      const keyPair = basecoin.generateKeyPair(seed);\n      assert.equal(\n        keyPair.pub,\n        'xpub661MyMwAqRbcFAwqvSGbk35kJf7CQqdN1w4CMUBBTqH5e3ivjU6D8ugv9hRSgRbRenC4w3ahXdLVahwjgjXhSuQKMdNdn55Y9TNSagBktws'\n      );\n      assert.equal(\n        keyPair.prv,\n        'xprv9s21ZrQH143K2gsNpQjbNu91kdGi1NuWei8bZ5mZuVk6mFPnBvmxb7NSJQdbZW3FGpK3Ycn7jorAXcEzMvviGtbyBz5tBrjfnWyQp3g75FK'\n      );\n    });\n  });\n\n  describe('Build Unsigned Sweep', () => {\n    afterEach(() => {\n      mock.reset();\n    });\n\n    it('should recover trx from base address to recovery address', async function () {\n      mock.method(Trx.prototype as any, 'getAccountBalancesFromNode', (...args) => {\n        if (args.length > 0 && args[0] === TestRecoverData.baseAddress) {\n          return Promise.resolve(baseAddressBalance(3000000));\n        }\n\n        return undefined;\n      });\n\n      const baseAddrHex = Utils.getHexAddressFromBase58Address(TestRecoverData.baseAddress);\n      const destinationHex = Utils.getHexAddressFromBase58Address(TestRecoverData.recoveryDestination);\n\n      mock.method(Trx.prototype as any, 'getBuildTransaction', (...args) => {\n        if (args.length > 0 && args[0] === destinationHex && args[1] === baseAddrHex && args[2] === 900000) {\n          return Promise.resolve(creationTransaction(baseAddrHex, destinationHex, 900000));\n        }\n\n        return undefined;\n      });\n\n      const res = await basecoin.recover({\n        userKey: TestRecoverData.userKey,\n        backupKey: TestRecoverData.backupKey,\n        bitgoKey: TestRecoverData.bitgoKey,\n        recoveryDestination: TestRecoverData.recoveryDestination,\n      });\n      assert.notEqual(res.length, 0);\n      assert.ok(Object.prototype.hasOwnProperty.call(res, 'txHex'));\n      assert.ok(Object.prototype.hasOwnProperty.call(res, 'feeInfo'));\n      const rawData = JSON.parse(res.txHex).raw_data;\n      assert.ok(Object.prototype.hasOwnProperty.call(rawData, 'contract'));\n      const value = rawData.contract[0].parameter.value;\n      assert.equal(value.amount, 900000);\n      assert.equal(Utils.getBase58AddressFromHex(value.owner_address), TestRecoverData.baseAddress);\n      assert.equal(Utils.getBase58AddressFromHex(value.to_address), TestRecoverData.recoveryDestination);\n    });\n\n    it('should recover trx from base address to recovery address with scan passed as valid integer string', async function () {\n      mock.method(Trx.prototype as any, 'getAccountBalancesFromNode', (...args) => {\n        if (args.length > 0 && args[0] === TestRecoverData.baseAddress) {\n          return Promise.resolve(baseAddressBalance(3000000));\n        }\n\n        return undefined;\n      });\n\n      const baseAddrHex = Utils.getHexAddressFromBase58Address(TestRecoverData.baseAddress);\n      const destinationHex = Utils.getHexAddressFromBase58Address(TestRecoverData.recoveryDestination);\n\n      mock.method(Trx.prototype as any, 'getBuildTransaction', (...args) => {\n        if (args.length > 0 && args[0] === destinationHex && args[1] === baseAddrHex && args[2] === 900000) {\n          return Promise.resolve(creationTransaction(baseAddrHex, destinationHex, 900000));\n        }\n\n        return undefined;\n      });\n\n      const res = await basecoin.recover({\n        userKey: TestRecoverData.userKey,\n        backupKey: TestRecoverData.backupKey,\n        bitgoKey: TestRecoverData.bitgoKey,\n        recoveryDestination: TestRecoverData.recoveryDestination,\n        scan: '10',\n      });\n      assert.notEqual(res.length, 0);\n      assert.ok(Object.prototype.hasOwnProperty.call(res, 'txHex'));\n      assert.ok(Object.prototype.hasOwnProperty.call(res, 'feeInfo'));\n      const rawData = JSON.parse(res.txHex).raw_data;\n      assert.ok(Object.prototype.hasOwnProperty.call(rawData, 'contract'));\n      const value = rawData.contract[0].parameter.value;\n      assert.equal(value.amount, 900000);\n      assert.equal(Utils.getBase58AddressFromHex(value.owner_address), TestRecoverData.baseAddress);\n      assert.equal(Utils.getBase58AddressFromHex(value.to_address), TestRecoverData.recoveryDestination);\n    });\n\n    it('should fail recover trx from base address to recovery address with scan passed as valid integer string', async function () {\n      mock.method(Trx.prototype as any, 'getAccountBalancesFromNode', (...args) => {\n        if (args.length > 0 && args[0] === TestRecoverData.baseAddress) {\n          return Promise.resolve(baseAddressBalance(3000000));\n        }\n\n        return undefined;\n      });\n\n      const baseAddrHex = Utils.getHexAddressFromBase58Address(TestRecoverData.baseAddress);\n      const destinationHex = Utils.getHexAddressFromBase58Address(TestRecoverData.recoveryDestination);\n\n      mock.method(Trx.prototype as any, 'getBuildTransaction', (...args) => {\n        if (args.length > 0 && args[0] === destinationHex && args[1] === baseAddrHex && args[2] === 900000) {\n          return Promise.resolve(creationTransaction(baseAddrHex, destinationHex, 900000));\n        }\n\n        return undefined;\n      });\n\n      await assert.rejects(\n        basecoin.recover({\n          userKey: TestRecoverData.userKey,\n          backupKey: TestRecoverData.backupKey,\n          bitgoKey: TestRecoverData.bitgoKey,\n          recoveryDestination: TestRecoverData.recoveryDestination,\n          scan: 'abc',\n        }),\n        {\n          message: 'Invalid scanning factor',\n        }\n      );\n    });\n\n    it('should recover trx from receive address to base address', async function () {\n      mock.method(Trx.prototype as any, 'getAccountBalancesFromNode', (...args) => {\n        if (args.length > 0 && args[0] === TestRecoverData.baseAddress) {\n          return Promise.resolve(baseAddressBalance(2000000));\n        }\n\n        if (args.length > 0 && args[0] === TestRecoverData.firstReceiveAddress) {\n          return Promise.resolve(receiveAddressBalance(102100000, TestRecoverData.firstReceiveAddress));\n        }\n\n        return undefined;\n      });\n\n      const firstReceiveAddressHex = Utils.getHexAddressFromBase58Address(TestRecoverData.firstReceiveAddress);\n      const baseAddrHex = Utils.getHexAddressFromBase58Address(TestRecoverData.baseAddress);\n\n      mock.method(Trx.prototype as any, 'getBuildTransaction', (...args) => {\n        if (args.length > 0 && args[0] === baseAddrHex && args[1] === firstReceiveAddressHex && args[2] === 100000000) {\n          return Promise.resolve(creationTransaction(firstReceiveAddressHex, baseAddrHex, 100000000));\n        }\n\n        return undefined;\n      });\n\n      const res = await basecoin.recover({\n        userKey: TestRecoverData.userKey,\n        backupKey: TestRecoverData.backupKey,\n        bitgoKey: TestRecoverData.bitgoKey,\n        recoveryDestination: TestRecoverData.recoveryDestination,\n      });\n      assert.notEqual(res.length, 0);\n      assert.ok(Object.prototype.hasOwnProperty.call(res, 'txHex'));\n      assert.ok(Object.prototype.hasOwnProperty.call(res, 'feeInfo'));\n      const rawData = JSON.parse(res.txHex).raw_data;\n      assert.ok(Object.prototype.hasOwnProperty.call(rawData, 'contract'));\n      const value = rawData.contract[0].parameter.value;\n      assert.equal(value.amount, 100000000);\n      assert.equal(Utils.getBase58AddressFromHex(value.owner_address), TestRecoverData.firstReceiveAddress);\n      assert.equal(Utils.getBase58AddressFromHex(value.to_address), TestRecoverData.baseAddress);\n    });\n\n    it('should recover token from base address to recovery address', async function () {\n      mock.method(Trx.prototype as any, 'getAccountBalancesFromNode', (...args) => {\n        if (args.length > 0 && args[0] === TestRecoverData.baseAddress) {\n          return Promise.resolve(\n            baseAddressBalance(100000000, [\n              {\n                TSdZwNqpHofzP6BsBKGQUWdBeJphLmF6id: '1000000000',\n              },\n              {\n                TG3XXyExBkPp9nzdajDZsozEu4BkaSJozs: '1100000000',\n              },\n            ])\n          );\n        }\n\n        return undefined;\n      });\n\n      mock.method(Trx.prototype as any, 'getTriggerSmartContractTransaction', (...args) => {\n        return Promise.resolve(SampleRawTokenSendTxn);\n      });\n\n      const res = await basecoin.recover({\n        userKey: TestRecoverData.userKey,\n        backupKey: TestRecoverData.backupKey,\n        bitgoKey: TestRecoverData.bitgoKey,\n        tokenContractAddress: 'TG3XXyExBkPp9nzdajDZsozEu4BkaSJozs',\n        recoveryDestination: TestRecoverData.recoveryDestination,\n      });\n      assert.notEqual(res.length, 0);\n      assert.equal(res.recoveryAmount, 1100000000);\n      assert.equal(res.feeInfo.fee, '100000000');\n      const expirationDuration = res.tx.raw_data.expiration - res.tx.raw_data.timestamp;\n      assert.ok(expirationDuration >= 86400000);\n      assert.equal(res.addressInfo, undefined);\n      const rawData = JSON.parse(res.txHex).raw_data;\n      assert.ok(Object.prototype.hasOwnProperty.call(rawData, 'contract'));\n      const value = rawData.contract[0].parameter.value;\n      assert.equal(Utils.getBase58AddressFromHex(value.owner_address), TestRecoverData.baseAddress);\n      assert.equal(Utils.getBase58AddressFromHex(value.contract_address), 'TG3XXyExBkPp9nzdajDZsozEu4BkaSJozs');\n    });\n\n    it('should throw if trx balance at base address is not sufficient to cover token send', async function () {\n      mock.method(Trx.prototype as any, 'getAccountBalancesFromNode', (...args) => {\n        if (args.length > 0 && args[0] === TestRecoverData.baseAddress) {\n          return Promise.resolve(\n            baseAddressBalance(1000000, [\n              {\n                TG3XXyExBkPp9nzdajDZsozEu4BkaSJozs: '1100000000',\n              },\n            ])\n          );\n        }\n\n        return undefined;\n      });\n\n      mock.method(Trx.prototype as any, 'getTriggerSmartContractTransaction', (...args) => {\n        return Promise.resolve(SampleRawTokenSendTxn);\n      });\n\n      await assert.rejects(\n        basecoin.recover({\n          userKey: TestRecoverData.userKey,\n          backupKey: TestRecoverData.backupKey,\n          bitgoKey: TestRecoverData.bitgoKey,\n          tokenContractAddress: 'TG3XXyExBkPp9nzdajDZsozEu4BkaSJozs',\n          recoveryDestination: TestRecoverData.recoveryDestination,\n        }),\n        {\n          message:\n            \"Amount of funds to recover 1000000 is less than 100000000 and wouldn't be able to fund a trc20 send\",\n        }\n      );\n    });\n  });\n\n  describe('Build Unsigned Consolidation Recoveries', () => {\n    afterEach(() => {\n      mock.reset();\n    });\n\n    it('should throw if startingScanIndex is not ge to 1', async () => {\n      await assert.rejects(\n        basecoin.recoverConsolidations({\n          userKey: TestRecoverData.userKey,\n          backupKey: TestRecoverData.backupKey,\n          bitgoKey: TestRecoverData.bitgoKey,\n          startingScanIndex: -1,\n        }),\n        {\n          message:\n            'Invalid starting or ending index to scan for addresses. startingScanIndex: -1, endingScanIndex: 19.',\n        }\n      );\n    });\n\n    it('should throw if scan factor is too high', async () => {\n      await assert.rejects(\n        basecoin.recoverConsolidations({\n          userKey: TestRecoverData.userKey,\n          backupKey: TestRecoverData.backupKey,\n          bitgoKey: TestRecoverData.bitgoKey,\n          startingScanIndex: 1,\n          endingScanIndex: 300,\n        }),\n        {\n          message:\n            'Invalid starting or ending index to scan for addresses. startingScanIndex: 1, endingScanIndex: 300.',\n        }\n      );\n    });\n\n    it('should build consolidate recoveries', async () => {\n      mock.method(Trx.prototype as any, 'getAccountBalancesFromNode', (...args) => {\n        if (args.length > 0 && args[0] === TestRecoverData.firstReceiveAddress) {\n          return Promise.resolve(receiveAddressBalance(102100000, TestRecoverData.firstReceiveAddress));\n        }\n\n        if (args.length > 0 && args[0] === TestRecoverData.secondReceiveAddress) {\n          return Promise.resolve(receiveAddressBalance(50000000, TestRecoverData.secondReceiveAddress));\n        }\n\n        return undefined;\n      });\n\n      mock.method(Trx.prototype as any, 'getBuildTransaction', (...args) => {\n        if (args.length > 0 && args[0] === baseAddrHex && args[1] === firstReceiveAddrHex && args[2] === 100000000) {\n          return Promise.resolve(creationTransaction(firstReceiveAddrHex, baseAddrHex, 100000000));\n        }\n\n        if (args.length > 0 && args[0] === baseAddrHex && args[1] === secondReceiveAddrHex && args[2] === 47900000) {\n          return Promise.resolve(creationTransaction(secondReceiveAddrHex, baseAddrHex, 47900000));\n        }\n\n        return undefined;\n      });\n\n      const firstReceiveAddrHex = Utils.getHexAddressFromBase58Address(TestRecoverData.firstReceiveAddress);\n      const secondReceiveAddrHex = Utils.getHexAddressFromBase58Address(TestRecoverData.secondReceiveAddress);\n      const baseAddrHex = Utils.getHexAddressFromBase58Address(TestRecoverData.baseAddress);\n\n      const res = await basecoin.recoverConsolidations({\n        userKey: TestRecoverData.userKey,\n        backupKey: TestRecoverData.backupKey,\n        bitgoKey: TestRecoverData.bitgoKey,\n        startingScanIndex: 1,\n        endingScanIndex: 3,\n      });\n\n      assert.notEqual(res.length, 0);\n      assert.ok(Object.prototype.hasOwnProperty.call(res, 'transactions'));\n      assert.equal(res.transactions.length, 2);\n      const txn1 = res.transactions[0];\n      const rawData1 = JSON.parse(txn1.txHex).raw_data;\n      assert.ok(Object.prototype.hasOwnProperty.call(rawData1, 'contract'));\n      const value1 = rawData1.contract[0].parameter.value;\n      assert.equal(value1.amount, 100000000);\n      assert.equal(Utils.getBase58AddressFromHex(value1.owner_address), TestRecoverData.firstReceiveAddress);\n      assert.equal(Utils.getBase58AddressFromHex(value1.to_address), TestRecoverData.baseAddress);\n      const txn2 = res.transactions[1];\n      const rawData2 = JSON.parse(txn2.txHex).raw_data;\n      assert.ok(Object.prototype.hasOwnProperty.call(rawData2, 'contract'));\n      const value2 = rawData2.contract[0].parameter.value;\n      assert.equal(value2.amount, 47900000);\n      assert.equal(Utils.getBase58AddressFromHex(value2.owner_address), TestRecoverData.secondReceiveAddress);\n      assert.equal(Utils.getBase58AddressFromHex(value2.to_address), TestRecoverData.baseAddress);\n    });\n\n    it('should build consolidate token recoveries', async () => {\n      mock.method(Trx.prototype as any, 'getAccountBalancesFromNode', (...args) => {\n        if (args.length > 0 && args[0] === TestRecoverData.firstReceiveAddress) {\n          return Promise.resolve(\n            receiveAddressBalance(202100000, TestRecoverData.firstReceiveAddress, [\n              {\n                TSdZwNqpHofzP6BsBKGQUWdBeJphLmF6id: '1100000000',\n              },\n            ])\n          );\n        }\n\n        if (args.length > 0 && args[0] === TestRecoverData.secondReceiveAddress) {\n          return Promise.resolve(receiveAddressBalance(500, TestRecoverData.secondReceiveAddress));\n        }\n\n        return undefined;\n      });\n\n      mock.method(Trx.prototype as any, 'getBuildTransaction', (...args) => {\n        if (args.length > 0 && args[0] === baseAddrHex && args[1] === firstReceiveAddrHex && args[2] === 1100000000) {\n          return Promise.resolve(creationTransaction(firstReceiveAddrHex, baseAddrHex, 1100000000));\n        }\n\n        return undefined;\n      });\n\n      const firstReceiveAddrHex = Utils.getHexAddressFromBase58Address(TestRecoverData.firstReceiveAddress);\n      const baseAddrHex = Utils.getHexAddressFromBase58Address(TestRecoverData.baseAddress);\n\n      const res = await basecoin.recoverConsolidations({\n        userKey: TestRecoverData.userKey,\n        backupKey: TestRecoverData.backupKey,\n        bitgoKey: TestRecoverData.bitgoKey,\n        tokenContractAddress: 'TSdZwNqpHofzP6BsBKGQUWdBeJphLmF6id',\n        startingScanIndex: 1,\n        endingScanIndex: 3,\n      });\n\n      assert.notEqual(res.length, 0);\n      assert.ok(Object.prototype.hasOwnProperty.call(res, 'transactions'));\n      assert.equal(res.transactions.length, 1);\n      const txn = res.transactions[0];\n      const rawData = JSON.parse(txn.txHex).raw_data;\n      assert.ok(Object.prototype.hasOwnProperty.call(rawData, 'contract'));\n      const value = rawData.contract[0].parameter.value;\n      assert.equal(\n        value.data,\n        'a9059cbb000000000000000000000000c25420255c2c5a2dd54ef69f92ef261e6bd4216a000000000000000000000000000000000000000000000000000000004190ab00'\n      );\n      assert.equal(Utils.getBase58AddressFromHex(value.owner_address), TestRecoverData.firstReceiveAddress);\n      assert.equal(Utils.getBase58AddressFromHex(value.contract_address), 'TSdZwNqpHofzP6BsBKGQUWdBeJphLmF6id');\n    });\n\n    it('should skip building consolidate transaction if balance is lower than reserved fee', async () => {\n      mock.method(Trx.prototype as any, 'getAccountBalancesFromNode', (...args) => {\n        if (args.length > 0 && args[0] === TestRecoverData.firstReceiveAddress) {\n          return Promise.resolve(receiveAddressBalance(102100000, TestRecoverData.firstReceiveAddress));\n        }\n\n        if (args.length > 0 && args[0] === TestRecoverData.secondReceiveAddress) {\n          return Promise.resolve(receiveAddressBalance(2000000, TestRecoverData.secondReceiveAddress));\n        }\n\n        return undefined;\n      });\n\n      mock.method(Trx.prototype as any, 'getBuildTransaction', (...args) => {\n        if (args.length > 0 && args[0] === baseAddrHex && args[1] === firstReceiveAddrHex && args[2] === 100000000) {\n          return Promise.resolve(creationTransaction(firstReceiveAddrHex, baseAddrHex, 100000000));\n        }\n\n        return undefined;\n      });\n\n      const firstReceiveAddrHex = Utils.getHexAddressFromBase58Address(TestRecoverData.firstReceiveAddress);\n      const baseAddrHex = Utils.getHexAddressFromBase58Address(TestRecoverData.baseAddress);\n\n      const res = await basecoin.recoverConsolidations({\n        userKey: TestRecoverData.userKey,\n        backupKey: TestRecoverData.backupKey,\n        bitgoKey: TestRecoverData.bitgoKey,\n        startingScanIndex: 1,\n        endingScanIndex: 3,\n      });\n\n      assert.notEqual(res.length, 0);\n      assert.ok(Object.prototype.hasOwnProperty.call(res, 'transactions'));\n      assert.equal(res.transactions.length, 1);\n      const txn1 = res.transactions[0];\n      const rawData1 = JSON.parse(txn1.txHex).raw_data;\n      assert.ok(Object.prototype.hasOwnProperty.call(rawData1, 'contract'));\n      const value1 = rawData1.contract[0].parameter.value;\n      assert.equal(value1.amount, 100000000);\n      assert.equal(Utils.getBase58AddressFromHex(value1.owner_address), TestRecoverData.firstReceiveAddress);\n      assert.equal(Utils.getBase58AddressFromHex(value1.to_address), TestRecoverData.baseAddress);\n    });\n  });\n\n  describe('isWalletAddress', () => {\n    it('should verify root address (index 0)', async function () {\n      const result = await basecoin.isWalletAddress({\n        address: testWalletData.rootAddress,\n        keychains: testWalletData.keychains,\n        index: 0,\n      });\n      assert.equal(result, true);\n    });\n\n    it('should verify receive address (index > 0)', async function () {\n      const result = await basecoin.isWalletAddress({\n        address: testWalletData.receiveAddress,\n        keychains: testWalletData.keychains,\n        index: testWalletData.receiveAddressIndex,\n        chain: 0,\n      });\n      assert.equal(result, true);\n    });\n\n    it('should verify address with index in coinSpecific', async function () {\n      const result = await basecoin.isWalletAddress({\n        address: testWalletData.rootAddress,\n        keychains: testWalletData.keychains,\n        coinSpecific: { index: 0 },\n      });\n      assert.equal(result, true);\n    });\n\n    it('should verify address with string index', async function () {\n      const result = await basecoin.isWalletAddress({\n        address: testWalletData.rootAddress,\n        keychains: testWalletData.keychains,\n        index: '0',\n      });\n      assert.equal(result, true);\n    });\n\n    it('should return false for wrong address at index 0', async function () {\n      const result = await basecoin.isWalletAddress({\n        address: testWalletData.receiveAddress, // wrong address for index 0\n        keychains: testWalletData.keychains,\n        index: 0,\n      });\n      assert.equal(result, false);\n    });\n\n    it('should return false for wrong address at receive index', async function () {\n      const result = await basecoin.isWalletAddress({\n        address: testWalletData.rootAddress, // wrong address for index 1\n        keychains: testWalletData.keychains,\n        index: testWalletData.receiveAddressIndex,\n        chain: 0,\n      });\n      assert.equal(result, false);\n    });\n\n    it('should throw for invalid address', async function () {\n      await assert.rejects(\n        basecoin.isWalletAddress({\n          address: 'invalid-address',\n          keychains: testWalletData.keychains,\n          index: 0,\n        }),\n        {\n          message: 'Invalid address: invalid-address',\n        }\n      );\n    });\n\n    it('should throw for missing index', async function () {\n      await assert.rejects(\n        basecoin.isWalletAddress({\n          address: testWalletData.rootAddress,\n          keychains: testWalletData.keychains,\n        }),\n        {\n          message: 'Invalid or missing index for address verification',\n        }\n      );\n    });\n\n    it('should throw for missing bitgo key on root address verification', async function () {\n      await assert.rejects(\n        basecoin.isWalletAddress({\n          address: testWalletData.rootAddress,\n          keychains: testWalletData.keychains.slice(0, 2), // only user and backup keys\n          index: 0,\n        }),\n        {\n          message: 'BitGo public key required for root address verification',\n        }\n      );\n    });\n\n    it('should throw for missing user key on receive address verification', async function () {\n      await assert.rejects(\n        basecoin.isWalletAddress({\n          address: testWalletData.receiveAddress,\n          keychains: [], // no keys\n          index: testWalletData.receiveAddressIndex,\n        }),\n        {\n          message: 'User public key required for receive address verification',\n        }\n      );\n    });\n  });\n});\n"]}