@bitgo-beta/sdk-coin-trx 1.2.3-alpha.40 → 1.2.3-alpha.401

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 (62) hide show
  1. package/.mocharc.yml +1 -1
  2. package/CHANGELOG.md +988 -0
  3. package/dist/resources/protobuf/Contract.proto +32 -0
  4. package/dist/resources/protobuf/tron.d.ts +1478 -214
  5. package/dist/resources/protobuf/tron.js +6312 -2600
  6. package/dist/resources/protobuf/tron.proto +6 -0
  7. package/package.json +16 -14
  8. package/resources/protobuf/Contract.proto +32 -0
  9. package/resources/protobuf/tron.d.ts +1478 -214
  10. package/resources/protobuf/tron.js +6312 -2600
  11. package/resources/protobuf/tron.proto +6 -0
  12. package/dist/src/index.d.ts +0 -6
  13. package/dist/src/index.d.ts.map +0 -1
  14. package/dist/src/index.js +0 -18
  15. package/dist/src/lib/address.d.ts +0 -11
  16. package/dist/src/lib/address.d.ts.map +0 -1
  17. package/dist/src/lib/address.js +0 -13
  18. package/dist/src/lib/builder.d.ts +0 -3
  19. package/dist/src/lib/builder.d.ts.map +0 -1
  20. package/dist/src/lib/builder.js +0 -10
  21. package/dist/src/lib/contractCallBuilder.d.ts +0 -96
  22. package/dist/src/lib/contractCallBuilder.d.ts.map +0 -1
  23. package/dist/src/lib/contractCallBuilder.js +0 -281
  24. package/dist/src/lib/enum.d.ts +0 -23
  25. package/dist/src/lib/enum.d.ts.map +0 -1
  26. package/dist/src/lib/enum.js +0 -28
  27. package/dist/src/lib/iface.d.ts +0 -103
  28. package/dist/src/lib/iface.d.ts.map +0 -1
  29. package/dist/src/lib/iface.js +0 -3
  30. package/dist/src/lib/index.d.ts +0 -12
  31. package/dist/src/lib/index.d.ts.map +0 -1
  32. package/dist/src/lib/index.js +0 -39
  33. package/dist/src/lib/keyPair.d.ts +0 -44
  34. package/dist/src/lib/keyPair.d.ts.map +0 -1
  35. package/dist/src/lib/keyPair.js +0 -121
  36. package/dist/src/lib/tokenTransferBuilder.d.ts +0 -23
  37. package/dist/src/lib/tokenTransferBuilder.d.ts.map +0 -1
  38. package/dist/src/lib/tokenTransferBuilder.js +0 -42
  39. package/dist/src/lib/transaction.d.ts +0 -74
  40. package/dist/src/lib/transaction.d.ts.map +0 -1
  41. package/dist/src/lib/transaction.js +0 -226
  42. package/dist/src/lib/transactionBuilder.d.ts +0 -65
  43. package/dist/src/lib/transactionBuilder.d.ts.map +0 -1
  44. package/dist/src/lib/transactionBuilder.js +0 -215
  45. package/dist/src/lib/utils.d.ts +0 -144
  46. package/dist/src/lib/utils.d.ts.map +0 -1
  47. package/dist/src/lib/utils.js +0 -426
  48. package/dist/src/lib/wrappedBuilder.d.ts +0 -54
  49. package/dist/src/lib/wrappedBuilder.d.ts.map +0 -1
  50. package/dist/src/lib/wrappedBuilder.js +0 -108
  51. package/dist/src/register.d.ts +0 -3
  52. package/dist/src/register.d.ts.map +0 -1
  53. package/dist/src/register.js +0 -15
  54. package/dist/src/trx.d.ts +0 -208
  55. package/dist/src/trx.d.ts.map +0 -1
  56. package/dist/src/trx.js +0 -563
  57. package/dist/src/trxToken.d.ts +0 -38
  58. package/dist/src/trxToken.d.ts.map +0 -1
  59. package/dist/src/trxToken.js +0 -91
  60. package/dist/src/ttrx.d.ts +0 -13
  61. package/dist/src/ttrx.d.ts.map +0 -1
  62. package/dist/src/ttrx.js +0 -14
