@bitgo-beta/sdk-coin-flrp 1.0.1-beta.39 → 1.0.1-beta.391
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 +10 -17
- package/dist/src/flrp.d.ts.map +1 -1
- package/dist/src/flrp.js +51 -77
- 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 +43 -0
- package/dist/src/lib/ExportInCTxBuilder.d.ts.map +1 -0
- package/dist/src/lib/ExportInCTxBuilder.js +150 -0
- package/dist/src/lib/ExportInPTxBuilder.d.ts +29 -0
- package/dist/src/lib/ExportInPTxBuilder.d.ts.map +1 -0
- package/dist/src/lib/ExportInPTxBuilder.js +185 -0
- package/dist/src/lib/ImportInCTxBuilder.d.ts +35 -0
- package/dist/src/lib/ImportInCTxBuilder.d.ts.map +1 -0
- package/dist/src/lib/ImportInCTxBuilder.js +186 -0
- package/dist/src/lib/ImportInPTxBuilder.d.ts +48 -0
- package/dist/src/lib/ImportInPTxBuilder.d.ts.map +1 -0
- package/dist/src/lib/ImportInPTxBuilder.js +228 -0
- package/dist/src/lib/atomicInCTransactionBuilder.d.ts +12 -16
- package/dist/src/lib/atomicInCTransactionBuilder.d.ts.map +1 -1
- package/dist/src/lib/atomicInCTransactionBuilder.js +30 -41
- package/dist/src/lib/atomicTransactionBuilder.d.ts +81 -69
- package/dist/src/lib/atomicTransactionBuilder.d.ts.map +1 -1
- package/dist/src/lib/atomicTransactionBuilder.js +189 -212
- package/dist/src/lib/iface.d.ts +65 -57
- package/dist/src/lib/iface.d.ts.map +1 -1
- package/dist/src/lib/iface.js +20 -14
- package/dist/src/lib/index.d.ts +5 -0
- package/dist/src/lib/index.d.ts.map +1 -1
- package/dist/src/lib/index.js +12 -2
- package/dist/src/lib/keyPair.d.ts +5 -5
- package/dist/src/lib/keyPair.d.ts.map +1 -1
- package/dist/src/lib/keyPair.js +17 -9
- package/dist/src/lib/permissionlessValidatorTxBuilder.d.ts +41 -0
- package/dist/src/lib/permissionlessValidatorTxBuilder.d.ts.map +1 -0
- package/dist/src/lib/permissionlessValidatorTxBuilder.js +126 -0
- package/dist/src/lib/transaction.d.ts +30 -66
- package/dist/src/lib/transaction.d.ts.map +1 -1
- package/dist/src/lib/transaction.js +338 -199
- package/dist/src/lib/transactionBuilder.d.ts +115 -0
- package/dist/src/lib/transactionBuilder.d.ts.map +1 -0
- package/dist/src/lib/transactionBuilder.js +228 -0
- package/dist/src/lib/transactionBuilderFactory.d.ts +50 -30
- package/dist/src/lib/transactionBuilderFactory.d.ts.map +1 -1
- package/dist/src/lib/transactionBuilderFactory.js +129 -72
- package/dist/src/lib/utils.d.ts +106 -146
- package/dist/src/lib/utils.d.ts.map +1 -1
- package/dist/src/lib/utils.js +305 -321
- package/dist/test/resources/account.d.ts +81 -0
- package/dist/test/resources/account.d.ts.map +1 -0
- package/dist/test/resources/account.js +79 -0
- package/dist/test/resources/transactionData/exportInC.d.ts +50 -0
- package/dist/test/resources/transactionData/exportInC.d.ts.map +1 -0
- package/dist/test/resources/transactionData/exportInC.js +58 -0
- package/dist/test/resources/transactionData/exportInP.d.ts +60 -0
- package/dist/test/resources/transactionData/exportInP.d.ts.map +1 -0
- package/dist/test/resources/transactionData/exportInP.js +101 -0
- package/dist/test/resources/transactionData/importInC.d.ts +56 -0
- package/dist/test/resources/transactionData/importInC.d.ts.map +1 -0
- package/dist/test/resources/transactionData/importInC.js +120 -0
- package/dist/test/resources/transactionData/importInP.d.ts +66 -0
- package/dist/test/resources/transactionData/importInP.d.ts.map +1 -0
- package/dist/test/resources/transactionData/importInP.js +84 -0
- package/dist/test/unit/flrp.js +449 -68
- 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 +193 -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 +191 -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 +204 -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 +312 -0
- package/dist/test/unit/lib/keyPair.d.ts +2 -0
- package/dist/test/unit/lib/keyPair.d.ts.map +1 -0
- package/dist/test/unit/lib/keyPair.js +158 -0
- package/dist/test/unit/lib/signFlowTestSuit.d.ts +20 -0
- package/dist/test/unit/lib/signFlowTestSuit.d.ts.map +1 -0
- package/dist/test/unit/lib/signFlowTestSuit.js +83 -0
- package/dist/test/unit/lib/signatureIndex.d.ts +13 -0
- package/dist/test/unit/lib/signatureIndex.d.ts.map +1 -0
- package/dist/test/unit/lib/signatureIndex.js +843 -0
- package/dist/test/unit/lib/transactionBuilderFactory.d.ts +2 -0
- package/dist/test/unit/lib/transactionBuilderFactory.d.ts.map +1 -0
- package/dist/test/unit/lib/transactionBuilderFactory.js +60 -0
- package/dist/test/unit/lib/utils.js +601 -207
- package/dist/tsconfig.tsbuildinfo +1 -1
- package/package.json +19 -10
- package/.eslintignore +0 -5
- package/.eslintrc.json +0 -7
- package/.mocharc.yml +0 -8
- package/CHANGELOG.md +0 -0
- 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 -11
- package/dist/src/lib/constants.d.ts.map +0 -1
- package/dist/src/lib/constants.js +0 -17
- 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 -170
- 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 -56
- 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/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
- 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/smoke.d.ts +0 -2
- package/dist/test/unit/smoke.d.ts.map +0 -1
- package/dist/test/unit/smoke.js +0 -23
|
@@ -1,91 +1,148 @@
|
|
|
1
1
|
"use strict";
|
|
2
|
+
var __importDefault = (this && this.__importDefault) || function (mod) {
|
|
3
|
+
return (mod && mod.__esModule) ? mod : { "default": mod };
|
|
4
|
+
};
|
|
2
5
|
Object.defineProperty(exports, "__esModule", { value: true });
|
|
3
|
-
exports.TransactionBuilderFactory =
|
|
6
|
+
exports.TransactionBuilderFactory = void 0;
|
|
7
|
+
const flarejs_1 = require("@flarenetwork/flarejs");
|
|
4
8
|
const sdk_core_1 = require("@bitgo-beta/sdk-core");
|
|
5
|
-
const
|
|
6
|
-
|
|
7
|
-
|
|
8
|
-
|
|
9
|
-
|
|
9
|
+
const ExportInPTxBuilder_1 = require("./ExportInPTxBuilder");
|
|
10
|
+
const ImportInPTxBuilder_1 = require("./ImportInPTxBuilder");
|
|
11
|
+
const ExportInCTxBuilder_1 = require("./ExportInCTxBuilder");
|
|
12
|
+
const ImportInCTxBuilder_1 = require("./ImportInCTxBuilder");
|
|
13
|
+
const utils_1 = __importDefault(require("./utils"));
|
|
14
|
+
class TransactionBuilderFactory extends sdk_core_1.BaseTransactionBuilderFactory {
|
|
15
|
+
constructor(_coinConfig) {
|
|
16
|
+
super(_coinConfig);
|
|
10
17
|
}
|
|
11
|
-
|
|
12
|
-
|
|
13
|
-
|
|
14
|
-
|
|
15
|
-
|
|
16
|
-
|
|
17
|
-
|
|
18
|
-
|
|
19
|
-
|
|
18
|
+
/**
|
|
19
|
+
* Extract credentials from remaining bytes after transaction using FlareJS codec.
|
|
20
|
+
* This is the proper way to parse credentials - using the codec's UnpackPrefix method.
|
|
21
|
+
* @param credentialBytes Remaining bytes after the transaction (starts with numCredentials)
|
|
22
|
+
* @param codec The FlareJS codec to use for unpacking
|
|
23
|
+
* @returns Array of parsed credentials
|
|
24
|
+
*/
|
|
25
|
+
extractCredentialsWithCodec(credentialBytes, codec) {
|
|
26
|
+
const credentials = [];
|
|
27
|
+
if (credentialBytes.length < 4) {
|
|
28
|
+
return credentials;
|
|
29
|
+
}
|
|
30
|
+
// Skip the first 4 bytes (numCredentials as Int type)
|
|
31
|
+
// The codec doesn't know about this Int, so we skip it manually
|
|
32
|
+
let remainingBytes = credentialBytes.slice(4);
|
|
33
|
+
let moreCredentials = true;
|
|
34
|
+
do {
|
|
35
|
+
try {
|
|
36
|
+
const [credential, rest] = codec.UnpackPrefix(remainingBytes);
|
|
37
|
+
credentials.push(credential);
|
|
38
|
+
remainingBytes = rest;
|
|
39
|
+
}
|
|
40
|
+
catch {
|
|
41
|
+
moreCredentials = false;
|
|
42
|
+
}
|
|
43
|
+
} while (remainingBytes.length > 0 && moreCredentials);
|
|
44
|
+
return credentials;
|
|
20
45
|
}
|
|
21
|
-
|
|
22
|
-
|
|
23
|
-
|
|
46
|
+
/**
|
|
47
|
+
* Parse a raw transaction buffer using the specified VM manager.
|
|
48
|
+
* @param rawBuffer The raw transaction buffer
|
|
49
|
+
* @param vmType The VM type to use for parsing ('EVM' or 'PVM')
|
|
50
|
+
* @returns Parsed transaction and credentials, or null if parsing fails
|
|
51
|
+
*/
|
|
52
|
+
parseWithVM(rawBuffer, vmType) {
|
|
53
|
+
try {
|
|
54
|
+
const manager = flarejs_1.utils.getManagerForVM(vmType);
|
|
55
|
+
const [codec, txBytes] = manager.getCodecFromBuffer(rawBuffer);
|
|
56
|
+
const [tx, credentialBytes] = codec.UnpackPrefix(txBytes);
|
|
57
|
+
const credentials = credentialBytes.length > 4 ? this.extractCredentialsWithCodec(credentialBytes, codec) : [];
|
|
58
|
+
return { tx, credentials };
|
|
59
|
+
}
|
|
60
|
+
catch {
|
|
61
|
+
return null;
|
|
62
|
+
}
|
|
24
63
|
}
|
|
25
|
-
|
|
26
|
-
|
|
27
|
-
|
|
28
|
-
|
|
29
|
-
|
|
64
|
+
/**
|
|
65
|
+
* Create the appropriate transaction builder based on transaction type.
|
|
66
|
+
* @param tx The parsed transaction
|
|
67
|
+
* @param rawBuffer The raw transaction buffer
|
|
68
|
+
* @param credentials The extracted credentials
|
|
69
|
+
* @param isEVM Whether this is an EVM transaction
|
|
70
|
+
* @returns The appropriate transaction builder
|
|
71
|
+
*/
|
|
72
|
+
createBuilder(tx, rawBuffer, credentials, isEVM) {
|
|
73
|
+
if (isEVM) {
|
|
74
|
+
if (ExportInCTxBuilder_1.ExportInCTxBuilder.verifyTxType(tx._type)) {
|
|
75
|
+
const builder = this.getExportInCBuilder();
|
|
76
|
+
builder.initBuilder(tx, rawBuffer, credentials);
|
|
77
|
+
return builder;
|
|
78
|
+
}
|
|
79
|
+
if (ImportInCTxBuilder_1.ImportInCTxBuilder.verifyTxType(tx._type)) {
|
|
80
|
+
const builder = this.getImportInCBuilder();
|
|
81
|
+
builder.initBuilder(tx, rawBuffer, credentials);
|
|
82
|
+
return builder;
|
|
83
|
+
}
|
|
84
|
+
}
|
|
85
|
+
else {
|
|
86
|
+
if (ImportInPTxBuilder_1.ImportInPTxBuilder.verifyTxType(tx._type)) {
|
|
87
|
+
const builder = this.getImportInPBuilder();
|
|
88
|
+
builder.initBuilder(tx, rawBuffer, credentials);
|
|
89
|
+
return builder;
|
|
90
|
+
}
|
|
91
|
+
if (ExportInPTxBuilder_1.ExportInPTxBuilder.verifyTxType(tx._type)) {
|
|
92
|
+
const builder = this.getExportInPBuilder();
|
|
93
|
+
builder.initBuilder(tx, rawBuffer, credentials);
|
|
94
|
+
return builder;
|
|
95
|
+
}
|
|
96
|
+
}
|
|
97
|
+
throw new sdk_core_1.NotSupported('Transaction type not supported');
|
|
30
98
|
}
|
|
31
|
-
|
|
32
|
-
|
|
33
|
-
|
|
99
|
+
/** @inheritdoc */
|
|
100
|
+
from(raw) {
|
|
101
|
+
utils_1.default.validateRawTransaction(raw);
|
|
102
|
+
const rawBuffer = Buffer.from(utils_1.default.removeHexPrefix(raw), 'hex');
|
|
103
|
+
// Try EVM first, then fall back to PVM
|
|
104
|
+
const evmResult = this.parseWithVM(rawBuffer, 'EVM');
|
|
105
|
+
if (evmResult) {
|
|
106
|
+
return this.createBuilder(evmResult.tx, rawBuffer, evmResult.credentials, true);
|
|
107
|
+
}
|
|
108
|
+
const pvmResult = this.parseWithVM(rawBuffer, 'PVM');
|
|
109
|
+
if (pvmResult) {
|
|
110
|
+
return this.createBuilder(pvmResult.tx, rawBuffer, pvmResult.credentials, false);
|
|
111
|
+
}
|
|
112
|
+
throw new sdk_core_1.NotSupported('Transaction type not supported');
|
|
34
113
|
}
|
|
35
|
-
|
|
36
|
-
|
|
37
|
-
|
|
38
|
-
get transactionType() {
|
|
39
|
-
return sdk_core_1.TransactionType.AddDelegator;
|
|
114
|
+
/** @inheritdoc */
|
|
115
|
+
getTransferBuilder() {
|
|
116
|
+
throw new sdk_core_1.NotSupported('Transfer is not supported in P Chain');
|
|
40
117
|
}
|
|
41
|
-
|
|
42
|
-
|
|
43
|
-
|
|
118
|
+
/**
|
|
119
|
+
* Export Cross chain transfer
|
|
120
|
+
*/
|
|
121
|
+
getExportInPBuilder() {
|
|
122
|
+
return new ExportInPTxBuilder_1.ExportInPTxBuilder(this._coinConfig);
|
|
44
123
|
}
|
|
45
|
-
|
|
46
|
-
|
|
47
|
-
|
|
48
|
-
|
|
49
|
-
|
|
50
|
-
class TransactionBuilderFactory {
|
|
51
|
-
constructor(coinConfig) {
|
|
52
|
-
this._coinConfig = coinConfig;
|
|
124
|
+
/**
|
|
125
|
+
* Import Cross chain transfer
|
|
126
|
+
*/
|
|
127
|
+
getImportInPBuilder() {
|
|
128
|
+
return new ImportInPTxBuilder_1.ImportInPTxBuilder(this._coinConfig);
|
|
53
129
|
}
|
|
54
130
|
/**
|
|
55
|
-
*
|
|
56
|
-
* @param txHex - Transaction hex string
|
|
131
|
+
* Import in C chain Cross chain transfer
|
|
57
132
|
*/
|
|
58
|
-
|
|
59
|
-
|
|
60
|
-
// For now, return a basic export builder as that's the most common use case
|
|
61
|
-
if (!txHex) {
|
|
62
|
-
throw new Error('Transaction hex is required');
|
|
63
|
-
}
|
|
64
|
-
// Create a mock export builder for now
|
|
65
|
-
// In the future, this will parse the transaction and determine the correct type
|
|
66
|
-
const builder = new ExportTxBuilder(this._coinConfig);
|
|
67
|
-
// Initialize with the hex data (placeholder)
|
|
68
|
-
builder.initBuilder({ txHex });
|
|
69
|
-
return builder;
|
|
133
|
+
getImportInCBuilder() {
|
|
134
|
+
return new ImportInCTxBuilder_1.ImportInCTxBuilder(this._coinConfig);
|
|
70
135
|
}
|
|
71
136
|
/**
|
|
72
|
-
*
|
|
73
|
-
* @param type - Transaction type
|
|
137
|
+
* Export in C chain Cross chain transfer
|
|
74
138
|
*/
|
|
75
|
-
|
|
76
|
-
|
|
77
|
-
|
|
78
|
-
|
|
79
|
-
|
|
80
|
-
|
|
81
|
-
case sdk_core_1.TransactionType.AddValidator:
|
|
82
|
-
return new ValidatorTxBuilder(this._coinConfig);
|
|
83
|
-
case sdk_core_1.TransactionType.AddDelegator:
|
|
84
|
-
return new DelegatorTxBuilder(this._coinConfig);
|
|
85
|
-
default:
|
|
86
|
-
throw new sdk_core_1.NotImplementedError(`Transaction type ${type} not supported`);
|
|
87
|
-
}
|
|
139
|
+
getExportInCBuilder() {
|
|
140
|
+
return new ExportInCTxBuilder_1.ExportInCTxBuilder(this._coinConfig);
|
|
141
|
+
}
|
|
142
|
+
/** @inheritdoc */
|
|
143
|
+
getWalletInitializationBuilder() {
|
|
144
|
+
throw new sdk_core_1.NotSupported('Wallet initialization is not needed');
|
|
88
145
|
}
|
|
89
146
|
}
|
|
90
147
|
exports.TransactionBuilderFactory = TransactionBuilderFactory;
|
|
91
|
-
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoidHJhbnNhY3Rpb25CdWlsZGVyRmFjdG9yeS5qcyIsInNvdXJjZVJvb3QiOiIiLCJzb3VyY2VzIjpbIi4uLy4uLy4uL3NyYy9saWIvdHJhbnNhY3Rpb25CdWlsZGVyRmFjdG9yeS50cyJdLCJuYW1lcyI6W10sIm1hcHBpbmdzIjoiOzs7QUFDQSxtREFBNEU7QUFDNUUseUVBQXNFO0FBRXRFLDJEQUEyRDtBQUMzRCxNQUFhLGVBQWdCLFNBQVEsbURBQXdCO0lBQzNELElBQWMsZUFBZTtRQUMzQixPQUFPLDBCQUFlLENBQUMsTUFBTSxDQUFDO0lBQ2hDLENBQUM7SUFFRCxZQUFZLFVBQWdDO1FBQzFDLEtBQUssQ0FBQyxVQUFVLENBQUMsQ0FBQztRQUNsQixxREFBcUQ7SUFDdkQsQ0FBQztDQUNGO0FBVEQsMENBU0M7QUFFRCxNQUFhLGVBQWdCLFNBQVEsbURBQXdCO0lBQzNELElBQWMsZUFBZTtRQUMzQixPQUFPLDBCQUFlLENBQUMsTUFBTSxDQUFDO0lBQ2hDLENBQUM7SUFFRCxZQUFZLFVBQWdDO1FBQzFDLEtBQUssQ0FBQyxVQUFVLENBQUMsQ0FBQztRQUNsQixxREFBcUQ7SUFDdkQsQ0FBQztDQUNGO0FBVEQsMENBU0M7QUFFRCxNQUFhLGtCQUFtQixTQUFRLG1EQUF3QjtJQUM5RCxJQUFjLGVBQWU7UUFDM0IsT0FBTywwQkFBZSxDQUFDLFlBQVksQ0FBQztJQUN0QyxDQUFDO0lBRUQsWUFBWSxVQUFnQztRQUMxQyxLQUFLLENBQUMsVUFBVSxDQUFDLENBQUM7UUFDbEIscURBQXFEO0lBQ3ZELENBQUM7Q0FDRjtBQVRELGdEQVNDO0FBRUQsTUFBYSxrQkFBbUIsU0FBUSxtREFBd0I7SUFDOUQsSUFBYyxlQUFlO1FBQzNCLE9BQU8sMEJBQWUsQ0FBQyxZQUFZLENBQUM7SUFDdEMsQ0FBQztJQUVELFlBQVksVUFBZ0M7UUFDMUMsS0FBSyxDQUFDLFVBQVUsQ0FBQyxDQUFDO1FBQ2xCLHFEQUFxRDtJQUN2RCxDQUFDO0NBQ0Y7QUFURCxnREFTQztBQUVEOztHQUVHO0FBQ0gsTUFBYSx5QkFBeUI7SUFHcEMsWUFBWSxVQUFnQztRQUMxQyxJQUFJLENBQUMsV0FBVyxHQUFHLFVBQVUsQ0FBQztJQUNoQyxDQUFDO0lBRUQ7OztPQUdHO0lBQ0gsSUFBSSxDQUFDLEtBQWE7UUFDaEIsc0ZBQXNGO1FBQ3RGLDRFQUE0RTtRQUM1RSxJQUFJLENBQUMsS0FBSyxFQUFFLENBQUM7WUFDWCxNQUFNLElBQUksS0FBSyxDQUFDLDZCQUE2QixDQUFDLENBQUM7UUFDakQsQ0FBQztRQUVELHVDQUF1QztRQUN2QyxnRkFBZ0Y7UUFDaEYsTUFBTSxPQUFPLEdBQUcsSUFBSSxlQUFlLENBQUMsSUFBSSxDQUFDLFdBQVcsQ0FBQyxDQUFDO1FBRXRELDZDQUE2QztRQUM3QyxPQUFPLENBQUMsV0FBVyxDQUFDLEVBQUUsS0FBSyxFQUFFLENBQUMsQ0FBQztRQUUvQixPQUFPLE9BQU8sQ0FBQztJQUNqQixDQUFDO0lBRUQ7OztPQUdHO0lBQ0gsVUFBVSxDQUFDLElBQXFCO1FBQzlCLFFBQVEsSUFBSSxFQUFFLENBQUM7WUFDYixLQUFLLDBCQUFlLENBQUMsTUFBTTtnQkFDekIsT0FBTyxJQUFJLGVBQWUsQ0FBQyxJQUFJLENBQUMsV0FBVyxDQUFDLENBQUM7WUFDL0MsS0FBSywwQkFBZSxDQUFDLE1BQU07Z0JBQ3pCLE9BQU8sSUFBSSxlQUFlLENBQUMsSUFBSSxDQUFDLFdBQVcsQ0FBQyxDQUFDO1lBQy9DLEtBQUssMEJBQWUsQ0FBQyxZQUFZO2dCQUMvQixPQUFPLElBQUksa0JBQWtCLENBQUMsSUFBSSxDQUFDLFdBQVcsQ0FBQyxDQUFDO1lBQ2xELEtBQUssMEJBQWUsQ0FBQyxZQUFZO2dCQUMvQixPQUFPLElBQUksa0JBQWtCLENBQUMsSUFBSSxDQUFDLFdBQVcsQ0FBQyxDQUFDO1lBQ2xEO2dCQUNFLE1BQU0sSUFBSSw4QkFBbUIsQ0FBQyxvQkFBb0IsSUFBSSxnQkFBZ0IsQ0FBQyxDQUFDO1FBQzVFLENBQUM7SUFDSCxDQUFDO0NBQ0Y7QUE5Q0QsOERBOENDIiwic291cmNlc0NvbnRlbnQiOlsiaW1wb3J0IHsgQmFzZUNvaW4gYXMgQ29pbkNvbmZpZyB9IGZyb20gJ0BiaXRnby1iZXRhL3N0YXRpY3MnO1xuaW1wb3J0IHsgTm90SW1wbGVtZW50ZWRFcnJvciwgVHJhbnNhY3Rpb25UeXBlIH0gZnJvbSAnQGJpdGdvLWJldGEvc2RrLWNvcmUnO1xuaW1wb3J0IHsgQXRvbWljVHJhbnNhY3Rpb25CdWlsZGVyIH0gZnJvbSAnLi9hdG9taWNUcmFuc2FjdGlvbkJ1aWxkZXInO1xuXG4vLyBQbGFjZWhvbGRlciBidWlsZGVycyAtIGJhc2ljIGltcGxlbWVudGF0aW9ucyBmb3IgdGVzdGluZ1xuZXhwb3J0IGNsYXNzIEV4cG9ydFR4QnVpbGRlciBleHRlbmRzIEF0b21pY1RyYW5zYWN0aW9uQnVpbGRlciB7XG4gIHByb3RlY3RlZCBnZXQgdHJhbnNhY3Rpb25UeXBlKCk6IFRyYW5zYWN0aW9uVHlwZSB7XG4gICAgcmV0dXJuIFRyYW5zYWN0aW9uVHlwZS5FeHBvcnQ7XG4gIH1cblxuICBjb25zdHJ1Y3Rvcihjb2luQ29uZmlnOiBSZWFkb25seTxDb2luQ29uZmlnPikge1xuICAgIHN1cGVyKGNvaW5Db25maWcpO1xuICAgIC8vIERvbid0IHRocm93IGVycm9yLCBhbGxvdyBwbGFjZWhvbGRlciBmdW5jdGlvbmFsaXR5XG4gIH1cbn1cblxuZXhwb3J0IGNsYXNzIEltcG9ydFR4QnVpbGRlciBleHRlbmRzIEF0b21pY1RyYW5zYWN0aW9uQnVpbGRlciB7XG4gIHByb3RlY3RlZCBnZXQgdHJhbnNhY3Rpb25UeXBlKCk6IFRyYW5zYWN0aW9uVHlwZSB7XG4gICAgcmV0dXJuIFRyYW5zYWN0aW9uVHlwZS5JbXBvcnQ7XG4gIH1cblxuICBjb25zdHJ1Y3Rvcihjb2luQ29uZmlnOiBSZWFkb25seTxDb2luQ29uZmlnPikge1xuICAgIHN1cGVyKGNvaW5Db25maWcpO1xuICAgIC8vIERvbid0IHRocm93IGVycm9yLCBhbGxvdyBwbGFjZWhvbGRlciBmdW5jdGlvbmFsaXR5XG4gIH1cbn1cblxuZXhwb3J0IGNsYXNzIFZhbGlkYXRvclR4QnVpbGRlciBleHRlbmRzIEF0b21pY1RyYW5zYWN0aW9uQnVpbGRlciB7XG4gIHByb3RlY3RlZCBnZXQgdHJhbnNhY3Rpb25UeXBlKCk6IFRyYW5zYWN0aW9uVHlwZSB7XG4gICAgcmV0dXJuIFRyYW5zYWN0aW9uVHlwZS5BZGRWYWxpZGF0b3I7XG4gIH1cblxuICBjb25zdHJ1Y3Rvcihjb2luQ29uZmlnOiBSZWFkb25seTxDb2luQ29uZmlnPikge1xuICAgIHN1cGVyKGNvaW5Db25maWcpO1xuICAgIC8vIERvbid0IHRocm93IGVycm9yLCBhbGxvdyBwbGFjZWhvbGRlciBmdW5jdGlvbmFsaXR5XG4gIH1cbn1cblxuZXhwb3J0IGNsYXNzIERlbGVnYXRvclR4QnVpbGRlciBleHRlbmRzIEF0b21pY1RyYW5zYWN0aW9uQnVpbGRlciB7XG4gIHByb3RlY3RlZCBnZXQgdHJhbnNhY3Rpb25UeXBlKCk6IFRyYW5zYWN0aW9uVHlwZSB7XG4gICAgcmV0dXJuIFRyYW5zYWN0aW9uVHlwZS5BZGREZWxlZ2F0b3I7XG4gIH1cblxuICBjb25zdHJ1Y3Rvcihjb2luQ29uZmlnOiBSZWFkb25seTxDb2luQ29uZmlnPikge1xuICAgIHN1cGVyKGNvaW5Db25maWcpO1xuICAgIC8vIERvbid0IHRocm93IGVycm9yLCBhbGxvdyBwbGFjZWhvbGRlciBmdW5jdGlvbmFsaXR5XG4gIH1cbn1cblxuLyoqXG4gKiBGYWN0b3J5IGZvciBGbGFyZSBQLWNoYWluIHRyYW5zYWN0aW9uIGJ1aWxkZXJzXG4gKi9cbmV4cG9ydCBjbGFzcyBUcmFuc2FjdGlvbkJ1aWxkZXJGYWN0b3J5IHtcbiAgcHJvdGVjdGVkIF9jb2luQ29uZmlnOiBSZWFkb25seTxDb2luQ29uZmlnPjtcblxuICBjb25zdHJ1Y3Rvcihjb2luQ29uZmlnOiBSZWFkb25seTxDb2luQ29uZmlnPikge1xuICAgIHRoaXMuX2NvaW5Db25maWcgPSBjb2luQ29uZmlnO1xuICB9XG5cbiAgLyoqXG4gICAqIENyZWF0ZSBhIHRyYW5zYWN0aW9uIGJ1aWxkZXIgZnJvbSBhIGhleCBzdHJpbmdcbiAgICogQHBhcmFtIHR4SGV4IC0gVHJhbnNhY3Rpb24gaGV4IHN0cmluZ1xuICAgKi9cbiAgZnJvbSh0eEhleDogc3RyaW5nKTogQXRvbWljVHJhbnNhY3Rpb25CdWlsZGVyIHtcbiAgICAvLyBUT0RPOiBQYXJzZSB0aGUgaGV4IGFuZCBkZXRlcm1pbmUgdHJhbnNhY3Rpb24gdHlwZSwgdGhlbiByZXR1cm4gYXBwcm9wcmlhdGUgYnVpbGRlclxuICAgIC8vIEZvciBub3csIHJldHVybiBhIGJhc2ljIGV4cG9ydCBidWlsZGVyIGFzIHRoYXQncyB0aGUgbW9zdCBjb21tb24gdXNlIGNhc2VcbiAgICBpZiAoIXR4SGV4KSB7XG4gICAgICB0aHJvdyBuZXcgRXJyb3IoJ1RyYW5zYWN0aW9uIGhleCBpcyByZXF1aXJlZCcpO1xuICAgIH1cblxuICAgIC8vIENyZWF0ZSBhIG1vY2sgZXhwb3J0IGJ1aWxkZXIgZm9yIG5vd1xuICAgIC8vIEluIHRoZSBmdXR1cmUsIHRoaXMgd2lsbCBwYXJzZSB0aGUgdHJhbnNhY3Rpb24gYW5kIGRldGVybWluZSB0aGUgY29ycmVjdCB0eXBlXG4gICAgY29uc3QgYnVpbGRlciA9IG5ldyBFeHBvcnRUeEJ1aWxkZXIodGhpcy5fY29pbkNvbmZpZyk7XG5cbiAgICAvLyBJbml0aWFsaXplIHdpdGggdGhlIGhleCBkYXRhIChwbGFjZWhvbGRlcilcbiAgICBidWlsZGVyLmluaXRCdWlsZGVyKHsgdHhIZXggfSk7XG5cbiAgICByZXR1cm4gYnVpbGRlcjtcbiAgfVxuXG4gIC8qKlxuICAgKiBDcmVhdGUgYSB0cmFuc2FjdGlvbiBidWlsZGVyIGZvciBhIHNwZWNpZmljIHR5cGVcbiAgICogQHBhcmFtIHR5cGUgLSBUcmFuc2FjdGlvbiB0eXBlXG4gICAqL1xuICBnZXRCdWlsZGVyKHR5cGU6IFRyYW5zYWN0aW9uVHlwZSk6IEF0b21pY1RyYW5zYWN0aW9uQnVpbGRlciB7XG4gICAgc3dpdGNoICh0eXBlKSB7XG4gICAgICBjYXNlIFRyYW5zYWN0aW9uVHlwZS5FeHBvcnQ6XG4gICAgICAgIHJldHVybiBuZXcgRXhwb3J0VHhCdWlsZGVyKHRoaXMuX2NvaW5Db25maWcpO1xuICAgICAgY2FzZSBUcmFuc2FjdGlvblR5cGUuSW1wb3J0OlxuICAgICAgICByZXR1cm4gbmV3IEltcG9ydFR4QnVpbGRlcih0aGlzLl9jb2luQ29uZmlnKTtcbiAgICAgIGNhc2UgVHJhbnNhY3Rpb25UeXBlLkFkZFZhbGlkYXRvcjpcbiAgICAgICAgcmV0dXJuIG5ldyBWYWxpZGF0b3JUeEJ1aWxkZXIodGhpcy5fY29pbkNvbmZpZyk7XG4gICAgICBjYXNlIFRyYW5zYWN0aW9uVHlwZS5BZGREZWxlZ2F0b3I6XG4gICAgICAgIHJldHVybiBuZXcgRGVsZWdhdG9yVHhCdWlsZGVyKHRoaXMuX2NvaW5Db25maWcpO1xuICAgICAgZGVmYXVsdDpcbiAgICAgICAgdGhyb3cgbmV3IE5vdEltcGxlbWVudGVkRXJyb3IoYFRyYW5zYWN0aW9uIHR5cGUgJHt0eXBlfSBub3Qgc3VwcG9ydGVkYCk7XG4gICAgfVxuICB9XG59XG4iXX0=
|
|
148
|
+
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"transactionBuilderFactory.js","sourceRoot":"","sources":["../../../src/lib/transactionBuilderFactory.ts"],"names":[],"mappings":"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","sourcesContent":["import { utils as FlareUtils, evmSerial, pvmSerial, Credential } from '@flarenetwork/flarejs';\nimport { BaseTransactionBuilderFactory, NotSupported } from '@bitgo-beta/sdk-core';\nimport { BaseCoin as CoinConfig } from '@bitgo-beta/statics';\nimport { TransactionBuilder } from './transactionBuilder';\nimport { ExportInPTxBuilder } from './ExportInPTxBuilder';\nimport { ImportInPTxBuilder } from './ImportInPTxBuilder';\nimport { ExportInCTxBuilder } from './ExportInCTxBuilder';\nimport { ImportInCTxBuilder } from './ImportInCTxBuilder';\nimport { SerializedTx } from './iface';\nimport utils from './utils';\n\ninterface Codec {\n  UnpackPrefix<T>(bytes: Uint8Array): [T, Uint8Array];\n}\n\nexport class TransactionBuilderFactory extends BaseTransactionBuilderFactory {\n  constructor(_coinConfig: Readonly<CoinConfig>) {\n    super(_coinConfig);\n  }\n\n  /**\n   * Extract credentials from remaining bytes after transaction using FlareJS codec.\n   * This is the proper way to parse credentials - using the codec's UnpackPrefix method.\n   * @param credentialBytes Remaining bytes after the transaction (starts with numCredentials)\n   * @param codec The FlareJS codec to use for unpacking\n   * @returns Array of parsed credentials\n   */\n  private extractCredentialsWithCodec(credentialBytes: Uint8Array, codec: Codec): Credential[] {\n    const credentials: Credential[] = [];\n    if (credentialBytes.length < 4) {\n      return credentials;\n    }\n\n    // Skip the first 4 bytes (numCredentials as Int type)\n    // The codec doesn't know about this Int, so we skip it manually\n    let remainingBytes: Uint8Array = credentialBytes.slice(4);\n    let moreCredentials = true;\n\n    do {\n      try {\n        const [credential, rest] = codec.UnpackPrefix<Credential>(remainingBytes);\n        credentials.push(credential);\n        remainingBytes = rest;\n      } catch {\n        moreCredentials = false;\n      }\n    } while (remainingBytes.length > 0 && moreCredentials);\n\n    return credentials;\n  }\n\n  /**\n   * Parse a raw transaction buffer using the specified VM manager.\n   * @param rawBuffer The raw transaction buffer\n   * @param vmType The VM type to use for parsing ('EVM' or 'PVM')\n   * @returns Parsed transaction and credentials, or null if parsing fails\n   */\n  private parseWithVM(\n    rawBuffer: Buffer,\n    vmType: 'EVM' | 'PVM'\n  ): { tx: SerializedTx; credentials: Credential[] } | null {\n    try {\n      const manager = FlareUtils.getManagerForVM(vmType);\n      const [codec, txBytes] = manager.getCodecFromBuffer(rawBuffer);\n      const [tx, credentialBytes] = (codec as Codec).UnpackPrefix<SerializedTx>(txBytes);\n\n      const credentials =\n        credentialBytes.length > 4 ? this.extractCredentialsWithCodec(credentialBytes, codec as Codec) : [];\n\n      return { tx, credentials };\n    } catch {\n      return null;\n    }\n  }\n\n  /**\n   * Create the appropriate transaction builder based on transaction type.\n   * @param tx The parsed transaction\n   * @param rawBuffer The raw transaction buffer\n   * @param credentials The extracted credentials\n   * @param isEVM Whether this is an EVM transaction\n   * @returns The appropriate transaction builder\n   */\n  private createBuilder(\n    tx: SerializedTx,\n    rawBuffer: Buffer,\n    credentials: Credential[],\n    isEVM: boolean\n  ): TransactionBuilder {\n    if (isEVM) {\n      if (ExportInCTxBuilder.verifyTxType(tx._type)) {\n        const builder = this.getExportInCBuilder();\n        builder.initBuilder(tx as evmSerial.ExportTx, rawBuffer, credentials);\n        return builder;\n      }\n      if (ImportInCTxBuilder.verifyTxType(tx._type)) {\n        const builder = this.getImportInCBuilder();\n        builder.initBuilder(tx as evmSerial.ImportTx, rawBuffer, credentials);\n        return builder;\n      }\n    } else {\n      if (ImportInPTxBuilder.verifyTxType(tx._type)) {\n        const builder = this.getImportInPBuilder();\n        builder.initBuilder(tx as pvmSerial.ImportTx, rawBuffer, credentials);\n        return builder;\n      }\n      if (ExportInPTxBuilder.verifyTxType(tx._type)) {\n        const builder = this.getExportInPBuilder();\n        builder.initBuilder(tx as pvmSerial.ExportTx, rawBuffer, credentials);\n        return builder;\n      }\n    }\n    throw new NotSupported('Transaction type not supported');\n  }\n\n  /** @inheritdoc */\n  from(raw: string): TransactionBuilder {\n    utils.validateRawTransaction(raw);\n    const rawBuffer = Buffer.from(utils.removeHexPrefix(raw), 'hex');\n\n    // Try EVM first, then fall back to PVM\n    const evmResult = this.parseWithVM(rawBuffer, 'EVM');\n    if (evmResult) {\n      return this.createBuilder(evmResult.tx, rawBuffer, evmResult.credentials, true);\n    }\n\n    const pvmResult = this.parseWithVM(rawBuffer, 'PVM');\n    if (pvmResult) {\n      return this.createBuilder(pvmResult.tx, rawBuffer, pvmResult.credentials, false);\n    }\n\n    throw new NotSupported('Transaction type not supported');\n  }\n\n  /** @inheritdoc */\n  getTransferBuilder(): TransactionBuilder {\n    throw new NotSupported('Transfer is not supported in P Chain');\n  }\n\n  /**\n   * Export Cross chain transfer\n   */\n  getExportInPBuilder(): ExportInPTxBuilder {\n    return new ExportInPTxBuilder(this._coinConfig);\n  }\n\n  /**\n   * Import Cross chain transfer\n   */\n  getImportInPBuilder(): ImportInPTxBuilder {\n    return new ImportInPTxBuilder(this._coinConfig);\n  }\n\n  /**\n   * Import in C chain Cross chain transfer\n   */\n  getImportInCBuilder(): ImportInCTxBuilder {\n    return new ImportInCTxBuilder(this._coinConfig);\n  }\n\n  /**\n   * Export in C chain Cross chain transfer\n   */\n  getExportInCBuilder(): ExportInCTxBuilder {\n    return new ExportInCTxBuilder(this._coinConfig);\n  }\n\n  /** @inheritdoc */\n  getWalletInitializationBuilder(): TransactionBuilder {\n    throw new NotSupported('Wallet initialization is not needed');\n  }\n}\n"]}
|
package/dist/src/lib/utils.d.ts
CHANGED
|
@@ -1,214 +1,174 @@
|
|
|
1
|
-
import { TransferableOutput } from '@flarenetwork/flarejs';
|
|
1
|
+
import { Signature, TransferableOutput, Id, Utxo } from '@flarenetwork/flarejs';
|
|
2
2
|
import { BaseUtils, Entry } from '@bitgo-beta/sdk-core';
|
|
3
3
|
import { FlareNetwork } from '@bitgo-beta/statics';
|
|
4
|
-
import {
|
|
4
|
+
import { Buffer } from 'buffer';
|
|
5
|
+
import { DecodedUtxoObj, Output, Tx } from './iface';
|
|
5
6
|
export declare class Utils implements BaseUtils {
|
|
7
|
+
isValidTransactionId(txId: string): boolean;
|
|
8
|
+
isValidSignature(signature: string): boolean;
|
|
9
|
+
/**
|
|
10
|
+
* Check if addresses in wallet match UTXO output addresses
|
|
11
|
+
*/
|
|
6
12
|
includeIn(walletAddresses: string[], otxoOutputAddresses: string[]): boolean;
|
|
7
13
|
/**
|
|
8
|
-
*
|
|
9
|
-
*
|
|
10
|
-
* @
|
|
11
|
-
* @returns {boolean} - the validation result
|
|
14
|
+
* Validates a Flare address or array of addresses
|
|
15
|
+
* @param {string | string[]} address - address(es) to validate
|
|
16
|
+
* @returns {boolean} - validation result
|
|
12
17
|
*/
|
|
13
|
-
/** @inheritdoc */
|
|
14
18
|
isValidAddress(address: string | string[]): boolean;
|
|
15
19
|
private isValidAddressRegex;
|
|
16
20
|
/**
|
|
17
|
-
*
|
|
18
|
-
*
|
|
19
|
-
* @
|
|
20
|
-
* @returns {boolean} - the validation result
|
|
21
|
+
* Validates a block ID
|
|
22
|
+
* @param {string} hash - block ID to validate
|
|
23
|
+
* @returns {boolean} - validation result
|
|
21
24
|
*/
|
|
22
|
-
/** @inheritdoc */
|
|
23
25
|
isValidBlockId(hash: string): boolean;
|
|
24
26
|
/**
|
|
25
|
-
*
|
|
26
|
-
*
|
|
27
|
-
*
|
|
28
|
-
* @param {string} pub - the public key to be validated
|
|
29
|
-
* @returns {boolean} - the validation result
|
|
27
|
+
* Validates a public key
|
|
28
|
+
* @param {string} pub - public key to validate
|
|
29
|
+
* @returns {boolean} - validation result
|
|
30
30
|
*/
|
|
31
31
|
isValidPublicKey(pub: string): boolean;
|
|
32
|
-
parseAddress: (pub: string) => Buffer;
|
|
33
32
|
/**
|
|
34
|
-
*
|
|
35
|
-
* private key
|
|
36
|
-
*
|
|
37
|
-
* The protocol key format is described in the @stacks/transactions npm package, in the
|
|
38
|
-
* createStacksPrivateKey function:
|
|
39
|
-
* https://github.com/blockstack/stacks.js/blob/master/packages/transactions/src/keys.ts#L125
|
|
40
|
-
*
|
|
41
|
-
* @param {string} prv - the private key (or extended private key) to be validated
|
|
42
|
-
* @returns {boolean} - the validation result
|
|
33
|
+
* Validates a private key
|
|
34
|
+
* @param {string} prv - private key to validate
|
|
35
|
+
* @returns {boolean} - validation result
|
|
43
36
|
*/
|
|
44
37
|
isValidPrivateKey(prv: string): boolean;
|
|
45
38
|
/**
|
|
46
|
-
*
|
|
47
|
-
*
|
|
48
|
-
* @param {string} maybe - the string to be validated
|
|
49
|
-
* @returns {boolean} - the validation result
|
|
39
|
+
* Checks if a string contains only hex characters
|
|
50
40
|
*/
|
|
51
|
-
allHexChars(
|
|
41
|
+
allHexChars(str: string): boolean;
|
|
52
42
|
/**
|
|
53
|
-
*
|
|
54
|
-
*
|
|
55
|
-
*
|
|
56
|
-
* @param {string} address - the Ethereum address to validate
|
|
57
|
-
* @returns {boolean} - true if valid Ethereum address format
|
|
43
|
+
* Creates a signature using the Flare network parameters
|
|
44
|
+
* Returns a 65-byte signature (64 bytes signature + 1 byte recovery parameter)
|
|
58
45
|
*/
|
|
59
|
-
|
|
46
|
+
createSignature(network: FlareNetwork, message: Buffer, prv: Buffer): Buffer;
|
|
60
47
|
/**
|
|
61
|
-
*
|
|
62
|
-
*
|
|
63
|
-
* @param
|
|
64
|
-
* @param
|
|
65
|
-
* @returns
|
|
48
|
+
* Verifies a signature
|
|
49
|
+
* @param messageHash - The SHA256 hash of the message (e.g., signablePayload)
|
|
50
|
+
* @param signature - The 64-byte signature (without recovery parameter)
|
|
51
|
+
* @param publicKey - The public key to verify against
|
|
52
|
+
* @returns true if signature is valid
|
|
66
53
|
*/
|
|
67
|
-
|
|
54
|
+
verifySignature(messageHash: Buffer, signature: Buffer, publicKey: Buffer): boolean;
|
|
68
55
|
/**
|
|
69
|
-
*
|
|
70
|
-
*
|
|
71
|
-
* @param {unknown} a - first value to compare
|
|
72
|
-
* @param {unknown} b - second value to compare
|
|
73
|
-
* @returns {boolean} - true if values are deeply equal
|
|
56
|
+
* Creates a new signature object
|
|
74
57
|
*/
|
|
75
|
-
|
|
76
|
-
/** @inheritdoc */
|
|
77
|
-
isValidSignature(signature: string): boolean;
|
|
78
|
-
/** @inheritdoc */
|
|
79
|
-
isValidTransactionId(txId: string): boolean;
|
|
58
|
+
createNewSig(sigHex: string): Signature;
|
|
80
59
|
/**
|
|
81
|
-
*
|
|
82
|
-
*
|
|
83
|
-
*
|
|
84
|
-
* @param
|
|
85
|
-
* @return signature
|
|
60
|
+
* Creates an empty signature with embedded address for signature slot identification.
|
|
61
|
+
* The address is embedded at position 90 (after the first 45 zero bytes).
|
|
62
|
+
* This allows the signing logic to determine which slot belongs to which address.
|
|
63
|
+
* @param addressHex The 20-byte address in hex format (40 chars, without 0x prefix)
|
|
86
64
|
*/
|
|
87
|
-
|
|
65
|
+
createEmptySigWithAddress(addressHex: string): Signature;
|
|
88
66
|
/**
|
|
89
|
-
*
|
|
90
|
-
*
|
|
91
|
-
* @param message
|
|
92
|
-
* @param signature
|
|
93
|
-
* @param publicKey - public key instead of private key for verification
|
|
94
|
-
* @return true if it's verify successful
|
|
67
|
+
* Extracts the embedded address from an empty signature.
|
|
68
|
+
* Returns the address hex string (40 chars) or empty string if not found.
|
|
95
69
|
*/
|
|
96
|
-
|
|
70
|
+
getAddressFromEmptySig(sig: string): string;
|
|
97
71
|
/**
|
|
98
|
-
*
|
|
99
|
-
* @param network
|
|
100
|
-
* @param message
|
|
101
|
-
* @param signature
|
|
102
|
-
* @return recovered public key
|
|
72
|
+
* Computes SHA256 hash
|
|
103
73
|
*/
|
|
104
|
-
recoverySignature(network: FlareNetwork, message: Buffer, signature: Buffer): Buffer;
|
|
105
74
|
sha256(buf: Uint8Array): Buffer;
|
|
106
75
|
/**
|
|
107
|
-
*
|
|
108
|
-
* It's to reuse in TransactionBuilder and TransactionBuilderFactory
|
|
109
|
-
*
|
|
110
|
-
* @param rawTransaction Transaction as hex string
|
|
76
|
+
* Validates raw transaction format
|
|
111
77
|
*/
|
|
112
78
|
validateRawTransaction(rawTransaction: string): void;
|
|
113
79
|
/**
|
|
114
|
-
*
|
|
115
|
-
*
|
|
116
|
-
* @param {DeprecatedTx} tx
|
|
117
|
-
* @param {string} blockchainId
|
|
118
|
-
* @returns true if tx is for blockchainId
|
|
80
|
+
* Checks if output is TransferableOutput type
|
|
119
81
|
*/
|
|
120
|
-
|
|
82
|
+
isTransferableOutput(output: Output): output is TransferableOutput;
|
|
121
83
|
/**
|
|
122
|
-
*
|
|
123
|
-
* Output could be EVM or PVM output.
|
|
124
|
-
* @param {DeprecatedOutput} output
|
|
125
|
-
* @returns {boolean} output has transferable output structure
|
|
84
|
+
* Maps outputs to entry format
|
|
126
85
|
*/
|
|
127
|
-
|
|
86
|
+
mapOutputToEntry(network: FlareNetwork): (Output: any) => Entry;
|
|
128
87
|
/**
|
|
129
|
-
*
|
|
130
|
-
* Output could be EVM or PVM output.
|
|
131
|
-
* @param {Output} output
|
|
132
|
-
* @returns {boolean} output is TransferableOutput
|
|
88
|
+
* Removes 0x prefix from hex string
|
|
133
89
|
*/
|
|
134
|
-
|
|
90
|
+
removeHexPrefix(hex: string): string;
|
|
135
91
|
/**
|
|
136
|
-
*
|
|
137
|
-
* @param network required to stringify addresses
|
|
138
|
-
* @return mapper function
|
|
92
|
+
* Converts output index to buffer
|
|
139
93
|
*/
|
|
140
|
-
|
|
94
|
+
outputidxNumberToBuffer(outputidx: string): Buffer;
|
|
141
95
|
/**
|
|
142
|
-
*
|
|
143
|
-
* @param network required to stringify addresses
|
|
144
|
-
* @return mapper function
|
|
96
|
+
* Converts output index buffer to number string
|
|
145
97
|
*/
|
|
146
|
-
|
|
98
|
+
outputidxBufferToNumber(outputidx: Buffer): string;
|
|
147
99
|
/**
|
|
148
|
-
*
|
|
149
|
-
* @param hex string
|
|
150
|
-
* @returns hex without 0x
|
|
100
|
+
* Helper method to convert address components to string
|
|
151
101
|
*/
|
|
152
|
-
|
|
102
|
+
addressToString: (hrp: string, prefix: string, address: Buffer) => string;
|
|
153
103
|
/**
|
|
154
|
-
*
|
|
155
|
-
* @param {string} outputidx number
|
|
156
|
-
* @return {Buffer} buffer of size 4 with that number value
|
|
104
|
+
* Decodes a base58 string with checksum to a Buffer
|
|
157
105
|
*/
|
|
158
|
-
|
|
106
|
+
cb58Decode(str: string): Buffer;
|
|
159
107
|
/**
|
|
160
|
-
*
|
|
161
|
-
* @param {Buffer} outputidx
|
|
162
|
-
* @return {string} outputidx number
|
|
108
|
+
* Validates a checksum on a Buffer and returns true if valid, false if not
|
|
163
109
|
*/
|
|
164
|
-
|
|
110
|
+
private validateChecksum;
|
|
111
|
+
/**
|
|
112
|
+
* Encodes a Buffer as a base58 string with checksum
|
|
113
|
+
*/
|
|
114
|
+
cb58Encode(bytes: Buffer): string;
|
|
115
|
+
/**
|
|
116
|
+
* Adds a checksum to a Buffer and returns the concatenated result
|
|
117
|
+
* Uses last 4 bytes of SHA256 hash as checksum (matching avaxp behavior)
|
|
118
|
+
*/
|
|
119
|
+
addChecksum(buff: Buffer | Uint8Array): Uint8Array;
|
|
165
120
|
/**
|
|
166
|
-
*
|
|
167
|
-
* @param
|
|
168
|
-
* @returns
|
|
121
|
+
* Parse an address string into a Buffer
|
|
122
|
+
* @param address - The address to parse
|
|
123
|
+
* @returns Buffer containing the parsed address
|
|
169
124
|
*/
|
|
170
|
-
|
|
125
|
+
parseAddress: (address: string) => Buffer;
|
|
126
|
+
stringToAddress: (address: string, hrp?: string) => Buffer;
|
|
127
|
+
flareIdString(value: string): Id;
|
|
171
128
|
/**
|
|
172
|
-
*
|
|
173
|
-
* @param
|
|
174
|
-
* @param
|
|
175
|
-
* @
|
|
176
|
-
* @returns {string} Address string
|
|
129
|
+
* Recover public key from signature
|
|
130
|
+
* @param messageHash - The SHA256 hash of the message (e.g., signablePayload)
|
|
131
|
+
* @param signature - 65-byte signature (64 bytes signature + 1 byte recovery parameter)
|
|
132
|
+
* @return recovered public key
|
|
177
133
|
*/
|
|
178
|
-
|
|
134
|
+
recoverySignature(messageHash: Buffer, signature: Buffer): Buffer;
|
|
179
135
|
/**
|
|
180
|
-
*
|
|
181
|
-
*
|
|
182
|
-
* @param {
|
|
183
|
-
* @
|
|
136
|
+
* Check if tx is for the blockchainId
|
|
137
|
+
*
|
|
138
|
+
* @param {Tx} tx
|
|
139
|
+
* @param {string} blockchainId - blockchain ID in hex format
|
|
140
|
+
* @returns true if tx is for blockchainId
|
|
184
141
|
*/
|
|
185
|
-
|
|
142
|
+
isTransactionOf(tx: Tx, blockchainId: string): boolean;
|
|
186
143
|
/**
|
|
187
|
-
* Convert
|
|
188
|
-
* @param
|
|
189
|
-
* @
|
|
144
|
+
* Convert FlareJS native Utxo to DecodedUtxoObj for internal use
|
|
145
|
+
* @param utxo - FlareJS Utxo object
|
|
146
|
+
* @param network - Flare network configuration
|
|
147
|
+
* @returns DecodedUtxoObj compatible with existing methods
|
|
190
148
|
*/
|
|
191
|
-
|
|
149
|
+
utxoToDecoded(utxo: Utxo, network: FlareNetwork): DecodedUtxoObj;
|
|
192
150
|
/**
|
|
193
|
-
*
|
|
194
|
-
*
|
|
195
|
-
* @param
|
|
196
|
-
* @returns
|
|
151
|
+
* Convert array of FlareJS Utxos to DecodedUtxoObj array
|
|
152
|
+
* @param utxos - Array of FlareJS Utxo objects
|
|
153
|
+
* @param network - Flare network configuration
|
|
154
|
+
* @returns Array of DecodedUtxoObj
|
|
197
155
|
*/
|
|
198
|
-
|
|
156
|
+
utxosToDecoded(utxos: Utxo[], network: FlareNetwork): DecodedUtxoObj[];
|
|
199
157
|
/**
|
|
200
|
-
*
|
|
201
|
-
*
|
|
202
|
-
* @
|
|
158
|
+
* Convert DecodedUtxoObj to native FlareJS Utxo object
|
|
159
|
+
* This is the reverse of utxoToDecoded
|
|
160
|
+
* @param decoded - DecodedUtxoObj to convert
|
|
161
|
+
* @param assetId - Asset ID as cb58 encoded string
|
|
162
|
+
* @returns Native FlareJS Utxo object
|
|
203
163
|
*/
|
|
204
|
-
|
|
164
|
+
decodedToUtxo(decoded: DecodedUtxoObj, assetId: string): Utxo;
|
|
205
165
|
/**
|
|
206
|
-
*
|
|
207
|
-
* @param
|
|
208
|
-
* @param
|
|
209
|
-
* @returns
|
|
166
|
+
* Convert array of DecodedUtxoObj to native FlareJS Utxo objects
|
|
167
|
+
* @param decodedUtxos - Array of DecodedUtxoObj
|
|
168
|
+
* @param assetId - Asset ID as cb58 encoded string
|
|
169
|
+
* @returns Array of native FlareJS Utxo objects
|
|
210
170
|
*/
|
|
211
|
-
|
|
171
|
+
decodedToUtxos(decodedUtxos: DecodedUtxoObj[], assetId: string): Utxo[];
|
|
212
172
|
}
|
|
213
173
|
declare const utils: Utils;
|
|
214
174
|
export default utils;
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"utils.d.ts","sourceRoot":"","sources":["../../../src/lib/utils.ts"],"names":[],"mappings":"AAAA,OAAO,
|
|
1
|
+
{"version":3,"file":"utils.d.ts","sourceRoot":"","sources":["../../../src/lib/utils.ts"],"names":[],"mappings":"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"}
|