@bitgo-beta/sdk-coin-flrp 1.0.0-alpha.54 → 1.0.0-alpha.56

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.
@@ -48,14 +48,6 @@ class ImportInCTxBuilder extends atomicInCTransactionBuilder_1.AtomicInCTransact
48
48
  const totalOutputAmount = output.amount.value();
49
49
  // Calculate fee based on input/output difference
50
50
  const fee = totalInputAmount - totalOutputAmount;
51
- const feeSize = this.calculateFeeSize(baseTx);
52
- // Use integer division to ensure feeRate can be converted back to BigInt
53
- const feeRate = Math.floor(Number(fee) / feeSize);
54
- this.transaction._fee = {
55
- fee: fee.toString(),
56
- feeRate: feeRate,
57
- size: feeSize,
58
- };
59
51
  // Use credentials passed from TransactionBuilderFactory (properly extracted using codec)
60
52
  const credentials = parsedCredentials || [];
61
53
  const hasCredentials = credentials.length > 0;
@@ -67,9 +59,56 @@ class ImportInCTxBuilder extends atomicInCTransactionBuilder_1.AtomicInCTransact
67
59
  const firstInput = inputs[0];
68
60
  const inputThreshold = firstInput.sigIndicies().length || this.transaction._threshold;
69
61
  this.transaction._threshold = inputThreshold;
70
- // Create proper UnsignedTx wrapper with credentials
71
- const toAddress = new flarejs_1.Address(output.address.toBytes());
72
- const addressMap = new flarejs_1.utils.AddressMap([[toAddress, 0]]);
62
+ // Create a temporary UnsignedTx for accurate fee size calculation
63
+ // This includes the full structure (ImportTx, AddressMaps, Credentials)
64
+ const tempAddressMap = new flarejs_1.utils.AddressMap();
65
+ for (let i = 0; i < inputThreshold; i++) {
66
+ if (this.transaction._fromAddresses && this.transaction._fromAddresses[i]) {
67
+ tempAddressMap.set(new flarejs_1.Address(this.transaction._fromAddresses[i]), i);
68
+ }
69
+ }
70
+ const tempAddressMaps = new flarejs_1.utils.AddressMaps([tempAddressMap]);
71
+ const tempCredentials = credentials.length > 0 ? credentials : [new flarejs_1.Credential(Array(inputThreshold).fill(utils_1.default.createNewSig('')))];
72
+ const tempUnsignedTx = new flarejs_1.UnsignedTx(baseTx, [], tempAddressMaps, tempCredentials);
73
+ // Calculate cost units using the full UnsignedTx structure
74
+ const feeSize = this.calculateImportCost(tempUnsignedTx);
75
+ // Use integer division to ensure feeRate can be converted back to BigInt
76
+ const feeRate = Math.floor(Number(fee) / feeSize);
77
+ this.transaction._fee = {
78
+ fee: fee.toString(),
79
+ feeRate: feeRate,
80
+ size: feeSize,
81
+ };
82
+ // Create AddressMaps based on signature slot order (matching credential order), not sorted addresses
83
+ // This matches the approach used in credentials: addressesIndex determines signature order
84
+ // AddressMaps should map addresses to signature slots in the same order as credentials
85
+ // If _fromAddresses is available, create AddressMap based on UTXO order (matching credential order)
86
+ // Otherwise, fall back to mapping just the output address
87
+ const firstUtxo = this.transaction._utxos[0];
88
+ let addressMap;
89
+ if (firstUtxo &&
90
+ firstUtxo.addresses &&
91
+ firstUtxo.addresses.length > 0 &&
92
+ this.transaction._fromAddresses &&
93
+ this.transaction._fromAddresses.length >= this.transaction._threshold) {
94
+ // Use centralized method for AddressMap creation
95
+ addressMap = this.createAddressMapForUtxo(firstUtxo, this.transaction._threshold);
96
+ }
97
+ else {
98
+ // Fallback: map output address to slot 0 (for C-chain imports, output is the destination)
99
+ // Or map addresses sequentially if _fromAddresses is available but UTXO addresses are not
100
+ addressMap = new flarejs_1.utils.AddressMap();
101
+ if (this.transaction._fromAddresses && this.transaction._fromAddresses.length >= this.transaction._threshold) {
102
+ this.transaction._fromAddresses.slice(0, this.transaction._threshold).forEach((addr, i) => {
103
+ addressMap.set(new flarejs_1.Address(addr), i);
104
+ });
105
+ }
106
+ else {
107
+ // Last resort: map output address
108
+ const toAddress = new flarejs_1.Address(output.address.toBytes());
109
+ addressMap.set(toAddress, 0);
110
+ }
111
+ }
73
112
  const addressMaps = new flarejs_1.utils.AddressMaps([addressMap]);
74
113
  // When credentials were extracted, use them directly to preserve existing signatures
75
114
  // For initBuilder, _fromAddresses may not be set yet, so use all zeros for credential slots
@@ -110,24 +149,36 @@ class ImportInCTxBuilder extends atomicInCTransactionBuilder_1.AtomicInCTransact
110
149
  throw new Error('fee rate is required');
111
150
  }
112
151
  const { inputs, amount, credentials } = this.createInputs();
113
- // Calculate fee
152
+ // Calculate import cost units (matching AVAXP's costImportTx approach)
153
+ // Create a temporary UnsignedTx with full amount to calculate fee size
154
+ // This includes the full structure (ImportTx, AddressMaps, Credentials) for accurate size calculation
155
+ const tempOutput = new flarejs_1.evmSerial.Output(new flarejs_1.Address(this.transaction._to[0]), new flarejs_1.BigIntPr(amount), new flarejs_1.Id(new Uint8Array(Buffer.from(this.transaction._assetId, 'hex'))));
156
+ const tempImportTx = new flarejs_1.evmSerial.ImportTx(new flarejs_1.Int(this.transaction._networkID), new flarejs_1.Id(new Uint8Array(Buffer.from(this.transaction._blockchainID, 'hex'))), new flarejs_1.Id(new Uint8Array(this._externalChainId)), inputs, [tempOutput]);
157
+ // Create AddressMaps for fee calculation (same as final transaction)
158
+ const firstUtxo = this.transaction._utxos[0];
159
+ const tempAddressMap = firstUtxo
160
+ ? this.createAddressMapForUtxo(firstUtxo, this.transaction._threshold)
161
+ : new flarejs_1.utils.AddressMap();
162
+ const tempAddressMaps = new flarejs_1.utils.AddressMaps([tempAddressMap]);
163
+ // Create temporary UnsignedTx with full structure for accurate fee calculation
164
+ const tempUnsignedTx = new flarejs_1.UnsignedTx(tempImportTx, [], tempAddressMaps, credentials);
165
+ // Calculate feeSize once using full UnsignedTx (matching AVAXP approach)
166
+ const feeSize = this.calculateImportCost(tempUnsignedTx);
114
167
  const feeRate = BigInt(this.transaction._fee.feeRate);
115
- const feeSize = this.calculateFeeSize();
116
168
  const fee = feeRate * BigInt(feeSize);
169
+ // Validate that we have enough funds to cover the fee
170
+ if (amount <= fee) {
171
+ throw new sdk_core_1.BuildTransactionError(`Insufficient funds: have ${amount.toString()}, need more than ${fee.toString()} for fee`);
172
+ }
117
173
  this.transaction._fee.fee = fee.toString();
118
174
  this.transaction._fee.size = feeSize;
119
- // Create EVM output using proper FlareJS class
175
+ // Create EVM output using proper FlareJS class with amount minus fee
120
176
  const output = new flarejs_1.evmSerial.Output(new flarejs_1.Address(this.transaction._to[0]), new flarejs_1.BigIntPr(amount - fee), new flarejs_1.Id(new Uint8Array(Buffer.from(this.transaction._assetId, 'hex'))));
121
177
  // Create the import transaction
122
178
  const importTx = new flarejs_1.evmSerial.ImportTx(new flarejs_1.Int(this.transaction._networkID), new flarejs_1.Id(new Uint8Array(Buffer.from(this.transaction._blockchainID, 'hex'))), new flarejs_1.Id(new Uint8Array(this._externalChainId)), inputs, [output]);
123
- // Create unsigned transaction with all potential signers in address map
124
- const addressMap = new flarejs_1.utils.AddressMap();
125
- this.transaction._fromAddresses.forEach((addr, i) => {
126
- addressMap.set(new flarejs_1.Address(addr), i);
127
- });
128
- const addressMaps = new flarejs_1.utils.AddressMaps([addressMap]);
179
+ // Reuse the AddressMaps already calculated for fee calculation
129
180
  const unsignedTx = new flarejs_1.UnsignedTx(importTx, [], // Empty UTXOs array, will be filled during processing
130
- addressMaps, credentials);
181
+ tempAddressMaps, credentials);
131
182
  this.transaction.setTransaction(unsignedTx);
132
183
  }
133
184
  /**
@@ -167,37 +218,8 @@ class ImportInCTxBuilder extends atomicInCTransactionBuilder_1.AtomicInCTransact
167
218
  inputs.push(transferableInput);
168
219
  // Create credential with empty signatures for slot identification
169
220
  // Match avaxp behavior: dynamic ordering based on addressesIndex from UTXO
170
- const hasAddresses = this.transaction._fromAddresses && this.transaction._fromAddresses.length >= this.transaction._threshold;
171
- if (!hasAddresses) {
172
- // If addresses not available, use all zeros
173
- const emptySignatures = sigIndices.map(() => utils_1.default.createNewSig(''));
174
- credentials.push(new flarejs_1.Credential(emptySignatures));
175
- }
176
- else {
177
- // Compute addressesIndex: position of each _fromAddresses in UTXO's address list
178
- const utxoAddresses = utxo.addresses.map((a) => utils_1.default.parseAddress(a));
179
- const addressesIndex = this.transaction._fromAddresses.map((a) => utxoAddresses.findIndex((u) => Buffer.compare(Buffer.from(u), Buffer.from(a)) === 0));
180
- // either user (0) or recovery (2)
181
- const firstIndex = this.recoverSigner ? 2 : 0;
182
- const bitgoIndex = 1;
183
- // Dynamic ordering based on addressesIndex
184
- let emptySignatures;
185
- if (addressesIndex[bitgoIndex] < addressesIndex[firstIndex]) {
186
- // Bitgo comes first in signature order: [zeros, userAddress]
187
- emptySignatures = [
188
- utils_1.default.createNewSig(''),
189
- utils_1.default.createEmptySigWithAddress(Buffer.from(this.transaction._fromAddresses[firstIndex]).toString('hex')),
190
- ];
191
- }
192
- else {
193
- // User comes first in signature order: [userAddress, zeros]
194
- emptySignatures = [
195
- utils_1.default.createEmptySigWithAddress(Buffer.from(this.transaction._fromAddresses[firstIndex]).toString('hex')),
196
- utils_1.default.createNewSig(''),
197
- ];
198
- }
199
- credentials.push(new flarejs_1.Credential(emptySignatures));
200
- }
221
+ // Use centralized method for credential creation
222
+ credentials.push(this.createCredentialForUtxo(utxo, this.transaction._threshold));
201
223
  });
202
224
  return {
203
225
  inputs,
@@ -206,17 +228,21 @@ class ImportInCTxBuilder extends atomicInCTransactionBuilder_1.AtomicInCTransact
206
228
  };
207
229
  }
208
230
  /**
209
- * Calculate the fee size for the transaction
210
- * For C-chain imports, the feeRate is treated as an absolute fee value
231
+ * @param unsignedTx The UnsignedTx to calculate the cost for (includes ImportTx, AddressMaps, and Credentials)
232
+ * @returns The total cost units
211
233
  */