@@ -1,144 +0,0 @@
1
- /// <reference types="node" />
2
- import { TransferContract, RawData, AccountPermissionUpdateContract, TransactionReceipt, TriggerSmartContract } from './iface';
3
- export declare const tokenMainnetContractAddresses: string[];
4
- export declare const tokenTestnetContractAddresses: string[];
5
- /**
6
- * Tron-specific helper functions
7
- */
8
- export declare type TronBinaryLike = ByteArray | Buffer | Uint8Array | string;
9
- export declare type ByteArray = number[];
10
- /**
11
- * @param address
12
- */
13
- export declare function isBase58Address(address: string): boolean;
14
- /**
15
- * @param str
16
- */
17
- export declare function getByteArrayFromHexAddress(str: string): ByteArray;
18
- /**
19
- * @param arr
20
- */
21
- export declare function getHexAddressFromByteArray(arr: ByteArray): string;
22
- /**
23
- * @param messageToVerify
24
- * @param base58Address
25
- * @param sigHex
26
- * @param useTronHeader
27
- */
28
- export declare function verifySignature(messageToVerify: string, base58Address: string, sigHex: string, useTronHeader?: boolean): boolean;
29
- /**
30
- * @param base58
31
- */
32
- export declare function getHexAddressFromBase58Address(base58: string): string;
33
- /**
34
- * @param privateKey
35
- */
36
- export declare function getPubKeyFromPriKey(privateKey: TronBinaryLike): ByteArray;
37
- /**
38
- * @param privateKey
39
- */
40
- export declare function getAddressFromPriKey(privateKey: TronBinaryLike): ByteArray;
41
- /**
42
- * @param address
43
- */
44
- export declare function getBase58AddressFromByteArray(address: ByteArray): string;
45
- /**
46
- * @param hex
47
- */
48
- export declare function getBase58AddressFromHex(hex: string): string;
49
- /**
50
- * @param privateKey
51
- * @param transaction
52
- */
53
- export declare function signTransaction(privateKey: string | ByteArray, transaction: TransactionReceipt): TransactionReceipt;
54
- /**
55
- * @param message
56
- * @param privateKey
57
- * @param useTronHeader
58
- */
59
- export declare function signString(message: string, privateKey: string | ByteArray, useTronHeader?: boolean): string;
60
- /**
61
- * @param pubBytes
62
- */
63
- export declare function getRawAddressFromPubKey(pubBytes: TronBinaryLike): ByteArray;
64
- /**
65
- * Decodes a hex encoded transaction in its protobuf representation.
66
- *
67
- * @param hexString raw_data_hex field from tron transactions
68
- */
69
- export declare function decodeTransaction(hexString: string): RawData;
70
- /**
71
- * Decodes a transaction's raw field from a base64 encoded string. This is a protobuf representation.
72
- *
73
- * @param hexString this is the raw hexadecimal encoded string. Doc found in the following link.
74
- * @example
75
- * @see {@link https://github.com/BitGo/bitgo-account-lib/blob/5f282588701778a4421c75fa61f42713f56e95b9/resources/protobuf/tron.proto#L319}
76
- */
77
- export declare function decodeRawTransaction(hexString: string): {
78
- expiration: number;
79
- timestamp: number;
80
- contracts: Array<any>;
81
- blockBytes: string;
82
- blockHash: string;
83
- feeLimit: string;
84
- };
85
- /**
86
- * Indicates whether the passed string is a safe hex string for tron's purposes.
87
- *
88
- * @param hex A valid hex string must be a string made of numbers and characters and has an even length.
89
- */
90
- export declare function isValidHex(hex: string): boolean;
91
- /** Deserialize the segment of the txHex which corresponds with the details of the transfer
92
- *
93
- * @param transferHex is the value property of the "parameter" field of contractList[0]
94
- * */
95
- export declare function decodeTransferContract(transferHex: string): TransferContract[];
96
- /**
97
- * Deserialize the segment of the txHex corresponding with trigger smart contract
98
- *
99
- * @param {string} base64
100
- * @returns {AccountPermissionUpdateContract}
101
- */
102
- export declare function decodeTriggerSmartContract(base64: string): TriggerSmartContract[];
103
- /**
104
- * Deserialize the segment of the txHex corresponding with the details of the contract which updates
105
- * account permission
106
- *
107
- * @param {string} base64
108
- * @returns {AccountPermissionUpdateContract}
109
- */
110
- export declare function decodeAccountPermissionUpdateContract(base64: string): AccountPermissionUpdateContract;
111
- /**
112
- * @param rawTransaction
113
- */
114
- export declare function isValidTxJsonString(rawTransaction: string): boolean;
115
- /**
116
- * Returns whether the provided raw transaction accommodates to bitgo's preferred format
117
- *
118
- * @param {any} rawTransaction - The raw transaction to be checked
119
- * @returns {boolean} the validation result
120
- */
121
- export declare function isValidRawTransactionFormat(rawTransaction: any): boolean;
122
- /**
123
- * Returns an hex string of the given buffer
124
- *
125
- * @param {Buffer | Uint8Array} buffer - the buffer to be converted to hex
126
- * @returns {string} - the hex value
127
- */
128
- export declare function toHex(buffer: Buffer | Uint8Array): string;
129
- /**
130
- * Returns a Keccak-256 encoded string of the parameters
131
- *
132
- * @param types - strings describing the types of the values
133
- * @param values - value to encode
134
- * @param methodId - the first 4 bytes of the function selector
135
- */
136
- export declare function encodeDataParams(types: string[], values: any[], methodId?: string): string;
137
- /**
138
- * Returns the decoded values according to the array of types
139
- *
140
- * @param types - strings describing the types of the values
141
- * @param data - encoded string
142
- */
143
- export declare function decodeDataParams(types: string[], data: string): any[];
144
- //# sourceMappingURL=utils.d.ts.map
@@ -1 +0,0 @@
1
- {"version":3,"file":"utils.d.ts","sourceRoot":"","sources":["../../../src/lib/utils.ts"],"names":[],"mappings":"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"}
@@ -1,426 +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
- Object.defineProperty(o, k2, { enumerable: true, get: function() { return m[k]; } });
5
- }) : (function(o, m, k, k2) {
6
- if (k2 === undefined) k2 = k;
7
- o[k2] = m[k];
8
- }));
9
- var __setModuleDefault = (this && this.__setModuleDefault) || (Object.create ? (function(o, v) {
10
- Object.defineProperty(o, "default", { enumerable: true, value: v });
11
- }) : function(o, v) {
12
- o["default"] = v;
13
- });
14
- var __importStar = (this && this.__importStar) || function (mod) {
15
- if (mod && mod.__esModule) return mod;
16
- var result = {};
17
- if (mod != null) for (var k in mod) if (k !== "default" && Object.prototype.hasOwnProperty.call(mod, k)) __createBinding(result, mod, k);
18
- __setModuleDefault(result, mod);
19
- return result;
20
- };
21
- var __importDefault = (this && this.__importDefault) || function (mod) {
22
- return (mod && mod.__esModule) ? mod : { "default": mod };
23
- };
24
- Object.defineProperty(exports, "__esModule", { value: true });
25
- exports.decodeDataParams = exports.encodeDataParams = exports.toHex = exports.isValidRawTransactionFormat = exports.isValidTxJsonString = exports.decodeAccountPermissionUpdateContract = exports.decodeTriggerSmartContract = exports.decodeTransferContract = exports.isValidHex = exports.decodeRawTransaction = exports.decodeTransaction = exports.getRawAddressFromPubKey = exports.signString = exports.signTransaction = exports.getBase58AddressFromHex = exports.getBase58AddressFromByteArray = exports.getAddressFromPriKey = exports.getPubKeyFromPriKey = exports.getHexAddressFromBase58Address = exports.verifySignature = exports.getHexAddressFromByteArray = exports.getByteArrayFromHexAddress = exports.isBase58Address = exports.tokenTestnetContractAddresses = exports.tokenMainnetContractAddresses = void 0;
26
- const assert_1 = __importDefault(require("assert"));
27
- const hex = __importStar(require("@stablelib/hex"));
28
- const tronweb = __importStar(require("tronweb"));
29
- const tron_1 = require("../../resources/protobuf/tron");
30
- const sdk_core_1 = require("@bitgo-beta/sdk-core");
31
- const enum_1 = require("./enum");
32
- const utils_1 = require("ethers/lib/utils");
33
- const ADDRESS_PREFIX_REGEX = /^(41)/;
34
- const ADDRESS_PREFIX = '41';
35
- exports.tokenMainnetContractAddresses = [
36
- 'TEkxiTehnzSmSe2XqrBj4w32RUN966rdz8',
37
- 'TR7NHqjeKQxGTCi8q8ZY4pL8otSzgjLj6t',
38
- ];
39
- exports.tokenTestnetContractAddresses = [
40
- 'TSdZwNqpHofzP6BsBKGQUWdBeJphLmF6id',
41
- 'TG3XXyExBkPp9nzdajDZsozEu4BkaSJozs',
42
- ];
43
- /**
44
- * @param address
45
- */
46
- function isBase58Address(address) {
47
- return tronweb.utils.crypto.isAddressValid(address);
48
- }
49
- exports.isBase58Address = isBase58Address;
50
- /**
51
- * @param str
52
- */
53
- function getByteArrayFromHexAddress(str) {
54
- return tronweb.utils.code.hexStr2byteArray(str.replace('0x', ''));
55
- }
56
- exports.getByteArrayFromHexAddress = getByteArrayFromHexAddress;
57
- /**
58
- * @param arr
59
- */
60
- function getHexAddressFromByteArray(arr) {
61
- return tronweb.utils.code.byteArray2hexStr(arr);
62
- }
63
- exports.getHexAddressFromByteArray = getHexAddressFromByteArray;
64
- /**
65
- * @param messageToVerify
66
- * @param base58Address
67
- * @param sigHex
68
- * @param useTronHeader
69
- */
70
- function verifySignature(messageToVerify, base58Address, sigHex, useTronHeader = true) {
71
- if (!isValidHex(sigHex)) {
72
- throw new sdk_core_1.UtilsError('signature is not in a valid format, needs to be hexadecimal');
73
- }
74
- if (!isValidHex(messageToVerify)) {
75
- throw new sdk_core_1.UtilsError('message is not in a valid format, needs to be hexadecimal');
76
- }
77
- if (!isBase58Address(base58Address)) {
78
- throw new sdk_core_1.UtilsError('address needs to be base58 encoded');
79
- }
80
- return tronweb.Trx.verifySignature(messageToVerify, base58Address, sigHex, useTronHeader);
81
- }
82
- exports.verifySignature = verifySignature;
83
- /**
84
- * @param base58
85
- */
86
- function getHexAddressFromBase58Address(base58) {
87
- // pulled from: https://github.com/TRON-US/tronweb/blob/dcb8efa36a5ebb65c4dab3626e90256a453f3b0d/src/utils/help.js#L17
88
- // but they don't surface this call in index.js
89
- const bytes = tronweb.utils.crypto.decodeBase58Address(base58);
90
- return getHexAddressFromByteArray(bytes);
91
- }
92
- exports.getHexAddressFromBase58Address = getHexAddressFromBase58Address;
93
- /**
94
- * @param privateKey
95
- */
96
- function getPubKeyFromPriKey(privateKey) {
97
- return tronweb.utils.crypto.getPubKeyFromPriKey(privateKey);
98
- }
99
- exports.getPubKeyFromPriKey = getPubKeyFromPriKey;
100
- /**
101
- * @param privateKey
102
- */
103
- function getAddressFromPriKey(privateKey) {
104
- return tronweb.utils.crypto.getAddressFromPriKey(privateKey);
105
- }
106
- exports.getAddressFromPriKey = getAddressFromPriKey;
107
- /**
108
- * @param address
109
- */
110
- function getBase58AddressFromByteArray(address) {
111
- return tronweb.utils.crypto.getBase58CheckAddress(address);
112
- }
113
- exports.getBase58AddressFromByteArray = getBase58AddressFromByteArray;
114
- /**
115
- * @param hex
116
- */
117
- function getBase58AddressFromHex(hex) {
118
- const arr = getByteArrayFromHexAddress(hex);
119
- return getBase58AddressFromByteArray(arr);
120
- }
121
- exports.getBase58AddressFromHex = getBase58AddressFromHex;
122
- /**
123
- * @param privateKey
124
- * @param transaction
125
- */
126
- function signTransaction(privateKey, transaction) {
127
- return tronweb.utils.crypto.signTransaction(privateKey, transaction);
128
- }
129
- exports.signTransaction = signTransaction;
130
- /**
131
- * @param message
132
- * @param privateKey
133
- * @param useTronHeader
134
- */
135
- function signString(message, privateKey, useTronHeader = true) {
136
- return tronweb.Trx.signString(message, privateKey, useTronHeader);
137
- }
138
- exports.signString = signString;
139
- /**
140
- * @param pubBytes
141
- */
142
- function getRawAddressFromPubKey(pubBytes) {
143
- return tronweb.utils.crypto.computeAddress(pubBytes);
144
- }
145
- exports.getRawAddressFromPubKey = getRawAddressFromPubKey;
146
- /**
147
- * Decodes a hex encoded transaction in its protobuf representation.
148
- *
149
- * @param hexString raw_data_hex field from tron transactions
150
- */
151
- function decodeTransaction(hexString) {
152
- const rawTransaction = decodeRawTransaction(hexString);
153
- // there should not be multiple contracts in this data
154
- if (rawTransaction.contracts.length !== 1) {
155
- throw new sdk_core_1.UtilsError('Number of contracts is greater than 1.');
156
- }
157
- let contract;
158
- let contractType;
159
- // ensure the contract type is supported
160
- switch (rawTransaction.contracts[0].parameter.type_url) {
161
- case 'type.googleapis.com/protocol.TransferContract':
162
- contractType = enum_1.ContractType.Transfer;
163
- contract = exports.decodeTransferContract(rawTransaction.contracts[0].parameter.value);
164
- break;
165
- case 'type.googleapis.com/protocol.AccountPermissionUpdateContract':
166
- contractType = enum_1.ContractType.AccountPermissionUpdate;
167
- contract = exports.decodeAccountPermissionUpdateContract(rawTransaction.contracts[0].parameter.value);
168
- break;
169
- case 'type.googleapis.com/protocol.TriggerSmartContract':
170
- contractType = enum_1.ContractType.TriggerSmartContract;
171
- contract = exports.decodeTriggerSmartContract(rawTransaction.contracts[0].parameter.value);
172
- break;
173
- default:
174
- throw new sdk_core_1.UtilsError('Unsupported contract type');
175
- }
176
- return {
177
- contractType,
178
- contract,
179
- expiration: rawTransaction.expiration,
180
- timestamp: rawTransaction.timestamp,
181
- ref_block_bytes: rawTransaction.blockBytes,
182
- ref_block_hash: rawTransaction.blockHash,
183
- fee_limit: +rawTransaction.feeLimit,
184
- };
185
- }
186
- exports.decodeTransaction = decodeTransaction;
187
- /**
188
- * Decodes a transaction's raw field from a base64 encoded string. This is a protobuf representation.
189
- *
190
- * @param hexString this is the raw hexadecimal encoded string. Doc found in the following link.
191
- * @example
192
- * @see {@link https://github.com/BitGo/bitgo-account-lib/blob/5f282588701778a4421c75fa61f42713f56e95b9/resources/protobuf/tron.proto#L319}
193
- */
194
- function decodeRawTransaction(hexString) {
195
- const bytes = Buffer.from(hexString, 'hex');
196
- let raw;
197
- try {
198
- // we need to decode our raw_data_hex field first
199
- raw = tron_1.protocol.Transaction.raw.decode(bytes);
200
- }
201
- catch (e) {
202
- throw new sdk_core_1.UtilsError('There was an error decoding the initial raw_data_hex from the serialized tx.');
203
- }
204
- return {
205
- expiration: Number(raw.expiration),
206
- timestamp: Number(raw.timestamp),
207
- contracts: raw.contract,
208
- blockBytes: toHex(raw.refBlockBytes),
209
- feeLimit: raw.feeLimit,
210
- blockHash: toHex(raw.refBlockHash),
211
- };
212
- }
213
- exports.decodeRawTransaction = decodeRawTransaction;
214
- /**
215
- * Indicates whether the passed string is a safe hex string for tron's purposes.
216
- *
217
- * @param hex A valid hex string must be a string made of numbers and characters and has an even length.
218
- */
219
- function isValidHex(hex) {
220
- return /^(0x)?([0-9a-f]{2})+$/i.test(hex);
221
- }
222
- exports.isValidHex = isValidHex;
223
- /** Deserialize the segment of the txHex which corresponds with the details of the transfer
224
- *
225
- * @param transferHex is the value property of the "parameter" field of contractList[0]
226
- * */
227
- function decodeTransferContract(transferHex) {
228
- const contractBytes = Buffer.from(transferHex, 'base64');
229
- let transferContract;
230
- try {
231
- transferContract = tron_1.protocol.TransferContract.decode(contractBytes);
232
- }
233
- catch (e) {
234
- throw new sdk_core_1.UtilsError('There was an error decoding the transfer contract in the transaction.');
235
- }
236
- if (!transferContract.ownerAddress) {
237
- throw new sdk_core_1.UtilsError('Owner address does not exist in this transfer contract.');
238
- }
239
- if (!transferContract.toAddress) {
240
- throw new sdk_core_1.UtilsError('Destination address does not exist in this transfer contract.');
241
- }
242
- if (!transferContract.hasOwnProperty('amount')) {
243
- throw new sdk_core_1.UtilsError('Amount does not exist in this transfer contract.');
244
- }
245
- // deserialize attributes
246
- const owner_address = getBase58AddressFromByteArray(getByteArrayFromHexAddress(Buffer.from(transferContract.ownerAddress, 'base64').toString('hex')));
247
- const to_address = getBase58AddressFromByteArray(getByteArrayFromHexAddress(Buffer.from(transferContract.toAddress, 'base64').toString('hex')));
248
- const amount = transferContract.amount;
249
- return [
250
- {
251
- parameter: {
252
- value: {
253
- amount: Number(amount),
254
- owner_address,
255
- to_address,
256
- },
257
- },
258
- },
259
- ];
260
- }
261
- exports.decodeTransferContract = decodeTransferContract;
262
- /**
263
- * Deserialize the segment of the txHex corresponding with trigger smart contract
264
- *
265
- * @param {string} base64
266
- * @returns {AccountPermissionUpdateContract}
267
- */
268
- function decodeTriggerSmartContract(base64) {
269
- let contractCallDecoded;
270
- try {
271
- contractCallDecoded = tron_1.protocol.TriggerSmartContract.decode(Buffer.from(base64, 'base64')).toJSON();
272
- }
273
- catch (e) {
274
- throw new sdk_core_1.UtilsError('There was an error decoding the contract call in the transaction.');
275
- }
276
- if (!contractCallDecoded.ownerAddress) {
277
- throw new sdk_core_1.UtilsError('Owner address does not exist in this contract call.');
278
- }
279
- if (!contractCallDecoded.contractAddress) {
280
- throw new sdk_core_1.UtilsError('Destination contract address does not exist in this contract call.');
281
- }
282
- if (!contractCallDecoded.data) {
283
- throw new sdk_core_1.UtilsError('Data does not exist in this contract call.');
284
- }
285
- // deserialize attributes
286
- const owner_address = getBase58AddressFromByteArray(getByteArrayFromHexAddress(Buffer.from(contractCallDecoded.ownerAddress, 'base64').toString('hex')));
287
- const contract_address = getBase58AddressFromByteArray(getByteArrayFromHexAddress(Buffer.from(contractCallDecoded.contractAddress, 'base64').toString('hex')));
288
- const data = contractCallDecoded.data;
289
- return [
290
- {
291
- parameter: {
292
- value: {
293
- data: data,
294
- owner_address,
295
- contract_address,
296
- },
297
- },
298
- },
299
- ];
300
- }
301
- exports.decodeTriggerSmartContract = decodeTriggerSmartContract;
302
- /**
303
- * Deserialize the segment of the txHex corresponding with the details of the contract which updates
304
- * account permission
305
- *
306
- * @param {string} base64
307
- * @returns {AccountPermissionUpdateContract}
308
- */
309
- function decodeAccountPermissionUpdateContract(base64) {
310
- const accountUpdateContract = tron_1.protocol.AccountPermissionUpdateContract.decode(Buffer.from(base64, 'base64')).toJSON();
311
- assert_1.default(accountUpdateContract.ownerAddress);
312
- assert_1.default(accountUpdateContract.owner);
313
- assert_1.default(accountUpdateContract.hasOwnProperty('actives'));
314
- const ownerAddress = getBase58AddressFromByteArray(getByteArrayFromHexAddress(Buffer.from(accountUpdateContract.ownerAddress, 'base64').toString('hex')));
315
- const owner = createPermission(accountUpdateContract.owner);
316
- let witness = undefined;
317
- if (accountUpdateContract.witness) {
318
- witness = createPermission(accountUpdateContract.witness);
319
- }
320
- const activeList = accountUpdateContract.actives.map((active) => createPermission(active));
321
- return {
322
- ownerAddress,
323
- owner,
324
- witness,
325
- actives: activeList,
326
- };
327
- }
328
- exports.decodeAccountPermissionUpdateContract = decodeAccountPermissionUpdateContract;
329
- /**
330
- * @param raw
331
- */
332
- function createPermission(raw) {
333
- let permissionType;
334
- const permission = raw.permissionName.toLowerCase().trim();
335
- if (permission === 'owner') {
336
- permissionType = enum_1.PermissionType.Owner;
337
- }
338
- else if (permission === 'witness') {
339
- permissionType = enum_1.PermissionType.Witness;
340
- }
341
- else if (permission.substr(0, 6) === 'active') {
342
- permissionType = enum_1.PermissionType.Active;
343
- }
344
- else {
345
- throw new sdk_core_1.UtilsError('Permission type not parseable.');
346
- }
347
- return { type: permissionType, threshold: raw.threshold };
348
- }
349
- /**
350
- * @param rawTransaction
351
- */
352
- function isValidTxJsonString(rawTransaction) {
353
- const transaction = JSON.parse(rawTransaction);
354
- return transaction.hasOwnProperty('txID');
355
- }
356
- exports.isValidTxJsonString = isValidTxJsonString;
357
- /**
358
- * Returns whether the provided raw transaction accommodates to bitgo's preferred format
359
- *
360
- * @param {any} rawTransaction - The raw transaction to be checked
361
- * @returns {boolean} the validation result
362
- */
363
- function isValidRawTransactionFormat(rawTransaction) {
364
- if (typeof rawTransaction === 'string' && (isValidHex(rawTransaction) || isValidTxJsonString(rawTransaction))) {
365
- return true;
366
- }
367
- return false;
368
- }
369
- exports.isValidRawTransactionFormat = isValidRawTransactionFormat;
370
- /**
371
- * Returns an hex string of the given buffer
372
- *
373
- * @param {Buffer | Uint8Array} buffer - the buffer to be converted to hex
374
- * @returns {string} - the hex value
375
- */
376
- function toHex(buffer) {
377
- return hex.encode(buffer, true);
378
- }
379
- exports.toHex = toHex;
380
- /**
381
- * Returns a Keccak-256 encoded string of the parameters
382
- *
383
- * @param types - strings describing the types of the values
384
- * @param values - value to encode
385
- * @param methodId - the first 4 bytes of the function selector
386
- */
387
- function encodeDataParams(types, values, methodId) {
388
- types.forEach((type, index) => {
389
- if (type == 'address') {
390
- values[index] = values[index].replace(ADDRESS_PREFIX_REGEX, '0x');
391
- }
392
- });
393
- const abiCoder = new utils_1.AbiCoder();
394
- let data;
395
- try {
396
- data = abiCoder.encode(types, values);
397
- }
398
- catch (e) {
399
- throw new sdk_core_1.UtilsError('There was an error encoding the data params.');
400
- }
401
- if (methodId) {
402
- return utils_1.hexConcat([methodId, data]).replace(/^(0x)/, '');
403
- }
404
- else {
405
- return data.replace(/^(0x)/, '');
406
- }
407
- }
408
- exports.encodeDataParams = encodeDataParams;
409
- /**
410
- * Returns the decoded values according to the array of types
411
- *
412
- * @param types - strings describing the types of the values
413
- * @param data - encoded string
414
- */
415
- function decodeDataParams(types, data) {
416
- const abiCoder = new utils_1.AbiCoder();
417
- data = '0x' + data.substring(8);
418
- return abiCoder.decode(types, data).reduce((obj, arg, index) => {
419
- if (types[index] == 'address')
420
- arg = ADDRESS_PREFIX + arg.substr(2).toLowerCase();
421
- obj.push(arg);
422
- return obj;
423
- }, []);
424
- }
425
- exports.decodeDataParams = decodeDataParams;
426
- //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"utils.js","sourceRoot":"","sources":["../../../src/lib/utils.ts"],"names":[],"mappings":"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","sourcesContent":["import assert from 'assert';\nimport * as hex from '@stablelib/hex';\nimport * as tronweb from 'tronweb';\nimport { protocol } from '../../resources/protobuf/tron';\n\nimport { UtilsError } from '@bitgo-beta/sdk-core';\nimport {\n  TransferContract,\n  RawData,\n  AccountPermissionUpdateContract,\n  TransactionReceipt,\n  Permission,\n  TriggerSmartContract,\n} from './iface';\nimport { ContractType, PermissionType } from './enum';\nimport { AbiCoder, hexConcat } from 'ethers/lib/utils';\n\nconst ADDRESS_PREFIX_REGEX = /^(41)/;\nconst ADDRESS_PREFIX = '41';\n\nexport const tokenMainnetContractAddresses = [\n  'TEkxiTehnzSmSe2XqrBj4w32RUN966rdz8',\n  'TR7NHqjeKQxGTCi8q8ZY4pL8otSzgjLj6t',\n];\nexport const tokenTestnetContractAddresses = [\n  'TSdZwNqpHofzP6BsBKGQUWdBeJphLmF6id',\n  'TG3XXyExBkPp9nzdajDZsozEu4BkaSJozs',\n];\n\n/**\n * Tron-specific helper functions\n */\nexport type TronBinaryLike = ByteArray | Buffer | Uint8Array | string;\nexport type ByteArray = number[];\n\n/**\n * @param address\n */\nexport function isBase58Address(address: string): boolean {\n  return tronweb.utils.crypto.isAddressValid(address);\n}\n\n/**\n * @param str\n */\nexport function getByteArrayFromHexAddress(str: string): ByteArray {\n  return tronweb.utils.code.hexStr2byteArray(str.replace('0x', ''));\n}\n\n/**\n * @param arr\n */\nexport function getHexAddressFromByteArray(arr: ByteArray): string {\n  return tronweb.utils.code.byteArray2hexStr(arr);\n}\n\n/**\n * @param messageToVerify\n * @param base58Address\n * @param sigHex\n * @param useTronHeader\n */\nexport function verifySignature(\n  messageToVerify: string,\n  base58Address: string,\n  sigHex: string,\n  useTronHeader = true\n): boolean {\n  if (!isValidHex(sigHex)) {\n    throw new UtilsError('signature is not in a valid format, needs to be hexadecimal');\n  }\n\n  if (!isValidHex(messageToVerify)) {\n    throw new UtilsError('message is not in a valid format, needs to be hexadecimal');\n  }\n\n  if (!isBase58Address(base58Address)) {\n    throw new UtilsError('address needs to be base58 encoded');\n  }\n\n  return tronweb.Trx.verifySignature(messageToVerify, base58Address, sigHex, useTronHeader);\n}\n\n/**\n * @param base58\n */\nexport function getHexAddressFromBase58Address(base58: string): string {\n  // pulled from: https://github.com/TRON-US/tronweb/blob/dcb8efa36a5ebb65c4dab3626e90256a453f3b0d/src/utils/help.js#L17\n  // but they don't surface this call in index.js\n  const bytes = tronweb.utils.crypto.decodeBase58Address(base58);\n  return getHexAddressFromByteArray(bytes);\n}\n\n/**\n * @param privateKey\n */\nexport function getPubKeyFromPriKey(privateKey: TronBinaryLike): ByteArray {\n  return tronweb.utils.crypto.getPubKeyFromPriKey(privateKey);\n}\n\n/**\n * @param privateKey\n */\nexport function getAddressFromPriKey(privateKey: TronBinaryLike): ByteArray {\n  return tronweb.utils.crypto.getAddressFromPriKey(privateKey);\n}\n\n/**\n * @param address\n */\nexport function getBase58AddressFromByteArray(address: ByteArray): string {\n  return tronweb.utils.crypto.getBase58CheckAddress(address);\n}\n\n/**\n * @param hex\n */\nexport function getBase58AddressFromHex(hex: string): string {\n  const arr = getByteArrayFromHexAddress(hex);\n  return getBase58AddressFromByteArray(arr);\n}\n\n/**\n * @param privateKey\n * @param transaction\n */\nexport function signTransaction(privateKey: string | ByteArray, transaction: TransactionReceipt): TransactionReceipt {\n  return tronweb.utils.crypto.signTransaction(privateKey, transaction);\n}\n\n/**\n * @param message\n * @param privateKey\n * @param useTronHeader\n */\nexport function signString(message: string, privateKey: string | ByteArray, useTronHeader = true): string {\n  return tronweb.Trx.signString(message, privateKey, useTronHeader);\n}\n\n/**\n * @param pubBytes\n */\nexport function getRawAddressFromPubKey(pubBytes: TronBinaryLike): ByteArray {\n  return tronweb.utils.crypto.computeAddress(pubBytes);\n}\n\n/**\n * Decodes a hex encoded transaction in its protobuf representation.\n *\n * @param hexString raw_data_hex field from tron transactions\n */\nexport function decodeTransaction(hexString: string): RawData {\n  const rawTransaction = decodeRawTransaction(hexString);\n\n  // there should not be multiple contracts in this data\n  if (rawTransaction.contracts.length !== 1) {\n    throw new UtilsError('Number of contracts is greater than 1.');\n  }\n\n  let contract: TransferContract[] | AccountPermissionUpdateContract[] | TriggerSmartContract[];\n  let contractType: ContractType;\n  // ensure the contract type is supported\n  switch (rawTransaction.contracts[0].parameter.type_url) {\n    case 'type.googleapis.com/protocol.TransferContract':\n      contractType = ContractType.Transfer;\n      contract = exports.decodeTransferContract(rawTransaction.contracts[0].parameter.value);\n      break;\n    case 'type.googleapis.com/protocol.AccountPermissionUpdateContract':\n      contractType = ContractType.AccountPermissionUpdate;\n      contract = exports.decodeAccountPermissionUpdateContract(rawTransaction.contracts[0].parameter.value);\n      break;\n    case 'type.googleapis.com/protocol.TriggerSmartContract':\n      contractType = ContractType.TriggerSmartContract;\n      contract = exports.decodeTriggerSmartContract(rawTransaction.contracts[0].parameter.value);\n      break;\n    default:\n      throw new UtilsError('Unsupported contract type');\n  }\n\n  return {\n    contractType,\n    contract,\n    expiration: rawTransaction.expiration,\n    timestamp: rawTransaction.timestamp,\n    ref_block_bytes: rawTransaction.blockBytes,\n    ref_block_hash: rawTransaction.blockHash,\n    fee_limit: +rawTransaction.feeLimit,\n  };\n}\n\n/**\n * Decodes a transaction's raw field from a base64 encoded string. This is a protobuf representation.\n *\n * @param hexString this is the raw hexadecimal encoded string. Doc found in the following link.\n * @example\n * @see {@link https://github.com/BitGo/bitgo-account-lib/blob/5f282588701778a4421c75fa61f42713f56e95b9/resources/protobuf/tron.proto#L319}\n */\nexport function decodeRawTransaction(hexString: string): {\n  expiration: number;\n  timestamp: number;\n  contracts: Array<any>;\n  blockBytes: string;\n  blockHash: string;\n  feeLimit: string;\n} {\n  const bytes = Buffer.from(hexString, 'hex');\n\n  let raw;\n  try {\n    // we need to decode our raw_data_hex field first\n    raw = protocol.Transaction.raw.decode(bytes);\n  } catch (e) {\n    throw new UtilsError('There was an error decoding the initial raw_data_hex from the serialized tx.');\n  }\n\n  return {\n    expiration: Number(raw.expiration),\n    timestamp: Number(raw.timestamp),\n    contracts: raw.contract,\n    blockBytes: toHex(raw.refBlockBytes),\n    feeLimit: raw.feeLimit,\n    blockHash: toHex(raw.refBlockHash),\n  };\n}\n\n/**\n * Indicates whether the passed string is a safe hex string for tron's purposes.\n *\n * @param hex A valid hex string must be a string made of numbers and characters and has an even length.\n */\nexport function isValidHex(hex: string): boolean {\n  return /^(0x)?([0-9a-f]{2})+$/i.test(hex);\n}\n\n/** Deserialize the segment of the txHex which corresponds with the details of the transfer\n *\n * @param transferHex is the value property of the \"parameter\" field of contractList[0]\n * */\nexport function decodeTransferContract(transferHex: string): TransferContract[] {\n  const contractBytes = Buffer.from(transferHex, 'base64');\n  let transferContract;\n\n  try {\n    transferContract = protocol.TransferContract.decode(contractBytes);\n  } catch (e) {\n    throw new UtilsError('There was an error decoding the transfer contract in the transaction.');\n  }\n\n  if (!transferContract.ownerAddress) {\n    throw new UtilsError('Owner address does not exist in this transfer contract.');\n  }\n\n  if (!transferContract.toAddress) {\n    throw new UtilsError('Destination address does not exist in this transfer contract.');\n  }\n\n  if (!transferContract.hasOwnProperty('amount')) {\n    throw new UtilsError('Amount does not exist in this transfer contract.');\n  }\n\n  // deserialize attributes\n  const owner_address = getBase58AddressFromByteArray(\n    getByteArrayFromHexAddress(Buffer.from(transferContract.ownerAddress, 'base64').toString('hex'))\n  );\n  const to_address = getBase58AddressFromByteArray(\n    getByteArrayFromHexAddress(Buffer.from(transferContract.toAddress, 'base64').toString('hex'))\n  );\n  const amount = transferContract.amount;\n\n  return [\n    {\n      parameter: {\n        value: {\n          amount: Number(amount),\n          owner_address,\n          to_address,\n        },\n      },\n    },\n  ];\n}\n\n/**\n * Deserialize the segment of the txHex corresponding with trigger smart contract\n *\n * @param {string} base64\n * @returns {AccountPermissionUpdateContract}\n */\nexport function decodeTriggerSmartContract(base64: string): TriggerSmartContract[] {\n  let contractCallDecoded;\n  try {\n    contractCallDecoded = protocol.TriggerSmartContract.decode(Buffer.from(base64, 'base64')).toJSON();\n  } catch (e) {\n    throw new UtilsError('There was an error decoding the contract call in the transaction.');\n  }\n\n  if (!contractCallDecoded.ownerAddress) {\n    throw new UtilsError('Owner address does not exist in this contract call.');\n  }\n\n  if (!contractCallDecoded.contractAddress) {\n    throw new UtilsError('Destination contract address does not exist in this contract call.');\n  }\n\n  if (!contractCallDecoded.data) {\n    throw new UtilsError('Data does not exist in this contract call.');\n  }\n\n  // deserialize attributes\n  const owner_address = getBase58AddressFromByteArray(\n    getByteArrayFromHexAddress(Buffer.from(contractCallDecoded.ownerAddress, 'base64').toString('hex'))\n  );\n  const contract_address = getBase58AddressFromByteArray(\n    getByteArrayFromHexAddress(Buffer.from(contractCallDecoded.contractAddress, 'base64').toString('hex'))\n  );\n  const data = contractCallDecoded.data;\n  return [\n    {\n      parameter: {\n        value: {\n          data: data,\n          owner_address,\n          contract_address,\n        },\n      },\n    },\n  ];\n}\n\n/**\n * Deserialize the segment of the txHex corresponding with the details of the contract which updates\n * account permission\n *\n * @param {string} base64\n * @returns {AccountPermissionUpdateContract}\n */\nexport function decodeAccountPermissionUpdateContract(base64: string): AccountPermissionUpdateContract {\n  const accountUpdateContract = protocol.AccountPermissionUpdateContract.decode(Buffer.from(base64, 'base64')).toJSON();\n  assert(accountUpdateContract.ownerAddress);\n  assert(accountUpdateContract.owner);\n  assert(accountUpdateContract.hasOwnProperty('actives'));\n\n  const ownerAddress = getBase58AddressFromByteArray(\n    getByteArrayFromHexAddress(Buffer.from(accountUpdateContract.ownerAddress, 'base64').toString('hex'))\n  );\n  const owner: Permission = createPermission(accountUpdateContract.owner);\n  let witness: Permission | undefined = undefined;\n  if (accountUpdateContract.witness) {\n    witness = createPermission(accountUpdateContract.witness);\n  }\n  const activeList = accountUpdateContract.actives.map((active) => createPermission(active));\n\n  return {\n    ownerAddress,\n    owner,\n    witness,\n    actives: activeList,\n  };\n}\n\n/**\n * @param raw\n */\nfunction createPermission(raw: { permissionName: string; threshold: number }): Permission {\n  let permissionType: PermissionType;\n  const permission = raw.permissionName.toLowerCase().trim();\n  if (permission === 'owner') {\n    permissionType = PermissionType.Owner;\n  } else if (permission === 'witness') {\n    permissionType = PermissionType.Witness;\n  } else if (permission.substr(0, 6) === 'active') {\n    permissionType = PermissionType.Active;\n  } else {\n    throw new UtilsError('Permission type not parseable.');\n  }\n  return { type: permissionType, threshold: raw.threshold };\n}\n\n/**\n * @param rawTransaction\n */\nexport function isValidTxJsonString(rawTransaction: string): boolean {\n  const transaction = JSON.parse(rawTransaction);\n  return transaction.hasOwnProperty('txID');\n}\n\n/**\n * Returns whether the provided raw transaction accommodates to bitgo's preferred format\n *\n * @param {any} rawTransaction - The raw transaction to be checked\n * @returns {boolean} the validation result\n */\nexport function isValidRawTransactionFormat(rawTransaction: any): boolean {\n  if (typeof rawTransaction === 'string' && (isValidHex(rawTransaction) || isValidTxJsonString(rawTransaction))) {\n    return true;\n  }\n  return false;\n}\n\n/**\n * Returns an hex string of the given buffer\n *\n * @param {Buffer | Uint8Array} buffer - the buffer to be converted to hex\n * @returns {string} - the hex value\n */\nexport function toHex(buffer: Buffer | Uint8Array): string {\n  return hex.encode(buffer, true);\n}\n\n/**\n * Returns a Keccak-256 encoded string of the parameters\n *\n * @param types - strings describing the types of the values\n * @param values - value to encode\n * @param methodId - the first 4 bytes of the function selector\n */\nexport function encodeDataParams(types: string[], values: any[], methodId?: string): string {\n  types.forEach((type, index) => {\n    if (type == 'address') {\n      values[index] = values[index].replace(ADDRESS_PREFIX_REGEX, '0x');\n    }\n  });\n\n  const abiCoder = new AbiCoder();\n  let data;\n  try {\n    data = abiCoder.encode(types, values);\n  } catch (e) {\n    throw new UtilsError('There was an error encoding the data params.');\n  }\n  if (methodId) {\n    return hexConcat([methodId, data]).replace(/^(0x)/, '');\n  } else {\n    return data.replace(/^(0x)/, '');\n  }\n}\n\n/**\n * Returns the decoded values according to the array of types\n *\n * @param types - strings describing the types of the values\n * @param data - encoded string\n */\nexport function decodeDataParams(types: string[], data: string): any[] {\n  const abiCoder = new AbiCoder();\n  data = '0x' + data.substring(8);\n  return abiCoder.decode(types, data).reduce((obj, arg, index) => {\n    if (types[index] == 'address') arg = ADDRESS_PREFIX + arg.substr(2).toLowerCase();\n    obj.push(arg);\n    return obj;\n  }, []);\n}\n"]}