@bitgo-beta/sdk-coin-flrp 1.0.1-beta.9 → 1.0.1-beta.91
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 +82 -61
- package/dist/src/flrp.d.ts.map +1 -1
- package/dist/src/flrp.js +293 -134
- package/dist/src/lib/atomicTransactionBuilder.d.ts +42 -6
- package/dist/src/lib/atomicTransactionBuilder.d.ts.map +1 -1
- package/dist/src/lib/atomicTransactionBuilder.js +233 -29
- package/dist/src/lib/constants.d.ts +160 -1
- package/dist/src/lib/constants.d.ts.map +1 -1
- package/dist/src/lib/constants.js +213 -3
- package/dist/src/lib/delegatorTxBuilder.d.ts +58 -0
- package/dist/src/lib/delegatorTxBuilder.d.ts.map +1 -0
- package/dist/src/lib/delegatorTxBuilder.js +224 -0
- package/dist/src/lib/exportInCTxBuilder.d.ts +1 -1
- package/dist/src/lib/exportInCTxBuilder.d.ts.map +1 -1
- package/dist/src/lib/exportInCTxBuilder.js +46 -17
- package/dist/src/lib/exportInPTxBuilder.d.ts +1 -1
- package/dist/src/lib/exportInPTxBuilder.d.ts.map +1 -1
- package/dist/src/lib/exportInPTxBuilder.js +70 -6
- package/dist/src/lib/iface.d.ts +52 -1
- package/dist/src/lib/iface.d.ts.map +1 -1
- package/dist/src/lib/iface.js +1 -1
- package/dist/src/lib/importInCTxBuilder.d.ts +67 -0
- package/dist/src/lib/importInCTxBuilder.d.ts.map +1 -0
- package/dist/src/lib/importInCTxBuilder.js +403 -0
- package/dist/src/lib/importInPTxBuilder.d.ts +73 -0
- package/dist/src/lib/importInPTxBuilder.d.ts.map +1 -0
- package/dist/src/lib/importInPTxBuilder.js +464 -0
- package/dist/src/lib/index.d.ts +7 -0
- package/dist/src/lib/index.d.ts.map +1 -1
- package/dist/src/lib/index.js +15 -2
- package/dist/src/lib/keyPair.d.ts.map +1 -1
- package/dist/src/lib/keyPair.js +4 -6
- package/dist/src/lib/permissionlessValidatorTxBuilder.d.ts +81 -0
- package/dist/src/lib/permissionlessValidatorTxBuilder.d.ts.map +1 -0
- package/dist/src/lib/permissionlessValidatorTxBuilder.js +248 -0
- package/dist/src/lib/transaction.d.ts +111 -0
- package/dist/src/lib/transaction.d.ts.map +1 -0
- package/dist/src/lib/transaction.js +322 -0
- package/dist/src/lib/transactionBuilder.d.ts +85 -0
- package/dist/src/lib/transactionBuilder.d.ts.map +1 -0
- package/dist/src/lib/transactionBuilder.js +167 -0
- package/dist/src/lib/transactionBuilderFactory.d.ts +37 -0
- package/dist/src/lib/transactionBuilderFactory.d.ts.map +1 -0
- package/dist/src/lib/transactionBuilderFactory.js +91 -0
- package/dist/src/lib/types.d.ts +78 -0
- package/dist/src/lib/types.d.ts.map +1 -0
- package/dist/src/lib/types.js +5 -0
- package/dist/src/lib/utils.d.ts +59 -0
- package/dist/src/lib/utils.d.ts.map +1 -1
- package/dist/src/lib/utils.js +160 -52
- package/dist/src/lib/validatorTxBuilder.d.ts +40 -0
- package/dist/src/lib/validatorTxBuilder.d.ts.map +1 -0
- package/dist/src/lib/validatorTxBuilder.js +180 -0
- package/dist/test/unit/delegatorTxBuilder.test.d.ts +2 -0
- package/dist/test/unit/delegatorTxBuilder.test.d.ts.map +1 -0
- package/dist/test/unit/delegatorTxBuilder.test.js +233 -0
- package/dist/test/unit/lib/atomicTransactionBuilder.js +37 -11
- package/dist/test/unit/lib/exportInCTxBuilder.d.ts +2 -0
- package/dist/test/unit/lib/exportInCTxBuilder.d.ts.map +1 -0
- package/dist/test/unit/lib/exportInCTxBuilder.js +584 -0
- package/dist/test/unit/lib/exportInPTxBuilder.d.ts +2 -0
- package/dist/test/unit/lib/exportInPTxBuilder.d.ts.map +1 -0
- package/dist/test/unit/lib/exportInPTxBuilder.js +377 -0
- package/dist/test/unit/lib/importInCTxBuilder.d.ts +2 -0
- package/dist/test/unit/lib/importInCTxBuilder.d.ts.map +1 -0
- package/dist/test/unit/lib/importInCTxBuilder.js +257 -0
- package/dist/test/unit/lib/importInPTxBuilder.d.ts +2 -0
- package/dist/test/unit/lib/importInPTxBuilder.d.ts.map +1 -0
- package/dist/test/unit/lib/importInPTxBuilder.js +500 -0
- package/dist/test/unit/lib/transaction.d.ts +2 -0
- package/dist/test/unit/lib/transaction.d.ts.map +1 -0
- package/dist/test/unit/lib/transaction.js +460 -0
- package/dist/test/unit/lib/utils.js +55 -1
- package/dist/test/unit/permissionlessValidatorTxBuilder.test.d.ts +2 -0
- package/dist/test/unit/permissionlessValidatorTxBuilder.test.d.ts.map +1 -0
- package/dist/test/unit/permissionlessValidatorTxBuilder.test.js +271 -0
- package/dist/test/unit/transactionBuilder.test.d.ts +2 -0
- package/dist/test/unit/transactionBuilder.test.d.ts.map +1 -0
- package/dist/test/unit/transactionBuilder.test.js +114 -0
- package/dist/test/unit/validatorTxBuilder.test.d.ts +2 -0
- package/dist/test/unit/validatorTxBuilder.test.d.ts.map +1 -0
- package/dist/test/unit/validatorTxBuilder.test.js +293 -0
- package/dist/tsconfig.tsbuildinfo +1 -1
- package/package.json +11 -11
- package/.eslintignore +0 -5
- package/.eslintrc.json +0 -7
- package/.mocharc.yml +0 -8
- package/CHANGELOG.md +0 -0
- package/dist/test/unit/lib/exportTxBuilder.d.ts +0 -2
- package/dist/test/unit/lib/exportTxBuilder.d.ts.map +0 -1
- package/dist/test/unit/lib/exportTxBuilder.js +0 -45
|
@@ -3,8 +3,8 @@ Object.defineProperty(exports, "__esModule", { value: true });
|
|
|
3
3
|
exports.AtomicTransactionBuilder = void 0;
|
|
4
4
|
const sdk_core_1 = require("@bitgo-beta/sdk-core");
|
|
5
5
|
const flarejs_1 = require("@flarenetwork/flarejs");
|
|
6
|
-
|
|
7
|
-
const
|
|
6
|
+
const constants_1 = require("./constants");
|
|
7
|
+
const utils_1 = require("./utils");
|
|
8
8
|
/**
|
|
9
9
|
* Flare P-chain atomic transaction builder with FlareJS credential support.
|
|
10
10
|
* This provides the foundation for building Flare P-chain transactions with proper
|
|
@@ -12,18 +12,17 @@ const SECP256K1_SIGNATURE_LENGTH = 65;
|
|
|
12
12
|
*/
|
|
13
13
|
class AtomicTransactionBuilder {
|
|
14
14
|
constructor(coinConfig) {
|
|
15
|
-
|
|
16
|
-
// Simplified internal transaction state
|
|
15
|
+
this._utxos = [];
|
|
17
16
|
this.transaction = {
|
|
18
17
|
_network: {},
|
|
19
|
-
_networkID:
|
|
20
|
-
_blockchainID: Buffer.alloc(
|
|
21
|
-
_assetId: Buffer.alloc(
|
|
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),
|
|
22
21
|
_fromAddresses: [],
|
|
23
22
|
_to: [],
|
|
24
|
-
_locktime:
|
|
25
|
-
_threshold:
|
|
26
|
-
_fee: { fee:
|
|
23
|
+
_locktime: constants_1.DEFAULT_LOCKTIME,
|
|
24
|
+
_threshold: constants_1.DEFAULT_THRESHOLD,
|
|
25
|
+
_fee: { fee: constants_1.AMOUNT_STRING_ZERO },
|
|
27
26
|
hasCredentials: false,
|
|
28
27
|
setTransaction: function (_tx) {
|
|
29
28
|
this._tx = _tx;
|
|
@@ -31,9 +30,23 @@ class AtomicTransactionBuilder {
|
|
|
31
30
|
};
|
|
32
31
|
this._coinConfig = coinConfig;
|
|
33
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
|
+
}
|
|
34
47
|
validateAmount(amount) {
|
|
35
|
-
if (amount <=
|
|
36
|
-
throw new sdk_core_1.BuildTransactionError(
|
|
48
|
+
if (amount <= constants_1.ZERO_BIGINT) {
|
|
49
|
+
throw new sdk_core_1.BuildTransactionError(constants_1.ERROR_AMOUNT_POSITIVE);
|
|
37
50
|
}
|
|
38
51
|
}
|
|
39
52
|
/**
|
|
@@ -42,7 +55,7 @@ class AtomicTransactionBuilder {
|
|
|
42
55
|
*/
|
|
43
56
|
validateCredentials(credentials) {
|
|
44
57
|
if (!Array.isArray(credentials)) {
|
|
45
|
-
throw new sdk_core_1.BuildTransactionError(
|
|
58
|
+
throw new sdk_core_1.BuildTransactionError(constants_1.ERROR_CREDENTIALS_ARRAY);
|
|
46
59
|
}
|
|
47
60
|
credentials.forEach((credential, index) => {
|
|
48
61
|
if (!(credential instanceof flarejs_1.Credential)) {
|
|
@@ -51,10 +64,103 @@ class AtomicTransactionBuilder {
|
|
|
51
64
|
});
|
|
52
65
|
}
|
|
53
66
|
/**
|
|
54
|
-
*
|
|
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[]
|
|
55
75
|
*/
|
|
56
|
-
createInputOutput(
|
|
57
|
-
|
|
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
|
+
}
|
|
80
|
+
const inputs = [];
|
|
81
|
+
const outputs = [];
|
|
82
|
+
const credentials = [];
|
|
83
|
+
let inputSum = 0n;
|
|
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) {
|
|
98
|
+
const utxoAmount = BigInt(utxo.amount);
|
|
99
|
+
if (inputSum >= total) {
|
|
100
|
+
break; // We have enough inputs
|
|
101
|
+
}
|
|
102
|
+
// Track input sum
|
|
103
|
+
inputSum += utxoAmount;
|
|
104
|
+
// Track address indices for signature ordering (mimics AVAX pattern)
|
|
105
|
+
const addressIndexArray = [];
|
|
106
|
+
for (const address of utxo.addresses) {
|
|
107
|
+
if (!(address in addressIndices)) {
|
|
108
|
+
addressIndices[address] = nextAddressIndex++;
|
|
109
|
+
}
|
|
110
|
+
addressIndexArray.push(addressIndices[address]);
|
|
111
|
+
}
|
|
112
|
+
// Store address indices on the UTXO for credential creation
|
|
113
|
+
utxo.addressesIndex = addressIndexArray;
|
|
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,
|
|
123
|
+
},
|
|
124
|
+
};
|
|
125
|
+
// Store the input (type assertion for compatibility)
|
|
126
|
+
inputs.push(transferableInput);
|
|
127
|
+
// Create credential with placeholder signatures
|
|
128
|
+
// In a real implementation, these would be actual signatures
|
|
129
|
+
const signatures = Array.from({ length: utxo.threshold }, () => '');
|
|
130
|
+
const credential = this.createFlareCredential(0, signatures);
|
|
131
|
+
credentials.push(credential);
|
|
132
|
+
}
|
|
133
|
+
// Verify we have enough inputs
|
|
134
|
+
if (inputSum < total) {
|
|
135
|
+
throw new sdk_core_1.BuildTransactionError(`Insufficient funds: need ${total}, have ${inputSum}`);
|
|
136
|
+
}
|
|
137
|
+
// Create change output if we have excess input amount
|
|
138
|
+
if (inputSum > total) {
|
|
139
|
+
const changeAmount = inputSum - total;
|
|
140
|
+
// Create change output for atomic transactions
|
|
141
|
+
const changeOutput = {
|
|
142
|
+
assetID: this.getAssetId(),
|
|
143
|
+
output: {
|
|
144
|
+
amount: changeAmount,
|
|
145
|
+
addresses: this.transaction._fromAddresses,
|
|
146
|
+
threshold: 1,
|
|
147
|
+
locktime: 0n,
|
|
148
|
+
},
|
|
149
|
+
};
|
|
150
|
+
// Add the change output (type assertion for compatibility)
|
|
151
|
+
outputs.push(changeOutput);
|
|
152
|
+
}
|
|
153
|
+
return { inputs, outputs, credentials };
|
|
154
|
+
}
|
|
155
|
+
/**
|
|
156
|
+
* Set UTXOs for the transaction. This is required for creating inputs and outputs.
|
|
157
|
+
*
|
|
158
|
+
* @param utxos - Array of decoded UTXO objects
|
|
159
|
+
* @returns this builder instance for chaining
|
|
160
|
+
*/
|
|
161
|
+
utxos(utxos) {
|
|
162
|
+
this._utxos = utxos;
|
|
163
|
+
return this;
|
|
58
164
|
}
|
|
59
165
|
/**
|
|
60
166
|
* Flare equivalent of Avalanche's SelectCredentialClass
|
|
@@ -66,41 +172,41 @@ class AtomicTransactionBuilder {
|
|
|
66
172
|
*/
|
|
67
173
|
createFlareCredential(_credentialId, signatures) {
|
|
68
174
|
if (!Array.isArray(signatures)) {
|
|
69
|
-
throw new sdk_core_1.BuildTransactionError(
|
|
175
|
+
throw new sdk_core_1.BuildTransactionError(constants_1.ERROR_SIGNATURES_ARRAY);
|
|
70
176
|
}
|
|
71
|
-
if (signatures.length ===
|
|
72
|
-
throw new sdk_core_1.BuildTransactionError(
|
|
177
|
+
if (signatures.length === constants_1.ZERO_NUMBER) {
|
|
178
|
+
throw new sdk_core_1.BuildTransactionError(constants_1.ERROR_SIGNATURES_EMPTY);
|
|
73
179
|
}
|
|
74
180
|
const sigs = signatures.map((sig, index) => {
|
|
75
181
|
// Handle empty/placeholder signatures
|
|
76
182
|
if (!sig || sig.length === 0) {
|
|
77
|
-
return new flarejs_1.Signature(new Uint8Array(SECP256K1_SIGNATURE_LENGTH));
|
|
183
|
+
return new flarejs_1.Signature(new Uint8Array(constants_1.SECP256K1_SIGNATURE_LENGTH));
|
|
78
184
|
}
|
|
79
185
|
// Validate hex string format
|
|
80
|
-
const cleanSig = sig.startsWith(
|
|
81
|
-
if (
|
|
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)) {
|
|
82
188
|
throw new sdk_core_1.BuildTransactionError(`Invalid hex signature at index ${index}: contains non-hex characters`);
|
|
83
189
|
}
|
|
84
190
|
// Convert to buffer and validate length
|
|
85
|
-
const sigBuffer = Buffer.from(cleanSig,
|
|
86
|
-
if (sigBuffer.length > SECP256K1_SIGNATURE_LENGTH) {
|
|
87
|
-
throw new sdk_core_1.BuildTransactionError(`Signature too long at index ${index}: ${sigBuffer.length} bytes (max ${SECP256K1_SIGNATURE_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})`);
|
|
88
194
|
}
|
|
89
195
|
// Create fixed-length buffer and copy signature data
|
|
90
|
-
const fixedLengthBuffer = Buffer.alloc(SECP256K1_SIGNATURE_LENGTH);
|
|
196
|
+
const fixedLengthBuffer = Buffer.alloc(constants_1.SECP256K1_SIGNATURE_LENGTH);
|
|
91
197
|
sigBuffer.copy(fixedLengthBuffer);
|
|
92
198
|
try {
|
|
93
199
|
return new flarejs_1.Signature(new Uint8Array(fixedLengthBuffer));
|
|
94
200
|
}
|
|
95
201
|
catch (error) {
|
|
96
|
-
throw new sdk_core_1.BuildTransactionError(`Failed to create signature at index ${index}: ${error instanceof Error ? error.message :
|
|
202
|
+
throw new sdk_core_1.BuildTransactionError(`Failed to create signature at index ${index}: ${error instanceof Error ? error.message : constants_1.ERROR_UNKNOWN}`);
|
|
97
203
|
}
|
|
98
204
|
});
|
|
99
205
|
try {
|
|
100
206
|
return new flarejs_1.Credential(sigs);
|
|
101
207
|
}
|
|
102
208
|
catch (error) {
|
|
103
|
-
throw new sdk_core_1.BuildTransactionError(
|
|
209
|
+
throw new sdk_core_1.BuildTransactionError(`${constants_1.ERROR_CREATE_CREDENTIAL_FAILED}: ${error instanceof Error ? error.message : constants_1.ERROR_UNKNOWN}`);
|
|
104
210
|
}
|
|
105
211
|
}
|
|
106
212
|
/**
|
|
@@ -109,6 +215,104 @@ class AtomicTransactionBuilder {
|
|
|
109
215
|
initBuilder(_tx) {
|
|
110
216
|
return this;
|
|
111
217
|
}
|
|
218
|
+
/**
|
|
219
|
+
* Sign transaction with private key using FlareJS compatibility
|
|
220
|
+
*/
|
|
221
|
+
sign(params) {
|
|
222
|
+
// FlareJS signing implementation with atomic transaction support
|
|
223
|
+
try {
|
|
224
|
+
// Validate private key format (placeholder implementation)
|
|
225
|
+
if (!params.key || params.key.length < constants_1.PRIVATE_KEY_HEX_LENGTH) {
|
|
226
|
+
throw new sdk_core_1.BuildTransactionError(constants_1.ERROR_INVALID_PRIVATE_KEY);
|
|
227
|
+
}
|
|
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
|
+
}
|
|
241
|
+
}
|
|
242
|
+
/**
|
|
243
|
+
* Build the transaction using FlareJS compatibility
|
|
244
|
+
*/
|
|
245
|
+
async build() {
|
|
246
|
+
// FlareJS UnsignedTx creation with atomic transaction support
|
|
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
|
+
}
|
|
293
|
+
}
|
|
294
|
+
/**
|
|
295
|
+
* Parse and explain a transaction from hex using FlareJS compatibility
|
|
296
|
+
*/
|
|
297
|
+
explainTransaction() {
|
|
298
|
+
// FlareJS transaction parsing with atomic support
|
|
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
|
+
}
|
|
315
|
+
}
|
|
112
316
|
}
|
|
113
317
|
exports.AtomicTransactionBuilder = AtomicTransactionBuilder;
|
|
114
|
-
//# 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 } from '@bitgo-beta/sdk-core';\nimport { Credential, Signature } from '@flarenetwork/flarejs';\n\n// Constants for signature handling\nconst SECP256K1_SIGNATURE_LENGTH = 65;\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  // Simplified internal transaction state (mirrors shape expected by existing builders)\n  // Simplified internal transaction state\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    setTransaction: (tx: unknown) => void;\n  } = {\n    _network: {},\n    _networkID: 0,\n    _blockchainID: Buffer.alloc(0),\n    _assetId: Buffer.alloc(0),\n    _fromAddresses: [],\n    _to: [],\n    _locktime: 0n,\n    _threshold: 1,\n    _fee: { fee: '0' },\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  validateAmount(amount: bigint): void {\n    if (amount <= 0n) {\n      throw new BuildTransactionError('Amount must be 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('Credentials must be an 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   * Placeholder that should assemble inputs/outputs and credentials once UTXO + key logic is implemented.\n   */\n  protected createInputOutput(_total: bigint): { inputs: unknown[]; outputs: unknown[]; credentials: Credential[] } {\n    return { inputs: [], outputs: [], credentials: [] };\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('Signatures must be an array');\n    }\n\n    if (signatures.length === 0) {\n      throw new BuildTransactionError('Signatures array cannot be 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('0x') ? sig.slice(2) : sig;\n      if (!/^[0-9a-fA-F]*$/.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');\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 : 'unknown error'}`\n        );\n      }\n    });\n\n    try {\n      return new Credential(sigs);\n    } catch (error) {\n      throw new BuildTransactionError(\n        `Failed to create credential: ${error instanceof Error ? error.message : 'unknown error'}`\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"]}
|
|
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"]}
|
|
@@ -1,4 +1,4 @@
|
|
|
1
|
-
export declare const DECODED_BLOCK_ID_LENGTH =
|
|
1
|
+
export declare const DECODED_BLOCK_ID_LENGTH = 32;
|
|
2
2
|
export declare const SHORT_PUB_KEY_LENGTH = 50;
|
|
3
3
|
export declare const COMPRESSED_PUBLIC_KEY_LENGTH = 66;
|
|
4
4
|
export declare const UNCOMPRESSED_PUBLIC_KEY_LENGTH = 130;
|
|
@@ -6,6 +6,165 @@ export declare const RAW_PRIVATE_KEY_LENGTH = 64;
|
|
|
6
6
|
export declare const SUFFIXED_PRIVATE_KEY_LENGTH = 66;
|
|
7
7
|
export declare const PRIVATE_KEY_COMPRESSED_SUFFIX = "01";
|
|
8
8
|
export declare const OUTPUT_INDEX_HEX_LENGTH = 8;
|
|
9
|
+
export declare const ASSET_ID_LENGTH = 32;
|
|
10
|
+
export declare const TRANSACTION_ID_HEX_LENGTH = 64;
|
|
11
|
+
export declare const PRIVATE_KEY_HEX_LENGTH = 64;
|
|
12
|
+
export declare const SECP256K1_SIGNATURE_LENGTH = 65;
|
|
13
|
+
export declare const BLS_PUBLIC_KEY_COMPRESSED_LENGTH = 96;
|
|
14
|
+
export declare const BLS_PUBLIC_KEY_UNCOMPRESSED_LENGTH = 192;
|
|
15
|
+
export declare const BLS_SIGNATURE_LENGTH = 192;
|
|
16
|
+
export declare const CHAIN_ID_HEX_LENGTH = 64;
|
|
17
|
+
export declare const MAX_CHAIN_ID_LENGTH = 128;
|
|
18
|
+
export declare const DEFAULT_BASE_FEE = "1000000";
|
|
19
|
+
export declare const DEFAULT_EVM_GAS_FEE = "21000";
|
|
20
|
+
export declare const INPUT_FEE = "100000";
|
|
21
|
+
export declare const OUTPUT_FEE = "50000";
|
|
22
|
+
export declare const MINIMUM_FEE = "1000000";
|
|
23
|
+
export declare const MIN_DELEGATION_FEE_BASIS_POINTS = 20000;
|
|
24
|
+
export declare const BASIS_POINTS_DIVISOR = 10000;
|
|
25
|
+
export declare const PERCENTAGE_MULTIPLIER = 100;
|
|
26
|
+
export declare const TRANSACTION_ID_PREFIX = "flare-atomic-tx-";
|
|
27
|
+
export declare const DELEGATOR_TRANSACTION_TYPE = "PlatformVM.AddDelegatorTx";
|
|
28
|
+
export declare const PRIMARY_DELEGATOR_TYPE = "primary";
|
|
29
|
+
export declare const DELEGATOR_STAKE_TYPE = "delegator";
|
|
30
|
+
export declare const SECP256K1_CREDENTIAL_TYPE = "secp256k1fx.Credential";
|
|
31
|
+
export declare const STAKE_OUTPUT_TYPE = "stake";
|
|
32
|
+
export declare const CREDENTIAL_VERSION = "1.0.0";
|
|
33
|
+
export declare const EMPTY_STRING = "";
|
|
34
|
+
export declare const ZERO_BIGINT = 0n;
|
|
35
|
+
export declare const ZERO_NUMBER = 0;
|
|
36
|
+
export declare const DEFAULT_THRESHOLD = 1;
|
|
37
|
+
export declare const DEFAULT_LOCKTIME = 0n;
|
|
38
|
+
export declare const MEMO_BUFFER_SIZE = 0;
|
|
39
|
+
export declare const FIRST_ADDRESS_INDEX = 0;
|
|
9
40
|
export declare const ADDRESS_REGEX: RegExp;
|
|
10
41
|
export declare const HEX_REGEX: RegExp;
|
|
42
|
+
export declare const HEX_CHAR_PATTERN = "[0-9a-fA-F]";
|
|
43
|
+
export declare const HEX_PATTERN_NO_PREFIX = "^[0-9a-fA-F]*$";
|
|
44
|
+
export declare const HEX_PATTERN_WITH_PREFIX = "^0x[0-9a-fA-F]";
|
|
45
|
+
export declare const DEFAULT_NETWORK_ID = 0;
|
|
46
|
+
export declare const FLARE_MAINNET_NETWORK_ID = 1;
|
|
47
|
+
export declare const FLARE_TESTNET_NETWORK_ID = 5;
|
|
48
|
+
export declare const EMPTY_BUFFER_SIZE = 0;
|
|
49
|
+
export declare const HEX_PREFIX = "0x";
|
|
50
|
+
export declare const HEX_PREFIX_LENGTH = 2;
|
|
51
|
+
export declare const DECIMAL_RADIX = 10;
|
|
52
|
+
export declare const SIGNING_METHOD = "secp256k1";
|
|
53
|
+
export declare const AMOUNT_STRING_ZERO = "0";
|
|
54
|
+
export declare const FIRST_ARRAY_INDEX = 0;
|
|
55
|
+
export declare const MAINNET_TYPE = "mainnet";
|
|
56
|
+
export declare const EXPORT_TRANSACTION_TYPE = "PlatformVM.ExportTx";
|
|
57
|
+
export declare const ERROR_AMOUNT_POSITIVE = "Amount must be positive";
|
|
58
|
+
export declare const ERROR_CREDENTIALS_ARRAY = "Credentials must be an array";
|
|
59
|
+
export declare const ERROR_UTXOS_REQUIRED = "UTXOs are required for creating inputs and outputs";
|
|
60
|
+
export declare const ERROR_SIGNATURES_ARRAY = "Signatures must be an array";
|
|
61
|
+
export declare const ERROR_SIGNATURES_EMPTY = "Signatures array cannot be empty";
|
|
62
|
+
export declare const ERROR_INVALID_PRIVATE_KEY = "Invalid private key format";
|
|
63
|
+
export declare const ERROR_UTXOS_REQUIRED_BUILD = "UTXOs are required for transaction building";
|
|
64
|
+
export declare const ERROR_ENHANCED_BUILD_FAILED = "Enhanced FlareJS transaction building failed";
|
|
65
|
+
export declare const ERROR_ENHANCED_PARSE_FAILED = "Enhanced FlareJS transaction parsing failed";
|
|
66
|
+
export declare const ERROR_FLAREJS_SIGNING_FAILED = "FlareJS signing failed";
|
|
67
|
+
export declare const ERROR_CREATE_CREDENTIAL_FAILED = "Failed to create credential";
|
|
68
|
+
export declare const ERROR_UNKNOWN = "unknown error";
|
|
69
|
+
export declare const ERROR_EXPORT_NOT_IMPLEMENTED = "Flare P-chain export transaction build not implemented";
|
|
70
|
+
export declare const ERROR_DESTINATION_CHAIN_REQUIRED = "Destination chain ID must be set for P-chain export";
|
|
71
|
+
export declare const ERROR_SOURCE_ADDRESSES_REQUIRED = "Source addresses must be set for P-chain export";
|
|
72
|
+
export declare const ERROR_DESTINATION_ADDRESSES_REQUIRED = "Destination addresses must be set for P-chain export";
|
|
73
|
+
export declare const ERROR_EXPORT_AMOUNT_POSITIVE = "Export amount must be positive";
|
|
74
|
+
export declare const ERROR_TRANSACTION_REQUIRED = "Transaction is required for initialization";
|
|
75
|
+
export declare const ERROR_BLOCKCHAIN_ID_MISMATCH = "Blockchain ID mismatch";
|
|
76
|
+
export declare const ERROR_TRANSACTION_PARSE_FAILED = "Transaction cannot be parsed or has an unsupported transaction type";
|
|
77
|
+
export declare const ERROR_FAILED_INITIALIZE_BUILDER = "Failed to initialize builder from transaction";
|
|
78
|
+
export declare const OBJECT_TYPE_STRING = "object";
|
|
79
|
+
export declare const STRING_TYPE = "string";
|
|
80
|
+
export declare const NUMBER_TYPE = "number";
|
|
81
|
+
export declare const FUNCTION_TYPE = "function";
|
|
82
|
+
export declare const BIGINT_TYPE = "bigint";
|
|
83
|
+
export declare const HEX_ENCODING = "hex";
|
|
84
|
+
export declare const UTF8_ENCODING = "utf8";
|
|
85
|
+
export declare const P_CHAIN = "P";
|
|
86
|
+
export declare const C_CHAIN = "C";
|
|
87
|
+
export declare const X_CHAIN = "X";
|
|
88
|
+
export declare const P_CHAIN_FULL = "P-chain";
|
|
89
|
+
export declare const C_CHAIN_FULL = "C-chain";
|
|
90
|
+
export declare const X_CHAIN_FULL = "X-chain";
|
|
91
|
+
export declare const CHAIN_SUFFIX = "-chain";
|
|
92
|
+
export declare const FLARE_ATOMIC_PREFIX = "flare-atomic-";
|
|
93
|
+
export declare const FLARE_ATOMIC_PARSED_PREFIX = "flare-atomic-parsed-";
|
|
94
|
+
export declare const FLARE_ADDRESS_PLACEHOLDER = "flare-address-placeholder";
|
|
95
|
+
export declare const ZERO_ADDRESS = "0x0000000000000000000000000000000000000000";
|
|
96
|
+
export declare const HEX_PREFIX_REMOVE = "0x";
|
|
97
|
+
export declare const PADSTART_CHAR = "0";
|
|
98
|
+
export declare const PLATFORM_VM_IMPORT_TX = "PlatformVM.ImportTx";
|
|
99
|
+
export declare const PLATFORM_VM_ADD_VALIDATOR_TX = "PlatformVM.AddValidatorTx";
|
|
100
|
+
export declare const IMPORT_TX_TYPE = "ImportTx";
|
|
101
|
+
export declare const P_CHAIN_IMPORT_TYPE = "P-chain-import";
|
|
102
|
+
export declare const IMPORT_TYPE = "import";
|
|
103
|
+
export declare const EXPORT_TYPE = "export";
|
|
104
|
+
export declare const SEND_TYPE = "send";
|
|
105
|
+
export declare const IMPORT_C_TYPE = "import-c";
|
|
106
|
+
export declare const VALIDATOR_TYPE = "validator";
|
|
107
|
+
export declare const ADDVALIDATOR_TYPE = "addValidator";
|
|
108
|
+
export declare const ADD_VALIDATOR_TX_TYPE = "AddValidatorTx";
|
|
109
|
+
export declare const VALIDATOR_TRANSACTION_TYPES: string[];
|
|
110
|
+
export declare const TRANSFERABLE_INPUT_TYPE = "TransferableInput";
|
|
111
|
+
export declare const CREDENTIAL_TYPE = "Credential";
|
|
112
|
+
export declare const SECP256K1_TRANSFER_INPUT_TYPE = "secp256k1fx.TransferInput";
|
|
113
|
+
export declare const SECP256K1_TRANSFER_OUTPUT_TYPE = "secp256k1fx.TransferOutput";
|
|
114
|
+
export declare const DESTINATION_CHAIN_PROP = "destinationChain";
|
|
115
|
+
export declare const DESTINATION_CHAIN_ID_PROP = "destinationChainID";
|
|
116
|
+
export declare const EXPORTED_OUTPUTS_PROP = "exportedOutputs";
|
|
117
|
+
export declare const OUTS_PROP = "outs";
|
|
118
|
+
export declare const INPUTS_PROP = "inputs";
|
|
119
|
+
export declare const INS_PROP = "ins";
|
|
120
|
+
export declare const NETWORK_ID_PROP = "networkID";
|
|
121
|
+
export declare const NETWORK_ID_PROP_ALT = "networkId";
|
|
122
|
+
export declare const BLOCKCHAIN_ID_PROP = "blockchainID";
|
|
123
|
+
export declare const GET_OUTPUT_METHOD = "getOutput";
|
|
124
|
+
export declare const OUTPUT_ID_FIELD = "outputID";
|
|
125
|
+
export declare const AMOUNT_FIELD = "amount";
|
|
126
|
+
export declare const TXID_FIELD = "txid";
|
|
127
|
+
export declare const OUTPUT_IDX_FIELD = "outputidx";
|
|
128
|
+
export declare const ID_FIELD = "id";
|
|
129
|
+
export declare const OUTPUT_AMOUNT_FIELD = "outputAmount";
|
|
130
|
+
export declare const CHANGE_AMOUNT_FIELD = "changeAmount";
|
|
131
|
+
export declare const OUTPUTS_FIELD = "outputs";
|
|
132
|
+
export declare const CHANGE_OUTPUTS_FIELD = "changeOutputs";
|
|
133
|
+
export declare const FEE_FIELD = "fee";
|
|
134
|
+
export declare const TYPE_FIELD = "type";
|
|
135
|
+
export declare const SECP256K1_SIG_TYPE = "secp256k1";
|
|
136
|
+
export declare const DER_FORMAT = "der";
|
|
137
|
+
export declare const SHA256_HASH = "sha256";
|
|
138
|
+
export declare const RECOVERY_KEY_METHOD = "recovery-key";
|
|
139
|
+
export declare const NORMAL_MODE = "normal";
|
|
140
|
+
export declare const RECOVERY_MODE = "recovery";
|
|
141
|
+
export declare const RECOVERY_VERSION = "1.0.0";
|
|
142
|
+
export declare const SIGNATURE_VERSION = "1.0.0";
|
|
143
|
+
export declare const HEX_RADIX = 16;
|
|
144
|
+
export declare const ADD_PERMISSIONLESS_VALIDATOR_TYPE = "addPermissionlessValidator";
|
|
145
|
+
export declare const DISPLAY_ORDER_BASE: string[];
|
|
146
|
+
export declare const MEMO_FIELD = "memo";
|
|
147
|
+
export declare const REWARD_ADDRESSES_FIELD = "rewardAddresses";
|
|
148
|
+
export declare const SOURCE_CHAIN_FIELD = "sourceChain";
|
|
149
|
+
export declare const DESTINATION_CHAIN_FIELD = "destinationChain";
|
|
150
|
+
export declare const FLR_ASSET_ID = "FLR";
|
|
151
|
+
export declare const FLARE_TX_HEX_PLACEHOLDER = "flare-tx-hex-placeholder";
|
|
152
|
+
export declare const FLARE_SIGNABLE_PAYLOAD = "flare-signable-payload";
|
|
153
|
+
export declare const FLARE_TRANSACTION_ID_PLACEHOLDER = "flare-transaction-id-placeholder";
|
|
154
|
+
export declare const PLACEHOLDER_NODE_ID = "placeholder-node-id";
|
|
155
|
+
export declare const P_CHAIN_SHORT = "P";
|
|
156
|
+
export declare const X_CHAIN_SHORT = "X";
|
|
157
|
+
export declare const VALID_IMPORT_SOURCE_CHAINS: string[];
|
|
158
|
+
export declare const VALID_P_CHAIN_IMPORT_TYPES: string[];
|
|
159
|
+
export declare const ERROR_NETWORK_ID_MISMATCH = "Network ID mismatch";
|
|
160
|
+
export declare const ERROR_BLOCKCHAIN_ID_MISMATCH_BUILDER = "Blockchain ID mismatch";
|
|
161
|
+
export declare const ERROR_INVALID_THRESHOLD = "Invalid transaction: threshold must be set to 2";
|
|
162
|
+
export declare const ERROR_INVALID_LOCKTIME = "Invalid transaction: locktime must be 0 or higher";
|
|
163
|
+
export declare const ERROR_UTXOS_EMPTY_ARRAY = "Utxos can't be empty array";
|
|
164
|
+
export declare const ERROR_UTXOS_MISSING_FIELD = "Utxos required";
|
|
165
|
+
export declare const ERROR_FROM_ADDRESSES_REQUIRED = "from addresses are required";
|
|
166
|
+
export declare const ERROR_UTXOS_REQUIRED_BUILDER = "utxos are required";
|
|
167
|
+
export declare const ERROR_PARSE_RAW_TRANSACTION = "Failed to parse raw transaction";
|
|
168
|
+
export declare const ERROR_UNKNOWN_PARSING = "Unknown error";
|
|
169
|
+
export declare const UTXO_REQUIRED_FIELDS: string[];
|
|
11
170
|
//# sourceMappingURL=constants.d.ts.map
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"constants.d.ts","sourceRoot":"","sources":["../../../src/lib/constants.ts"],"names":[],"mappings":"AAGA,eAAO,MAAM,uBAAuB,KAAK,CAAC;AAC1C,eAAO,MAAM,oBAAoB,KAAK,CAAC;AACvC,eAAO,MAAM,4BAA4B,KAAK,CAAC;AAC/C,eAAO,MAAM,8BAA8B,MAAM,CAAC;AAClD,eAAO,MAAM,sBAAsB,KAAK,CAAC;AACzC,eAAO,MAAM,2BAA2B,KAAK,CAAC;AAC9C,eAAO,MAAM,6BAA6B,OAAO,CAAC;AAClD,eAAO,MAAM,uBAAuB,IAAI,CAAC;AAGzC,eAAO,MAAM,aAAa,QAAgC,CAAC;AAC3D,eAAO,MAAM,SAAS,QAA4B,CAAC"}
|
|
1
|
+
{"version":3,"file":"constants.d.ts","sourceRoot":"","sources":["../../../src/lib/constants.ts"],"names":[],"mappings":"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"}
|