@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.
Files changed (42) hide show
  1. package/dist/src/iota.d.ts +123 -27
  2. package/dist/src/iota.d.ts.map +1 -1
  3. package/dist/src/iota.js +217 -103
  4. package/dist/src/lib/constants.d.ts +50 -1
  5. package/dist/src/lib/constants.d.ts.map +1 -1
  6. package/dist/src/lib/constants.js +68 -4
  7. package/dist/src/lib/iface.d.ts +141 -1
  8. package/dist/src/lib/iface.d.ts.map +1 -1
  9. package/dist/src/lib/iface.js +1 -1
  10. package/dist/src/lib/keyPair.d.ts +100 -6
  11. package/dist/src/lib/keyPair.d.ts.map +1 -1
  12. package/dist/src/lib/keyPair.js +103 -10
  13. package/dist/src/lib/transaction.d.ts +117 -14
  14. package/dist/src/lib/transaction.d.ts.map +1 -1
  15. package/dist/src/lib/transaction.js +190 -67
  16. package/dist/src/lib/transactionBuilder.d.ts +73 -34
  17. package/dist/src/lib/transactionBuilder.d.ts.map +1 -1
  18. package/dist/src/lib/transactionBuilder.js +90 -45
  19. package/dist/src/lib/transactionBuilderFactory.d.ts +89 -6
  20. package/dist/src/lib/transactionBuilderFactory.d.ts.map +1 -1
  21. package/dist/src/lib/transactionBuilderFactory.js +103 -16
  22. package/dist/src/lib/transferBuilder.d.ts +43 -0
  23. package/dist/src/lib/transferBuilder.d.ts.map +1 -1
  24. package/dist/src/lib/transferBuilder.js +50 -5
  25. package/dist/src/lib/transferTransaction.d.ts +93 -2
  26. package/dist/src/lib/transferTransaction.d.ts.map +1 -1
  27. package/dist/src/lib/transferTransaction.js +180 -51
  28. package/dist/src/lib/utils.d.ts +107 -8
  29. package/dist/src/lib/utils.d.ts.map +1 -1
  30. package/dist/src/lib/utils.js +134 -23
  31. package/dist/test/unit/helpers/testHelpers.d.ts +57 -0
  32. package/dist/test/unit/helpers/testHelpers.d.ts.map +1 -0
  33. package/dist/test/unit/helpers/testHelpers.js +176 -0
  34. package/dist/test/unit/iota.js +47 -152
  35. package/dist/test/unit/keyPair.js +34 -61
  36. package/dist/test/unit/transactionBuilder/transactionBuilder.js +137 -255
  37. package/dist/test/unit/transactionBuilder/transactionBuilderFactory.js +43 -108
  38. package/dist/test/unit/transactionBuilder/transferBuilder.js +296 -762
  39. package/dist/test/unit/transferTransaction.js +106 -353
  40. package/dist/test/unit/utils.js +171 -197
  41. package/dist/tsconfig.tsbuildinfo +1 -1
  42. 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._rebuildRequired = true;
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._rebuildRequired = true;
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._rebuildRequired = true;
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._rebuildRequired = true;
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._rebuildRequired = true;
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
- try {
61
- this.validateTxData();
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
- if (this._txDataBytes === undefined || this._rebuildRequired) {
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
- /** @inheritDoc **/
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.buildTransaction();
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
- if (txData.gasData?.budget) {
152
- this.gasBudget = Number(txData.gasData.budget);
153
- }
154
- else {
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
- if (this.gasBudget && this.gasPrice && this.gasPaymentObjects && this.gasPaymentObjects?.length > 0) {
199
- this.isSimulateTx = false;
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
- async buildTransaction() {
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._iotaTransaction.setGasPrice(this.gasPrice);
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
- if (this.gasSponsor && this._sender !== this.gasSponsor) {
236
- this._iotaTransaction = transactions_1.Transaction.fromKind(await this._iotaTransaction.build({ onlyTransactionKind: true }));
237
- this._iotaTransaction.setGasOwner(this._gasSponsor);
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 serialized_sig = new Uint8Array(1 + signature.signature.length + pubKey.length);
244
- serialized_sig.set([0x00]); //Hardcoding the signature scheme flag since we only support EDDSA for iota
245
- serialized_sig.set(signature.signature, 1);
246
- serialized_sig.set(pubKey, 1 + signature.signature.length);
247
- return (0, utils_1.toBase64)(serialized_sig);
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
- if (!this.sender || this.sender === '') {
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?.length === 0) {
378
+ if (!this.gasPaymentObjects || this.gasPaymentObjects.length === 0) {
261
379
  throw new sdk_core_1.InvalidTransactionError('Gas payment objects are required');
262
380
  }
263
- if (this._signature &&
264
- !(utils_2.default.isValidPublicKey(this._signature.publicKey.pub) &&
265
- utils_2.default.isValidSignature((0, utils_1.toBase64)(this._signature.signature)))) {
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"]}