@bitgo-beta/sdk-coin-iota 1.0.1-beta.44 → 1.0.1-beta.441

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 (69) hide show
  1. package/README.md +1 -1
  2. package/dist/src/iota.d.ts +134 -23
  3. package/dist/src/iota.d.ts.map +1 -1
  4. package/dist/src/iota.js +286 -46
  5. package/dist/src/lib/constants.d.ts +59 -6
  6. package/dist/src/lib/constants.d.ts.map +1 -1
  7. package/dist/src/lib/constants.js +76 -8
  8. package/dist/src/lib/iface.d.ts +174 -2
  9. package/dist/src/lib/iface.d.ts.map +1 -1
  10. package/dist/src/lib/iface.js +1 -1
  11. package/dist/src/lib/index.d.ts +1 -0
  12. package/dist/src/lib/index.d.ts.map +1 -1
  13. package/dist/src/lib/index.js +4 -2
  14. package/dist/src/lib/keyPair.d.ts +100 -6
  15. package/dist/src/lib/keyPair.d.ts.map +1 -1
  16. package/dist/src/lib/keyPair.js +103 -10
  17. package/dist/src/lib/transaction.d.ts +175 -5
  18. package/dist/src/lib/transaction.d.ts.map +1 -1
  19. package/dist/src/lib/transaction.js +390 -6
  20. package/dist/src/lib/transactionBuilder.d.ts +109 -9
  21. package/dist/src/lib/transactionBuilder.d.ts.map +1 -1
  22. package/dist/src/lib/transactionBuilder.js +200 -14
  23. package/dist/src/lib/transactionBuilderFactory.d.ts +98 -2
  24. package/dist/src/lib/transactionBuilderFactory.d.ts.map +1 -1
  25. package/dist/src/lib/transactionBuilderFactory.js +132 -5
  26. package/dist/src/lib/transferBuilder.d.ts +52 -2
  27. package/dist/src/lib/transferBuilder.d.ts.map +1 -1
  28. package/dist/src/lib/transferBuilder.js +86 -3
  29. package/dist/src/lib/transferTransaction.d.ts +124 -0
  30. package/dist/src/lib/transferTransaction.d.ts.map +1 -0
  31. package/dist/src/lib/transferTransaction.js +341 -0
  32. package/dist/src/lib/utils.d.ts +108 -7
  33. package/dist/src/lib/utils.d.ts.map +1 -1
  34. package/dist/src/lib/utils.js +146 -11
  35. package/dist/test/resources/iota.d.ts +35 -0
  36. package/dist/test/resources/iota.d.ts.map +1 -0
  37. package/dist/test/resources/iota.js +93 -0
  38. package/dist/test/unit/helpers/testHelpers.d.ts +57 -0
  39. package/dist/test/unit/helpers/testHelpers.d.ts.map +1 -0
  40. package/dist/test/unit/helpers/testHelpers.js +176 -0
  41. package/dist/test/unit/index.d.ts +2 -0
  42. package/dist/test/unit/index.d.ts.map +1 -0
  43. package/dist/test/unit/index.js +16 -0
  44. package/dist/test/unit/iota.d.ts +2 -0
  45. package/dist/test/unit/iota.d.ts.map +1 -0
  46. package/dist/test/unit/iota.js +501 -0
  47. package/dist/test/unit/keyPair.d.ts +2 -0
  48. package/dist/test/unit/keyPair.d.ts.map +1 -0
  49. package/dist/test/unit/keyPair.js +108 -0
  50. package/dist/test/unit/transactionBuilder/transactionBuilder.d.ts +2 -0
  51. package/dist/test/unit/transactionBuilder/transactionBuilder.d.ts.map +1 -0
  52. package/dist/test/unit/transactionBuilder/transactionBuilder.js +188 -0
  53. package/dist/test/unit/transactionBuilder/transactionBuilderFactory.d.ts +2 -0
  54. package/dist/test/unit/transactionBuilder/transactionBuilderFactory.d.ts.map +1 -0
  55. package/dist/test/unit/transactionBuilder/transactionBuilderFactory.js +178 -0
  56. package/dist/test/unit/transactionBuilder/transferBuilder.d.ts +2 -0
  57. package/dist/test/unit/transactionBuilder/transferBuilder.d.ts.map +1 -0
  58. package/dist/test/unit/transactionBuilder/transferBuilder.js +438 -0
  59. package/dist/test/unit/transferTransaction.d.ts +2 -0
  60. package/dist/test/unit/transferTransaction.d.ts.map +1 -0
  61. package/dist/test/unit/transferTransaction.js +218 -0
  62. package/dist/test/unit/utils.d.ts +2 -0
  63. package/dist/test/unit/utils.d.ts.map +1 -0
  64. package/dist/test/unit/utils.js +252 -0
  65. package/dist/tsconfig.tsbuildinfo +1 -0
  66. package/package.json +17 -11
  67. package/.eslintignore +0 -5
  68. package/.mocharc.yml +0 -8
  69. package/CHANGELOG.md +0 -28
