@bitgo-beta/sdk-coin-iota 1.0.1-beta.44 → 1.0.1-beta.441
This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
- package/README.md +1 -1
- package/dist/src/iota.d.ts +134 -23
- package/dist/src/iota.d.ts.map +1 -1
- package/dist/src/iota.js +286 -46
- package/dist/src/lib/constants.d.ts +59 -6
- package/dist/src/lib/constants.d.ts.map +1 -1
- package/dist/src/lib/constants.js +76 -8
- package/dist/src/lib/iface.d.ts +174 -2
- package/dist/src/lib/iface.d.ts.map +1 -1
- package/dist/src/lib/iface.js +1 -1
- package/dist/src/lib/index.d.ts +1 -0
- package/dist/src/lib/index.d.ts.map +1 -1
- package/dist/src/lib/index.js +4 -2
- 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 +175 -5
- package/dist/src/lib/transaction.d.ts.map +1 -1
- package/dist/src/lib/transaction.js +390 -6
- package/dist/src/lib/transactionBuilder.d.ts +109 -9
- package/dist/src/lib/transactionBuilder.d.ts.map +1 -1
- package/dist/src/lib/transactionBuilder.js +200 -14
- package/dist/src/lib/transactionBuilderFactory.d.ts +98 -2
- package/dist/src/lib/transactionBuilderFactory.d.ts.map +1 -1
- package/dist/src/lib/transactionBuilderFactory.js +132 -5
- package/dist/src/lib/transferBuilder.d.ts +52 -2
- package/dist/src/lib/transferBuilder.d.ts.map +1 -1
- package/dist/src/lib/transferBuilder.js +86 -3
- package/dist/src/lib/transferTransaction.d.ts +124 -0
- package/dist/src/lib/transferTransaction.d.ts.map +1 -0
- package/dist/src/lib/transferTransaction.js +341 -0
- package/dist/src/lib/utils.d.ts +108 -7
- package/dist/src/lib/utils.d.ts.map +1 -1
- package/dist/src/lib/utils.js +146 -11
- package/dist/test/resources/iota.d.ts +35 -0
- package/dist/test/resources/iota.d.ts.map +1 -0
- package/dist/test/resources/iota.js +93 -0
- 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/index.d.ts +2 -0
- package/dist/test/unit/index.d.ts.map +1 -0
- package/dist/test/unit/index.js +16 -0
- package/dist/test/unit/iota.d.ts +2 -0
- package/dist/test/unit/iota.d.ts.map +1 -0
- package/dist/test/unit/iota.js +501 -0
- package/dist/test/unit/keyPair.d.ts +2 -0
- package/dist/test/unit/keyPair.d.ts.map +1 -0
- package/dist/test/unit/keyPair.js +108 -0
- package/dist/test/unit/transactionBuilder/transactionBuilder.d.ts +2 -0
- package/dist/test/unit/transactionBuilder/transactionBuilder.d.ts.map +1 -0
- package/dist/test/unit/transactionBuilder/transactionBuilder.js +188 -0
- package/dist/test/unit/transactionBuilder/transactionBuilderFactory.d.ts +2 -0
- package/dist/test/unit/transactionBuilder/transactionBuilderFactory.d.ts.map +1 -0
- package/dist/test/unit/transactionBuilder/transactionBuilderFactory.js +178 -0
- package/dist/test/unit/transactionBuilder/transferBuilder.d.ts +2 -0
- package/dist/test/unit/transactionBuilder/transferBuilder.d.ts.map +1 -0
- package/dist/test/unit/transactionBuilder/transferBuilder.js +438 -0
- package/dist/test/unit/transferTransaction.d.ts +2 -0
- package/dist/test/unit/transferTransaction.d.ts.map +1 -0
- package/dist/test/unit/transferTransaction.js +218 -0
- package/dist/test/unit/utils.d.ts +2 -0
- package/dist/test/unit/utils.d.ts.map +1 -0
- package/dist/test/unit/utils.js +252 -0
- package/dist/tsconfig.tsbuildinfo +1 -0
- package/package.json +17 -11
- package/.eslintignore +0 -5
- package/.mocharc.yml +0 -8
- package/CHANGELOG.md +0 -28
package/dist/src/iota.js
CHANGED
|
@@ -1,13 +1,54 @@
|
|
|
1
1
|
"use strict";
|
|
2
|
+
var __createBinding = (this && this.__createBinding) || (Object.create ? (function(o, m, k, k2) {
|
|
3
|
+
if (k2 === undefined) k2 = k;
|
|
4
|
+
var desc = Object.getOwnPropertyDescriptor(m, k);
|
|
5
|
+
if (!desc || ("get" in desc ? !m.__esModule : desc.writable || desc.configurable)) {
|
|
6
|
+
desc = { enumerable: true, get: function() { return m[k]; } };
|
|
7
|
+
}
|
|
8
|
+
Object.defineProperty(o, k2, desc);
|
|
9
|
+
}) : (function(o, m, k, k2) {
|
|
10
|
+
if (k2 === undefined) k2 = k;
|
|
11
|
+
o[k2] = m[k];
|
|
12
|
+
}));
|
|
13
|
+
var __setModuleDefault = (this && this.__setModuleDefault) || (Object.create ? (function(o, v) {
|
|
14
|
+
Object.defineProperty(o, "default", { enumerable: true, value: v });
|
|
15
|
+
}) : function(o, v) {
|
|
16
|
+
o["default"] = v;
|
|
17
|
+
});
|
|
18
|
+
var __importStar = (this && this.__importStar) || (function () {
|
|
19
|
+
var ownKeys = function(o) {
|
|
20
|
+
ownKeys = Object.getOwnPropertyNames || function (o) {
|
|
21
|
+
var ar = [];
|
|
22
|
+
for (var k in o) if (Object.prototype.hasOwnProperty.call(o, k)) ar[ar.length] = k;
|
|
23
|
+
return ar;
|
|
24
|
+
};
|
|
25
|
+
return ownKeys(o);
|
|
26
|
+
};
|
|
27
|
+
return function (mod) {
|
|
28
|
+
if (mod && mod.__esModule) return mod;
|
|
29
|
+
var result = {};
|
|
30
|
+
if (mod != null) for (var k = ownKeys(mod), i = 0; i < k.length; i++) if (k[i] !== "default") __createBinding(result, mod, k[i]);
|
|
31
|
+
__setModuleDefault(result, mod);
|
|
32
|
+
return result;
|
|
33
|
+
};
|
|
34
|
+
})();
|
|
2
35
|
var __importDefault = (this && this.__importDefault) || function (mod) {
|
|
3
36
|
return (mod && mod.__esModule) ? mod : { "default": mod };
|
|
4
37
|
};
|
|
5
38
|
Object.defineProperty(exports, "__esModule", { value: true });
|
|
6
39
|
exports.Iota = void 0;
|
|
7
40
|
const sdk_core_1 = require("@bitgo-beta/sdk-core");
|
|
41
|
+
const statics_1 = require("@bitgo-beta/statics");
|
|
8
42
|
const utils_1 = __importDefault(require("./lib/utils"));
|
|
9
43
|
const lib_1 = require("./lib");
|
|
10
44
|
const sdk_lib_mpc_1 = require("@bitgo-beta/sdk-lib-mpc");
|
|
45
|
+
const bignumber_js_1 = __importDefault(require("bignumber.js"));
|
|
46
|
+
const _ = __importStar(require("lodash"));
|
|
47
|
+
const transferTransaction_1 = require("./lib/transferTransaction");
|
|
48
|
+
/**
|
|
49
|
+
* IOTA coin implementation.
|
|
50
|
+
* Supports TSS (Threshold Signature Scheme) with EDDSA algorithm.
|
|
51
|
+
*/
|
|
11
52
|
class Iota extends sdk_core_1.BaseCoin {
|
|
12
53
|
constructor(bitgo, staticsCoin) {
|
|
13
54
|
super(bitgo);
|
|
@@ -16,9 +57,15 @@ class Iota extends sdk_core_1.BaseCoin {
|
|
|
16
57
|
}
|
|
17
58
|
this._staticsCoin = staticsCoin;
|
|
18
59
|
}
|
|
60
|
+
/**
|
|
61
|
+
* Factory method to create an IOTA coin instance.
|
|
62
|
+
*/
|
|
19
63
|
static createInstance(bitgo, staticsCoin) {
|
|
20
64
|
return new Iota(bitgo, staticsCoin);
|
|
21
65
|
}
|
|
66
|
+
// ========================================
|
|
67
|
+
// Coin Configuration Methods
|
|
68
|
+
// ========================================
|
|
22
69
|
getBaseFactor() {
|
|
23
70
|
return Math.pow(10, this._staticsCoin.decimalPlaces);
|
|
24
71
|
}
|
|
@@ -31,69 +78,100 @@ class Iota extends sdk_core_1.BaseCoin {
|
|
|
31
78
|
getFullName() {
|
|
32
79
|
return this._staticsCoin.fullName;
|
|
33
80
|
}
|
|
34
|
-
|
|
81
|
+
// ========================================
|
|
82
|
+
// Multi-Signature and TSS Support
|
|
83
|
+
// ========================================
|
|
35
84
|
supportsTss() {
|
|
36
85
|
return true;
|
|
37
86
|
}
|
|
38
|
-
/** inherited doc */
|
|
39
87
|
getDefaultMultisigType() {
|
|
40
88
|
return sdk_core_1.multisigTypes.tss;
|
|
41
89
|
}
|
|
42
90
|
getMPCAlgorithm() {
|
|
43
91
|
return sdk_core_1.MPCType.EDDSA;
|
|
44
92
|
}
|
|
93
|
+
// ========================================
|
|
94
|
+
// Address and Public Key Validation
|
|
95
|
+
// ========================================
|
|
45
96
|
/**
|
|
46
|
-
*
|
|
47
|
-
* @param address
|
|
97
|
+
* Validates an IOTA address.
|
|
98
|
+
* @param address - The address to validate (64-character hex string)
|
|
48
99
|
* @returns true if the address is valid
|
|
49
100
|
*/
|
|
50
101
|
isValidAddress(address) {
|
|
51
|
-
// IOTA addresses are 64-character hex strings
|
|
52
102
|
return utils_1.default.isValidAddress(address);
|
|
53
103
|
}
|
|
54
104
|
/**
|
|
55
|
-
*
|
|
56
|
-
* @param
|
|
105
|
+
* Validates a public key.
|
|
106
|
+
* @param pub - The public key to validate
|
|
107
|
+
* @returns true if the public key is valid
|
|
57
108
|
*/
|
|
58
|
-
|
|
59
|
-
|
|
60
|
-
return true;
|
|
109
|
+
isValidPub(pub) {
|
|
110
|
+
return utils_1.default.isValidPublicKey(pub);
|
|
61
111
|
}
|
|
62
112
|
/**
|
|
63
|
-
*
|
|
64
|
-
* @param params
|
|
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
|
|
65
116
|
*/
|
|
66
117
|
async isWalletAddress(params) {
|
|
67
|
-
|
|
68
|
-
|
|
69
|
-
|
|
70
|
-
|
|
71
|
-
|
|
72
|
-
|
|
73
|
-
|
|
74
|
-
|
|
75
|
-
|
|
76
|
-
|
|
77
|
-
|
|
78
|
-
|
|
79
|
-
|
|
80
|
-
|
|
81
|
-
|
|
82
|
-
|
|
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
|
|
128
|
+
*/
|
|
129
|
+
async explainTransaction(params) {
|
|
130
|
+
const rawTx = this.validateAndExtractTxHex(params.txHex, 'explain');
|
|
131
|
+
const transaction = await this.rebuildTransaction(rawTx);
|
|
132
|
+
return transaction.explainTransaction();
|
|
133
|
+
}
|
|
134
|
+
/**
|
|
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
|
|
141
|
+
*/
|
|
142
|
+
async verifyTransaction(params) {
|
|
143
|
+
const { txPrebuild, txParams } = params;
|
|
144
|
+
const rawTx = this.validateAndExtractTxHex(txPrebuild.txHex, 'verify');
|
|
145
|
+
const transaction = await this.rebuildTransaction(rawTx);
|
|
146
|
+
this.validateTransactionType(transaction);
|
|
147
|
+
if (txParams.recipients !== undefined) {
|
|
148
|
+
this.verifyTransactionRecipients(transaction, txParams.recipients);
|
|
83
149
|
}
|
|
84
150
|
return true;
|
|
85
151
|
}
|
|
86
152
|
/**
|
|
87
|
-
*
|
|
88
|
-
* @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
|
|
89
156
|
*/
|
|
90
157
|
async parseTransaction(params) {
|
|
91
|
-
|
|
92
|
-
|
|
158
|
+
const transactionExplanation = await this.explainTransaction({ txHex: params.txHex });
|
|
159
|
+
if (!transactionExplanation || transactionExplanation.outputs.length === 0) {
|
|
160
|
+
return this.createEmptyParsedTransaction();
|
|
161
|
+
}
|
|
162
|
+
const fee = this.calculateTransactionFee(transactionExplanation);
|
|
163
|
+
const inputs = this.buildTransactionInputs(transactionExplanation, fee);
|
|
164
|
+
const outputs = this.buildTransactionOutputs(transactionExplanation);
|
|
165
|
+
return { inputs, outputs, fee };
|
|
93
166
|
}
|
|
167
|
+
// ========================================
|
|
168
|
+
// Key Generation and Signing
|
|
169
|
+
// ========================================
|
|
94
170
|
/**
|
|
95
|
-
*
|
|
96
|
-
* @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
|
|
97
175
|
*/
|
|
98
176
|
generateKeyPair(seed) {
|
|
99
177
|
const keyPair = seed ? new lib_1.KeyPair({ seed }) : new lib_1.KeyPair();
|
|
@@ -107,22 +185,16 @@ class Iota extends sdk_core_1.BaseCoin {
|
|
|
107
185
|
};
|
|
108
186
|
}
|
|
109
187
|
/**
|
|
110
|
-
*
|
|
111
|
-
*
|
|
112
|
-
*/
|
|
113
|
-
isValidPub(pub) {
|
|
114
|
-
return utils_1.default.isValidPublicKey(pub);
|
|
115
|
-
}
|
|
116
|
-
/**
|
|
117
|
-
* Sign a transaction
|
|
118
|
-
* @param params
|
|
188
|
+
* Signs a transaction (not implemented for IOTA).
|
|
189
|
+
* IOTA transactions are signed externally using TSS.
|
|
119
190
|
*/
|
|
120
191
|
async signTransaction(params) {
|
|
121
192
|
throw new Error('Method not implemented.');
|
|
122
193
|
}
|
|
123
194
|
/**
|
|
124
|
-
*
|
|
125
|
-
* @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
|
|
126
198
|
*/
|
|
127
199
|
auditDecryptedKey({ multiSigType, prv, publicKey }) {
|
|
128
200
|
if (multiSigType !== sdk_core_1.multisigTypes.tss) {
|
|
@@ -130,6 +202,174 @@ class Iota extends sdk_core_1.BaseCoin {
|
|
|
130
202
|
}
|
|
131
203
|
(0, sdk_lib_mpc_1.auditEddsaPrivateKey)(prv, publicKey ?? '');
|
|
132
204
|
}
|
|
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
|
+
*/
|
|
210
|
+
async getSignablePayload(serializedTx) {
|
|
211
|
+
const rebuiltTransaction = await this.rebuildTransaction(serializedTx);
|
|
212
|
+
return rebuiltTransaction.signablePayload;
|
|
213
|
+
}
|
|
214
|
+
/**
|
|
215
|
+
* @inheritDoc
|
|
216
|
+
*/
|
|
217
|
+
allowsAccountConsolidations() {
|
|
218
|
+
return true;
|
|
219
|
+
}
|
|
220
|
+
/**
|
|
221
|
+
* Sets coin-specific fields in the transaction intent.
|
|
222
|
+
* @param intent - The populated intent object to modify
|
|
223
|
+
* @param params - Parameters containing unspents data
|
|
224
|
+
*/
|
|
225
|
+
setCoinSpecificFieldsInIntent(intent, params) {
|
|
226
|
+
intent.unspents = params.unspents;
|
|
227
|
+
}
|
|
228
|
+
// ========================================
|
|
229
|
+
// Private Helper Methods
|
|
230
|
+
// ========================================
|
|
231
|
+
/**
|
|
232
|
+
* Validates and extracts transaction hex from parameters.
|
|
233
|
+
* @param txHex - The transaction hex to validate
|
|
234
|
+
* @param operation - The operation being performed (for error messages)
|
|
235
|
+
* @returns The validated transaction hex
|
|
236
|
+
* @throws Error if txHex is missing
|
|
237
|
+
*/
|
|
238
|
+
validateAndExtractTxHex(txHex, operation) {
|
|
239
|
+
if (!txHex) {
|
|
240
|
+
throw new Error(`missing required tx prebuild property txHex for ${operation} operation`);
|
|
241
|
+
}
|
|
242
|
+
return txHex;
|
|
243
|
+
}
|
|
244
|
+
/**
|
|
245
|
+
* Validates that the transaction is a TransferTransaction.
|
|
246
|
+
* @param transaction - The transaction to validate
|
|
247
|
+
* @throws Error if transaction is not a TransferTransaction
|
|
248
|
+
*/
|
|
249
|
+
validateTransactionType(transaction) {
|
|
250
|
+
if (!(transaction instanceof transferTransaction_1.TransferTransaction)) {
|
|
251
|
+
throw new Error('Tx not a transfer transaction');
|
|
252
|
+
}
|
|
253
|
+
}
|
|
254
|
+
/**
|
|
255
|
+
* Verifies that transaction recipients match the expected recipients.
|
|
256
|
+
* @param transaction - The transfer transaction to verify
|
|
257
|
+
* @param expectedRecipients - The expected recipients from transaction params
|
|
258
|
+
* @throws Error if recipients don't match
|
|
259
|
+
*/
|
|
260
|
+
verifyTransactionRecipients(transaction, expectedRecipients) {
|
|
261
|
+
const txData = transaction.toJson();
|
|
262
|
+
if (!txData.recipients) {
|
|
263
|
+
throw new Error('Tx recipients does not match with expected txParams recipients');
|
|
264
|
+
}
|
|
265
|
+
const actualRecipients = this.normalizeRecipients(txData.recipients);
|
|
266
|
+
const expected = this.normalizeRecipients(expectedRecipients);
|
|
267
|
+
if (!this.recipientsMatch(expected, actualRecipients)) {
|
|
268
|
+
throw new Error('Tx recipients does not match with expected txParams recipients');
|
|
269
|
+
}
|
|
270
|
+
}
|
|
271
|
+
/**
|
|
272
|
+
* Normalizes recipients by extracting only relevant fields.
|
|
273
|
+
* @param recipients - Recipients to normalize
|
|
274
|
+
* @returns Normalized recipients with address, amount, and tokenName only
|
|
275
|
+
*/
|
|
276
|
+
normalizeRecipients(recipients) {
|
|
277
|
+
return recipients.map((recipient) => _.pick(recipient, ['address', 'amount', 'tokenName']));
|
|
278
|
+
}
|
|
279
|
+
/**
|
|
280
|
+
* Checks if expected recipients match actual recipients.
|
|
281
|
+
* @param expected - Expected recipients
|
|
282
|
+
* @param actual - Actual recipients from transaction
|
|
283
|
+
* @returns true if all expected recipients are found in actual recipients
|
|
284
|
+
*/
|
|
285
|
+
recipientsMatch(expected, actual) {
|
|
286
|
+
return expected.every((expectedRecipient) => actual.some((actualRecipient) => _.isEqual(expectedRecipient, actualRecipient)));
|
|
287
|
+
}
|
|
288
|
+
/**
|
|
289
|
+
* Creates an empty parsed transaction result.
|
|
290
|
+
* Used when transaction has no outputs.
|
|
291
|
+
*/
|
|
292
|
+
createEmptyParsedTransaction() {
|
|
293
|
+
return {
|
|
294
|
+
inputs: [],
|
|
295
|
+
outputs: [],
|
|
296
|
+
fee: new bignumber_js_1.default(0),
|
|
297
|
+
};
|
|
298
|
+
}
|
|
299
|
+
/**
|
|
300
|
+
* Calculates the transaction fee from the explanation.
|
|
301
|
+
* @param explanation - The transaction explanation
|
|
302
|
+
* @returns The fee as a BigNumber
|
|
303
|
+
*/
|
|
304
|
+
calculateTransactionFee(explanation) {
|
|
305
|
+
if (explanation.fee.fee === '') {
|
|
306
|
+
return new bignumber_js_1.default(0);
|
|
307
|
+
}
|
|
308
|
+
return new bignumber_js_1.default(explanation.fee.fee);
|
|
309
|
+
}
|
|
310
|
+
/**
|
|
311
|
+
* Builds the inputs array for a parsed transaction.
|
|
312
|
+
* Includes sender input and optionally sponsor input if present.
|
|
313
|
+
*
|
|
314
|
+
* @param explanation - The transaction explanation
|
|
315
|
+
* @param fee - The calculated transaction fee
|
|
316
|
+
* @returns Array of transaction inputs
|
|
317
|
+
*/
|
|
318
|
+
buildTransactionInputs(explanation, fee) {
|
|
319
|
+
const senderAddress = explanation.outputs[0].address;
|
|
320
|
+
const outputAmount = new bignumber_js_1.default(explanation.outputAmount);
|
|
321
|
+
// If there's a sponsor, sender only pays for outputs
|
|
322
|
+
// Otherwise, sender pays for outputs + fee
|
|
323
|
+
const senderAmount = explanation.sponsor ? outputAmount.toFixed() : outputAmount.plus(fee).toFixed();
|
|
324
|
+
const inputs = [
|
|
325
|
+
{
|
|
326
|
+
address: senderAddress,
|
|
327
|
+
amount: senderAmount,
|
|
328
|
+
},
|
|
329
|
+
];
|
|
330
|
+
// Add sponsor input if present
|
|
331
|
+
if (explanation.sponsor) {
|
|
332
|
+
inputs.push({
|
|
333
|
+
address: explanation.sponsor,
|
|
334
|
+
amount: fee.toFixed(),
|
|
335
|
+
});
|
|
336
|
+
}
|
|
337
|
+
return inputs;
|
|
338
|
+
}
|
|
339
|
+
/**
|
|
340
|
+
* Builds the outputs array for a parsed transaction.
|
|
341
|
+
* @param explanation - The transaction explanation
|
|
342
|
+
* @returns Array of transaction outputs
|
|
343
|
+
*/
|
|
344
|
+
buildTransactionOutputs(explanation) {
|
|
345
|
+
return explanation.outputs.map((output) => ({
|
|
346
|
+
address: output.address,
|
|
347
|
+
amount: new bignumber_js_1.default(output.amount).toFixed(),
|
|
348
|
+
}));
|
|
349
|
+
}
|
|
350
|
+
/**
|
|
351
|
+
* Creates a transaction builder factory instance.
|
|
352
|
+
* @returns TransactionBuilderFactory for this coin
|
|
353
|
+
*/
|
|
354
|
+
getTxBuilderFactory() {
|
|
355
|
+
return new lib_1.TransactionBuilderFactory(statics_1.coins.get(this.getChain()));
|
|
356
|
+
}
|
|
357
|
+
/**
|
|
358
|
+
* Rebuilds a transaction from its hex representation.
|
|
359
|
+
* @param txHex - The transaction hex to rebuild
|
|
360
|
+
* @returns The rebuilt transaction
|
|
361
|
+
* @throws Error if transaction cannot be rebuilt
|
|
362
|
+
*/
|
|
363
|
+
async rebuildTransaction(txHex) {
|
|
364
|
+
const txBuilderFactory = this.getTxBuilderFactory();
|
|
365
|
+
try {
|
|
366
|
+
const txBuilder = txBuilderFactory.from(txHex);
|
|
367
|
+
return (await txBuilder.build());
|
|
368
|
+
}
|
|
369
|
+
catch (err) {
|
|
370
|
+
throw new Error(`Failed to rebuild transaction: ${err.toString()}`);
|
|
371
|
+
}
|
|
372
|
+
}
|
|
133
373
|
}
|
|
134
374
|
exports.Iota = Iota;
|
|
135
|
-
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"iota.js","sourceRoot":"","sources":["../../src/iota.ts"],"names":[],"mappings":";;;;;;AAAA,mDAiB8B;AAE9B,wDAAgC;AAChC,+BAA+C;AAC/C,yDAA+D;AAE/D,MAAa,IAAK,SAAQ,mBAAQ;IAGhC,YAAsB,KAAgB,EAAE,WAAuC;QAC7E,KAAK,CAAC,KAAK,CAAC,CAAC;QAEb,IAAI,CAAC,WAAW,EAAE,CAAC;YACjB,MAAM,IAAI,KAAK,CAAC,oDAAoD,CAAC,CAAC;QACxE,CAAC;QAED,IAAI,CAAC,YAAY,GAAG,WAAW,CAAC;IAClC,CAAC;IAED,MAAM,CAAC,cAAc,CAAC,KAAgB,EAAE,WAAuC;QAC7E,OAAO,IAAI,IAAI,CAAC,KAAK,EAAE,WAAW,CAAC,CAAC;IACtC,CAAC;IAED,aAAa;QACX,OAAO,IAAI,CAAC,GAAG,CAAC,EAAE,EAAE,IAAI,CAAC,YAAY,CAAC,aAAa,CAAC,CAAC;IACvD,CAAC;IAED,QAAQ;QACN,OAAO,IAAI,CAAC,YAAY,CAAC,IAAI,CAAC;IAChC,CAAC;IAED,SAAS;QACP,OAAO,IAAI,CAAC,YAAY,CAAC,MAAM,CAAC;IAClC,CAAC;IAED,WAAW;QACT,OAAO,IAAI,CAAC,YAAY,CAAC,QAAQ,CAAC;IACpC,CAAC;IAED,kBAAkB;IAClB,WAAW;QACT,OAAO,IAAI,CAAC;IACd,CAAC;IAED,oBAAoB;IACpB,sBAAsB;QACpB,OAAO,wBAAa,CAAC,GAAG,CAAC;IAC3B,CAAC;IAED,eAAe;QACb,OAAO,kBAAO,CAAC,KAAK,CAAC;IACvB,CAAC;IAED;;;;OAIG;IACH,cAAc,CAAC,OAAe;QAC5B,8CAA8C;QAC9C,OAAO,eAAK,CAAC,cAAc,CAAC,OAAO,CAAC,CAAC;IACvC,CAAC;IAED;;;OAGG;IACH,KAAK,CAAC,iBAAiB,CAAC,MAAgC;QACtD,yDAAyD;QACzD,OAAO,IAAI,CAAC;IACd,CAAC;IAED;;;OAGG;IACH,KAAK,CAAC,eAAe,CAAC,MAA+B;QACnD,MAAM,EAAE,SAAS,EAAE,OAAO,EAAE,KAAK,EAAE,GAAG,MAAM,CAAC;QAE7C,IAAI,CAAC,IAAI,CAAC,cAAc,CAAC,OAAO,CAAC,EAAE,CAAC;YAClC,MAAM,IAAI,8BAAmB,CAAC,oBAAoB,OAAO,EAAE,CAAC,CAAC;QAC/D,CAAC;QAED,IAAI,CAAC,SAAS,EAAE,CAAC;YACf,MAAM,IAAI,KAAK,CAAC,kCAAkC,CAAC,CAAC;QACtD,CAAC;QAED,KAAK,MAAM,QAAQ,IAAI,SAAS,EAAE,CAAC;YACjC,MAAM,GAAG,GAAG,MAAM,uBAAY,CAAC,yBAAyB,EAAE,CAAC;YAC3D,MAAM,cAAc,GAAG,QAAQ,CAAC,cAAwB,CAAC;YAEzD,MAAM,cAAc,GAAG,IAAI,GAAG,KAAK,CAAC;YACpC,MAAM,gBAAgB,GAAG,GAAG,CAAC,gBAAgB,CAAC,cAAc,EAAE,cAAc,CAAC,CAAC,KAAK,CAAC,CAAC,EAAE,EAAE,CAAC,CAAC;YAC3F,MAAM,eAAe,GAAG,eAAK,CAAC,uBAAuB,CAAC,gBAAgB,CAAC,CAAC;YAExE,IAAI,OAAO,KAAK,eAAe,EAAE,CAAC;gBAChC,OAAO,KAAK,CAAC;YACf,CAAC;QACH,CAAC;QACD,OAAO,IAAI,CAAC;IACd,CAAC;IAED;;;OAGG;IACH,KAAK,CAAC,gBAAgB,CAAC,MAA+B;QACpD,oDAAoD;QACpD,OAAO,EAAE,CAAC;IACZ,CAAC;IAED;;;OAGG;IACH,eAAe,CAAC,IAAa;QAC3B,MAAM,OAAO,GAAG,IAAI,CAAC,CAAC,CAAC,IAAI,aAAW,CAAC,EAAE,IAAI,EAAE,CAAC,CAAC,CAAC,CAAC,IAAI,aAAW,EAAE,CAAC;QACrE,MAAM,IAAI,GAAG,OAAO,CAAC,OAAO,EAAE,CAAC;QAC/B,IAAI,CAAC,IAAI,CAAC,GAAG,EAAE,CAAC;YACd,MAAM,IAAI,KAAK,CAAC,gCAAgC,CAAC,CAAC;QACpD,CAAC;QACD,OAAO;YACL,GAAG,EAAE,IAAI,CAAC,GAAG;YACb,GAAG,EAAE,IAAI,CAAC,GAAG;SACd,CAAC;IACJ,CAAC;IAED;;;OAGG;IACH,UAAU,CAAC,GAAW;QACpB,OAAO,eAAK,CAAC,gBAAgB,CAAC,GAAG,CAAC,CAAC;IACrC,CAAC;IAED;;;OAGG;IACH,KAAK,CAAC,eAAe,CAAC,MAA8B;QAClD,MAAM,IAAI,KAAK,CAAC,yBAAyB,CAAC,CAAC;IAC7C,CAAC;IAED;;;OAGG;IACH,iBAAiB,CAAC,EAAE,YAAY,EAAE,GAAG,EAAE,SAAS,EAA2B;QACzE,IAAI,YAAY,KAAK,wBAAa,CAAC,GAAG,EAAE,CAAC;YACvC,MAAM,IAAI,KAAK,CAAC,0BAA0B,CAAC,CAAC;QAC9C,CAAC;QACD,IAAA,kCAAoB,EAAC,GAAG,EAAE,SAAS,IAAI,EAAE,CAAC,CAAC;IAC7C,CAAC;CACF;AAnJD,oBAmJC","sourcesContent":["import {\n  AuditDecryptedKeyParams,\n  BaseCoin,\n  BitGoBase,\n  KeyPair,\n  ParseTransactionOptions,\n  ParsedTransaction,\n  SignTransactionOptions,\n  SignedTransaction,\n  VerifyTransactionOptions,\n  MultisigType,\n  multisigTypes,\n  MPCAlgorithm,\n  InvalidAddressError,\n  EDDSAMethods,\n  TssVerifyAddressOptions,\n  MPCType,\n} from '@bitgo-beta/sdk-core';\nimport { BaseCoin as StaticsBaseCoin, CoinFamily } from '@bitgo-beta/statics';\nimport utils from './lib/utils';\nimport { KeyPair as IotaKeyPair } from './lib';\nimport { auditEddsaPrivateKey } from '@bitgo-beta/sdk-lib-mpc';\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   * Verifies that a transaction prebuild complies with the original intention\n   * @param params\n   */\n  async verifyTransaction(params: VerifyTransactionOptions): Promise<boolean> {\n    // TODO: Add IOTA-specific transaction verification logic\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    const { keychains, address, index } = params;\n\n    if (!this.isValidAddress(address)) {\n      throw new InvalidAddressError(`invalid address: ${address}`);\n    }\n\n    if (!keychains) {\n      throw new Error('missing required param keychains');\n    }\n\n    for (const keychain of keychains) {\n      const MPC = await EDDSAMethods.getInitializedMpcInstance();\n      const commonKeychain = keychain.commonKeychain as string;\n\n      const derivationPath = 'm/' + index;\n      const derivedPublicKey = MPC.deriveUnhardened(commonKeychain, derivationPath).slice(0, 64);\n      const expectedAddress = utils.getAddressFromPublicKey(derivedPublicKey);\n\n      if (address !== expectedAddress) {\n        return false;\n      }\n    }\n    return true;\n  }\n\n  /**\n   * Parse a transaction\n   * @param params\n   */\n  async parseTransaction(params: ParseTransactionOptions): Promise<ParsedTransaction> {\n    // TODO: Add IOTA-specific transaction parsing logic\n    return {};\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"]}
|
|
375
|
+
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"iota.js","sourceRoot":"","sources":["../../src/iota.ts"],"names":[],"mappings":";;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;AAAA,mDAkB8B;AAC9B,iDAAqF;AACrF,wDAAgC;AAChC,+BAAuF;AACvF,yDAA+D;AAC/D,gEAAqC;AACrC,0CAA4B;AAO5B,mEAAgE;AAEhE;;;GAGG;AACH,MAAa,IAAK,SAAQ,mBAAQ;IAGhC,YAAsB,KAAgB,EAAE,WAAuC;QAC7E,KAAK,CAAC,KAAK,CAAC,CAAC;QAEb,IAAI,CAAC,WAAW,EAAE,CAAC;YACjB,MAAM,IAAI,KAAK,CAAC,oDAAoD,CAAC,CAAC;QACxE,CAAC;QAED,IAAI,CAAC,YAAY,GAAG,WAAW,CAAC;IAClC,CAAC;IAED;;OAEG;IACH,MAAM,CAAC,cAAc,CAAC,KAAgB,EAAE,WAAuC;QAC7E,OAAO,IAAI,IAAI,CAAC,KAAK,EAAE,WAAW,CAAC,CAAC;IACtC,CAAC;IAED,2CAA2C;IAC3C,6BAA6B;IAC7B,2CAA2C;IAE3C,aAAa;QACX,OAAO,IAAI,CAAC,GAAG,CAAC,EAAE,EAAE,IAAI,CAAC,YAAY,CAAC,aAAa,CAAC,CAAC;IACvD,CAAC;IAED,QAAQ;QACN,OAAO,IAAI,CAAC,YAAY,CAAC,IAAI,CAAC;IAChC,CAAC;IAED,SAAS;QACP,OAAO,IAAI,CAAC,YAAY,CAAC,MAAM,CAAC;IAClC,CAAC;IAED,WAAW;QACT,OAAO,IAAI,CAAC,YAAY,CAAC,QAAQ,CAAC;IACpC,CAAC;IAED,2CAA2C;IAC3C,kCAAkC;IAClC,2CAA2C;IAE3C,WAAW;QACT,OAAO,IAAI,CAAC;IACd,CAAC;IAED,sBAAsB;QACpB,OAAO,wBAAa,CAAC,GAAG,CAAC;IAC3B,CAAC;IAED,eAAe;QACb,OAAO,kBAAO,CAAC,KAAK,CAAC;IACvB,CAAC;IAED,2CAA2C;IAC3C,oCAAoC;IACpC,2CAA2C;IAE3C;;;;OAIG;IACH,cAAc,CAAC,OAAe;QAC5B,OAAO,eAAK,CAAC,cAAc,CAAC,OAAO,CAAC,CAAC;IACvC,CAAC;IAED;;;;OAIG;IACH,UAAU,CAAC,GAAW;QACpB,OAAO,eAAK,CAAC,gBAAgB,CAAC,GAAG,CAAC,CAAC;IACrC,CAAC;IAED;;;;OAIG;IACH,KAAK,CAAC,eAAe,CAAC,MAA+B;QACnD,OAAO,IAAA,sCAA2B,EAChC,MAAM,EACN,CAAC,OAAO,EAAE,EAAE,CAAC,IAAI,CAAC,cAAc,CAAC,OAAO,CAAC,EACzC,CAAC,SAAS,EAAE,EAAE,CAAC,eAAK,CAAC,uBAAuB,CAAC,SAAS,CAAC,CACxD,CAAC;IACJ,CAAC;IAED,2CAA2C;IAC3C,2CAA2C;IAC3C,2CAA2C;IAE3C;;;;;OAKG;IACH,KAAK,CAAC,kBAAkB,CAAC,MAAiC;QACxD,MAAM,KAAK,GAAG,IAAI,CAAC,uBAAuB,CAAC,MAAM,CAAC,KAAK,EAAE,SAAS,CAAC,CAAC;QACpE,MAAM,WAAW,GAAG,MAAM,IAAI,CAAC,kBAAkB,CAAC,KAAK,CAAC,CAAC;QACzD,OAAO,WAAW,CAAC,kBAAkB,EAAE,CAAC;IAC1C,CAAC;IAED;;;;;;;OAOG;IACH,KAAK,CAAC,iBAAiB,CAAC,MAAgC;QACtD,MAAM,EAAE,UAAU,EAAE,QAAQ,EAAE,GAAG,MAAM,CAAC;QACxC,MAAM,KAAK,GAAG,IAAI,CAAC,uBAAuB,CAAC,UAAU,CAAC,KAAK,EAAE,QAAQ,CAAC,CAAC;QAEvE,MAAM,WAAW,GAAG,MAAM,IAAI,CAAC,kBAAkB,CAAC,KAAK,CAAC,CAAC;QACzD,IAAI,CAAC,uBAAuB,CAAC,WAAW,CAAC,CAAC;QAE1C,IAAI,QAAQ,CAAC,UAAU,KAAK,SAAS,EAAE,CAAC;YACtC,IAAI,CAAC,2BAA2B,CAAC,WAAkC,EAAE,QAAQ,CAAC,UAAU,CAAC,CAAC;QAC5F,CAAC;QAED,OAAO,IAAI,CAAC;IACd,CAAC;IAED;;;;OAIG;IACH,KAAK,CAAC,gBAAgB,CAAC,MAAmC;QACxD,MAAM,sBAAsB,GAAG,MAAM,IAAI,CAAC,kBAAkB,CAAC,EAAE,KAAK,EAAE,MAAM,CAAC,KAAK,EAAE,CAAC,CAAC;QAEtF,IAAI,CAAC,sBAAsB,IAAI,sBAAsB,CAAC,OAAO,CAAC,MAAM,KAAK,CAAC,EAAE,CAAC;YAC3E,OAAO,IAAI,CAAC,4BAA4B,EAAE,CAAC;QAC7C,CAAC;QAED,MAAM,GAAG,GAAG,IAAI,CAAC,uBAAuB,CAAC,sBAAsB,CAAC,CAAC;QACjE,MAAM,MAAM,GAAG,IAAI,CAAC,sBAAsB,CAAC,sBAAsB,EAAE,GAAG,CAAC,CAAC;QACxE,MAAM,OAAO,GAAG,IAAI,CAAC,uBAAuB,CAAC,sBAAsB,CAAC,CAAC;QAErE,OAAO,EAAE,MAAM,EAAE,OAAO,EAAE,GAAG,EAAE,CAAC;IAClC,CAAC;IAED,2CAA2C;IAC3C,6BAA6B;IAC7B,2CAA2C;IAE3C;;;;;OAKG;IACH,eAAe,CAAC,IAAa;QAC3B,MAAM,OAAO,GAAG,IAAI,CAAC,CAAC,CAAC,IAAI,aAAW,CAAC,EAAE,IAAI,EAAE,CAAC,CAAC,CAAC,CAAC,IAAI,aAAW,EAAE,CAAC;QACrE,MAAM,IAAI,GAAG,OAAO,CAAC,OAAO,EAAE,CAAC;QAE/B,IAAI,CAAC,IAAI,CAAC,GAAG,EAAE,CAAC;YACd,MAAM,IAAI,KAAK,CAAC,gCAAgC,CAAC,CAAC;QACpD,CAAC;QAED,OAAO;YACL,GAAG,EAAE,IAAI,CAAC,GAAG;YACb,GAAG,EAAE,IAAI,CAAC,GAAG;SACd,CAAC;IACJ,CAAC;IAED;;;OAGG;IACH,KAAK,CAAC,eAAe,CAAC,MAA8B;QAClD,MAAM,IAAI,KAAK,CAAC,yBAAyB,CAAC,CAAC;IAC7C,CAAC;IAED;;;;OAIG;IACH,iBAAiB,CAAC,EAAE,YAAY,EAAE,GAAG,EAAE,SAAS,EAA2B;QACzE,IAAI,YAAY,KAAK,wBAAa,CAAC,GAAG,EAAE,CAAC;YACvC,MAAM,IAAI,KAAK,CAAC,0BAA0B,CAAC,CAAC;QAC9C,CAAC;QACD,IAAA,kCAAoB,EAAC,GAAG,EAAE,SAAS,IAAI,EAAE,CAAC,CAAC;IAC7C,CAAC;IAED;;;;OAIG;IACH,KAAK,CAAC,kBAAkB,CAAC,YAAoB;QAC3C,MAAM,kBAAkB,GAAG,MAAM,IAAI,CAAC,kBAAkB,CAAC,YAAY,CAAC,CAAC;QACvE,OAAO,kBAAkB,CAAC,eAAe,CAAC;IAC5C,CAAC;IAED;;OAEG;IACH,2BAA2B;QACzB,OAAO,IAAI,CAAC;IACd,CAAC;IAED;;;;OAIG;IACH,6BAA6B,CAAC,MAAuB,EAAE,MAA4C;QACjG,MAAM,CAAC,QAAQ,GAAG,MAAM,CAAC,QAAQ,CAAC;IACpC,CAAC;IAED,2CAA2C;IAC3C,yBAAyB;IACzB,2CAA2C;IAE3C;;;;;;OAMG;IACK,uBAAuB,CAAC,KAAyB,EAAE,SAAiB;QAC1E,IAAI,CAAC,KAAK,EAAE,CAAC;YACX,MAAM,IAAI,KAAK,CAAC,mDAAmD,SAAS,YAAY,CAAC,CAAC;QAC5F,CAAC;QACD,OAAO,KAAK,CAAC;IACf,CAAC;IAED;;;;OAIG;IACK,uBAAuB,CAAC,WAAwB;QACtD,IAAI,CAAC,CAAC,WAAW,YAAY,yCAAmB,CAAC,EAAE,CAAC;YAClD,MAAM,IAAI,KAAK,CAAC,+BAA+B,CAAC,CAAC;QACnD,CAAC;IACH,CAAC;IAED;;;;;OAKG;IACK,2BAA2B,CACjC,WAAgC,EAChC,kBAA0C;QAE1C,MAAM,MAAM,GAAG,WAAW,CAAC,MAAM,EAAoB,CAAC;QAEtD,IAAI,CAAC,MAAM,CAAC,UAAU,EAAE,CAAC;YACvB,MAAM,IAAI,KAAK,CAAC,gEAAgE,CAAC,CAAC;QACpF,CAAC;QAED,MAAM,gBAAgB,GAAG,IAAI,CAAC,mBAAmB,CAAC,MAAM,CAAC,UAAU,CAAC,CAAC;QACrE,MAAM,QAAQ,GAAG,IAAI,CAAC,mBAAmB,CAAC,kBAAkB,CAAC,CAAC;QAE9D,IAAI,CAAC,IAAI,CAAC,eAAe,CAAC,QAAQ,EAAE,gBAAgB,CAAC,EAAE,CAAC;YACtD,MAAM,IAAI,KAAK,CAAC,gEAAgE,CAAC,CAAC;QACpF,CAAC;IACH,CAAC;IAED;;;;OAIG;IACK,mBAAmB,CAAC,UAAkC;QAC5D,OAAO,UAAU,CAAC,GAAG,CAAC,CAAC,SAAS,EAAE,EAAE,CAAC,CAAC,CAAC,IAAI,CAAC,SAAS,EAAE,CAAC,SAAS,EAAE,QAAQ,EAAE,WAAW,CAAC,CAAC,CAAC,CAAC;IAC9F,CAAC;IAED;;;;;OAKG;IACK,eAAe,CAAC,QAAgC,EAAE,MAA8B;QACtF,OAAO,QAAQ,CAAC,KAAK,CAAC,CAAC,iBAAiB,EAAE,EAAE,CAC1C,MAAM,CAAC,IAAI,CAAC,CAAC,eAAe,EAAE,EAAE,CAAC,CAAC,CAAC,OAAO,CAAC,iBAAiB,EAAE,eAAe,CAAC,CAAC,CAChF,CAAC;IACJ,CAAC;IAED;;;OAGG;IACK,4BAA4B;QAClC,OAAO;YACL,MAAM,EAAE,EAAE;YACV,OAAO,EAAE,EAAE;YACX,GAAG,EAAE,IAAI,sBAAS,CAAC,CAAC,CAAC;SACtB,CAAC;IACJ,CAAC;IAED;;;;OAIG;IACK,uBAAuB,CAAC,WAAmC;QACjE,IAAI,WAAW,CAAC,GAAG,CAAC,GAAG,KAAK,EAAE,EAAE,CAAC;YAC/B,OAAO,IAAI,sBAAS,CAAC,CAAC,CAAC,CAAC;QAC1B,CAAC;QACD,OAAO,IAAI,sBAAS,CAAC,WAAW,CAAC,GAAG,CAAC,GAAG,CAAC,CAAC;IAC5C,CAAC;IAED;;;;;;;OAOG;IACK,sBAAsB,CAC5B,WAAmC,EACnC,GAAc;QAKd,MAAM,aAAa,GAAG,WAAW,CAAC,OAAO,CAAC,CAAC,CAAC,CAAC,OAAO,CAAC;QACrD,MAAM,YAAY,GAAG,IAAI,sBAAS,CAAC,WAAW,CAAC,YAAY,CAAC,CAAC;QAE7D,qDAAqD;QACrD,2CAA2C;QAC3C,MAAM,YAAY,GAAG,WAAW,CAAC,OAAO,CAAC,CAAC,CAAC,YAAY,CAAC,OAAO,EAAE,CAAC,CAAC,CAAC,YAAY,CAAC,IAAI,CAAC,GAAG,CAAC,CAAC,OAAO,EAAE,CAAC;QAErG,MAAM,MAAM,GAAG;YACb;gBACE,OAAO,EAAE,aAAa;gBACtB,MAAM,EAAE,YAAY;aACrB;SACF,CAAC;QAEF,+BAA+B;QAC/B,IAAI,WAAW,CAAC,OAAO,EAAE,CAAC;YACxB,MAAM,CAAC,IAAI,CAAC;gBACV,OAAO,EAAE,WAAW,CAAC,OAAO;gBAC5B,MAAM,EAAE,GAAG,CAAC,OAAO,EAAE;aACtB,CAAC,CAAC;QACL,CAAC;QAED,OAAO,MAAM,CAAC;IAChB,CAAC;IAED;;;;OAIG;IACK,uBAAuB,CAAC,WAAmC;QAIjE,OAAO,WAAW,CAAC,OAAO,CAAC,GAAG,CAAC,CAAC,MAAM,EAAE,EAAE,CAAC,CAAC;YAC1C,OAAO,EAAE,MAAM,CAAC,OAAO;YACvB,MAAM,EAAE,IAAI,sBAAS,CAAC,MAAM,CAAC,MAAM,CAAC,CAAC,OAAO,EAAE;SAC/C,CAAC,CAAC,CAAC;IACN,CAAC;IAED;;;OAGG;IACK,mBAAmB;QACzB,OAAO,IAAI,+BAAyB,CAAC,eAAK,CAAC,GAAG,CAAC,IAAI,CAAC,QAAQ,EAAE,CAAC,CAAC,CAAC;IACnE,CAAC;IAED;;;;;OAKG;IACK,KAAK,CAAC,kBAAkB,CAAC,KAAa;QAC5C,MAAM,gBAAgB,GAAG,IAAI,CAAC,mBAAmB,EAAE,CAAC;QACpD,IAAI,CAAC;YACH,MAAM,SAAS,GAAG,gBAAgB,CAAC,IAAI,CAAC,KAAK,CAAC,CAAC;YAC/C,OAAO,CAAC,MAAM,SAAS,CAAC,KAAK,EAAE,CAAgB,CAAC;QAClD,CAAC;QAAC,OAAO,GAAG,EAAE,CAAC;YACb,MAAM,IAAI,KAAK,CAAC,kCAAkC,GAAG,CAAC,QAAQ,EAAE,EAAE,CAAC,CAAC;QACtE,CAAC;IACH,CAAC;CACF;AA1YD,oBA0YC","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   * @inheritDoc\n   */\n  allowsAccountConsolidations(): boolean {\n    return true;\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,8 +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;
|
|
2
|
-
|
|
3
|
-
|
|
4
|
-
|
|
5
|
-
|
|
6
|
-
export declare const
|
|
7
|
-
|
|
6
|
+
/**
|
|
7
|
+
* Length of transaction digest in bytes.
|
|
8
|
+
* Used for transaction IDs and hashes.
|
|
9
|
+
*/
|
|
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
|
+
*/
|
|
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
|
+
*/
|
|
20
|
+
export declare const IOTA_SIGNATURE_LENGTH = 64;
|
|
21
|
+
/**
|
|
22
|
+
* Length of Ed25519 public keys in bytes.
|
|
23
|
+
* Standard Ed25519 key size.
|
|
24
|
+
*/
|
|
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
|
+
*/
|
|
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
|
+
*/
|
|
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
|
+
*/
|
|
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
|
+
*/
|
|
52
|
+
export declare const MAX_GAS_PRICE = 100000;
|
|
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
|
+
*/
|
|
60
|
+
export declare const TRANSFER_TRANSACTION_COMMANDS: string[];
|
|
8
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"}
|