212
- calculateFeeSize(tx) {
213
- // If tx is provided, calculate based on actual transaction size
214
- if (tx) {
215
- const codec = flarejs_1.avmSerial.getAVMManager().getDefaultCodec();
216
- return tx.toBytes(codec).length;
217
- }
218
- // For C-chain imports, treat feeRate as the absolute fee (multiplier of 1)
219
- return 1;
234
+ calculateImportCost(unsignedTx) {
235
+ const signedTxBytes = unsignedTx.getSignedTx().toBytes();
236
+ const txBytesGas = 1;
237
+ let bytesCost = signedTxBytes.length * txBytesGas;
238
+ const costPerSignature = 1000;
239
+ const importTx = unsignedTx.getTx();
240
+ importTx.importedInputs.forEach((input) => {
241
+ const inCost = costPerSignature * input.sigIndicies().length;
242
+ bytesCost += inCost;
243
+ });
244
+ const fixedFee = 10000;
245
+ return bytesCost + fixedFee;
220
246
  }
221
247
  /**
222
248
  * Recover UTXOs from imported inputs
@@ -239,4 +265,4 @@ class ImportInCTxBuilder extends atomicInCTransactionBuilder_1.AtomicInCTransact
239
265
  }
240
266
  }
241
267
  exports.ImportInCTxBuilder = ImportInCTxBuilder;
242
- //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"ImportInCTxBuilder.js","sourceRoot":"","sources":["../../../src/lib/ImportInCTxBuilder.ts"],"names":[],"mappings":";;;;;;AACA,mDAA4F;AAC5F,+EAA4E;AAC5E,mDAW+B;AAC/B,oDAA4B;AAC5B,mCAA8F;AAE9F,MAAa,kBAAmB,SAAQ,yDAA2B;IACjE,YAAY,WAAiC;QAC3C,KAAK,CAAC,WAAW,CAAC,CAAC;IACrB,CAAC;IAED;;;;OAIG;IACH,EAAE,CAAC,QAAgB;QACjB,IAAI,CAAC,WAAW,CAAC,GAAG,GAAG,CAAC,eAAK,CAAC,YAAY,CAAC,QAAQ,CAAC,CAAC,CAAC;QACtD,OAAO,IAAI,CAAC;IACd,CAAC;IAED,IAAc,eAAe;QAC3B,OAAO,0BAAe,CAAC,MAAM,CAAC;IAChC,CAAC;IAED,WAAW,CAAC,EAAM,EAAE,QAAiB,EAAE,iBAAgC;QACrE,MAAM,MAAM,GAAG,EAAwB,CAAC;QACxC,IAAI,CAAC,IAAI,CAAC,YAAY,CAAC,MAAM,CAAC,KAAK,CAAC,EAAE,CAAC;YACrC,MAAM,IAAI,uBAAY,CAAC,qEAAqE,CAAC,CAAC;QAChG,CAAC;QAED,kDAAkD;QAClD,4EAA4E;QAC5E,MAAM,OAAO,GAAG,MAAM,CAAC,IAAI,CAAC;QAC5B,IAAI,OAAO,CAAC,MAAM,KAAK,CAAC,EAAE,CAAC;YACzB,MAAM,IAAI,gCAAqB,CAAC,iCAAiC,CAAC,CAAC;QACrE,CAAC;QACD,MAAM,MAAM,GAAG,OAAO,CAAC,CAAC,CAAC,CAAC;QAE1B,IAAI,MAAM,CAAC,IAAI,CAAC,MAAM,CAAC,OAAO,CAAC,OAAO,EAAE,CAAC,CAAC,QAAQ,CAAC,KAAK,CAAC,KAAK,IAAI,CAAC,WAAW,CAAC,QAAQ,EAAE,CAAC;YACxF,MAAM,IAAI,KAAK,CAAC,wBAAwB,CAAC,CAAC;QAC5C,CAAC;QACD,IAAI,CAAC,WAAW,CAAC,GAAG,GAAG,CAAC,MAAM,CAAC,IAAI,CAAC,MAAM,CAAC,OAAO,CAAC,OAAO,EAAE,CAAC,CAAC,CAAC;QAE/D,MAAM,MAAM,GAAG,MAAM,CAAC,cAAc,CAAC;QACrC,IAAI,CAAC,WAAW,CAAC,MAAM,GAAG,IAAI,CAAC,YAAY,CAAC,MAAM,CAAC,CAAC;QAEpD,2CAA2C;QAC3C,MAAM,gBAAgB,GAAG,MAAM,CAAC,MAAM,CAAC,CAAC,CAAC,EAAE,CAAC,EAAE,EAAE,CAAC,CAAC,GAAG,CAAC,CAAC,MAAM,EAAE,EAAE,MAAM,CAAC,CAAC,CAAC,CAAC,CAAC;QAC5E,MAAM,iBAAiB,GAAG,MAAM,CAAC,MAAM,CAAC,KAAK,EAAE,CAAC;QAEhD,iDAAiD;QACjD,MAAM,GAAG,GAAG,gBAAgB,GAAG,iBAAiB,CAAC;QACjD,MAAM,OAAO,GAAG,IAAI,CAAC,gBAAgB,CAAC,MAAM,CAAC,CAAC;QAC9C,yEAAyE;QACzE,MAAM,OAAO,GAAG,IAAI,CAAC,KAAK,CAAC,MAAM,CAAC,GAAG,CAAC,GAAG,OAAO,CAAC,CAAC;QAElD,IAAI,CAAC,WAAW,CAAC,IAAI,GAAG;YACtB,GAAG,EAAE,GAAG,CAAC,QAAQ,EAAE;YACnB,OAAO,EAAE,OAAO;YAChB,IAAI,EAAE,OAAO;SACd,CAAC;QAEF,yFAAyF;QACzF,MAAM,WAAW,GAAG,iBAAiB,IAAI,EAAE,CAAC;QAC5C,MAAM,cAAc,GAAG,WAAW,CAAC,MAAM,GAAG,CAAC,CAAC;QAE9C,sFAAsF;QACtF,IAAI,cAAc,IAAI,QAAQ,EAAE,CAAC;YAC/B,IAAI,CAAC,WAAW,CAAC,eAAe,GAAG,QAAQ,CAAC;QAC9C,CAAC;QAED,mFAAmF;QACnF,MAAM,UAAU,GAAG,MAAM,CAAC,CAAC,CAAC,CAAC;QAC7B,MAAM,cAAc,GAAG,UAAU,CAAC,WAAW,EAAE,CAAC,MAAM,IAAI,IAAI,CAAC,WAAW,CAAC,UAAU,CAAC;QACtF,IAAI,CAAC,WAAW,CAAC,UAAU,GAAG,cAAc,CAAC;QAE7C,oDAAoD;QACpD,MAAM,SAAS,GAAG,IAAI,iBAAO,CAAC,MAAM,CAAC,OAAO,CAAC,OAAO,EAAE,CAAC,CAAC;QACxD,MAAM,UAAU,GAAG,IAAI,eAAU,CAAC,UAAU,CAAC,CAAC,CAAC,SAAS,EAAE,CAAC,CAAC,CAAC,CAAC,CAAC;QAC/D,MAAM,WAAW,GAAG,IAAI,eAAU,CAAC,WAAW,CAAC,CAAC,UAAU,CAAC,CAAC,CAAC;QAE7D,qFAAqF;QACrF,4FAA4F;QAC5F,IAAI,aAA2B,CAAC;QAChC,IAAI,WAAW,CAAC,MAAM,GAAG,CAAC,EAAE,CAAC;YAC3B,aAAa,GAAG,WAAW,CAAC;QAC9B,CAAC;aAAM,CAAC;YACN,+EAA+E;YAC/E,MAAM,eAAe,GAA4C,EAAE,CAAC;YACpE,KAAK,IAAI,CAAC,GAAG,CAAC,EAAE,CAAC,GAAG,cAAc,EAAE,CAAC,EAAE,EAAE,CAAC;gBACxC,eAAe,CAAC,IAAI,CAAC,eAAK,CAAC,YAAY,CAAC,EAAE,CAAC,CAAC,CAAC;YAC/C,CAAC;YACD,aAAa,GAAG,CAAC,IAAI,oBAAU,CAAC,eAAe,CAAC,CAAC,CAAC;QACpD,CAAC;QAED,MAAM,UAAU,GAAG,IAAI,oBAAU,CAAC,MAAM,EAAE,EAAE,EAAE,WAAW,EAAE,aAAa,CAAC,CAAC;QAE1E,IAAI,CAAC,WAAW,CAAC,cAAc,CAAC,UAAU,CAAC,CAAC;QAC5C,OAAO,IAAI,CAAC;IACd,CAAC;IAED,MAAM,CAAC,YAAY,CAAC,OAAe;QACjC,OAAO,OAAO,KAAK,4BAAoB,CAAC,WAAW,CAAC;IACtD,CAAC;IAED,YAAY,CAAC,OAAe;QAC1B,OAAO,kBAAkB,CAAC,YAAY,CAAC,OAAO,CAAC,CAAC;IAClD,CAAC;IAED;;;OAGG;IACO,qBAAqB;QAC7B,+EAA+E;QAC/E,IAAI,IAAI,CAAC,WAAW,CAAC,cAAc;YAAE,OAAO;QAC5C,IAAI,IAAI,CAAC,WAAW,CAAC,GAAG,CAAC,MAAM,KAAK,CAAC,EAAE,CAAC;YACtC,MAAM,IAAI,KAAK,CAAC,gBAAgB,CAAC,CAAC;QACpC,CAAC;QACD,IAAI,CAAC,IAAI,CAAC,WAAW,CAAC,IAAI,CAAC,OAAO,EAAE,CAAC;YACnC,MAAM,IAAI,KAAK,CAAC,sBAAsB,CAAC,CAAC;QAC1C,CAAC;QAED,MAAM,EAAE,MAAM,EAAE,MAAM,EAAE,WAAW,EAAE,GAAG,IAAI,CAAC,YAAY,EAAE,CAAC;QAE5D,gBAAgB;QAChB,MAAM,OAAO,GAAG,MAAM,CAAC,IAAI,CAAC,WAAW,CAAC,IAAI,CAAC,OAAO,CAAC,CAAC;QACtD,MAAM,OAAO,GAAG,IAAI,CAAC,gBAAgB,EAAE,CAAC;QACxC,MAAM,GAAG,GAAG,OAAO,GAAG,MAAM,CAAC,OAAO,CAAC,CAAC;QACtC,IAAI,CAAC,WAAW,CAAC,IAAI,CAAC,GAAG,GAAG,GAAG,CAAC,QAAQ,EAAE,CAAC;QAC3C,IAAI,CAAC,WAAW,CAAC,IAAI,CAAC,IAAI,GAAG,OAAO,CAAC;QAErC,+CAA+C;QAC/C,MAAM,MAAM,GAAG,IAAI,mBAAS,CAAC,MAAM,CACjC,IAAI,iBAAO,CAAC,IAAI,CAAC,WAAW,CAAC,GAAG,CAAC,CAAC,CAAC,CAAC,EACpC,IAAI,kBAAQ,CAAC,MAAM,GAAG,GAAG,CAAC,EAC1B,IAAI,YAAE,CAAC,IAAI,UAAU,CAAC,MAAM,CAAC,IAAI,CAAC,IAAI,CAAC,WAAW,CAAC,QAAQ,EAAE,KAAK,CAAC,CAAC,CAAC,CACtE,CAAC;QAEF,gCAAgC;QAChC,MAAM,QAAQ,GAAG,IAAI,mBAAS,CAAC,QAAQ,CACrC,IAAI,aAAG,CAAC,IAAI,CAAC,WAAW,CAAC,UAAU,CAAC,EACpC,IAAI,YAAE,CAAC,IAAI,UAAU,CAAC,MAAM,CAAC,IAAI,CAAC,IAAI,CAAC,WAAW,CAAC,aAAa,EAAE,KAAK,CAAC,CAAC,CAAC,EAC1E,IAAI,YAAE,CAAC,IAAI,UAAU,CAAC,IAAI,CAAC,gBAAgB,CAAC,CAAC,EAC7C,MAAM,EACN,CAAC,MAAM,CAAC,CACT,CAAC;QAEF,wEAAwE;QACxE,MAAM,UAAU,GAAG,IAAI,eAAU,CAAC,UAAU,EAAE,CAAC;QAC/C,IAAI,CAAC,WAAW,CAAC,cAAc,CAAC,OAAO,CAAC,CAAC,IAAI,EAAE,CAAC,EAAE,EAAE;YAClD,UAAU,CAAC,GAAG,CAAC,IAAI,iBAAO,CAAC,IAAI,CAAC,EAAE,CAAC,CAAC,CAAC;QACvC,CAAC,CAAC,CAAC;QACH,MAAM,WAAW,GAAG,IAAI,eAAU,CAAC,WAAW,CAAC,CAAC,UAAU,CAAC,CAAC,CAAC;QAE7D,MAAM,UAAU,GAAG,IAAI,oBAAU,CAC/B,QAAQ,EACR,EAAE,EAAE,sDAAsD;QAC1D,WAAW,EACX,WAAW,CACZ,CAAC;QAEF,IAAI,CAAC,WAAW,CAAC,cAAc,CAAC,UAAU,CAAC,CAAC;IAC9C,CAAC;IAED;;;;;;;OAOG;IACO,YAAY;QAKpB,MAAM,MAAM,GAAG,IAAI,CAAC,WAAW,CAAC,cAAc,CAAC,KAAK,EAAE,CAAC;QACvD,IAAI,IAAI,CAAC,aAAa,EAAE,CAAC;YACvB,+BAA+B;YAC/B,MAAM,GAAG,GAAG,MAAM,CAAC,GAAG,EAAE,CAAC;YACzB,MAAM,CAAC,IAAI,CAAC,MAAM,CAAC,CAAC,CAAC,CAAC,CAAC;YACvB,IAAI,GAAG,EAAE,CAAC;gBACR,MAAM,CAAC,CAAC,CAAC,GAAG,GAAG,CAAC;YAClB,CAAC;QACH,CAAC;QAED,IAAI,WAAW,GAAG,MAAM,CAAC,CAAC,CAAC,CAAC;QAC5B,MAAM,MAAM,GAAwB,EAAE,CAAC;QACvC,MAAM,WAAW,GAAiB,EAAE,CAAC;QAErC,IAAI,CAAC,WAAW,CAAC,MAAM,CAAC,OAAO,CAAC,CAAC,IAAI,EAAE,EAAE;YACvC,MAAM,MAAM,GAAG,MAAM,CAAC,IAAI,CAAC,MAAM,CAAC,CAAC;YACnC,WAAW,IAAI,MAAM,CAAC;YAEtB,yCAAyC;YACzC,MAAM,UAAU,GAAa,EAAE,CAAC;YAChC,KAAK,IAAI,CAAC,GAAG,CAAC,EAAE,CAAC,GAAG,IAAI,CAAC,WAAW,CAAC,UAAU,EAAE,CAAC,EAAE,EAAE,CAAC;gBACrD,UAAU,CAAC,IAAI,CAAC,CAAC,CAAC,CAAC;YACrB,CAAC;YAED,kFAAkF;YAClF,+DAA+D;YAC/D,MAAM,QAAQ,GAAG,IAAI,CAAC,IAAI,CAAC,CAAC,uBAAuB;YACnD,MAAM,WAAW,GAAG,eAAK,CAAC,UAAU,CAAC,MAAM,CAAC,IAAI,CAAC,IAAI,CAAC,WAAW,CAAC,QAAQ,EAAE,KAAK,CAAC,CAAC,CAAC;YAEpF,MAAM,iBAAiB,GAAG,2BAAiB,CAAC,UAAU,CACpD,QAAQ,EACR,MAAM,CAAC,IAAI,CAAC,SAAS,CAAC,EACtB,WAAW,EACX,MAAM,EACN,UAAU,CACX,CAAC;YAEF,MAAM,CAAC,IAAI,CAAC,iBAAiB,CAAC,CAAC;YAE/B,kEAAkE;YAClE,2EAA2E;YAC3E,MAAM,YAAY,GAChB,IAAI,CAAC,WAAW,CAAC,cAAc,IAAI,IAAI,CAAC,WAAW,CAAC,cAAc,CAAC,MAAM,IAAI,IAAI,CAAC,WAAW,CAAC,UAAU,CAAC;YAE3G,IAAI,CAAC,YAAY,EAAE,CAAC;gBAClB,4CAA4C;gBAC5C,MAAM,eAAe,GAAG,UAAU,CAAC,GAAG,CAAC,GAAG,EAAE,CAAC,eAAK,CAAC,YAAY,CAAC,EAAE,CAAC,CAAC,CAAC;gBACrE,WAAW,CAAC,IAAI,CAAC,IAAI,oBAAU,CAAC,eAAe,CAAC,CAAC,CAAC;YACpD,CAAC;iBAAM,CAAC;gBACN,iFAAiF;gBACjF,MAAM,aAAa,GAAG,IAAI,CAAC,SAAS,CAAC,GAAG,CAAC,CAAC,CAAC,EAAE,EAAE,CAAC,eAAK,CAAC,YAAY,CAAC,CAAC,CAAC,CAAC,CAAC;gBACvE,MAAM,cAAc,GAAG,IAAI,CAAC,WAAW,CAAC,cAAc,CAAC,GAAG,CAAC,CAAC,CAAC,EAAE,EAAE,CAC/D,aAAa,CAAC,SAAS,CAAC,CAAC,CAAC,EAAE,EAAE,CAAC,MAAM,CAAC,OAAO,CAAC,MAAM,CAAC,IAAI,CAAC,CAAC,CAAC,EAAE,MAAM,CAAC,IAAI,CAAC,CAAC,CAAC,CAAC,KAAK,CAAC,CAAC,CACrF,CAAC;gBAEF,kCAAkC;gBAClC,MAAM,UAAU,GAAG,IAAI,CAAC,aAAa,CAAC,CAAC,CAAC,CAAC,CAAC,CAAC,CAAC,CAAC,CAAC;gBAC9C,MAAM,UAAU,GAAG,CAAC,CAAC;gBAErB,2CAA2C;gBAC3C,IAAI,eAAwD,CAAC;gBAC7D,IAAI,cAAc,CAAC,UAAU,CAAC,GAAG,cAAc,CAAC,UAAU,CAAC,EAAE,CAAC;oBAC5D,6DAA6D;oBAC7D,eAAe,GAAG;wBAChB,eAAK,CAAC,YAAY,CAAC,EAAE,CAAC;wBACtB,eAAK,CAAC,yBAAyB,CAAC,MAAM,CAAC,IAAI,CAAC,IAAI,CAAC,WAAW,CAAC,cAAc,CAAC,UAAU,CAAC,CAAC,CAAC,QAAQ,CAAC,KAAK,CAAC,CAAC;qBAC1G,CAAC;gBACJ,CAAC;qBAAM,CAAC;oBACN,4DAA4D;oBAC5D,eAAe,GAAG;wBAChB,eAAK,CAAC,yBAAyB,CAAC,MAAM,CAAC,IAAI,CAAC,IAAI,CAAC,WAAW,CAAC,cAAc,CAAC,UAAU,CAAC,CAAC,CAAC,QAAQ,CAAC,KAAK,CAAC,CAAC;wBACzG,eAAK,CAAC,YAAY,CAAC,EAAE,CAAC;qBACvB,CAAC;gBACJ,CAAC;gBACD,WAAW,CAAC,IAAI,CAAC,IAAI,oBAAU,CAAC,eAAe,CAAC,CAAC,CAAC;YACpD,CAAC;QACH,CAAC,CAAC,CAAC;QAEH,OAAO;YACL,MAAM;YACN,WAAW;YACX,MAAM,EAAE,WAAW;SACpB,CAAC;IACJ,CAAC;IAED;;;OAGG;IACK,gBAAgB,CAAC,EAAuB;QAC9C,gEAAgE;QAChE,IAAI,EAAE,EAAE,CAAC;YACP,MAAM,KAAK,GAAG,mBAAS,CAAC,aAAa,EAAE,CAAC,eAAe,EAAE,CAAC;YAC1D,OAAO,EAAE,CAAC,OAAO,CAAC,KAAK,CAAC,CAAC,MAAM,CAAC;QAClC,CAAC;QAED,2EAA2E;QAC3E,OAAO,CAAC,CAAC;IACX,CAAC;IAED;;;;OAIG;IACK,YAAY,CAAC,cAAmC;QACtD,OAAO,cAAc,CAAC,GAAG,CAAC,CAAC,KAAK,EAAE,EAAE;YAClC,MAAM,IAAI,GAAG,KAAK,CAAC,MAAM,CAAC,QAAQ,EAAE,CAAC;YACrC,MAAM,SAAS,GAAG,KAAK,CAAC,MAAM,CAAC,SAAS,CAAC,QAAQ,EAAE,CAAC;YAEpD,OAAO;gBACL,QAAQ,EAAE,iCAAyB;gBACnC,MAAM,EAAE,KAAK,CAAC,MAAM,EAAE,CAAC,QAAQ,EAAE;gBACjC,IAAI,EAAE,eAAK,CAAC,UAAU,CAAC,MAAM,CAAC,IAAI,CAAC,IAAI,EAAE,KAAK,CAAC,CAAC;gBAChD,SAAS,EAAE,SAAS;gBACpB,SAAS,EAAE,IAAI,CAAC,WAAW,CAAC,UAAU;gBACtC,SAAS,EAAE,IAAI,CAAC,WAAW,CAAC,cAAc,CAAC,GAAG,CAAC,CAAC,IAAI,EAAE,EAAE,CACtD,eAAK,CAAC,eAAe,CAAC,IAAI,CAAC,WAAW,CAAC,QAAQ,CAAC,GAAG,EAAE,IAAI,CAAC,WAAW,CAAC,QAAQ,CAAC,KAAK,EAAE,MAAM,CAAC,IAAI,CAAC,IAAI,CAAC,CAAC,CACzG;aACF,CAAC;QACJ,CAAC,CAAC,CAAC;IACL,CAAC;CACF;AAvSD,gDAuSC","sourcesContent":["import { BaseCoin as CoinConfig } from '@bitgo-beta/statics';\nimport { BuildTransactionError, NotSupported, TransactionType } from '@bitgo-beta/sdk-core';\nimport { AtomicInCTransactionBuilder } from './atomicInCTransactionBuilder';\nimport {\n  evmSerial,\n  UnsignedTx,\n  Credential,\n  BigIntPr,\n  Int,\n  Id,\n  TransferableInput,\n  Address,\n  utils as FlareUtils,\n  avmSerial,\n} from '@flarenetwork/flarejs';\nimport utils from './utils';\nimport { DecodedUtxoObj, FlareTransactionType, SECP256K1_Transfer_Output, Tx } from './iface';\n\nexport class ImportInCTxBuilder extends AtomicInCTransactionBuilder {\n  constructor(_coinConfig: Readonly<CoinConfig>) {\n    super(_coinConfig);\n  }\n\n  /**\n   * C-chain address who is target of the import.\n   * Address format is eth like\n   * @param {string} cAddress\n   */\n  to(cAddress: string): this {\n    this.transaction._to = [utils.parseAddress(cAddress)];\n    return this;\n  }\n\n  protected get transactionType(): TransactionType {\n    return TransactionType.Import;\n  }\n\n  initBuilder(tx: Tx, rawBytes?: Buffer, parsedCredentials?: Credential[]): this {\n    const baseTx = tx as evmSerial.ImportTx;\n    if (!this.verifyTxType(baseTx._type)) {\n      throw new NotSupported('Transaction cannot be parsed or has an unsupported transaction type');\n    }\n\n    // The outputs is a single C-Chain address result.\n    // It's expected to have only one output to the destination C-Chain address.\n    const outputs = baseTx.Outs;\n    if (outputs.length !== 1) {\n      throw new BuildTransactionError('Transaction can have one output');\n    }\n    const output = outputs[0];\n\n    if (Buffer.from(output.assetId.toBytes()).toString('hex') !== this.transaction._assetId) {\n      throw new Error('AssetID are not equals');\n    }\n    this.transaction._to = [Buffer.from(output.address.toBytes())];\n\n    const inputs = baseTx.importedInputs;\n    this.transaction._utxos = this.recoverUtxos(inputs);\n\n    // Calculate total input and output amounts\n    const totalInputAmount = inputs.reduce((t, i) => t + i.amount(), BigInt(0));\n    const totalOutputAmount = output.amount.value();\n\n    // Calculate fee based on input/output difference\n    const fee = totalInputAmount - totalOutputAmount;\n    const feeSize = this.calculateFeeSize(baseTx);\n    // Use integer division to ensure feeRate can be converted back to BigInt\n    const feeRate = Math.floor(Number(fee) / feeSize);\n\n    this.transaction._fee = {\n      fee: fee.toString(),\n      feeRate: feeRate,\n      size: feeSize,\n    };\n\n    // Use credentials passed from TransactionBuilderFactory (properly extracted using codec)\n    const credentials = parsedCredentials || [];\n    const hasCredentials = credentials.length > 0;\n\n    // If it's a signed transaction, store the original raw bytes to preserve exact format\n    if (hasCredentials && rawBytes) {\n      this.transaction._rawSignedBytes = rawBytes;\n    }\n\n    // Extract threshold from first input's sigIndicies (number of required signatures)\n    const firstInput = inputs[0];\n    const inputThreshold = firstInput.sigIndicies().length || this.transaction._threshold;\n    this.transaction._threshold = inputThreshold;\n\n    // Create proper UnsignedTx wrapper with credentials\n    const toAddress = new Address(output.address.toBytes());\n    const addressMap = new FlareUtils.AddressMap([[toAddress, 0]]);\n    const addressMaps = new FlareUtils.AddressMaps([addressMap]);\n\n    // When credentials were extracted, use them directly to preserve existing signatures\n    // For initBuilder, _fromAddresses may not be set yet, so use all zeros for credential slots\n    let txCredentials: Credential[];\n    if (credentials.length > 0) {\n      txCredentials = credentials;\n    } else {\n      // Create empty credential with threshold number of signature slots (all zeros)\n      const emptySignatures: ReturnType<typeof utils.createNewSig>[] = [];\n      for (let i = 0; i < inputThreshold; i++) {\n        emptySignatures.push(utils.createNewSig(''));\n      }\n      txCredentials = [new Credential(emptySignatures)];\n    }\n\n    const unsignedTx = new UnsignedTx(baseTx, [], addressMaps, txCredentials);\n\n    this.transaction.setTransaction(unsignedTx);\n    return this;\n  }\n\n  static verifyTxType(txnType: string): boolean {\n    return txnType === FlareTransactionType.EvmImportTx;\n  }\n\n  verifyTxType(txnType: string): boolean {\n    return ImportInCTxBuilder.verifyTxType(txnType);\n  }\n\n  /**\n   * Build the import in C-chain transaction\n   * @protected\n   */\n  protected buildFlareTransaction(): void {\n    // if tx has credentials or was already recovered from raw, tx shouldn't change\n    if (this.transaction.hasCredentials) return;\n    if (this.transaction._to.length !== 1) {\n      throw new Error('to is required');\n    }\n    if (!this.transaction._fee.feeRate) {\n      throw new Error('fee rate is required');\n    }\n\n    const { inputs, amount, credentials } = this.createInputs();\n\n    // Calculate fee\n    const feeRate = BigInt(this.transaction._fee.feeRate);\n    const feeSize = this.calculateFeeSize();\n    const fee = feeRate * BigInt(feeSize);\n    this.transaction._fee.fee = fee.toString();\n    this.transaction._fee.size = feeSize;\n\n    // Create EVM output using proper FlareJS class\n    const output = new evmSerial.Output(\n      new Address(this.transaction._to[0]),\n      new BigIntPr(amount - fee),\n      new Id(new Uint8Array(Buffer.from(this.transaction._assetId, 'hex')))\n    );\n\n    // Create the import transaction\n    const importTx = new evmSerial.ImportTx(\n      new Int(this.transaction._networkID),\n      new Id(new Uint8Array(Buffer.from(this.transaction._blockchainID, 'hex'))),\n      new Id(new Uint8Array(this._externalChainId)),\n      inputs,\n      [output]\n    );\n\n    // Create unsigned transaction with all potential signers in address map\n    const addressMap = new FlareUtils.AddressMap();\n    this.transaction._fromAddresses.forEach((addr, i) => {\n      addressMap.set(new Address(addr), i);\n    });\n    const addressMaps = new FlareUtils.AddressMaps([addressMap]);\n\n    const unsignedTx = new UnsignedTx(\n      importTx,\n      [], // Empty UTXOs array, will be filled during processing\n      addressMaps,\n      credentials\n    );\n\n    this.transaction.setTransaction(unsignedTx);\n  }\n\n  /**\n   * Create inputs from UTXOs\n   * @return {\n   *     inputs: TransferableInput[];\n   *     credentials: Credential[];\n   *     amount: bigint;\n   * }\n   */\n  protected createInputs(): {\n    inputs: TransferableInput[];\n    credentials: Credential[];\n    amount: bigint;\n  } {\n    const sender = this.transaction._fromAddresses.slice();\n    if (this.recoverSigner) {\n      // switch first and last signer\n      const tmp = sender.pop();\n      sender.push(sender[0]);\n      if (tmp) {\n        sender[0] = tmp;\n      }\n    }\n\n    let totalAmount = BigInt(0);\n    const inputs: TransferableInput[] = [];\n    const credentials: Credential[] = [];\n\n    this.transaction._utxos.forEach((utxo) => {\n      const amount = BigInt(utxo.amount);\n      totalAmount += amount;\n\n      // Create signature indices for threshold\n      const sigIndices: number[] = [];\n      for (let i = 0; i < this.transaction._threshold; i++) {\n        sigIndices.push(i);\n      }\n\n      // Use fromNative to create TransferableInput (same pattern as ImportInPTxBuilder)\n      // fromNative expects cb58-encoded strings for txId and assetId\n      const txIdCb58 = utxo.txid; // Already cb58 encoded\n      const assetIdCb58 = utils.cb58Encode(Buffer.from(this.transaction._assetId, 'hex'));\n\n      const transferableInput = TransferableInput.fromNative(\n        txIdCb58,\n        Number(utxo.outputidx),\n        assetIdCb58,\n        amount,\n        sigIndices\n      );\n\n      inputs.push(transferableInput);\n\n      // Create credential with empty signatures for slot identification\n      // Match avaxp behavior: dynamic ordering based on addressesIndex from UTXO\n      const hasAddresses =\n        this.transaction._fromAddresses && this.transaction._fromAddresses.length >= this.transaction._threshold;\n\n      if (!hasAddresses) {\n        // If addresses not available, use all zeros\n        const emptySignatures = sigIndices.map(() => utils.createNewSig(''));\n        credentials.push(new Credential(emptySignatures));\n      } else {\n        // Compute addressesIndex: position of each _fromAddresses in UTXO's address list\n        const utxoAddresses = utxo.addresses.map((a) => utils.parseAddress(a));\n        const addressesIndex = this.transaction._fromAddresses.map((a) =>\n          utxoAddresses.findIndex((u) => Buffer.compare(Buffer.from(u), Buffer.from(a)) === 0)\n        );\n\n        // either user (0) or recovery (2)\n        const firstIndex = this.recoverSigner ? 2 : 0;\n        const bitgoIndex = 1;\n\n        // Dynamic ordering based on addressesIndex\n        let emptySignatures: ReturnType<typeof utils.createNewSig>[];\n        if (addressesIndex[bitgoIndex] < addressesIndex[firstIndex]) {\n          // Bitgo comes first in signature order: [zeros, userAddress]\n          emptySignatures = [\n            utils.createNewSig(''),\n            utils.createEmptySigWithAddress(Buffer.from(this.transaction._fromAddresses[firstIndex]).toString('hex')),\n          ];\n        } else {\n          // User comes first in signature order: [userAddress, zeros]\n          emptySignatures = [\n            utils.createEmptySigWithAddress(Buffer.from(this.transaction._fromAddresses[firstIndex]).toString('hex')),\n            utils.createNewSig(''),\n          ];\n        }\n        credentials.push(new Credential(emptySignatures));\n      }\n    });\n\n    return {\n      inputs,\n      credentials,\n      amount: totalAmount,\n    };\n  }\n\n  /**\n   * Calculate the fee size for the transaction\n   * For C-chain imports, the feeRate is treated as an absolute fee value\n   */\n  private calculateFeeSize(tx?: evmSerial.ImportTx): number {\n    // If tx is provided, calculate based on actual transaction size\n    if (tx) {\n      const codec = avmSerial.getAVMManager().getDefaultCodec();\n      return tx.toBytes(codec).length;\n    }\n\n    // For C-chain imports, treat feeRate as the absolute fee (multiplier of 1)\n    return 1;\n  }\n\n  /**\n   * Recover UTXOs from imported inputs\n   * @param importedInputs Array of transferable inputs\n   * @returns Array of decoded UTXO objects\n   */\n  private recoverUtxos(importedInputs: TransferableInput[]): DecodedUtxoObj[] {\n    return importedInputs.map((input) => {\n      const txid = input.utxoID.toString();\n      const outputidx = input.utxoID.outputIdx.toString();\n\n      return {\n        outputID: SECP256K1_Transfer_Output,\n        amount: input.amount().toString(),\n        txid: utils.cb58Encode(Buffer.from(txid, 'hex')),\n        outputidx: outputidx,\n        threshold: this.transaction._threshold,\n        addresses: this.transaction._fromAddresses.map((addr) =>\n          utils.addressToString(this.transaction._network.hrp, this.transaction._network.alias, Buffer.from(addr))\n        ),\n      };\n    });\n  }\n}\n"]}
268
+ //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"ImportInCTxBuilder.js","sourceRoot":"","sources":["../../../src/lib/ImportInCTxBuilder.ts"],"names":[],"mappings":"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","sourcesContent":["import { BaseCoin as CoinConfig } from '@bitgo-beta/statics';\nimport { BuildTransactionError, NotSupported, TransactionType } from '@bitgo-beta/sdk-core';\nimport { AtomicInCTransactionBuilder } from './atomicInCTransactionBuilder';\nimport {\n  evmSerial,\n  UnsignedTx,\n  Credential,\n  BigIntPr,\n  Int,\n  Id,\n  TransferableInput,\n  Address,\n  utils as FlareUtils,\n} from '@flarenetwork/flarejs';\nimport utils from './utils';\nimport { DecodedUtxoObj, FlareTransactionType, SECP256K1_Transfer_Output, Tx } from './iface';\n\nexport class ImportInCTxBuilder extends AtomicInCTransactionBuilder {\n  constructor(_coinConfig: Readonly<CoinConfig>) {\n    super(_coinConfig);\n  }\n\n  /**\n   * C-chain address who is target of the import.\n   * Address format is eth like\n   * @param {string} cAddress\n   */\n  to(cAddress: string): this {\n    this.transaction._to = [utils.parseAddress(cAddress)];\n    return this;\n  }\n\n  protected get transactionType(): TransactionType {\n    return TransactionType.Import;\n  }\n\n  initBuilder(tx: Tx, rawBytes?: Buffer, parsedCredentials?: Credential[]): this {\n    const baseTx = tx as evmSerial.ImportTx;\n    if (!this.verifyTxType(baseTx._type)) {\n      throw new NotSupported('Transaction cannot be parsed or has an unsupported transaction type');\n    }\n\n    // The outputs is a single C-Chain address result.\n    // It's expected to have only one output to the destination C-Chain address.\n    const outputs = baseTx.Outs;\n    if (outputs.length !== 1) {\n      throw new BuildTransactionError('Transaction can have one output');\n    }\n    const output = outputs[0];\n\n    if (Buffer.from(output.assetId.toBytes()).toString('hex') !== this.transaction._assetId) {\n      throw new Error('AssetID are not equals');\n    }\n    this.transaction._to = [Buffer.from(output.address.toBytes())];\n\n    const inputs = baseTx.importedInputs;\n    this.transaction._utxos = this.recoverUtxos(inputs);\n\n    // Calculate total input and output amounts\n    const totalInputAmount = inputs.reduce((t, i) => t + i.amount(), BigInt(0));\n    const totalOutputAmount = output.amount.value();\n\n    // Calculate fee based on input/output difference\n    const fee = totalInputAmount - totalOutputAmount;\n\n    // Use credentials passed from TransactionBuilderFactory (properly extracted using codec)\n    const credentials = parsedCredentials || [];\n    const hasCredentials = credentials.length > 0;\n\n    // If it's a signed transaction, store the original raw bytes to preserve exact format\n    if (hasCredentials && rawBytes) {\n      this.transaction._rawSignedBytes = rawBytes;\n    }\n\n    // Extract threshold from first input's sigIndicies (number of required signatures)\n    const firstInput = inputs[0];\n    const inputThreshold = firstInput.sigIndicies().length || this.transaction._threshold;\n    this.transaction._threshold = inputThreshold;\n\n    // Create a temporary UnsignedTx for accurate fee size calculation\n    // This includes the full structure (ImportTx, AddressMaps, Credentials)\n    const tempAddressMap = new FlareUtils.AddressMap();\n    for (let i = 0; i < inputThreshold; i++) {\n      if (this.transaction._fromAddresses && this.transaction._fromAddresses[i]) {\n        tempAddressMap.set(new Address(this.transaction._fromAddresses[i]), i);\n      }\n    }\n    const tempAddressMaps = new FlareUtils.AddressMaps([tempAddressMap]);\n    const tempCredentials =\n      credentials.length > 0 ? credentials : [new Credential(Array(inputThreshold).fill(utils.createNewSig('')))];\n    const tempUnsignedTx = new UnsignedTx(baseTx, [], tempAddressMaps, tempCredentials);\n\n    // Calculate cost units using the full UnsignedTx structure\n    const feeSize = this.calculateImportCost(tempUnsignedTx);\n    // Use integer division to ensure feeRate can be converted back to BigInt\n    const feeRate = Math.floor(Number(fee) / feeSize);\n\n    this.transaction._fee = {\n      fee: fee.toString(),\n      feeRate: feeRate,\n      size: feeSize,\n    };\n\n    // Create AddressMaps based on signature slot order (matching credential order), not sorted addresses\n    // This matches the approach used in credentials: addressesIndex determines signature order\n    // AddressMaps should map addresses to signature slots in the same order as credentials\n    // If _fromAddresses is available, create AddressMap based on UTXO order (matching credential order)\n    // Otherwise, fall back to mapping just the output address\n    const firstUtxo = this.transaction._utxos[0];\n    let addressMap: FlareUtils.AddressMap;\n    if (\n      firstUtxo &&\n      firstUtxo.addresses &&\n      firstUtxo.addresses.length > 0 &&\n      this.transaction._fromAddresses &&\n      this.transaction._fromAddresses.length >= this.transaction._threshold\n    ) {\n      // Use centralized method for AddressMap creation\n      addressMap = this.createAddressMapForUtxo(firstUtxo, this.transaction._threshold);\n    } else {\n      // Fallback: map output address to slot 0 (for C-chain imports, output is the destination)\n      // Or map addresses sequentially if _fromAddresses is available but UTXO addresses are not\n      addressMap = new FlareUtils.AddressMap();\n      if (this.transaction._fromAddresses && this.transaction._fromAddresses.length >= this.transaction._threshold) {\n        this.transaction._fromAddresses.slice(0, this.transaction._threshold).forEach((addr, i) => {\n          addressMap.set(new Address(addr), i);\n        });\n      } else {\n        // Last resort: map output address\n        const toAddress = new Address(output.address.toBytes());\n        addressMap.set(toAddress, 0);\n      }\n    }\n\n    const addressMaps = new FlareUtils.AddressMaps([addressMap]);\n\n    // When credentials were extracted, use them directly to preserve existing signatures\n    // For initBuilder, _fromAddresses may not be set yet, so use all zeros for credential slots\n    let txCredentials: Credential[];\n    if (credentials.length > 0) {\n      txCredentials = credentials;\n    } else {\n      // Create empty credential with threshold number of signature slots (all zeros)\n      const emptySignatures: ReturnType<typeof utils.createNewSig>[] = [];\n      for (let i = 0; i < inputThreshold; i++) {\n        emptySignatures.push(utils.createNewSig(''));\n      }\n      txCredentials = [new Credential(emptySignatures)];\n    }\n\n    const unsignedTx = new UnsignedTx(baseTx, [], addressMaps, txCredentials);\n\n    this.transaction.setTransaction(unsignedTx);\n    return this;\n  }\n\n  static verifyTxType(txnType: string): boolean {\n    return txnType === FlareTransactionType.EvmImportTx;\n  }\n\n  verifyTxType(txnType: string): boolean {\n    return ImportInCTxBuilder.verifyTxType(txnType);\n  }\n\n  /**\n   * Build the import in C-chain transaction\n   * @protected\n   */\n  protected buildFlareTransaction(): void {\n    // if tx has credentials or was already recovered from raw, tx shouldn't change\n    if (this.transaction.hasCredentials) return;\n    if (this.transaction._to.length !== 1) {\n      throw new Error('to is required');\n    }\n    if (!this.transaction._fee.feeRate) {\n      throw new Error('fee rate is required');\n    }\n\n    const { inputs, amount, credentials } = this.createInputs();\n\n    // Calculate import cost units (matching AVAXP's costImportTx approach)\n    // Create a temporary UnsignedTx with full amount to calculate fee size\n    // This includes the full structure (ImportTx, AddressMaps, Credentials) for accurate size calculation\n    const tempOutput = new evmSerial.Output(\n      new Address(this.transaction._to[0]),\n      new BigIntPr(amount),\n      new Id(new Uint8Array(Buffer.from(this.transaction._assetId, 'hex')))\n    );\n    const tempImportTx = new evmSerial.ImportTx(\n      new Int(this.transaction._networkID),\n      new Id(new Uint8Array(Buffer.from(this.transaction._blockchainID, 'hex'))),\n      new Id(new Uint8Array(this._externalChainId)),\n      inputs,\n      [tempOutput]\n    );\n\n    // Create AddressMaps for fee calculation (same as final transaction)\n    const firstUtxo = this.transaction._utxos[0];\n    const tempAddressMap = firstUtxo\n      ? this.createAddressMapForUtxo(firstUtxo, this.transaction._threshold)\n      : new FlareUtils.AddressMap();\n    const tempAddressMaps = new FlareUtils.AddressMaps([tempAddressMap]);\n\n    // Create temporary UnsignedTx with full structure for accurate fee calculation\n    const tempUnsignedTx = new UnsignedTx(tempImportTx, [], tempAddressMaps, credentials);\n\n    // Calculate feeSize once using full UnsignedTx (matching AVAXP approach)\n    const feeSize = this.calculateImportCost(tempUnsignedTx);\n    const feeRate = BigInt(this.transaction._fee.feeRate);\n    const fee = feeRate * BigInt(feeSize);\n\n    // Validate that we have enough funds to cover the fee\n    if (amount <= fee) {\n      throw new BuildTransactionError(\n        `Insufficient funds: have ${amount.toString()}, need more than ${fee.toString()} for fee`\n      );\n    }\n\n    this.transaction._fee.fee = fee.toString();\n    this.transaction._fee.size = feeSize;\n\n    // Create EVM output using proper FlareJS class with amount minus fee\n    const output = new evmSerial.Output(\n      new Address(this.transaction._to[0]),\n      new BigIntPr(amount - fee),\n      new Id(new Uint8Array(Buffer.from(this.transaction._assetId, 'hex')))\n    );\n\n    // Create the import transaction\n    const importTx = new evmSerial.ImportTx(\n      new Int(this.transaction._networkID),\n      new Id(new Uint8Array(Buffer.from(this.transaction._blockchainID, 'hex'))),\n      new Id(new Uint8Array(this._externalChainId)),\n      inputs,\n      [output]\n    );\n\n    // Reuse the AddressMaps already calculated for fee calculation\n    const unsignedTx = new UnsignedTx(\n      importTx,\n      [], // Empty UTXOs array, will be filled during processing\n      tempAddressMaps,\n      credentials\n    );\n\n    this.transaction.setTransaction(unsignedTx);\n  }\n\n  /**\n   * Create inputs from UTXOs\n   * @return {\n   *     inputs: TransferableInput[];\n   *     credentials: Credential[];\n   *     amount: bigint;\n   * }\n   */\n  protected createInputs(): {\n    inputs: TransferableInput[];\n    credentials: Credential[];\n    amount: bigint;\n  } {\n    const sender = this.transaction._fromAddresses.slice();\n    if (this.recoverSigner) {\n      // switch first and last signer\n      const tmp = sender.pop();\n      sender.push(sender[0]);\n      if (tmp) {\n        sender[0] = tmp;\n      }\n    }\n\n    let totalAmount = BigInt(0);\n    const inputs: TransferableInput[] = [];\n    const credentials: Credential[] = [];\n\n    this.transaction._utxos.forEach((utxo) => {\n      const amount = BigInt(utxo.amount);\n      totalAmount += amount;\n\n      // Create signature indices for threshold\n      const sigIndices: number[] = [];\n      for (let i = 0; i < this.transaction._threshold; i++) {\n        sigIndices.push(i);\n      }\n\n      // Use fromNative to create TransferableInput (same pattern as ImportInPTxBuilder)\n      // fromNative expects cb58-encoded strings for txId and assetId\n      const txIdCb58 = utxo.txid; // Already cb58 encoded\n      const assetIdCb58 = utils.cb58Encode(Buffer.from(this.transaction._assetId, 'hex'));\n\n      const transferableInput = TransferableInput.fromNative(\n        txIdCb58,\n        Number(utxo.outputidx),\n        assetIdCb58,\n        amount,\n        sigIndices\n      );\n\n      inputs.push(transferableInput);\n\n      // Create credential with empty signatures for slot identification\n      // Match avaxp behavior: dynamic ordering based on addressesIndex from UTXO\n      // Use centralized method for credential creation\n      credentials.push(this.createCredentialForUtxo(utxo, this.transaction._threshold));\n    });\n\n    return {\n      inputs,\n      credentials,\n      amount: totalAmount,\n    };\n  }\n\n  /**\n   * @param unsignedTx The UnsignedTx to calculate the cost for (includes ImportTx, AddressMaps, and Credentials)\n   * @returns The total cost units\n   */\n  private calculateImportCost(unsignedTx: UnsignedTx): number {\n    const signedTxBytes = unsignedTx.getSignedTx().toBytes();\n    const txBytesGas = 1;\n    let bytesCost = signedTxBytes.length * txBytesGas;\n    const costPerSignature = 1000;\n    const importTx = unsignedTx.getTx() as evmSerial.ImportTx;\n    importTx.importedInputs.forEach((input: TransferableInput) => {\n      const inCost = costPerSignature * input.sigIndicies().length;\n      bytesCost += inCost;\n    });\n    const fixedFee = 10000;\n    return bytesCost + fixedFee;\n  }\n\n  /**\n   * Recover UTXOs from imported inputs\n   * @param importedInputs Array of transferable inputs\n   * @returns Array of decoded UTXO objects\n   */\n  private recoverUtxos(importedInputs: TransferableInput[]): DecodedUtxoObj[] {\n    return importedInputs.map((input) => {\n      const txid = input.utxoID.toString();\n      const outputidx = input.utxoID.outputIdx.toString();\n\n      return {\n        outputID: SECP256K1_Transfer_Output,\n        amount: input.amount().toString(),\n        txid: utils.cb58Encode(Buffer.from(txid, 'hex')),\n        outputidx: outputidx,\n        threshold: this.transaction._threshold,\n        addresses: this.transaction._fromAddresses.map((addr) =>\n          utils.addressToString(this.transaction._network.hrp, this.transaction._network.alias, Buffer.from(addr))\n        ),\n      };\n    });\n  }\n}\n"]}
@@ -1 +1 @@
1
- {"version":3,"file":"ImportInPTxBuilder.d.ts","sourceRoot":"","sources":["../../../src/lib/ImportInPTxBuilder.ts"],"names":[],"mappings":"AAAA,OAAO,EAAE,QAAQ,IAAI,UAAU,EAAE,MAAM,qBAAqB,CAAC;AAC7D,OAAO,EAAuC,eAAe,EAAE,MAAM,sBAAsB,CAAC;AAC5F,OAAO,EAAE,wBAAwB,EAAE,MAAM,4BAA4B,CAAC;AACtE,OAAO,EAML,iBAAiB,EAQjB,UAAU,EAEX,MAAM,uBAAuB,CAAC;AAE/B,OAAO,EAAmE,EAAE,EAAE,MAAM,SAAS,CAAC;AAE9F,qBAAa,kBAAmB,SAAQ,wBAAwB;gBAClD,WAAW,EAAE,QAAQ,CAAC,UAAU,CAAC;IAY7C,SAAS,KAAK,eAAe,IAAI,eAAe,CAE/C;IAED,WAAW,CAAC,EAAE,EAAE,EAAE,EAAE,QAAQ,CAAC,EAAE,MAAM,EAAE,iBAAiB,CAAC,EAAE,UAAU,EAAE,GAAG,IAAI;IA8G9E,MAAM,CAAC,YAAY,CAAC,OAAO,EAAE,MAAM,GAAG,OAAO;IAI7C,YAAY,CAAC,OAAO,EAAE,MAAM,GAAG,OAAO;IAItC;;;OAGG;IACH,SAAS,CAAC,qBAAqB,IAAI,IAAI;IAsDvC;;;OAGG;IACH,SAAS,CAAC,kBAAkB,IAAI;QAC9B,MAAM,EAAE,iBAAiB,EAAE,CAAC;QAC5B,WAAW,EAAE,UAAU,EAAE,CAAC;QAC1B,WAAW,EAAE,MAAM,CAAC;KACrB;IAsFD;;;;OAIG;IACH,OAAO,CAAC,YAAY;CAiBrB"}
1
+ {"version":3,"file":"ImportInPTxBuilder.d.ts","sourceRoot":"","sources":["../../../src/lib/ImportInPTxBuilder.ts"],"names":[],"mappings":"AAAA,OAAO,EAAE,QAAQ,IAAI,UAAU,EAAE,MAAM,qBAAqB,CAAC;AAC7D,OAAO,EAAuC,eAAe,EAAE,MAAM,sBAAsB,CAAC;AAC5F,OAAO,EAAE,wBAAwB,EAAE,MAAM,4BAA4B,CAAC;AACtE,OAAO,EAML,iBAAiB,EAQjB,UAAU,EAEX,MAAM,uBAAuB,CAAC;AAE/B,OAAO,EAAmE,EAAE,EAAE,MAAM,SAAS,CAAC;AAE9F,qBAAa,kBAAmB,SAAQ,wBAAwB;gBAClD,WAAW,EAAE,QAAQ,CAAC,UAAU,CAAC;IAY7C,SAAS,KAAK,eAAe,IAAI,eAAe,CAE/C;IAED,WAAW,CAAC,EAAE,EAAE,EAAE,EAAE,QAAQ,CAAC,EAAE,MAAM,EAAE,iBAAiB,CAAC,EAAE,UAAU,EAAE,GAAG,IAAI;IA0E9E,MAAM,CAAC,YAAY,CAAC,OAAO,EAAE,MAAM,GAAG,OAAO;IAI7C,YAAY,CAAC,OAAO,EAAE,MAAM,GAAG,OAAO;IAItC;;;OAGG;IACH,SAAS,CAAC,qBAAqB,IAAI,IAAI;IAkEvC;;;OAGG;IACH,SAAS,CAAC,kBAAkB,IAAI;QAC9B,MAAM,EAAE,iBAAiB,EAAE,CAAC;QAC5B,WAAW,EAAE,UAAU,EAAE,CAAC;QAC1B,WAAW,EAAE,MAAM,CAAC;KACrB;IAqDD;;;;OAIG;IACH,OAAO,CAAC,YAAY;CAiBrB"}
@@ -63,47 +63,15 @@ class ImportInPTxBuilder extends atomicTransactionBuilder_1.AtomicTransactionBui
63
63
  this.transaction._rawSignedBytes = rawBytes;
64
64
  }
65
65
  // Create proper UnsignedTx wrapper with credentials
66
- const sortedAddresses = [...this.transaction._fromAddresses].sort((a, b) => Buffer.compare(a, b));
67
- const addressMaps = sortedAddresses.map((a, i) => new flarejs_1.utils.AddressMap([[new flarejs_1.Address(a), i]]));
68
- // When credentials were extracted, use them directly to preserve existing signatures
69
66
  // Match avaxp behavior: dynamic ordering based on addressesIndex from UTXO
67
+ // Use centralized methods for credential and AddressMap creation
70
68
  const txCredentials = credentials.length > 0
71
69
  ? credentials
72
- : this.transaction._utxos.map((utxo) => {
73
- // either user (0) or recovery (2)
74
- const firstIndex = this.recoverSigner ? 2 : 0;
75
- const bitgoIndex = 1;
76
- // If UTXO has addresses, compute dynamic ordering
77
- if (utxo && utxo.addresses && utxo.addresses.length > 0) {
78
- const utxoAddresses = utxo.addresses.map((a) => utils_1.default.parseAddress(a));
79
- const addressesIndex = this.transaction._fromAddresses.map((a) => utxoAddresses.findIndex((u) => Buffer.compare(Buffer.from(u), Buffer.from(a)) === 0));
80
- // Dynamic ordering based on addressesIndex
81
- let sigSlots;
82
- if (addressesIndex[bitgoIndex] < addressesIndex[firstIndex]) {
83
- // Bitgo comes first: [zeros, userAddress]
84
- sigSlots = [
85
- utils_1.default.createNewSig(''),
86
- utils_1.default.createEmptySigWithAddress(Buffer.from(this.transaction._fromAddresses[firstIndex]).toString('hex')),
87
- ];
88
- }
89
- else {
90
- // User comes first: [userAddress, zeros]
91
- sigSlots = [
92
- utils_1.default.createEmptySigWithAddress(Buffer.from(this.transaction._fromAddresses[firstIndex]).toString('hex')),
93
- utils_1.default.createNewSig(''),
94
- ];
95
- }
96
- return new flarejs_1.Credential(sigSlots);
97
- }
98
- else {
99
- // Fallback: use all zeros if no UTXO addresses available
100
- const sigSlots = [];
101
- for (let i = 0; i < this.transaction._threshold; i++) {
102
- sigSlots.push(utils_1.default.createNewSig(''));
103
- }
104
- return new flarejs_1.Credential(sigSlots);
105
- }
106
- });
70
+ : this.transaction._utxos.map((utxo) => this.createCredentialForUtxo(utxo, this.transaction._threshold));
71
+ // Create AddressMaps based on signature slot order (matching credential order), not sorted addresses
72
+ // This matches the approach used in credentials: addressesIndex determines signature order
73
+ // AddressMaps should map addresses to signature slots in the same order as credentials
74
+ const addressMaps = this.transaction._utxos.map((utxo) => this.createAddressMapForUtxo(utxo, this.transaction._threshold));
107
75
  const unsignedTx = new flarejs_1.UnsignedTx(importTx, [], new flarejs_1.utils.AddressMaps(addressMaps), txCredentials);
108
76
  this.transaction.setTransaction(unsignedTx);
109
77
  return this;
@@ -125,6 +93,11 @@ class ImportInPTxBuilder extends atomicTransactionBuilder_1.AtomicTransactionBui
125
93
  const { inputs, credentials, totalAmount } = this.createImportInputs();
126
94
  // Calculate fee from transaction fee settings
127
95
  const fee = BigInt(this.transaction.fee.fee);
96
+ // Validate that totalAmount is sufficient to cover the fee (matching AVAX validation)
97
+ // This ensures we don't create transactions with insufficient funds
98
+ if (totalAmount < fee) {
99
+ throw new sdk_core_1.BuildTransactionError(`Utxo outputs get ${totalAmount.toString()} and ${fee.toString()} is required`);
100
+ }
128
101
  const outputAmount = totalAmount - fee;
129
102
  // Create the output for P-chain (TransferableOutput with TransferOutput)
130
103
  const assetIdBytes = new Uint8Array(Buffer.from(this.transaction._assetId, 'hex'));
@@ -142,8 +115,11 @@ class ImportInPTxBuilder extends atomicTransactionBuilder_1.AtomicTransactionBui
142
115
  const importTx = new flarejs_1.pvmSerial.ImportTx(baseTx, new flarejs_1.Id(this._externalChainId), // sourceChain (C-chain)
143
116
  inputs // importedInputs (ins)
144
117
  );
145
- // Create address maps for signing
146
- const addressMaps = this.transaction._fromAddresses.map((a, i) => new flarejs_1.utils.AddressMap([[new flarejs_1.Address(a), i]]));
118
+ // Create AddressMaps based on signature slot order (matching credential order), not sorted addresses
119
+ // This matches the approach used in credentials: addressesIndex determines signature order
120
+ // AddressMaps should map addresses to signature slots in the same order as credentials
121
+ // Use centralized method for AddressMap creation
122
+ const addressMaps = credentials.map((credential, credIdx) => this.createAddressMapForUtxo(this.transaction._utxos[credIdx], this.transaction._threshold));
147
123
  // Create unsigned transaction
148
124
  const unsignedTx = new flarejs_1.UnsignedTx(importTx, [], // Empty UTXOs array
149
125
  new flarejs_1.utils.AddressMaps(addressMaps), credentials);
@@ -182,37 +158,8 @@ class ImportInPTxBuilder extends atomicTransactionBuilder_1.AtomicTransactionBui
182
158
  inputs.push(transferableInput);
183
159
  // Create credential with empty signatures for slot identification
184
160
  // Match avaxp behavior: dynamic ordering based on addressesIndex from UTXO
185
- const hasAddresses = this.transaction._fromAddresses && this.transaction._fromAddresses.length >= this.transaction._threshold;
186
- if (!hasAddresses) {
187
- // If addresses not available, use all zeros
188
- const emptySignatures = sigIndices.map(() => utils_1.default.createNewSig(''));
189
- credentials.push(new flarejs_1.Credential(emptySignatures));
190
- }
191
- else {
192
- // Compute addressesIndex: position of each _fromAddresses in UTXO's address list
193
- const utxoAddresses = utxo.addresses.map((a) => utils_1.default.parseAddress(a));
194
- const addressesIndex = this.transaction._fromAddresses.map((a) => utxoAddresses.findIndex((u) => Buffer.compare(Buffer.from(u), Buffer.from(a)) === 0));
195
- // either user (0) or recovery (2)
196
- const firstIndex = this.recoverSigner ? 2 : 0;
197
- const bitgoIndex = 1;
198
- // Dynamic ordering based on addressesIndex
199
- let emptySignatures;
200
- if (addressesIndex[bitgoIndex] < addressesIndex[firstIndex]) {
201
- // Bitgo comes first in signature order: [zeros, userAddress]
202
- emptySignatures = [
203
- utils_1.default.createNewSig(''),
204
- utils_1.default.createEmptySigWithAddress(Buffer.from(this.transaction._fromAddresses[firstIndex]).toString('hex')),
205
- ];
206
- }
207
- else {
208
- // User comes first in signature order: [userAddress, zeros]
209
- emptySignatures = [
210
- utils_1.default.createEmptySigWithAddress(Buffer.from(this.transaction._fromAddresses[firstIndex]).toString('hex')),
211
- utils_1.default.createNewSig(''),
212
- ];
213
- }
214
- credentials.push(new flarejs_1.Credential(emptySignatures));
215
- }
161
+ // Use centralized method for credential creation
162
+ credentials.push(this.createCredentialForUtxo(utxo, this.transaction._threshold));
216
163
  });
