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

This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
Files changed (69) hide show
  1. package/README.md +1 -1
  2. package/dist/src/iota.d.ts +134 -23
  3. package/dist/src/iota.d.ts.map +1 -1
  4. package/dist/src/iota.js +286 -46
  5. package/dist/src/lib/constants.d.ts +59 -6
  6. package/dist/src/lib/constants.d.ts.map +1 -1
  7. package/dist/src/lib/constants.js +76 -8
  8. package/dist/src/lib/iface.d.ts +174 -2
  9. package/dist/src/lib/iface.d.ts.map +1 -1
  10. package/dist/src/lib/iface.js +1 -1
  11. package/dist/src/lib/index.d.ts +1 -0
  12. package/dist/src/lib/index.d.ts.map +1 -1
  13. package/dist/src/lib/index.js +4 -2
  14. package/dist/src/lib/keyPair.d.ts +100 -6
  15. package/dist/src/lib/keyPair.d.ts.map +1 -1
  16. package/dist/src/lib/keyPair.js +103 -10
  17. package/dist/src/lib/transaction.d.ts +175 -5
  18. package/dist/src/lib/transaction.d.ts.map +1 -1
  19. package/dist/src/lib/transaction.js +390 -6
  20. package/dist/src/lib/transactionBuilder.d.ts +109 -9
  21. package/dist/src/lib/transactionBuilder.d.ts.map +1 -1
  22. package/dist/src/lib/transactionBuilder.js +200 -14
  23. package/dist/src/lib/transactionBuilderFactory.d.ts +98 -2
  24. package/dist/src/lib/transactionBuilderFactory.d.ts.map +1 -1
  25. package/dist/src/lib/transactionBuilderFactory.js +132 -5
  26. package/dist/src/lib/transferBuilder.d.ts +52 -2
  27. package/dist/src/lib/transferBuilder.d.ts.map +1 -1
  28. package/dist/src/lib/transferBuilder.js +86 -3
  29. package/dist/src/lib/transferTransaction.d.ts +124 -0
  30. package/dist/src/lib/transferTransaction.d.ts.map +1 -0
  31. package/dist/src/lib/transferTransaction.js +341 -0
  32. package/dist/src/lib/utils.d.ts +108 -7
  33. package/dist/src/lib/utils.d.ts.map +1 -1
  34. package/dist/src/lib/utils.js +146 -11
  35. package/dist/test/resources/iota.d.ts +35 -0
  36. package/dist/test/resources/iota.d.ts.map +1 -0
  37. package/dist/test/resources/iota.js +93 -0
  38. package/dist/test/unit/helpers/testHelpers.d.ts +57 -0
  39. package/dist/test/unit/helpers/testHelpers.d.ts.map +1 -0
  40. package/dist/test/unit/helpers/testHelpers.js +176 -0
  41. package/dist/test/unit/index.d.ts +2 -0
  42. package/dist/test/unit/index.d.ts.map +1 -0
  43. package/dist/test/unit/index.js +16 -0
  44. package/dist/test/unit/iota.d.ts +2 -0
  45. package/dist/test/unit/iota.d.ts.map +1 -0
  46. package/dist/test/unit/iota.js +501 -0
  47. package/dist/test/unit/keyPair.d.ts +2 -0
  48. package/dist/test/unit/keyPair.d.ts.map +1 -0
  49. package/dist/test/unit/keyPair.js +108 -0
  50. package/dist/test/unit/transactionBuilder/transactionBuilder.d.ts +2 -0
  51. package/dist/test/unit/transactionBuilder/transactionBuilder.d.ts.map +1 -0
  52. package/dist/test/unit/transactionBuilder/transactionBuilder.js +188 -0
  53. package/dist/test/unit/transactionBuilder/transactionBuilderFactory.d.ts +2 -0
  54. package/dist/test/unit/transactionBuilder/transactionBuilderFactory.d.ts.map +1 -0
  55. package/dist/test/unit/transactionBuilder/transactionBuilderFactory.js +178 -0
  56. package/dist/test/unit/transactionBuilder/transferBuilder.d.ts +2 -0
  57. package/dist/test/unit/transactionBuilder/transferBuilder.d.ts.map +1 -0
  58. package/dist/test/unit/transactionBuilder/transferBuilder.js +438 -0
  59. package/dist/test/unit/transferTransaction.d.ts +2 -0
  60. package/dist/test/unit/transferTransaction.d.ts.map +1 -0
  61. package/dist/test/unit/transferTransaction.js +218 -0
  62. package/dist/test/unit/utils.d.ts +2 -0
  63. package/dist/test/unit/utils.d.ts.map +1 -0
  64. package/dist/test/unit/utils.js +252 -0
  65. package/dist/tsconfig.tsbuildinfo +1 -0
  66. package/package.json +17 -11
  67. package/.eslintignore +0 -5
  68. package/.mocharc.yml +0 -8
  69. package/CHANGELOG.md +0 -28
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
- /** @inheritDoc */
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
- * Check if an address is valid
47
- * @param address the address to be validated
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
- * Verifies that a transaction prebuild complies with the original intention
56
- * @param params
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
- async verifyTransaction(params) {
59
- // TODO: Add IOTA-specific transaction verification logic
60
- return true;
109
+ isValidPub(pub) {
110
+ return utils_1.default.isValidPublicKey(pub);
61
111
  }
62
112
  /**
63
- * Check if an address belongs to a wallet
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
- const { keychains, address, index } = params;
68
- if (!this.isValidAddress(address)) {
69
- throw new sdk_core_1.InvalidAddressError(`invalid address: ${address}`);
70
- }
71
- if (!keychains) {
72
- throw new Error('missing required param keychains');
73
- }
74
- for (const keychain of keychains) {
75
- const MPC = await sdk_core_1.EDDSAMethods.getInitializedMpcInstance();
76
- const commonKeychain = keychain.commonKeychain;
77
- const derivationPath = 'm/' + index;
78
- const derivedPublicKey = MPC.deriveUnhardened(commonKeychain, derivationPath).slice(0, 64);
79
- const expectedAddress = utils_1.default.getAddressFromPublicKey(derivedPublicKey);
80
- if (address !== expectedAddress) {
81
- return false;
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
- * Parse a transaction
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
- // TODO: Add IOTA-specific transaction parsing logic
92
- return {};
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
- * Generate a key pair
96
- * @param seed Optional seed to generate key pair from
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
- * Check if a public key is valid
111
- * @param pub Public key to check
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
- * Audit a decrypted private key to ensure it's valid
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":"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","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":"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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   * @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
- export declare const IOTA_TRANSACTION_ID_LENGTH = 64;
3
- export declare const IOTA_BLOCK_ID_LENGTH = 64;
4
- export declare const IOTA_SIGNATURE_LENGTH = 128;
5
- export declare const ADDRESS_BYTES_LENGTH = 32;
6
- export declare const AMOUNT_BYTES_LENGTH = 8;
7
- export declare const SECONDS_PER_WEEK: number;
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":"AAAA,eAAO,MAAM,mBAAmB,KAAK,CAAC;AACtC,eAAO,MAAM,0BAA0B,KAAK,CAAC;AAC7C,eAAO,MAAM,oBAAoB,KAAK,CAAC;AACvC,eAAO,MAAM,qBAAqB,MAAM,CAAC;AACzC,eAAO,MAAM,oBAAoB,KAAK,CAAC;AACvC,eAAO,MAAM,mBAAmB,IAAI,CAAC;AACrC,eAAO,MAAM,gBAAgB,QAAmB,CAAC"}
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"}