@bitgo-beta/sdk-coin-iota 1.0.1-beta.324 → 1.0.1-beta.326
This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
- package/dist/src/iota.d.ts +123 -27
- package/dist/src/iota.d.ts.map +1 -1
- package/dist/src/iota.js +217 -103
- package/dist/src/lib/constants.d.ts +50 -1
- package/dist/src/lib/constants.d.ts.map +1 -1
- package/dist/src/lib/constants.js +68 -4
- package/dist/src/lib/iface.d.ts +141 -1
- package/dist/src/lib/iface.d.ts.map +1 -1
- package/dist/src/lib/iface.js +1 -1
- package/dist/src/lib/keyPair.d.ts +100 -6
- package/dist/src/lib/keyPair.d.ts.map +1 -1
- package/dist/src/lib/keyPair.js +103 -10
- package/dist/src/lib/transaction.d.ts +117 -14
- package/dist/src/lib/transaction.d.ts.map +1 -1
- package/dist/src/lib/transaction.js +190 -67
- package/dist/src/lib/transactionBuilder.d.ts +73 -34
- package/dist/src/lib/transactionBuilder.d.ts.map +1 -1
- package/dist/src/lib/transactionBuilder.js +90 -45
- package/dist/src/lib/transactionBuilderFactory.d.ts +89 -6
- package/dist/src/lib/transactionBuilderFactory.d.ts.map +1 -1
- package/dist/src/lib/transactionBuilderFactory.js +103 -16
- package/dist/src/lib/transferBuilder.d.ts +43 -0
- package/dist/src/lib/transferBuilder.d.ts.map +1 -1
- package/dist/src/lib/transferBuilder.js +50 -5
- package/dist/src/lib/transferTransaction.d.ts +93 -2
- package/dist/src/lib/transferTransaction.d.ts.map +1 -1
- package/dist/src/lib/transferTransaction.js +180 -51
- package/dist/src/lib/utils.d.ts +107 -8
- package/dist/src/lib/utils.d.ts.map +1 -1
- package/dist/src/lib/utils.js +134 -23
- package/dist/test/unit/helpers/testHelpers.d.ts +57 -0
- package/dist/test/unit/helpers/testHelpers.d.ts.map +1 -0
- package/dist/test/unit/helpers/testHelpers.js +176 -0
- package/dist/test/unit/iota.js +47 -152
- package/dist/test/unit/keyPair.js +34 -61
- package/dist/test/unit/transactionBuilder/transactionBuilder.js +137 -255
- package/dist/test/unit/transactionBuilder/transactionBuilderFactory.js +43 -108
- package/dist/test/unit/transactionBuilder/transferBuilder.js +296 -762
- package/dist/test/unit/transferTransaction.js +106 -353
- package/dist/test/unit/utils.js +171 -197
- package/dist/tsconfig.tsbuildinfo +1 -1
- package/package.json +7 -7
|
@@ -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
|
-
*
|
|
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
|
-
*
|
|
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
|
|
26
|
-
*
|
|
27
|
-
* @
|
|
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
|
|
33
|
-
*
|
|
34
|
-
* @
|
|
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
|
|
40
|
-
|
|
41
|
-
|
|
42
|
-
|
|
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
|
-
*
|
|
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
|
-
*
|
|
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
|
-
/**
|
|
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
|
-
*
|
|
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
|
-
*
|
|
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
|
-
*
|
|
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
|
-
*
|
|
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
|
|
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
|
-
*
|
|
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
|
|
45
|
-
*
|
|
46
|
-
* @
|
|
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
|
|
56
|
-
*
|
|
57
|
-
* @
|
|
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
|
|
69
|
-
*
|
|
70
|
-
* @param
|
|
71
|
-
* @returns
|
|
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
|
-
|
|
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
|
-
*
|
|
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
|
-
*
|
|
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
|
-
|
|
133
|
+
if (value.isLessThan(0)) {
|
|
109
134
|
throw new sdk_core_1.BuildTransactionError('Value cannot be less than zero');
|
|
110
135
|
}
|
|
111
136
|
}
|
|
112
|
-
/**
|
|
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
|
-
*
|
|
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
|
-
*
|
|
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
|
-
*
|
|
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
|
-
*
|
|
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
|
-
|
|
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":";;;;;;AAAA,mDAS8B;AAC9B,gEAAqC;AAGrC,oDAA4B;AAE5B,gDAAgD;AAEhD;;;GAGG;AACH,MAAsB,kBAAmB,SAAQ,iCAAsB;IAGrE,YAAsB,UAAgC;QACpD,KAAK,CAAC,UAAU,CAAC,CAAC;IACpB,CAAC;IAED;;;OAGG;IACH,WAAW,CAAC,EAAe;QACzB,IAAI,CAAC,mBAAmB,CAAC,EAAE,CAAC,CAAC;QAC7B,IAAI,CAAC,mBAAmB,CAAC,EAAE,CAAC,CAAC;IAC/B,CAAC;IAED;;OAEG;IACK,mBAAmB,CAAC,EAAe;QACzC,IAAI,CAAC,WAAW,CAAC,MAAM,GAAG,EAAE,CAAC,MAAM,CAAC;QACpC,IAAI,CAAC,WAAW,CAAC,QAAQ,GAAG,EAAE,CAAC,QAAQ,CAAC;QACxC,IAAI,CAAC,WAAW,CAAC,SAAS,GAAG,EAAE,CAAC,SAAS,CAAC;QAC1C,IAAI,CAAC,WAAW,CAAC,iBAAiB,GAAG,EAAE,CAAC,iBAAiB,CAAC;QAC1D,IAAI,CAAC,WAAW,CAAC,UAAU,GAAG,EAAE,CAAC,UAAU,CAAC;IAC9C,CAAC;IAED,IAAI,eAAe;QACjB,OAAO,IAAI,CAAC,WAAW,CAAC,IAAI,CAAC;IAC/B,CAAC;IAED,IAAI,WAAW;QACb,OAAO,IAAI,CAAC,YAAY,CAAC;IAC3B,CAAC;IAED,IAAc,WAAW,CAAC,WAAwB;QAChD,IAAI,CAAC,YAAY,GAAG,WAAW,CAAC;IAClC,CAAC;IAED;;;;OAIG;IACH,MAAM,CAAC,aAAqB;QAC1B,IAAI,CAAC,eAAe,CAAC,EAAE,OAAO,EAAE,aAAa,EAAE,CAAC,CAAC;QACjD,IAAI,CAAC,WAAW,CAAC,MAAM,GAAG,aAAa,CAAC;QACxC,OAAO,IAAI,CAAC;IACd,CAAC;IAED;;;;OAIG;IACH,OAAO,CAAC,OAAgB;QACtB,IAAI,CAAC,eAAe,CAAC,OAAO,CAAC,CAAC;QAC9B,IAAI,CAAC,uBAAuB,CAAC,OAAO,CAAC,CAAC;QACtC,OAAO,IAAI,CAAC;IACd,CAAC;IAED;;OAEG;IACK,uBAAuB,CAAC,OAAgB;QAC9C,IAAI,CAAC,WAAW,CAAC,QAAQ,GAAG,OAAO,CAAC,QAAQ,CAAC;QAC7C,IAAI,CAAC,WAAW,CAAC,SAAS,GAAG,OAAO,CAAC,SAAS,CAAC;QAC/C,IAAI,CAAC,WAAW,CAAC,iBAAiB,GAAG,OAAO,CAAC,iBAA6C,CAAC;IAC7F,CAAC;IAED;;;;;OAKG;IACH,UAAU,CAAC,cAAsB;QAC/B,IAAI,CAAC,eAAe,CAAC,EAAE,OAAO,EAAE,cAAc,EAAE,CAAC,CAAC;QAClD,IAAI,CAAC,WAAW,CAAC,UAAU,GAAG,cAAc,CAAC;QAC7C,OAAO,IAAI,CAAC;IACd,CAAC;IAED;;;;;OAKG;IACH,YAAY,CAAC,SAAoB,EAAE,SAAiB;QAClD,IAAI,CAAC,qBAAqB,CAAC,SAAS,EAAE,SAAS,CAAC,CAAC;QACjD,IAAI,CAAC,WAAW,CAAC,YAAY,CAAC,SAAS,EAAE,SAAS,CAAC,CAAC;IACtD,CAAC;IAED;;;;;OAKG;IACH,sBAAsB,CAAC,SAAoB,EAAE,SAAiB;QAC5D,IAAI,CAAC,qBAAqB,CAAC,SAAS,EAAE,SAAS,CAAC,CAAC;QACjD,IAAI,CAAC,WAAW,CAAC,sBAAsB,CAAC,SAAS,EAAE,SAAS,CAAC,CAAC;IAChE,CAAC;IAED;;OAEG;IACK,qBAAqB,CAAC,SAAoB,EAAE,SAAiB;QACnE,IAAI,CAAC,eAAK,CAAC,gBAAgB,CAAC,SAAS,CAAC,GAAG,CAAC,IAAI,CAAC,eAAK,CAAC,gBAAgB,CAAC,IAAA,gBAAQ,EAAC,SAAS,CAAC,CAAC,EAAE,CAAC;YAC3F,MAAM,IAAI,gCAAqB,CAAC,+BAA+B,CAAC,CAAC;QACnE,CAAC;IACH,CAAC;IAED,WAAW,CAAC,GAAY;QACtB,MAAM,IAAI,KAAK,CAAC,yBAAyB,CAAC,CAAC;IAC7C,CAAC;IAED;;;OAGG;IACH,eAAe,CAAC,OAAoB,EAAE,aAAsB;QAC1D,IAAI,CAAC,eAAK,CAAC,cAAc,CAAC,OAAO,CAAC,OAAO,CAAC,EAAE,CAAC;YAC3C,MAAM,IAAI,gCAAqB,CAAC,kBAAkB,GAAG,OAAO,CAAC,OAAO,CAAC,CAAC;QACxE,CAAC;IACH,CAAC;IAED;;;OAGG;IACH,aAAa,CAAC,KAAgB;QAC5B,IAAI,KAAK,CAAC,KAAK,EAAE,EAAE,CAAC;YAClB,MAAM,IAAI,gCAAqB,CAAC,uBAAuB,CAAC,CAAC;QAC3D,CAAC;QACD,IAAI,KAAK,CAAC,UAAU,CAAC,CAAC,CAAC,EAAE,CAAC;YACxB,MAAM,IAAI,gCAAqB,CAAC,gCAAgC,CAAC,CAAC;QACpE,CAAC;IACH,CAAC;IAED;;;OAGG;IACH,sBAAsB,CAAC,cAAsB;QAC3C,IAAI,CAAC,cAAc,EAAE,CAAC;YACpB,MAAM,IAAI,gCAAqB,CAAC,oCAAoC,CAAC,CAAC;QACxE,CAAC;QACD,IAAI,CAAC,eAAK,CAAC,qBAAqB,CAAC,cAAc,CAAC,EAAE,CAAC;YACjD,MAAM,IAAI,gCAAqB,CAAC,yBAAyB,CAAC,CAAC;QAC7D,CAAC;IACH,CAAC;IAED;;;OAGG;IACH,mBAAmB,CAAC,WAAyB;QAC3C,IAAI,CAAC,WAAW,EAAE,CAAC;YACjB,MAAM,IAAI,KAAK,CAAC,yBAAyB,CAAC,CAAC;QAC7C,CAAC;QAED,IAAI,CAAC,eAAe,CAAC,EAAE,OAAO,EAAE,WAAW,CAAC,MAAM,EAAE,CAAC,CAAC;QACtD,IAAI,CAAC,eAAe,CAAC;YACnB,SAAS,EAAE,WAAW,CAAC,SAAS;YAChC,QAAQ,EAAE,WAAW,CAAC,QAAQ;YAC9B,iBAAiB,EAAE,WAAW,CAAC,iBAAiB;SACjD,CAAC,CAAC;QAEH,IAAI,WAAW,CAAC,UAAU,EAAE,CAAC;YAC3B,IAAI,CAAC,eAAe,CAAC,EAAE,OAAO,EAAE,WAAW,CAAC,UAAU,EAAE,CAAC,CAAC;QAC5D,CAAC;IACH,CAAC;IAED;;;;;OAKG;IACH,kBAAkB,CAAC,cAAmC;QACpD,IAAI,CAAC,eAAK,CAAC,qBAAqB,CAAC,cAAc,CAAC,EAAE,CAAC;YACjD,MAAM,IAAI,gCAAqB,CAAC,qBAAqB,CAAC,CAAC;QACzD,CAAC;QACD,IAAI,CAAC,WAAW,CAAC,oBAAoB,CAAC,cAAc,CAAC,CAAC;QACtD,OAAO,IAAI,CAAC,WAAW,CAAC;IAC1B,CAAC;IAED;;;OAGG;IACO,kBAAkB,CAAC,GAAY;QACvC,MAAM,IAAI,KAAK,CAAC,yBAAyB,CAAC,CAAC;IAC7C,CAAC;IAED;;;OAGG;IACO,KAAK,CAAC,mBAAmB;QACjC,IAAI,CAAC,qBAAqB,EAAE,CAAC;QAC7B,MAAM,IAAI,CAAC,WAAW,CAAC,KAAK,EAAE,CAAC;QAC/B,IAAI,CAAC,WAAW,CAAC,mBAAmB,EAAE,CAAC;QACvC,OAAO,IAAI,CAAC,WAAW,CAAC;IAC1B,CAAC;IAED;;;OAGG;IACK,qBAAqB;QAC3B,MAAM,kBAAkB,GACtB,IAAI,CAAC,WAAW,CAAC,QAAQ,IAAI,IAAI,CAAC,WAAW,CAAC,SAAS,IAAI,IAAI,CAAC,WAAW,CAAC,iBAAiB,CAAC;QAEhG,IAAI,kBAAkB,EAAE,CAAC;YACvB,IAAI,CAAC,WAAW,CAAC,YAAY,GAAG,KAAK,CAAC;QACxC,CAAC;IACH,CAAC;IAED;;;OAGG;IACK,eAAe,CAAC,OAAgB;QACtC,IAAI,OAAO,CAAC,SAAS,EAAE,CAAC;YACtB,IAAI,CAAC,aAAa,CAAC,IAAI,sBAAS,CAAC,OAAO,CAAC,SAAS,CAAC,CAAC,CAAC;QACvD,CAAC;QAED,IAAI,OAAO,CAAC,QAAQ,EAAE,CAAC;YACrB,IAAI,CAAC,aAAa,CAAC,IAAI,sBAAS,CAAC,OAAO,CAAC,QAAQ,CAAC,CAAC,CAAC;QACtD,CAAC;QAED,IAAI,OAAO,CAAC,iBAAiB,IAAI,OAAO,CAAC,iBAAiB,CAAC,MAAM,KAAK,CAAC,EAAE,CAAC;YACxE,MAAM,IAAI,gCAAqB,CAAC,iCAAiC,CAAC,CAAC;QACrE,CAAC;IACH,CAAC;CACF;AA7OD,gDA6OC","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
|
-
/**
|
|
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
|
-
*
|
|
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
|
|
17
|
-
* @param
|
|
18
|
-
* @returns
|
|
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;
|
|
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"}
|