@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
@@ -3,74 +3,113 @@ import BigNumber from 'bignumber.js';
3
3
  import { Transaction } from './transaction';
4
4
  import { BaseCoin as CoinConfig } from '@bitgo-beta/statics';
5
5
  import { GasData } from './iface';
6
+ /**
7
+ * Base class for IOTA transaction builders.
8
+ * Provides common functionality for building and validating IOTA transactions.
9
+ */
6
10
  export declare abstract class TransactionBuilder extends BaseTransactionBuilder {
7
11
  protected _transaction: Transaction;
8
12
  protected constructor(coinConfig: Readonly<CoinConfig>);
9
13
  /**
10
- * Initialize the transaction builder fields using the decoded transaction data
11
- *
12
- * @param {Transaction} tx the transaction data
14
+ * Initializes the transaction builder with data from an existing transaction.
15
+ * Copies sender, gas data, and gas sponsor information.
13
16
  */
14
17
  initBuilder(tx: Transaction): void;
15
- get transactionType(): TransactionType;
16
18
  /**
17
- * @inheritdoc
18
- * */
19
+ * Copies transaction data from the source transaction to the builder's transaction.
20
+ */
21
+ private copyTransactionData;
22
+ get transactionType(): TransactionType;
19
23
  get transaction(): Transaction;
20
- /**
21
- * @inheritdoc
22
- * */
23
24
  protected set transaction(transaction: Transaction);
24
25
  /**
25
- * Sets the sender of this transaction.
26
- *
27
- * @param {string} senderAddress the account that is sending this transaction
28
- * @returns {TransactionBuilder} This transaction builder
26
+ * Sets the sender address for this transaction.
27
+ * @param senderAddress - The IOTA address that is sending this transaction
28
+ * @returns This transaction builder for method chaining
29
29
  */
30
30
  sender(senderAddress: string): this;
31
31
  /**
32
- * Sets the gasData for this transaction.
33
- *
34
- * @param {string} gasData the gas details for this transaction
35
- * @returns {TransactionBuilder} This transaction builder
32
+ * Sets the gas data for this transaction (budget, price, and payment objects).
33
+ * @param gasData - The gas configuration including budget, price, and payment objects
34
+ * @returns This transaction builder for method chaining
36
35
  */
37
36
  gasData(gasData: GasData): this;
38
37
  /**
39
- * Sets the gasSponsor of this transaction.
40
- *
41
- * @param {string} sponsorAddress the account that is sponsoring this transaction's gas
42
- * @returns {TransactionBuilder} This transaction builder
38
+ * Sets gas data fields on the transaction.
39
+ */
40
+ private setGasDataOnTransaction;
41
+ /**
42
+ * Sets the gas sponsor for this transaction.
43
+ * The gas sponsor pays for transaction fees instead of the sender.
44
+ * @param sponsorAddress - The IOTA address sponsoring this transaction's gas fees
45
+ * @returns This transaction builder for method chaining
43
46
  */
44
47
  gasSponsor(sponsorAddress: string): this;
48
+ /**
49
+ * Adds a signature from the transaction sender.
50
+ * @param publicKey - The sender's public key
51
+ * @param signature - The signature bytes
52
+ * @throws BuildTransactionError if the signature or public key is invalid
53
+ */
45
54
  addSignature(publicKey: PublicKey, signature: Buffer): void;
55
+ /**
56
+ * Adds a signature from the gas sponsor.
57
+ * @param publicKey - The gas sponsor's public key
58
+ * @param signature - The signature bytes
59
+ * @throws BuildTransactionError if the signature or public key is invalid
60
+ */
46
61
  addGasSponsorSignature(publicKey: PublicKey, signature: Buffer): void;
62
+ /**
63
+ * Validates that the signature and public key are in valid formats.
64
+ */
65
+ private validateSignatureData;
47
66
  validateKey(key: BaseKey): void;
48
67
  /**
49
- * @inheritdoc
50
- * */
68
+ * Validates an IOTA address format.
69
+ * @throws BuildTransactionError if address is invalid
70
+ */
51
71
  validateAddress(address: BaseAddress, addressFormat?: string): void;
52
72
  /**
53
- * @inheritdoc
54
- * */
73
+ * Validates that a numeric value is valid (not NaN and not negative).
74
+ * @throws BuildTransactionError if value is invalid
75
+ */
55
76
  validateValue(value: BigNumber): void;
56
- /** @inheritdoc */
77
+ /**
78
+ * Validates that a raw transaction string is properly formatted.
79
+ * @throws ParseTransactionError if raw transaction is invalid
80
+ */
57
81
  validateRawTransaction(rawTransaction: string): void;
58
82
  /**
59
- * @inheritdoc
60
- * */
83
+ * Validates a transaction object has all required fields.
84
+ * @throws Error if transaction is undefined or has invalid data
85
+ */
61
86
  validateTransaction(transaction?: Transaction): void;
62
87
  /**
63
- * @inheritdoc
64
- * */
88
+ * Creates a transaction object from a raw transaction string or bytes.
89
+ * @param rawTransaction - Raw transaction in base64 string or Uint8Array format
90
+ * @returns The parsed transaction object
91
+ * @throws BuildTransactionError if raw transaction is invalid
92
+ */
65
93
  fromImplementation(rawTransaction: string | Uint8Array): Transaction;
66
94
  /**
67
- * @inheritdoc
68
- * */
95
+ * Sign implementation - not supported for IOTA transactions.
96
+ * IOTA transactions must be signed externally.
97
+ */
69
98
  protected signImplementation(key: BaseKey): BaseTransaction;
70
99
  /**
71
- * @inheritdoc
72
- * */
100
+ * Builds the transaction and prepares it for broadcast.
101
+ * Automatically switches from simulate to real transaction mode if gas data is present.
102
+ */
73
103
  protected buildImplementation(): Promise<Transaction>;
104
+ /**
105
+ * Updates the transaction mode based on gas data availability.
106
+ * Switches to real transaction mode if all gas data is provided.
107
+ */
108
+ private updateTransactionMode;
109
+ /**
110
+ * Validates gas data values and presence.
111
+ * @throws BuildTransactionError if gas data is invalid
112
+ */
74
113
  private validateGasData;
75
114
  }
