@bitgo-beta/sdk-coin-iota 1.0.1-beta.324 → 1.0.1-beta.326
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.
- package/dist/src/iota.d.ts +123 -27
- package/dist/src/iota.d.ts.map +1 -1
- package/dist/src/iota.js +217 -103
- package/dist/src/lib/constants.d.ts +50 -1
- package/dist/src/lib/constants.d.ts.map +1 -1
- package/dist/src/lib/constants.js +68 -4
- package/dist/src/lib/iface.d.ts +141 -1
- package/dist/src/lib/iface.d.ts.map +1 -1
- package/dist/src/lib/iface.js +1 -1
- package/dist/src/lib/keyPair.d.ts +100 -6
- package/dist/src/lib/keyPair.d.ts.map +1 -1
- package/dist/src/lib/keyPair.js +103 -10
- package/dist/src/lib/transaction.d.ts +117 -14
- package/dist/src/lib/transaction.d.ts.map +1 -1
- package/dist/src/lib/transaction.js +190 -67
- package/dist/src/lib/transactionBuilder.d.ts +73 -34
- package/dist/src/lib/transactionBuilder.d.ts.map +1 -1
- package/dist/src/lib/transactionBuilder.js +90 -45
- package/dist/src/lib/transactionBuilderFactory.d.ts +89 -6
- package/dist/src/lib/transactionBuilderFactory.d.ts.map +1 -1
- package/dist/src/lib/transactionBuilderFactory.js +103 -16
- package/dist/src/lib/transferBuilder.d.ts +43 -0
- package/dist/src/lib/transferBuilder.d.ts.map +1 -1
- package/dist/src/lib/transferBuilder.js +50 -5
- package/dist/src/lib/transferTransaction.d.ts +93 -2
- package/dist/src/lib/transferTransaction.d.ts.map +1 -1
- package/dist/src/lib/transferTransaction.js +180 -51
- package/dist/src/lib/utils.d.ts +107 -8
- package/dist/src/lib/utils.d.ts.map +1 -1
- package/dist/src/lib/utils.js +134 -23
- package/dist/test/unit/helpers/testHelpers.d.ts +57 -0
- package/dist/test/unit/helpers/testHelpers.d.ts.map +1 -0
- package/dist/test/unit/helpers/testHelpers.js +176 -0
- package/dist/test/unit/iota.js +47 -152
- package/dist/test/unit/keyPair.js +34 -61
- package/dist/test/unit/transactionBuilder/transactionBuilder.js +137 -255
- package/dist/test/unit/transactionBuilder/transactionBuilderFactory.js +43 -108
- package/dist/test/unit/transactionBuilder/transferBuilder.js +296 -762
- package/dist/test/unit/transferTransaction.js +106 -353
- package/dist/test/unit/utils.js +171 -197
- package/dist/tsconfig.tsbuildinfo +1 -1
- package/package.json +7 -7
|
@@ -10,6 +10,10 @@ const utils_1 = require("@iota/iota-sdk/utils");
|
|
|
10
10
|
const blake2b_1 = __importDefault(require("@bitgo-beta/blake2b"));
|
|
11
11
|
const constants_1 = require("./constants");
|
|
12
12
|
const utils_2 = __importDefault(require("./utils"));
|
|
13
|
+
/**
|
|
14
|
+
* Base class for IOTA transactions.
|
|
15
|
+
* Manages transaction state, gas data, signatures, and building/serialization.
|
|
16
|
+
*/
|
|
13
17
|
class Transaction extends sdk_core_1.BaseTransaction {
|
|
14
18
|
constructor(coinConfig) {
|
|
15
19
|
super(coinConfig);
|
|
@@ -17,83 +21,130 @@ class Transaction extends sdk_core_1.BaseTransaction {
|
|
|
17
21
|
this._rebuildRequired = false;
|
|
18
22
|
this._isSimulateTx = true;
|
|
19
23
|
}
|
|
24
|
+
// Gas budget getter/setter - marks rebuild required when changed
|
|
20
25
|
get gasBudget() {
|
|
21
26
|
return this._gasBudget;
|
|
22
27
|
}
|
|
23
28
|
set gasBudget(value) {
|
|
24
29
|
this._gasBudget = value;
|
|
25
|
-
this.
|
|
30
|
+
this.markRebuildRequired();
|
|
26
31
|
}
|
|
32
|
+
// Gas payment objects getter/setter - marks rebuild required when changed
|
|
27
33
|
get gasPaymentObjects() {
|
|
28
34
|
return this._gasPaymentObjects;
|
|
29
35
|
}
|
|
30
36
|
set gasPaymentObjects(value) {
|
|
31
37
|
this._gasPaymentObjects = value;
|
|
32
|
-
this.
|
|
38
|
+
this.markRebuildRequired();
|
|
33
39
|
}
|
|
40
|
+
// Gas price getter/setter - marks rebuild required when changed
|
|
34
41
|
get gasPrice() {
|
|
35
42
|
return this._gasPrice;
|
|
36
43
|
}
|
|
37
44
|
set gasPrice(value) {
|
|
38
45
|
this._gasPrice = value;
|
|
39
|
-
this.
|
|
46
|
+
this.markRebuildRequired();
|
|
40
47
|
}
|
|
48
|
+
// Gas sponsor getter/setter - marks rebuild required when changed
|
|
41
49
|
get gasSponsor() {
|
|
42
50
|
return this._gasSponsor;
|
|
43
51
|
}
|
|
44
52
|
set gasSponsor(value) {
|
|
45
53
|
this._gasSponsor = value;
|
|
46
|
-
this.
|
|
54
|
+
this.markRebuildRequired();
|
|
47
55
|
}
|
|
56
|
+
// Transaction sender getter/setter - marks rebuild required when changed
|
|
48
57
|
get sender() {
|
|
49
58
|
return this._sender;
|
|
50
59
|
}
|
|
51
60
|
set sender(value) {
|
|
52
61
|
this._sender = value;
|
|
53
|
-
this.
|
|
62
|
+
this.markRebuildRequired();
|
|
54
63
|
}
|
|
64
|
+
/**
|
|
65
|
+
* Indicates whether this is a simulate transaction (dry run) or a real transaction.
|
|
66
|
+
* Simulate transactions use maximum gas values for estimation purposes.
|
|
67
|
+
*/
|
|
55
68
|
get isSimulateTx() {
|
|
56
69
|
return this._isSimulateTx;
|
|
57
70
|
}
|
|
58
71
|
set isSimulateTx(value) {
|
|
59
72
|
if (!value) {
|
|
60
|
-
|
|
61
|
-
|
|
62
|
-
this._rebuildRequired = true;
|
|
63
|
-
}
|
|
64
|
-
catch (error) {
|
|
65
|
-
const errorMessage = error instanceof Error ? error.message : 'Unknown error';
|
|
66
|
-
throw new Error(`Tx data validation failed: ${errorMessage}. {Cause: ${error}}`);
|
|
67
|
-
}
|
|
73
|
+
this.validateTxDataForRealTransaction();
|
|
74
|
+
this.markRebuildRequired();
|
|
68
75
|
}
|
|
69
76
|
this._isSimulateTx = value;
|
|
70
77
|
}
|
|
78
|
+
/**
|
|
79
|
+
* Marks that the transaction needs to be rebuilt before it can be signed or broadcast.
|
|
80
|
+
*/
|
|
81
|
+
markRebuildRequired() {
|
|
82
|
+
this._rebuildRequired = true;
|
|
83
|
+
}
|
|
84
|
+
/**
|
|
85
|
+
* Validates transaction data when switching from simulate to real transaction mode.
|
|
86
|
+
*/
|
|
87
|
+
validateTxDataForRealTransaction() {
|
|
88
|
+
try {
|
|
89
|
+
this.validateTxData();
|
|
90
|
+
}
|
|
91
|
+
catch (error) {
|
|
92
|
+
const errorMessage = error instanceof Error ? error.message : 'Unknown error';
|
|
93
|
+
throw new Error(`Tx data validation failed: ${errorMessage}. {Cause: ${error}}`);
|
|
94
|
+
}
|
|
95
|
+
}
|
|
96
|
+
/**
|
|
97
|
+
* Returns the signable payload for this transaction.
|
|
98
|
+
* This is the Blake2b hash of the transaction data with intent message.
|
|
99
|
+
* @throws Error if transaction is in simulate mode or not built
|
|
100
|
+
*/
|
|
71
101
|
get signablePayload() {
|
|
72
102
|
if (this.isSimulateTx) {
|
|
73
103
|
throw new Error('Cannot sign a simulate tx');
|
|
74
104
|
}
|
|
75
|
-
|
|
76
|
-
throw new Error('Tx not built or a rebuild is required');
|
|
77
|
-
}
|
|
105
|
+
this.ensureTransactionIsBuilt();
|
|
78
106
|
const intentMessage = this.messageWithIntent(this._txDataBytes);
|
|
79
107
|
return Buffer.from((0, blake2b_1.default)(32).update(intentMessage).digest('binary'));
|
|
80
108
|
}
|
|
81
|
-
/**
|
|
109
|
+
/**
|
|
110
|
+
* Returns the transaction digest (ID).
|
|
111
|
+
* @throws Error if transaction is not built or needs rebuilding
|
|
112
|
+
*/
|
|
82
113
|
get id() {
|
|
114
|
+
this.ensureTransactionIsBuilt();
|
|
115
|
+
return transactions_1.TransactionDataBuilder.getDigestFromBytes(this._txDataBytes);
|
|
116
|
+
}
|
|
117
|
+
/**
|
|
118
|
+
* Ensures the transaction is built and doesn't need rebuilding.
|
|
119
|
+
* @throws Error if transaction is not built or rebuild is required
|
|
120
|
+
*/
|
|
121
|
+
ensureTransactionIsBuilt() {
|
|
83
122
|
if (this._txDataBytes === undefined || this._rebuildRequired) {
|
|
84
123
|
throw new Error('Tx not built or a rebuild is required');
|
|
85
124
|
}
|
|
86
|
-
return transactions_1.TransactionDataBuilder.getDigestFromBytes(this._txDataBytes);
|
|
87
125
|
}
|
|
126
|
+
/**
|
|
127
|
+
* Adds a signature from the transaction sender.
|
|
128
|
+
*/
|
|
88
129
|
addSignature(publicKey, signature) {
|
|
89
130
|
this._signature = { publicKey, signature };
|
|
90
131
|
}
|
|
132
|
+
/**
|
|
133
|
+
* Adds a signature from the gas sponsor (if different from sender).
|
|
134
|
+
*/
|
|
91
135
|
addGasSponsorSignature(publicKey, signature) {
|
|
92
136
|
this._gasSponsorSignature = { publicKey, signature };
|
|
93
137
|
}
|
|
138
|
+
/**
|
|
139
|
+
* Checks if this transaction can be signed.
|
|
140
|
+
* Only real transactions (not simulate) can be signed.
|
|
141
|
+
*/
|
|
94
142
|
canSign(_key) {
|
|
95
143
|
return !this.isSimulateTx;
|
|
96
144
|
}
|
|
145
|
+
/**
|
|
146
|
+
* Returns the transaction fee (gas budget).
|
|
147
|
+
*/
|
|
97
148
|
getFee() {
|
|
98
149
|
return this.gasBudget?.toString();
|
|
99
150
|
}
|
|
@@ -103,6 +154,10 @@ class Transaction extends sdk_core_1.BaseTransaction {
|
|
|
103
154
|
get serializedSignature() {
|
|
104
155
|
return this._serializedSignature;
|
|
105
156
|
}
|
|
157
|
+
/**
|
|
158
|
+
* Serializes all signatures for the transaction.
|
|
159
|
+
* Includes both sender signature and gas sponsor signature if present.
|
|
160
|
+
*/
|
|
106
161
|
serializeSignatures() {
|
|
107
162
|
this._signatures = [];
|
|
108
163
|
if (this._signature) {
|
|
@@ -114,15 +169,23 @@ class Transaction extends sdk_core_1.BaseTransaction {
|
|
|
114
169
|
this._signatures.push(this._serializedGasSponsorSignature);
|
|
115
170
|
}
|
|
116
171
|
}
|
|
172
|
+
/**
|
|
173
|
+
* Converts the transaction to broadcast format (base64 encoded).
|
|
174
|
+
*/
|
|
117
175
|
async toBroadcastFormat() {
|
|
118
176
|
const txDataBytes = await this.build();
|
|
119
177
|
return (0, utils_1.toBase64)(txDataBytes);
|
|
120
178
|
}
|
|
179
|
+
/**
|
|
180
|
+
* Builds the transaction bytes.
|
|
181
|
+
* If in simulate mode, builds a dry run transaction with max gas values.
|
|
182
|
+
* Otherwise, builds a real transaction with actual gas data.
|
|
183
|
+
*/
|
|
121
184
|
async build() {
|
|
122
185
|
if (this.isSimulateTx) {
|
|
123
186
|
return this.buildDryRunTransaction();
|
|
124
187
|
}
|
|
125
|
-
return this.
|
|
188
|
+
return this.buildRealTransaction();
|
|
126
189
|
}
|
|
127
190
|
toJson() {
|
|
128
191
|
return {
|
|
@@ -143,35 +206,42 @@ class Transaction extends sdk_core_1.BaseTransaction {
|
|
|
143
206
|
this.gasSponsor = txData.gasSponsor;
|
|
144
207
|
}
|
|
145
208
|
}
|
|
209
|
+
/**
|
|
210
|
+
* Parses transaction data from its broadcast format (base64 or raw bytes).
|
|
211
|
+
* Extracts sender, gas data, and gas sponsor information.
|
|
212
|
+
*/
|
|
146
213
|
parseFromBroadcastTx(tx) {
|
|
147
214
|
const txData = transactions_1.Transaction.from(tx).getData();
|
|
215
|
+
this.parseSender(txData);
|
|
216
|
+
this.parseGasData(txData);
|
|
217
|
+
}
|
|
218
|
+
/**
|
|
219
|
+
* Parses the sender address from transaction data.
|
|
220
|
+
*/
|
|
221
|
+
parseSender(txData) {
|
|
148
222
|
if (txData.sender) {
|
|
149
223
|
this.sender = txData.sender;
|
|
150
224
|
}
|
|
151
|
-
|
|
152
|
-
|
|
153
|
-
|
|
154
|
-
|
|
225
|
+
}
|
|
226
|
+
/**
|
|
227
|
+
* Parses gas-related data from transaction data.
|
|
228
|
+
*/
|
|
229
|
+
parseGasData(txData) {
|
|
230
|
+
const gasData = txData.gasData;
|
|
231
|
+
if (!gasData) {
|
|
155
232
|
this.gasBudget = undefined;
|
|
156
|
-
}
|
|
157
|
-
if (txData.gasData?.price) {
|
|
158
|
-
this.gasPrice = Number(txData.gasData.price);
|
|
159
|
-
}
|
|
160
|
-
else {
|
|
161
233
|
this.gasPrice = undefined;
|
|
162
|
-
}
|
|
163
|
-
if (txData.gasData?.payment && txData.gasData.payment.length > 0) {
|
|
164
|
-
this.gasPaymentObjects = txData.gasData.payment.map((payment) => payment);
|
|
165
|
-
}
|
|
166
|
-
else {
|
|
167
234
|
this.gasPaymentObjects = undefined;
|
|
168
|
-
}
|
|
169
|
-
if (txData.gasData?.owner) {
|
|
170
|
-
this.gasSponsor = txData.gasData.owner;
|
|
171
|
-
}
|
|
172
|
-
else {
|
|
173
235
|
this.gasSponsor = undefined;
|
|
236
|
+
return;
|
|
174
237
|
}
|
|
238
|
+
this.gasBudget = gasData.budget ? Number(gasData.budget) : undefined;
|
|
239
|
+
this.gasPrice = gasData.price ? Number(gasData.price) : undefined;
|
|
240
|
+
this.gasPaymentObjects =
|
|
241
|
+
gasData.payment && gasData.payment.length > 0
|
|
242
|
+
? gasData.payment.map((payment) => payment)
|
|
243
|
+
: undefined;
|
|
244
|
+
this.gasSponsor = gasData.owner || undefined;
|
|
175
245
|
}
|
|
176
246
|
/**
|
|
177
247
|
* @inheritDoc
|
|
@@ -194,14 +264,18 @@ class Transaction extends sdk_core_1.BaseTransaction {
|
|
|
194
264
|
};
|
|
195
265
|
return this.explainTransactionImplementation(result, explanationResult);
|
|
196
266
|
}
|
|
267
|
+
/**
|
|
268
|
+
* Updates the simulate transaction flag based on gas data availability.
|
|
269
|
+
* If all gas data is present, switches to real transaction mode.
|
|
270
|
+
*/
|
|
197
271
|
updateIsSimulateTx() {
|
|
198
|
-
|
|
199
|
-
|
|
200
|
-
}
|
|
201
|
-
else {
|
|
202
|
-
this.isSimulateTx = true;
|
|
203
|
-
}
|
|
272
|
+
const hasAllGasData = this.gasBudget && this.gasPrice && this.gasPaymentObjects && this.gasPaymentObjects.length > 0;
|
|
273
|
+
this.isSimulateTx = !hasAllGasData;
|
|
204
274
|
}
|
|
275
|
+
/**
|
|
276
|
+
* Builds a dry run (simulate) transaction with maximum gas values.
|
|
277
|
+
* Used for gas estimation without committing the transaction.
|
|
278
|
+
*/
|
|
205
279
|
async buildDryRunTransaction() {
|
|
206
280
|
this.validateTxDataImplementation();
|
|
207
281
|
await this.populateTxData();
|
|
@@ -216,39 +290,83 @@ class Transaction extends sdk_core_1.BaseTransaction {
|
|
|
216
290
|
},
|
|
217
291
|
});
|
|
218
292
|
}
|
|
219
|
-
|
|
293
|
+
/**
|
|
294
|
+
* Builds a real transaction with actual gas data.
|
|
295
|
+
* Only builds if necessary (first time or rebuild required).
|
|
296
|
+
*/
|
|
297
|
+
async buildRealTransaction() {
|
|
220
298
|
if (this._txDataBytes === undefined || this._rebuildRequired) {
|
|
221
299
|
this.validateTxData();
|
|
222
300
|
await this.populateTxData();
|
|
223
|
-
this.
|
|
224
|
-
this._iotaTransaction.setGasBudget(this.gasBudget);
|
|
225
|
-
this._iotaTransaction.setGasPayment(this.gasPaymentObjects?.slice(0, constants_1.MAX_GAS_PAYMENT_OBJECTS - 1));
|
|
301
|
+
this.setGasDataOnTransaction();
|
|
226
302
|
this._txDataBytes = await this._iotaTransaction.build();
|
|
227
303
|
this._rebuildRequired = false;
|
|
228
304
|
}
|
|
229
305
|
this.serializeSignatures();
|
|
230
306
|
return this._txDataBytes;
|
|
231
307
|
}
|
|
308
|
+
/**
|
|
309
|
+
* Sets gas data on the IOTA transaction object.
|
|
310
|
+
*/
|
|
311
|
+
setGasDataOnTransaction() {
|
|
312
|
+
this._iotaTransaction.setGasPrice(this.gasPrice);
|
|
313
|
+
this._iotaTransaction.setGasBudget(this.gasBudget);
|
|
314
|
+
this._iotaTransaction.setGasPayment(this.gasPaymentObjects.slice(0, constants_1.MAX_GAS_PAYMENT_OBJECTS - 1));
|
|
315
|
+
}
|
|
316
|
+
/**
|
|
317
|
+
* Populates the IOTA transaction with inputs, commands, and gas sponsor if applicable.
|
|
318
|
+
*/
|
|
232
319
|
async populateTxData() {
|
|
233
320
|
this._iotaTransaction = new transactions_1.Transaction();
|
|
234
321
|
this.populateTxInputsAndCommands();
|
|
235
|
-
|
|
236
|
-
|
|
237
|
-
this.
|
|
322
|
+
// If gas sponsor is different from sender, set up sponsored transaction
|
|
323
|
+
if (this.hasDifferentGasSponsor()) {
|
|
324
|
+
await this.setupGasSponsoredTransaction();
|
|
238
325
|
}
|
|
239
326
|
this._iotaTransaction.setSender(this.sender);
|
|
240
327
|
}
|
|
328
|
+
/**
|
|
329
|
+
* Checks if the transaction has a gas sponsor different from the sender.
|
|
330
|
+
*/
|
|
331
|
+
hasDifferentGasSponsor() {
|
|
332
|
+
return Boolean(this.gasSponsor && this._sender !== this.gasSponsor);
|
|
333
|
+
}
|
|
334
|
+
/**
|
|
335
|
+
* Sets up a gas-sponsored transaction by building the transaction kind
|
|
336
|
+
* and setting the gas owner.
|
|
337
|
+
*/
|
|
338
|
+
async setupGasSponsoredTransaction() {
|
|
339
|
+
const transactionKind = await this._iotaTransaction.build({ onlyTransactionKind: true });
|
|
340
|
+
this._iotaTransaction = transactions_1.Transaction.fromKind(transactionKind);
|
|
341
|
+
this._iotaTransaction.setGasOwner(this._gasSponsor);
|
|
342
|
+
}
|
|
343
|
+
/**
|
|
344
|
+
* Serializes a signature into IOTA's expected format.
|
|
345
|
+
* Format: [signature_scheme_flag (1 byte), signature, public_key]
|
|
346
|
+
* Currently hardcoded to EDDSA (0x00) as IOTA only supports this scheme.
|
|
347
|
+
*/
|
|
241
348
|
serializeSignature(signature) {
|
|
349
|
+
const SIGNATURE_SCHEME_EDDSA = 0x00;
|
|
242
350
|
const pubKey = Buffer.from(signature.publicKey.pub, 'hex');
|
|
243
|
-
const
|
|
244
|
-
|
|
245
|
-
|
|
246
|
-
|
|
247
|
-
return (0, utils_1.toBase64)(
|
|
351
|
+
const serializedSignature = new Uint8Array(1 + signature.signature.length + pubKey.length);
|
|
352
|
+
serializedSignature.set([SIGNATURE_SCHEME_EDDSA]);
|
|
353
|
+
serializedSignature.set(signature.signature, 1);
|
|
354
|
+
serializedSignature.set(pubKey, 1 + signature.signature.length);
|
|
355
|
+
return (0, utils_1.toBase64)(serializedSignature);
|
|
248
356
|
}
|
|
357
|
+
/**
|
|
358
|
+
* Validates all transaction data required for a real (non-simulate) transaction.
|
|
359
|
+
*/
|
|
249
360
|
validateTxData() {
|
|
250
361
|
this.validateTxDataImplementation();
|
|
251
|
-
|
|
362
|
+
this.validateCommonTxData();
|
|
363
|
+
this.validateSignatures();
|
|
364
|
+
}
|
|
365
|
+
/**
|
|
366
|
+
* Validates common transaction data (sender, gas data).
|
|
367
|
+
*/
|
|
368
|
+
validateCommonTxData() {
|
|
369
|
+
if (!this.sender) {
|
|
252
370
|
throw new sdk_core_1.InvalidTransactionError('Transaction sender is required');
|
|
253
371
|
}
|
|
254
372
|
if (!this.gasPrice) {
|
|
@@ -257,22 +375,27 @@ class Transaction extends sdk_core_1.BaseTransaction {
|
|
|
257
375
|
if (!this.gasBudget) {
|
|
258
376
|
throw new sdk_core_1.InvalidTransactionError('Gas budget is required');
|
|
259
377
|
}
|
|
260
|
-
if (!this.gasPaymentObjects || this.gasPaymentObjects
|
|
378
|
+
if (!this.gasPaymentObjects || this.gasPaymentObjects.length === 0) {
|
|
261
379
|
throw new sdk_core_1.InvalidTransactionError('Gas payment objects are required');
|
|
262
380
|
}
|
|
263
|
-
|
|
264
|
-
|
|
265
|
-
|
|
381
|
+
}
|
|
382
|
+
/**
|
|
383
|
+
* Validates sender and gas sponsor signatures if present.
|
|
384
|
+
*/
|
|
385
|
+
validateSignatures() {
|
|
386
|
+
if (this._signature && !this.isValidSignature(this._signature)) {
|
|
266
387
|
throw new sdk_core_1.InvalidTransactionError('Invalid sender signature');
|
|
267
388
|
}
|
|
268
|
-
if (this._gasSponsorSignature &&
|
|
269
|
-
!(utils_2.default.isValidPublicKey(this._gasSponsorSignature.publicKey.pub) &&
|
|
270
|
-
utils_2.default.isValidSignature((0, utils_1.toBase64)(this._gasSponsorSignature.signature)))) {
|
|
389
|
+
if (this._gasSponsorSignature && !this.isValidSignature(this._gasSponsorSignature)) {
|
|
271
390
|
throw new sdk_core_1.InvalidTransactionError('Invalid gas sponsor signature');
|
|
272
391
|
}
|
|
273
392
|
}
|
|
393
|
+
/**
|
|
394
|
+
* Checks if a signature has valid public key and signature data.
|
|
395
|
+
*/
|
|
396
|
+
isValidSignature(signature) {
|
|
397
|
+
return utils_2.default.isValidPublicKey(signature.publicKey.pub) && utils_2.default.isValidSignature((0, utils_1.toBase64)(signature.signature));
|
|
398
|
+
}
|
|
274
399
|
}
|
|
275
400
|
exports.Transaction = Transaction;
|
|
276
|
-
Transaction.EMPTY_PUBLIC_KEY = Buffer.alloc(constants_1.IOTA_KEY_BYTES_LENGTH);
|
|
277
|
-
Transaction.EMPTY_SIGNATURE = Buffer.alloc(constants_1.IOTA_SIGNATURE_LENGTH);
|
|
278
|
-
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"transaction.js","sourceRoot":"","sources":["../../../src/lib/transaction.ts"],"names":[],"mappings":"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","sourcesContent":["import {\n  BaseKey,\n  BaseTransaction,\n  InvalidTransactionError,\n  PublicKey,\n  Signature,\n  TransactionRecipient,\n  TransactionType,\n} from '@bitgo-beta/sdk-core';\nimport { BaseCoin as CoinConfig } from '@bitgo-beta/statics';\nimport {\n  TransactionData as IotaTransactionData,\n  Transaction as IotaTransaction,\n  TransactionDataBuilder as IotaTransactionDataBuilder,\n} from '@iota/iota-sdk/transactions';\nimport { TxData, TransactionObjectInput, TransactionExplanation } from './iface';\nimport { toBase64 } from '@iota/iota-sdk/utils';\nimport blake2b from '@bitgo-beta/blake2b';\nimport {\n  MAX_GAS_BUDGET,\n  MAX_GAS_PAYMENT_OBJECTS,\n  MAX_GAS_PRICE,\n  IOTA_KEY_BYTES_LENGTH,\n  IOTA_SIGNATURE_LENGTH,\n} from './constants';\nimport utils from './utils';\n\nexport abstract class Transaction extends BaseTransaction {\n  static EMPTY_PUBLIC_KEY = Buffer.alloc(IOTA_KEY_BYTES_LENGTH);\n  static EMPTY_SIGNATURE = Buffer.alloc(IOTA_SIGNATURE_LENGTH);\n\n  protected _rebuildRequired: boolean;\n  protected _type: TransactionType;\n  protected _iotaTransaction: IotaTransaction;\n\n  private _gasBudget?: number;\n  private _gasPaymentObjects?: TransactionObjectInput[];\n  private _gasPrice?: number;\n  private _gasSponsor?: string;\n  private _sender: string;\n  private _signature?: Signature;\n  private _serializedSignature?: string;\n  private _gasSponsorSignature?: Signature;\n  private _serializedGasSponsorSignature?: string;\n  private _txDataBytes?: Uint8Array<ArrayBufferLike>;\n  private _isSimulateTx: boolean;\n\n  protected constructor(coinConfig: Readonly<CoinConfig>) {\n    super(coinConfig);\n    this._sender = '';\n    this._rebuildRequired = false;\n    this._isSimulateTx = true;\n  }\n\n  get gasBudget(): number | undefined {\n    return this._gasBudget;\n  }\n\n  set gasBudget(value: number | undefined) {\n    this._gasBudget = value;\n    this._rebuildRequired = true;\n  }\n\n  get gasPaymentObjects(): TransactionObjectInput[] | undefined {\n    return this._gasPaymentObjects;\n  }\n\n  set gasPaymentObjects(value: TransactionObjectInput[] | undefined) {\n    this._gasPaymentObjects = value;\n    this._rebuildRequired = true;\n  }\n\n  get gasPrice(): number | undefined {\n    return this._gasPrice;\n  }\n\n  set gasPrice(value: number | undefined) {\n    this._gasPrice = value;\n    this._rebuildRequired = true;\n  }\n\n  get gasSponsor(): string | undefined {\n    return this._gasSponsor;\n  }\n\n  set gasSponsor(value: string | undefined) {\n    this._gasSponsor = value;\n    this._rebuildRequired = true;\n  }\n\n  get sender(): string {\n    return this._sender;\n  }\n\n  set sender(value: string) {\n    this._sender = value;\n    this._rebuildRequired = true;\n  }\n\n  get isSimulateTx(): boolean {\n    return this._isSimulateTx;\n  }\n\n  set isSimulateTx(value: boolean) {\n    if (!value) {\n      try {\n        this.validateTxData();\n        this._rebuildRequired = true;\n      } catch (error) {\n        const errorMessage = error instanceof Error ? error.message : 'Unknown error';\n        throw new Error(`Tx data validation failed: ${errorMessage}. {Cause: ${error}}`);\n      }\n    }\n    this._isSimulateTx = value;\n  }\n\n  get signablePayload(): Buffer {\n    if (this.isSimulateTx) {\n      throw new Error('Cannot sign a simulate tx');\n    }\n    if (this._txDataBytes === undefined || this._rebuildRequired) {\n      throw new Error('Tx not built or a rebuild is required');\n    }\n    const intentMessage = this.messageWithIntent(this._txDataBytes);\n    return Buffer.from(blake2b(32).update(intentMessage).digest('binary'));\n  }\n\n  /** @inheritDoc **/\n  get id(): string {\n    if (this._txDataBytes === undefined || this._rebuildRequired) {\n      throw new Error('Tx not built or a rebuild is required');\n    }\n    return IotaTransactionDataBuilder.getDigestFromBytes(this._txDataBytes);\n  }\n\n  addSignature(publicKey: PublicKey, signature: Buffer): void {\n    this._signature = { publicKey, signature };\n  }\n\n  addGasSponsorSignature(publicKey: PublicKey, signature: Buffer): void {\n    this._gasSponsorSignature = { publicKey, signature };\n  }\n\n  canSign(_key: BaseKey): boolean {\n    return !this.isSimulateTx;\n  }\n\n  getFee(): string | undefined {\n    return this.gasBudget?.toString();\n  }\n\n  get serializedGasSponsorSignature(): string | undefined {\n    return this._serializedGasSponsorSignature;\n  }\n\n  get serializedSignature(): string | undefined {\n    return this._serializedSignature;\n  }\n\n  serializeSignatures(): void {\n    this._signatures = [];\n    if (this._signature) {\n      this._serializedSignature = this.serializeSignature(this._signature as Signature);\n      this._signatures.push(this._serializedSignature);\n    }\n    if (this._gasSponsorSignature) {\n      this._serializedGasSponsorSignature = this.serializeSignature(this._gasSponsorSignature as Signature);\n      this._signatures.push(this._serializedGasSponsorSignature);\n    }\n  }\n\n  async toBroadcastFormat(): Promise<string> {\n    const txDataBytes: Uint8Array<ArrayBufferLike> = await this.build();\n    return toBase64(txDataBytes);\n  }\n\n  async build(): Promise<Uint8Array<ArrayBufferLike>> {\n    if (this.isSimulateTx) {\n      return this.buildDryRunTransaction();\n    }\n    return this.buildTransaction();\n  }\n\n  toJson(): TxData {\n    return {\n      sender: this.sender,\n      gasBudget: this.gasBudget,\n      gasPrice: this.gasPrice,\n      gasPaymentObjects: this.gasPaymentObjects,\n      gasSponsor: this.gasSponsor,\n      type: this.type,\n    };\n  }\n\n  parseFromJSON(txData: TxData): void {\n    this.sender = txData.sender;\n    this.gasBudget = txData.gasBudget;\n    this.gasPrice = txData.gasPrice;\n    this.gasPaymentObjects = txData.gasPaymentObjects;\n    if (txData.gasSponsor !== undefined) {\n      this.gasSponsor = txData.gasSponsor;\n    }\n  }\n\n  parseFromBroadcastTx(tx: string | Uint8Array): void {\n    const txData = IotaTransaction.from(tx).getData();\n    if (txData.sender) {\n      this.sender = txData.sender;\n    }\n    if (txData.gasData?.budget) {\n      this.gasBudget = Number(txData.gasData.budget);\n    } else {\n      this.gasBudget = undefined;\n    }\n    if (txData.gasData?.price) {\n      this.gasPrice = Number(txData.gasData.price);\n    } else {\n      this.gasPrice = undefined;\n    }\n    if (txData.gasData?.payment && txData.gasData.payment.length > 0) {\n      this.gasPaymentObjects = txData.gasData.payment.map((payment) => payment as TransactionObjectInput);\n    } else {\n      this.gasPaymentObjects = undefined;\n    }\n    if (txData.gasData?.owner) {\n      this.gasSponsor = txData.gasData.owner;\n    } else {\n      this.gasSponsor = undefined;\n    }\n  }\n\n  /**\n   * @inheritDoc\n   */\n  explainTransaction(): any {\n    const result = this.toJson();\n    const displayOrder = ['id', 'outputs', 'outputAmount', 'changeOutputs', 'changeAmount', 'fee', 'type'];\n    const outputs: TransactionRecipient[] = [];\n\n    const explanationResult: TransactionExplanation = {\n      displayOrder,\n      id: this.id,\n      outputs,\n      outputAmount: '0',\n      changeOutputs: [],\n      changeAmount: '0',\n      fee: { fee: this.gasBudget ? this.gasBudget.toString() : '' },\n      sender: this.sender,\n      sponsor: this.gasSponsor,\n      type: this.type,\n    };\n\n    return this.explainTransactionImplementation(result, explanationResult);\n  }\n\n  protected updateIsSimulateTx(): void {\n    if (this.gasBudget && this.gasPrice && this.gasPaymentObjects && this.gasPaymentObjects?.length > 0) {\n      this.isSimulateTx = false;\n    } else {\n      this.isSimulateTx = true;\n    }\n  }\n\n  protected abstract messageWithIntent(message: Uint8Array): Uint8Array;\n  protected abstract populateTxInputsAndCommands(): void;\n  protected abstract validateTxDataImplementation(): void;\n\n  /**\n   * Add the input and output entries for this transaction.\n   */\n  abstract addInputsAndOutputs(): void;\n\n  /**\n   * Returns a complete explanation for a transfer transaction\n   * @param {TxData} json The transaction data in json format\n   * @param {TransactionExplanation} explanationResult The transaction explanation to be completed\n   * @returns {TransactionExplanation}\n   */\n  protected abstract explainTransactionImplementation(\n    json: TxData,\n    explanationResult: TransactionExplanation\n  ): TransactionExplanation;\n\n  private async buildDryRunTransaction(): Promise<Uint8Array<ArrayBufferLike>> {\n    this.validateTxDataImplementation();\n    await this.populateTxData();\n    const txDataBuilder = new IotaTransactionDataBuilder(this._iotaTransaction.getData() as IotaTransactionData);\n    return txDataBuilder.build({\n      overrides: {\n        gasData: {\n          budget: MAX_GAS_BUDGET.toString(),\n          price: MAX_GAS_PRICE.toString(),\n          payment: [],\n        },\n      },\n    });\n  }\n\n  private async buildTransaction(): Promise<Uint8Array<ArrayBufferLike>> {\n    if (this._txDataBytes === undefined || this._rebuildRequired) {\n      this.validateTxData();\n      await this.populateTxData();\n      this._iotaTransaction.setGasPrice(this.gasPrice as number);\n      this._iotaTransaction.setGasBudget(this.gasBudget as number);\n      this._iotaTransaction.setGasPayment(\n        this.gasPaymentObjects?.slice(0, MAX_GAS_PAYMENT_OBJECTS - 1) as TransactionObjectInput[]\n      );\n      this._txDataBytes = await this._iotaTransaction.build();\n      this._rebuildRequired = false;\n    }\n    this.serializeSignatures();\n    return this._txDataBytes;\n  }\n\n  private async populateTxData(): Promise<void> {\n    this._iotaTransaction = new IotaTransaction();\n    this.populateTxInputsAndCommands();\n    if (this.gasSponsor && this._sender !== this.gasSponsor) {\n      this._iotaTransaction = IotaTransaction.fromKind(\n        await this._iotaTransaction.build({ onlyTransactionKind: true })\n      );\n      this._iotaTransaction.setGasOwner(this._gasSponsor as string);\n    }\n    this._iotaTransaction.setSender(this.sender);\n  }\n\n  private serializeSignature(signature: Signature): string {\n    const pubKey = Buffer.from(signature.publicKey.pub, 'hex');\n    const serialized_sig = new Uint8Array(1 + signature.signature.length + pubKey.length);\n    serialized_sig.set([0x00]); //Hardcoding the signature scheme flag since we only support EDDSA for iota\n    serialized_sig.set(signature.signature, 1);\n    serialized_sig.set(pubKey, 1 + signature.signature.length);\n    return toBase64(serialized_sig);\n  }\n\n  private validateTxData(): void {\n    this.validateTxDataImplementation();\n    if (!this.sender || this.sender === '') {\n      throw new InvalidTransactionError('Transaction sender is required');\n    }\n\n    if (!this.gasPrice) {\n      throw new InvalidTransactionError('Gas price is required');\n    }\n\n    if (!this.gasBudget) {\n      throw new InvalidTransactionError('Gas budget is required');\n    }\n\n    if (!this.gasPaymentObjects || this.gasPaymentObjects?.length === 0) {\n      throw new InvalidTransactionError('Gas payment objects are required');\n    }\n\n    if (\n      this._signature &&\n      !(\n        utils.isValidPublicKey(this._signature.publicKey.pub) &&\n        utils.isValidSignature(toBase64(this._signature.signature))\n      )\n    ) {\n      throw new InvalidTransactionError('Invalid sender signature');\n    }\n\n    if (\n      this._gasSponsorSignature &&\n      !(\n        utils.isValidPublicKey(this._gasSponsorSignature.publicKey.pub) &&\n        utils.isValidSignature(toBase64(this._gasSponsorSignature.signature))\n      )\n    ) {\n      throw new InvalidTransactionError('Invalid gas sponsor signature');\n    }\n  }\n}\n"]}
|
|
401
|
+
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"transaction.js","sourceRoot":"","sources":["../../../src/lib/transaction.ts"],"names":[],"mappings":";;;;;;AAAA,mDAQ8B;AAE9B,8DAIqC;AAErC,gDAAgD;AAChD,kEAA0C;AAC1C,2CAAqF;AACrF,oDAA4B;AAE5B;;;GAGG;AACH,MAAsB,WAAY,SAAQ,0BAAe;IAuBvD,YAAsB,UAAgC;QACpD,KAAK,CAAC,UAAU,CAAC,CAAC;QAClB,IAAI,CAAC,OAAO,GAAG,EAAE,CAAC;QAClB,IAAI,CAAC,gBAAgB,GAAG,KAAK,CAAC;QAC9B,IAAI,CAAC,aAAa,GAAG,IAAI,CAAC;IAC5B,CAAC;IAED,iEAAiE;IACjE,IAAI,SAAS;QACX,OAAO,IAAI,CAAC,UAAU,CAAC;IACzB,CAAC;IAED,IAAI,SAAS,CAAC,KAAyB;QACrC,IAAI,CAAC,UAAU,GAAG,KAAK,CAAC;QACxB,IAAI,CAAC,mBAAmB,EAAE,CAAC;IAC7B,CAAC;IAED,0EAA0E;IAC1E,IAAI,iBAAiB;QACnB,OAAO,IAAI,CAAC,kBAAkB,CAAC;IACjC,CAAC;IAED,IAAI,iBAAiB,CAAC,KAA2C;QAC/D,IAAI,CAAC,kBAAkB,GAAG,KAAK,CAAC;QAChC,IAAI,CAAC,mBAAmB,EAAE,CAAC;IAC7B,CAAC;IAED,gEAAgE;IAChE,IAAI,QAAQ;QACV,OAAO,IAAI,CAAC,SAAS,CAAC;IACxB,CAAC;IAED,IAAI,QAAQ,CAAC,KAAyB;QACpC,IAAI,CAAC,SAAS,GAAG,KAAK,CAAC;QACvB,IAAI,CAAC,mBAAmB,EAAE,CAAC;IAC7B,CAAC;IAED,kEAAkE;IAClE,IAAI,UAAU;QACZ,OAAO,IAAI,CAAC,WAAW,CAAC;IAC1B,CAAC;IAED,IAAI,UAAU,CAAC,KAAyB;QACtC,IAAI,CAAC,WAAW,GAAG,KAAK,CAAC;QACzB,IAAI,CAAC,mBAAmB,EAAE,CAAC;IAC7B,CAAC;IAED,yEAAyE;IACzE,IAAI,MAAM;QACR,OAAO,IAAI,CAAC,OAAO,CAAC;IACtB,CAAC;IAED,IAAI,MAAM,CAAC,KAAa;QACtB,IAAI,CAAC,OAAO,GAAG,KAAK,CAAC;QACrB,IAAI,CAAC,mBAAmB,EAAE,CAAC;IAC7B,CAAC;IAED;;;OAGG;IACH,IAAI,YAAY;QACd,OAAO,IAAI,CAAC,aAAa,CAAC;IAC5B,CAAC;IAED,IAAI,YAAY,CAAC,KAAc;QAC7B,IAAI,CAAC,KAAK,EAAE,CAAC;YACX,IAAI,CAAC,gCAAgC,EAAE,CAAC;YACxC,IAAI,CAAC,mBAAmB,EAAE,CAAC;QAC7B,CAAC;QACD,IAAI,CAAC,aAAa,GAAG,KAAK,CAAC;IAC7B,CAAC;IAED;;OAEG;IACK,mBAAmB;QACzB,IAAI,CAAC,gBAAgB,GAAG,IAAI,CAAC;IAC/B,CAAC;IAED;;OAEG;IACK,gCAAgC;QACtC,IAAI,CAAC;YACH,IAAI,CAAC,cAAc,EAAE,CAAC;QACxB,CAAC;QAAC,OAAO,KAAK,EAAE,CAAC;YACf,MAAM,YAAY,GAAG,KAAK,YAAY,KAAK,CAAC,CAAC,CAAC,KAAK,CAAC,OAAO,CAAC,CAAC,CAAC,eAAe,CAAC;YAC9E,MAAM,IAAI,KAAK,CAAC,8BAA8B,YAAY,aAAa,KAAK,GAAG,CAAC,CAAC;QACnF,CAAC;IACH,CAAC;IAED;;;;OAIG;IACH,IAAI,eAAe;QACjB,IAAI,IAAI,CAAC,YAAY,EAAE,CAAC;YACtB,MAAM,IAAI,KAAK,CAAC,2BAA2B,CAAC,CAAC;QAC/C,CAAC;QACD,IAAI,CAAC,wBAAwB,EAAE,CAAC;QAEhC,MAAM,aAAa,GAAG,IAAI,CAAC,iBAAiB,CAAC,IAAI,CAAC,YAA2C,CAAC,CAAC;QAC/F,OAAO,MAAM,CAAC,IAAI,CAAC,IAAA,iBAAO,EAAC,EAAE,CAAC,CAAC,MAAM,CAAC,aAAa,CAAC,CAAC,MAAM,CAAC,QAAQ,CAAC,CAAC,CAAC;IACzE,CAAC;IAED;;;OAGG;IACH,IAAI,EAAE;QACJ,IAAI,CAAC,wBAAwB,EAAE,CAAC;QAChC,OAAO,qCAA0B,CAAC,kBAAkB,CAAC,IAAI,CAAC,YAA2C,CAAC,CAAC;IACzG,CAAC;IAED;;;OAGG;IACK,wBAAwB;QAC9B,IAAI,IAAI,CAAC,YAAY,KAAK,SAAS,IAAI,IAAI,CAAC,gBAAgB,EAAE,CAAC;YAC7D,MAAM,IAAI,KAAK,CAAC,uCAAuC,CAAC,CAAC;QAC3D,CAAC;IACH,CAAC;IAED;;OAEG;IACH,YAAY,CAAC,SAAoB,EAAE,SAAiB;QAClD,IAAI,CAAC,UAAU,GAAG,EAAE,SAAS,EAAE,SAAS,EAAE,CAAC;IAC7C,CAAC;IAED;;OAEG;IACH,sBAAsB,CAAC,SAAoB,EAAE,SAAiB;QAC5D,IAAI,CAAC,oBAAoB,GAAG,EAAE,SAAS,EAAE,SAAS,EAAE,CAAC;IACvD,CAAC;IAED;;;OAGG;IACH,OAAO,CAAC,IAAa;QACnB,OAAO,CAAC,IAAI,CAAC,YAAY,CAAC;IAC5B,CAAC;IAED;;OAEG;IACH,MAAM;QACJ,OAAO,IAAI,CAAC,SAAS,EAAE,QAAQ,EAAE,CAAC;IACpC,CAAC;IAED,IAAI,6BAA6B;QAC/B,OAAO,IAAI,CAAC,8BAA8B,CAAC;IAC7C,CAAC;IAED,IAAI,mBAAmB;QACrB,OAAO,IAAI,CAAC,oBAAoB,CAAC;IACnC,CAAC;IAED;;;OAGG;IACH,mBAAmB;QACjB,IAAI,CAAC,WAAW,GAAG,EAAE,CAAC;QAEtB,IAAI,IAAI,CAAC,UAAU,EAAE,CAAC;YACpB,IAAI,CAAC,oBAAoB,GAAG,IAAI,CAAC,kBAAkB,CAAC,IAAI,CAAC,UAAU,CAAC,CAAC;YACrE,IAAI,CAAC,WAAW,CAAC,IAAI,CAAC,IAAI,CAAC,oBAAoB,CAAC,CAAC;QACnD,CAAC;QAED,IAAI,IAAI,CAAC,oBAAoB,EAAE,CAAC;YAC9B,IAAI,CAAC,8BAA8B,GAAG,IAAI,CAAC,kBAAkB,CAAC,IAAI,CAAC,oBAAoB,CAAC,CAAC;YACzF,IAAI,CAAC,WAAW,CAAC,IAAI,CAAC,IAAI,CAAC,8BAA8B,CAAC,CAAC;QAC7D,CAAC;IACH,CAAC;IAED;;OAEG;IACH,KAAK,CAAC,iBAAiB;QACrB,MAAM,WAAW,GAAG,MAAM,IAAI,CAAC,KAAK,EAAE,CAAC;QACvC,OAAO,IAAA,gBAAQ,EAAC,WAAW,CAAC,CAAC;IAC/B,CAAC;IAED;;;;OAIG;IACH,KAAK,CAAC,KAAK;QACT,IAAI,IAAI,CAAC,YAAY,EAAE,CAAC;YACtB,OAAO,IAAI,CAAC,sBAAsB,EAAE,CAAC;QACvC,CAAC;QACD,OAAO,IAAI,CAAC,oBAAoB,EAAE,CAAC;IACrC,CAAC;IAED,MAAM;QACJ,OAAO;YACL,MAAM,EAAE,IAAI,CAAC,MAAM;YACnB,SAAS,EAAE,IAAI,CAAC,SAAS;YACzB,QAAQ,EAAE,IAAI,CAAC,QAAQ;YACvB,iBAAiB,EAAE,IAAI,CAAC,iBAAiB;YACzC,UAAU,EAAE,IAAI,CAAC,UAAU;YAC3B,IAAI,EAAE,IAAI,CAAC,IAAI;SAChB,CAAC;IACJ,CAAC;IAED,aAAa,CAAC,MAAc;QAC1B,IAAI,CAAC,MAAM,GAAG,MAAM,CAAC,MAAM,CAAC;QAC5B,IAAI,CAAC,SAAS,GAAG,MAAM,CAAC,SAAS,CAAC;QAClC,IAAI,CAAC,QAAQ,GAAG,MAAM,CAAC,QAAQ,CAAC;QAChC,IAAI,CAAC,iBAAiB,GAAG,MAAM,CAAC,iBAAiB,CAAC;QAClD,IAAI,MAAM,CAAC,UAAU,KAAK,SAAS,EAAE,CAAC;YACpC,IAAI,CAAC,UAAU,GAAG,MAAM,CAAC,UAAU,CAAC;QACtC,CAAC;IACH,CAAC;IAED;;;OAGG;IACH,oBAAoB,CAAC,EAAuB;QAC1C,MAAM,MAAM,GAAG,0BAAe,CAAC,IAAI,CAAC,EAAE,CAAC,CAAC,OAAO,EAAE,CAAC;QAElD,IAAI,CAAC,WAAW,CAAC,MAAM,CAAC,CAAC;QACzB,IAAI,CAAC,YAAY,CAAC,MAAM,CAAC,CAAC;IAC5B,CAAC;IAED;;OAEG;IACK,WAAW,CAAC,MAA8C;QAChE,IAAI,MAAM,CAAC,MAAM,EAAE,CAAC;YAClB,IAAI,CAAC,MAAM,GAAG,MAAM,CAAC,MAAM,CAAC;QAC9B,CAAC;IACH,CAAC;IAED;;OAEG;IACK,YAAY,CAAC,MAA8C;QACjE,MAAM,OAAO,GAAG,MAAM,CAAC,OAAO,CAAC;QAE/B,IAAI,CAAC,OAAO,EAAE,CAAC;YACb,IAAI,CAAC,SAAS,GAAG,SAAS,CAAC;YAC3B,IAAI,CAAC,QAAQ,GAAG,SAAS,CAAC;YAC1B,IAAI,CAAC,iBAAiB,GAAG,SAAS,CAAC;YACnC,IAAI,CAAC,UAAU,GAAG,SAAS,CAAC;YAC5B,OAAO;QACT,CAAC;QAED,IAAI,CAAC,SAAS,GAAG,OAAO,CAAC,MAAM,CAAC,CAAC,CAAC,MAAM,CAAC,OAAO,CAAC,MAAM,CAAC,CAAC,CAAC,CAAC,SAAS,CAAC;QACrE,IAAI,CAAC,QAAQ,GAAG,OAAO,CAAC,KAAK,CAAC,CAAC,CAAC,MAAM,CAAC,OAAO,CAAC,KAAK,CAAC,CAAC,CAAC,CAAC,SAAS,CAAC;QAElE,IAAI,CAAC,iBAAiB;YACpB,OAAO,CAAC,OAAO,IAAI,OAAO,CAAC,OAAO,CAAC,MAAM,GAAG,CAAC;gBAC3C,CAAC,CAAC,OAAO,CAAC,OAAO,CAAC,GAAG,CAAC,CAAC,OAAO,EAAE,EAAE,CAAC,OAAiC,CAAC;gBACrE,CAAC,CAAC,SAAS,CAAC;QAEhB,IAAI,CAAC,UAAU,GAAG,OAAO,CAAC,KAAK,IAAI,SAAS,CAAC;IAC/C,CAAC;IAED;;OAEG;IACH,kBAAkB;QAChB,MAAM,MAAM,GAAG,IAAI,CAAC,MAAM,EAAE,CAAC;QAC7B,MAAM,YAAY,GAAG,CAAC,IAAI,EAAE,SAAS,EAAE,cAAc,EAAE,eAAe,EAAE,cAAc,EAAE,KAAK,EAAE,MAAM,CAAC,CAAC;QACvG,MAAM,OAAO,GAA2B,EAAE,CAAC;QAE3C,MAAM,iBAAiB,GAA2B;YAChD,YAAY;YACZ,EAAE,EAAE,IAAI,CAAC,EAAE;YACX,OAAO;YACP,YAAY,EAAE,GAAG;YACjB,aAAa,EAAE,EAAE;YACjB,YAAY,EAAE,GAAG;YACjB,GAAG,EAAE,EAAE,GAAG,EAAE,IAAI,CAAC,SAAS,CAAC,CAAC,CAAC,IAAI,CAAC,SAAS,CAAC,QAAQ,EAAE,CAAC,CAAC,CAAC,EAAE,EAAE;YAC7D,MAAM,EAAE,IAAI,CAAC,MAAM;YACnB,OAAO,EAAE,IAAI,CAAC,UAAU;YACxB,IAAI,EAAE,IAAI,CAAC,IAAI;SAChB,CAAC;QAEF,OAAO,IAAI,CAAC,gCAAgC,CAAC,MAAM,EAAE,iBAAiB,CAAC,CAAC;IAC1E,CAAC;IAED;;;OAGG;IACO,kBAAkB;QAC1B,MAAM,aAAa,GACjB,IAAI,CAAC,SAAS,IAAI,IAAI,CAAC,QAAQ,IAAI,IAAI,CAAC,iBAAiB,IAAI,IAAI,CAAC,iBAAiB,CAAC,MAAM,GAAG,CAAC,CAAC;QAEjG,IAAI,CAAC,YAAY,GAAG,CAAC,aAAa,CAAC;IACrC,CAAC;IAYD;;;OAGG;IACK,KAAK,CAAC,sBAAsB;QAClC,IAAI,CAAC,4BAA4B,EAAE,CAAC;QACpC,MAAM,IAAI,CAAC,cAAc,EAAE,CAAC;QAE5B,MAAM,aAAa,GAAG,IAAI,qCAA0B,CAAC,IAAI,CAAC,gBAAgB,CAAC,OAAO,EAAyB,CAAC,CAAC;QAC7G,OAAO,aAAa,CAAC,KAAK,CAAC;YACzB,SAAS,EAAE;gBACT,OAAO,EAAE;oBACP,MAAM,EAAE,0BAAc,CAAC,QAAQ,EAAE;oBACjC,KAAK,EAAE,yBAAa,CAAC,QAAQ,EAAE;oBAC/B,OAAO,EAAE,EAAE;iBACZ;aACF;SACF,CAAC,CAAC;IACL,CAAC;IAED;;;OAGG;IACK,KAAK,CAAC,oBAAoB;QAChC,IAAI,IAAI,CAAC,YAAY,KAAK,SAAS,IAAI,IAAI,CAAC,gBAAgB,EAAE,CAAC;YAC7D,IAAI,CAAC,cAAc,EAAE,CAAC;YACtB,MAAM,IAAI,CAAC,cAAc,EAAE,CAAC;YAC5B,IAAI,CAAC,uBAAuB,EAAE,CAAC;YAC/B,IAAI,CAAC,YAAY,GAAG,MAAM,IAAI,CAAC,gBAAgB,CAAC,KAAK,EAAE,CAAC;YACxD,IAAI,CAAC,gBAAgB,GAAG,KAAK,CAAC;QAChC,CAAC;QAED,IAAI,CAAC,mBAAmB,EAAE,CAAC;QAC3B,OAAO,IAAI,CAAC,YAAY,CAAC;IAC3B,CAAC;IAED;;OAEG;IACK,uBAAuB;QAC7B,IAAI,CAAC,gBAAgB,CAAC,WAAW,CAAC,IAAI,CAAC,QAAS,CAAC,CAAC;QAClD,IAAI,CAAC,gBAAgB,CAAC,YAAY,CAAC,IAAI,CAAC,SAAU,CAAC,CAAC;QACpD,IAAI,CAAC,gBAAgB,CAAC,aAAa,CACjC,IAAI,CAAC,iBAAkB,CAAC,KAAK,CAAC,CAAC,EAAE,mCAAuB,GAAG,CAAC,CAA6B,CAC1F,CAAC;IACJ,CAAC;IAED;;OAEG;IACK,KAAK,CAAC,cAAc;QAC1B,IAAI,CAAC,gBAAgB,GAAG,IAAI,0BAAe,EAAE,CAAC;QAC9C,IAAI,CAAC,2BAA2B,EAAE,CAAC;QAEnC,wEAAwE;QACxE,IAAI,IAAI,CAAC,sBAAsB,EAAE,EAAE,CAAC;YAClC,MAAM,IAAI,CAAC,4BAA4B,EAAE,CAAC;QAC5C,CAAC;QAED,IAAI,CAAC,gBAAgB,CAAC,SAAS,CAAC,IAAI,CAAC,MAAM,CAAC,CAAC;IAC/C,CAAC;IAED;;OAEG;IACK,sBAAsB;QAC5B,OAAO,OAAO,CAAC,IAAI,CAAC,UAAU,IAAI,IAAI,CAAC,OAAO,KAAK,IAAI,CAAC,UAAU,CAAC,CAAC;IACtE,CAAC;IAED;;;OAGG;IACK,KAAK,CAAC,4BAA4B;QACxC,MAAM,eAAe,GAAG,MAAM,IAAI,CAAC,gBAAgB,CAAC,KAAK,CAAC,EAAE,mBAAmB,EAAE,IAAI,EAAE,CAAC,CAAC;QACzF,IAAI,CAAC,gBAAgB,GAAG,0BAAe,CAAC,QAAQ,CAAC,eAAe,CAAC,CAAC;QAClE,IAAI,CAAC,gBAAgB,CAAC,WAAW,CAAC,IAAI,CAAC,WAAY,CAAC,CAAC;IACvD,CAAC;IAED;;;;OAIG;IACK,kBAAkB,CAAC,SAAoB;QAC7C,MAAM,sBAAsB,GAAG,IAAI,CAAC;QACpC,MAAM,MAAM,GAAG,MAAM,CAAC,IAAI,CAAC,SAAS,CAAC,SAAS,CAAC,GAAG,EAAE,KAAK,CAAC,CAAC;QAC3D,MAAM,mBAAmB,GAAG,IAAI,UAAU,CAAC,CAAC,GAAG,SAAS,CAAC,SAAS,CAAC,MAAM,GAAG,MAAM,CAAC,MAAM,CAAC,CAAC;QAE3F,mBAAmB,CAAC,GAAG,CAAC,CAAC,sBAAsB,CAAC,CAAC,CAAC;QAClD,mBAAmB,CAAC,GAAG,CAAC,SAAS,CAAC,SAAS,EAAE,CAAC,CAAC,CAAC;QAChD,mBAAmB,CAAC,GAAG,CAAC,MAAM,EAAE,CAAC,GAAG,SAAS,CAAC,SAAS,CAAC,MAAM,CAAC,CAAC;QAEhE,OAAO,IAAA,gBAAQ,EAAC,mBAAmB,CAAC,CAAC;IACvC,CAAC;IAED;;OAEG;IACK,cAAc;QACpB,IAAI,CAAC,4BAA4B,EAAE,CAAC;QACpC,IAAI,CAAC,oBAAoB,EAAE,CAAC;QAC5B,IAAI,CAAC,kBAAkB,EAAE,CAAC;IAC5B,CAAC;IAED;;OAEG;IACK,oBAAoB;QAC1B,IAAI,CAAC,IAAI,CAAC,MAAM,EAAE,CAAC;YACjB,MAAM,IAAI,kCAAuB,CAAC,gCAAgC,CAAC,CAAC;QACtE,CAAC;QAED,IAAI,CAAC,IAAI,CAAC,QAAQ,EAAE,CAAC;YACnB,MAAM,IAAI,kCAAuB,CAAC,uBAAuB,CAAC,CAAC;QAC7D,CAAC;QAED,IAAI,CAAC,IAAI,CAAC,SAAS,EAAE,CAAC;YACpB,MAAM,IAAI,kCAAuB,CAAC,wBAAwB,CAAC,CAAC;QAC9D,CAAC;QAED,IAAI,CAAC,IAAI,CAAC,iBAAiB,IAAI,IAAI,CAAC,iBAAiB,CAAC,MAAM,KAAK,CAAC,EAAE,CAAC;YACnE,MAAM,IAAI,kCAAuB,CAAC,kCAAkC,CAAC,CAAC;QACxE,CAAC;IACH,CAAC;IAED;;OAEG;IACK,kBAAkB;QACxB,IAAI,IAAI,CAAC,UAAU,IAAI,CAAC,IAAI,CAAC,gBAAgB,CAAC,IAAI,CAAC,UAAU,CAAC,EAAE,CAAC;YAC/D,MAAM,IAAI,kCAAuB,CAAC,0BAA0B,CAAC,CAAC;QAChE,CAAC;QAED,IAAI,IAAI,CAAC,oBAAoB,IAAI,CAAC,IAAI,CAAC,gBAAgB,CAAC,IAAI,CAAC,oBAAoB,CAAC,EAAE,CAAC;YACnF,MAAM,IAAI,kCAAuB,CAAC,+BAA+B,CAAC,CAAC;QACrE,CAAC;IACH,CAAC;IAED;;OAEG;IACK,gBAAgB,CAAC,SAAoB;QAC3C,OAAO,eAAK,CAAC,gBAAgB,CAAC,SAAS,CAAC,SAAS,CAAC,GAAG,CAAC,IAAI,eAAK,CAAC,gBAAgB,CAAC,IAAA,gBAAQ,EAAC,SAAS,CAAC,SAAS,CAAC,CAAC,CAAC;IAClH,CAAC;CACF;AAjeD,kCAieC","sourcesContent":["import {\n  BaseKey,\n  BaseTransaction,\n  InvalidTransactionError,\n  PublicKey,\n  Signature,\n  TransactionRecipient,\n  TransactionType,\n} from '@bitgo-beta/sdk-core';\nimport { BaseCoin as CoinConfig } from '@bitgo-beta/statics';\nimport {\n  TransactionData as IotaTransactionData,\n  Transaction as IotaTransaction,\n  TransactionDataBuilder as IotaTransactionDataBuilder,\n} from '@iota/iota-sdk/transactions';\nimport { TxData, TransactionObjectInput, TransactionExplanation } from './iface';\nimport { toBase64 } from '@iota/iota-sdk/utils';\nimport blake2b from '@bitgo-beta/blake2b';\nimport { MAX_GAS_BUDGET, MAX_GAS_PAYMENT_OBJECTS, MAX_GAS_PRICE } from './constants';\nimport utils from './utils';\n\n/**\n * Base class for IOTA transactions.\n * Manages transaction state, gas data, signatures, and building/serialization.\n */\nexport abstract class Transaction extends BaseTransaction {\n  // Transaction state management\n  protected _rebuildRequired: boolean;\n  protected _type: TransactionType;\n  protected _iotaTransaction: IotaTransaction;\n\n  // Gas and payment data\n  private _gasBudget?: number;\n  private _gasPaymentObjects?: TransactionObjectInput[];\n  private _gasPrice?: number;\n  private _gasSponsor?: string;\n\n  // Transaction identifiers and data\n  private _sender: string;\n  private _txDataBytes?: Uint8Array<ArrayBufferLike>;\n  private _isSimulateTx: boolean;\n\n  // Signature data\n  private _signature?: Signature;\n  private _serializedSignature?: string;\n  private _gasSponsorSignature?: Signature;\n  private _serializedGasSponsorSignature?: string;\n\n  protected constructor(coinConfig: Readonly<CoinConfig>) {\n    super(coinConfig);\n    this._sender = '';\n    this._rebuildRequired = false;\n    this._isSimulateTx = true;\n  }\n\n  // Gas budget getter/setter - marks rebuild required when changed\n  get gasBudget(): number | undefined {\n    return this._gasBudget;\n  }\n\n  set gasBudget(value: number | undefined) {\n    this._gasBudget = value;\n    this.markRebuildRequired();\n  }\n\n  // Gas payment objects getter/setter - marks rebuild required when changed\n  get gasPaymentObjects(): TransactionObjectInput[] | undefined {\n    return this._gasPaymentObjects;\n  }\n\n  set gasPaymentObjects(value: TransactionObjectInput[] | undefined) {\n    this._gasPaymentObjects = value;\n    this.markRebuildRequired();\n  }\n\n  // Gas price getter/setter - marks rebuild required when changed\n  get gasPrice(): number | undefined {\n    return this._gasPrice;\n  }\n\n  set gasPrice(value: number | undefined) {\n    this._gasPrice = value;\n    this.markRebuildRequired();\n  }\n\n  // Gas sponsor getter/setter - marks rebuild required when changed\n  get gasSponsor(): string | undefined {\n    return this._gasSponsor;\n  }\n\n  set gasSponsor(value: string | undefined) {\n    this._gasSponsor = value;\n    this.markRebuildRequired();\n  }\n\n  // Transaction sender getter/setter - marks rebuild required when changed\n  get sender(): string {\n    return this._sender;\n  }\n\n  set sender(value: string) {\n    this._sender = value;\n    this.markRebuildRequired();\n  }\n\n  /**\n   * Indicates whether this is a simulate transaction (dry run) or a real transaction.\n   * Simulate transactions use maximum gas values for estimation purposes.\n   */\n  get isSimulateTx(): boolean {\n    return this._isSimulateTx;\n  }\n\n  set isSimulateTx(value: boolean) {\n    if (!value) {\n      this.validateTxDataForRealTransaction();\n      this.markRebuildRequired();\n    }\n    this._isSimulateTx = value;\n  }\n\n  /**\n   * Marks that the transaction needs to be rebuilt before it can be signed or broadcast.\n   */\n  private markRebuildRequired(): void {\n    this._rebuildRequired = true;\n  }\n\n  /**\n   * Validates transaction data when switching from simulate to real transaction mode.\n   */\n  private validateTxDataForRealTransaction(): void {\n    try {\n      this.validateTxData();\n    } catch (error) {\n      const errorMessage = error instanceof Error ? error.message : 'Unknown error';\n      throw new Error(`Tx data validation failed: ${errorMessage}. {Cause: ${error}}`);\n    }\n  }\n\n  /**\n   * Returns the signable payload for this transaction.\n   * This is the Blake2b hash of the transaction data with intent message.\n   * @throws Error if transaction is in simulate mode or not built\n   */\n  get signablePayload(): Buffer {\n    if (this.isSimulateTx) {\n      throw new Error('Cannot sign a simulate tx');\n    }\n    this.ensureTransactionIsBuilt();\n\n    const intentMessage = this.messageWithIntent(this._txDataBytes as Uint8Array<ArrayBufferLike>);\n    return Buffer.from(blake2b(32).update(intentMessage).digest('binary'));\n  }\n\n  /**\n   * Returns the transaction digest (ID).\n   * @throws Error if transaction is not built or needs rebuilding\n   */\n  get id(): string {\n    this.ensureTransactionIsBuilt();\n    return IotaTransactionDataBuilder.getDigestFromBytes(this._txDataBytes as Uint8Array<ArrayBufferLike>);\n  }\n\n  /**\n   * Ensures the transaction is built and doesn't need rebuilding.\n   * @throws Error if transaction is not built or rebuild is required\n   */\n  private ensureTransactionIsBuilt(): void {\n    if (this._txDataBytes === undefined || this._rebuildRequired) {\n      throw new Error('Tx not built or a rebuild is required');\n    }\n  }\n\n  /**\n   * Adds a signature from the transaction sender.\n   */\n  addSignature(publicKey: PublicKey, signature: Buffer): void {\n    this._signature = { publicKey, signature };\n  }\n\n  /**\n   * Adds a signature from the gas sponsor (if different from sender).\n   */\n  addGasSponsorSignature(publicKey: PublicKey, signature: Buffer): void {\n    this._gasSponsorSignature = { publicKey, signature };\n  }\n\n  /**\n   * Checks if this transaction can be signed.\n   * Only real transactions (not simulate) can be signed.\n   */\n  canSign(_key: BaseKey): boolean {\n    return !this.isSimulateTx;\n  }\n\n  /**\n   * Returns the transaction fee (gas budget).\n   */\n  getFee(): string | undefined {\n    return this.gasBudget?.toString();\n  }\n\n  get serializedGasSponsorSignature(): string | undefined {\n    return this._serializedGasSponsorSignature;\n  }\n\n  get serializedSignature(): string | undefined {\n    return this._serializedSignature;\n  }\n\n  /**\n   * Serializes all signatures for the transaction.\n   * Includes both sender signature and gas sponsor signature if present.\n   */\n  serializeSignatures(): void {\n    this._signatures = [];\n\n    if (this._signature) {\n      this._serializedSignature = this.serializeSignature(this._signature);\n      this._signatures.push(this._serializedSignature);\n    }\n\n    if (this._gasSponsorSignature) {\n      this._serializedGasSponsorSignature = this.serializeSignature(this._gasSponsorSignature);\n      this._signatures.push(this._serializedGasSponsorSignature);\n    }\n  }\n\n  /**\n   * Converts the transaction to broadcast format (base64 encoded).\n   */\n  async toBroadcastFormat(): Promise<string> {\n    const txDataBytes = await this.build();\n    return toBase64(txDataBytes);\n  }\n\n  /**\n   * Builds the transaction bytes.\n   * If in simulate mode, builds a dry run transaction with max gas values.\n   * Otherwise, builds a real transaction with actual gas data.\n   */\n  async build(): Promise<Uint8Array<ArrayBufferLike>> {\n    if (this.isSimulateTx) {\n      return this.buildDryRunTransaction();\n    }\n    return this.buildRealTransaction();\n  }\n\n  toJson(): TxData {\n    return {\n      sender: this.sender,\n      gasBudget: this.gasBudget,\n      gasPrice: this.gasPrice,\n      gasPaymentObjects: this.gasPaymentObjects,\n      gasSponsor: this.gasSponsor,\n      type: this.type,\n    };\n  }\n\n  parseFromJSON(txData: TxData): void {\n    this.sender = txData.sender;\n    this.gasBudget = txData.gasBudget;\n    this.gasPrice = txData.gasPrice;\n    this.gasPaymentObjects = txData.gasPaymentObjects;\n    if (txData.gasSponsor !== undefined) {\n      this.gasSponsor = txData.gasSponsor;\n    }\n  }\n\n  /**\n   * Parses transaction data from its broadcast format (base64 or raw bytes).\n   * Extracts sender, gas data, and gas sponsor information.\n   */\n  parseFromBroadcastTx(tx: string | Uint8Array): void {\n    const txData = IotaTransaction.from(tx).getData();\n\n    this.parseSender(txData);\n    this.parseGasData(txData);\n  }\n\n  /**\n   * Parses the sender address from transaction data.\n   */\n  private parseSender(txData: ReturnType<IotaTransaction['getData']>): void {\n    if (txData.sender) {\n      this.sender = txData.sender;\n    }\n  }\n\n  /**\n   * Parses gas-related data from transaction data.\n   */\n  private parseGasData(txData: ReturnType<IotaTransaction['getData']>): void {\n    const gasData = txData.gasData;\n\n    if (!gasData) {\n      this.gasBudget = undefined;\n      this.gasPrice = undefined;\n      this.gasPaymentObjects = undefined;\n      this.gasSponsor = undefined;\n      return;\n    }\n\n    this.gasBudget = gasData.budget ? Number(gasData.budget) : undefined;\n    this.gasPrice = gasData.price ? Number(gasData.price) : undefined;\n\n    this.gasPaymentObjects =\n      gasData.payment && gasData.payment.length > 0\n        ? gasData.payment.map((payment) => payment as TransactionObjectInput)\n        : undefined;\n\n    this.gasSponsor = gasData.owner || undefined;\n  }\n\n  /**\n   * @inheritDoc\n   */\n  explainTransaction(): any {\n    const result = this.toJson();\n    const displayOrder = ['id', 'outputs', 'outputAmount', 'changeOutputs', 'changeAmount', 'fee', 'type'];\n    const outputs: TransactionRecipient[] = [];\n\n    const explanationResult: TransactionExplanation = {\n      displayOrder,\n      id: this.id,\n      outputs,\n      outputAmount: '0',\n      changeOutputs: [],\n      changeAmount: '0',\n      fee: { fee: this.gasBudget ? this.gasBudget.toString() : '' },\n      sender: this.sender,\n      sponsor: this.gasSponsor,\n      type: this.type,\n    };\n\n    return this.explainTransactionImplementation(result, explanationResult);\n  }\n\n  /**\n   * Updates the simulate transaction flag based on gas data availability.\n   * If all gas data is present, switches to real transaction mode.\n   */\n  protected updateIsSimulateTx(): void {\n    const hasAllGasData =\n      this.gasBudget && this.gasPrice && this.gasPaymentObjects && this.gasPaymentObjects.length > 0;\n\n    this.isSimulateTx = !hasAllGasData;\n  }\n\n  // Abstract methods to be implemented by child classes\n  protected abstract messageWithIntent(message: Uint8Array): Uint8Array;\n  protected abstract populateTxInputsAndCommands(): void;\n  protected abstract validateTxDataImplementation(): void;\n  abstract addInputsAndOutputs(): void;\n  protected abstract explainTransactionImplementation(\n    json: TxData,\n    explanationResult: TransactionExplanation\n  ): TransactionExplanation;\n\n  /**\n   * Builds a dry run (simulate) transaction with maximum gas values.\n   * Used for gas estimation without committing the transaction.\n   */\n  private async buildDryRunTransaction(): Promise<Uint8Array<ArrayBufferLike>> {\n    this.validateTxDataImplementation();\n    await this.populateTxData();\n\n    const txDataBuilder = new IotaTransactionDataBuilder(this._iotaTransaction.getData() as IotaTransactionData);\n    return txDataBuilder.build({\n      overrides: {\n        gasData: {\n          budget: MAX_GAS_BUDGET.toString(),\n          price: MAX_GAS_PRICE.toString(),\n          payment: [],\n        },\n      },\n    });\n  }\n\n  /**\n   * Builds a real transaction with actual gas data.\n   * Only builds if necessary (first time or rebuild required).\n   */\n  private async buildRealTransaction(): Promise<Uint8Array<ArrayBufferLike>> {\n    if (this._txDataBytes === undefined || this._rebuildRequired) {\n      this.validateTxData();\n      await this.populateTxData();\n      this.setGasDataOnTransaction();\n      this._txDataBytes = await this._iotaTransaction.build();\n      this._rebuildRequired = false;\n    }\n\n    this.serializeSignatures();\n    return this._txDataBytes;\n  }\n\n  /**\n   * Sets gas data on the IOTA transaction object.\n   */\n  private setGasDataOnTransaction(): void {\n    this._iotaTransaction.setGasPrice(this.gasPrice!);\n    this._iotaTransaction.setGasBudget(this.gasBudget!);\n    this._iotaTransaction.setGasPayment(\n      this.gasPaymentObjects!.slice(0, MAX_GAS_PAYMENT_OBJECTS - 1) as TransactionObjectInput[]\n    );\n  }\n\n  /**\n   * Populates the IOTA transaction with inputs, commands, and gas sponsor if applicable.\n   */\n  private async populateTxData(): Promise<void> {\n    this._iotaTransaction = new IotaTransaction();\n    this.populateTxInputsAndCommands();\n\n    // If gas sponsor is different from sender, set up sponsored transaction\n    if (this.hasDifferentGasSponsor()) {\n      await this.setupGasSponsoredTransaction();\n    }\n\n    this._iotaTransaction.setSender(this.sender);\n  }\n\n  /**\n   * Checks if the transaction has a gas sponsor different from the sender.\n   */\n  private hasDifferentGasSponsor(): boolean {\n    return Boolean(this.gasSponsor && this._sender !== this.gasSponsor);\n  }\n\n  /**\n   * Sets up a gas-sponsored transaction by building the transaction kind\n   * and setting the gas owner.\n   */\n  private async setupGasSponsoredTransaction(): Promise<void> {\n    const transactionKind = await this._iotaTransaction.build({ onlyTransactionKind: true });\n    this._iotaTransaction = IotaTransaction.fromKind(transactionKind);\n    this._iotaTransaction.setGasOwner(this._gasSponsor!);\n  }\n\n  /**\n   * Serializes a signature into IOTA's expected format.\n   * Format: [signature_scheme_flag (1 byte), signature, public_key]\n   * Currently hardcoded to EDDSA (0x00) as IOTA only supports this scheme.\n   */\n  private serializeSignature(signature: Signature): string {\n    const SIGNATURE_SCHEME_EDDSA = 0x00;\n    const pubKey = Buffer.from(signature.publicKey.pub, 'hex');\n    const serializedSignature = new Uint8Array(1 + signature.signature.length + pubKey.length);\n\n    serializedSignature.set([SIGNATURE_SCHEME_EDDSA]);\n    serializedSignature.set(signature.signature, 1);\n    serializedSignature.set(pubKey, 1 + signature.signature.length);\n\n    return toBase64(serializedSignature);\n  }\n\n  /**\n   * Validates all transaction data required for a real (non-simulate) transaction.\n   */\n  private validateTxData(): void {\n    this.validateTxDataImplementation();\n    this.validateCommonTxData();\n    this.validateSignatures();\n  }\n\n  /**\n   * Validates common transaction data (sender, gas data).\n   */\n  private validateCommonTxData(): void {\n    if (!this.sender) {\n      throw new InvalidTransactionError('Transaction sender is required');\n    }\n\n    if (!this.gasPrice) {\n      throw new InvalidTransactionError('Gas price is required');\n    }\n\n    if (!this.gasBudget) {\n      throw new InvalidTransactionError('Gas budget is required');\n    }\n\n    if (!this.gasPaymentObjects || this.gasPaymentObjects.length === 0) {\n      throw new InvalidTransactionError('Gas payment objects are required');\n    }\n  }\n\n  /**\n   * Validates sender and gas sponsor signatures if present.\n   */\n  private validateSignatures(): void {\n    if (this._signature && !this.isValidSignature(this._signature)) {\n      throw new InvalidTransactionError('Invalid sender signature');\n    }\n\n    if (this._gasSponsorSignature && !this.isValidSignature(this._gasSponsorSignature)) {\n      throw new InvalidTransactionError('Invalid gas sponsor signature');\n    }\n  }\n\n  /**\n   * Checks if a signature has valid public key and signature data.\n   */\n  private isValidSignature(signature: Signature): boolean {\n    return utils.isValidPublicKey(signature.publicKey.pub) && utils.isValidSignature(toBase64(signature.signature));\n  }\n}\n"]}
|