@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
package/dist/src/iota.js
CHANGED
|
@@ -45,6 +45,10 @@ const sdk_lib_mpc_1 = require("@bitgo-beta/sdk-lib-mpc");
|
|
|
45
45
|
const bignumber_js_1 = __importDefault(require("bignumber.js"));
|
|
46
46
|
const _ = __importStar(require("lodash"));
|
|
47
47
|
const transferTransaction_1 = require("./lib/transferTransaction");
|
|
48
|
+
/**
|
|
49
|
+
* IOTA coin implementation.
|
|
50
|
+
* Supports TSS (Threshold Signature Scheme) with EDDSA algorithm.
|
|
51
|
+
*/
|
|
48
52
|
class Iota extends sdk_core_1.BaseCoin {
|
|
49
53
|
constructor(bitgo, staticsCoin) {
|
|
50
54
|
super(bitgo);
|
|
@@ -53,9 +57,15 @@ class Iota extends sdk_core_1.BaseCoin {
|
|
|
53
57
|
}
|
|
54
58
|
this._staticsCoin = staticsCoin;
|
|
55
59
|
}
|
|
60
|
+
/**
|
|
61
|
+
* Factory method to create an IOTA coin instance.
|
|
62
|
+
*/
|
|
56
63
|
static createInstance(bitgo, staticsCoin) {
|
|
57
64
|
return new Iota(bitgo, staticsCoin);
|
|
58
65
|
}
|
|
66
|
+
// ========================================
|
|
67
|
+
// Coin Configuration Methods
|
|
68
|
+
// ========================================
|
|
59
69
|
getBaseFactor() {
|
|
60
70
|
return Math.pow(10, this._staticsCoin.decimalPlaces);
|
|
61
71
|
}
|
|
@@ -68,130 +78,100 @@ class Iota extends sdk_core_1.BaseCoin {
|
|
|
68
78
|
getFullName() {
|
|
69
79
|
return this._staticsCoin.fullName;
|
|
70
80
|
}
|
|
71
|
-
|
|
81
|
+
// ========================================
|
|
82
|
+
// Multi-Signature and TSS Support
|
|
83
|
+
// ========================================
|
|
72
84
|
supportsTss() {
|
|
73
85
|
return true;
|
|
74
86
|
}
|
|
75
|
-
/** inherited doc */
|
|
76
87
|
getDefaultMultisigType() {
|
|
77
88
|
return sdk_core_1.multisigTypes.tss;
|
|
78
89
|
}
|
|
79
90
|
getMPCAlgorithm() {
|
|
80
91
|
return sdk_core_1.MPCType.EDDSA;
|
|
81
92
|
}
|
|
93
|
+
// ========================================
|
|
94
|
+
// Address and Public Key Validation
|
|
95
|
+
// ========================================
|
|
82
96
|
/**
|
|
83
|
-
*
|
|
84
|
-
* @param address
|
|
97
|
+
* Validates an IOTA address.
|
|
98
|
+
* @param address - The address to validate (64-character hex string)
|
|
85
99
|
* @returns true if the address is valid
|
|
86
100
|
*/
|
|
87
101
|
isValidAddress(address) {
|
|
88
|
-
// IOTA addresses are 64-character hex strings
|
|
89
102
|
return utils_1.default.isValidAddress(address);
|
|
90
103
|
}
|
|
91
104
|
/**
|
|
92
|
-
*
|
|
105
|
+
* Validates a public key.
|
|
106
|
+
* @param pub - The public key to validate
|
|
107
|
+
* @returns true if the public key is valid
|
|
108
|
+
*/
|
|
109
|
+
isValidPub(pub) {
|
|
110
|
+
return utils_1.default.isValidPublicKey(pub);
|
|
111
|
+
}
|
|
112
|
+
/**
|
|
113
|
+
* Verifies if an address belongs to a TSS wallet.
|
|
114
|
+
* @param params - Verification parameters including wallet address and user/backup public keys
|
|
115
|
+
* @returns true if the address belongs to the wallet
|
|
116
|
+
*/
|
|
117
|
+
async isWalletAddress(params) {
|
|
118
|
+
return (0, sdk_core_1.verifyEddsaTssWalletAddress)(params, (address) => this.isValidAddress(address), (publicKey) => utils_1.default.getAddressFromPublicKey(publicKey));
|
|
119
|
+
}
|
|
120
|
+
// ========================================
|
|
121
|
+
// Transaction Explanation and Verification
|
|
122
|
+
// ========================================
|
|
123
|
+
/**
|
|
124
|
+
* Explains a transaction by parsing its hex representation.
|
|
125
|
+
* @param params - Parameters containing the transaction hex
|
|
126
|
+
* @returns Detailed explanation of the transaction
|
|
127
|
+
* @throws Error if txHex is missing or transaction cannot be explained
|
|
93
128
|
*/
|
|
94
129
|
async explainTransaction(params) {
|
|
95
|
-
const rawTx = params.txHex;
|
|
96
|
-
if (!rawTx) {
|
|
97
|
-
throw new Error('missing required tx prebuild property txHex');
|
|
98
|
-
}
|
|
130
|
+
const rawTx = this.validateAndExtractTxHex(params.txHex, 'explain');
|
|
99
131
|
const transaction = await this.rebuildTransaction(rawTx);
|
|
100
|
-
if (!transaction) {
|
|
101
|
-
throw new Error('failed to explain transaction');
|
|
102
|
-
}
|
|
103
132
|
return transaction.explainTransaction();
|
|
104
133
|
}
|
|
105
134
|
/**
|
|
106
|
-
* Verifies that a transaction prebuild
|
|
107
|
-
*
|
|
135
|
+
* Verifies that a transaction prebuild matches the original transaction parameters.
|
|
136
|
+
* Ensures recipients and amounts align with the intended transaction.
|
|
137
|
+
*
|
|
138
|
+
* @param params - Verification parameters containing prebuild and original params
|
|
139
|
+
* @returns true if verification succeeds
|
|
140
|
+
* @throws Error if verification fails
|
|
108
141
|
*/
|
|
109
142
|
async verifyTransaction(params) {
|
|
110
|
-
const { txPrebuild
|
|
111
|
-
const rawTx = txPrebuild.txHex;
|
|
112
|
-
if (!rawTx) {
|
|
113
|
-
throw new Error('missing required tx prebuild property txHex');
|
|
114
|
-
}
|
|
143
|
+
const { txPrebuild, txParams } = params;
|
|
144
|
+
const rawTx = this.validateAndExtractTxHex(txPrebuild.txHex, 'verify');
|
|
115
145
|
const transaction = await this.rebuildTransaction(rawTx);
|
|
116
|
-
|
|
117
|
-
throw new Error('failed to verify transaction');
|
|
118
|
-
}
|
|
146
|
+
this.validateTransactionType(transaction);
|
|
119
147
|
if (txParams.recipients !== undefined) {
|
|
120
|
-
|
|
121
|
-
throw new Error('Tx not a transfer transaction');
|
|
122
|
-
}
|
|
123
|
-
const txData = transaction.toJson();
|
|
124
|
-
if (!txData.recipients) {
|
|
125
|
-
throw new Error('Tx recipients does not match with expected txParams recipients');
|
|
126
|
-
}
|
|
127
|
-
const normalizeRecipient = (recipient) => _.pick(recipient, ['address', 'amount', 'tokenName']);
|
|
128
|
-
const txDataRecipients = txData.recipients.map(normalizeRecipient);
|
|
129
|
-
const txParamsRecipients = txParams.recipients.map(normalizeRecipient);
|
|
130
|
-
const allRecipientsMatch = txParamsRecipients.every((expectedRecipient) => txDataRecipients.some((actualRecipient) => _.isEqual(expectedRecipient, actualRecipient)));
|
|
131
|
-
if (!allRecipientsMatch) {
|
|
132
|
-
throw new Error('Tx recipients does not match with expected txParams recipients');
|
|
133
|
-
}
|
|
148
|
+
this.verifyTransactionRecipients(transaction, txParams.recipients);
|
|
134
149
|
}
|
|
135
150
|
return true;
|
|
136
151
|
}
|
|
137
152
|
/**
|
|
138
|
-
*
|
|
139
|
-
* @param params
|
|
140
|
-
|
|
141
|
-
async isWalletAddress(params) {
|
|
142
|
-
return (0, sdk_core_1.verifyEddsaTssWalletAddress)(params, (address) => this.isValidAddress(address), (publicKey) => utils_1.default.getAddressFromPublicKey(publicKey));
|
|
143
|
-
}
|
|
144
|
-
/**
|
|
145
|
-
* Parse a transaction
|
|
146
|
-
* @param params
|
|
153
|
+
* Parses a transaction and extracts inputs, outputs, and fees.
|
|
154
|
+
* @param params - Parameters containing the transaction hex
|
|
155
|
+
* @returns Parsed transaction with inputs, outputs, and fee information
|
|
147
156
|
*/
|
|
148
157
|
async parseTransaction(params) {
|
|
149
158
|
const transactionExplanation = await this.explainTransaction({ txHex: params.txHex });
|
|
150
|
-
if (!transactionExplanation) {
|
|
151
|
-
|
|
152
|
-
}
|
|
153
|
-
let fee = new bignumber_js_1.default(0);
|
|
154
|
-
if (transactionExplanation.outputs.length <= 0) {
|
|
155
|
-
return {
|
|
156
|
-
inputs: [],
|
|
157
|
-
outputs: [],
|
|
158
|
-
fee,
|
|
159
|
-
};
|
|
160
|
-
}
|
|
161
|
-
const senderAddress = transactionExplanation.outputs[0].address;
|
|
162
|
-
if (transactionExplanation.fee.fee !== '') {
|
|
163
|
-
fee = new bignumber_js_1.default(transactionExplanation.fee.fee);
|
|
159
|
+
if (!transactionExplanation || transactionExplanation.outputs.length === 0) {
|
|
160
|
+
return this.createEmptyParsedTransaction();
|
|
164
161
|
}
|
|
165
|
-
const
|
|
166
|
-
|
|
167
|
-
|
|
168
|
-
|
|
169
|
-
{
|
|
170
|
-
address: senderAddress,
|
|
171
|
-
amount: outputAmount,
|
|
172
|
-
},
|
|
173
|
-
];
|
|
174
|
-
if (transactionExplanation.sponsor) {
|
|
175
|
-
inputs.push({
|
|
176
|
-
address: transactionExplanation.sponsor,
|
|
177
|
-
amount: fee.toFixed(),
|
|
178
|
-
});
|
|
179
|
-
}
|
|
180
|
-
const outputs = transactionExplanation.outputs.map((output) => {
|
|
181
|
-
return {
|
|
182
|
-
address: output.address,
|
|
183
|
-
amount: new bignumber_js_1.default(output.amount).toFixed(),
|
|
184
|
-
};
|
|
185
|
-
});
|
|
186
|
-
return {
|
|
187
|
-
inputs,
|
|
188
|
-
outputs,
|
|
189
|
-
fee,
|
|
190
|
-
};
|
|
162
|
+
const fee = this.calculateTransactionFee(transactionExplanation);
|
|
163
|
+
const inputs = this.buildTransactionInputs(transactionExplanation, fee);
|
|
164
|
+
const outputs = this.buildTransactionOutputs(transactionExplanation);
|
|
165
|
+
return { inputs, outputs, fee };
|
|
191
166
|
}
|
|
167
|
+
// ========================================
|
|
168
|
+
// Key Generation and Signing
|
|
169
|
+
// ========================================
|
|
192
170
|
/**
|
|
193
|
-
*
|
|
194
|
-
* @param seed Optional seed to generate key pair
|
|
171
|
+
* Generates a key pair for IOTA transactions.
|
|
172
|
+
* @param seed - Optional seed to generate deterministic key pair
|
|
173
|
+
* @returns Key pair with public and private keys
|
|
174
|
+
* @throws Error if private key generation fails
|
|
195
175
|
*/
|
|
196
176
|
generateKeyPair(seed) {
|
|
197
177
|
const keyPair = seed ? new lib_1.KeyPair({ seed }) : new lib_1.KeyPair();
|
|
@@ -205,22 +185,16 @@ class Iota extends sdk_core_1.BaseCoin {
|
|
|
205
185
|
};
|
|
206
186
|
}
|
|
207
187
|
/**
|
|
208
|
-
*
|
|
209
|
-
*
|
|
210
|
-
*/
|
|
211
|
-
isValidPub(pub) {
|
|
212
|
-
return utils_1.default.isValidPublicKey(pub);
|
|
213
|
-
}
|
|
214
|
-
/**
|
|
215
|
-
* Sign a transaction
|
|
216
|
-
* @param params
|
|
188
|
+
* Signs a transaction (not implemented for IOTA).
|
|
189
|
+
* IOTA transactions are signed externally using TSS.
|
|
217
190
|
*/
|
|
218
191
|
async signTransaction(params) {
|
|
219
192
|
throw new Error('Method not implemented.');
|
|
220
193
|
}
|
|
221
194
|
/**
|
|
222
|
-
*
|
|
223
|
-
* @param params
|
|
195
|
+
* Audits a decrypted private key to ensure it's valid for the given public key.
|
|
196
|
+
* @param params - Parameters containing multiSigType, private key, and public key
|
|
197
|
+
* @throws Error if multiSigType is not TSS or if key validation fails
|
|
224
198
|
*/
|
|
225
199
|
auditDecryptedKey({ multiSigType, prv, publicKey }) {
|
|
226
200
|
if (multiSigType !== sdk_core_1.multisigTypes.tss) {
|
|
@@ -228,18 +202,158 @@ class Iota extends sdk_core_1.BaseCoin {
|
|
|
228
202
|
}
|
|
229
203
|
(0, sdk_lib_mpc_1.auditEddsaPrivateKey)(prv, publicKey ?? '');
|
|
230
204
|
}
|
|
231
|
-
/**
|
|
205
|
+
/**
|
|
206
|
+
* Extracts the signable payload from a serialized transaction.
|
|
207
|
+
* @param serializedTx - The serialized transaction hex
|
|
208
|
+
* @returns Buffer containing the signable payload
|
|
209
|
+
*/
|
|
232
210
|
async getSignablePayload(serializedTx) {
|
|
233
211
|
const rebuiltTransaction = await this.rebuildTransaction(serializedTx);
|
|
234
212
|
return rebuiltTransaction.signablePayload;
|
|
235
213
|
}
|
|
236
|
-
/**
|
|
214
|
+
/**
|
|
215
|
+
* Sets coin-specific fields in the transaction intent.
|
|
216
|
+
* @param intent - The populated intent object to modify
|
|
217
|
+
* @param params - Parameters containing unspents data
|
|
218
|
+
*/
|
|
237
219
|
setCoinSpecificFieldsInIntent(intent, params) {
|
|
238
220
|
intent.unspents = params.unspents;
|
|
239
221
|
}
|
|
222
|
+
// ========================================
|
|
223
|
+
// Private Helper Methods
|
|
224
|
+
// ========================================
|
|
225
|
+
/**
|
|
226
|
+
* Validates and extracts transaction hex from parameters.
|
|
227
|
+
* @param txHex - The transaction hex to validate
|
|
228
|
+
* @param operation - The operation being performed (for error messages)
|
|
229
|
+
* @returns The validated transaction hex
|
|
230
|
+
* @throws Error if txHex is missing
|
|
231
|
+
*/
|
|
232
|
+
validateAndExtractTxHex(txHex, operation) {
|
|
233
|
+
if (!txHex) {
|
|
234
|
+
throw new Error(`missing required tx prebuild property txHex for ${operation} operation`);
|
|
235
|
+
}
|
|
236
|
+
return txHex;
|
|
237
|
+
}
|
|
238
|
+
/**
|
|
239
|
+
* Validates that the transaction is a TransferTransaction.
|
|
240
|
+
* @param transaction - The transaction to validate
|
|
241
|
+
* @throws Error if transaction is not a TransferTransaction
|
|
242
|
+
*/
|
|
243
|
+
validateTransactionType(transaction) {
|
|
244
|
+
if (!(transaction instanceof transferTransaction_1.TransferTransaction)) {
|
|
245
|
+
throw new Error('Tx not a transfer transaction');
|
|
246
|
+
}
|
|
247
|
+
}
|
|
248
|
+
/**
|
|
249
|
+
* Verifies that transaction recipients match the expected recipients.
|
|
250
|
+
* @param transaction - The transfer transaction to verify
|
|
251
|
+
* @param expectedRecipients - The expected recipients from transaction params
|
|
252
|
+
* @throws Error if recipients don't match
|
|
253
|
+
*/
|
|
254
|
+
verifyTransactionRecipients(transaction, expectedRecipients) {
|
|
255
|
+
const txData = transaction.toJson();
|
|
256
|
+
if (!txData.recipients) {
|
|
257
|
+
throw new Error('Tx recipients does not match with expected txParams recipients');
|
|
258
|
+
}
|
|
259
|
+
const actualRecipients = this.normalizeRecipients(txData.recipients);
|
|
260
|
+
const expected = this.normalizeRecipients(expectedRecipients);
|
|
261
|
+
if (!this.recipientsMatch(expected, actualRecipients)) {
|
|
262
|
+
throw new Error('Tx recipients does not match with expected txParams recipients');
|
|
263
|
+
}
|
|
264
|
+
}
|
|
265
|
+
/**
|
|
266
|
+
* Normalizes recipients by extracting only relevant fields.
|
|
267
|
+
* @param recipients - Recipients to normalize
|
|
268
|
+
* @returns Normalized recipients with address, amount, and tokenName only
|
|
269
|
+
*/
|
|
270
|
+
normalizeRecipients(recipients) {
|
|
271
|
+
return recipients.map((recipient) => _.pick(recipient, ['address', 'amount', 'tokenName']));
|
|
272
|
+
}
|
|
273
|
+
/**
|
|
274
|
+
* Checks if expected recipients match actual recipients.
|
|
275
|
+
* @param expected - Expected recipients
|
|
276
|
+
* @param actual - Actual recipients from transaction
|
|
277
|
+
* @returns true if all expected recipients are found in actual recipients
|
|
278
|
+
*/
|
|
279
|
+
recipientsMatch(expected, actual) {
|
|
280
|
+
return expected.every((expectedRecipient) => actual.some((actualRecipient) => _.isEqual(expectedRecipient, actualRecipient)));
|
|
281
|
+
}
|
|
282
|
+
/**
|
|
283
|
+
* Creates an empty parsed transaction result.
|
|
284
|
+
* Used when transaction has no outputs.
|
|
285
|
+
*/
|
|
286
|
+
createEmptyParsedTransaction() {
|
|
287
|
+
return {
|
|
288
|
+
inputs: [],
|
|
289
|
+
outputs: [],
|
|
290
|
+
fee: new bignumber_js_1.default(0),
|
|
291
|
+
};
|
|
292
|
+
}
|
|
293
|
+
/**
|
|
294
|
+
* Calculates the transaction fee from the explanation.
|
|
295
|
+
* @param explanation - The transaction explanation
|
|
296
|
+
* @returns The fee as a BigNumber
|
|
297
|
+
*/
|
|
298
|
+
calculateTransactionFee(explanation) {
|
|
299
|
+
if (explanation.fee.fee === '') {
|
|
300
|
+
return new bignumber_js_1.default(0);
|
|
301
|
+
}
|
|
302
|
+
return new bignumber_js_1.default(explanation.fee.fee);
|
|
303
|
+
}
|
|
304
|
+
/**
|
|
305
|
+
* Builds the inputs array for a parsed transaction.
|
|
306
|
+
* Includes sender input and optionally sponsor input if present.
|
|
307
|
+
*
|
|
308
|
+
* @param explanation - The transaction explanation
|
|
309
|
+
* @param fee - The calculated transaction fee
|
|
310
|
+
* @returns Array of transaction inputs
|
|
311
|
+
*/
|
|
312
|
+
buildTransactionInputs(explanation, fee) {
|
|
313
|
+
const senderAddress = explanation.outputs[0].address;
|
|
314
|
+
const outputAmount = new bignumber_js_1.default(explanation.outputAmount);
|
|
315
|
+
// If there's a sponsor, sender only pays for outputs
|
|
316
|
+
// Otherwise, sender pays for outputs + fee
|
|
317
|
+
const senderAmount = explanation.sponsor ? outputAmount.toFixed() : outputAmount.plus(fee).toFixed();
|
|
318
|
+
const inputs = [
|
|
319
|
+
{
|
|
320
|
+
address: senderAddress,
|
|
321
|
+
amount: senderAmount,
|
|
322
|
+
},
|
|
323
|
+
];
|
|
324
|
+
// Add sponsor input if present
|
|
325
|
+
if (explanation.sponsor) {
|
|
326
|
+
inputs.push({
|
|
327
|
+
address: explanation.sponsor,
|
|
328
|
+
amount: fee.toFixed(),
|
|
329
|
+
});
|
|
330
|
+
}
|
|
331
|
+
return inputs;
|
|
332
|
+
}
|
|
333
|
+
/**
|
|
334
|
+
* Builds the outputs array for a parsed transaction.
|
|
335
|
+
* @param explanation - The transaction explanation
|
|
336
|
+
* @returns Array of transaction outputs
|
|
337
|
+
*/
|
|
338
|
+
buildTransactionOutputs(explanation) {
|
|
339
|
+
return explanation.outputs.map((output) => ({
|
|
340
|
+
address: output.address,
|
|
341
|
+
amount: new bignumber_js_1.default(output.amount).toFixed(),
|
|
342
|
+
}));
|
|
343
|
+
}
|
|
344
|
+
/**
|
|
345
|
+
* Creates a transaction builder factory instance.
|
|
346
|
+
* @returns TransactionBuilderFactory for this coin
|
|
347
|
+
*/
|
|
240
348
|
getTxBuilderFactory() {
|
|
241
349
|
return new lib_1.TransactionBuilderFactory(statics_1.coins.get(this.getChain()));
|
|
242
350
|
}
|
|
351
|
+
/**
|
|
352
|
+
* Rebuilds a transaction from its hex representation.
|
|
353
|
+
* @param txHex - The transaction hex to rebuild
|
|
354
|
+
* @returns The rebuilt transaction
|
|
355
|
+
* @throws Error if transaction cannot be rebuilt
|
|
356
|
+
*/
|
|
243
357
|
async rebuildTransaction(txHex) {
|
|
244
358
|
const txBuilderFactory = this.getTxBuilderFactory();
|
|
245
359
|
try {
|
|
@@ -247,9 +361,9 @@ class Iota extends sdk_core_1.BaseCoin {
|
|
|
247
361
|
return (await txBuilder.build());
|
|
248
362
|
}
|
|
249
363
|
catch (err) {
|
|
250
|
-
throw new Error(`Failed to rebuild transaction ${err.toString()}`);
|
|
364
|
+
throw new Error(`Failed to rebuild transaction: ${err.toString()}`);
|
|
251
365
|
}
|
|
252
366
|
}
|
|
253
367
|
}
|
|
254
368
|
exports.Iota = Iota;
|
|
255
|
-
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"iota.js","sourceRoot":"","sources":["../../src/iota.ts"],"names":[],"mappings":"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","sourcesContent":["import {\n  AuditDecryptedKeyParams,\n  BaseCoin,\n  BitGoBase,\n  KeyPair,\n  ParsedTransaction,\n  SignTransactionOptions,\n  SignedTransaction,\n  VerifyTransactionOptions,\n  MultisigType,\n  multisigTypes,\n  MPCAlgorithm,\n  TssVerifyAddressOptions,\n  MPCType,\n  PopulatedIntent,\n  PrebuildTransactionWithIntentOptions,\n  TransactionRecipient,\n  verifyEddsaTssWalletAddress,\n} from '@bitgo-beta/sdk-core';\nimport { BaseCoin as StaticsBaseCoin, CoinFamily, coins } from '@bitgo-beta/statics';\nimport utils from './lib/utils';\nimport { KeyPair as IotaKeyPair, Transaction, TransactionBuilderFactory } from './lib';\nimport { auditEddsaPrivateKey } from '@bitgo-beta/sdk-lib-mpc';\nimport BigNumber from 'bignumber.js';\nimport * as _ from 'lodash';\nimport {\n  ExplainTransactionOptions,\n  IotaParseTransactionOptions,\n  TransactionExplanation,\n  TransferTxData,\n} from './lib/iface';\nimport { TransferTransaction } from './lib/transferTransaction';\n\nexport class Iota extends BaseCoin {\n  protected readonly _staticsCoin: Readonly<StaticsBaseCoin>;\n\n  protected constructor(bitgo: BitGoBase, staticsCoin?: Readonly<StaticsBaseCoin>) {\n    super(bitgo);\n\n    if (!staticsCoin) {\n      throw new Error('missing required constructor parameter staticsCoin');\n    }\n\n    this._staticsCoin = staticsCoin;\n  }\n\n  static createInstance(bitgo: BitGoBase, staticsCoin?: Readonly<StaticsBaseCoin>): BaseCoin {\n    return new Iota(bitgo, staticsCoin);\n  }\n\n  getBaseFactor(): string | number {\n    return Math.pow(10, this._staticsCoin.decimalPlaces);\n  }\n\n  getChain() {\n    return this._staticsCoin.name;\n  }\n\n  getFamily(): CoinFamily {\n    return this._staticsCoin.family;\n  }\n\n  getFullName() {\n    return this._staticsCoin.fullName;\n  }\n\n  /** @inheritDoc */\n  supportsTss(): boolean {\n    return true;\n  }\n\n  /** inherited doc */\n  getDefaultMultisigType(): MultisigType {\n    return multisigTypes.tss;\n  }\n\n  getMPCAlgorithm(): MPCAlgorithm {\n    return MPCType.EDDSA;\n  }\n\n  /**\n   * Check if an address is valid\n   * @param address the address to be validated\n   * @returns true if the address is valid\n   */\n  isValidAddress(address: string): boolean {\n    // IOTA addresses are 64-character hex strings\n    return utils.isValidAddress(address);\n  }\n\n  /**\n   * @inheritDoc\n   */\n  async explainTransaction(params: ExplainTransactionOptions): Promise<TransactionExplanation> {\n    const rawTx = params.txHex;\n    if (!rawTx) {\n      throw new Error('missing required tx prebuild property txHex');\n    }\n    const transaction = await this.rebuildTransaction(rawTx);\n    if (!transaction) {\n      throw new Error('failed to explain transaction');\n    }\n    return transaction.explainTransaction();\n  }\n\n  /**\n   * Verifies that a transaction prebuild complies with the original intention\n   * @param params\n   */\n  async verifyTransaction(params: VerifyTransactionOptions): Promise<boolean> {\n    const { txPrebuild: txPrebuild, txParams: txParams } = params;\n    const rawTx = txPrebuild.txHex;\n    if (!rawTx) {\n      throw new Error('missing required tx prebuild property txHex');\n    }\n    const transaction = await this.rebuildTransaction(rawTx);\n    if (!transaction) {\n      throw new Error('failed to verify transaction');\n    }\n    if (txParams.recipients !== undefined) {\n      if (!(transaction instanceof TransferTransaction)) {\n        throw new Error('Tx not a transfer transaction');\n      }\n      const txData = transaction.toJson() as TransferTxData;\n\n      if (!txData.recipients) {\n        throw new Error('Tx recipients does not match with expected txParams recipients');\n      }\n\n      const normalizeRecipient = (recipient: TransactionRecipient) =>\n        _.pick(recipient, ['address', 'amount', 'tokenName']);\n      const txDataRecipients = txData.recipients.map(normalizeRecipient);\n      const txParamsRecipients = txParams.recipients.map(normalizeRecipient);\n\n      const allRecipientsMatch = txParamsRecipients.every((expectedRecipient) =>\n        txDataRecipients.some((actualRecipient) => _.isEqual(expectedRecipient, actualRecipient))\n      );\n\n      if (!allRecipientsMatch) {\n        throw new Error('Tx recipients does not match with expected txParams recipients');\n      }\n    }\n    return true;\n  }\n\n  /**\n   * Check if an address belongs to a wallet\n   * @param params\n   */\n  async isWalletAddress(params: TssVerifyAddressOptions): Promise<boolean> {\n    return verifyEddsaTssWalletAddress(\n      params,\n      (address) => this.isValidAddress(address),\n      (publicKey) => utils.getAddressFromPublicKey(publicKey)\n    );\n  }\n\n  /**\n   * Parse a transaction\n   * @param params\n   */\n  async parseTransaction(params: IotaParseTransactionOptions): Promise<ParsedTransaction> {\n    const transactionExplanation = await this.explainTransaction({ txHex: params.txHex });\n\n    if (!transactionExplanation) {\n      throw new Error('Invalid transaction');\n    }\n\n    let fee = new BigNumber(0);\n\n    if (transactionExplanation.outputs.length <= 0) {\n      return {\n        inputs: [],\n        outputs: [],\n        fee,\n      };\n    }\n\n    const senderAddress = transactionExplanation.outputs[0].address;\n    if (transactionExplanation.fee.fee !== '') {\n      fee = new BigNumber(transactionExplanation.fee.fee);\n    }\n\n    const outputAmount = transactionExplanation.sponsor\n      ? new BigNumber(transactionExplanation.outputAmount).toFixed()\n      : new BigNumber(transactionExplanation.outputAmount).plus(fee).toFixed(); // assume 1 sender, who is also the fee payer\n\n    const inputs = [\n      {\n        address: senderAddress,\n        amount: outputAmount,\n      },\n    ];\n    if (transactionExplanation.sponsor) {\n      inputs.push({\n        address: transactionExplanation.sponsor,\n        amount: fee.toFixed(),\n      });\n    }\n\n    const outputs: {\n      address: string;\n      amount: string;\n    }[] = transactionExplanation.outputs.map((output) => {\n      return {\n        address: output.address,\n        amount: new BigNumber(output.amount).toFixed(),\n      };\n    });\n\n    return {\n      inputs,\n      outputs,\n      fee,\n    };\n  }\n\n  /**\n   * Generate a key pair\n   * @param seed Optional seed to generate key pair from\n   */\n  generateKeyPair(seed?: Buffer): KeyPair {\n    const keyPair = seed ? new IotaKeyPair({ seed }) : new IotaKeyPair();\n    const keys = keyPair.getKeys();\n    if (!keys.prv) {\n      throw new Error('Missing prv in key generation.');\n    }\n    return {\n      pub: keys.pub,\n      prv: keys.prv,\n    };\n  }\n\n  /**\n   * Check if a public key is valid\n   * @param pub Public key to check\n   */\n  isValidPub(pub: string): boolean {\n    return utils.isValidPublicKey(pub);\n  }\n\n  /**\n   * Sign a transaction\n   * @param params\n   */\n  async signTransaction(params: SignTransactionOptions): Promise<SignedTransaction> {\n    throw new Error('Method not implemented.');\n  }\n\n  /**\n   * Audit a decrypted private key to ensure it's valid\n   * @param params\n   */\n  auditDecryptedKey({ multiSigType, prv, publicKey }: AuditDecryptedKeyParams): void {\n    if (multiSigType !== multisigTypes.tss) {\n      throw new Error('Unsupported multiSigType');\n    }\n    auditEddsaPrivateKey(prv, publicKey ?? '');\n  }\n\n  /** @inheritDoc */\n  async getSignablePayload(serializedTx: string): Promise<Buffer> {\n    const rebuiltTransaction = await this.rebuildTransaction(serializedTx);\n    return rebuiltTransaction.signablePayload;\n  }\n\n  /** inherited doc */\n  setCoinSpecificFieldsInIntent(intent: PopulatedIntent, params: PrebuildTransactionWithIntentOptions): void {\n    intent.unspents = params.unspents;\n  }\n\n  private getTxBuilderFactory(): TransactionBuilderFactory {\n    return new TransactionBuilderFactory(coins.get(this.getChain()));\n  }\n\n  private async rebuildTransaction(txHex: string): Promise<Transaction> {\n    const txBuilderFactory = this.getTxBuilderFactory();\n    try {\n      const txBuilder = txBuilderFactory.from(txHex);\n      return (await txBuilder.build()) as Transaction;\n    } catch (err) {\n      throw new Error(`Failed to rebuild transaction ${err.toString()}`);\n    }\n  }\n}\n"]}
|
|
369
|
+
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"iota.js","sourceRoot":"","sources":["../../src/iota.ts"],"names":[],"mappings":"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","sourcesContent":["import {\n  AuditDecryptedKeyParams,\n  BaseCoin,\n  BitGoBase,\n  KeyPair,\n  ParsedTransaction,\n  SignTransactionOptions,\n  SignedTransaction,\n  VerifyTransactionOptions,\n  MultisigType,\n  multisigTypes,\n  MPCAlgorithm,\n  TssVerifyAddressOptions,\n  MPCType,\n  PopulatedIntent,\n  PrebuildTransactionWithIntentOptions,\n  TransactionRecipient,\n  verifyEddsaTssWalletAddress,\n} from '@bitgo-beta/sdk-core';\nimport { BaseCoin as StaticsBaseCoin, CoinFamily, coins } from '@bitgo-beta/statics';\nimport utils from './lib/utils';\nimport { KeyPair as IotaKeyPair, Transaction, TransactionBuilderFactory } from './lib';\nimport { auditEddsaPrivateKey } from '@bitgo-beta/sdk-lib-mpc';\nimport BigNumber from 'bignumber.js';\nimport * as _ from 'lodash';\nimport {\n  ExplainTransactionOptions,\n  IotaParseTransactionOptions,\n  TransactionExplanation,\n  TransferTxData,\n} from './lib/iface';\nimport { TransferTransaction } from './lib/transferTransaction';\n\n/**\n * IOTA coin implementation.\n * Supports TSS (Threshold Signature Scheme) with EDDSA algorithm.\n */\nexport class Iota extends BaseCoin {\n  protected readonly _staticsCoin: Readonly<StaticsBaseCoin>;\n\n  protected constructor(bitgo: BitGoBase, staticsCoin?: Readonly<StaticsBaseCoin>) {\n    super(bitgo);\n\n    if (!staticsCoin) {\n      throw new Error('missing required constructor parameter staticsCoin');\n    }\n\n    this._staticsCoin = staticsCoin;\n  }\n\n  /**\n   * Factory method to create an IOTA coin instance.\n   */\n  static createInstance(bitgo: BitGoBase, staticsCoin?: Readonly<StaticsBaseCoin>): BaseCoin {\n    return new Iota(bitgo, staticsCoin);\n  }\n\n  // ========================================\n  // Coin Configuration Methods\n  // ========================================\n\n  getBaseFactor(): string | number {\n    return Math.pow(10, this._staticsCoin.decimalPlaces);\n  }\n\n  getChain(): string {\n    return this._staticsCoin.name;\n  }\n\n  getFamily(): CoinFamily {\n    return this._staticsCoin.family;\n  }\n\n  getFullName(): string {\n    return this._staticsCoin.fullName;\n  }\n\n  // ========================================\n  // Multi-Signature and TSS Support\n  // ========================================\n\n  supportsTss(): boolean {\n    return true;\n  }\n\n  getDefaultMultisigType(): MultisigType {\n    return multisigTypes.tss;\n  }\n\n  getMPCAlgorithm(): MPCAlgorithm {\n    return MPCType.EDDSA;\n  }\n\n  // ========================================\n  // Address and Public Key Validation\n  // ========================================\n\n  /**\n   * Validates an IOTA address.\n   * @param address - The address to validate (64-character hex string)\n   * @returns true if the address is valid\n   */\n  isValidAddress(address: string): boolean {\n    return utils.isValidAddress(address);\n  }\n\n  /**\n   * Validates a public key.\n   * @param pub - The public key to validate\n   * @returns true if the public key is valid\n   */\n  isValidPub(pub: string): boolean {\n    return utils.isValidPublicKey(pub);\n  }\n\n  /**\n   * Verifies if an address belongs to a TSS wallet.\n   * @param params - Verification parameters including wallet address and user/backup public keys\n   * @returns true if the address belongs to the wallet\n   */\n  async isWalletAddress(params: TssVerifyAddressOptions): Promise<boolean> {\n    return verifyEddsaTssWalletAddress(\n      params,\n      (address) => this.isValidAddress(address),\n      (publicKey) => utils.getAddressFromPublicKey(publicKey)\n    );\n  }\n\n  // ========================================\n  // Transaction Explanation and Verification\n  // ========================================\n\n  /**\n   * Explains a transaction by parsing its hex representation.\n   * @param params - Parameters containing the transaction hex\n   * @returns Detailed explanation of the transaction\n   * @throws Error if txHex is missing or transaction cannot be explained\n   */\n  async explainTransaction(params: ExplainTransactionOptions): Promise<TransactionExplanation> {\n    const rawTx = this.validateAndExtractTxHex(params.txHex, 'explain');\n    const transaction = await this.rebuildTransaction(rawTx);\n    return transaction.explainTransaction();\n  }\n\n  /**\n   * Verifies that a transaction prebuild matches the original transaction parameters.\n   * Ensures recipients and amounts align with the intended transaction.\n   *\n   * @param params - Verification parameters containing prebuild and original params\n   * @returns true if verification succeeds\n   * @throws Error if verification fails\n   */\n  async verifyTransaction(params: VerifyTransactionOptions): Promise<boolean> {\n    const { txPrebuild, txParams } = params;\n    const rawTx = this.validateAndExtractTxHex(txPrebuild.txHex, 'verify');\n\n    const transaction = await this.rebuildTransaction(rawTx);\n    this.validateTransactionType(transaction);\n\n    if (txParams.recipients !== undefined) {\n      this.verifyTransactionRecipients(transaction as TransferTransaction, txParams.recipients);\n    }\n\n    return true;\n  }\n\n  /**\n   * Parses a transaction and extracts inputs, outputs, and fees.\n   * @param params - Parameters containing the transaction hex\n   * @returns Parsed transaction with inputs, outputs, and fee information\n   */\n  async parseTransaction(params: IotaParseTransactionOptions): Promise<ParsedTransaction> {\n    const transactionExplanation = await this.explainTransaction({ txHex: params.txHex });\n\n    if (!transactionExplanation || transactionExplanation.outputs.length === 0) {\n      return this.createEmptyParsedTransaction();\n    }\n\n    const fee = this.calculateTransactionFee(transactionExplanation);\n    const inputs = this.buildTransactionInputs(transactionExplanation, fee);\n    const outputs = this.buildTransactionOutputs(transactionExplanation);\n\n    return { inputs, outputs, fee };\n  }\n\n  // ========================================\n  // Key Generation and Signing\n  // ========================================\n\n  /**\n   * Generates a key pair for IOTA transactions.\n   * @param seed - Optional seed to generate deterministic key pair\n   * @returns Key pair with public and private keys\n   * @throws Error if private key generation fails\n   */\n  generateKeyPair(seed?: Buffer): KeyPair {\n    const keyPair = seed ? new IotaKeyPair({ seed }) : new IotaKeyPair();\n    const keys = keyPair.getKeys();\n\n    if (!keys.prv) {\n      throw new Error('Missing prv in key generation.');\n    }\n\n    return {\n      pub: keys.pub,\n      prv: keys.prv,\n    };\n  }\n\n  /**\n   * Signs a transaction (not implemented for IOTA).\n   * IOTA transactions are signed externally using TSS.\n   */\n  async signTransaction(params: SignTransactionOptions): Promise<SignedTransaction> {\n    throw new Error('Method not implemented.');\n  }\n\n  /**\n   * Audits a decrypted private key to ensure it's valid for the given public key.\n   * @param params - Parameters containing multiSigType, private key, and public key\n   * @throws Error if multiSigType is not TSS or if key validation fails\n   */\n  auditDecryptedKey({ multiSigType, prv, publicKey }: AuditDecryptedKeyParams): void {\n    if (multiSigType !== multisigTypes.tss) {\n      throw new Error('Unsupported multiSigType');\n    }\n    auditEddsaPrivateKey(prv, publicKey ?? '');\n  }\n\n  /**\n   * Extracts the signable payload from a serialized transaction.\n   * @param serializedTx - The serialized transaction hex\n   * @returns Buffer containing the signable payload\n   */\n  async getSignablePayload(serializedTx: string): Promise<Buffer> {\n    const rebuiltTransaction = await this.rebuildTransaction(serializedTx);\n    return rebuiltTransaction.signablePayload;\n  }\n\n  /**\n   * Sets coin-specific fields in the transaction intent.\n   * @param intent - The populated intent object to modify\n   * @param params - Parameters containing unspents data\n   */\n  setCoinSpecificFieldsInIntent(intent: PopulatedIntent, params: PrebuildTransactionWithIntentOptions): void {\n    intent.unspents = params.unspents;\n  }\n\n  // ========================================\n  // Private Helper Methods\n  // ========================================\n\n  /**\n   * Validates and extracts transaction hex from parameters.\n   * @param txHex - The transaction hex to validate\n   * @param operation - The operation being performed (for error messages)\n   * @returns The validated transaction hex\n   * @throws Error if txHex is missing\n   */\n  private validateAndExtractTxHex(txHex: string | undefined, operation: string): string {\n    if (!txHex) {\n      throw new Error(`missing required tx prebuild property txHex for ${operation} operation`);\n    }\n    return txHex;\n  }\n\n  /**\n   * Validates that the transaction is a TransferTransaction.\n   * @param transaction - The transaction to validate\n   * @throws Error if transaction is not a TransferTransaction\n   */\n  private validateTransactionType(transaction: Transaction): void {\n    if (!(transaction instanceof TransferTransaction)) {\n      throw new Error('Tx not a transfer transaction');\n    }\n  }\n\n  /**\n   * Verifies that transaction recipients match the expected recipients.\n   * @param transaction - The transfer transaction to verify\n   * @param expectedRecipients - The expected recipients from transaction params\n   * @throws Error if recipients don't match\n   */\n  private verifyTransactionRecipients(\n    transaction: TransferTransaction,\n    expectedRecipients: TransactionRecipient[]\n  ): void {\n    const txData = transaction.toJson() as TransferTxData;\n\n    if (!txData.recipients) {\n      throw new Error('Tx recipients does not match with expected txParams recipients');\n    }\n\n    const actualRecipients = this.normalizeRecipients(txData.recipients);\n    const expected = this.normalizeRecipients(expectedRecipients);\n\n    if (!this.recipientsMatch(expected, actualRecipients)) {\n      throw new Error('Tx recipients does not match with expected txParams recipients');\n    }\n  }\n\n  /**\n   * Normalizes recipients by extracting only relevant fields.\n   * @param recipients - Recipients to normalize\n   * @returns Normalized recipients with address, amount, and tokenName only\n   */\n  private normalizeRecipients(recipients: TransactionRecipient[]): TransactionRecipient[] {\n    return recipients.map((recipient) => _.pick(recipient, ['address', 'amount', 'tokenName']));\n  }\n\n  /**\n   * Checks if expected recipients match actual recipients.\n   * @param expected - Expected recipients\n   * @param actual - Actual recipients from transaction\n   * @returns true if all expected recipients are found in actual recipients\n   */\n  private recipientsMatch(expected: TransactionRecipient[], actual: TransactionRecipient[]): boolean {\n    return expected.every((expectedRecipient) =>\n      actual.some((actualRecipient) => _.isEqual(expectedRecipient, actualRecipient))\n    );\n  }\n\n  /**\n   * Creates an empty parsed transaction result.\n   * Used when transaction has no outputs.\n   */\n  private createEmptyParsedTransaction(): ParsedTransaction {\n    return {\n      inputs: [],\n      outputs: [],\n      fee: new BigNumber(0),\n    };\n  }\n\n  /**\n   * Calculates the transaction fee from the explanation.\n   * @param explanation - The transaction explanation\n   * @returns The fee as a BigNumber\n   */\n  private calculateTransactionFee(explanation: TransactionExplanation): BigNumber {\n    if (explanation.fee.fee === '') {\n      return new BigNumber(0);\n    }\n    return new BigNumber(explanation.fee.fee);\n  }\n\n  /**\n   * Builds the inputs array for a parsed transaction.\n   * Includes sender input and optionally sponsor input if present.\n   *\n   * @param explanation - The transaction explanation\n   * @param fee - The calculated transaction fee\n   * @returns Array of transaction inputs\n   */\n  private buildTransactionInputs(\n    explanation: TransactionExplanation,\n    fee: BigNumber\n  ): Array<{\n    address: string;\n    amount: string;\n  }> {\n    const senderAddress = explanation.outputs[0].address;\n    const outputAmount = new BigNumber(explanation.outputAmount);\n\n    // If there's a sponsor, sender only pays for outputs\n    // Otherwise, sender pays for outputs + fee\n    const senderAmount = explanation.sponsor ? outputAmount.toFixed() : outputAmount.plus(fee).toFixed();\n\n    const inputs = [\n      {\n        address: senderAddress,\n        amount: senderAmount,\n      },\n    ];\n\n    // Add sponsor input if present\n    if (explanation.sponsor) {\n      inputs.push({\n        address: explanation.sponsor,\n        amount: fee.toFixed(),\n      });\n    }\n\n    return inputs;\n  }\n\n  /**\n   * Builds the outputs array for a parsed transaction.\n   * @param explanation - The transaction explanation\n   * @returns Array of transaction outputs\n   */\n  private buildTransactionOutputs(explanation: TransactionExplanation): Array<{\n    address: string;\n    amount: string;\n  }> {\n    return explanation.outputs.map((output) => ({\n      address: output.address,\n      amount: new BigNumber(output.amount).toFixed(),\n    }));\n  }\n\n  /**\n   * Creates a transaction builder factory instance.\n   * @returns TransactionBuilderFactory for this coin\n   */\n  private getTxBuilderFactory(): TransactionBuilderFactory {\n    return new TransactionBuilderFactory(coins.get(this.getChain()));\n  }\n\n  /**\n   * Rebuilds a transaction from its hex representation.\n   * @param txHex - The transaction hex to rebuild\n   * @returns The rebuilt transaction\n   * @throws Error if transaction cannot be rebuilt\n   */\n  private async rebuildTransaction(txHex: string): Promise<Transaction> {\n    const txBuilderFactory = this.getTxBuilderFactory();\n    try {\n      const txBuilder = txBuilderFactory.from(txHex);\n      return (await txBuilder.build()) as Transaction;\n    } catch (err) {\n      throw new Error(`Failed to rebuild transaction: ${err.toString()}`);\n    }\n  }\n}\n"]}
|
|
@@ -1,12 +1,61 @@
|
|
|
1
|
+
/**
|
|
2
|
+
* Length of IOTA addresses in characters (excluding 0x prefix).
|
|
3
|
+
* IOTA uses 64-character hexadecimal addresses.
|
|
4
|
+
*/
|
|
1
5
|
export declare const IOTA_ADDRESS_LENGTH = 64;
|
|
6
|
+
/**
|
|
7
|
+
* Length of transaction digest in bytes.
|
|
8
|
+
* Used for transaction IDs and hashes.
|
|
9
|
+
*/
|
|
2
10
|
export declare const IOTA_TRANSACTION_DIGEST_LENGTH = 32;
|
|
11
|
+
/**
|
|
12
|
+
* Length of block digest in bytes.
|
|
13
|
+
* Used for block IDs and references.
|
|
14
|
+
*/
|
|
3
15
|
export declare const IOTA_BLOCK_DIGEST_LENGTH = 32;
|
|
16
|
+
/**
|
|
17
|
+
* Length of Ed25519 signatures in bytes.
|
|
18
|
+
* IOTA uses Ed25519 for transaction signing.
|
|
19
|
+
*/
|
|
4
20
|
export declare const IOTA_SIGNATURE_LENGTH = 64;
|
|
21
|
+
/**
|
|
22
|
+
* Length of Ed25519 public keys in bytes.
|
|
23
|
+
* Standard Ed25519 key size.
|
|
24
|
+
*/
|
|
5
25
|
export declare const IOTA_KEY_BYTES_LENGTH = 32;
|
|
26
|
+
/**
|
|
27
|
+
* Maximum number of input objects allowed in a single transaction.
|
|
28
|
+
* This limit ensures transactions can be processed efficiently by the network.
|
|
29
|
+
*/
|
|
6
30
|
export declare const MAX_INPUT_OBJECTS = 2048;
|
|
31
|
+
/**
|
|
32
|
+
* Maximum number of gas payment objects allowed per transaction.
|
|
33
|
+
* When exceeded, objects must be merged before the transaction can be built.
|
|
34
|
+
* This prevents transaction size from becoming too large.
|
|
35
|
+
*/
|
|
7
36
|
export declare const MAX_GAS_PAYMENT_OBJECTS = 256;
|
|
37
|
+
/**
|
|
38
|
+
* Maximum number of recipients in a transfer transaction.
|
|
39
|
+
* Limits the number of outputs to keep transaction size manageable.
|
|
40
|
+
*/
|
|
41
|
+
export declare const MAX_RECIPIENTS = 256;
|
|
42
|
+
/**
|
|
43
|
+
* Maximum gas budget allowed for a transaction.
|
|
44
|
+
* Used for dry-run simulations to estimate gas costs.
|
|
45
|
+
* Set to a very high value (50 billion) to ensure simulation completes.
|
|
46
|
+
*/
|
|
8
47
|
export declare const MAX_GAS_BUDGET = 50000000000;
|
|
48
|
+
/**
|
|
49
|
+
* Maximum gas price for simulated transactions.
|
|
50
|
+
* Used when building dry-run transactions for gas estimation.
|
|
51
|
+
*/
|
|
9
52
|
export declare const MAX_GAS_PRICE = 100000;
|
|
10
|
-
|
|
53
|
+
/**
|
|
54
|
+
* Valid command types for transfer transactions.
|
|
55
|
+
* Transfer transactions can only contain these three command types:
|
|
56
|
+
* - SplitCoins: Split a coin into multiple coins with specified amounts
|
|
57
|
+
* - MergeCoins: Merge multiple coins into a single coin
|
|
58
|
+
* - TransferObjects: Transfer coins/objects to recipients
|
|
59
|
+
*/
|
|
11
60
|
export declare const TRANSFER_TRANSACTION_COMMANDS: string[];
|
|
12
61
|
//# sourceMappingURL=constants.d.ts.map
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"constants.d.ts","sourceRoot":"","sources":["../../../src/lib/constants.ts"],"names":[],"mappings":"
|
|
1
|
+
{"version":3,"file":"constants.d.ts","sourceRoot":"","sources":["../../../src/lib/constants.ts"],"names":[],"mappings":"AAIA;;;GAGG;AACH,eAAO,MAAM,mBAAmB,KAAK,CAAC;AAEtC;;;GAGG;AACH,eAAO,MAAM,8BAA8B,KAAK,CAAC;AAEjD;;;GAGG;AACH,eAAO,MAAM,wBAAwB,KAAK,CAAC;AAM3C;;;GAGG;AACH,eAAO,MAAM,qBAAqB,KAAK,CAAC;AAExC;;;GAGG;AACH,eAAO,MAAM,qBAAqB,KAAK,CAAC;AAMxC;;;GAGG;AACH,eAAO,MAAM,iBAAiB,OAAO,CAAC;AAEtC;;;;GAIG;AACH,eAAO,MAAM,uBAAuB,MAAM,CAAC;AAE3C;;;GAGG;AACH,eAAO,MAAM,cAAc,MAAM,CAAC;AAMlC;;;;GAIG;AACH,eAAO,MAAM,cAAc,cAAc,CAAC;AAE1C;;;GAGG;AACH,eAAO,MAAM,aAAa,SAAS,CAAC;AAMpC;;;;;;GAMG;AACH,eAAO,MAAM,6BAA6B,UAAkD,CAAC"}
|