76
115
  //# sourceMappingURL=transactionBuilder.d.ts.map
@@ -1 +1 @@
1
- {"version":3,"file":"transactionBuilder.d.ts","sourceRoot":"","sources":["../../../src/lib/transactionBuilder.ts"],"names":[],"mappings":"AAAA,OAAO,EACL,WAAW,EACX,OAAO,EACP,eAAe,EACf,sBAAsB,EAGtB,SAAS,EACT,eAAe,EAChB,MAAM,sBAAsB,CAAC;AAC9B,OAAO,SAAS,MAAM,cAAc,CAAC;AACrC,OAAO,EAAE,WAAW,EAAE,MAAM,eAAe,CAAC;AAC5C,OAAO,EAAE,QAAQ,IAAI,UAAU,EAAE,MAAM,qBAAqB,CAAC;AAE7D,OAAO,EAA0B,OAAO,EAAE,MAAM,SAAS,CAAC;AAG1D,8BAAsB,kBAAmB,SAAQ,sBAAsB;IACrE,SAAS,CAAC,YAAY,EAAE,WAAW,CAAC;IAEpC,SAAS,aAAa,UAAU,EAAE,QAAQ,CAAC,UAAU,CAAC;IAItD;;;;OAIG;IACH,WAAW,CAAC,EAAE,EAAE,WAAW,GAAG,IAAI;IASlC,IAAI,eAAe,IAAI,eAAe,CAErC;IAED;;SAEK;IACL,IAAI,WAAW,IAAI,WAAW,CAE7B;IAED;;SAEK;IACL,SAAS,KAAK,WAAW,CAAC,WAAW,EAAE,WAAW,EAEjD;IAED;;;;;OAKG;IACH,MAAM,CAAC,aAAa,EAAE,MAAM,GAAG,IAAI;IAMnC;;;;;OAKG;IACH,OAAO,CAAC,OAAO,EAAE,OAAO,GAAG,IAAI;IAQ/B;;;;;OAKG;IACH,UAAU,CAAC,cAAc,EAAE,MAAM,GAAG,IAAI;IAMxC,YAAY,CAAC,SAAS,EAAE,SAAS,EAAE,SAAS,EAAE,MAAM,GAAG,IAAI;IAO3D,sBAAsB,CAAC,SAAS,EAAE,SAAS,EAAE,SAAS,EAAE,MAAM,GAAG,IAAI;IAOrE,WAAW,CAAC,GAAG,EAAE,OAAO,GAAG,IAAI;IAI/B;;SAEK;IACL,eAAe,CAAC,OAAO,EAAE,WAAW,EAAE,aAAa,CAAC,EAAE,MAAM,GAAG,IAAI;IAMnE;;SAEK;IACL,aAAa,CAAC,KAAK,EAAE,SAAS,GAAG,IAAI;IAQrC,kBAAkB;IAClB,sBAAsB,CAAC,cAAc,EAAE,MAAM,GAAG,IAAI;IASpD;;SAEK;IACL,mBAAmB,CAAC,WAAW,CAAC,EAAE,WAAW,GAAG,IAAI;IAepD;;SAEK;IACL,kBAAkB,CAAC,cAAc,EAAE,MAAM,GAAG,UAAU,GAAG,WAAW;IAQpE;;SAEK;IACL,SAAS,CAAC,kBAAkB,CAAC,GAAG,EAAE,OAAO,GAAG,eAAe;IAI3D;;SAEK;cACW,mBAAmB,IAAI,OAAO,CAAC,WAAW,CAAC;IAU3D,OAAO,CAAC,eAAe;CAWxB"}
1
+ {"version":3,"file":"transactionBuilder.d.ts","sourceRoot":"","sources":["../../../src/lib/transactionBuilder.ts"],"names":[],"mappings":"AAAA,OAAO,EACL,WAAW,EACX,OAAO,EACP,eAAe,EACf,sBAAsB,EAGtB,SAAS,EACT,eAAe,EAChB,MAAM,sBAAsB,CAAC;AAC9B,OAAO,SAAS,MAAM,cAAc,CAAC;AACrC,OAAO,EAAE,WAAW,EAAE,MAAM,eAAe,CAAC;AAC5C,OAAO,EAAE,QAAQ,IAAI,UAAU,EAAE,MAAM,qBAAqB,CAAC;AAE7D,OAAO,EAA0B,OAAO,EAAE,MAAM,SAAS,CAAC;AAG1D;;;GAGG;AACH,8BAAsB,kBAAmB,SAAQ,sBAAsB;IACrE,SAAS,CAAC,YAAY,EAAE,WAAW,CAAC;IAEpC,SAAS,aAAa,UAAU,EAAE,QAAQ,CAAC,UAAU,CAAC;IAItD;;;OAGG;IACH,WAAW,CAAC,EAAE,EAAE,WAAW,GAAG,IAAI;IAKlC;;OAEG;IACH,OAAO,CAAC,mBAAmB;IAQ3B,IAAI,eAAe,IAAI,eAAe,CAErC;IAED,IAAI,WAAW,IAAI,WAAW,CAE7B;IAED,SAAS,KAAK,WAAW,CAAC,WAAW,EAAE,WAAW,EAEjD;IAED;;;;OAIG;IACH,MAAM,CAAC,aAAa,EAAE,MAAM,GAAG,IAAI;IAMnC;;;;OAIG;IACH,OAAO,CAAC,OAAO,EAAE,OAAO,GAAG,IAAI;IAM/B;;OAEG;IACH,OAAO,CAAC,uBAAuB;IAM/B;;;;;OAKG;IACH,UAAU,CAAC,cAAc,EAAE,MAAM,GAAG,IAAI;IAMxC;;;;;OAKG;IACH,YAAY,CAAC,SAAS,EAAE,SAAS,EAAE,SAAS,EAAE,MAAM,GAAG,IAAI;IAK3D;;;;;OAKG;IACH,sBAAsB,CAAC,SAAS,EAAE,SAAS,EAAE,SAAS,EAAE,MAAM,GAAG,IAAI;IAKrE;;OAEG;IACH,OAAO,CAAC,qBAAqB;IAM7B,WAAW,CAAC,GAAG,EAAE,OAAO,GAAG,IAAI;IAI/B;;;OAGG;IACH,eAAe,CAAC,OAAO,EAAE,WAAW,EAAE,aAAa,CAAC,EAAE,MAAM,GAAG,IAAI;IAMnE;;;OAGG;IACH,aAAa,CAAC,KAAK,EAAE,SAAS,GAAG,IAAI;IASrC;;;OAGG;IACH,sBAAsB,CAAC,cAAc,EAAE,MAAM,GAAG,IAAI;IASpD;;;OAGG;IACH,mBAAmB,CAAC,WAAW,CAAC,EAAE,WAAW,GAAG,IAAI;IAiBpD;;;;;OAKG;IACH,kBAAkB,CAAC,cAAc,EAAE,MAAM,GAAG,UAAU,GAAG,WAAW;IAQpE;;;OAGG;IACH,SAAS,CAAC,kBAAkB,CAAC,GAAG,EAAE,OAAO,GAAG,eAAe;IAI3D;;;OAGG;cACa,mBAAmB,IAAI,OAAO,CAAC,WAAW,CAAC;IAO3D;;;OAGG;IACH,OAAO,CAAC,qBAAqB;IAS7B;;;OAGG;IACH,OAAO,CAAC,eAAe;CAaxB"}
@@ -8,17 +8,26 @@ const sdk_core_1 = require("@bitgo-beta/sdk-core");
8
8
  const bignumber_js_1 = __importDefault(require("bignumber.js"));
