@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,226 +0,0 @@
1
- "use strict";
2
- var __importDefault = (this && this.__importDefault) || function (mod) {
3
- return (mod && mod.__esModule) ? mod : { "default": mod };
4
- };
5
- Object.defineProperty(exports, "__esModule", { value: true });
6
- exports.Transaction = void 0;
7
- const crypto_1 = require("crypto");
8
- const bignumber_js_1 = __importDefault(require("bignumber.js"));
9
- const tron_1 = require("../../resources/protobuf/tron");
10
- const sdk_core_1 = require("@bitgo-beta/sdk-core");
11
- const enum_1 = require("./enum");
12
- const utils_1 = require("./utils");
13
- /**
14
- * Tron transaction model.
15
- */
16
- class Transaction extends sdk_core_1.BaseTransaction {
17
- /**
18
- * Public constructor.
19
- *
20
- * @param coinConfig
21
- * @param rawTransaction
22
- */
23
- constructor(coinConfig, rawTransaction) {
24
- super(coinConfig);
25
- if (rawTransaction) {
26
- if (!rawTransaction.txID) {
27
- throw new sdk_core_1.ParseTransactionError('Transaction has no id');
28
- }
29
- this._id = rawTransaction.txID;
30
- this._transaction = rawTransaction;
31
- this._decodedRawDataHex = utils_1.decodeTransaction(rawTransaction.raw_data_hex);
32
- // Destination depends on the contract type
33
- this.recordRawDataFields(this._decodedRawDataHex);
34
- }
35
- }
36
- /**
37
- * Parse the transaction raw data and record the most important fields.
38
- *
39
- * @param rawData Object from a tron transaction
40
- */
41
- recordRawDataFields(rawData) {
42
- // Contract-agnostic fields
43
- this._validFrom = rawData.timestamp;
44
- this._validTo = rawData.expiration;
45
- let output, input;
46
- // Contract-specific fields
47
- switch (rawData.contractType) {
48
- case enum_1.ContractType.Transfer:
49
- this._type = sdk_core_1.TransactionType.Send;
50
- const value = new bignumber_js_1.default(rawData.contract[0].parameter.value.amount).toFixed(0);
51
- output = {
52
- address: rawData.contract[0].parameter.value.to_address,
53
- value,
54
- };
55
- input = {
56
- address: rawData.contract[0].parameter.value.owner_address,
57
- value,
58
- };
59
- break;
60
- case enum_1.ContractType.AccountPermissionUpdate:
61
- this._type = sdk_core_1.TransactionType.WalletInitialization;
62
- output = {
63
- address: rawData.contract.owner_address,
64
- value: '0',
65
- };
66
- input = {
67
- address: rawData.contract.owner_address,
68
- value: '0',
69
- };
70
- break;
71
- case enum_1.ContractType.TriggerSmartContract:
72
- this._type = sdk_core_1.TransactionType.ContractCall;
73
- const contractCallValues = rawData.contract[0].parameter.value;
74
- const contractAddress = contractCallValues.contract_address;
75
- if (utils_1.tokenMainnetContractAddresses.includes(contractAddress) ||
76
- utils_1.tokenTestnetContractAddresses.includes(contractAddress)) {
77
- // this is then a token smart contract transaction and the data must be decoded
78
- const types = ['address', 'uint256'];
79
- const data = Buffer.from(contractCallValues.data, 'base64').toString('hex');
80
- const decodedData = utils_1.decodeDataParams(types, data);
81
- const recipient_address = utils_1.getBase58AddressFromHex(decodedData[0]);
82
- const value = decodedData[1].toString();
83
- output = {
84
- address: recipient_address,
85
- value,
86
- };
87
- input = {
88
- address: contractCallValues.owner_address,
89
- contractAddress,
90
- data,
91
- value,
92
- };
93
- break;
94
- }
95
- output = {
96
- address: contractCallValues.owner_address,
97
- value: '0',
98
- };
99
- input = {
100
- address: contractCallValues.owner_address,
101
- contractAddress,
102
- data: contractCallValues.data,
103
- value: '0',
104
- };
105
- break;
106
- default:
107
- throw new sdk_core_1.ParseTransactionError('Unsupported contract type');
108
- }
109
- this._inputs = [input];
110
- this._outputs = [output];
111
- }
112
- /**
113
- * Recalculate and update the transaction id. This should be done after changing any transaction
114
- * field since the the id is a hash of the transaction body.
115
- */
116
- updateId() {
117
- if (!this._transaction) {
118
- throw new sdk_core_1.ParseTransactionError('Empty transaction');
119
- }
120
- const hexBuffer = Buffer.from(this._transaction.raw_data_hex, 'hex');
121
- const newTxid = crypto_1.createHash('sha256').update(hexBuffer).digest('hex');
122
- this._transaction.txID = newTxid;
123
- this._id = newTxid;
124
- }
125
- /**
126
- * Extend the expiration date by the given number of milliseconds.
127
- *
128
- * @param extensionMs The number of milliseconds to extend the expiration by
129
- */
130
- extendExpiration(extensionMs) {
131
- if (extensionMs < 0) {
132
- throw new sdk_core_1.ExtendTransactionError('Invalid extension range. Must be positive a integer');
133
- }
134
- if (!this._transaction) {
135
- throw new sdk_core_1.ExtendTransactionError('Empty transaction');
136
- }
137
- if (this._transaction.signature && this._transaction.signature.length > 0) {
138
- throw new sdk_core_1.ExtendTransactionError('Cannot extend a signed transaction');
139
- }
140
- const rawDataHex = this._transaction.raw_data_hex;
141
- const bytes = Buffer.from(rawDataHex, 'hex');
142
- let raw;
143
- try {
144
- raw = tron_1.protocol.Transaction.raw.decode(bytes);
145
- const newExpiration = new bignumber_js_1.default(raw.expiration).plus(extensionMs).toNumber();
146
- raw.expiration = newExpiration;
147
- const newRawDataHex = Buffer.from(tron_1.protocol.Transaction.raw.encode(raw).finish()).toString('hex');
148
- // Set the internal variables to account for the new expiration date
149
- this._transaction.raw_data_hex = newRawDataHex;
150
- this._transaction.raw_data.expiration = newExpiration;
151
- this._decodedRawDataHex = utils_1.decodeTransaction(newRawDataHex);
152
- this.recordRawDataFields(this._decodedRawDataHex);
153
- this.updateId();
154
- }
155
- catch (e) {
156
- throw new sdk_core_1.ExtendTransactionError('There was an error decoding the initial raw_data_hex from the serialized tx.');
157
- }
158
- }
159
- /**
160
- * Get the signatures associated with this transaction.
161
- */
162
- get signature() {
163
- if (this._transaction && this._transaction.signature) {
164
- return this._transaction.signature;
165
- }
166
- return [];
167
- }
168
- /**
169
- * Get the time in milliseconds this transaction becomes valid and can be broadcasted to the
170
- * network.
171
- */
172
- get validFrom() {
173
- return this._validFrom;
174
- }
175
- /**
176
- * Get the expiration time in milliseconds.
177
- */
178
- get validTo() {
179
- return this._validTo;
180
- }
181
- /** @inheritdoc */
182
- get outputs() {
183
- return this._outputs;
184
- }
185
- /** @inheritdoc */
186
- get inputs() {
187
- return this._inputs;
188
- }
189
- /** @inheritdoc */
190
- canSign(key) {
191
- // Tron transaction do not contain the owners account address so it is not possible to check the
192
- // private key with any but the account main address. This is not enough to fail this check, so
193
- // it is a no-op.
194
- return true;
195
- }
196
- /**
197
- * Sets this transaction
198
- *
199
- * @param {Transaction} tx transaction
200
- */
201
- setTransactionReceipt(tx) {
202
- this._transaction = tx;
203
- this.updateId();
204
- }
205
- /**
206
- * Set the transaction type
207
- *
208
- * @param {TransactionType} transactionType The transaction type to be set
209
- */
210
- setTransactionType(transactionType) {
211
- this._type = transactionType;
212
- }
213
- /** @inheritdoc */
214
- toJson() {
215
- if (!this._transaction) {
216
- throw new sdk_core_1.ParseTransactionError('Empty transaction');
217
- }
218
- return this._transaction;
219
- }
220
- /** @inheritdoc */
221
- toBroadcastFormat() {
222
- return JSON.stringify(this.toJson());
223
- }
224
- }
225
- exports.Transaction = Transaction;
226
- //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"transaction.js","sourceRoot":"","sources":["../../../src/lib/transaction.ts"],"names":[],"mappings":";;;;;;AAAA,mCAAoC;AAEpC,gEAAqC;AACrC,wDAAyD;AACzD,mDAM8B;AAC9B,iCAAsC;AACtC,mCAMiB;AAGjB;;GAEG;AACH,MAAa,WAAY,SAAQ,0BAAe;IAU9C;;;;;OAKG;IACH,YAAY,UAAgC,EAAE,cAAmC;QAC/E,KAAK,CAAC,UAAU,CAAC,CAAC;QAClB,IAAI,cAAc,EAAE;YAClB,IAAI,CAAC,cAAc,CAAC,IAAI,EAAE;gBACxB,MAAM,IAAI,gCAAqB,CAAC,uBAAuB,CAAC,CAAC;aAC1D;YACD,IAAI,CAAC,GAAG,GAAG,cAAc,CAAC,IAAI,CAAC;YAC/B,IAAI,CAAC,YAAY,GAAG,cAAc,CAAC;YACnC,IAAI,CAAC,kBAAkB,GAAG,yBAAiB,CAAC,cAAc,CAAC,YAAY,CAAC,CAAC;YAEzE,2CAA2C;YAC3C,IAAI,CAAC,mBAAmB,CAAC,IAAI,CAAC,kBAAkB,CAAC,CAAC;SACnD;IACH,CAAC;IAED;;;;OAIG;IACK,mBAAmB,CAAC,OAAgB;QAC1C,2BAA2B;QAC3B,IAAI,CAAC,UAAU,GAAG,OAAO,CAAC,SAAS,CAAC;QACpC,IAAI,CAAC,QAAQ,GAAG,OAAO,CAAC,UAAU,CAAC;QAEnC,IAAI,MAAqB,EAAE,KAAoB,CAAC;QAChD,2BAA2B;QAC3B,QAAQ,OAAO,CAAC,YAAY,EAAE;YAC5B,KAAK,mBAAY,CAAC,QAAQ;gBACxB,IAAI,CAAC,KAAK,GAAG,0BAAe,CAAC,IAAI,CAAC;gBAClC,MAAM,KAAK,GAAG,IAAI,sBAAS,CAAE,OAAO,CAAC,QAAQ,CAAC,CAAC,CAAsB,CAAC,SAAS,CAAC,KAAK,CAAC,MAAM,CAAC,CAAC,OAAO,CAAC,CAAC,CAAC,CAAC;gBACzG,MAAM,GAAG;oBACP,OAAO,EAAG,OAAO,CAAC,QAAQ,CAAC,CAAC,CAAsB,CAAC,SAAS,CAAC,KAAK,CAAC,UAAU;oBAC7E,KAAK;iBACN,CAAC;gBACF,KAAK,GAAG;oBACN,OAAO,EAAG,OAAO,CAAC,QAAQ,CAAC,CAAC,CAAsB,CAAC,SAAS,CAAC,KAAK,CAAC,aAAa;oBAChF,KAAK;iBACN,CAAC;gBACF,MAAM;YACR,KAAK,mBAAY,CAAC,uBAAuB;gBACvC,IAAI,CAAC,KAAK,GAAG,0BAAe,CAAC,oBAAoB,CAAC;gBAClD,MAAM,GAAG;oBACP,OAAO,EAAG,OAAO,CAAC,QAAgB,CAAC,aAAa;oBAChD,KAAK,EAAE,GAAG;iBACX,CAAC;gBACF,KAAK,GAAG;oBACN,OAAO,EAAG,OAAO,CAAC,QAAgB,CAAC,aAAa;oBAChD,KAAK,EAAE,GAAG;iBACX,CAAC;gBACF,MAAM;YACR,KAAK,mBAAY,CAAC,oBAAoB;gBACpC,IAAI,CAAC,KAAK,GAAG,0BAAe,CAAC,YAAY,CAAC;gBAC1C,MAAM,kBAAkB,GAAI,OAAO,CAAC,QAAQ,CAAC,CAAC,CAA0B,CAAC,SAAS,CAAC,KAAK,CAAC;gBACzF,MAAM,eAAe,GAAG,kBAAkB,CAAC,gBAAgB,CAAC;gBAC5D,IACE,qCAA6B,CAAC,QAAQ,CAAC,eAAe,CAAC;oBACvD,qCAA6B,CAAC,QAAQ,CAAC,eAAe,CAAC,EACvD;oBACA,+EAA+E;oBAC/E,MAAM,KAAK,GAAG,CAAC,SAAS,EAAE,SAAS,CAAC,CAAC;oBACrC,MAAM,IAAI,GAAG,MAAM,CAAC,IAAI,CAAC,kBAAkB,CAAC,IAAI,EAAE,QAAQ,CAAC,CAAC,QAAQ,CAAC,KAAK,CAAC,CAAC;oBAC5E,MAAM,WAAW,GAAG,wBAAgB,CAAC,KAAK,EAAE,IAAI,CAAC,CAAC;oBAClD,MAAM,iBAAiB,GAAG,+BAAuB,CAAC,WAAW,CAAC,CAAC,CAAC,CAAC,CAAC;oBAClE,MAAM,KAAK,GAAG,WAAW,CAAC,CAAC,CAAC,CAAC,QAAQ,EAAE,CAAC;oBACxC,MAAM,GAAG;wBACP,OAAO,EAAE,iBAAiB;wBAC1B,KAAK;qBACN,CAAC;oBACF,KAAK,GAAG;wBACN,OAAO,EAAE,kBAAkB,CAAC,aAAa;wBACzC,eAAe;wBACf,IAAI;wBACJ,KAAK;qBACN,CAAC;oBACF,MAAM;iBACP;gBACD,MAAM,GAAG;oBACP,OAAO,EAAE,kBAAkB,CAAC,aAAa;oBACzC,KAAK,EAAE,GAAG;iBACX,CAAC;gBACF,KAAK,GAAG;oBACN,OAAO,EAAE,kBAAkB,CAAC,aAAa;oBACzC,eAAe;oBACf,IAAI,EAAE,kBAAkB,CAAC,IAAI;oBAC7B,KAAK,EAAE,GAAG;iBACX,CAAC;gBACF,MAAM;YACR;gBACE,MAAM,IAAI,gCAAqB,CAAC,2BAA2B,CAAC,CAAC;SAChE;QACD,IAAI,CAAC,OAAO,GAAG,CAAC,KAAK,CAAC,CAAC;QACvB,IAAI,CAAC,QAAQ,GAAG,CAAC,MAAM,CAAC,CAAC;IAC3B,CAAC;IAED;;;OAGG;IACK,QAAQ;QACd,IAAI,CAAC,IAAI,CAAC,YAAY,EAAE;YACtB,MAAM,IAAI,gCAAqB,CAAC,mBAAmB,CAAC,CAAC;SACtD;QACD,MAAM,SAAS,GAAG,MAAM,CAAC,IAAI,CAAC,IAAI,CAAC,YAAY,CAAC,YAAY,EAAE,KAAK,CAAC,CAAC;QACrE,MAAM,OAAO,GAAG,mBAAU,CAAC,QAAQ,CAAC,CAAC,MAAM,CAAC,SAAS,CAAC,CAAC,MAAM,CAAC,KAAK,CAAC,CAAC;QACrE,IAAI,CAAC,YAAY,CAAC,IAAI,GAAG,OAAO,CAAC;QACjC,IAAI,CAAC,GAAG,GAAG,OAAO,CAAC;IACrB,CAAC;IAED;;;;OAIG;IACH,gBAAgB,CAAC,WAAmB;QAClC,IAAI,WAAW,GAAG,CAAC,EAAE;YACnB,MAAM,IAAI,iCAAsB,CAAC,qDAAqD,CAAC,CAAC;SACzF;QAED,IAAI,CAAC,IAAI,CAAC,YAAY,EAAE;YACtB,MAAM,IAAI,iCAAsB,CAAC,mBAAmB,CAAC,CAAC;SACvD;QAED,IAAI,IAAI,CAAC,YAAY,CAAC,SAAS,IAAI,IAAI,CAAC,YAAY,CAAC,SAAS,CAAC,MAAM,GAAG,CAAC,EAAE;YACzE,MAAM,IAAI,iCAAsB,CAAC,oCAAoC,CAAC,CAAC;SACxE;QAED,MAAM,UAAU,GAAG,IAAI,CAAC,YAAY,CAAC,YAAY,CAAC;QAClD,MAAM,KAAK,GAAG,MAAM,CAAC,IAAI,CAAC,UAAU,EAAE,KAAK,CAAC,CAAC;QAC7C,IAAI,GAAG,CAAC;QACR,IAAI;YACF,GAAG,GAAG,eAAQ,CAAC,WAAW,CAAC,GAAG,CAAC,MAAM,CAAC,KAAK,CAAC,CAAC;YAC7C,MAAM,aAAa,GAAG,IAAI,sBAAS,CAAC,GAAG,CAAC,UAAU,CAAC,CAAC,IAAI,CAAC,WAAW,CAAC,CAAC,QAAQ,EAAE,CAAC;YACjF,GAAG,CAAC,UAAU,GAAG,aAAa,CAAC;YAC/B,MAAM,aAAa,GAAG,MAAM,CAAC,IAAI,CAAC,eAAQ,CAAC,WAAW,CAAC,GAAG,CAAC,MAAM,CAAC,GAAG,CAAC,CAAC,MAAM,EAAE,CAAC,CAAC,QAAQ,CAAC,KAAK,CAAC,CAAC;YACjG,oEAAoE;YACpE,IAAI,CAAC,YAAY,CAAC,YAAY,GAAG,aAAa,CAAC;YAC/C,IAAI,CAAC,YAAY,CAAC,QAAQ,CAAC,UAAU,GAAG,aAAa,CAAC;YACtD,IAAI,CAAC,kBAAkB,GAAG,yBAAiB,CAAC,aAAa,CAAC,CAAC;YAC3D,IAAI,CAAC,mBAAmB,CAAC,IAAI,CAAC,kBAAkB,CAAC,CAAC;YAClD,IAAI,CAAC,QAAQ,EAAE,CAAC;SACjB;QAAC,OAAO,CAAC,EAAE;YACV,MAAM,IAAI,iCAAsB,CAAC,8EAA8E,CAAC,CAAC;SAClH;IACH,CAAC;IAED;;OAEG;IACH,IAAI,SAAS;QACX,IAAI,IAAI,CAAC,YAAY,IAAI,IAAI,CAAC,YAAY,CAAC,SAAS,EAAE;YACpD,OAAO,IAAI,CAAC,YAAY,CAAC,SAAS,CAAC;SACpC;QACD,OAAO,EAAE,CAAC;IACZ,CAAC;IACD;;;OAGG;IACH,IAAI,SAAS;QACX,OAAO,IAAI,CAAC,UAAU,CAAC;IACzB,CAAC;IAED;;OAEG;IACH,IAAI,OAAO;QACT,OAAO,IAAI,CAAC,QAAQ,CAAC;IACvB,CAAC;IAED,kBAAkB;IAClB,IAAI,OAAO;QACT,OAAO,IAAI,CAAC,QAAQ,CAAC;IACvB,CAAC;IAED,kBAAkB;IAClB,IAAI,MAAM;QACR,OAAO,IAAI,CAAC,OAAO,CAAC;IACtB,CAAC;IAED,kBAAkB;IAClB,OAAO,CAAC,GAAY;QAClB,gGAAgG;QAChG,+FAA+F;QAC/F,iBAAiB;QACjB,OAAO,IAAI,CAAC;IACd,CAAC;IAED;;;;OAIG;IACH,qBAAqB,CAAC,EAAsB;QAC1C,IAAI,CAAC,YAAY,GAAG,EAAE,CAAC;QACvB,IAAI,CAAC,QAAQ,EAAE,CAAC;IAClB,CAAC;IAED;;;;OAIG;IACH,kBAAkB,CAAC,eAAgC;QACjD,IAAI,CAAC,KAAK,GAAG,eAAe,CAAC;IAC/B,CAAC;IAED,kBAAkB;IAClB,MAAM;QACJ,IAAI,CAAC,IAAI,CAAC,YAAY,EAAE;YACtB,MAAM,IAAI,gCAAqB,CAAC,mBAAmB,CAAC,CAAC;SACtD;QACD,OAAO,IAAI,CAAC,YAAY,CAAC;IAC3B,CAAC;IAED,kBAAkB;IAClB,iBAAiB;QACf,OAAO,IAAI,CAAC,SAAS,CAAC,IAAI,CAAC,MAAM,EAAE,CAAC,CAAC;IACvC,CAAC;CACF;AA3OD,kCA2OC","sourcesContent":["import { createHash } from 'crypto';\nimport { BaseCoin as CoinConfig } from '@bitgo-beta/statics';\nimport BigNumber from 'bignumber.js';\nimport { protocol } from '../../resources/protobuf/tron';\nimport {\n  BaseKey,\n  BaseTransaction,\n  ExtendTransactionError,\n  ParseTransactionError,\n  TransactionType,\n} from '@bitgo-beta/sdk-core';\nimport { ContractType } from './enum';\nimport {\n  decodeTransaction,\n  decodeDataParams,\n  getBase58AddressFromHex,\n  tokenMainnetContractAddresses,\n  tokenTestnetContractAddresses,\n} from './utils';\nimport { ContractEntry, RawData, TransactionReceipt, TransferContract, TriggerSmartContract } from './iface';\n\n/**\n * Tron transaction model.\n */\nexport class Transaction extends BaseTransaction {\n  // Tron specific fields\n  protected _validFrom: number;\n  protected _validTo: number;\n  protected _inputs: ContractEntry[];\n  protected _outputs: ContractEntry[];\n\n  private _decodedRawDataHex: RawData;\n  private _transaction?: TransactionReceipt;\n\n  /**\n   * Public constructor.\n   *\n   * @param coinConfig\n   * @param rawTransaction\n   */\n  constructor(coinConfig: Readonly<CoinConfig>, rawTransaction?: TransactionReceipt) {\n    super(coinConfig);\n    if (rawTransaction) {\n      if (!rawTransaction.txID) {\n        throw new ParseTransactionError('Transaction has no id');\n      }\n      this._id = rawTransaction.txID;\n      this._transaction = rawTransaction;\n      this._decodedRawDataHex = decodeTransaction(rawTransaction.raw_data_hex);\n\n      // Destination depends on the contract type\n      this.recordRawDataFields(this._decodedRawDataHex);\n    }\n  }\n\n  /**\n   * Parse the transaction raw data and record the most important fields.\n   *\n   * @param rawData Object from a tron transaction\n   */\n  private recordRawDataFields(rawData: RawData) {\n    // Contract-agnostic fields\n    this._validFrom = rawData.timestamp;\n    this._validTo = rawData.expiration;\n\n    let output: ContractEntry, input: ContractEntry;\n    // Contract-specific fields\n    switch (rawData.contractType) {\n      case ContractType.Transfer:\n        this._type = TransactionType.Send;\n        const value = new BigNumber((rawData.contract[0] as TransferContract).parameter.value.amount).toFixed(0);\n        output = {\n          address: (rawData.contract[0] as TransferContract).parameter.value.to_address,\n          value,\n        };\n        input = {\n          address: (rawData.contract[0] as TransferContract).parameter.value.owner_address,\n          value,\n        };\n        break;\n      case ContractType.AccountPermissionUpdate:\n        this._type = TransactionType.WalletInitialization;\n        output = {\n          address: (rawData.contract as any).owner_address,\n          value: '0',\n        };\n        input = {\n          address: (rawData.contract as any).owner_address,\n          value: '0',\n        };\n        break;\n      case ContractType.TriggerSmartContract:\n        this._type = TransactionType.ContractCall;\n        const contractCallValues = (rawData.contract[0] as TriggerSmartContract).parameter.value;\n        const contractAddress = contractCallValues.contract_address;\n        if (\n          tokenMainnetContractAddresses.includes(contractAddress) ||\n          tokenTestnetContractAddresses.includes(contractAddress)\n        ) {\n          // this is then a token smart contract transaction and the data must be decoded\n          const types = ['address', 'uint256'];\n          const data = Buffer.from(contractCallValues.data, 'base64').toString('hex');\n          const decodedData = decodeDataParams(types, data);\n          const recipient_address = getBase58AddressFromHex(decodedData[0]);\n          const value = decodedData[1].toString();\n          output = {\n            address: recipient_address,\n            value,\n          };\n          input = {\n            address: contractCallValues.owner_address,\n            contractAddress,\n            data,\n            value,\n          };\n          break;\n        }\n        output = {\n          address: contractCallValues.owner_address,\n          value: '0',\n        };\n        input = {\n          address: contractCallValues.owner_address,\n          contractAddress,\n          data: contractCallValues.data,\n          value: '0',\n        };\n        break;\n      default:\n        throw new ParseTransactionError('Unsupported contract type');\n    }\n    this._inputs = [input];\n    this._outputs = [output];\n  }\n\n  /**\n   * Recalculate and update the transaction id. This should be done after changing any transaction\n   * field since the the id is a hash of the transaction body.\n   */\n  private updateId(): void {\n    if (!this._transaction) {\n      throw new ParseTransactionError('Empty transaction');\n    }\n    const hexBuffer = Buffer.from(this._transaction.raw_data_hex, 'hex');\n    const newTxid = createHash('sha256').update(hexBuffer).digest('hex');\n    this._transaction.txID = newTxid;\n    this._id = newTxid;\n  }\n\n  /**\n   * Extend the expiration date by the given number of milliseconds.\n   *\n   * @param extensionMs The number of milliseconds to extend the expiration by\n   */\n  extendExpiration(extensionMs: number): void {\n    if (extensionMs < 0) {\n      throw new ExtendTransactionError('Invalid extension range. Must be positive a integer');\n    }\n\n    if (!this._transaction) {\n      throw new ExtendTransactionError('Empty transaction');\n    }\n\n    if (this._transaction.signature && this._transaction.signature.length > 0) {\n      throw new ExtendTransactionError('Cannot extend a signed transaction');\n    }\n\n    const rawDataHex = this._transaction.raw_data_hex;\n    const bytes = Buffer.from(rawDataHex, 'hex');\n    let raw;\n    try {\n      raw = protocol.Transaction.raw.decode(bytes);\n      const newExpiration = new BigNumber(raw.expiration).plus(extensionMs).toNumber();\n      raw.expiration = newExpiration;\n      const newRawDataHex = Buffer.from(protocol.Transaction.raw.encode(raw).finish()).toString('hex');\n      // Set the internal variables to account for the new expiration date\n      this._transaction.raw_data_hex = newRawDataHex;\n      this._transaction.raw_data.expiration = newExpiration;\n      this._decodedRawDataHex = decodeTransaction(newRawDataHex);\n      this.recordRawDataFields(this._decodedRawDataHex);\n      this.updateId();\n    } catch (e) {\n      throw new ExtendTransactionError('There was an error decoding the initial raw_data_hex from the serialized tx.');\n    }\n  }\n\n  /**\n   * Get the signatures associated with this transaction.\n   */\n  get signature(): string[] {\n    if (this._transaction && this._transaction.signature) {\n      return this._transaction.signature;\n    }\n    return [];\n  }\n  /**\n   * Get the time in milliseconds this transaction becomes valid and can be broadcasted to the\n   * network.\n   */\n  get validFrom(): number {\n    return this._validFrom;\n  }\n\n  /**\n   * Get the expiration time in milliseconds.\n   */\n  get validTo(): number {\n    return this._validTo;\n  }\n\n  /** @inheritdoc */\n  get outputs(): ContractEntry[] {\n    return this._outputs;\n  }\n\n  /** @inheritdoc */\n  get inputs(): ContractEntry[] {\n    return this._inputs;\n  }\n\n  /** @inheritdoc */\n  canSign(key: BaseKey): boolean {\n    // Tron transaction do not contain the owners account address so it is not possible to check the\n    // private key with any but the account main address. This is not enough to fail this check, so\n    // it is a no-op.\n    return true;\n  }\n\n  /**\n   * Sets this transaction\n   *\n   * @param {Transaction} tx transaction\n   */\n  setTransactionReceipt(tx: TransactionReceipt) {\n    this._transaction = tx;\n    this.updateId();\n  }\n\n  /**\n   * Set the transaction type\n   *\n   * @param {TransactionType} transactionType The transaction type to be set\n   */\n  setTransactionType(transactionType: TransactionType): void {\n    this._type = transactionType;\n  }\n\n  /** @inheritdoc */\n  toJson(): TransactionReceipt {\n    if (!this._transaction) {\n      throw new ParseTransactionError('Empty transaction');\n    }\n    return this._transaction;\n  }\n\n  /** @inheritdoc */\n  toBroadcastFormat(): any {\n    return JSON.stringify(this.toJson());\n  }\n}\n"]}
@@ -1,65 +0,0 @@
1
- import BigNumber from 'bignumber.js';
2
- import { BaseCoin as CoinConfig } from '@bitgo-beta/statics';
3
- import { BaseKey, BaseTransactionBuilder } from '@bitgo-beta/sdk-core';
4
- import { TransactionReceipt } from './iface';
5
- import { Address } from './address';
6
- import { Transaction } from './transaction';
7
- /**
8
- * Tron transaction builder.
9
- */
10
- export declare class TransactionBuilder extends BaseTransactionBuilder {
11
- private _transaction;
12
- /**
13
- * Public constructor.
14
- *
15
- * @param {CoinConfig} _coinConfig Configuration object
16
- */
17
- constructor(_coinConfig: Readonly<CoinConfig>);
18
- /**
19
- * Parse transaction takes in raw JSON directly from the node.
20
- *
21
- * @param {TransactionReceipt} rawTransaction The Tron transaction in JSON format as returned by the Tron lib or a stringifyed version of such JSON.
22
- * @returns {Transaction} Tron transaction
23
- */
24
- protected fromImplementation(rawTransaction: TransactionReceipt | string): Transaction;
25
- /** @inheritdoc */
26
- protected signImplementation(key: BaseKey): Transaction;
27
- protected applySignature(key: BaseKey): Transaction;
28
- /** @inheritdoc */
29
- protected buildImplementation(): Promise<Transaction>;
30
- initBuilder(tx: TransactionReceipt | string): void;
31
- /**
32
- * Extend the validity of this transaction by the given amount of time
33
- *
34
- * @param {number} extensionMs The number of milliseconds to extend the validTo time
35
- * @returns {undefined}
36
- */
37
- extendValidTo(extensionMs: number): void;
38
- /** @inheritdoc */
39
- validateValue(value: BigNumber): void;
40
- /** @inheritdoc */
41
- validateAddress(address: Address): void;
42
- /** @inheritdoc */
43
- validateKey(key: BaseKey): void;
44
- /**
45
- * Validate the contents of a raw transaction. The validation
46
- * phase is to compare the raw-data-hex to the raw-data of the
47
- * transaction.
48
- *
49
- * The contents to be validated are
50
- * 1. The transaction id
51
- * 2. The expiration date
52
- * 3. The timestamp
53
- * 4. The contract
54
- *
55
- * @param {TransactionReceipt | string} rawTransaction The raw transaction to be validated
56
- */
57
- validateRawTransaction(rawTransaction: TransactionReceipt | string): void;
58
- /** @inheritdoc */
59
- validateTransaction(transaction: Transaction): void;
60
- /** @inheritdoc */
61
- protected get transaction(): Transaction;
62
- /** @inheritdoc */
63
- protected set transaction(transaction: Transaction);
64
- }
65
- //# sourceMappingURL=transactionBuilder.d.ts.map
@@ -1 +0,0 @@
1
- {"version":3,"file":"transactionBuilder.d.ts","sourceRoot":"","sources":["../../../src/lib/transactionBuilder.ts"],"names":[],"mappings":"AAEA,OAAO,SAAS,MAAM,cAAc,CAAC;AACrC,OAAO,EAAE,QAAQ,IAAI,UAAU,EAAE,MAAM,qBAAqB,CAAC;AAC7D,OAAO,EACL,OAAO,EACP,sBAAsB,EAKvB,MAAM,sBAAsB,CAAC;AAC9B,OAAO,EAAE,kBAAkB,EAAE,MAAM,SAAS,CAAC;AAC7C,OAAO,EAAE,OAAO,EAAE,MAAM,WAAW,CAAC;AAEpC,OAAO,EAAE,WAAW,EAAE,MAAM,eAAe,CAAC;AAG5C;;GAEG;AACH,qBAAa,kBAAmB,SAAQ,sBAAsB;IAE5D,OAAO,CAAC,YAAY,CAAc;IAClC;;;;OAIG;gBACS,WAAW,EAAE,QAAQ,CAAC,UAAU,CAAC;IAI7C;;;;;OAKG;IACH,SAAS,CAAC,kBAAkB,CAAC,cAAc,EAAE,kBAAkB,GAAG,MAAM,GAAG,WAAW;IAWtF,kBAAkB;IAClB,SAAS,CAAC,kBAAkB,CAAC,GAAG,EAAE,OAAO,GAAG,WAAW;IAWvD,SAAS,CAAC,cAAc,CAAC,GAAG,EAAE,OAAO,GAAG,WAAW;IAuBnD,kBAAkB;cACF,mBAAmB,IAAI,OAAO,CAAC,WAAW,CAAC;IAQ3D,WAAW,CAAC,EAAE,EAAE,kBAAkB,GAAG,MAAM;IAI3C;;;;;OAKG;IACH,aAAa,CAAC,WAAW,EAAE,MAAM,GAAG,IAAI;IAIxC,kBAAkB;IAClB,aAAa,CAAC,KAAK,EAAE,SAAS,GAAG,IAAI;IAWrC,kBAAkB;IAClB,eAAe,CAAC,OAAO,EAAE,OAAO,GAAG,IAAI;IAOvC,kBAAkB;IAClB,WAAW,CAAC,GAAG,EAAE,OAAO,GAAG,IAAI;IAQ/B;;;;;;;;;;;;OAYG;IACH,sBAAsB,CAAC,cAAc,EAAE,kBAAkB,GAAG,MAAM,GAAG,IAAI;IA2CzE,kBAAkB;IAClB,mBAAmB,CAAC,WAAW,EAAE,WAAW,GAAG,IAAI;IAQnD,kBAAkB;IAClB,SAAS,KAAK,WAAW,IAAI,WAAW,CAEvC;IAED,kBAAkB;IAClB,SAAS,KAAK,WAAW,CAAC,WAAW,EAAE,WAAW,EAEjD;CACF"}
@@ -1,215 +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.TransactionBuilder = void 0;
26
- const crypto_1 = require("crypto");
27
- const _ = __importStar(require("lodash"));
28
- const bignumber_js_1 = __importDefault(require("bignumber.js"));
29
- const sdk_core_1 = require("@bitgo-beta/sdk-core");
30
- const utils_1 = require("./utils");
31
- const transaction_1 = require("./transaction");
32
- const keyPair_1 = require("./keyPair");
33
- /**
34
- * Tron transaction builder.
35
- */
36
- class TransactionBuilder extends sdk_core_1.BaseTransactionBuilder {
37
- /**
38
- * Public constructor.
39
- *
40
- * @param {CoinConfig} _coinConfig Configuration object
41
- */
42
- constructor(_coinConfig) {
43
- super(_coinConfig);
44
- }
45
- /**
46
- * Parse transaction takes in raw JSON directly from the node.
47
- *
48
- * @param {TransactionReceipt} rawTransaction The Tron transaction in JSON format as returned by the Tron lib or a stringifyed version of such JSON.
49
- * @returns {Transaction} Tron transaction
50
- */
51
- fromImplementation(rawTransaction) {
52
- let tx;
53
- if (typeof rawTransaction === 'string') {
54
- const transaction = JSON.parse(rawTransaction);
55
- tx = new transaction_1.Transaction(this._coinConfig, transaction);
56
- }
57
- else {
58
- tx = new transaction_1.Transaction(this._coinConfig, rawTransaction);
59
- }
60
- return tx;
61
- }
62
- /** @inheritdoc */
63
- signImplementation(key) {
64
- if (!this.transaction.inputs) {
65
- throw new sdk_core_1.SigningError('Transaction has no sender');
66
- }
67
- if (!this.transaction.outputs) {
68
- throw new sdk_core_1.SigningError('Transaction has no receiver');
69
- }
70
- return this.applySignature(key);
71
- }
72
- applySignature(key) {
73
- const oldTransaction = this.transaction.toJson();
74
- // Store the original signatures to compare them with the new ones in a later step. Signatures
75
- // can be undefined if this is the first time the transaction is being signed
76
- const oldSignatureCount = oldTransaction.signature ? oldTransaction.signature.length : 0;
77
- let signedTransaction;
78
- try {
79
- const keyPair = new keyPair_1.KeyPair({ prv: key.key });
80
- // Since the key pair was generated using a private key, it will always have a prv attribute,
81
- // hence it is safe to use non-null operator
82
- signedTransaction = utils_1.signTransaction(keyPair.getKeys().prv, this.transaction.toJson());
83
- }
84
- catch (e) {
85
- throw new sdk_core_1.SigningError('Failed to sign transaction via helper.');
86
- }
87
- // Ensure that we have more signatures than what we started with
88
- if (!signedTransaction.signature || oldSignatureCount >= signedTransaction.signature.length) {
89
- throw new sdk_core_1.SigningError('Transaction signing did not return an additional signature.');
90
- }
91
- return new transaction_1.Transaction(this._coinConfig, signedTransaction);
92
- }
93
- /** @inheritdoc */
94
- async buildImplementation() {
95
- // This is a no-op since Tron transactions are built from
96
- if (!this.transaction.id) {
97
- throw new sdk_core_1.BuildTransactionError('A valid transaction must have an id');
98
- }
99
- return Promise.resolve(this.transaction);
100
- }
101
- initBuilder(tx) {
102
- this.transaction = this.fromImplementation(tx);
103
- }
104
- /**
105
- * Extend the validity of this transaction by the given amount of time
106
- *
107
- * @param {number} extensionMs The number of milliseconds to extend the validTo time
108
- * @returns {undefined}
109
- */
110
- extendValidTo(extensionMs) {
111
- this.transaction.extendExpiration(extensionMs);
112
- }
113
- /** @inheritdoc */
114
- validateValue(value) {
115
- if (value.isLessThanOrEqualTo(0)) {
116
- throw new Error('Value cannot be below zero.');
117
- }
118
- // max long in Java - assumed upper limit for a TRX transaction
119
- if (value.isGreaterThan(new bignumber_js_1.default('9223372036854775807'))) {
120
- throw new Error('Value cannot be greater than handled by the javatron node.');
121
- }
122
- }
123
- /** @inheritdoc */
124
- validateAddress(address) {
125
- // assumes a base 58 address for our addresses
126
- if (!utils_1.isBase58Address(address.address)) {
127
- throw new Error(address.address + ' is not a valid base58 address.');
128
- }
129
- }
130
- /** @inheritdoc */
131
- validateKey(key) {
132
- try {
133
- new keyPair_1.KeyPair({ prv: key.key });
134
- }
135
- catch (err) {
136
- throw new Error('The provided key is not valid');
137
- }
138
- }
139
- /**
140
- * Validate the contents of a raw transaction. The validation
141
- * phase is to compare the raw-data-hex to the raw-data of the
142
- * transaction.
143
- *
144
- * The contents to be validated are
145
- * 1. The transaction id
146
- * 2. The expiration date
147
- * 3. The timestamp
148
- * 4. The contract
149
- *
150
- * @param {TransactionReceipt | string} rawTransaction The raw transaction to be validated
151
- */
152
- validateRawTransaction(rawTransaction) {
153
- // TODO: Validation of signature
154
- if (!rawTransaction) {
155
- throw new sdk_core_1.InvalidTransactionError('Raw transaction is empty');
156
- }
157
- let currTransaction;
158
- // rawTransaction can be either Stringified JSON OR
159
- // it can be a regular JSON object (not stringified).
160
- if (typeof rawTransaction === 'string') {
161
- try {
162
- currTransaction = JSON.parse(rawTransaction);
163
- }
164
- catch (e) {
165
- throw new sdk_core_1.ParseTransactionError('There was error in parsing the JSON string');
166
- }
167
- }
168
- else if (_.isObject(rawTransaction)) {
169
- currTransaction = rawTransaction;
170
- }
171
- else {
172
- throw new sdk_core_1.InvalidTransactionError('Transaction is not an object or stringified json');
173
- }
174
- const decodedRawDataHex = utils_1.decodeTransaction(currTransaction.raw_data_hex);
175
- if (!currTransaction.txID) {
176
- throw new sdk_core_1.InvalidTransactionError('Transaction ID is empty');
177
- }
178
- // Validate the transaction ID from the raw data hex
179
- const hexBuffer = Buffer.from(currTransaction.raw_data_hex, 'hex');
180
- const currTxID = crypto_1.createHash('sha256').update(hexBuffer).digest('hex');
181
- if (currTransaction.txID !== currTxID) {
182
- throw new sdk_core_1.InvalidTransactionError('Transaction has not have a valid id');
183
- }
184
- // Validate the expiration time from the raw-data-hex
185
- if (currTransaction.raw_data.expiration !== decodedRawDataHex.expiration) {
186
- throw new sdk_core_1.InvalidTransactionError('Transaction has not have a valid expiration');
187
- }
188
- // Validate the timestamp from the raw-data-hex
189
- if (currTransaction.raw_data.timestamp !== decodedRawDataHex.timestamp) {
190
- throw new sdk_core_1.InvalidTransactionError('Transaction has not have a valid timetamp');
191
- }
192
- // Transaction contract must exist
193
- if (!currTransaction.raw_data.contract) {
194
- throw new sdk_core_1.InvalidTransactionError('Transaction contracts are empty');
195
- }
196
- }
197
- /** @inheritdoc */
198
- validateTransaction(transaction) {
199
- const hexBuffer = Buffer.from(transaction.toJson().raw_data_hex, 'hex');
200
- const txId = crypto_1.createHash('sha256').update(hexBuffer).digest('hex');
201
- if (transaction.id !== txId) {
202
- throw new sdk_core_1.InvalidTransactionError(transaction.id + ' is not a valid transaction id. Expecting: ' + txId);
203
- }
204
- }
205
- /** @inheritdoc */
206
- get transaction() {
207
- return this._transaction;
208
- }
209
- /** @inheritdoc */
210
- set transaction(transaction) {
211
- this._transaction = transaction;
212
- }
213
- }
214
- exports.TransactionBuilder = TransactionBuilder;
215
- //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"transactionBuilder.js","sourceRoot":"","sources":["../../../src/lib/transactionBuilder.ts"],"names":[],"mappings":"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","sourcesContent":["import { createHash } from 'crypto';\nimport * as _ from 'lodash';\nimport BigNumber from 'bignumber.js';\nimport { BaseCoin as CoinConfig } from '@bitgo-beta/statics';\nimport {\n  BaseKey,\n  BaseTransactionBuilder,\n  BuildTransactionError,\n  InvalidTransactionError,\n  ParseTransactionError,\n  SigningError,\n} from '@bitgo-beta/sdk-core';\nimport { TransactionReceipt } from './iface';\nimport { Address } from './address';\nimport { signTransaction, isBase58Address, decodeTransaction } from './utils';\nimport { Transaction } from './transaction';\nimport { KeyPair } from './keyPair';\n\n/**\n * Tron transaction builder.\n */\nexport class TransactionBuilder extends BaseTransactionBuilder {\n  // transaction being built\n  private _transaction: Transaction;\n  /**\n   * Public constructor.\n   *\n   * @param {CoinConfig} _coinConfig Configuration object\n   */\n  constructor(_coinConfig: Readonly<CoinConfig>) {\n    super(_coinConfig);\n  }\n\n  /**\n   * Parse transaction takes in raw JSON directly from the node.\n   *\n   * @param {TransactionReceipt} rawTransaction The Tron transaction in JSON format as returned by the Tron lib or a stringifyed version of such JSON.\n   * @returns {Transaction} Tron transaction\n   */\n  protected fromImplementation(rawTransaction: TransactionReceipt | string): Transaction {\n    let tx;\n    if (typeof rawTransaction === 'string') {\n      const transaction = JSON.parse(rawTransaction);\n      tx = new Transaction(this._coinConfig, transaction);\n    } else {\n      tx = new Transaction(this._coinConfig, rawTransaction);\n    }\n    return tx;\n  }\n\n  /** @inheritdoc */\n  protected signImplementation(key: BaseKey): Transaction {\n    if (!this.transaction.inputs) {\n      throw new SigningError('Transaction has no sender');\n    }\n\n    if (!this.transaction.outputs) {\n      throw new SigningError('Transaction has no receiver');\n    }\n    return this.applySignature(key);\n  }\n\n  protected applySignature(key: BaseKey): Transaction {\n    const oldTransaction = this.transaction.toJson();\n    // Store the original signatures to compare them with the new ones in a later step. Signatures\n    // can be undefined if this is the first time the transaction is being signed\n    const oldSignatureCount = oldTransaction.signature ? oldTransaction.signature.length : 0;\n    let signedTransaction: TransactionReceipt;\n    try {\n      const keyPair = new KeyPair({ prv: key.key });\n      // Since the key pair was generated using a private key, it will always have a prv attribute,\n      // hence it is safe to use non-null operator\n      signedTransaction = signTransaction(keyPair.getKeys().prv!, this.transaction.toJson());\n    } catch (e) {\n      throw new SigningError('Failed to sign transaction via helper.');\n    }\n\n    // Ensure that we have more signatures than what we started with\n    if (!signedTransaction.signature || oldSignatureCount >= signedTransaction.signature.length) {\n      throw new SigningError('Transaction signing did not return an additional signature.');\n    }\n\n    return new Transaction(this._coinConfig, signedTransaction);\n  }\n\n  /** @inheritdoc */\n  protected async buildImplementation(): Promise<Transaction> {\n    // This is a no-op since Tron transactions are built from\n    if (!this.transaction.id) {\n      throw new BuildTransactionError('A valid transaction must have an id');\n    }\n    return Promise.resolve(this.transaction);\n  }\n\n  initBuilder(tx: TransactionReceipt | string) {\n    this.transaction = this.fromImplementation(tx);\n  }\n\n  /**\n   * Extend the validity of this transaction by the given amount of time\n   *\n   * @param {number} extensionMs The number of milliseconds to extend the validTo time\n   * @returns {undefined}\n   */\n  extendValidTo(extensionMs: number): void {\n    this.transaction.extendExpiration(extensionMs);\n  }\n\n  /** @inheritdoc */\n  validateValue(value: BigNumber): void {\n    if (value.isLessThanOrEqualTo(0)) {\n      throw new Error('Value cannot be below zero.');\n    }\n\n    // max long in Java - assumed upper limit for a TRX transaction\n    if (value.isGreaterThan(new BigNumber('9223372036854775807'))) {\n      throw new Error('Value cannot be greater than handled by the javatron node.');\n    }\n  }\n\n  /** @inheritdoc */\n  validateAddress(address: Address): void {\n    // assumes a base 58 address for our addresses\n    if (!isBase58Address(address.address)) {\n      throw new Error(address.address + ' is not a valid base58 address.');\n    }\n  }\n\n  /** @inheritdoc */\n  validateKey(key: BaseKey): void {\n    try {\n      new KeyPair({ prv: key.key });\n    } catch (err) {\n      throw new Error('The provided key is not valid');\n    }\n  }\n\n  /**\n   * Validate the contents of a raw transaction. The validation\n   * phase is to compare the raw-data-hex to the raw-data of the\n   * transaction.\n   *\n   * The contents to be validated are\n   * 1. The transaction id\n   * 2. The expiration date\n   * 3. The timestamp\n   * 4. The contract\n   *\n   * @param {TransactionReceipt | string} rawTransaction The raw transaction to be validated\n   */\n  validateRawTransaction(rawTransaction: TransactionReceipt | string): void {\n    // TODO: Validation of signature\n    if (!rawTransaction) {\n      throw new InvalidTransactionError('Raw transaction is empty');\n    }\n    let currTransaction: TransactionReceipt;\n    // rawTransaction can be either Stringified JSON OR\n    // it can be a regular JSON object (not stringified).\n    if (typeof rawTransaction === 'string') {\n      try {\n        currTransaction = JSON.parse(rawTransaction);\n      } catch (e) {\n        throw new ParseTransactionError('There was error in parsing the JSON string');\n      }\n    } else if (_.isObject(rawTransaction)) {\n      currTransaction = rawTransaction;\n    } else {\n      throw new InvalidTransactionError('Transaction is not an object or stringified json');\n    }\n    const decodedRawDataHex = decodeTransaction(currTransaction.raw_data_hex);\n    if (!currTransaction.txID) {\n      throw new InvalidTransactionError('Transaction ID is empty');\n    }\n    // Validate the transaction ID from the raw data hex\n    const hexBuffer = Buffer.from(currTransaction.raw_data_hex, 'hex');\n    const currTxID = createHash('sha256').update(hexBuffer).digest('hex');\n    if (currTransaction.txID !== currTxID) {\n      throw new InvalidTransactionError('Transaction has not have a valid id');\n    }\n    // Validate the expiration time from the raw-data-hex\n    if (currTransaction.raw_data.expiration !== decodedRawDataHex.expiration) {\n      throw new InvalidTransactionError('Transaction has not have a valid expiration');\n    }\n    // Validate the timestamp from the raw-data-hex\n    if (currTransaction.raw_data.timestamp !== decodedRawDataHex.timestamp) {\n      throw new InvalidTransactionError('Transaction has not have a valid timetamp');\n    }\n    // Transaction contract must exist\n    if (!currTransaction.raw_data.contract) {\n      throw new InvalidTransactionError('Transaction contracts are empty');\n    }\n  }\n\n  /** @inheritdoc */\n  validateTransaction(transaction: Transaction): void {\n    const hexBuffer = Buffer.from(transaction.toJson().raw_data_hex, 'hex');\n    const txId = createHash('sha256').update(hexBuffer).digest('hex');\n    if (transaction.id !== txId) {\n      throw new InvalidTransactionError(transaction.id + ' is not a valid transaction id. Expecting: ' + txId);\n    }\n  }\n\n  /** @inheritdoc */\n  protected get transaction(): Transaction {\n    return this._transaction;\n  }\n\n  /** @inheritdoc */\n  protected set transaction(transaction: Transaction) {\n    this._transaction = transaction;\n  }\n}\n"]}