@@ -1,15 +1,115 @@
1
- import { BaseAddress, BaseKey, BaseTransaction, BaseTransactionBuilder } from '@bitgo-beta/sdk-core';
1
+ import { BaseAddress, BaseKey, BaseTransaction, BaseTransactionBuilder, PublicKey, TransactionType } from '@bitgo-beta/sdk-core';
2
2
  import BigNumber from 'bignumber.js';
3
- export declare class TransactionBuilder extends BaseTransactionBuilder {
4
- protected fromImplementation(rawTransaction: any): BaseTransaction;
5
- protected signImplementation(key: BaseKey): BaseTransaction;
6
- protected buildImplementation(): Promise<BaseTransaction>;
3
+ import { Transaction } from './transaction';
4
+ import { BaseCoin as CoinConfig } from '@bitgo-beta/statics';
5
+ import { GasData } from './iface';
6
+ /**
7
+ * Base class for IOTA transaction builders.
8
+ * Provides common functionality for building and validating IOTA transactions.
9
+ */
10
+ export declare abstract class TransactionBuilder extends BaseTransactionBuilder {
11
+ protected _transaction: Transaction;
12
+ protected constructor(coinConfig: Readonly<CoinConfig>);
13
+ /**
14
+ * Initializes the transaction builder with data from an existing transaction.
15
+ * Copies sender, gas data, and gas sponsor information.
16
+ */
17
+ initBuilder(tx: Transaction): void;
18
+ /**
19
+ * Copies transaction data from the source transaction to the builder's transaction.
20
+ */
21
+ private copyTransactionData;
22
+ get transactionType(): TransactionType;
23
+ get transaction(): Transaction;
24
+ protected set transaction(transaction: Transaction);
25
+ /**
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
+ */
30
+ sender(senderAddress: string): this;
31
+ /**
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
35
+ */
36
+ gasData(gasData: GasData): this;
37
+ /**
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
46
+ */
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
+ */
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
+ */
61
+ addGasSponsorSignature(publicKey: PublicKey, signature: Buffer): void;
62
+ /**
63
+ * Validates that the signature and public key are in valid formats.
64
+ */
65
+ private validateSignatureData;
7
66
  validateKey(key: BaseKey): void;
67
+ /**
68
+ * Validates an IOTA address format.
69
+ * @throws BuildTransactionError if address is invalid
70
+ */
8
71
  validateAddress(address: BaseAddress, addressFormat?: string): void;
72
+ /**
73
+ * Validates that a numeric value is valid (not NaN and not negative).
74
+ * @throws BuildTransactionError if value is invalid
75
+ */
9
76
  validateValue(value: BigNumber): void;
10
- validateRawTransaction(rawTransaction: any): void;
11
- validateTransaction(transaction?: BaseTransaction): void;
12
- protected get transaction(): BaseTransaction;
13
- protected set transaction(transaction: BaseTransaction);
77
+ /**
78
+ * Validates that a raw transaction string is properly formatted.
79
+ * @throws ParseTransactionError if raw transaction is invalid
80
+ */
81
+ validateRawTransaction(rawTransaction: string): void;
82
+ /**
83
+ * Validates a transaction object has all required fields.
84
+ * @throws Error if transaction is undefined or has invalid data
85
+ */
86
+ validateTransaction(transaction?: Transaction): void;
87
+ /**
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
+ */
93
+ fromImplementation(rawTransaction: string | Uint8Array): Transaction;
94
+ /**
95
+ * Sign implementation - not supported for IOTA transactions.
96
+ * IOTA transactions must be signed externally.
97
+ */
98
+ protected signImplementation(key: BaseKey): BaseTransaction;
99
+ /**
100
+ * Builds the transaction and prepares it for broadcast.
101
+ * Automatically switches from simulate to real transaction mode if gas data is present.
102
+ */
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
+ */
113
+ private validateGasData;
14
114
  }
15
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,EAAE,WAAW,EAAE,OAAO,EAAE,eAAe,EAAE,sBAAsB,EAAE,MAAM,sBAAsB,CAAC;AACrG,OAAO,SAAS,MAAM,cAAc,CAAC;AAErC,qBAAa,kBAAmB,SAAQ,sBAAsB;IAC5D,SAAS,CAAC,kBAAkB,CAAC,cAAc,EAAE,GAAG,GAAG,eAAe;IAGlE,SAAS,CAAC,kBAAkB,CAAC,GAAG,EAAE,OAAO,GAAG,eAAe;IAG3D,SAAS,CAAC,mBAAmB,IAAI,OAAO,CAAC,eAAe,CAAC;IAGzD,WAAW,CAAC,GAAG,EAAE,OAAO,GAAG,IAAI;IAG/B,eAAe,CAAC,OAAO,EAAE,WAAW,EAAE,aAAa,CAAC,EAAE,MAAM,GAAG,IAAI;IAGnE,aAAa,CAAC,KAAK,EAAE,SAAS,GAAG,IAAI;IAGrC,sBAAsB,CAAC,cAAc,EAAE,GAAG,GAAG,IAAI;IAGjD,mBAAmB,CAAC,WAAW,CAAC,EAAE,eAAe,GAAG,IAAI;IAGxD,SAAS,KAAK,WAAW,IAAI,eAAe,CAE3C;IACD,SAAS,KAAK,WAAW,CAAC,WAAW,EAAE,eAAe,EAErD;CACF"}
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"}
@@ -1,38 +1,224 @@
1
1
  "use strict";
2
+ var __importDefault = (this && this.__importDefault) || function (mod) {
3
+ return (mod && mod.__esModule) ? mod : { "default": mod };
4
+ };
2
5
  Object.defineProperty(exports, "__esModule", { value: true });
3
6
  exports.TransactionBuilder = void 0;
4
7
  const sdk_core_1 = require("@bitgo-beta/sdk-core");
8
+ const bignumber_js_1 = __importDefault(require("bignumber.js"));
9
+ const utils_1 = __importDefault(require("./utils"));
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
+ */
5
15
  class TransactionBuilder extends sdk_core_1.BaseTransactionBuilder {
6
- fromImplementation(rawTransaction) {
7
- throw new Error('Method not implemented.');
16
+ constructor(coinConfig) {
17
+ super(coinConfig);
8
18
  }
9
- signImplementation(key) {
10
- throw new Error('Method not implemented.');
19
+ /**
20
+ * Initializes the transaction builder with data from an existing transaction.
21
+ * Copies sender, gas data, and gas sponsor information.
22
+ */
23
+ initBuilder(tx) {
24
+ this.validateTransaction(tx);
25
+ this.copyTransactionData(tx);
11
26
  }
12
- buildImplementation() {
13
- throw new Error('Method not implemented.');
27
+ /**
28
+ * Copies transaction data from the source transaction to the builder's transaction.
29
+ */
30
+ copyTransactionData(tx) {
31
+ this.transaction.sender = tx.sender;
32
+ this.transaction.gasPrice = tx.gasPrice;
33
+ this.transaction.gasBudget = tx.gasBudget;
34
+ this.transaction.gasPaymentObjects = tx.gasPaymentObjects;
35
+ this.transaction.gasSponsor = tx.gasSponsor;
36
+ }
37
+ get transactionType() {
38
+ return this.transaction.type;
39
+ }
40
+ get transaction() {
41
+ return this._transaction;
42
+ }
43
+ set transaction(transaction) {
44
+ this._transaction = transaction;
45
+ }
46
+ /**
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
50
+ */
51
+ sender(senderAddress) {
52
+ this.validateAddress({ address: senderAddress });
53
+ this.transaction.sender = senderAddress;
54
+ return this;
55
+ }
56
+ /**
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
60
+ */
61
+ gasData(gasData) {
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) {
70
+ this.transaction.gasPrice = gasData.gasPrice;
71
+ this.transaction.gasBudget = gasData.gasBudget;
72
+ this.transaction.gasPaymentObjects = gasData.gasPaymentObjects;
73
+ }
74
+ /**
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
79
+ */
80
+ gasSponsor(sponsorAddress) {
81
+ this.validateAddress({ address: sponsorAddress });
82
+ this.transaction.gasSponsor = sponsorAddress;
83
+ return this;
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
+ */
91
+ addSignature(publicKey, signature) {
92
+ this.validateSignatureData(publicKey, signature);
93
+ this.transaction.addSignature(publicKey, signature);
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
+ */
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) {
109
+ if (!utils_1.default.isValidPublicKey(publicKey.pub) || !utils_1.default.isValidSignature((0, utils_2.toBase64)(signature))) {
110
+ throw new sdk_core_1.BuildTransactionError('Invalid transaction signature');
111
+ }
14
112
  }
15
113
  validateKey(key) {
16
114
  throw new Error('Method not implemented.');
17
115
  }
116
+ /**
117
+ * Validates an IOTA address format.
118
+ * @throws BuildTransactionError if address is invalid
119
+ */
18
120
  validateAddress(address, addressFormat) {
19
- throw new Error('Method not implemented.');
121
+ if (!utils_1.default.isValidAddress(address.address)) {
122
+ throw new sdk_core_1.BuildTransactionError('Invalid address ' + address.address);
123
+ }
20
124
  }
125
+ /**
126
+ * Validates that a numeric value is valid (not NaN and not negative).
127
+ * @throws BuildTransactionError if value is invalid
128
+ */
21
129
  validateValue(value) {
22
- throw new Error('Method not implemented.');
130
+ if (value.isNaN()) {
131
+ throw new sdk_core_1.BuildTransactionError('Invalid amount format');
132
+ }
133
+ if (value.isLessThan(0)) {
134
+ throw new sdk_core_1.BuildTransactionError('Value cannot be less than zero');
135
+ }
23
136
  }
137
+ /**
138
+ * Validates that a raw transaction string is properly formatted.
139
+ * @throws ParseTransactionError if raw transaction is invalid
140
+ */
24
141
  validateRawTransaction(rawTransaction) {
25
- throw new Error('Method not implemented.');
142
+ if (!rawTransaction) {
143
+ throw new sdk_core_1.ParseTransactionError('Invalid raw transaction: Undefined');
144
+ }
145
+ if (!utils_1.default.isValidRawTransaction(rawTransaction)) {
146
+ throw new sdk_core_1.ParseTransactionError('Invalid raw transaction');
147
+ }
26
148
  }
149
+ /**
150
+ * Validates a transaction object has all required fields.
151
+ * @throws Error if transaction is undefined or has invalid data
152
+ */
27
153
  validateTransaction(transaction) {
28
- throw new Error('Method not implemented.');
154
+ if (!transaction) {
155
+ throw new Error('transaction not defined');
156
+ }
157
+ this.validateAddress({ address: transaction.sender });
158
+ this.validateGasData({
159
+ gasBudget: transaction.gasBudget,
160
+ gasPrice: transaction.gasPrice,
161
+ gasPaymentObjects: transaction.gasPaymentObjects,
162
+ });
163
+ if (transaction.gasSponsor) {
164
+ this.validateAddress({ address: transaction.gasSponsor });
165
+ }
29
166
  }
30
- get transaction() {
31
- throw new Error('Method not implemented.');
167
+ /**
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
+ */
173
+ fromImplementation(rawTransaction) {
174
+ if (!utils_1.default.isValidRawTransaction(rawTransaction)) {
175
+ throw new sdk_core_1.BuildTransactionError('Invalid transaction');
176
+ }
177
+ this.transaction.parseFromBroadcastTx(rawTransaction);
178
+ return this.transaction;
32
179
  }
33
- set transaction(transaction) {
180
+ /**
181
+ * Sign implementation - not supported for IOTA transactions.
182
+ * IOTA transactions must be signed externally.
183
+ */
184
+ signImplementation(key) {
34
185
  throw new Error('Method not implemented.');
35
186
  }
187
+ /**
188
+ * Builds the transaction and prepares it for broadcast.
189
+ * Automatically switches from simulate to real transaction mode if gas data is present.
190
+ */
191
+ async buildImplementation() {
192
+ this.updateTransactionMode();
193
+ await this.transaction.build();
194
+ this.transaction.addInputsAndOutputs();
195
+ return this.transaction;
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
+ */
211
+ validateGasData(gasData) {
212
+ if (gasData.gasBudget) {
213
+ this.validateValue(new bignumber_js_1.default(gasData.gasBudget));
214
+ }
215
+ if (gasData.gasPrice) {
216
+ this.validateValue(new bignumber_js_1.default(gasData.gasPrice));
217
+ }
218
+ if (gasData.gasPaymentObjects && gasData.gasPaymentObjects.length === 0) {
219
+ throw new sdk_core_1.BuildTransactionError('Gas input objects list is empty');
220
+ }
221
+ }
36
222
  }
37
223
  exports.TransactionBuilder = TransactionBuilder;
38
- //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoidHJhbnNhY3Rpb25CdWlsZGVyLmpzIiwic291cmNlUm9vdCI6IiIsInNvdXJjZXMiOlsiLi4vLi4vLi4vc3JjL2xpYi90cmFuc2FjdGlvbkJ1aWxkZXIudHMiXSwibmFtZXMiOltdLCJtYXBwaW5ncyI6Ijs7O0FBQUEsbURBQXFHO0FBR3JHLE1BQWEsa0JBQW1CLFNBQVEsaUNBQXNCO0lBQ2xELGtCQUFrQixDQUFDLGNBQW1CO1FBQzlDLE1BQU0sSUFBSSxLQUFLLENBQUMseUJBQXlCLENBQUMsQ0FBQztJQUM3QyxDQUFDO0lBQ1Msa0JBQWtCLENBQUMsR0FBWTtRQUN2QyxNQUFNLElBQUksS0FBSyxDQUFDLHlCQUF5QixDQUFDLENBQUM7SUFDN0MsQ0FBQztJQUNTLG1CQUFtQjtRQUMzQixNQUFNLElBQUksS0FBSyxDQUFDLHlCQUF5QixDQUFDLENBQUM7SUFDN0MsQ0FBQztJQUNELFdBQVcsQ0FBQyxHQUFZO1FBQ3RCLE1BQU0sSUFBSSxLQUFLLENBQUMseUJBQXlCLENBQUMsQ0FBQztJQUM3QyxDQUFDO0lBQ0QsZUFBZSxDQUFDLE9BQW9CLEVBQUUsYUFBc0I7UUFDMUQsTUFBTSxJQUFJLEtBQUssQ0FBQyx5QkFBeUIsQ0FBQyxDQUFDO0lBQzdDLENBQUM7SUFDRCxhQUFhLENBQUMsS0FBZ0I7UUFDNUIsTUFBTSxJQUFJLEtBQUssQ0FBQyx5QkFBeUIsQ0FBQyxDQUFDO0lBQzdDLENBQUM7SUFDRCxzQkFBc0IsQ0FBQyxjQUFtQjtRQUN4QyxNQUFNLElBQUksS0FBSyxDQUFDLHlCQUF5QixDQUFDLENBQUM7SUFDN0MsQ0FBQztJQUNELG1CQUFtQixDQUFDLFdBQTZCO1FBQy9DLE1BQU0sSUFBSSxLQUFLLENBQUMseUJBQXlCLENBQUMsQ0FBQztJQUM3QyxDQUFDO0lBQ0QsSUFBYyxXQUFXO1FBQ3ZCLE1BQU0sSUFBSSxLQUFLLENBQUMseUJBQXlCLENBQUMsQ0FBQztJQUM3QyxDQUFDO0lBQ0QsSUFBYyxXQUFXLENBQUMsV0FBNEI7UUFDcEQsTUFBTSxJQUFJLEtBQUssQ0FBQyx5QkFBeUIsQ0FBQyxDQUFDO0lBQzdDLENBQUM7Q0FDRjtBQS9CRCxnREErQkMiLCJzb3VyY2VzQ29udGVudCI6WyJpbXBvcnQgeyBCYXNlQWRkcmVzcywgQmFzZUtleSwgQmFzZVRyYW5zYWN0aW9uLCBCYXNlVHJhbnNhY3Rpb25CdWlsZGVyIH0gZnJvbSAnQGJpdGdvLWJldGEvc2RrLWNvcmUnO1xuaW1wb3J0IEJpZ051bWJlciBmcm9tICdiaWdudW1iZXIuanMnO1xuXG5leHBvcnQgY2xhc3MgVHJhbnNhY3Rpb25CdWlsZGVyIGV4dGVuZHMgQmFzZVRyYW5zYWN0aW9uQnVpbGRlciB7XG4gIHByb3RlY3RlZCBmcm9tSW1wbGVtZW50YXRpb24ocmF3VHJhbnNhY3Rpb246IGFueSk6IEJhc2VUcmFuc2FjdGlvbiB7XG4gICAgdGhyb3cgbmV3IEVycm9yKCdNZXRob2Qgbm90IGltcGxlbWVudGVkLicpO1xuICB9XG4gIHByb3RlY3RlZCBzaWduSW1wbGVtZW50YXRpb24oa2V5OiBCYXNlS2V5KTogQmFzZVRyYW5zYWN0aW9uIHtcbiAgICB0aHJvdyBuZXcgRXJyb3IoJ01ldGhvZCBub3QgaW1wbGVtZW50ZWQuJyk7XG4gIH1cbiAgcHJvdGVjdGVkIGJ1aWxkSW1wbGVtZW50YXRpb24oKTogUHJvbWlzZTxCYXNlVHJhbnNhY3Rpb24+IHtcbiAgICB0aHJvdyBuZXcgRXJyb3IoJ01ldGhvZCBub3QgaW1wbGVtZW50ZWQuJyk7XG4gIH1cbiAgdmFsaWRhdGVLZXkoa2V5OiBCYXNlS2V5KTogdm9pZCB7XG4gICAgdGhyb3cgbmV3IEVycm9yKCdNZXRob2Qgbm90IGltcGxlbWVudGVkLicpO1xuICB9XG4gIHZhbGlkYXRlQWRkcmVzcyhhZGRyZXNzOiBCYXNlQWRkcmVzcywgYWRkcmVzc0Zvcm1hdD86IHN0cmluZyk6IHZvaWQge1xuICAgIHRocm93IG5ldyBFcnJvcignTWV0aG9kIG5vdCBpbXBsZW1lbnRlZC4nKTtcbiAgfVxuICB2YWxpZGF0ZVZhbHVlKHZhbHVlOiBCaWdOdW1iZXIpOiB2b2lkIHtcbiAgICB0aHJvdyBuZXcgRXJyb3IoJ01ldGhvZCBub3QgaW1wbGVtZW50ZWQuJyk7XG4gIH1cbiAgdmFsaWRhdGVSYXdUcmFuc2FjdGlvbihyYXdUcmFuc2FjdGlvbjogYW55KTogdm9pZCB7XG4gICAgdGhyb3cgbmV3IEVycm9yKCdNZXRob2Qgbm90IGltcGxlbWVudGVkLicpO1xuICB9XG4gIHZhbGlkYXRlVHJhbnNhY3Rpb24odHJhbnNhY3Rpb24/OiBCYXNlVHJhbnNhY3Rpb24pOiB2b2lkIHtcbiAgICB0aHJvdyBuZXcgRXJyb3IoJ01ldGhvZCBub3QgaW1wbGVtZW50ZWQuJyk7XG4gIH1cbiAgcHJvdGVjdGVkIGdldCB0cmFuc2FjdGlvbigpOiBCYXNlVHJhbnNhY3Rpb24ge1xuICAgIHRocm93IG5ldyBFcnJvcignTWV0aG9kIG5vdCBpbXBsZW1lbnRlZC4nKTtcbiAgfVxuICBwcm90ZWN0ZWQgc2V0IHRyYW5zYWN0aW9uKHRyYW5zYWN0aW9uOiBCYXNlVHJhbnNhY3Rpb24pIHtcbiAgICB0aHJvdyBuZXcgRXJyb3IoJ01ldGhvZCBub3QgaW1wbGVtZW50ZWQuJyk7XG4gIH1cbn1cbiJdfQ==
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"]}
@@ -1,9 +1,105 @@
1
1
  import { BaseTransactionBuilderFactory } from '@bitgo-beta/sdk-core';
2
2
  import { TransactionBuilder } from './transactionBuilder';
3
3
  import { TransferBuilder } from './transferBuilder';
4
+ import { Transaction } from './transaction';
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
+ */
4
23
  export declare class TransactionBuilderFactory extends BaseTransactionBuilderFactory {
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
+ */
5
31
  getWalletInitializationBuilder(): void;
6
- getTransferBuilder(): TransferBuilder;
7
- from(raw: string | Uint8Array): TransactionBuilder;
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
+ */
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
+ */
70
+ from(rawTx: string | Uint8Array): TransactionBuilder;
71
+ /**
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.
98
+ *
99
+ * @param tx - Optional transaction to initialize from
100
+ * @param builder - The builder to initialize
101
+ * @returns The initialized builder
102
+ */
103
+ private initializeBuilder;
8
104
  }
9
105
  //# sourceMappingURL=transactionBuilderFactory.d.ts.map
@@ -1 +1 @@
1
- {"version":3,"file":"transactionBuilderFactory.d.ts","sourceRoot":"","sources":["../../../src/lib/transactionBuilderFactory.ts"],"names":[],"mappings":"AAAA,OAAO,EAAE,6BAA6B,EAAE,MAAM,sBAAsB,CAAC;AACrE,OAAO,EAAE,kBAAkB,EAAE,MAAM,sBAAsB,CAAC;AAC1D,OAAO,EAAE,eAAe,EAAE,MAAM,mBAAmB,CAAC;AAEpD,qBAAa,yBAA0B,SAAQ,6BAA6B;IACnE,8BAA8B,IAAI,IAAI;IAGtC,kBAAkB,IAAI,eAAe;IAGrC,IAAI,CAAC,GAAG,EAAE,MAAM,GAAG,UAAU,GAAG,kBAAkB;CAG1D"}
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"}