9
9
  const utils_1 = __importDefault(require("./utils"));
10
10
  const utils_2 = require("@iota/iota-sdk/utils");
11
+ /**
12
+ * Base class for IOTA transaction builders.
13
+ * Provides common functionality for building and validating IOTA transactions.
14
+ */
11
15
  class TransactionBuilder extends sdk_core_1.BaseTransactionBuilder {
12
16
  constructor(coinConfig) {
13
17
  super(coinConfig);
14
18
  }
15
19
  /**
16
- * Initialize the transaction builder fields using the decoded transaction data
17
- *
18
- * @param {Transaction} tx the transaction data
20
+ * Initializes the transaction builder with data from an existing transaction.
21
+ * Copies sender, gas data, and gas sponsor information.
19
22
  */
20
23
  initBuilder(tx) {
21
24
  this.validateTransaction(tx);
25
+ this.copyTransactionData(tx);
26
+ }
27
+ /**
28
+ * Copies transaction data from the source transaction to the builder's transaction.
29
+ */
30
+ copyTransactionData(tx) {
22
31
  this.transaction.sender = tx.sender;
23
32
  this.transaction.gasPrice = tx.gasPrice;
24
33
  this.transaction.gasBudget = tx.gasBudget;
@@ -28,23 +37,16 @@ class TransactionBuilder extends sdk_core_1.BaseTransactionBuilder {
28
37
  get transactionType() {
29
38
  return this.transaction.type;
30
39
  }
31
- /**
32
- * @inheritdoc
33
- * */
34
40
  get transaction() {
35
41
  return this._transaction;
36
42
  }
37
- /**
38
- * @inheritdoc
39
- * */
40
43
  set transaction(transaction) {
41
44
  this._transaction = transaction;
42
45
  }
43
46
  /**
44
- * Sets the sender of this transaction.
45
- *
46
- * @param {string} senderAddress the account that is sending this transaction
47
- * @returns {TransactionBuilder} This transaction builder
47
+ * Sets the sender address for this transaction.
48
+ * @param senderAddress - The IOTA address that is sending this transaction
49
+ * @returns This transaction builder for method chaining
48
50
  */
49
51
  sender(senderAddress) {
50
52
  this.validateAddress({ address: senderAddress });
@@ -52,64 +54,90 @@ class TransactionBuilder extends sdk_core_1.BaseTransactionBuilder {
52
54
  return this;
53
55
  }
54
56
  /**
55
- * Sets the gasData for this transaction.
56
- *
57
- * @param {string} gasData the gas details for this transaction
58
- * @returns {TransactionBuilder} This transaction builder
57
+ * Sets the gas data for this transaction (budget, price, and payment objects).
58
+ * @param gasData - The gas configuration including budget, price, and payment objects
59
+ * @returns This transaction builder for method chaining
59
60
  */
60
61
  gasData(gasData) {
61
62
  this.validateGasData(gasData);
63
+ this.setGasDataOnTransaction(gasData);
64
+ return this;
65
+ }
66
+ /**
67
+ * Sets gas data fields on the transaction.
68
+ */
69
+ setGasDataOnTransaction(gasData) {
62
70
  this.transaction.gasPrice = gasData.gasPrice;
63
71
  this.transaction.gasBudget = gasData.gasBudget;
64
72
  this.transaction.gasPaymentObjects = gasData.gasPaymentObjects;
65
- return this;
66
73
  }
67
74
  /**
68
- * Sets the gasSponsor of this transaction.
69
- *
70
- * @param {string} sponsorAddress the account that is sponsoring this transaction's gas
71
- * @returns {TransactionBuilder} This transaction builder
75
+ * Sets the gas sponsor for this transaction.
76
+ * The gas sponsor pays for transaction fees instead of the sender.
77
+ * @param sponsorAddress - The IOTA address sponsoring this transaction's gas fees
78
+ * @returns This transaction builder for method chaining
72
79
  */
73
80
  gasSponsor(sponsorAddress) {
74
81
  this.validateAddress({ address: sponsorAddress });
75
82
  this.transaction.gasSponsor = sponsorAddress;
76
83
  return this;
77
84
  }
85
+ /**
86
+ * Adds a signature from the transaction sender.
87
+ * @param publicKey - The sender's public key
88
+ * @param signature - The signature bytes
89
+ * @throws BuildTransactionError if the signature or public key is invalid
90
+ */
78
91
  addSignature(publicKey, signature) {
79
- if (!utils_1.default.isValidPublicKey(publicKey.pub) || !utils_1.default.isValidSignature((0, utils_2.toBase64)(signature))) {
80
- throw new sdk_core_1.BuildTransactionError('Invalid transaction signature');
81
- }
92
+ this.validateSignatureData(publicKey, signature);
82
93
  this.transaction.addSignature(publicKey, signature);
83
94
  }
95
+ /**
96
+ * Adds a signature from the gas sponsor.
97
+ * @param publicKey - The gas sponsor's public key
98
+ * @param signature - The signature bytes
99
+ * @throws BuildTransactionError if the signature or public key is invalid
100
+ */
84
101
  addGasSponsorSignature(publicKey, signature) {
102
+ this.validateSignatureData(publicKey, signature);
103
+ this.transaction.addGasSponsorSignature(publicKey, signature);
104
+ }
105
+ /**
106
+ * Validates that the signature and public key are in valid formats.
107
+ */
108
+ validateSignatureData(publicKey, signature) {
85
109
  if (!utils_1.default.isValidPublicKey(publicKey.pub) || !utils_1.default.isValidSignature((0, utils_2.toBase64)(signature))) {
86
110
  throw new sdk_core_1.BuildTransactionError('Invalid transaction signature');
87
111
  }
88
- this.transaction.addGasSponsorSignature(publicKey, signature);
89
112
  }
90
113
  validateKey(key) {
91
114
  throw new Error('Method not implemented.');
92
115
  }
93
116
  /**
94
- * @inheritdoc
95
- * */
117
+ * Validates an IOTA address format.
118
+ * @throws BuildTransactionError if address is invalid
119
+ */
96
120
  validateAddress(address, addressFormat) {
97
121
  if (!utils_1.default.isValidAddress(address.address)) {
98
122
  throw new sdk_core_1.BuildTransactionError('Invalid address ' + address.address);
99
123
  }
100
124
  }
101
125
  /**
102
- * @inheritdoc
103
- * */
126
+ * Validates that a numeric value is valid (not NaN and not negative).
127
+ * @throws BuildTransactionError if value is invalid
128
+ */
104
129
  validateValue(value) {
105
130
  if (value.isNaN()) {
106
131
  throw new sdk_core_1.BuildTransactionError('Invalid amount format');
107
132
  }
108
- else if (value.isLessThan(0)) {
133
+ if (value.isLessThan(0)) {
109
134
  throw new sdk_core_1.BuildTransactionError('Value cannot be less than zero');
110
135
  }
111
136
  }
112
- /** @inheritdoc */
137
+ /**
138
+ * Validates that a raw transaction string is properly formatted.
139
+ * @throws ParseTransactionError if raw transaction is invalid
140
+ */
113
141
  validateRawTransaction(rawTransaction) {
114
142
  if (!rawTransaction) {
115
143
  throw new sdk_core_1.ParseTransactionError('Invalid raw transaction: Undefined');
@@ -119,8 +147,9 @@ class TransactionBuilder extends sdk_core_1.BaseTransactionBuilder {
119
147
  }
120
148
  }
121
149
  /**
122
- * @inheritdoc
123
- * */
150
+ * Validates a transaction object has all required fields.
151
+ * @throws Error if transaction is undefined or has invalid data
152
+ */
124
153
  validateTransaction(transaction) {
125
154
  if (!transaction) {
126
155
  throw new Error('transaction not defined');
@@ -136,8 +165,11 @@ class TransactionBuilder extends sdk_core_1.BaseTransactionBuilder {
136
165
  }
137
166
  }
138
167
  /**
139
- * @inheritdoc
140
- * */
168
+ * Creates a transaction object from a raw transaction string or bytes.
169
+ * @param rawTransaction - Raw transaction in base64 string or Uint8Array format
170
+ * @returns The parsed transaction object
171
+ * @throws BuildTransactionError if raw transaction is invalid
172
+ */
141
173
  fromImplementation(rawTransaction) {
142
174
  if (!utils_1.default.isValidRawTransaction(rawTransaction)) {
143
175
  throw new sdk_core_1.BuildTransactionError('Invalid transaction');
@@ -146,23 +178,36 @@ class TransactionBuilder extends sdk_core_1.BaseTransactionBuilder {
146
178
  return this.transaction;
147
179
  }
148
180
  /**
149
- * @inheritdoc
150
- * */
181
+ * Sign implementation - not supported for IOTA transactions.
182
+ * IOTA transactions must be signed externally.
183
+ */
151
184
  signImplementation(key) {
152
185
  throw new Error('Method not implemented.');
153
186
  }
154
187
  /**
155
- * @inheritdoc
156
- * */
188
+ * Builds the transaction and prepares it for broadcast.
189
+ * Automatically switches from simulate to real transaction mode if gas data is present.
190
+ */
157
191
  async buildImplementation() {
158
- // If gas data is provided, this is not a simulate transaction
159
- if (this.transaction.gasPrice && this.transaction.gasBudget && this.transaction.gasPaymentObjects) {
160
- this.transaction.isSimulateTx = false;
161
- }
192
+ this.updateTransactionMode();
162
193
  await this.transaction.build();
163
194
  this.transaction.addInputsAndOutputs();
164
195
  return this.transaction;
165
196
  }
197
+ /**
198
+ * Updates the transaction mode based on gas data availability.
199
+ * Switches to real transaction mode if all gas data is provided.
200
+ */
201
+ updateTransactionMode() {
202
+ const hasCompleteGasData = this.transaction.gasPrice && this.transaction.gasBudget && this.transaction.gasPaymentObjects;
203
+ if (hasCompleteGasData) {
204
+ this.transaction.isSimulateTx = false;
205
+ }
206
+ }
207
+ /**
208
+ * Validates gas data values and presence.
209
+ * @throws BuildTransactionError if gas data is invalid
210
+ */
166
211
  validateGasData(gasData) {
167
212
  if (gasData.gasBudget) {
168
213
  this.validateValue(new bignumber_js_1.default(gasData.gasBudget));
@@ -176,4 +221,4 @@ class TransactionBuilder extends sdk_core_1.BaseTransactionBuilder {
176
221
  }
177
222
  }
178
223
  exports.TransactionBuilder = TransactionBuilder;
179
- //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"transactionBuilder.js","sourceRoot":"","sources":["../../../src/lib/transactionBuilder.ts"],"names":[],"mappings":"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","sourcesContent":["import {\n  BaseAddress,\n  BaseKey,\n  BaseTransaction,\n  BaseTransactionBuilder,\n  BuildTransactionError,\n  ParseTransactionError,\n  PublicKey,\n  TransactionType,\n} from '@bitgo-beta/sdk-core';\nimport BigNumber from 'bignumber.js';\nimport { Transaction } from './transaction';\nimport { BaseCoin as CoinConfig } from '@bitgo-beta/statics';\nimport utils from './utils';\nimport { TransactionObjectInput, GasData } from './iface';\nimport { toBase64 } from '@iota/iota-sdk/utils';\n\nexport abstract class TransactionBuilder extends BaseTransactionBuilder {\n  protected _transaction: Transaction;\n\n  protected constructor(coinConfig: Readonly<CoinConfig>) {\n    super(coinConfig);\n  }\n\n  /**\n   * Initialize the transaction builder fields using the decoded transaction data\n   *\n   * @param {Transaction} tx the transaction data\n   */\n  initBuilder(tx: Transaction): void {\n    this.validateTransaction(tx);\n    this.transaction.sender = tx.sender;\n    this.transaction.gasPrice = tx.gasPrice;\n    this.transaction.gasBudget = tx.gasBudget;\n    this.transaction.gasPaymentObjects = tx.gasPaymentObjects;\n    this.transaction.gasSponsor = tx.gasSponsor;\n  }\n\n  get transactionType(): TransactionType {\n    return this.transaction.type;\n  }\n\n  /**\n   * @inheritdoc\n   * */\n  get transaction(): Transaction {\n    return this._transaction;\n  }\n\n  /**\n   * @inheritdoc\n   * */\n  protected set transaction(transaction: Transaction) {\n    this._transaction = transaction;\n  }\n\n  /**\n   * Sets the sender of this transaction.\n   *\n   * @param {string} senderAddress the account that is sending this transaction\n   * @returns {TransactionBuilder} This transaction builder\n   */\n  sender(senderAddress: string): this {\n    this.validateAddress({ address: senderAddress });\n    this.transaction.sender = senderAddress;\n    return this;\n  }\n\n  /**\n   * Sets the gasData for this transaction.\n   *\n   * @param {string} gasData the gas details for this transaction\n   * @returns {TransactionBuilder} This transaction builder\n   */\n  gasData(gasData: GasData): this {\n    this.validateGasData(gasData);\n    this.transaction.gasPrice = gasData.gasPrice;\n    this.transaction.gasBudget = gasData.gasBudget;\n    this.transaction.gasPaymentObjects = gasData.gasPaymentObjects as TransactionObjectInput[];\n    return this;\n  }\n\n  /**\n   * Sets the gasSponsor of this transaction.\n   *\n   * @param {string} sponsorAddress the account that is sponsoring this transaction's gas\n   * @returns {TransactionBuilder} This transaction builder\n   */\n  gasSponsor(sponsorAddress: string): this {\n    this.validateAddress({ address: sponsorAddress });\n    this.transaction.gasSponsor = sponsorAddress;\n    return this;\n  }\n\n  addSignature(publicKey: PublicKey, signature: Buffer): void {\n    if (!utils.isValidPublicKey(publicKey.pub) || !utils.isValidSignature(toBase64(signature))) {\n      throw new BuildTransactionError('Invalid transaction signature');\n    }\n    this.transaction.addSignature(publicKey, signature);\n  }\n\n  addGasSponsorSignature(publicKey: PublicKey, signature: Buffer): void {\n    if (!utils.isValidPublicKey(publicKey.pub) || !utils.isValidSignature(toBase64(signature))) {\n      throw new BuildTransactionError('Invalid transaction signature');\n    }\n    this.transaction.addGasSponsorSignature(publicKey, signature);\n  }\n\n  validateKey(key: BaseKey): void {\n    throw new Error('Method not implemented.');\n  }\n\n  /**\n   * @inheritdoc\n   * */\n  validateAddress(address: BaseAddress, addressFormat?: string): void {\n    if (!utils.isValidAddress(address.address)) {\n      throw new BuildTransactionError('Invalid address ' + address.address);\n    }\n  }\n\n  /**\n   * @inheritdoc\n   * */\n  validateValue(value: BigNumber): void {\n    if (value.isNaN()) {\n      throw new BuildTransactionError('Invalid amount format');\n    } else if (value.isLessThan(0)) {\n      throw new BuildTransactionError('Value cannot be less than zero');\n    }\n  }\n\n  /** @inheritdoc */\n  validateRawTransaction(rawTransaction: string): void {\n    if (!rawTransaction) {\n      throw new ParseTransactionError('Invalid raw transaction: Undefined');\n    }\n    if (!utils.isValidRawTransaction(rawTransaction)) {\n      throw new ParseTransactionError('Invalid raw transaction');\n    }\n  }\n\n  /**\n   * @inheritdoc\n   * */\n  validateTransaction(transaction?: Transaction): void {\n    if (!transaction) {\n      throw new Error('transaction not defined');\n    }\n    this.validateAddress({ address: transaction.sender });\n    this.validateGasData({\n      gasBudget: transaction.gasBudget,\n      gasPrice: transaction.gasPrice,\n      gasPaymentObjects: transaction.gasPaymentObjects,\n    });\n    if (transaction.gasSponsor) {\n      this.validateAddress({ address: transaction.gasSponsor });\n    }\n  }\n\n  /**\n   * @inheritdoc\n   * */\n  fromImplementation(rawTransaction: string | Uint8Array): Transaction {\n    if (!utils.isValidRawTransaction(rawTransaction)) {\n      throw new BuildTransactionError('Invalid transaction');\n    }\n    this.transaction.parseFromBroadcastTx(rawTransaction);\n    return this.transaction;\n  }\n\n  /**\n   * @inheritdoc\n   * */\n  protected signImplementation(key: BaseKey): BaseTransaction {\n    throw new Error('Method not implemented.');\n  }\n\n  /**\n   * @inheritdoc\n   * */\n  protected async buildImplementation(): Promise<Transaction> {\n    // If gas data is provided, this is not a simulate transaction\n    if (this.transaction.gasPrice && this.transaction.gasBudget && this.transaction.gasPaymentObjects) {\n      this.transaction.isSimulateTx = false;\n    }\n    await this.transaction.build();\n    this.transaction.addInputsAndOutputs();\n    return this.transaction;\n  }\n\n  private validateGasData(gasData: GasData): void {\n    if (gasData.gasBudget) {\n      this.validateValue(new BigNumber(gasData.gasBudget));\n    }\n    if (gasData.gasPrice) {\n      this.validateValue(new BigNumber(gasData.gasPrice));\n    }\n    if (gasData.gasPaymentObjects && gasData.gasPaymentObjects.length === 0) {\n      throw new BuildTransactionError('Gas input objects list is empty');\n    }\n  }\n}\n"]}
224
+ //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"transactionBuilder.js","sourceRoot":"","sources":["../../../src/lib/transactionBuilder.ts"],"names":[],"mappings":"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","sourcesContent":["import {\n  BaseAddress,\n  BaseKey,\n  BaseTransaction,\n  BaseTransactionBuilder,\n  BuildTransactionError,\n  ParseTransactionError,\n  PublicKey,\n  TransactionType,\n} from '@bitgo-beta/sdk-core';\nimport BigNumber from 'bignumber.js';\nimport { Transaction } from './transaction';\nimport { BaseCoin as CoinConfig } from '@bitgo-beta/statics';\nimport utils from './utils';\nimport { TransactionObjectInput, GasData } from './iface';\nimport { toBase64 } from '@iota/iota-sdk/utils';\n\n/**\n * Base class for IOTA transaction builders.\n * Provides common functionality for building and validating IOTA transactions.\n */\nexport abstract class TransactionBuilder extends BaseTransactionBuilder {\n  protected _transaction: Transaction;\n\n  protected constructor(coinConfig: Readonly<CoinConfig>) {\n    super(coinConfig);\n  }\n\n  /**\n   * Initializes the transaction builder with data from an existing transaction.\n   * Copies sender, gas data, and gas sponsor information.\n   */\n  initBuilder(tx: Transaction): void {\n    this.validateTransaction(tx);\n    this.copyTransactionData(tx);\n  }\n\n  /**\n   * Copies transaction data from the source transaction to the builder's transaction.\n   */\n  private copyTransactionData(tx: Transaction): void {\n    this.transaction.sender = tx.sender;\n    this.transaction.gasPrice = tx.gasPrice;\n    this.transaction.gasBudget = tx.gasBudget;\n    this.transaction.gasPaymentObjects = tx.gasPaymentObjects;\n    this.transaction.gasSponsor = tx.gasSponsor;\n  }\n\n  get transactionType(): TransactionType {\n    return this.transaction.type;\n  }\n\n  get transaction(): Transaction {\n    return this._transaction;\n  }\n\n  protected set transaction(transaction: Transaction) {\n    this._transaction = transaction;\n  }\n\n  /**\n   * Sets the sender address for this transaction.\n   * @param senderAddress - The IOTA address that is sending this transaction\n   * @returns This transaction builder for method chaining\n   */\n  sender(senderAddress: string): this {\n    this.validateAddress({ address: senderAddress });\n    this.transaction.sender = senderAddress;\n    return this;\n  }\n\n  /**\n   * Sets the gas data for this transaction (budget, price, and payment objects).\n   * @param gasData - The gas configuration including budget, price, and payment objects\n   * @returns This transaction builder for method chaining\n   */\n  gasData(gasData: GasData): this {\n    this.validateGasData(gasData);\n    this.setGasDataOnTransaction(gasData);\n    return this;\n  }\n\n  /**\n   * Sets gas data fields on the transaction.\n   */\n  private setGasDataOnTransaction(gasData: GasData): void {\n    this.transaction.gasPrice = gasData.gasPrice;\n    this.transaction.gasBudget = gasData.gasBudget;\n    this.transaction.gasPaymentObjects = gasData.gasPaymentObjects as TransactionObjectInput[];\n  }\n\n  /**\n   * Sets the gas sponsor for this transaction.\n   * The gas sponsor pays for transaction fees instead of the sender.\n   * @param sponsorAddress - The IOTA address sponsoring this transaction's gas fees\n   * @returns This transaction builder for method chaining\n   */\n  gasSponsor(sponsorAddress: string): this {\n    this.validateAddress({ address: sponsorAddress });\n    this.transaction.gasSponsor = sponsorAddress;\n    return this;\n  }\n\n  /**\n   * Adds a signature from the transaction sender.\n   * @param publicKey - The sender's public key\n   * @param signature - The signature bytes\n   * @throws BuildTransactionError if the signature or public key is invalid\n   */\n  addSignature(publicKey: PublicKey, signature: Buffer): void {\n    this.validateSignatureData(publicKey, signature);\n    this.transaction.addSignature(publicKey, signature);\n  }\n\n  /**\n   * Adds a signature from the gas sponsor.\n   * @param publicKey - The gas sponsor's public key\n   * @param signature - The signature bytes\n   * @throws BuildTransactionError if the signature or public key is invalid\n   */\n  addGasSponsorSignature(publicKey: PublicKey, signature: Buffer): void {\n    this.validateSignatureData(publicKey, signature);\n    this.transaction.addGasSponsorSignature(publicKey, signature);\n  }\n\n  /**\n   * Validates that the signature and public key are in valid formats.\n   */\n  private validateSignatureData(publicKey: PublicKey, signature: Buffer): void {\n    if (!utils.isValidPublicKey(publicKey.pub) || !utils.isValidSignature(toBase64(signature))) {\n      throw new BuildTransactionError('Invalid transaction signature');\n    }\n  }\n\n  validateKey(key: BaseKey): void {\n    throw new Error('Method not implemented.');\n  }\n\n  /**\n   * Validates an IOTA address format.\n   * @throws BuildTransactionError if address is invalid\n   */\n  validateAddress(address: BaseAddress, addressFormat?: string): void {\n    if (!utils.isValidAddress(address.address)) {\n      throw new BuildTransactionError('Invalid address ' + address.address);\n    }\n  }\n\n  /**\n   * Validates that a numeric value is valid (not NaN and not negative).\n   * @throws BuildTransactionError if value is invalid\n   */\n  validateValue(value: BigNumber): void {\n    if (value.isNaN()) {\n      throw new BuildTransactionError('Invalid amount format');\n    }\n    if (value.isLessThan(0)) {\n      throw new BuildTransactionError('Value cannot be less than zero');\n    }\n  }\n\n  /**\n   * Validates that a raw transaction string is properly formatted.\n   * @throws ParseTransactionError if raw transaction is invalid\n   */\n  validateRawTransaction(rawTransaction: string): void {\n    if (!rawTransaction) {\n      throw new ParseTransactionError('Invalid raw transaction: Undefined');\n    }\n    if (!utils.isValidRawTransaction(rawTransaction)) {\n      throw new ParseTransactionError('Invalid raw transaction');\n    }\n  }\n\n  /**\n   * Validates a transaction object has all required fields.\n   * @throws Error if transaction is undefined or has invalid data\n   */\n  validateTransaction(transaction?: Transaction): void {\n    if (!transaction) {\n      throw new Error('transaction not defined');\n    }\n\n    this.validateAddress({ address: transaction.sender });\n    this.validateGasData({\n      gasBudget: transaction.gasBudget,\n      gasPrice: transaction.gasPrice,\n      gasPaymentObjects: transaction.gasPaymentObjects,\n    });\n\n    if (transaction.gasSponsor) {\n      this.validateAddress({ address: transaction.gasSponsor });\n    }\n  }\n\n  /**\n   * Creates a transaction object from a raw transaction string or bytes.\n   * @param rawTransaction - Raw transaction in base64 string or Uint8Array format\n   * @returns The parsed transaction object\n   * @throws BuildTransactionError if raw transaction is invalid\n   */\n  fromImplementation(rawTransaction: string | Uint8Array): Transaction {\n    if (!utils.isValidRawTransaction(rawTransaction)) {\n      throw new BuildTransactionError('Invalid transaction');\n    }\n    this.transaction.parseFromBroadcastTx(rawTransaction);\n    return this.transaction;\n  }\n\n  /**\n   * Sign implementation - not supported for IOTA transactions.\n   * IOTA transactions must be signed externally.\n   */\n  protected signImplementation(key: BaseKey): BaseTransaction {\n    throw new Error('Method not implemented.');\n  }\n\n  /**\n   * Builds the transaction and prepares it for broadcast.\n   * Automatically switches from simulate to real transaction mode if gas data is present.\n   */\n  protected async buildImplementation(): Promise<Transaction> {\n    this.updateTransactionMode();\n    await this.transaction.build();\n    this.transaction.addInputsAndOutputs();\n    return this.transaction;\n  }\n\n  /**\n   * Updates the transaction mode based on gas data availability.\n   * Switches to real transaction mode if all gas data is provided.\n   */\n  private updateTransactionMode(): void {\n    const hasCompleteGasData =\n      this.transaction.gasPrice && this.transaction.gasBudget && this.transaction.gasPaymentObjects;\n\n    if (hasCompleteGasData) {\n      this.transaction.isSimulateTx = false;\n    }\n  }\n\n  /**\n   * Validates gas data values and presence.\n   * @throws BuildTransactionError if gas data is invalid\n   */\n  private validateGasData(gasData: GasData): void {\n    if (gasData.gasBudget) {\n      this.validateValue(new BigNumber(gasData.gasBudget));\n    }\n\n    if (gasData.gasPrice) {\n      this.validateValue(new BigNumber(gasData.gasPrice));\n    }\n\n    if (gasData.gasPaymentObjects && gasData.gasPaymentObjects.length === 0) {\n      throw new BuildTransactionError('Gas input objects list is empty');\n    }\n  }\n}\n"]}
@@ -3,19 +3,102 @@ import { TransactionBuilder } from './transactionBuilder';
3
3
  import { TransferBuilder } from './transferBuilder';
4
4
  import { Transaction } from './transaction';
5
5
  import { BaseCoin as CoinConfig } from '@bitgo-beta/statics';
6
+ /**
7
+ * Factory class for creating IOTA transaction builders.
8
+ *
9
+ * This factory provides methods to create transaction builders for different
10
+ * transaction types and to reconstruct transactions from raw transaction data.
11
+ *
12
+ * @example
13
+ * ```typescript
14
+ * const factory = new TransactionBuilderFactory(coins.get('tiota'));
15
+ *
16
+ * // Create a new transfer builder
17
+ * const builder = factory.getTransferBuilder();
18
+ *
19
+ * // Rebuild from raw transaction
20
+ * const rebuiltBuilder = factory.from(rawTxHex);
21
+ * ```
22
+ */
6
23
  export declare class TransactionBuilderFactory extends BaseTransactionBuilderFactory {
7
24
  constructor(coinConfig: Readonly<CoinConfig>);
25
+ /**
26
+ * Wallet initialization is not implemented for IOTA.
27
+ * IOTA wallets are initialized through the TSS flow.
28
+ *
29
+ * @throws Error always - not implemented
30
+ */
8
31
  getWalletInitializationBuilder(): void;
9
- /** @inheritdoc */
32
+ /**
33
+ * Creates a transfer transaction builder.
34
+ * Optionally initializes the builder with data from an existing transaction.
35
+ *
36
+ * @param tx - Optional existing transaction to initialize the builder
37
+ * @returns A new TransferBuilder instance
38
+ *
39
+ * @example
40
+ * ```typescript
41
+ * // Create a new transfer builder
42
+ * const builder = factory.getTransferBuilder();
43
+ *
44
+ * // Initialize from existing transaction
45
+ * const existingTx = await builder.build();
46
+ * const newBuilder = factory.getTransferBuilder(existingTx);
47
+ * ```
48
+ */
10
49
  getTransferBuilder(tx?: Transaction): TransferBuilder;
50
+ /**
51
+ * Reconstructs a transaction builder from raw transaction data.
52
+ * Automatically identifies the transaction type and creates the appropriate builder.
53
+ *
54
+ * @param rawTx - Raw transaction data (hex string or Uint8Array)
55
+ * @returns TransactionBuilder appropriate for the transaction type
56
+ * @throws InvalidTransactionError if the transaction type is not supported
57
+ *
58
+ * @example
59
+ * ```typescript
60
+ * // From hex string
61
+ * const builder = factory.from('0x1234...');
62
+ *
63
+ * // From Uint8Array
64
+ * const builder = factory.from(new Uint8Array([...]));
65
+ *
66
+ * // Rebuild and access the transaction
67
+ * const tx = await builder.build();
68
+ * ```
69
+ */
11
70
  from(rawTx: string | Uint8Array): TransactionBuilder;
12
- private identifyTxTypeFromRawTx;
13
71
  /**
14
- * Initialize the builder with the given transaction
72
+ * Identifies the transaction type by analyzing its commands.
73
+ * Currently supports transfer transactions (Send type).
74
+ *
75
+ * @param rawTx - Raw transaction in base64 format
76
+ * @returns The identified transaction type
77
+ * @throws InvalidTransactionError if transaction contains unsupported commands
78
+ */
79
+ private identifyTransactionType;
80
+ /**
81
+ * Checks if a transaction is a transfer transaction by validating its commands.
82
+ * Transfer transactions only contain: SplitCoins, MergeCoins, and TransferObjects commands.
83
+ *
84
+ * @param txData - The parsed transaction data
85
+ * @returns true if all commands are valid transfer commands
86
+ */
87
+ private isTransferTransaction;
88
+ /**
89
+ * Creates a TransferBuilder from raw transaction data.
90
+ *
91
+ * @param rawTxBase64 - Raw transaction in base64 format
92
+ * @returns Initialized TransferBuilder
93
+ */
94
+ private createTransferBuilderFromRawTx;
95
+ /**
96
+ * Initializes a builder with data from an existing transaction.
97
+ * If no transaction is provided, returns the builder as-is.
15
98
  *
16
- * @param {Transaction | undefined} tx - the transaction used to initialize the builder
17
- * @param {TransactionBuilder} builder - the builder to be initialized
18
- * @returns {TransactionBuilder} the builder initialized
99
+ * @param tx - Optional transaction to initialize from
100
+ * @param builder - The builder to initialize
101
+ * @returns The initialized builder
19
102
  */
20
103
  private initializeBuilder;
21
104
  }
@@ -1 +1 @@
1
- {"version":3,"file":"transactionBuilderFactory.d.ts","sourceRoot":"","sources":["../../../src/lib/transactionBuilderFactory.ts"],"names":[],"mappings":"AAAA,OAAO,EAAE,6BAA6B,EAA4C,MAAM,sBAAsB,CAAC;AAC/G,OAAO,EAAE,kBAAkB,EAAE,MAAM,sBAAsB,CAAC;AAC1D,OAAO,EAAE,eAAe,EAAE,MAAM,mBAAmB,CAAC;AACpD,OAAO,EAAE,WAAW,EAAE,MAAM,eAAe,CAAC;AAI5C,OAAO,EAAE,QAAQ,IAAI,UAAU,EAAE,MAAM,qBAAqB,CAAC;AAE7D,qBAAa,yBAA0B,SAAQ,6BAA6B;gBAC9D,UAAU,EAAE,QAAQ,CAAC,UAAU,CAAC;IAIrC,8BAA8B,IAAI,IAAI;IAI7C,kBAAkB;IAClB,kBAAkB,CAAC,EAAE,CAAC,EAAE,WAAW,GAAG,eAAe;IAIrD,IAAI,CAAC,KAAK,EAAE,MAAM,GAAG,UAAU,GAAG,kBAAkB;IAapD,OAAO,CAAC,uBAAuB;IAQ/B;;;;;;OAMG;IACH,OAAO,CAAC,iBAAiB;CAM1B"}
1
+ {"version":3,"file":"transactionBuilderFactory.d.ts","sourceRoot":"","sources":["../../../src/lib/transactionBuilderFactory.ts"],"names":[],"mappings":"AAAA,OAAO,EAAE,6BAA6B,EAA4C,MAAM,sBAAsB,CAAC;AAC/G,OAAO,EAAE,kBAAkB,EAAE,MAAM,sBAAsB,CAAC;AAC1D,OAAO,EAAE,eAAe,EAAE,MAAM,mBAAmB,CAAC;AACpD,OAAO,EAAE,WAAW,EAAE,MAAM,eAAe,CAAC;AAI5C,OAAO,EAAE,QAAQ,IAAI,UAAU,EAAE,MAAM,qBAAqB,CAAC;AAE7D;;;;;;;;;;;;;;;;GAgBG;AACH,qBAAa,yBAA0B,SAAQ,6BAA6B;gBAC9D,UAAU,EAAE,QAAQ,CAAC,UAAU,CAAC;IAI5C;;;;;OAKG;IACI,8BAA8B,IAAI,IAAI;IAI7C;;;;;;;;;;;;;;;;OAgBG;IACH,kBAAkB,CAAC,EAAE,CAAC,EAAE,WAAW,GAAG,eAAe;IAIrD;;;;;;;;;;;;;;;;;;;OAmBG;IACH,IAAI,CAAC,KAAK,EAAE,MAAM,GAAG,UAAU,GAAG,kBAAkB;IAYpD;;;;;;;OAOG;IACH,OAAO,CAAC,uBAAuB;IAU/B;;;;;;OAMG;IACH,OAAO,CAAC,qBAAqB;IAI7B;;;;;OAKG;IACH,OAAO,CAAC,8BAA8B;IAMtC;;;;;;;OAOG;IACH,OAAO,CAAC,iBAAiB;CAM1B"}