@bitgo-beta/sdk-coin-flrp 1.0.1-beta.21 → 1.0.1-beta.23

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.
@@ -1,42 +1,9 @@
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
- })();
35
2
  Object.defineProperty(exports, "__esModule", { value: true });
36
3
  exports.Utils = void 0;
37
4
  const sdk_core_1 = require("@bitgo-beta/sdk-core");
38
- const createHash = __importStar(require("create-hash"));
39
- const secp256k1_1 = require("@noble/curves/secp256k1");
5
+ const secp256k1_1 = require("@bitgo-beta/secp256k1");
6
+ const crypto_1 = require("crypto");
40
7
  const constants_1 = require("./constants");
41
8
  class Utils {
42
9
  constructor() {
@@ -121,9 +88,9 @@ class Utils {
121
88
  return false;
122
89
  pubBuf = Buffer.from(pub, 'hex');
123
90
  }
124
- // validate the public key using noble secp256k1
91
+ // validate the public key using BitGo secp256k1
125
92
  try {
126
- secp256k1_1.secp256k1.ProjectivePoint.fromHex(pubBuf.toString('hex'));
93
+ secp256k1_1.ecc.isPoint(pubBuf); // Check if it's a valid point
127
94
  return true;
128
95
  }
129
96
  catch (e) {
@@ -162,6 +129,81 @@ class Utils {
162
129
  allHexChars(maybe) {
163
130
  return constants_1.HEX_REGEX.test(maybe);
164
131
  }
132
+ /**
133
+ * Lightweight Ethereum address validation
134
+ * Validates that an address is a 40-character hex string (optionally prefixed with 0x)
135
+ *
136
+ * @param {string} address - the Ethereum address to validate
137
+ * @returns {boolean} - true if valid Ethereum address format
138
+ */
139
+ isValidEthereumAddress(address) {
140
+ if (!address || typeof address !== 'string') {
141
+ return false;
142
+ }
143
+ // Remove 0x prefix if present
144
+ const cleanAddress = address.startsWith('0x') ? address.slice(2) : address;
145
+ // Check if it's exactly 40 hex characters
146
+ return cleanAddress.length === 40 && /^[0-9a-fA-F]{40}$/.test(cleanAddress);
147
+ }
148
+ /**
149
+ * Pick specific properties from an object (replaces lodash.pick)
150
+ *
151
+ * @param {T} obj - the source object
152
+ * @param {K[]} keys - array of property keys to pick
153
+ * @returns {Pick<T, K>} - new object with only the specified properties
154
+ */
155
+ pick(obj, keys) {
156
+ const result = {};
157
+ for (const key of keys) {
158
+ if (Object.prototype.hasOwnProperty.call(obj, key)) {
159
+ result[key] = obj[key];
160
+ }
161
+ }
162
+ return result;
163
+ }
164
+ /**
165
+ * Deep equality comparison (replaces lodash.isEqual)
166
+ *
167
+ * @param {unknown} a - first value to compare
168
+ * @param {unknown} b - second value to compare
169
+ * @returns {boolean} - true if values are deeply equal
170
+ */
171
+ isEqual(a, b) {
172
+ if (a === b)
173
+ return true;
174
+ if (a === null || a === undefined || b === null || b === undefined)
175
+ return a === b;
176
+ if (typeof a !== typeof b)
177
+ return false;
178
+ if (typeof a === 'object') {
179
+ if (Array.isArray(a) !== Array.isArray(b))
180
+ return false;
181
+ if (Array.isArray(a)) {
182
+ const arrB = b;
183
+ if (a.length !== arrB.length)
184
+ return false;
185
+ for (let i = 0; i < a.length; i++) {
186
+ if (!this.isEqual(a[i], arrB[i]))
187
+ return false;
188
+ }
189
+ return true;
190
+ }
191
+ const objA = a;
192
+ const objB = b;
193
+ const keysA = Object.keys(objA);
194
+ const keysB = Object.keys(objB);
195
+ if (keysA.length !== keysB.length)
196
+ return false;
197
+ for (const key of keysA) {
198
+ if (!keysB.includes(key))
199
+ return false;
200
+ if (!this.isEqual(objA[key], objB[key]))
201
+ return false;
202
+ }
203
+ return true;
204
+ }
205
+ return false;
206
+ }
165
207
  /** @inheritdoc */
166
208
  isValidSignature(signature) {
167
209
  throw new sdk_core_1.NotImplementedError('isValidSignature not implemented');
@@ -178,10 +220,10 @@ class Utils {
178
220
  * @return signature
179
221
  */
180
222
  createSignature(network, message, prv) {
181
- // Use secp256k1 directly since FlareJS may not expose KeyPair in the same way
223
+ // Use BitGo secp256k1 since FlareJS may not expose KeyPair in the same way
182
224
  try {
183
- const signature = secp256k1_1.secp256k1.sign(message, prv);
184
- return Buffer.from(signature.toCompactRawBytes());
225
+ const signature = secp256k1_1.ecc.sign(message, prv);
226
+ return Buffer.from(signature);
185
227
  }
186
228
  catch (error) {
187
229
  throw new Error(`Failed to create signature: ${error}`);
@@ -197,7 +239,7 @@ class Utils {
197
239
  */
198
240
  verifySignature(network, message, signature, publicKey) {
199
241
  try {
200
- return secp256k1_1.secp256k1.verify(signature, message, publicKey);
242
+ return secp256k1_1.ecc.verify(message, publicKey, signature);
201
243
  }
202
244
  catch (error) {
203
245
  return false;
@@ -221,7 +263,7 @@ class Utils {
221
263
  }
222
264
  }
223
265
  sha256(buf) {
224
- return createHash.default('sha256').update(buf).digest();
266
+ return (0, crypto_1.createHash)('sha256').update(buf).digest();
225
267
  }
226
268
  /**
227
269
  * Check the raw transaction has a valid format in the blockchain context, throw otherwise.
@@ -383,8 +425,63 @@ class Utils {
383
425
  // Simple implementation - in practice this would use bech32 encoding
384
426
  return `${chainid}-${addressBuffer.toString('hex')}`;
385
427
  }
428
+ /**
429
+ * Convert string to bytes for FlareJS memo
430
+ * Follows FlareJS utils.stringToBytes pattern
431
+ * @param {string} text - Text to convert
432
+ * @returns {Uint8Array} Byte array
433
+ */
434
+ stringToBytes(text) {
435
+ return new TextEncoder().encode(text);
436
+ }
437
+ /**
438
+ * Convert bytes to string from FlareJS memo
439
+ * @param {Uint8Array} bytes - Bytes to convert
440
+ * @returns {string} Decoded string
441
+ */
442
+ bytesToString(bytes) {
443
+ return new TextDecoder().decode(bytes);
444
+ }
445
+ /**
446
+ * Create memo bytes from various input formats
447
+ * Supports string, JSON object, or raw bytes
448
+ * @param {string | Record<string, unknown> | Uint8Array} memo - Memo data
449
+ * @returns {Uint8Array} Memo bytes for FlareJS
450
+ */
451
+ createMemoBytes(memo) {
452
+ if (memo instanceof Uint8Array) {
453
+ return memo;
454
+ }
455
+ if (typeof memo === 'string') {
456
+ return this.stringToBytes(memo);
457
+ }
458
+ if (typeof memo === 'object') {
459
+ return this.stringToBytes(JSON.stringify(memo));
460
+ }
461
+ throw new sdk_core_1.InvalidTransactionError('Invalid memo format');
462
+ }
463
+ /**
464
+ * Parse memo bytes to string
465
+ * @param {Uint8Array} memoBytes - Memo bytes from FlareJS transaction
466
+ * @returns {string} Decoded memo string
467
+ */
468
+ parseMemoBytes(memoBytes) {
469
+ if (memoBytes.length === 0) {
470
+ return '';
471
+ }
472
+ return this.bytesToString(memoBytes);
473
+ }
474
+ /**
475
+ * Validate memo size (FlareJS has transaction size limits)
476
+ * @param {Uint8Array} memoBytes - Memo bytes
477
+ * @param {number} maxSize - Maximum size in bytes (default 4KB)
478
+ * @returns {boolean} Whether memo is within size limits
479
+ */
480
+ validateMemoSize(memoBytes, maxSize = 4096) {
481
+ return memoBytes.length <= maxSize;
482
+ }
386
483
  }
387
484
  exports.Utils = Utils;
388
485
  const utils = new Utils();
389
486
  exports.default = utils;
390
- //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"utils.js","sourceRoot":"","sources":["../../../src/lib/utils.ts"],"names":[],"mappings":"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","sourcesContent":["import { TransferableOutput } from '@flarenetwork/flarejs';\nimport {\n  BaseUtils,\n  Entry,\n  InvalidTransactionError,\n  isValidXprv,\n  isValidXpub,\n  NotImplementedError,\n  ParseTransactionError,\n} from '@bitgo-beta/sdk-core';\nimport { FlareNetwork } from '@bitgo-beta/statics';\nimport * as createHash from 'create-hash';\nimport { secp256k1 } from '@noble/curves/secp256k1';\nimport { DeprecatedOutput, DeprecatedTx, Output } from './iface';\nimport {\n  DECODED_BLOCK_ID_LENGTH,\n  SHORT_PUB_KEY_LENGTH,\n  COMPRESSED_PUBLIC_KEY_LENGTH,\n  UNCOMPRESSED_PUBLIC_KEY_LENGTH,\n  RAW_PRIVATE_KEY_LENGTH,\n  SUFFIXED_PRIVATE_KEY_LENGTH,\n  PRIVATE_KEY_COMPRESSED_SUFFIX,\n  OUTPUT_INDEX_HEX_LENGTH,\n  ADDRESS_REGEX,\n  HEX_REGEX,\n} from './constants';\n\nexport class Utils implements BaseUtils {\n  public includeIn(walletAddresses: string[], otxoOutputAddresses: string[]): boolean {\n    return walletAddresses.map((a) => otxoOutputAddresses.includes(a)).reduce((a, b) => a && b, true);\n  }\n\n  /**\n   * Checks if it is a valid address no illegal characters\n   *\n   * @param {string} address - address to be validated\n   * @returns {boolean} - the validation result\n   */\n  /** @inheritdoc */\n  isValidAddress(address: string | string[]): boolean {\n    const addressArr: string[] = Array.isArray(address) ? address : address.split('~');\n\n    for (const address of addressArr) {\n      if (!this.isValidAddressRegex(address)) {\n        return false;\n      }\n    }\n\n    return true;\n  }\n\n  private isValidAddressRegex(address: string): boolean {\n    return ADDRESS_REGEX.test(address);\n  }\n\n  /**\n   * Checks if it is a valid blockId with length 66 including 0x\n   *\n   * @param {string} hash - blockId to be validated\n   * @returns {boolean} - the validation result\n   */\n  /** @inheritdoc */\n  isValidBlockId(hash: string): boolean {\n    // FlareJS equivalent - check if it's a valid CB58 hash with correct length\n    try {\n      const decoded = Buffer.from(hash); // FlareJS should provide CB58 utilities\n      return decoded.length === DECODED_BLOCK_ID_LENGTH;\n    } catch {\n      return false;\n    }\n  }\n\n  /**\n   * Checks if the string is a valid protocol public key or\n   * extended public key.\n   *\n   * @param {string} pub - the  public key to be validated\n   * @returns {boolean} - the validation result\n   */\n  isValidPublicKey(pub: string): boolean {\n    if (isValidXpub(pub)) return true;\n\n    let pubBuf: Buffer;\n    if (pub.length === SHORT_PUB_KEY_LENGTH) {\n      try {\n        // For FlareJS, we'll need to implement CB58 decode functionality\n        pubBuf = Buffer.from(pub, 'hex'); // Temporary placeholder\n      } catch {\n        return false;\n      }\n    } else {\n      if (pub.length !== COMPRESSED_PUBLIC_KEY_LENGTH && pub.length !== UNCOMPRESSED_PUBLIC_KEY_LENGTH) {\n        return false;\n      }\n\n      const firstByte = pub.slice(0, 2);\n\n      // uncompressed public key\n      if (pub.length === UNCOMPRESSED_PUBLIC_KEY_LENGTH && firstByte !== '04') {\n        return false;\n      }\n\n      // compressed public key\n      if (pub.length === COMPRESSED_PUBLIC_KEY_LENGTH && firstByte !== '02' && firstByte !== '03') {\n        return false;\n      }\n\n      if (!this.allHexChars(pub)) return false;\n      pubBuf = Buffer.from(pub, 'hex');\n    }\n    // validate the public key using noble secp256k1\n    try {\n      secp256k1.ProjectivePoint.fromHex(pubBuf.toString('hex'));\n      return true;\n    } catch (e) {\n      return false;\n    }\n  }\n\n  public parseAddress = (pub: string): Buffer => {\n    // FlareJS equivalent for address parsing\n    return Buffer.from(pub, 'hex'); // Simplified implementation\n  };\n\n  /**\n   * Returns whether or not the string is a valid protocol private key, or extended\n   * private key.\n   *\n   * The protocol key format is described in the @stacks/transactions npm package, in the\n   * createStacksPrivateKey function:\n   * https://github.com/blockstack/stacks.js/blob/master/packages/transactions/src/keys.ts#L125\n   *\n   * @param {string} prv - the private key (or extended private key) to be validated\n   * @returns {boolean} - the validation result\n   */\n  isValidPrivateKey(prv: string): boolean {\n    if (isValidXprv(prv)) return true;\n\n    if (prv.length !== RAW_PRIVATE_KEY_LENGTH && prv.length !== SUFFIXED_PRIVATE_KEY_LENGTH) {\n      return false;\n    }\n\n    if (\n      prv.length === SUFFIXED_PRIVATE_KEY_LENGTH &&\n      prv.slice(RAW_PRIVATE_KEY_LENGTH) !== PRIVATE_KEY_COMPRESSED_SUFFIX\n    ) {\n      return false;\n    }\n\n    return this.allHexChars(prv);\n  }\n\n  /**\n   * Returns whether or not the string is a composed of hex chars only\n   *\n   * @param {string} maybe - the  string to be validated\n   * @returns {boolean} - the validation result\n   */\n  allHexChars(maybe: string): boolean {\n    return HEX_REGEX.test(maybe);\n  }\n\n  /** @inheritdoc */\n  isValidSignature(signature: string): boolean {\n    throw new NotImplementedError('isValidSignature not implemented');\n  }\n\n  /** @inheritdoc */\n  isValidTransactionId(txId: string): boolean {\n    throw new NotImplementedError('isValidTransactionId not implemented');\n  }\n\n  /**\n   * FlareJS wrapper to create signature and return it for credentials\n   * @param network\n   * @param message\n   * @param prv\n   * @return signature\n   */\n  createSignature(network: FlareNetwork, message: Buffer, prv: Buffer): Buffer {\n    // Use secp256k1 directly since FlareJS may not expose KeyPair in the same way\n    try {\n      const signature = secp256k1.sign(message, prv);\n      return Buffer.from(signature.toCompactRawBytes());\n    } catch (error) {\n      throw new Error(`Failed to create signature: ${error}`);\n    }\n  }\n\n  /**\n   * FlareJS wrapper to verify signature\n   * @param network\n   * @param message\n   * @param signature\n   * @param publicKey - public key instead of private key for verification\n   * @return true if it's verify successful\n   */\n  verifySignature(network: FlareNetwork, message: Buffer, signature: Buffer, publicKey: Buffer): boolean {\n    try {\n      return secp256k1.verify(signature, message, publicKey);\n    } catch (error) {\n      return false;\n    }\n  }\n\n  /**\n   * FlareJS wrapper to recover signature\n   * @param network\n   * @param message\n   * @param signature\n   * @return recovered public key\n   */\n  recoverySignature(network: FlareNetwork, message: Buffer, signature: Buffer): Buffer {\n    try {\n      // This would need to be implemented with secp256k1 recovery\n      // For now, throwing error since recovery logic would need to be adapted\n      throw new NotImplementedError('recoverySignature not fully implemented for FlareJS');\n    } catch (error) {\n      throw new Error(`Failed to recover signature: ${error}`);\n    }\n  }\n\n  sha256(buf: Uint8Array): Buffer {\n    return createHash.default('sha256').update(buf).digest();\n  }\n\n  /**\n   * Check the raw transaction has a valid format in the blockchain context, throw otherwise.\n   * It's to reuse in TransactionBuilder and TransactionBuilderFactory\n   *\n   * @param rawTransaction Transaction as hex string\n   */\n  validateRawTransaction(rawTransaction: string): void {\n    if (!rawTransaction) {\n      throw new InvalidTransactionError('Raw transaction is empty');\n    }\n    if (!utils.allHexChars(rawTransaction)) {\n      throw new ParseTransactionError('Raw transaction is not hex string');\n    }\n  }\n\n  /**\n   * Check if tx is for the blockchainId\n   *\n   * @param {DeprecatedTx} tx\n   * @param {string} blockchainId\n   * @returns true if tx is for blockchainId\n   */\n  isTransactionOf(tx: DeprecatedTx, blockchainId: string): boolean {\n    // FlareJS equivalent - this would need proper CB58 encoding implementation\n    try {\n      const txRecord = tx as unknown as Record<string, unknown>;\n      const unsignedTx = (txRecord.getUnsignedTx as () => Record<string, unknown>)();\n      const transaction = (unsignedTx.getTransaction as () => Record<string, unknown>)();\n      const txBlockchainId = (transaction.getBlockchainID as () => unknown)();\n      return Buffer.from(txBlockchainId as string).toString('hex') === blockchainId;\n    } catch (error) {\n      return false;\n    }\n  }\n\n  /**\n   * Check if Output is from PVM.\n   * Output could be EVM or PVM output.\n   * @param {DeprecatedOutput} output\n   * @returns {boolean} output has transferable output structure\n   */\n  deprecatedIsTransferableOutput(output: DeprecatedOutput): boolean {\n    return 'getOutput' in (output as Record<string, unknown>);\n  }\n\n  /**\n   * Check if Output is from PVM.\n   * Output could be EVM or PVM output.\n   * @param {Output} output\n   * @returns {boolean} output is TransferableOutput\n   */\n  isTransferableOutput(output: Output): output is TransferableOutput {\n    return typeof (output as unknown as Record<string, unknown>).getOutput === 'function';\n  }\n\n  /**\n   * Return a mapper function to that network address representation.\n   * @param network required to stringify addresses\n   * @return mapper function\n   */\n  deprecatedMapOutputToEntry(network: FlareNetwork): (output: DeprecatedOutput) => Entry {\n    return (output: DeprecatedOutput) => {\n      if (this.deprecatedIsTransferableOutput(output)) {\n        // Simplified implementation for FlareJS\n        try {\n          const transferableOutput = output as unknown as TransferableOutput;\n          const amount = transferableOutput.amount();\n\n          // Simplified address handling - would need proper FlareJS address utilities\n          const address = 'flare-address-placeholder'; // TODO: implement proper address conversion\n\n          return {\n            value: amount.toString(),\n            address,\n          };\n        } catch (error) {\n          throw new Error(`Failed to map output: ${error}`);\n        }\n      } else {\n        // Handle EVM output case - simplified\n        return {\n          value: '0', // TODO: implement proper amount extraction\n          address: '0x0000000000000000000000000000000000000000', // TODO: implement proper address extraction\n        };\n      }\n    };\n  }\n\n  /**\n   * Return a mapper function to that network address representation.\n   * @param network required to stringify addresses\n   * @return mapper function\n   */\n  mapOutputToEntry(network: FlareNetwork): (Output) => Entry {\n    return (output: Output) => {\n      if (this.isTransferableOutput(output)) {\n        const transferableOutput = output as TransferableOutput;\n        const outputAmount = transferableOutput.amount();\n\n        // Simplified address handling for FlareJS\n        const address = 'flare-address-placeholder'; // TODO: implement proper address conversion\n\n        return {\n          value: outputAmount.toString(),\n          address,\n        };\n      } else {\n        throw new Error('Invalid output type');\n      }\n    };\n  }\n\n  /**\n   * remove hex prefix (0x)\n   * @param hex string\n   * @returns hex without 0x\n   */\n  removeHexPrefix(hex: string): string {\n    if (hex.startsWith('0x')) {\n      return hex.substring(2);\n    }\n    return hex;\n  }\n\n  /**\n   * Outputidx convert from number (as string) to buffer.\n   * @param {string} outputidx number\n   * @return {Buffer} buffer of size 4 with that number value\n   */\n  outputidxNumberToBuffer(outputidx: string): Buffer {\n    return Buffer.from(Number(outputidx).toString(16).padStart(OUTPUT_INDEX_HEX_LENGTH, '0'), 'hex');\n  }\n\n  /**\n   * Outputidx buffer to number (as string)\n   * @param {Buffer} outputidx\n   * @return {string} outputidx number\n   */\n  outputidxBufferToNumber(outputidx: Buffer): string {\n    return parseInt(outputidx.toString('hex'), 16).toString();\n  }\n\n  /**\n   * CB58 decode function - simple Base58 decode implementation\n   * @param {string} data - CB58 encoded string\n   * @returns {Buffer} decoded buffer\n   */\n  cb58Decode(data: string): Buffer {\n    // For now, use a simple hex decode as placeholder\n    // In a full implementation, this would be proper CB58 decoding\n    try {\n      return Buffer.from(data, 'hex');\n    } catch {\n      // Fallback to buffer from string\n      return Buffer.from(data);\n    }\n  }\n\n  /**\n   * Convert address buffer to bech32 string\n   * @param {string} hrp - Human readable part\n   * @param {string} chainid - Chain identifier\n   * @param {Buffer} addressBuffer - Address buffer\n   * @returns {string} Address string\n   */\n  addressToString(hrp: string, chainid: string, addressBuffer: Buffer): string {\n    // Simple implementation - in practice this would use bech32 encoding\n    return `${chainid}-${addressBuffer.toString('hex')}`;\n  }\n}\n\nconst utils = new Utils();\n\nexport default utils;\n"]}
487
+ //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"utils.js","sourceRoot":"","sources":["../../../src/lib/utils.ts"],"names":[],"mappings":"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","sourcesContent":["import { TransferableOutput } from '@flarenetwork/flarejs';\nimport {\n  BaseUtils,\n  Entry,\n  InvalidTransactionError,\n  isValidXprv,\n  isValidXpub,\n  NotImplementedError,\n  ParseTransactionError,\n} from '@bitgo-beta/sdk-core';\nimport { FlareNetwork } from '@bitgo-beta/statics';\nimport { ecc } from '@bitgo-beta/secp256k1';\nimport { createHash } from 'crypto';\nimport { DeprecatedOutput, DeprecatedTx, Output } from './iface';\nimport {\n  DECODED_BLOCK_ID_LENGTH,\n  SHORT_PUB_KEY_LENGTH,\n  COMPRESSED_PUBLIC_KEY_LENGTH,\n  UNCOMPRESSED_PUBLIC_KEY_LENGTH,\n  RAW_PRIVATE_KEY_LENGTH,\n  SUFFIXED_PRIVATE_KEY_LENGTH,\n  PRIVATE_KEY_COMPRESSED_SUFFIX,\n  OUTPUT_INDEX_HEX_LENGTH,\n  ADDRESS_REGEX,\n  HEX_REGEX,\n} from './constants';\n\nexport class Utils implements BaseUtils {\n  public includeIn(walletAddresses: string[], otxoOutputAddresses: string[]): boolean {\n    return walletAddresses.map((a) => otxoOutputAddresses.includes(a)).reduce((a, b) => a && b, true);\n  }\n\n  /**\n   * Checks if it is a valid address no illegal characters\n   *\n   * @param {string} address - address to be validated\n   * @returns {boolean} - the validation result\n   */\n  /** @inheritdoc */\n  isValidAddress(address: string | string[]): boolean {\n    const addressArr: string[] = Array.isArray(address) ? address : address.split('~');\n\n    for (const address of addressArr) {\n      if (!this.isValidAddressRegex(address)) {\n        return false;\n      }\n    }\n\n    return true;\n  }\n\n  private isValidAddressRegex(address: string): boolean {\n    return ADDRESS_REGEX.test(address);\n  }\n\n  /**\n   * Checks if it is a valid blockId with length 66 including 0x\n   *\n   * @param {string} hash - blockId to be validated\n   * @returns {boolean} - the validation result\n   */\n  /** @inheritdoc */\n  isValidBlockId(hash: string): boolean {\n    // FlareJS equivalent - check if it's a valid CB58 hash with correct length\n    try {\n      const decoded = Buffer.from(hash); // FlareJS should provide CB58 utilities\n      return decoded.length === DECODED_BLOCK_ID_LENGTH;\n    } catch {\n      return false;\n    }\n  }\n\n  /**\n   * Checks if the string is a valid protocol public key or\n   * extended public key.\n   *\n   * @param {string} pub - the  public key to be validated\n   * @returns {boolean} - the validation result\n   */\n  isValidPublicKey(pub: string): boolean {\n    if (isValidXpub(pub)) return true;\n\n    let pubBuf: Buffer;\n    if (pub.length === SHORT_PUB_KEY_LENGTH) {\n      try {\n        // For FlareJS, we'll need to implement CB58 decode functionality\n        pubBuf = Buffer.from(pub, 'hex'); // Temporary placeholder\n      } catch {\n        return false;\n      }\n    } else {\n      if (pub.length !== COMPRESSED_PUBLIC_KEY_LENGTH && pub.length !== UNCOMPRESSED_PUBLIC_KEY_LENGTH) {\n        return false;\n      }\n\n      const firstByte = pub.slice(0, 2);\n\n      // uncompressed public key\n      if (pub.length === UNCOMPRESSED_PUBLIC_KEY_LENGTH && firstByte !== '04') {\n        return false;\n      }\n\n      // compressed public key\n      if (pub.length === COMPRESSED_PUBLIC_KEY_LENGTH && firstByte !== '02' && firstByte !== '03') {\n        return false;\n      }\n\n      if (!this.allHexChars(pub)) return false;\n      pubBuf = Buffer.from(pub, 'hex');\n    }\n    // validate the public key using BitGo secp256k1\n    try {\n      ecc.isPoint(pubBuf); // Check if it's a valid point\n      return true;\n    } catch (e) {\n      return false;\n    }\n  }\n\n  public parseAddress = (pub: string): Buffer => {\n    // FlareJS equivalent for address parsing\n    return Buffer.from(pub, 'hex'); // Simplified implementation\n  };\n\n  /**\n   * Returns whether or not the string is a valid protocol private key, or extended\n   * private key.\n   *\n   * The protocol key format is described in the @stacks/transactions npm package, in the\n   * createStacksPrivateKey function:\n   * https://github.com/blockstack/stacks.js/blob/master/packages/transactions/src/keys.ts#L125\n   *\n   * @param {string} prv - the private key (or extended private key) to be validated\n   * @returns {boolean} - the validation result\n   */\n  isValidPrivateKey(prv: string): boolean {\n    if (isValidXprv(prv)) return true;\n\n    if (prv.length !== RAW_PRIVATE_KEY_LENGTH && prv.length !== SUFFIXED_PRIVATE_KEY_LENGTH) {\n      return false;\n    }\n\n    if (\n      prv.length === SUFFIXED_PRIVATE_KEY_LENGTH &&\n      prv.slice(RAW_PRIVATE_KEY_LENGTH) !== PRIVATE_KEY_COMPRESSED_SUFFIX\n    ) {\n      return false;\n    }\n\n    return this.allHexChars(prv);\n  }\n\n  /**\n   * Returns whether or not the string is a composed of hex chars only\n   *\n   * @param {string} maybe - the  string to be validated\n   * @returns {boolean} - the validation result\n   */\n  allHexChars(maybe: string): boolean {\n    return HEX_REGEX.test(maybe);\n  }\n\n  /**\n   * Lightweight Ethereum address validation\n   * Validates that an address is a 40-character hex string (optionally prefixed with 0x)\n   *\n   * @param {string} address - the Ethereum address to validate\n   * @returns {boolean} - true if valid Ethereum address format\n   */\n  isValidEthereumAddress(address: string): boolean {\n    if (!address || typeof address !== 'string') {\n      return false;\n    }\n\n    // Remove 0x prefix if present\n    const cleanAddress = address.startsWith('0x') ? address.slice(2) : address;\n\n    // Check if it's exactly 40 hex characters\n    return cleanAddress.length === 40 && /^[0-9a-fA-F]{40}$/.test(cleanAddress);\n  }\n\n  /**\n   * Pick specific properties from an object (replaces lodash.pick)\n   *\n   * @param {T} obj - the source object\n   * @param {K[]} keys - array of property keys to pick\n   * @returns {Pick<T, K>} - new object with only the specified properties\n   */\n  pick<T, K extends keyof T>(obj: T, keys: K[]): Pick<T, K> {\n    const result = {} as Pick<T, K>;\n    for (const key of keys) {\n      if (Object.prototype.hasOwnProperty.call(obj, key)) {\n        result[key] = obj[key];\n      }\n    }\n    return result;\n  }\n\n  /**\n   * Deep equality comparison (replaces lodash.isEqual)\n   *\n   * @param {unknown} a - first value to compare\n   * @param {unknown} b - second value to compare\n   * @returns {boolean} - true if values are deeply equal\n   */\n  isEqual(a: unknown, b: unknown): boolean {\n    if (a === b) return true;\n\n    if (a === null || a === undefined || b === null || b === undefined) return a === b;\n\n    if (typeof a !== typeof b) return false;\n\n    if (typeof a === 'object') {\n      if (Array.isArray(a) !== Array.isArray(b)) return false;\n\n      if (Array.isArray(a)) {\n        const arrB = b as unknown[];\n        if (a.length !== arrB.length) return false;\n        for (let i = 0; i < a.length; i++) {\n          if (!this.isEqual(a[i], arrB[i])) return false;\n        }\n        return true;\n      }\n\n      const objA = a as Record<string, unknown>;\n      const objB = b as Record<string, unknown>;\n      const keysA = Object.keys(objA);\n      const keysB = Object.keys(objB);\n      if (keysA.length !== keysB.length) return false;\n\n      for (const key of keysA) {\n        if (!keysB.includes(key)) return false;\n        if (!this.isEqual(objA[key], objB[key])) return false;\n      }\n      return true;\n    }\n\n    return false;\n  }\n\n  /** @inheritdoc */\n  isValidSignature(signature: string): boolean {\n    throw new NotImplementedError('isValidSignature not implemented');\n  }\n\n  /** @inheritdoc */\n  isValidTransactionId(txId: string): boolean {\n    throw new NotImplementedError('isValidTransactionId not implemented');\n  }\n\n  /**\n   * FlareJS wrapper to create signature and return it for credentials\n   * @param network\n   * @param message\n   * @param prv\n   * @return signature\n   */\n  createSignature(network: FlareNetwork, message: Buffer, prv: Buffer): Buffer {\n    // Use BitGo secp256k1 since FlareJS may not expose KeyPair in the same way\n    try {\n      const signature = ecc.sign(message, prv);\n      return Buffer.from(signature);\n    } catch (error) {\n      throw new Error(`Failed to create signature: ${error}`);\n    }\n  }\n\n  /**\n   * FlareJS wrapper to verify signature\n   * @param network\n   * @param message\n   * @param signature\n   * @param publicKey - public key instead of private key for verification\n   * @return true if it's verify successful\n   */\n  verifySignature(network: FlareNetwork, message: Buffer, signature: Buffer, publicKey: Buffer): boolean {\n    try {\n      return ecc.verify(message, publicKey, signature);\n    } catch (error) {\n      return false;\n    }\n  }\n\n  /**\n   * FlareJS wrapper to recover signature\n   * @param network\n   * @param message\n   * @param signature\n   * @return recovered public key\n   */\n  recoverySignature(network: FlareNetwork, message: Buffer, signature: Buffer): Buffer {\n    try {\n      // This would need to be implemented with secp256k1 recovery\n      // For now, throwing error since recovery logic would need to be adapted\n      throw new NotImplementedError('recoverySignature not fully implemented for FlareJS');\n    } catch (error) {\n      throw new Error(`Failed to recover signature: ${error}`);\n    }\n  }\n\n  sha256(buf: Uint8Array): Buffer {\n    return createHash('sha256').update(buf).digest();\n  }\n\n  /**\n   * Check the raw transaction has a valid format in the blockchain context, throw otherwise.\n   * It's to reuse in TransactionBuilder and TransactionBuilderFactory\n   *\n   * @param rawTransaction Transaction as hex string\n   */\n  validateRawTransaction(rawTransaction: string): void {\n    if (!rawTransaction) {\n      throw new InvalidTransactionError('Raw transaction is empty');\n    }\n    if (!utils.allHexChars(rawTransaction)) {\n      throw new ParseTransactionError('Raw transaction is not hex string');\n    }\n  }\n\n  /**\n   * Check if tx is for the blockchainId\n   *\n   * @param {DeprecatedTx} tx\n   * @param {string} blockchainId\n   * @returns true if tx is for blockchainId\n   */\n  isTransactionOf(tx: DeprecatedTx, blockchainId: string): boolean {\n    // FlareJS equivalent - this would need proper CB58 encoding implementation\n    try {\n      const txRecord = tx as unknown as Record<string, unknown>;\n      const unsignedTx = (txRecord.getUnsignedTx as () => Record<string, unknown>)();\n      const transaction = (unsignedTx.getTransaction as () => Record<string, unknown>)();\n      const txBlockchainId = (transaction.getBlockchainID as () => unknown)();\n      return Buffer.from(txBlockchainId as string).toString('hex') === blockchainId;\n    } catch (error) {\n      return false;\n    }\n  }\n\n  /**\n   * Check if Output is from PVM.\n   * Output could be EVM or PVM output.\n   * @param {DeprecatedOutput} output\n   * @returns {boolean} output has transferable output structure\n   */\n  deprecatedIsTransferableOutput(output: DeprecatedOutput): boolean {\n    return 'getOutput' in (output as Record<string, unknown>);\n  }\n\n  /**\n   * Check if Output is from PVM.\n   * Output could be EVM or PVM output.\n   * @param {Output} output\n   * @returns {boolean} output is TransferableOutput\n   */\n  isTransferableOutput(output: Output): output is TransferableOutput {\n    return typeof (output as unknown as Record<string, unknown>).getOutput === 'function';\n  }\n\n  /**\n   * Return a mapper function to that network address representation.\n   * @param network required to stringify addresses\n   * @return mapper function\n   */\n  deprecatedMapOutputToEntry(network: FlareNetwork): (output: DeprecatedOutput) => Entry {\n    return (output: DeprecatedOutput) => {\n      if (this.deprecatedIsTransferableOutput(output)) {\n        // Simplified implementation for FlareJS\n        try {\n          const transferableOutput = output as unknown as TransferableOutput;\n          const amount = transferableOutput.amount();\n\n          // Simplified address handling - would need proper FlareJS address utilities\n          const address = 'flare-address-placeholder'; // TODO: implement proper address conversion\n\n          return {\n            value: amount.toString(),\n            address,\n          };\n        } catch (error) {\n          throw new Error(`Failed to map output: ${error}`);\n        }\n      } else {\n        // Handle EVM output case - simplified\n        return {\n          value: '0', // TODO: implement proper amount extraction\n          address: '0x0000000000000000000000000000000000000000', // TODO: implement proper address extraction\n        };\n      }\n    };\n  }\n\n  /**\n   * Return a mapper function to that network address representation.\n   * @param network required to stringify addresses\n   * @return mapper function\n   */\n  mapOutputToEntry(network: FlareNetwork): (Output) => Entry {\n    return (output: Output) => {\n      if (this.isTransferableOutput(output)) {\n        const transferableOutput = output as TransferableOutput;\n        const outputAmount = transferableOutput.amount();\n\n        // Simplified address handling for FlareJS\n        const address = 'flare-address-placeholder'; // TODO: implement proper address conversion\n\n        return {\n          value: outputAmount.toString(),\n          address,\n        };\n      } else {\n        throw new Error('Invalid output type');\n      }\n    };\n  }\n\n  /**\n   * remove hex prefix (0x)\n   * @param hex string\n   * @returns hex without 0x\n   */\n  removeHexPrefix(hex: string): string {\n    if (hex.startsWith('0x')) {\n      return hex.substring(2);\n    }\n    return hex;\n  }\n\n  /**\n   * Outputidx convert from number (as string) to buffer.\n   * @param {string} outputidx number\n   * @return {Buffer} buffer of size 4 with that number value\n   */\n  outputidxNumberToBuffer(outputidx: string): Buffer {\n    return Buffer.from(Number(outputidx).toString(16).padStart(OUTPUT_INDEX_HEX_LENGTH, '0'), 'hex');\n  }\n\n  /**\n   * Outputidx buffer to number (as string)\n   * @param {Buffer} outputidx\n   * @return {string} outputidx number\n   */\n  outputidxBufferToNumber(outputidx: Buffer): string {\n    return parseInt(outputidx.toString('hex'), 16).toString();\n  }\n\n  /**\n   * CB58 decode function - simple Base58 decode implementation\n   * @param {string} data - CB58 encoded string\n   * @returns {Buffer} decoded buffer\n   */\n  cb58Decode(data: string): Buffer {\n    // For now, use a simple hex decode as placeholder\n    // In a full implementation, this would be proper CB58 decoding\n    try {\n      return Buffer.from(data, 'hex');\n    } catch {\n      // Fallback to buffer from string\n      return Buffer.from(data);\n    }\n  }\n\n  /**\n   * Convert address buffer to bech32 string\n   * @param {string} hrp - Human readable part\n   * @param {string} chainid - Chain identifier\n   * @param {Buffer} addressBuffer - Address buffer\n   * @returns {string} Address string\n   */\n  addressToString(hrp: string, chainid: string, addressBuffer: Buffer): string {\n    // Simple implementation - in practice this would use bech32 encoding\n    return `${chainid}-${addressBuffer.toString('hex')}`;\n  }\n\n  /**\n   * Convert string to bytes for FlareJS memo\n   * Follows FlareJS utils.stringToBytes pattern\n   * @param {string} text - Text to convert\n   * @returns {Uint8Array} Byte array\n   */\n  stringToBytes(text: string): Uint8Array {\n    return new TextEncoder().encode(text);\n  }\n\n  /**\n   * Convert bytes to string from FlareJS memo\n   * @param {Uint8Array} bytes - Bytes to convert\n   * @returns {string} Decoded string\n   */\n  bytesToString(bytes: Uint8Array): string {\n    return new TextDecoder().decode(bytes);\n  }\n\n  /**\n   * Create memo bytes from various input formats\n   * Supports string, JSON object, or raw bytes\n   * @param {string | Record<string, unknown> | Uint8Array} memo - Memo data\n   * @returns {Uint8Array} Memo bytes for FlareJS\n   */\n  createMemoBytes(memo: string | Record<string, unknown> | Uint8Array): Uint8Array {\n    if (memo instanceof Uint8Array) {\n      return memo;\n    }\n\n    if (typeof memo === 'string') {\n      return this.stringToBytes(memo);\n    }\n\n    if (typeof memo === 'object') {\n      return this.stringToBytes(JSON.stringify(memo));\n    }\n\n    throw new InvalidTransactionError('Invalid memo format');\n  }\n\n  /**\n   * Parse memo bytes to string\n   * @param {Uint8Array} memoBytes - Memo bytes from FlareJS transaction\n   * @returns {string} Decoded memo string\n   */\n  parseMemoBytes(memoBytes: Uint8Array): string {\n    if (memoBytes.length === 0) {\n      return '';\n    }\n    return this.bytesToString(memoBytes);\n  }\n\n  /**\n   * Validate memo size (FlareJS has transaction size limits)\n   * @param {Uint8Array} memoBytes - Memo bytes\n   * @param {number} maxSize - Maximum size in bytes (default 4KB)\n   * @returns {boolean} Whether memo is within size limits\n   */\n  validateMemoSize(memoBytes: Uint8Array, maxSize = 4096): boolean {\n    return memoBytes.length <= maxSize;\n  }\n}\n\nconst utils = new Utils();\n\nexport default utils;\n"]}
@@ -161,23 +161,49 @@ describe('AtomicTransactionBuilder', function () {
161
161
  });
162
162
  });
163
163
  describe('createInputOutput', function () {
164
- it('should return placeholder structure', function () {
165
- const result = builder.testCreateInputOutput(100n);
164
+ const sampleUtxos = [
165
+ {
166
+ outputID: 7,
167
+ amount: '1000000',
168
+ txid: '1234567890abcdef1234567890abcdef12345678',
169
+ outputidx: '0',
170
+ threshold: 2,
171
+ addresses: ['P-test1234567890abcdef', 'P-test567890abcdef1234'],
172
+ },
173
+ {
174
+ outputID: 7,
175
+ amount: '500000',
176
+ txid: 'abcdef1234567890abcdef1234567890abcdef12',
177
+ outputidx: '1',
178
+ threshold: 2,
179
+ addresses: ['P-test1234567890abcdef', 'P-test567890abcdef1234'],
180
+ },
181
+ ];
182
+ it('should return empty structure when no UTXOs set', function () {
183
+ assert.throws(() => builder.testCreateInputOutput(100n), /UTXOs are required for creating inputs and outputs/);
184
+ });
185
+ it('should process UTXOs and return structured output', function () {
186
+ // Set UTXOs first
187
+ builder.utxos(sampleUtxos);
188
+ const result = builder.testCreateInputOutput(100000n);
166
189
  assert.ok('inputs' in result);
167
190
  assert.ok('outputs' in result);
168
191
  assert.ok('credentials' in result);
169
192
  assert.ok(Array.isArray(result.inputs));
170
- assert.strictEqual(result.inputs.length, 0);
171
193
  assert.ok(Array.isArray(result.outputs));
172
- assert.strictEqual(result.outputs.length, 0);
173
194
  assert.ok(Array.isArray(result.credentials));
174
- assert.strictEqual(result.credentials.length, 0);
195
+ assert.strictEqual(result.credentials.length, 1); // Should create credential for first UTXO
175
196
  });
176
- it('should handle different amounts', function () {
177
- const result1 = builder.testCreateInputOutput(1n);
178
- const result2 = builder.testCreateInputOutput(BigInt('1000000000'));
179
- // Both should return same placeholder structure regardless of amount
180
- assert.deepStrictEqual(result1, result2);
197
+ it('should handle insufficient funds', function () {
198
+ builder.utxos(sampleUtxos);
199
+ // Request more than available (total available is 1,500,000)
200
+ assert.throws(() => builder.testCreateInputOutput(2000000n), /Insufficient funds: need 2000000, have 1500000/);
201
+ });
202
+ it('should use multiple UTXOs when needed', function () {
203
+ builder.utxos(sampleUtxos);
204
+ // Request amount that requires both UTXOs
205
+ const result = builder.testCreateInputOutput(1200000n);
206
+ assert.strictEqual(result.credentials.length, 2); // Should use both UTXOs
181
207
  });
182
208
  });
183
209
  describe('initBuilder', function () {
@@ -193,4 +219,4 @@ describe('AtomicTransactionBuilder', function () {
193
219
  });
194
220
  });
195
221
  });
196
- //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"atomicTransactionBuilder.js","sourceRoot":"","sources":["../../../../test/unit/lib/atomicTransactionBuilder.ts"],"names":[],"mappings":"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","sourcesContent":["import { coins } from '@bitgo-beta/statics';\nimport { BuildTransactionError, TransactionType } from '@bitgo-beta/sdk-core';\nimport * as assert from 'assert';\nimport { Credential, Signature } from '@flarenetwork/flarejs';\nimport { AtomicTransactionBuilder } from '../../../src/lib/atomicTransactionBuilder';\n\n// Concrete implementation for testing\nclass TestAtomicTransactionBuilder extends AtomicTransactionBuilder {\n  protected get transactionType(): TransactionType {\n    return TransactionType.Send;\n  }\n\n  // Expose protected method for testing\n  public testCreateFlareCredential(credentialId: number, signatures: string[]): Credential {\n    return this.createFlareCredential(credentialId, signatures);\n  }\n\n  // Expose protected method for testing\n  public testValidateCredentials(credentials: Credential[]): void {\n    return this.validateCredentials(credentials);\n  }\n\n  // Expose protected method for testing\n  public testCreateInputOutput(total: bigint) {\n    return this.createInputOutput(total);\n  }\n}\n\ndescribe('AtomicTransactionBuilder', function () {\n  let builder: TestAtomicTransactionBuilder;\n  const coinConfig = coins.get('flrp');\n\n  beforeEach(function () {\n    builder = new TestAtomicTransactionBuilder(coinConfig);\n  });\n\n  describe('constructor', function () {\n    it('should create instance with proper coin config', function () {\n      assert.ok(builder instanceof AtomicTransactionBuilder);\n      assert.strictEqual(builder['_coinConfig'], coinConfig);\n    });\n\n    it('should initialize transaction state properly', function () {\n      const transaction = builder['transaction'];\n      assert.strictEqual(typeof transaction._network, 'object');\n      assert.strictEqual(transaction._networkID, 0);\n      assert.ok(Array.isArray(transaction._fromAddresses));\n      assert.strictEqual(transaction._fromAddresses.length, 0);\n      assert.ok(Array.isArray(transaction._to));\n      assert.strictEqual(transaction._to.length, 0);\n      assert.strictEqual(transaction._locktime, 0n);\n      assert.strictEqual(transaction._threshold, 1);\n      assert.strictEqual(transaction._fee.fee, '0');\n      assert.strictEqual(transaction.hasCredentials, false);\n    });\n  });\n\n  describe('validateAmount', function () {\n    it('should accept positive amounts', function () {\n      assert.doesNotThrow(() => builder.validateAmount(1n));\n      assert.doesNotThrow(() => builder.validateAmount(100n));\n      assert.doesNotThrow(() => builder.validateAmount(BigInt('1000000000000000000')));\n    });\n\n    it('should reject zero amount', function () {\n      assert.throws(() => builder.validateAmount(0n), BuildTransactionError, 'Amount must be positive');\n    });\n\n    it('should reject negative amounts', function () {\n      assert.throws(() => builder.validateAmount(-1n), BuildTransactionError, 'Amount must be positive');\n      assert.throws(() => builder.validateAmount(-100n), BuildTransactionError, 'Amount must be positive');\n    });\n  });\n\n  describe('createFlareCredential', function () {\n    const validHexSignature = '3045022100' + '0'.repeat(56) + '02200' + '1'.repeat(55);\n\n    it('should create credential with valid signatures', function () {\n      const signatures = [validHexSignature, ''];\n      const credential = builder.testCreateFlareCredential(0, signatures);\n\n      assert.ok(credential instanceof Credential);\n      const sigArray = credential.getSignatures();\n      assert.strictEqual(sigArray.length, 2);\n    });\n\n    it('should handle empty signatures as placeholders', function () {\n      const signatures = ['', ''];\n      const credential = builder.testCreateFlareCredential(0, signatures);\n\n      assert.ok(credential instanceof Credential);\n      const sigArray = credential.getSignatures();\n      assert.strictEqual(sigArray.length, 2);\n    });\n\n    it('should handle hex signatures with 0x prefix', function () {\n      const signatures = [`0x${validHexSignature}`];\n      const credential = builder.testCreateFlareCredential(0, signatures);\n\n      assert.ok(credential instanceof Credential);\n      const sigArray = credential.getSignatures();\n      assert.strictEqual(sigArray.length, 1);\n    });\n\n    it('should throw error for non-array signatures', function () {\n      assert.throws(\n        () => builder.testCreateFlareCredential(0, 'invalid' as unknown as string[]),\n        BuildTransactionError,\n        'Signatures must be an array'\n      );\n    });\n\n    it('should throw error for empty signatures array', function () {\n      assert.throws(\n        () => builder.testCreateFlareCredential(0, []),\n        BuildTransactionError,\n        'Signatures array cannot be empty'\n      );\n    });\n\n    it('should throw error for invalid hex characters', function () {\n      const invalidSig = '304502210xyz'; // Contains invalid hex chars\n      assert.throws(\n        () => builder.testCreateFlareCredential(0, [invalidSig]),\n        BuildTransactionError,\n        'Invalid hex signature at index 0: contains non-hex characters'\n      );\n    });\n\n    it('should throw error for signatures that are too long', function () {\n      const longSig = 'a'.repeat(200); // 100 bytes, longer than 65\n      assert.throws(() => builder.testCreateFlareCredential(0, [longSig]), BuildTransactionError);\n    });\n\n    it('should handle signatures shorter than 65 bytes', function () {\n      const shortSig = 'abcd1234'; // 4 bytes\n      const credential = builder.testCreateFlareCredential(0, [shortSig]);\n\n      assert.ok(credential instanceof Credential);\n    });\n  });\n\n  describe('validateCredentials', function () {\n    it('should accept valid credentials array', function () {\n      const credential = new Credential([new Signature(new Uint8Array(65))]);\n      assert.doesNotThrow(() => builder.testValidateCredentials([credential]));\n    });\n\n    it('should accept empty credentials array', function () {\n      assert.doesNotThrow(() => builder.testValidateCredentials([]));\n    });\n\n    it('should throw error for non-array input', function () {\n      assert.throws(\n        () => builder.testValidateCredentials('invalid' as unknown as Credential[]),\n        BuildTransactionError,\n        'Credentials must be an array'\n      );\n    });\n\n    it('should throw error for invalid credential objects', function () {\n      const invalidCredentials = [{ fake: 'credential' }] as unknown as Credential[];\n      assert.throws(\n        () => builder.testValidateCredentials(invalidCredentials),\n        BuildTransactionError,\n        'Invalid credential at index 0'\n      );\n    });\n\n    it('should throw error for mixed valid/invalid credentials', function () {\n      const validCredential = new Credential([new Signature(new Uint8Array(65))]);\n      const invalidCredential = { fake: 'credential' };\n      const credentials = [validCredential, invalidCredential] as unknown as Credential[];\n\n      assert.throws(\n        () => builder.testValidateCredentials(credentials),\n        BuildTransactionError,\n        'Invalid credential at index 1'\n      );\n    });\n  });\n\n  describe('createInputOutput', function () {\n    it('should return placeholder structure', function () {\n      const result = builder.testCreateInputOutput(100n);\n\n      assert.ok('inputs' in result);\n      assert.ok('outputs' in result);\n      assert.ok('credentials' in result);\n\n      assert.ok(Array.isArray(result.inputs));\n      assert.strictEqual(result.inputs.length, 0);\n      assert.ok(Array.isArray(result.outputs));\n      assert.strictEqual(result.outputs.length, 0);\n      assert.ok(Array.isArray(result.credentials));\n      assert.strictEqual(result.credentials.length, 0);\n    });\n\n    it('should handle different amounts', function () {\n      const result1 = builder.testCreateInputOutput(1n);\n      const result2 = builder.testCreateInputOutput(BigInt('1000000000'));\n\n      // Both should return same placeholder structure regardless of amount\n      assert.deepStrictEqual(result1, result2);\n    });\n  });\n\n  describe('initBuilder', function () {\n    it('should return this for fluent API', function () {\n      const result = builder.initBuilder({});\n      assert.strictEqual(result, builder);\n    });\n\n    it('should handle different transaction objects', function () {\n      const tx1 = { id: '123' };\n      const tx2 = { data: 'test' };\n\n      assert.strictEqual(builder.initBuilder(tx1), builder);\n      assert.strictEqual(builder.initBuilder(tx2), builder);\n    });\n  });\n});\n"]}
222
+ //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"atomicTransactionBuilder.js","sourceRoot":"","sources":["../../../../test/unit/lib/atomicTransactionBuilder.ts"],"names":[],"mappings":"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","sourcesContent":["import { coins } from '@bitgo-beta/statics';\nimport { BuildTransactionError, TransactionType } from '@bitgo-beta/sdk-core';\nimport * as assert from 'assert';\nimport { Credential, Signature } from '@flarenetwork/flarejs';\nimport { AtomicTransactionBuilder } from '../../../src/lib/atomicTransactionBuilder';\n\n// Concrete implementation for testing\nclass TestAtomicTransactionBuilder extends AtomicTransactionBuilder {\n  protected get transactionType(): TransactionType {\n    return TransactionType.Send;\n  }\n\n  // Expose protected method for testing\n  public testCreateFlareCredential(credentialId: number, signatures: string[]): Credential {\n    return this.createFlareCredential(credentialId, signatures);\n  }\n\n  // Expose protected method for testing\n  public testValidateCredentials(credentials: Credential[]): void {\n    return this.validateCredentials(credentials);\n  }\n\n  // Expose protected method for testing\n  public testCreateInputOutput(total: bigint) {\n    return this.createInputOutput(total);\n  }\n}\n\ndescribe('AtomicTransactionBuilder', function () {\n  let builder: TestAtomicTransactionBuilder;\n  const coinConfig = coins.get('flrp');\n\n  beforeEach(function () {\n    builder = new TestAtomicTransactionBuilder(coinConfig);\n  });\n\n  describe('constructor', function () {\n    it('should create instance with proper coin config', function () {\n      assert.ok(builder instanceof AtomicTransactionBuilder);\n      assert.strictEqual(builder['_coinConfig'], coinConfig);\n    });\n\n    it('should initialize transaction state properly', function () {\n      const transaction = builder['transaction'];\n      assert.strictEqual(typeof transaction._network, 'object');\n      assert.strictEqual(transaction._networkID, 0);\n      assert.ok(Array.isArray(transaction._fromAddresses));\n      assert.strictEqual(transaction._fromAddresses.length, 0);\n      assert.ok(Array.isArray(transaction._to));\n      assert.strictEqual(transaction._to.length, 0);\n      assert.strictEqual(transaction._locktime, 0n);\n      assert.strictEqual(transaction._threshold, 1);\n      assert.strictEqual(transaction._fee.fee, '0');\n      assert.strictEqual(transaction.hasCredentials, false);\n    });\n  });\n\n  describe('validateAmount', function () {\n    it('should accept positive amounts', function () {\n      assert.doesNotThrow(() => builder.validateAmount(1n));\n      assert.doesNotThrow(() => builder.validateAmount(100n));\n      assert.doesNotThrow(() => builder.validateAmount(BigInt('1000000000000000000')));\n    });\n\n    it('should reject zero amount', function () {\n      assert.throws(() => builder.validateAmount(0n), BuildTransactionError, 'Amount must be positive');\n    });\n\n    it('should reject negative amounts', function () {\n      assert.throws(() => builder.validateAmount(-1n), BuildTransactionError, 'Amount must be positive');\n      assert.throws(() => builder.validateAmount(-100n), BuildTransactionError, 'Amount must be positive');\n    });\n  });\n\n  describe('createFlareCredential', function () {\n    const validHexSignature = '3045022100' + '0'.repeat(56) + '02200' + '1'.repeat(55);\n\n    it('should create credential with valid signatures', function () {\n      const signatures = [validHexSignature, ''];\n      const credential = builder.testCreateFlareCredential(0, signatures);\n\n      assert.ok(credential instanceof Credential);\n      const sigArray = credential.getSignatures();\n      assert.strictEqual(sigArray.length, 2);\n    });\n\n    it('should handle empty signatures as placeholders', function () {\n      const signatures = ['', ''];\n      const credential = builder.testCreateFlareCredential(0, signatures);\n\n      assert.ok(credential instanceof Credential);\n      const sigArray = credential.getSignatures();\n      assert.strictEqual(sigArray.length, 2);\n    });\n\n    it('should handle hex signatures with 0x prefix', function () {\n      const signatures = [`0x${validHexSignature}`];\n      const credential = builder.testCreateFlareCredential(0, signatures);\n\n      assert.ok(credential instanceof Credential);\n      const sigArray = credential.getSignatures();\n      assert.strictEqual(sigArray.length, 1);\n    });\n\n    it('should throw error for non-array signatures', function () {\n      assert.throws(\n        () => builder.testCreateFlareCredential(0, 'invalid' as unknown as string[]),\n        BuildTransactionError,\n        'Signatures must be an array'\n      );\n    });\n\n    it('should throw error for empty signatures array', function () {\n      assert.throws(\n        () => builder.testCreateFlareCredential(0, []),\n        BuildTransactionError,\n        'Signatures array cannot be empty'\n      );\n    });\n\n    it('should throw error for invalid hex characters', function () {\n      const invalidSig = '304502210xyz'; // Contains invalid hex chars\n      assert.throws(\n        () => builder.testCreateFlareCredential(0, [invalidSig]),\n        BuildTransactionError,\n        'Invalid hex signature at index 0: contains non-hex characters'\n      );\n    });\n\n    it('should throw error for signatures that are too long', function () {\n      const longSig = 'a'.repeat(200); // 100 bytes, longer than 65\n      assert.throws(() => builder.testCreateFlareCredential(0, [longSig]), BuildTransactionError);\n    });\n\n    it('should handle signatures shorter than 65 bytes', function () {\n      const shortSig = 'abcd1234'; // 4 bytes\n      const credential = builder.testCreateFlareCredential(0, [shortSig]);\n\n      assert.ok(credential instanceof Credential);\n    });\n  });\n\n  describe('validateCredentials', function () {\n    it('should accept valid credentials array', function () {\n      const credential = new Credential([new Signature(new Uint8Array(65))]);\n      assert.doesNotThrow(() => builder.testValidateCredentials([credential]));\n    });\n\n    it('should accept empty credentials array', function () {\n      assert.doesNotThrow(() => builder.testValidateCredentials([]));\n    });\n\n    it('should throw error for non-array input', function () {\n      assert.throws(\n        () => builder.testValidateCredentials('invalid' as unknown as Credential[]),\n        BuildTransactionError,\n        'Credentials must be an array'\n      );\n    });\n\n    it('should throw error for invalid credential objects', function () {\n      const invalidCredentials = [{ fake: 'credential' }] as unknown as Credential[];\n      assert.throws(\n        () => builder.testValidateCredentials(invalidCredentials),\n        BuildTransactionError,\n        'Invalid credential at index 0'\n      );\n    });\n\n    it('should throw error for mixed valid/invalid credentials', function () {\n      const validCredential = new Credential([new Signature(new Uint8Array(65))]);\n      const invalidCredential = { fake: 'credential' };\n      const credentials = [validCredential, invalidCredential] as unknown as Credential[];\n\n      assert.throws(\n        () => builder.testValidateCredentials(credentials),\n        BuildTransactionError,\n        'Invalid credential at index 1'\n      );\n    });\n  });\n\n  describe('createInputOutput', function () {\n    const sampleUtxos = [\n      {\n        outputID: 7,\n        amount: '1000000',\n        txid: '1234567890abcdef1234567890abcdef12345678',\n        outputidx: '0',\n        threshold: 2,\n        addresses: ['P-test1234567890abcdef', 'P-test567890abcdef1234'],\n      },\n      {\n        outputID: 7,\n        amount: '500000',\n        txid: 'abcdef1234567890abcdef1234567890abcdef12',\n        outputidx: '1',\n        threshold: 2,\n        addresses: ['P-test1234567890abcdef', 'P-test567890abcdef1234'],\n      },\n    ];\n\n    it('should return empty structure when no UTXOs set', function () {\n      assert.throws(() => builder.testCreateInputOutput(100n), /UTXOs are required for creating inputs and outputs/);\n    });\n\n    it('should process UTXOs and return structured output', function () {\n      // Set UTXOs first\n      builder.utxos(sampleUtxos);\n\n      const result = builder.testCreateInputOutput(100000n);\n\n      assert.ok('inputs' in result);\n      assert.ok('outputs' in result);\n      assert.ok('credentials' in result);\n\n      assert.ok(Array.isArray(result.inputs));\n      assert.ok(Array.isArray(result.outputs));\n      assert.ok(Array.isArray(result.credentials));\n      assert.strictEqual(result.credentials.length, 1); // Should create credential for first UTXO\n    });\n\n    it('should handle insufficient funds', function () {\n      builder.utxos(sampleUtxos);\n\n      // Request more than available (total available is 1,500,000)\n      assert.throws(() => builder.testCreateInputOutput(2000000n), /Insufficient funds: need 2000000, have 1500000/);\n    });\n\n    it('should use multiple UTXOs when needed', function () {\n      builder.utxos(sampleUtxos);\n\n      // Request amount that requires both UTXOs\n      const result = builder.testCreateInputOutput(1200000n);\n\n      assert.strictEqual(result.credentials.length, 2); // Should use both UTXOs\n    });\n  });\n\n  describe('initBuilder', function () {\n    it('should return this for fluent API', function () {\n      const result = builder.initBuilder({});\n      assert.strictEqual(result, builder);\n    });\n\n    it('should handle different transaction objects', function () {\n      const tx1 = { id: '123' };\n      const tx2 = { data: 'test' };\n\n      assert.strictEqual(builder.initBuilder(tx1), builder);\n      assert.strictEqual(builder.initBuilder(tx2), builder);\n    });\n  });\n});\n"]}
@@ -0,0 +1,2 @@
1
+ export {};
2
+ //# sourceMappingURL=transaction.d.ts.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"transaction.d.ts","sourceRoot":"","sources":["../../../../test/unit/lib/transaction.ts"],"names":[],"mappings":""}