217
164
  return {
218
165
  inputs,
@@ -242,4 +189,4 @@ class ImportInPTxBuilder extends atomicTransactionBuilder_1.AtomicTransactionBui
242
189
  }
243
190
  }
244
191
  exports.ImportInPTxBuilder = ImportInPTxBuilder;
245
- //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"ImportInPTxBuilder.js","sourceRoot":"","sources":["../../../src/lib/ImportInPTxBuilder.ts"],"names":[],"mappings":"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","sourcesContent":["import { BaseCoin as CoinConfig } from '@bitgo-beta/statics';\nimport { BuildTransactionError, NotSupported, TransactionType } from '@bitgo-beta/sdk-core';\nimport { AtomicTransactionBuilder } from './atomicTransactionBuilder';\nimport {\n  pvmSerial,\n  avaxSerial,\n  UnsignedTx,\n  Int,\n  Id,\n  TransferableInput,\n  TransferableOutput,\n  TransferOutput,\n  TransferInput,\n  OutputOwners,\n  utils as FlareUtils,\n  Address,\n  BigIntPr,\n  Credential,\n  Bytes,\n} from '@flarenetwork/flarejs';\nimport utils from './utils';\nimport { DecodedUtxoObj, FlareTransactionType, SECP256K1_Transfer_Output, Tx } from './iface';\n\nexport class ImportInPTxBuilder extends AtomicTransactionBuilder {\n  constructor(_coinConfig: Readonly<CoinConfig>) {\n    super(_coinConfig);\n    // For Import INTO P-chain:\n    // - external chain (source) is C-chain\n    // - blockchain ID (destination) is P-chain\n    this._externalChainId = utils.cb58Decode(this.transaction._network.cChainBlockchainID);\n    // P-chain blockchain ID (from network config - typically all zeros for primary network)\n    this.transaction._blockchainID = Buffer.from(utils.cb58Decode(this.transaction._network.blockchainID)).toString(\n      'hex'\n    );\n  }\n\n  protected get transactionType(): TransactionType {\n    return TransactionType.Import;\n  }\n\n  initBuilder(tx: Tx, rawBytes?: Buffer, parsedCredentials?: Credential[]): this {\n    const importTx = tx as pvmSerial.ImportTx;\n\n    if (!this.verifyTxType(importTx._type)) {\n      throw new NotSupported('Transaction cannot be parsed or has an unsupported transaction type');\n    }\n\n    // The regular change output is the tx output in Import tx.\n    // It's expected to have only one output with the addresses of the sender.\n    const outputs = importTx.baseTx.outputs;\n    if (outputs.length !== 1) {\n      throw new BuildTransactionError('Transaction can have one external output');\n    }\n\n    const output = outputs[0];\n    const assetId = output.assetId.toBytes();\n    if (Buffer.compare(assetId, Buffer.from(this.transaction._assetId, 'hex')) !== 0) {\n      throw new Error('The Asset ID of the output does not match the transaction');\n    }\n\n    const transferOutput = output.output as TransferOutput;\n    const outputOwners = transferOutput.outputOwners;\n\n    // Set locktime from output\n    this.transaction._locktime = outputOwners.locktime.value();\n\n    // Set threshold from output\n    this.transaction._threshold = outputOwners.threshold.value();\n\n    // Convert output addresses to buffers and set as fromAddresses\n    this.transaction._fromAddresses = outputOwners.addrs.map((addr) => Buffer.from(addr.toBytes()));\n\n    // Set external chain ID from the source chain\n    this._externalChainId = Buffer.from(importTx.sourceChain.toBytes());\n\n    // Recover UTXOs from imported inputs\n    this.transaction._utxos = this.recoverUtxos(importTx.ins);\n\n    // Calculate and set fee from input/output difference\n    const totalInputAmount = importTx.ins.reduce((sum, input) => sum + input.amount(), BigInt(0));\n    const outputAmount = transferOutput.amount();\n    const fee = totalInputAmount - outputAmount;\n    this.transaction._fee.fee = fee.toString();\n\n    // Use credentials passed from TransactionBuilderFactory (properly extracted using codec)\n    const credentials = parsedCredentials || [];\n    const hasCredentials = credentials.length > 0;\n\n    // If there are credentials, store the original bytes to preserve exact format\n    if (rawBytes && hasCredentials) {\n      this.transaction._rawSignedBytes = rawBytes;\n    }\n\n    // Create proper UnsignedTx wrapper with credentials\n    const sortedAddresses = [...this.transaction._fromAddresses].sort((a, b) => Buffer.compare(a, b));\n    const addressMaps = sortedAddresses.map((a, i) => new FlareUtils.AddressMap([[new Address(a), i]]));\n\n    // When credentials were extracted, use them directly to preserve existing signatures\n    // Match avaxp behavior: dynamic ordering based on addressesIndex from UTXO\n    const txCredentials =\n      credentials.length > 0\n        ? credentials\n        : this.transaction._utxos.map((utxo) => {\n            // either user (0) or recovery (2)\n            const firstIndex = this.recoverSigner ? 2 : 0;\n            const bitgoIndex = 1;\n\n            // If UTXO has addresses, compute dynamic ordering\n            if (utxo && utxo.addresses && utxo.addresses.length > 0) {\n              const utxoAddresses = utxo.addresses.map((a) => utils.parseAddress(a));\n              const addressesIndex = this.transaction._fromAddresses.map((a) =>\n                utxoAddresses.findIndex((u) => Buffer.compare(Buffer.from(u), Buffer.from(a)) === 0)\n              );\n\n              // Dynamic ordering based on addressesIndex\n              let sigSlots: ReturnType<typeof utils.createNewSig>[];\n              if (addressesIndex[bitgoIndex] < addressesIndex[firstIndex]) {\n                // Bitgo comes first: [zeros, userAddress]\n                sigSlots = [\n                  utils.createNewSig(''),\n                  utils.createEmptySigWithAddress(\n                    Buffer.from(this.transaction._fromAddresses[firstIndex]).toString('hex')\n                  ),\n                ];\n              } else {\n                // User comes first: [userAddress, zeros]\n                sigSlots = [\n                  utils.createEmptySigWithAddress(\n                    Buffer.from(this.transaction._fromAddresses[firstIndex]).toString('hex')\n                  ),\n                  utils.createNewSig(''),\n                ];\n              }\n              return new Credential(sigSlots);\n            } else {\n              // Fallback: use all zeros if no UTXO addresses available\n              const sigSlots: ReturnType<typeof utils.createNewSig>[] = [];\n              for (let i = 0; i < this.transaction._threshold; i++) {\n                sigSlots.push(utils.createNewSig(''));\n              }\n              return new Credential(sigSlots);\n            }\n          });\n\n    const unsignedTx = new UnsignedTx(importTx, [], new FlareUtils.AddressMaps(addressMaps), txCredentials);\n\n    this.transaction.setTransaction(unsignedTx);\n    return this;\n  }\n\n  static verifyTxType(txnType: string): boolean {\n    return txnType === FlareTransactionType.PvmImportTx;\n  }\n\n  verifyTxType(txnType: string): boolean {\n    return ImportInPTxBuilder.verifyTxType(txnType);\n  }\n\n  /**\n   * Build the import transaction for P-chain\n   * @protected\n   */\n  protected buildFlareTransaction(): void {\n    // if tx has credentials, tx shouldn't change\n    if (this.transaction.hasCredentials) return;\n\n    const { inputs, credentials, totalAmount } = this.createImportInputs();\n\n    // Calculate fee from transaction fee settings\n    const fee = BigInt(this.transaction.fee.fee);\n    const outputAmount = totalAmount - fee;\n\n    // Create the output for P-chain (TransferableOutput with TransferOutput)\n    const assetIdBytes = new Uint8Array(Buffer.from(this.transaction._assetId, 'hex'));\n\n    // Create OutputOwners with the P-chain addresses (sorted by byte value as per AVAX protocol)\n    const sortedAddresses = [...this.transaction._fromAddresses].sort((a, b) => Buffer.compare(a, b));\n    const outputOwners = new OutputOwners(\n      new BigIntPr(this.transaction._locktime),\n      new Int(this.transaction._threshold),\n      sortedAddresses.map((addr) => new Address(addr))\n    );\n\n    const transferOutput = new TransferOutput(new BigIntPr(outputAmount), outputOwners);\n    const output = new TransferableOutput(new Id(assetIdBytes), transferOutput);\n\n    // Create the BaseTx for the P-chain import transaction\n    const baseTx = new avaxSerial.BaseTx(\n      new Int(this.transaction._networkID),\n      new Id(Buffer.from(this.transaction._blockchainID, 'hex')),\n      [output], // outputs\n      [], // inputs (empty for import - inputs come from importedInputs)\n      new Bytes(new Uint8Array(0)) // empty memo\n    );\n\n    // Create the P-chain import transaction using pvmSerial.ImportTx\n    const importTx = new pvmSerial.ImportTx(\n      baseTx,\n      new Id(this._externalChainId), // sourceChain (C-chain)\n      inputs // importedInputs (ins)\n    );\n\n    // Create address maps for signing\n    const addressMaps = this.transaction._fromAddresses.map((a, i) => new FlareUtils.AddressMap([[new Address(a), i]]));\n\n    // Create unsigned transaction\n    const unsignedTx = new UnsignedTx(\n      importTx,\n      [], // Empty UTXOs array\n      new FlareUtils.AddressMaps(addressMaps),\n      credentials\n    );\n\n    this.transaction.setTransaction(unsignedTx);\n  }\n\n  /**\n   * Create inputs from UTXOs for P-chain import\n   * @returns inputs, credentials, and total amount\n   */\n  protected createImportInputs(): {\n    inputs: TransferableInput[];\n    credentials: Credential[];\n    totalAmount: bigint;\n  } {\n    const sender = this.transaction._fromAddresses.slice();\n    if (this.recoverSigner) {\n      // switch first and last signer\n      const tmp = sender.pop();\n      sender.push(sender[0]);\n      if (tmp) {\n        sender[0] = tmp;\n      }\n    }\n\n    let totalAmount = BigInt(0);\n    const inputs: TransferableInput[] = [];\n    const credentials: Credential[] = [];\n\n    this.transaction._utxos.forEach((utxo: DecodedUtxoObj) => {\n      const amount = BigInt(utxo.amount);\n      totalAmount += amount;\n\n      // Create signature indices for threshold\n      const sigIndices: number[] = [];\n      for (let i = 0; i < this.transaction._threshold; i++) {\n        sigIndices.push(i);\n      }\n\n      // Use fromNative to create TransferableInput\n      // fromNative expects cb58-encoded strings for txId and assetId\n      const txIdCb58 = utxo.txid; // Already cb58 encoded\n      const assetIdCb58 = utils.cb58Encode(Buffer.from(this.transaction._assetId, 'hex'));\n\n      const transferableInput = TransferableInput.fromNative(\n        txIdCb58,\n        Number(utxo.outputidx),\n        assetIdCb58,\n        amount,\n        sigIndices\n      );\n\n      inputs.push(transferableInput);\n\n      // Create credential with empty signatures for slot identification\n      // Match avaxp behavior: dynamic ordering based on addressesIndex from UTXO\n      const hasAddresses =\n        this.transaction._fromAddresses && this.transaction._fromAddresses.length >= this.transaction._threshold;\n\n      if (!hasAddresses) {\n        // If addresses not available, use all zeros\n        const emptySignatures = sigIndices.map(() => utils.createNewSig(''));\n        credentials.push(new Credential(emptySignatures));\n      } else {\n        // Compute addressesIndex: position of each _fromAddresses in UTXO's address list\n        const utxoAddresses = utxo.addresses.map((a) => utils.parseAddress(a));\n        const addressesIndex = this.transaction._fromAddresses.map((a) =>\n          utxoAddresses.findIndex((u) => Buffer.compare(Buffer.from(u), Buffer.from(a)) === 0)\n        );\n\n        // either user (0) or recovery (2)\n        const firstIndex = this.recoverSigner ? 2 : 0;\n        const bitgoIndex = 1;\n\n        // Dynamic ordering based on addressesIndex\n        let emptySignatures: ReturnType<typeof utils.createNewSig>[];\n        if (addressesIndex[bitgoIndex] < addressesIndex[firstIndex]) {\n          // Bitgo comes first in signature order: [zeros, userAddress]\n          emptySignatures = [\n            utils.createNewSig(''),\n            utils.createEmptySigWithAddress(Buffer.from(this.transaction._fromAddresses[firstIndex]).toString('hex')),\n          ];\n        } else {\n          // User comes first in signature order: [userAddress, zeros]\n          emptySignatures = [\n            utils.createEmptySigWithAddress(Buffer.from(this.transaction._fromAddresses[firstIndex]).toString('hex')),\n            utils.createNewSig(''),\n          ];\n        }\n        credentials.push(new Credential(emptySignatures));\n      }\n    });\n\n    return {\n      inputs,\n      credentials,\n      totalAmount,\n    };\n  }\n\n  /**\n   * Recover UTXOs from imported inputs\n   * @param importedInputs Array of transferable inputs\n   * @returns Array of decoded UTXO objects\n   */\n  private recoverUtxos(importedInputs: TransferableInput[]): DecodedUtxoObj[] {\n    return importedInputs.map((input) => {\n      const utxoId = input.utxoID;\n      const transferInput = input.input as TransferInput;\n      const utxo: DecodedUtxoObj = {\n        outputID: SECP256K1_Transfer_Output,\n        amount: transferInput.amount().toString(),\n        txid: utils.cb58Encode(Buffer.from(utxoId.txID.toBytes())),\n        outputidx: utxoId.outputIdx.value().toString(),\n        threshold: this.transaction._threshold,\n        addresses: this.transaction._fromAddresses.map((addr) =>\n          utils.addressToString(this.transaction._network.hrp, this.transaction._network.alias, Buffer.from(addr))\n        ),\n      };\n      return utxo;\n    });\n  }\n}\n"]}
192
+ //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"ImportInPTxBuilder.js","sourceRoot":"","sources":["../../../src/lib/ImportInPTxBuilder.ts"],"names":[],"mappings":"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","sourcesContent":["import { BaseCoin as CoinConfig } from '@bitgo-beta/statics';\nimport { BuildTransactionError, NotSupported, TransactionType } from '@bitgo-beta/sdk-core';\nimport { AtomicTransactionBuilder } from './atomicTransactionBuilder';\nimport {\n  pvmSerial,\n  avaxSerial,\n  UnsignedTx,\n  Int,\n  Id,\n  TransferableInput,\n  TransferableOutput,\n  TransferOutput,\n  TransferInput,\n  OutputOwners,\n  utils as FlareUtils,\n  Address,\n  BigIntPr,\n  Credential,\n  Bytes,\n} from '@flarenetwork/flarejs';\nimport utils from './utils';\nimport { DecodedUtxoObj, FlareTransactionType, SECP256K1_Transfer_Output, Tx } from './iface';\n\nexport class ImportInPTxBuilder extends AtomicTransactionBuilder {\n  constructor(_coinConfig: Readonly<CoinConfig>) {\n    super(_coinConfig);\n    // For Import INTO P-chain:\n    // - external chain (source) is C-chain\n    // - blockchain ID (destination) is P-chain\n    this._externalChainId = utils.cb58Decode(this.transaction._network.cChainBlockchainID);\n    // P-chain blockchain ID (from network config - typically all zeros for primary network)\n    this.transaction._blockchainID = Buffer.from(utils.cb58Decode(this.transaction._network.blockchainID)).toString(\n      'hex'\n    );\n  }\n\n  protected get transactionType(): TransactionType {\n    return TransactionType.Import;\n  }\n\n  initBuilder(tx: Tx, rawBytes?: Buffer, parsedCredentials?: Credential[]): this {\n    const importTx = tx as pvmSerial.ImportTx;\n\n    if (!this.verifyTxType(importTx._type)) {\n      throw new NotSupported('Transaction cannot be parsed or has an unsupported transaction type');\n    }\n\n    // The regular change output is the tx output in Import tx.\n    // It's expected to have only one output with the addresses of the sender.\n    const outputs = importTx.baseTx.outputs;\n    if (outputs.length !== 1) {\n      throw new BuildTransactionError('Transaction can have one external output');\n    }\n\n    const output = outputs[0];\n    const assetId = output.assetId.toBytes();\n    if (Buffer.compare(assetId, Buffer.from(this.transaction._assetId, 'hex')) !== 0) {\n      throw new Error('The Asset ID of the output does not match the transaction');\n    }\n\n    const transferOutput = output.output as TransferOutput;\n    const outputOwners = transferOutput.outputOwners;\n\n    // Set locktime from output\n    this.transaction._locktime = outputOwners.locktime.value();\n\n    // Set threshold from output\n    this.transaction._threshold = outputOwners.threshold.value();\n\n    // Convert output addresses to buffers and set as fromAddresses\n    this.transaction._fromAddresses = outputOwners.addrs.map((addr) => Buffer.from(addr.toBytes()));\n\n    // Set external chain ID from the source chain\n    this._externalChainId = Buffer.from(importTx.sourceChain.toBytes());\n\n    // Recover UTXOs from imported inputs\n    this.transaction._utxos = this.recoverUtxos(importTx.ins);\n\n    // Calculate and set fee from input/output difference\n    const totalInputAmount = importTx.ins.reduce((sum, input) => sum + input.amount(), BigInt(0));\n    const outputAmount = transferOutput.amount();\n    const fee = totalInputAmount - outputAmount;\n    this.transaction._fee.fee = fee.toString();\n\n    // Use credentials passed from TransactionBuilderFactory (properly extracted using codec)\n    const credentials = parsedCredentials || [];\n    const hasCredentials = credentials.length > 0;\n\n    // If there are credentials, store the original bytes to preserve exact format\n    if (rawBytes && hasCredentials) {\n      this.transaction._rawSignedBytes = rawBytes;\n    }\n\n    // Create proper UnsignedTx wrapper with credentials\n    // Match avaxp behavior: dynamic ordering based on addressesIndex from UTXO\n    // Use centralized methods for credential and AddressMap creation\n    const txCredentials =\n      credentials.length > 0\n        ? credentials\n        : this.transaction._utxos.map((utxo) => this.createCredentialForUtxo(utxo, this.transaction._threshold));\n\n    // Create AddressMaps based on signature slot order (matching credential order), not sorted addresses\n    // This matches the approach used in credentials: addressesIndex determines signature order\n    // AddressMaps should map addresses to signature slots in the same order as credentials\n    const addressMaps = this.transaction._utxos.map((utxo) =>\n      this.createAddressMapForUtxo(utxo, this.transaction._threshold)\n    );\n\n    const unsignedTx = new UnsignedTx(importTx, [], new FlareUtils.AddressMaps(addressMaps), txCredentials);\n\n    this.transaction.setTransaction(unsignedTx);\n    return this;\n  }\n\n  static verifyTxType(txnType: string): boolean {\n    return txnType === FlareTransactionType.PvmImportTx;\n  }\n\n  verifyTxType(txnType: string): boolean {\n    return ImportInPTxBuilder.verifyTxType(txnType);\n  }\n\n  /**\n   * Build the import transaction for P-chain\n   * @protected\n   */\n  protected buildFlareTransaction(): void {\n    // if tx has credentials, tx shouldn't change\n    if (this.transaction.hasCredentials) return;\n\n    const { inputs, credentials, totalAmount } = this.createImportInputs();\n\n    // Calculate fee from transaction fee settings\n    const fee = BigInt(this.transaction.fee.fee);\n\n    // Validate that totalAmount is sufficient to cover the fee (matching AVAX validation)\n    // This ensures we don't create transactions with insufficient funds\n    if (totalAmount < fee) {\n      throw new BuildTransactionError(`Utxo outputs get ${totalAmount.toString()} and ${fee.toString()} is required`);\n    }\n\n    const outputAmount = totalAmount - fee;\n\n    // Create the output for P-chain (TransferableOutput with TransferOutput)\n    const assetIdBytes = new Uint8Array(Buffer.from(this.transaction._assetId, 'hex'));\n\n    // Create OutputOwners with the P-chain addresses (sorted by byte value as per AVAX protocol)\n    const sortedAddresses = [...this.transaction._fromAddresses].sort((a, b) => Buffer.compare(a, b));\n    const outputOwners = new OutputOwners(\n      new BigIntPr(this.transaction._locktime),\n      new Int(this.transaction._threshold),\n      sortedAddresses.map((addr) => new Address(addr))\n    );\n\n    const transferOutput = new TransferOutput(new BigIntPr(outputAmount), outputOwners);\n    const output = new TransferableOutput(new Id(assetIdBytes), transferOutput);\n\n    // Create the BaseTx for the P-chain import transaction\n    const baseTx = new avaxSerial.BaseTx(\n      new Int(this.transaction._networkID),\n      new Id(Buffer.from(this.transaction._blockchainID, 'hex')),\n      [output], // outputs\n      [], // inputs (empty for import - inputs come from importedInputs)\n      new Bytes(new Uint8Array(0)) // empty memo\n    );\n\n    // Create the P-chain import transaction using pvmSerial.ImportTx\n    const importTx = new pvmSerial.ImportTx(\n      baseTx,\n      new Id(this._externalChainId), // sourceChain (C-chain)\n      inputs // importedInputs (ins)\n    );\n\n    // Create AddressMaps based on signature slot order (matching credential order), not sorted addresses\n    // This matches the approach used in credentials: addressesIndex determines signature order\n    // AddressMaps should map addresses to signature slots in the same order as credentials\n    // Use centralized method for AddressMap creation\n    const addressMaps = credentials.map((credential, credIdx) =>\n      this.createAddressMapForUtxo(this.transaction._utxos[credIdx], this.transaction._threshold)\n    );\n\n    // Create unsigned transaction\n    const unsignedTx = new UnsignedTx(\n      importTx,\n      [], // Empty UTXOs array\n      new FlareUtils.AddressMaps(addressMaps),\n      credentials\n    );\n\n    this.transaction.setTransaction(unsignedTx);\n  }\n\n  /**\n   * Create inputs from UTXOs for P-chain import\n   * @returns inputs, credentials, and total amount\n   */\n  protected createImportInputs(): {\n    inputs: TransferableInput[];\n    credentials: Credential[];\n    totalAmount: bigint;\n  } {\n    const sender = this.transaction._fromAddresses.slice();\n    if (this.recoverSigner) {\n      // switch first and last signer\n      const tmp = sender.pop();\n      sender.push(sender[0]);\n      if (tmp) {\n        sender[0] = tmp;\n      }\n    }\n\n    let totalAmount = BigInt(0);\n    const inputs: TransferableInput[] = [];\n    const credentials: Credential[] = [];\n\n    this.transaction._utxos.forEach((utxo: DecodedUtxoObj) => {\n      const amount = BigInt(utxo.amount);\n      totalAmount += amount;\n\n      // Create signature indices for threshold\n      const sigIndices: number[] = [];\n      for (let i = 0; i < this.transaction._threshold; i++) {\n        sigIndices.push(i);\n      }\n\n      // Use fromNative to create TransferableInput\n      // fromNative expects cb58-encoded strings for txId and assetId\n      const txIdCb58 = utxo.txid; // Already cb58 encoded\n      const assetIdCb58 = utils.cb58Encode(Buffer.from(this.transaction._assetId, 'hex'));\n\n      const transferableInput = TransferableInput.fromNative(\n        txIdCb58,\n        Number(utxo.outputidx),\n        assetIdCb58,\n        amount,\n        sigIndices\n      );\n\n      inputs.push(transferableInput);\n\n      // Create credential with empty signatures for slot identification\n      // Match avaxp behavior: dynamic ordering based on addressesIndex from UTXO\n      // Use centralized method for credential creation\n      credentials.push(this.createCredentialForUtxo(utxo, this.transaction._threshold));\n    });\n\n    return {\n      inputs,\n      credentials,\n      totalAmount,\n    };\n  }\n\n  /**\n   * Recover UTXOs from imported inputs\n   * @param importedInputs Array of transferable inputs\n   * @returns Array of decoded UTXO objects\n   */\n  private recoverUtxos(importedInputs: TransferableInput[]): DecodedUtxoObj[] {\n    return importedInputs.map((input) => {\n      const utxoId = input.utxoID;\n      const transferInput = input.input as TransferInput;\n      const utxo: DecodedUtxoObj = {\n        outputID: SECP256K1_Transfer_Output,\n        amount: transferInput.amount().toString(),\n        txid: utils.cb58Encode(Buffer.from(utxoId.txID.toBytes())),\n        outputidx: utxoId.outputIdx.value().toString(),\n        threshold: this.transaction._threshold,\n        addresses: this.transaction._fromAddresses.map((addr) =>\n          utils.addressToString(this.transaction._network.hrp, this.transaction._network.alias, Buffer.from(addr))\n        ),\n      };\n      return utxo;\n    });\n  }\n}\n"]}