@bitgo-beta/sdk-coin-flrp 1.0.1-beta.266 → 1.0.1-beta.267
This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
- package/dist/src/flrp.d.ts +6 -75
- package/dist/src/flrp.d.ts.map +1 -1
- package/dist/src/flrp.js +13 -298
- package/dist/src/index.d.ts +0 -1
- package/dist/src/index.d.ts.map +1 -1
- package/dist/src/index.js +1 -2
- package/dist/src/lib/ExportInCTxBuilder.d.ts +50 -0
- package/dist/src/lib/ExportInCTxBuilder.d.ts.map +1 -0
- package/dist/src/lib/ExportInCTxBuilder.js +163 -0
- package/dist/src/lib/ExportInPTxBuilder.d.ts +36 -0
- package/dist/src/lib/ExportInPTxBuilder.d.ts.map +1 -0
- package/dist/src/lib/ExportInPTxBuilder.js +128 -0
- package/dist/src/lib/ImportInCTxBuilder.d.ts +47 -0
- package/dist/src/lib/ImportInCTxBuilder.d.ts.map +1 -0
- package/dist/src/lib/ImportInCTxBuilder.js +213 -0
- package/dist/src/lib/ImportInPTxBuilder.d.ts +23 -0
- package/dist/src/lib/ImportInPTxBuilder.d.ts.map +1 -0
- package/dist/src/lib/ImportInPTxBuilder.js +101 -0
- package/dist/src/lib/atomicInCTransactionBuilder.d.ts +18 -16
- package/dist/src/lib/atomicInCTransactionBuilder.d.ts.map +1 -1
- package/dist/src/lib/atomicInCTransactionBuilder.js +38 -36
- package/dist/src/lib/atomicTransactionBuilder.d.ts +34 -84
- package/dist/src/lib/atomicTransactionBuilder.d.ts.map +1 -1
- package/dist/src/lib/atomicTransactionBuilder.js +119 -288
- package/dist/src/lib/iface.d.ts +50 -51
- package/dist/src/lib/iface.d.ts.map +1 -1
- package/dist/src/lib/iface.js +22 -10
- package/dist/src/lib/index.d.ts +2 -3
- package/dist/src/lib/index.d.ts.map +1 -1
- package/dist/src/lib/index.js +5 -6
- package/dist/src/lib/keyPair.d.ts +1 -1
- package/dist/src/lib/keyPair.d.ts.map +1 -1
- package/dist/src/lib/keyPair.js +9 -5
- package/dist/src/lib/permissionlessValidatorTxBuilder.d.ts +32 -67
- package/dist/src/lib/permissionlessValidatorTxBuilder.d.ts.map +1 -1
- package/dist/src/lib/permissionlessValidatorTxBuilder.js +91 -205
- package/dist/src/lib/transaction.d.ts +8 -74
- package/dist/src/lib/transaction.d.ts.map +1 -1
- package/dist/src/lib/transaction.js +61 -210
- package/dist/src/lib/transactionBuilder.d.ts +56 -34
- package/dist/src/lib/transactionBuilder.d.ts.map +1 -1
- package/dist/src/lib/transactionBuilder.js +112 -69
- package/dist/src/lib/transactionBuilderFactory.d.ts +27 -30
- package/dist/src/lib/transactionBuilderFactory.d.ts.map +1 -1
- package/dist/src/lib/transactionBuilderFactory.js +69 -75
- package/dist/src/lib/utils.d.ts +58 -157
- package/dist/src/lib/utils.d.ts.map +1 -1
- package/dist/src/lib/utils.js +134 -399
- package/dist/test/resources/transactionData/exportInC.d.ts +20 -0
- package/dist/test/resources/transactionData/exportInC.d.ts.map +1 -0
- package/dist/test/resources/transactionData/exportInC.js +30 -0
- package/dist/test/unit/lib/exportInCTxBuilder.js +92 -513
- package/dist/tsconfig.tsbuildinfo +1 -1
- package/package.json +9 -11
- package/dist/src/iface.d.ts +0 -25
- package/dist/src/iface.d.ts.map +0 -1
- package/dist/src/iface.js +0 -3
- package/dist/src/lib/constants.d.ts +0 -170
- package/dist/src/lib/constants.d.ts.map +0 -1
- package/dist/src/lib/constants.js +0 -227
- package/dist/src/lib/delegatorTxBuilder.d.ts +0 -58
- package/dist/src/lib/delegatorTxBuilder.d.ts.map +0 -1
- package/dist/src/lib/delegatorTxBuilder.js +0 -224
- package/dist/src/lib/errors.d.ts +0 -8
- package/dist/src/lib/errors.d.ts.map +0 -1
- package/dist/src/lib/errors.js +0 -19
- package/dist/src/lib/exportInCTxBuilder.d.ts +0 -77
- package/dist/src/lib/exportInCTxBuilder.d.ts.map +0 -1
- package/dist/src/lib/exportInCTxBuilder.js +0 -199
- package/dist/src/lib/exportInPTxBuilder.d.ts +0 -30
- package/dist/src/lib/exportInPTxBuilder.d.ts.map +0 -1
- package/dist/src/lib/exportInPTxBuilder.js +0 -120
- package/dist/src/lib/importInCTxBuilder.d.ts +0 -67
- package/dist/src/lib/importInCTxBuilder.d.ts.map +0 -1
- package/dist/src/lib/importInCTxBuilder.js +0 -403
- package/dist/src/lib/importInPTxBuilder.d.ts +0 -73
- package/dist/src/lib/importInPTxBuilder.d.ts.map +0 -1
- package/dist/src/lib/importInPTxBuilder.js +0 -464
- package/dist/src/lib/types.d.ts +0 -78
- package/dist/src/lib/types.d.ts.map +0 -1
- package/dist/src/lib/types.js +0 -5
- package/dist/src/lib/validatorTxBuilder.d.ts +0 -40
- package/dist/src/lib/validatorTxBuilder.d.ts.map +0 -1
- package/dist/src/lib/validatorTxBuilder.js +0 -180
- package/dist/test/unit/delegatorTxBuilder.test.d.ts +0 -2
- package/dist/test/unit/delegatorTxBuilder.test.d.ts.map +0 -1
- package/dist/test/unit/delegatorTxBuilder.test.js +0 -233
- package/dist/test/unit/flrp.d.ts +0 -2
- package/dist/test/unit/flrp.d.ts.map +0 -1
- package/dist/test/unit/flrp.js +0 -118
- package/dist/test/unit/lib/atomicTransactionBuilder.d.ts +0 -2
- package/dist/test/unit/lib/atomicTransactionBuilder.d.ts.map +0 -1
- package/dist/test/unit/lib/atomicTransactionBuilder.js +0 -222
- package/dist/test/unit/lib/exportInPTxBuilder.d.ts +0 -2
- package/dist/test/unit/lib/exportInPTxBuilder.d.ts.map +0 -1
- package/dist/test/unit/lib/exportInPTxBuilder.js +0 -377
- package/dist/test/unit/lib/importInCTxBuilder.d.ts +0 -2
- package/dist/test/unit/lib/importInCTxBuilder.d.ts.map +0 -1
- package/dist/test/unit/lib/importInCTxBuilder.js +0 -258
- package/dist/test/unit/lib/importInPTxBuilder.d.ts +0 -2
- package/dist/test/unit/lib/importInPTxBuilder.d.ts.map +0 -1
- package/dist/test/unit/lib/importInPTxBuilder.js +0 -501
- package/dist/test/unit/lib/transaction.d.ts +0 -2
- package/dist/test/unit/lib/transaction.d.ts.map +0 -1
- package/dist/test/unit/lib/transaction.js +0 -460
- package/dist/test/unit/lib/utils.d.ts +0 -2
- package/dist/test/unit/lib/utils.d.ts.map +0 -1
- package/dist/test/unit/lib/utils.js +0 -365
- package/dist/test/unit/permissionlessValidatorTxBuilder.test.d.ts +0 -2
- package/dist/test/unit/permissionlessValidatorTxBuilder.test.d.ts.map +0 -1
- package/dist/test/unit/permissionlessValidatorTxBuilder.test.js +0 -271
- package/dist/test/unit/smoke.d.ts +0 -2
- package/dist/test/unit/smoke.d.ts.map +0 -1
- package/dist/test/unit/smoke.js +0 -23
- package/dist/test/unit/transactionBuilder.test.d.ts +0 -2
- package/dist/test/unit/transactionBuilder.test.d.ts.map +0 -1
- package/dist/test/unit/transactionBuilder.test.js +0 -114
- package/dist/test/unit/validatorTxBuilder.test.d.ts +0 -2
- package/dist/test/unit/validatorTxBuilder.test.d.ts.map +0 -1
- package/dist/test/unit/validatorTxBuilder.test.js +0 -293
|
@@ -1,318 +1,149 @@
|
|
|
1
1
|
"use strict";
|
|
2
2
|
Object.defineProperty(exports, "__esModule", { value: true });
|
|
3
3
|
exports.AtomicTransactionBuilder = void 0;
|
|
4
|
-
const
|
|
4
|
+
const transactionBuilder_1 = require("./transactionBuilder");
|
|
5
|
+
const transaction_1 = require("./transaction");
|
|
5
6
|
const flarejs_1 = require("@flarenetwork/flarejs");
|
|
6
|
-
|
|
7
|
-
|
|
8
|
-
|
|
9
|
-
|
|
10
|
-
|
|
11
|
-
* credential handling using FlareJS Credential and Signature classes.
|
|
12
|
-
*/
|
|
13
|
-
class AtomicTransactionBuilder {
|
|
14
|
-
constructor(coinConfig) {
|
|
15
|
-
this._utxos = [];
|
|
16
|
-
this.transaction = {
|
|
17
|
-
_network: {},
|
|
18
|
-
_networkID: constants_1.DEFAULT_NETWORK_ID,
|
|
19
|
-
_blockchainID: Buffer.alloc(constants_1.EMPTY_BUFFER_SIZE),
|
|
20
|
-
_assetId: Buffer.alloc(constants_1.EMPTY_BUFFER_SIZE),
|
|
21
|
-
_fromAddresses: [],
|
|
22
|
-
_to: [],
|
|
23
|
-
_locktime: constants_1.DEFAULT_LOCKTIME,
|
|
24
|
-
_threshold: constants_1.DEFAULT_THRESHOLD,
|
|
25
|
-
_fee: { fee: constants_1.AMOUNT_STRING_ZERO },
|
|
26
|
-
hasCredentials: false,
|
|
27
|
-
setTransaction: function (_tx) {
|
|
28
|
-
this._tx = _tx;
|
|
29
|
-
},
|
|
30
|
-
};
|
|
31
|
-
this._coinConfig = coinConfig;
|
|
32
|
-
}
|
|
33
|
-
/**
|
|
34
|
-
* Get the asset ID for Flare network transactions
|
|
35
|
-
* @returns Buffer containing the asset ID
|
|
36
|
-
*/
|
|
37
|
-
getAssetId() {
|
|
38
|
-
// Use the asset ID from transaction if already set
|
|
39
|
-
if (this.transaction._assetId && this.transaction._assetId.length > 0) {
|
|
40
|
-
return this.transaction._assetId;
|
|
41
|
-
}
|
|
42
|
-
// For native FLR transactions, return zero-filled buffer as placeholder
|
|
43
|
-
// In a real implementation, this would be obtained from the network configuration
|
|
44
|
-
// or FlareJS API to get the actual native asset ID
|
|
45
|
-
return Buffer.alloc(constants_1.ASSET_ID_LENGTH);
|
|
46
|
-
}
|
|
47
|
-
validateAmount(amount) {
|
|
48
|
-
if (amount <= constants_1.ZERO_BIGINT) {
|
|
49
|
-
throw new sdk_core_1.BuildTransactionError(constants_1.ERROR_AMOUNT_POSITIVE);
|
|
50
|
-
}
|
|
7
|
+
class AtomicTransactionBuilder extends transactionBuilder_1.TransactionBuilder {
|
|
8
|
+
constructor(_coinConfig) {
|
|
9
|
+
super(_coinConfig);
|
|
10
|
+
this.recoverSigner = false;
|
|
11
|
+
this.transaction = new transaction_1.Transaction(_coinConfig);
|
|
51
12
|
}
|
|
52
13
|
/**
|
|
53
|
-
*
|
|
54
|
-
* @param
|
|
14
|
+
* Create inputs and outputs from UTXOs
|
|
15
|
+
* @param {bigint} amount Amount to transfer
|
|
16
|
+
* @return {
|
|
17
|
+
* inputs: TransferableInput[];
|
|
18
|
+
* outputs: TransferableInput[];
|
|
19
|
+
* credentials: Credential[];
|
|
20
|
+
* }
|
|
21
|
+
* @protected
|
|
55
22
|
*/
|
|
56
|
-
|
|
57
|
-
|
|
58
|
-
|
|
59
|
-
|
|
60
|
-
|
|
61
|
-
|
|
62
|
-
|
|
23
|
+
createInputOutput(amount) {
|
|
24
|
+
const sender = this.transaction._fromAddresses.slice();
|
|
25
|
+
if (this.recoverSigner) {
|
|
26
|
+
// switch first and last signer
|
|
27
|
+
const tmp = sender.pop();
|
|
28
|
+
sender.push(sender[0]);
|
|
29
|
+
if (tmp) {
|
|
30
|
+
sender[0] = tmp;
|
|
63
31
|
}
|
|
64
|
-
});
|
|
65
|
-
}
|
|
66
|
-
/**
|
|
67
|
-
* Creates inputs, outputs, and credentials for Flare P-chain atomic transactions.
|
|
68
|
-
* Based on AVAX P-chain implementation adapted for FlareJS.
|
|
69
|
-
*
|
|
70
|
-
* Note: This is a simplified implementation that creates the core structure.
|
|
71
|
-
* The FlareJS type system integration will be refined in future iterations.
|
|
72
|
-
*
|
|
73
|
-
* @param total - Total amount needed including fees
|
|
74
|
-
* @returns Object containing TransferableInput[], TransferableOutput[], and Credential[]
|
|
75
|
-
*/
|
|
76
|
-
createInputOutput(total) {
|
|
77
|
-
if (!this._utxos || this._utxos.length === constants_1.ZERO_NUMBER) {
|
|
78
|
-
throw new sdk_core_1.BuildTransactionError(constants_1.ERROR_UTXOS_REQUIRED);
|
|
79
32
|
}
|
|
33
|
+
let totalAmount = BigInt(0);
|
|
80
34
|
const inputs = [];
|
|
81
35
|
const outputs = [];
|
|
82
36
|
const credentials = [];
|
|
83
|
-
|
|
84
|
-
const addressIndices = {};
|
|
85
|
-
let nextAddressIndex = 0;
|
|
86
|
-
// Sort UTXOs by amount in descending order for optimal coin selection
|
|
87
|
-
const sortedUtxos = [...this._utxos].sort((a, b) => {
|
|
88
|
-
const amountA = BigInt(a.amount);
|
|
89
|
-
const amountB = BigInt(b.amount);
|
|
90
|
-
if (amountA > amountB)
|
|
91
|
-
return -1;
|
|
92
|
-
if (amountA < amountB)
|
|
93
|
-
return 1;
|
|
94
|
-
return 0;
|
|
95
|
-
});
|
|
96
|
-
// Process UTXOs to create inputs and credentials
|
|
97
|
-
for (const utxo of sortedUtxos) {
|
|
37
|
+
this.transaction._utxos.forEach((utxo) => {
|
|
98
38
|
const utxoAmount = BigInt(utxo.amount);
|
|
99
|
-
|
|
100
|
-
|
|
101
|
-
|
|
102
|
-
|
|
103
|
-
|
|
104
|
-
|
|
105
|
-
|
|
106
|
-
|
|
107
|
-
|
|
108
|
-
|
|
109
|
-
|
|
110
|
-
|
|
111
|
-
|
|
112
|
-
|
|
113
|
-
|
|
114
|
-
// Create TransferableInput for atomic transactions
|
|
115
|
-
const transferableInput = {
|
|
116
|
-
txID: Buffer.from(utxo.txid || constants_1.AMOUNT_STRING_ZERO.repeat(constants_1.TRANSACTION_ID_HEX_LENGTH), constants_1.HEX_ENCODING),
|
|
117
|
-
outputIndex: parseInt(utxo.outputidx || constants_1.AMOUNT_STRING_ZERO, constants_1.DECIMAL_RADIX),
|
|
118
|
-
assetID: this.getAssetId(),
|
|
119
|
-
input: {
|
|
120
|
-
amount: utxoAmount,
|
|
121
|
-
addressIndices: addressIndexArray,
|
|
122
|
-
threshold: utxo.threshold,
|
|
39
|
+
totalAmount += utxoAmount;
|
|
40
|
+
// Create input
|
|
41
|
+
const input = {
|
|
42
|
+
_type: flarejs_1.TypeSymbols.Input,
|
|
43
|
+
amount: () => utxoAmount,
|
|
44
|
+
sigIndices: sender.map((_, i) => i),
|
|
45
|
+
toBytes: () => new Uint8Array(),
|
|
46
|
+
};
|
|
47
|
+
// Create asset with Amounter interface
|
|
48
|
+
const assetId = {
|
|
49
|
+
_type: flarejs_1.TypeSymbols.BaseTx,
|
|
50
|
+
amount: () => utxoAmount,
|
|
51
|
+
toBytes: () => {
|
|
52
|
+
const bytes = new Uint8Array(Buffer.from(this.transaction._assetId, 'hex'));
|
|
53
|
+
return bytes;
|
|
123
54
|
},
|
|
124
55
|
};
|
|
125
|
-
//
|
|
56
|
+
// Create TransferableInput
|
|
57
|
+
const transferableInput = new flarejs_1.TransferableInput({
|
|
58
|
+
_type: flarejs_1.TypeSymbols.UTXOID,
|
|
59
|
+
txID: new flarejs_1.Id(new Uint8Array(Buffer.from(utxo.txid, 'hex'))),
|
|
60
|
+
outputIdx: new flarejs_1.Int(Number(utxo.outputidx)),
|
|
61
|
+
ID: () => utxo.txid,
|
|
62
|
+
toBytes: () => {
|
|
63
|
+
const txIdBytes = new Uint8Array(Buffer.from(utxo.txid, 'hex'));
|
|
64
|
+
const outputIdxBytes = new Uint8Array(4);
|
|
65
|
+
new DataView(outputIdxBytes.buffer).setInt32(0, Number(utxo.outputidx), true);
|
|
66
|
+
return Buffer.concat([txIdBytes, outputIdxBytes]);
|
|
67
|
+
},
|
|
68
|
+
}, new flarejs_1.Id(new Uint8Array(Buffer.from(utxo.outputidx.toString()))), assetId);
|
|
69
|
+
// Set input properties
|
|
70
|
+
Object.assign(transferableInput, { input });
|
|
126
71
|
inputs.push(transferableInput);
|
|
127
|
-
// Create credential
|
|
128
|
-
|
|
129
|
-
|
|
130
|
-
|
|
131
|
-
|
|
132
|
-
|
|
133
|
-
|
|
134
|
-
|
|
135
|
-
|
|
136
|
-
|
|
137
|
-
|
|
138
|
-
|
|
139
|
-
|
|
140
|
-
|
|
141
|
-
|
|
142
|
-
|
|
143
|
-
|
|
144
|
-
|
|
145
|
-
|
|
146
|
-
|
|
147
|
-
|
|
72
|
+
// Create empty credential for each input
|
|
73
|
+
const emptySignatures = sender.map(() => Buffer.alloc(0));
|
|
74
|
+
credentials.push({ signatures: emptySignatures });
|
|
75
|
+
});
|
|
76
|
+
// Create output if there is change
|
|
77
|
+
if (totalAmount > amount) {
|
|
78
|
+
const changeAmount = totalAmount - amount;
|
|
79
|
+
const output = {
|
|
80
|
+
_type: flarejs_1.TypeSymbols.BaseTx,
|
|
81
|
+
amount: () => changeAmount,
|
|
82
|
+
addresses: sender,
|
|
83
|
+
locktime: this.transaction._locktime,
|
|
84
|
+
threshold: this.transaction._threshold,
|
|
85
|
+
toBytes: () => new Uint8Array(),
|
|
86
|
+
};
|
|
87
|
+
// Create asset with Amounter interface
|
|
88
|
+
const assetId = {
|
|
89
|
+
_type: flarejs_1.TypeSymbols.BaseTx,
|
|
90
|
+
amount: () => changeAmount,
|
|
91
|
+
toBytes: () => {
|
|
92
|
+
const bytes = new Uint8Array(Buffer.from(this.transaction._assetId, 'hex'));
|
|
93
|
+
return bytes;
|
|
148
94
|
},
|
|
149
95
|
};
|
|
150
|
-
//
|
|
151
|
-
|
|
152
|
-
|
|
153
|
-
|
|
154
|
-
|
|
155
|
-
|
|
156
|
-
|
|
157
|
-
|
|
158
|
-
|
|
159
|
-
|
|
160
|
-
|
|
161
|
-
|
|
162
|
-
|
|
163
|
-
|
|
164
|
-
|
|
165
|
-
|
|
166
|
-
|
|
167
|
-
|
|
168
|
-
|
|
169
|
-
|
|
170
|
-
|
|
171
|
-
* @returns Credential instance
|
|
172
|
-
*/
|
|
173
|
-
createFlareCredential(_credentialId, signatures) {
|
|
174
|
-
if (!Array.isArray(signatures)) {
|
|
175
|
-
throw new sdk_core_1.BuildTransactionError(constants_1.ERROR_SIGNATURES_ARRAY);
|
|
176
|
-
}
|
|
177
|
-
if (signatures.length === constants_1.ZERO_NUMBER) {
|
|
178
|
-
throw new sdk_core_1.BuildTransactionError(constants_1.ERROR_SIGNATURES_EMPTY);
|
|
179
|
-
}
|
|
180
|
-
const sigs = signatures.map((sig, index) => {
|
|
181
|
-
// Handle empty/placeholder signatures
|
|
182
|
-
if (!sig || sig.length === 0) {
|
|
183
|
-
return new flarejs_1.Signature(new Uint8Array(constants_1.SECP256K1_SIGNATURE_LENGTH));
|
|
184
|
-
}
|
|
185
|
-
// Validate hex string format
|
|
186
|
-
const cleanSig = sig.startsWith(constants_1.HEX_PREFIX) ? sig.slice(constants_1.HEX_PREFIX_LENGTH) : sig;
|
|
187
|
-
if (!(0, utils_1.createFlexibleHexRegex)().test(cleanSig)) {
|
|
188
|
-
throw new sdk_core_1.BuildTransactionError(`Invalid hex signature at index ${index}: contains non-hex characters`);
|
|
189
|
-
}
|
|
190
|
-
// Convert to buffer and validate length
|
|
191
|
-
const sigBuffer = Buffer.from(cleanSig, constants_1.HEX_ENCODING);
|
|
192
|
-
if (sigBuffer.length > constants_1.SECP256K1_SIGNATURE_LENGTH) {
|
|
193
|
-
throw new sdk_core_1.BuildTransactionError(`Signature too long at index ${index}: ${sigBuffer.length} bytes (max ${constants_1.SECP256K1_SIGNATURE_LENGTH})`);
|
|
194
|
-
}
|
|
195
|
-
// Create fixed-length buffer and copy signature data
|
|
196
|
-
const fixedLengthBuffer = Buffer.alloc(constants_1.SECP256K1_SIGNATURE_LENGTH);
|
|
197
|
-
sigBuffer.copy(fixedLengthBuffer);
|
|
198
|
-
try {
|
|
199
|
-
return new flarejs_1.Signature(new Uint8Array(fixedLengthBuffer));
|
|
200
|
-
}
|
|
201
|
-
catch (error) {
|
|
202
|
-
throw new sdk_core_1.BuildTransactionError(`Failed to create signature at index ${index}: ${error instanceof Error ? error.message : constants_1.ERROR_UNKNOWN}`);
|
|
203
|
-
}
|
|
204
|
-
});
|
|
205
|
-
try {
|
|
206
|
-
return new flarejs_1.Credential(sigs);
|
|
207
|
-
}
|
|
208
|
-
catch (error) {
|
|
209
|
-
throw new sdk_core_1.BuildTransactionError(`${constants_1.ERROR_CREATE_CREDENTIAL_FAILED}: ${error instanceof Error ? error.message : constants_1.ERROR_UNKNOWN}`);
|
|
210
|
-
}
|
|
211
|
-
}
|
|
212
|
-
/**
|
|
213
|
-
* Base initBuilder used by concrete builders. For now just returns this so fluent API works.
|
|
214
|
-
*/
|
|
215
|
-
initBuilder(_tx) {
|
|
216
|
-
return this;
|
|
96
|
+
// Create TransferableOutput
|
|
97
|
+
const transferableOutput = new flarejs_1.TransferableInput({
|
|
98
|
+
_type: flarejs_1.TypeSymbols.UTXOID,
|
|
99
|
+
txID: new flarejs_1.Id(new Uint8Array(32)),
|
|
100
|
+
outputIdx: new flarejs_1.Int(0),
|
|
101
|
+
ID: () => '',
|
|
102
|
+
toBytes: () => {
|
|
103
|
+
const txIdBytes = new Uint8Array(32);
|
|
104
|
+
const outputIdxBytes = new Uint8Array(4);
|
|
105
|
+
return Buffer.concat([txIdBytes, outputIdxBytes]);
|
|
106
|
+
},
|
|
107
|
+
}, new flarejs_1.Id(new Uint8Array([0])), assetId);
|
|
108
|
+
// Set output properties
|
|
109
|
+
Object.assign(transferableOutput, { output });
|
|
110
|
+
outputs.push(transferableOutput);
|
|
111
|
+
}
|
|
112
|
+
return {
|
|
113
|
+
inputs,
|
|
114
|
+
outputs,
|
|
115
|
+
credentials,
|
|
116
|
+
};
|
|
217
117
|
}
|
|
218
|
-
/**
|
|
219
|
-
|
|
220
|
-
|
|
221
|
-
|
|
222
|
-
|
|
223
|
-
|
|
224
|
-
|
|
225
|
-
|
|
226
|
-
throw new sdk_core_1.BuildTransactionError(constants_1.ERROR_INVALID_PRIVATE_KEY);
|
|
118
|
+
/** @inheritdoc */
|
|
119
|
+
async buildImplementation() {
|
|
120
|
+
this.buildFlareTransaction();
|
|
121
|
+
this.setTransactionType(this.transactionType);
|
|
122
|
+
if (this.hasSigner()) {
|
|
123
|
+
// Sign sequentially to ensure proper order
|
|
124
|
+
for (const keyPair of this._signer) {
|
|
125
|
+
await this.transaction.sign(keyPair);
|
|
227
126
|
}
|
|
228
|
-
// Create signature structure
|
|
229
|
-
const signature = {
|
|
230
|
-
privateKey: params.key,
|
|
231
|
-
signingMethod: constants_1.SIGNING_METHOD,
|
|
232
|
-
};
|
|
233
|
-
// Store signature for FlareJS compatibility
|
|
234
|
-
this.transaction._signature = signature;
|
|
235
|
-
this.transaction.hasCredentials = true;
|
|
236
|
-
return this;
|
|
237
|
-
}
|
|
238
|
-
catch (error) {
|
|
239
|
-
throw new sdk_core_1.BuildTransactionError(`${constants_1.ERROR_FLAREJS_SIGNING_FAILED}: ${error instanceof Error ? error.message : constants_1.ERROR_UNKNOWN}`);
|
|
240
127
|
}
|
|
128
|
+
return this.transaction;
|
|
241
129
|
}
|
|
242
130
|
/**
|
|
243
|
-
*
|
|
131
|
+
* Fee is fix for AVM atomic tx.
|
|
132
|
+
*
|
|
133
|
+
* @returns network.txFee
|
|
134
|
+
* @protected
|
|
244
135
|
*/
|
|
245
|
-
|
|
246
|
-
|
|
247
|
-
try {
|
|
248
|
-
// Validate transaction requirements
|
|
249
|
-
if (!this._utxos || this._utxos.length === 0) {
|
|
250
|
-
throw new sdk_core_1.BuildTransactionError(constants_1.ERROR_UTXOS_REQUIRED_BUILD);
|
|
251
|
-
}
|
|
252
|
-
// Create FlareJS transaction structure with atomic support
|
|
253
|
-
const transaction = {
|
|
254
|
-
_id: `${constants_1.TRANSACTION_ID_PREFIX}${Date.now()}`,
|
|
255
|
-
_inputs: [],
|
|
256
|
-
_outputs: [],
|
|
257
|
-
_type: this.transactionType,
|
|
258
|
-
signature: [],
|
|
259
|
-
fromAddresses: this.transaction._fromAddresses,
|
|
260
|
-
validationErrors: [],
|
|
261
|
-
// FlareJS methods with atomic support
|
|
262
|
-
toBroadcastFormat: () => `${constants_1.TRANSACTION_ID_PREFIX}${Date.now()}`,
|
|
263
|
-
toJson: () => ({
|
|
264
|
-
type: this.transactionType,
|
|
265
|
-
}),
|
|
266
|
-
explainTransaction: () => ({
|
|
267
|
-
type: this.transactionType,
|
|
268
|
-
inputs: [],
|
|
269
|
-
outputs: [],
|
|
270
|
-
outputAmount: constants_1.AMOUNT_STRING_ZERO,
|
|
271
|
-
rewardAddresses: [],
|
|
272
|
-
id: `${constants_1.FLARE_ATOMIC_PREFIX}${Date.now()}`,
|
|
273
|
-
changeOutputs: [],
|
|
274
|
-
changeAmount: constants_1.AMOUNT_STRING_ZERO,
|
|
275
|
-
fee: { fee: this.transaction._fee.fee },
|
|
276
|
-
}),
|
|
277
|
-
isTransactionForCChain: false,
|
|
278
|
-
loadInputsAndOutputs: () => {
|
|
279
|
-
/* FlareJS atomic transaction loading */
|
|
280
|
-
},
|
|
281
|
-
inputs: () => [],
|
|
282
|
-
outputs: () => [],
|
|
283
|
-
fee: () => ({ fee: this.transaction._fee.fee }),
|
|
284
|
-
feeRate: () => 0,
|
|
285
|
-
id: () => `${constants_1.FLARE_ATOMIC_PREFIX}${Date.now()}`,
|
|
286
|
-
type: this.transactionType,
|
|
287
|
-
};
|
|
288
|
-
return transaction;
|
|
289
|
-
}
|
|
290
|
-
catch (error) {
|
|
291
|
-
throw new sdk_core_1.BuildTransactionError(`${constants_1.ERROR_ENHANCED_BUILD_FAILED}: ${error instanceof Error ? error.message : constants_1.ERROR_UNKNOWN}`);
|
|
292
|
-
}
|
|
136
|
+
get fixedFee() {
|
|
137
|
+
return this.transaction._network.txFee;
|
|
293
138
|
}
|
|
294
139
|
/**
|
|
295
|
-
*
|
|
140
|
+
* Set the transaction type
|
|
141
|
+
*
|
|
142
|
+
* @param {TransactionType} transactionType The transaction type to be set
|
|
296
143
|
*/
|
|
297
|
-
|
|
298
|
-
|
|
299
|
-
try {
|
|
300
|
-
return {
|
|
301
|
-
type: this.transactionType,
|
|
302
|
-
inputs: [],
|
|
303
|
-
outputs: [],
|
|
304
|
-
outputAmount: constants_1.AMOUNT_STRING_ZERO,
|
|
305
|
-
rewardAddresses: [],
|
|
306
|
-
id: `${constants_1.FLARE_ATOMIC_PARSED_PREFIX}${Date.now()}`,
|
|
307
|
-
changeOutputs: [],
|
|
308
|
-
changeAmount: constants_1.AMOUNT_STRING_ZERO,
|
|
309
|
-
fee: { fee: this.transaction._fee.fee },
|
|
310
|
-
};
|
|
311
|
-
}
|
|
312
|
-
catch (error) {
|
|
313
|
-
throw new sdk_core_1.BuildTransactionError(`${constants_1.ERROR_ENHANCED_PARSE_FAILED}: ${error instanceof Error ? error.message : constants_1.ERROR_UNKNOWN}`);
|
|
314
|
-
}
|
|
144
|
+
setTransactionType(transactionType) {
|
|
145
|
+
this.transaction._type = transactionType;
|
|
315
146
|
}
|
|
316
147
|
}
|
|
317
148
|
exports.AtomicTransactionBuilder = AtomicTransactionBuilder;
|
|
318
|
-
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"atomicTransactionBuilder.js","sourceRoot":"","sources":["../../../src/lib/atomicTransactionBuilder.ts"],"names":[],"mappings":"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","sourcesContent":["import { BaseCoin as CoinConfig } from '@bitgo-beta/statics';\nimport { BuildTransactionError, TransactionType, BaseTransaction } from '@bitgo-beta/sdk-core';\nimport { Credential, Signature, TransferableInput, TransferableOutput } from '@flarenetwork/flarejs';\nimport { TransactionExplanation, DecodedUtxoObj } from './iface';\nimport {\n  ASSET_ID_LENGTH,\n  TRANSACTION_ID_HEX_LENGTH,\n  PRIVATE_KEY_HEX_LENGTH,\n  SECP256K1_SIGNATURE_LENGTH,\n  TRANSACTION_ID_PREFIX,\n  DEFAULT_NETWORK_ID,\n  EMPTY_BUFFER_SIZE,\n  HEX_PREFIX,\n  HEX_PREFIX_LENGTH,\n  DECIMAL_RADIX,\n  SIGNING_METHOD,\n  AMOUNT_STRING_ZERO,\n  DEFAULT_LOCKTIME,\n  DEFAULT_THRESHOLD,\n  ZERO_BIGINT,\n  ZERO_NUMBER,\n  ERROR_AMOUNT_POSITIVE,\n  ERROR_CREDENTIALS_ARRAY,\n  ERROR_UTXOS_REQUIRED,\n  ERROR_SIGNATURES_ARRAY,\n  ERROR_SIGNATURES_EMPTY,\n  ERROR_INVALID_PRIVATE_KEY,\n  ERROR_UTXOS_REQUIRED_BUILD,\n  ERROR_ENHANCED_BUILD_FAILED,\n  ERROR_ENHANCED_PARSE_FAILED,\n  ERROR_FLAREJS_SIGNING_FAILED,\n  ERROR_CREATE_CREDENTIAL_FAILED,\n  ERROR_UNKNOWN,\n  FLARE_ATOMIC_PREFIX,\n  FLARE_ATOMIC_PARSED_PREFIX,\n  HEX_ENCODING,\n} from './constants';\nimport { createFlexibleHexRegex } from './utils';\n\n/**\n * Flare P-chain atomic transaction builder with FlareJS credential support.\n * This provides the foundation for building Flare P-chain transactions with proper\n * credential handling using FlareJS Credential and Signature classes.\n */\nexport abstract class AtomicTransactionBuilder {\n  protected readonly _coinConfig: Readonly<CoinConfig>;\n  // External chain id (destination) for export transactions\n  protected _externalChainId: Buffer | undefined;\n\n  protected _utxos: DecodedUtxoObj[] = [];\n\n  protected transaction: {\n    _network: Record<string, unknown>;\n    _networkID: number;\n    _blockchainID: Buffer;\n    _assetId: Buffer;\n    _fromAddresses: string[];\n    _to: string[];\n    _locktime: bigint;\n    _threshold: number;\n    _fee: { fee: string; feeRate?: string; size?: number };\n    hasCredentials: boolean;\n    _tx?: unknown;\n    _signature?: unknown;\n    setTransaction: (tx: unknown) => void;\n  } = {\n    _network: {},\n    _networkID: DEFAULT_NETWORK_ID,\n    _blockchainID: Buffer.alloc(EMPTY_BUFFER_SIZE),\n    _assetId: Buffer.alloc(EMPTY_BUFFER_SIZE),\n    _fromAddresses: [],\n    _to: [],\n    _locktime: DEFAULT_LOCKTIME,\n    _threshold: DEFAULT_THRESHOLD,\n    _fee: { fee: AMOUNT_STRING_ZERO },\n    hasCredentials: false,\n    setTransaction: function (_tx: unknown) {\n      this._tx = _tx;\n    },\n  };\n\n  constructor(coinConfig: Readonly<CoinConfig>) {\n    this._coinConfig = coinConfig;\n  }\n\n  protected abstract get transactionType(): TransactionType;\n\n  /**\n   * Get the asset ID for Flare network transactions\n   * @returns Buffer containing the asset ID\n   */\n  protected getAssetId(): Buffer {\n    // Use the asset ID from transaction if already set\n    if (this.transaction._assetId && this.transaction._assetId.length > 0) {\n      return this.transaction._assetId;\n    }\n\n    // For native FLR transactions, return zero-filled buffer as placeholder\n    // In a real implementation, this would be obtained from the network configuration\n    // or FlareJS API to get the actual native asset ID\n    return Buffer.alloc(ASSET_ID_LENGTH);\n  }\n\n  validateAmount(amount: bigint): void {\n    if (amount <= ZERO_BIGINT) {\n      throw new BuildTransactionError(ERROR_AMOUNT_POSITIVE);\n    }\n  }\n\n  /**\n   * Validates that credentials array is properly formed\n   * @param credentials - Array of credentials to validate\n   */\n  protected validateCredentials(credentials: Credential[]): void {\n    if (!Array.isArray(credentials)) {\n      throw new BuildTransactionError(ERROR_CREDENTIALS_ARRAY);\n    }\n\n    credentials.forEach((credential, index) => {\n      if (!(credential instanceof Credential)) {\n        throw new BuildTransactionError(`Invalid credential at index ${index}`);\n      }\n    });\n  }\n\n  /**\n   * Creates inputs, outputs, and credentials for Flare P-chain atomic transactions.\n   * Based on AVAX P-chain implementation adapted for FlareJS.\n   *\n   * Note: This is a simplified implementation that creates the core structure.\n   * The FlareJS type system integration will be refined in future iterations.\n   *\n   * @param total - Total amount needed including fees\n   * @returns Object containing TransferableInput[], TransferableOutput[], and Credential[]\n   */\n  protected createInputOutput(total: bigint): {\n    inputs: TransferableInput[];\n    outputs: TransferableOutput[];\n    credentials: Credential[];\n  } {\n    if (!this._utxos || this._utxos.length === ZERO_NUMBER) {\n      throw new BuildTransactionError(ERROR_UTXOS_REQUIRED);\n    }\n\n    const inputs: TransferableInput[] = [];\n    const outputs: TransferableOutput[] = [];\n    const credentials: Credential[] = [];\n\n    let inputSum = 0n;\n    const addressIndices: { [address: string]: number } = {};\n    let nextAddressIndex = 0;\n\n    // Sort UTXOs by amount in descending order for optimal coin selection\n    const sortedUtxos = [...this._utxos].sort((a, b) => {\n      const amountA = BigInt(a.amount);\n      const amountB = BigInt(b.amount);\n      if (amountA > amountB) return -1;\n      if (amountA < amountB) return 1;\n      return 0;\n    });\n\n    // Process UTXOs to create inputs and credentials\n    for (const utxo of sortedUtxos) {\n      const utxoAmount = BigInt(utxo.amount);\n\n      if (inputSum >= total) {\n        break; // We have enough inputs\n      }\n\n      // Track input sum\n      inputSum += utxoAmount;\n\n      // Track address indices for signature ordering (mimics AVAX pattern)\n      const addressIndexArray: number[] = [];\n      for (const address of utxo.addresses) {\n        if (!(address in addressIndices)) {\n          addressIndices[address] = nextAddressIndex++;\n        }\n        addressIndexArray.push(addressIndices[address]);\n      }\n\n      // Store address indices on the UTXO for credential creation\n      utxo.addressesIndex = addressIndexArray;\n\n      // Create TransferableInput for atomic transactions\n      const transferableInput = {\n        txID: Buffer.from(utxo.txid || AMOUNT_STRING_ZERO.repeat(TRANSACTION_ID_HEX_LENGTH), HEX_ENCODING),\n        outputIndex: parseInt(utxo.outputidx || AMOUNT_STRING_ZERO, DECIMAL_RADIX),\n        assetID: this.getAssetId(),\n        input: {\n          amount: utxoAmount,\n          addressIndices: addressIndexArray,\n          threshold: utxo.threshold,\n        },\n      };\n\n      // Store the input (type assertion for compatibility)\n      inputs.push(transferableInput as unknown as TransferableInput);\n\n      // Create credential with placeholder signatures\n      // In a real implementation, these would be actual signatures\n      const signatures = Array.from({ length: utxo.threshold }, () => '');\n      const credential = this.createFlareCredential(0, signatures);\n      credentials.push(credential);\n    }\n\n    // Verify we have enough inputs\n    if (inputSum < total) {\n      throw new BuildTransactionError(`Insufficient funds: need ${total}, have ${inputSum}`);\n    }\n\n    // Create change output if we have excess input amount\n    if (inputSum > total) {\n      const changeAmount = inputSum - total;\n\n      // Create change output for atomic transactions\n      const changeOutput = {\n        assetID: this.getAssetId(),\n        output: {\n          amount: changeAmount,\n          addresses: this.transaction._fromAddresses,\n          threshold: 1,\n          locktime: 0n,\n        },\n      };\n\n      // Add the change output (type assertion for compatibility)\n      outputs.push(changeOutput as unknown as TransferableOutput);\n    }\n\n    return { inputs, outputs, credentials };\n  }\n\n  /**\n   * Set UTXOs for the transaction. This is required for creating inputs and outputs.\n   *\n   * @param utxos - Array of decoded UTXO objects\n   * @returns this builder instance for chaining\n   */\n  utxos(utxos: DecodedUtxoObj[]): this {\n    this._utxos = utxos;\n    return this;\n  }\n\n  /**\n   * Flare equivalent of Avalanche's SelectCredentialClass\n   * Creates a credential with the provided signatures\n   *\n   * @param credentialId - The credential ID (not used in FlareJS but kept for compatibility)\n   * @param signatures - Array of signature hex strings or empty strings for placeholders\n   * @returns Credential instance\n   */\n  protected createFlareCredential(_credentialId: number, signatures: string[]): Credential {\n    if (!Array.isArray(signatures)) {\n      throw new BuildTransactionError(ERROR_SIGNATURES_ARRAY);\n    }\n\n    if (signatures.length === ZERO_NUMBER) {\n      throw new BuildTransactionError(ERROR_SIGNATURES_EMPTY);\n    }\n\n    const sigs = signatures.map((sig, index) => {\n      // Handle empty/placeholder signatures\n      if (!sig || sig.length === 0) {\n        return new Signature(new Uint8Array(SECP256K1_SIGNATURE_LENGTH));\n      }\n\n      // Validate hex string format\n      const cleanSig = sig.startsWith(HEX_PREFIX) ? sig.slice(HEX_PREFIX_LENGTH) : sig;\n      if (!createFlexibleHexRegex().test(cleanSig)) {\n        throw new BuildTransactionError(`Invalid hex signature at index ${index}: contains non-hex characters`);\n      }\n\n      // Convert to buffer and validate length\n      const sigBuffer = Buffer.from(cleanSig, HEX_ENCODING);\n      if (sigBuffer.length > SECP256K1_SIGNATURE_LENGTH) {\n        throw new BuildTransactionError(\n          `Signature too long at index ${index}: ${sigBuffer.length} bytes (max ${SECP256K1_SIGNATURE_LENGTH})`\n        );\n      }\n\n      // Create fixed-length buffer and copy signature data\n      const fixedLengthBuffer = Buffer.alloc(SECP256K1_SIGNATURE_LENGTH);\n      sigBuffer.copy(fixedLengthBuffer);\n\n      try {\n        return new Signature(new Uint8Array(fixedLengthBuffer));\n      } catch (error) {\n        throw new BuildTransactionError(\n          `Failed to create signature at index ${index}: ${error instanceof Error ? error.message : ERROR_UNKNOWN}`\n        );\n      }\n    });\n\n    try {\n      return new Credential(sigs);\n    } catch (error) {\n      throw new BuildTransactionError(\n        `${ERROR_CREATE_CREDENTIAL_FAILED}: ${error instanceof Error ? error.message : ERROR_UNKNOWN}`\n      );\n    }\n  }\n\n  /**\n   * Base initBuilder used by concrete builders. For now just returns this so fluent API works.\n   */\n  initBuilder(_tx: unknown): this {\n    return this;\n  }\n\n  /**\n   * Sign transaction with private key using FlareJS compatibility\n   */\n  sign(params: { key: string }): this {\n    // FlareJS signing implementation with atomic transaction support\n    try {\n      // Validate private key format (placeholder implementation)\n      if (!params.key || params.key.length < PRIVATE_KEY_HEX_LENGTH) {\n        throw new BuildTransactionError(ERROR_INVALID_PRIVATE_KEY);\n      }\n\n      // Create signature structure\n      const signature = {\n        privateKey: params.key,\n        signingMethod: SIGNING_METHOD,\n      };\n\n      // Store signature for FlareJS compatibility\n      this.transaction._signature = signature;\n      this.transaction.hasCredentials = true;\n\n      return this;\n    } catch (error) {\n      throw new BuildTransactionError(\n        `${ERROR_FLAREJS_SIGNING_FAILED}: ${error instanceof Error ? error.message : ERROR_UNKNOWN}`\n      );\n    }\n  }\n\n  /**\n   * Build the transaction using FlareJS compatibility\n   */\n  async build(): Promise<BaseTransaction> {\n    // FlareJS UnsignedTx creation with atomic transaction support\n    try {\n      // Validate transaction requirements\n      if (!this._utxos || this._utxos.length === 0) {\n        throw new BuildTransactionError(ERROR_UTXOS_REQUIRED_BUILD);\n      }\n\n      // Create FlareJS transaction structure with atomic support\n      const transaction = {\n        _id: `${TRANSACTION_ID_PREFIX}${Date.now()}`,\n        _inputs: [],\n        _outputs: [],\n        _type: this.transactionType,\n        signature: [] as string[],\n\n        fromAddresses: this.transaction._fromAddresses,\n        validationErrors: [],\n\n        // FlareJS methods with atomic support\n        toBroadcastFormat: () => `${TRANSACTION_ID_PREFIX}${Date.now()}`,\n        toJson: () => ({\n          type: this.transactionType,\n        }),\n\n        explainTransaction: (): TransactionExplanation => ({\n          type: this.transactionType,\n          inputs: [],\n          outputs: [],\n          outputAmount: AMOUNT_STRING_ZERO,\n          rewardAddresses: [],\n          id: `${FLARE_ATOMIC_PREFIX}${Date.now()}`,\n          changeOutputs: [],\n          changeAmount: AMOUNT_STRING_ZERO,\n          fee: { fee: this.transaction._fee.fee },\n        }),\n\n        isTransactionForCChain: false,\n        loadInputsAndOutputs: () => {\n          /* FlareJS atomic transaction loading */\n        },\n        inputs: () => [],\n        outputs: () => [],\n        fee: () => ({ fee: this.transaction._fee.fee }),\n        feeRate: () => 0,\n        id: () => `${FLARE_ATOMIC_PREFIX}${Date.now()}`,\n        type: this.transactionType,\n      } as unknown as BaseTransaction;\n\n      return transaction;\n    } catch (error) {\n      throw new BuildTransactionError(\n        `${ERROR_ENHANCED_BUILD_FAILED}: ${error instanceof Error ? error.message : ERROR_UNKNOWN}`\n      );\n    }\n  }\n\n  /**\n   * Parse and explain a transaction from hex using FlareJS compatibility\n   */\n  explainTransaction(): TransactionExplanation {\n    // FlareJS transaction parsing with atomic support\n    try {\n      return {\n        type: this.transactionType,\n        inputs: [],\n        outputs: [],\n        outputAmount: AMOUNT_STRING_ZERO,\n        rewardAddresses: [],\n        id: `${FLARE_ATOMIC_PARSED_PREFIX}${Date.now()}`,\n        changeOutputs: [],\n        changeAmount: AMOUNT_STRING_ZERO,\n        fee: { fee: this.transaction._fee.fee },\n      };\n    } catch (error) {\n      throw new BuildTransactionError(\n        `${ERROR_ENHANCED_PARSE_FAILED}: ${error instanceof Error ? error.message : ERROR_UNKNOWN}`\n      );\n    }\n  }\n}\n"]}
|
|
149
|
+
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"atomicTransactionBuilder.js","sourceRoot":"","sources":["../../../src/lib/atomicTransactionBuilder.ts"],"names":[],"mappings":"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","sourcesContent":["import { BaseCoin as CoinConfig } from '@bitgo-beta/statics';\nimport { TransactionType } from '@bitgo-beta/sdk-core';\nimport { TransactionBuilder } from './transactionBuilder';\nimport { Transaction } from './transaction';\nimport { TransferableInput, Int, Id, TypeSymbols } from '@flarenetwork/flarejs';\nimport { DecodedUtxoObj } from './iface';\n\n// Interface for objects that can provide an amount\ninterface Amounter {\n  _type: TypeSymbols;\n  amount: () => bigint;\n  toBytes: () => Uint8Array;\n}\n\nexport abstract class AtomicTransactionBuilder extends TransactionBuilder {\n  protected _externalChainId: Buffer;\n  protected recoverSigner = false;\n\n  constructor(_coinConfig: Readonly<CoinConfig>) {\n    super(_coinConfig);\n    this.transaction = new Transaction(_coinConfig);\n  }\n\n  /**\n   * Create inputs and outputs from UTXOs\n   * @param {bigint} amount Amount to transfer\n   * @return {\n   *     inputs: TransferableInput[];\n   *     outputs: TransferableInput[];\n   *     credentials: Credential[];\n   * }\n   * @protected\n   */\n  protected createInputOutput(amount: bigint): {\n    inputs: TransferableInput[];\n    outputs: TransferableInput[];\n    credentials: any[];\n  } {\n    const sender = (this.transaction as 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 outputs: TransferableInput[] = [];\n    const credentials: any[] = [];\n\n    (this.transaction as Transaction)._utxos.forEach((utxo: DecodedUtxoObj) => {\n      const utxoAmount = BigInt(utxo.amount);\n      totalAmount += utxoAmount;\n\n      // Create input\n      const input = {\n        _type: TypeSymbols.Input,\n        amount: () => utxoAmount,\n        sigIndices: sender.map((_, i) => i),\n        toBytes: () => new Uint8Array(),\n      };\n\n      // Create asset with Amounter interface\n      const assetId: Amounter = {\n        _type: TypeSymbols.BaseTx,\n        amount: () => utxoAmount,\n        toBytes: () => {\n          const bytes = new Uint8Array(Buffer.from((this.transaction as Transaction)._assetId, 'hex'));\n          return bytes;\n        },\n      };\n\n      // Create TransferableInput\n      const transferableInput = new TransferableInput(\n        {\n          _type: TypeSymbols.UTXOID,\n          txID: new Id(new Uint8Array(Buffer.from(utxo.txid, 'hex'))),\n          outputIdx: new Int(Number(utxo.outputidx)),\n          ID: () => utxo.txid,\n          toBytes: () => {\n            const txIdBytes = new Uint8Array(Buffer.from(utxo.txid, 'hex'));\n            const outputIdxBytes = new Uint8Array(4);\n            new DataView(outputIdxBytes.buffer).setInt32(0, Number(utxo.outputidx), true);\n            return Buffer.concat([txIdBytes, outputIdxBytes]);\n          },\n        },\n        new Id(new Uint8Array(Buffer.from(utxo.outputidx.toString()))),\n        assetId\n      );\n\n      // Set input properties\n      Object.assign(transferableInput, { input });\n      inputs.push(transferableInput);\n\n      // Create empty credential for each input\n      const emptySignatures = sender.map(() => Buffer.alloc(0));\n      credentials.push({ signatures: emptySignatures });\n    });\n\n    // Create output if there is change\n    if (totalAmount > amount) {\n      const changeAmount = totalAmount - amount;\n      const output = {\n        _type: TypeSymbols.BaseTx,\n        amount: () => changeAmount,\n        addresses: sender,\n        locktime: (this.transaction as Transaction)._locktime,\n        threshold: (this.transaction as Transaction)._threshold,\n        toBytes: () => new Uint8Array(),\n      };\n\n      // Create asset with Amounter interface\n      const assetId: Amounter = {\n        _type: TypeSymbols.BaseTx,\n        amount: () => changeAmount,\n        toBytes: () => {\n          const bytes = new Uint8Array(Buffer.from((this.transaction as Transaction)._assetId, 'hex'));\n          return bytes;\n        },\n      };\n\n      // Create TransferableOutput\n      const transferableOutput = new TransferableInput(\n        {\n          _type: TypeSymbols.UTXOID,\n          txID: new Id(new Uint8Array(32)),\n          outputIdx: new Int(0),\n          ID: () => '',\n          toBytes: () => {\n            const txIdBytes = new Uint8Array(32);\n            const outputIdxBytes = new Uint8Array(4);\n            return Buffer.concat([txIdBytes, outputIdxBytes]);\n          },\n        },\n        new Id(new Uint8Array([0])),\n        assetId\n      );\n\n      // Set output properties\n      Object.assign(transferableOutput, { output });\n      outputs.push(transferableOutput);\n    }\n\n    return {\n      inputs,\n      outputs,\n      credentials,\n    };\n  }\n\n  /** @inheritdoc */\n  protected async buildImplementation(): Promise<Transaction> {\n    this.buildFlareTransaction();\n    this.setTransactionType(this.transactionType);\n    if (this.hasSigner()) {\n      // Sign sequentially to ensure proper order\n      for (const keyPair of this._signer) {\n        await this.transaction.sign(keyPair);\n      }\n    }\n    return this.transaction;\n  }\n\n  /**\n   * Builds the avax transaction. transaction field is changed.\n   */\n  protected abstract buildFlareTransaction(): void;\n\n  protected abstract get transactionType(): TransactionType;\n\n  /**\n   * Fee is fix for AVM atomic tx.\n   *\n   * @returns network.txFee\n   * @protected\n   */\n  protected get fixedFee(): string {\n    return this.transaction._network.txFee;\n  }\n\n  /**\n   * Set the transaction type\n   *\n   * @param {TransactionType} transactionType The transaction type to be set\n   */\n  setTransactionType(transactionType: TransactionType): void {\n    this.transaction._type = transactionType;\n  }\n}\n"]}
|