@atomiqlabs/chain-evm 1.0.0-dev.75 → 1.0.0-dev.77
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/LICENSE +201 -201
- package/dist/chains/botanix/BotanixChainType.d.ts +13 -13
- package/dist/chains/botanix/BotanixChainType.js +2 -2
- package/dist/chains/botanix/BotanixInitializer.d.ts +30 -30
- package/dist/chains/botanix/BotanixInitializer.js +122 -122
- package/dist/chains/citrea/CitreaBtcRelay.d.ts +21 -21
- package/dist/chains/citrea/CitreaBtcRelay.js +43 -43
- package/dist/chains/citrea/CitreaChainType.d.ts +13 -13
- package/dist/chains/citrea/CitreaChainType.js +2 -2
- package/dist/chains/citrea/CitreaFees.d.ts +29 -29
- package/dist/chains/citrea/CitreaFees.js +67 -67
- package/dist/chains/citrea/CitreaInitializer.d.ts +30 -30
- package/dist/chains/citrea/CitreaInitializer.js +129 -129
- package/dist/chains/citrea/CitreaSpvVaultContract.d.ts +15 -15
- package/dist/chains/citrea/CitreaSpvVaultContract.js +74 -74
- package/dist/chains/citrea/CitreaSwapContract.d.ts +22 -22
- package/dist/chains/citrea/CitreaSwapContract.js +96 -96
- package/dist/chains/citrea/CitreaTokens.d.ts +9 -9
- package/dist/chains/citrea/CitreaTokens.js +20 -20
- package/dist/evm/btcrelay/BtcRelayAbi.d.ts +198 -198
- package/dist/evm/btcrelay/BtcRelayAbi.js +261 -261
- package/dist/evm/btcrelay/BtcRelayTypechain.d.ts +172 -172
- package/dist/evm/btcrelay/BtcRelayTypechain.js +2 -2
- package/dist/evm/btcrelay/EVMBtcRelay.d.ts +197 -197
- package/dist/evm/btcrelay/EVMBtcRelay.js +435 -435
- package/dist/evm/btcrelay/headers/EVMBtcHeader.d.ts +33 -33
- package/dist/evm/btcrelay/headers/EVMBtcHeader.js +84 -84
- package/dist/evm/btcrelay/headers/EVMBtcStoredHeader.d.ts +56 -56
- package/dist/evm/btcrelay/headers/EVMBtcStoredHeader.js +123 -123
- package/dist/evm/chain/EVMChainInterface.d.ts +51 -51
- package/dist/evm/chain/EVMChainInterface.js +89 -89
- package/dist/evm/chain/EVMModule.d.ts +9 -9
- package/dist/evm/chain/EVMModule.js +13 -13
- package/dist/evm/chain/modules/ERC20Abi.d.ts +168 -168
- package/dist/evm/chain/modules/ERC20Abi.js +225 -225
- package/dist/evm/chain/modules/EVMAddresses.d.ts +10 -10
- package/dist/evm/chain/modules/EVMAddresses.js +30 -30
- package/dist/evm/chain/modules/EVMBlocks.d.ts +20 -20
- package/dist/evm/chain/modules/EVMBlocks.js +64 -64
- package/dist/evm/chain/modules/EVMEvents.d.ts +36 -36
- package/dist/evm/chain/modules/EVMEvents.js +122 -122
- package/dist/evm/chain/modules/EVMFees.d.ts +36 -36
- package/dist/evm/chain/modules/EVMFees.js +74 -74
- package/dist/evm/chain/modules/EVMSignatures.d.ts +29 -29
- package/dist/evm/chain/modules/EVMSignatures.js +68 -68
- package/dist/evm/chain/modules/EVMTokens.d.ts +70 -70
- package/dist/evm/chain/modules/EVMTokens.js +142 -142
- package/dist/evm/chain/modules/EVMTransactions.d.ts +94 -94
- package/dist/evm/chain/modules/EVMTransactions.js +286 -286
- package/dist/evm/contract/EVMContractBase.d.ts +22 -22
- package/dist/evm/contract/EVMContractBase.js +34 -34
- package/dist/evm/contract/EVMContractModule.d.ts +8 -8
- package/dist/evm/contract/EVMContractModule.js +11 -11
- package/dist/evm/contract/modules/EVMContractEvents.d.ts +42 -42
- package/dist/evm/contract/modules/EVMContractEvents.js +75 -75
- package/dist/evm/events/EVMChainEvents.d.ts +22 -22
- package/dist/evm/events/EVMChainEvents.js +69 -69
- package/dist/evm/events/EVMChainEventsBrowser.d.ts +102 -102
- package/dist/evm/events/EVMChainEventsBrowser.js +413 -404
- package/dist/evm/providers/JsonRpcProviderWithRetries.d.ts +15 -15
- package/dist/evm/providers/JsonRpcProviderWithRetries.js +19 -19
- package/dist/evm/providers/ReconnectingWebSocketProvider.d.ts +22 -22
- package/dist/evm/providers/ReconnectingWebSocketProvider.js +87 -87
- package/dist/evm/providers/SocketProvider.d.ts +111 -111
- package/dist/evm/providers/SocketProvider.js +334 -334
- package/dist/evm/providers/WebSocketProviderWithRetries.d.ts +17 -17
- package/dist/evm/providers/WebSocketProviderWithRetries.js +19 -19
- package/dist/evm/spv_swap/EVMSpvVaultContract.d.ts +79 -79
- package/dist/evm/spv_swap/EVMSpvVaultContract.js +482 -482
- package/dist/evm/spv_swap/EVMSpvVaultData.d.ts +39 -39
- package/dist/evm/spv_swap/EVMSpvVaultData.js +0 -180
- package/dist/evm/spv_swap/EVMSpvWithdrawalData.d.ts +19 -19
- package/dist/evm/spv_swap/EVMSpvWithdrawalData.js +55 -55
- package/dist/evm/spv_swap/SpvVaultContractAbi.d.ts +91 -91
- package/dist/evm/spv_swap/SpvVaultContractAbi.js +849 -849
- package/dist/evm/spv_swap/SpvVaultContractTypechain.d.ts +450 -450
- package/dist/evm/spv_swap/SpvVaultContractTypechain.js +2 -2
- package/dist/evm/swaps/EVMSwapContract.d.ts +193 -193
- package/dist/evm/swaps/EVMSwapContract.js +378 -378
- package/dist/evm/swaps/EVMSwapData.d.ts +66 -66
- package/dist/evm/swaps/EVMSwapData.js +260 -260
- package/dist/evm/swaps/EVMSwapModule.d.ts +9 -9
- package/dist/evm/swaps/EVMSwapModule.js +11 -11
- package/dist/evm/swaps/EscrowManagerAbi.d.ts +120 -120
- package/dist/evm/swaps/EscrowManagerAbi.js +985 -985
- package/dist/evm/swaps/EscrowManagerTypechain.d.ts +475 -475
- package/dist/evm/swaps/EscrowManagerTypechain.js +2 -2
- package/dist/evm/swaps/handlers/IHandler.d.ts +13 -13
- package/dist/evm/swaps/handlers/IHandler.js +2 -2
- package/dist/evm/swaps/handlers/claim/ClaimHandlers.d.ts +10 -10
- package/dist/evm/swaps/handlers/claim/ClaimHandlers.js +13 -13
- package/dist/evm/swaps/handlers/claim/HashlockClaimHandler.d.ts +20 -20
- package/dist/evm/swaps/handlers/claim/HashlockClaimHandler.js +39 -39
- package/dist/evm/swaps/handlers/claim/btc/BitcoinNoncedOutputClaimHandler.d.ts +24 -24
- package/dist/evm/swaps/handlers/claim/btc/BitcoinNoncedOutputClaimHandler.js +59 -59
- package/dist/evm/swaps/handlers/claim/btc/BitcoinOutputClaimHandler.d.ts +25 -25
- package/dist/evm/swaps/handlers/claim/btc/BitcoinOutputClaimHandler.js +51 -51
- package/dist/evm/swaps/handlers/claim/btc/BitcoinTxIdClaimHandler.d.ts +21 -21
- package/dist/evm/swaps/handlers/claim/btc/BitcoinTxIdClaimHandler.js +28 -28
- package/dist/evm/swaps/handlers/claim/btc/IBitcoinClaimHandler.d.ts +48 -48
- package/dist/evm/swaps/handlers/claim/btc/IBitcoinClaimHandler.js +63 -63
- package/dist/evm/swaps/handlers/refund/TimelockRefundHandler.d.ts +17 -17
- package/dist/evm/swaps/handlers/refund/TimelockRefundHandler.js +28 -28
- package/dist/evm/swaps/modules/EVMLpVault.d.ts +69 -69
- package/dist/evm/swaps/modules/EVMLpVault.js +134 -134
- package/dist/evm/swaps/modules/EVMSwapClaim.d.ts +54 -54
- package/dist/evm/swaps/modules/EVMSwapClaim.js +137 -137
- package/dist/evm/swaps/modules/EVMSwapInit.d.ts +88 -88
- package/dist/evm/swaps/modules/EVMSwapInit.js +274 -274
- package/dist/evm/swaps/modules/EVMSwapRefund.d.ts +62 -62
- package/dist/evm/swaps/modules/EVMSwapRefund.js +167 -167
- package/dist/evm/typechain/common.d.ts +50 -50
- package/dist/evm/typechain/common.js +2 -2
- package/dist/evm/wallet/EVMBrowserSigner.d.ts +5 -5
- package/dist/evm/wallet/EVMBrowserSigner.js +11 -11
- package/dist/evm/wallet/EVMPersistentSigner.d.ts +29 -29
- package/dist/evm/wallet/EVMPersistentSigner.js +222 -222
- package/dist/evm/wallet/EVMSigner.d.ts +11 -11
- package/dist/evm/wallet/EVMSigner.js +24 -24
- package/dist/index.d.ts +44 -44
- package/dist/index.js +60 -60
- package/dist/utils/Utils.d.ts +17 -17
- package/dist/utils/Utils.js +81 -81
- package/package.json +39 -39
- package/src/chains/botanix/BotanixChainType.ts +28 -28
- package/src/chains/botanix/BotanixInitializer.ts +171 -171
- package/src/chains/citrea/CitreaBtcRelay.ts +57 -57
- package/src/chains/citrea/CitreaChainType.ts +28 -28
- package/src/chains/citrea/CitreaFees.ts +77 -77
- package/src/chains/citrea/CitreaInitializer.ts +178 -178
- package/src/chains/citrea/CitreaSpvVaultContract.ts +75 -75
- package/src/chains/citrea/CitreaSwapContract.ts +102 -102
- package/src/chains/citrea/CitreaTokens.ts +21 -21
- package/src/evm/btcrelay/BtcRelayAbi.ts +258 -258
- package/src/evm/btcrelay/BtcRelayTypechain.ts +371 -371
- package/src/evm/btcrelay/EVMBtcRelay.ts +537 -537
- package/src/evm/btcrelay/headers/EVMBtcHeader.ts +109 -109
- package/src/evm/btcrelay/headers/EVMBtcStoredHeader.ts +152 -152
- package/src/evm/chain/EVMChainInterface.ts +155 -155
- package/src/evm/chain/EVMModule.ts +21 -21
- package/src/evm/chain/modules/ERC20Abi.ts +222 -222
- package/src/evm/chain/modules/EVMAddresses.ts +28 -28
- package/src/evm/chain/modules/EVMBlocks.ts +75 -75
- package/src/evm/chain/modules/EVMEvents.ts +139 -139
- package/src/evm/chain/modules/EVMFees.ts +104 -104
- package/src/evm/chain/modules/EVMSignatures.ts +76 -76
- package/src/evm/chain/modules/EVMTokens.ts +155 -155
- package/src/evm/chain/modules/EVMTransactions.ts +325 -325
- package/src/evm/contract/EVMContractBase.ts +63 -63
- package/src/evm/contract/EVMContractModule.ts +16 -16
- package/src/evm/contract/modules/EVMContractEvents.ts +102 -102
- package/src/evm/events/EVMChainEvents.ts +82 -82
- package/src/evm/events/EVMChainEventsBrowser.ts +534 -525
- package/src/evm/providers/JsonRpcProviderWithRetries.ts +24 -24
- package/src/evm/providers/ReconnectingWebSocketProvider.ts +101 -101
- package/src/evm/providers/SocketProvider.ts +368 -368
- package/src/evm/providers/WebSocketProviderWithRetries.ts +27 -27
- package/src/evm/spv_swap/EVMSpvVaultContract.ts +615 -615
- package/src/evm/spv_swap/EVMSpvVaultData.ts +224 -224
- package/src/evm/spv_swap/EVMSpvWithdrawalData.ts +70 -70
- package/src/evm/spv_swap/SpvVaultContractAbi.ts +846 -846
- package/src/evm/spv_swap/SpvVaultContractTypechain.ts +685 -685
- package/src/evm/swaps/EVMSwapContract.ts +600 -600
- package/src/evm/swaps/EVMSwapData.ts +378 -378
- package/src/evm/swaps/EVMSwapModule.ts +16 -16
- package/src/evm/swaps/EscrowManagerAbi.ts +982 -982
- package/src/evm/swaps/EscrowManagerTypechain.ts +723 -723
- package/src/evm/swaps/handlers/IHandler.ts +17 -17
- package/src/evm/swaps/handlers/claim/ClaimHandlers.ts +20 -20
- package/src/evm/swaps/handlers/claim/HashlockClaimHandler.ts +46 -46
- package/src/evm/swaps/handlers/claim/btc/BitcoinNoncedOutputClaimHandler.ts +82 -82
- package/src/evm/swaps/handlers/claim/btc/BitcoinOutputClaimHandler.ts +76 -76
- package/src/evm/swaps/handlers/claim/btc/BitcoinTxIdClaimHandler.ts +46 -46
- package/src/evm/swaps/handlers/claim/btc/IBitcoinClaimHandler.ts +115 -115
- package/src/evm/swaps/handlers/refund/TimelockRefundHandler.ts +37 -37
- package/src/evm/swaps/modules/EVMLpVault.ts +154 -154
- package/src/evm/swaps/modules/EVMSwapClaim.ts +172 -172
- package/src/evm/swaps/modules/EVMSwapInit.ts +328 -328
- package/src/evm/swaps/modules/EVMSwapRefund.ts +229 -229
- package/src/evm/typechain/common.ts +131 -131
- package/src/evm/wallet/EVMBrowserSigner.ts +11 -11
- package/src/evm/wallet/EVMPersistentSigner.ts +298 -298
- package/src/evm/wallet/EVMSigner.ts +31 -31
- package/src/index.ts +53 -53
- package/src/utils/Utils.ts +92 -92
|
@@ -1,33 +1,33 @@
|
|
|
1
|
-
/// <reference types="node" />
|
|
2
|
-
/// <reference types="node" />
|
|
3
|
-
import { BtcHeader } from "@atomiqlabs/base";
|
|
4
|
-
import { Buffer } from "buffer";
|
|
5
|
-
export type EVMBtcHeaderType = {
|
|
6
|
-
version: number;
|
|
7
|
-
previousBlockhash?: Buffer;
|
|
8
|
-
merkleRoot: Buffer;
|
|
9
|
-
timestamp: number;
|
|
10
|
-
nbits: number;
|
|
11
|
-
nonce: number;
|
|
12
|
-
hash?: Buffer;
|
|
13
|
-
};
|
|
14
|
-
export declare class EVMBtcHeader implements BtcHeader {
|
|
15
|
-
version: number;
|
|
16
|
-
previousBlockhash: Buffer;
|
|
17
|
-
merkleRoot: Buffer;
|
|
18
|
-
timestamp: number;
|
|
19
|
-
nbits: number;
|
|
20
|
-
nonce: number;
|
|
21
|
-
hash?: Buffer;
|
|
22
|
-
constructor(data: EVMBtcHeaderType);
|
|
23
|
-
getMerkleRoot(): Buffer;
|
|
24
|
-
getNbits(): number;
|
|
25
|
-
getNonce(): number;
|
|
26
|
-
getReversedPrevBlockhash(): Buffer;
|
|
27
|
-
getTimestamp(): number;
|
|
28
|
-
getVersion(): number;
|
|
29
|
-
getHash(): Buffer;
|
|
30
|
-
serializeCompact(): Buffer;
|
|
31
|
-
serialize(): Buffer;
|
|
32
|
-
static deserialize(rawData: Buffer): EVMBtcHeader;
|
|
33
|
-
}
|
|
1
|
+
/// <reference types="node" />
|
|
2
|
+
/// <reference types="node" />
|
|
3
|
+
import { BtcHeader } from "@atomiqlabs/base";
|
|
4
|
+
import { Buffer } from "buffer";
|
|
5
|
+
export type EVMBtcHeaderType = {
|
|
6
|
+
version: number;
|
|
7
|
+
previousBlockhash?: Buffer;
|
|
8
|
+
merkleRoot: Buffer;
|
|
9
|
+
timestamp: number;
|
|
10
|
+
nbits: number;
|
|
11
|
+
nonce: number;
|
|
12
|
+
hash?: Buffer;
|
|
13
|
+
};
|
|
14
|
+
export declare class EVMBtcHeader implements BtcHeader {
|
|
15
|
+
version: number;
|
|
16
|
+
previousBlockhash: Buffer;
|
|
17
|
+
merkleRoot: Buffer;
|
|
18
|
+
timestamp: number;
|
|
19
|
+
nbits: number;
|
|
20
|
+
nonce: number;
|
|
21
|
+
hash?: Buffer;
|
|
22
|
+
constructor(data: EVMBtcHeaderType);
|
|
23
|
+
getMerkleRoot(): Buffer;
|
|
24
|
+
getNbits(): number;
|
|
25
|
+
getNonce(): number;
|
|
26
|
+
getReversedPrevBlockhash(): Buffer;
|
|
27
|
+
getTimestamp(): number;
|
|
28
|
+
getVersion(): number;
|
|
29
|
+
getHash(): Buffer;
|
|
30
|
+
serializeCompact(): Buffer;
|
|
31
|
+
serialize(): Buffer;
|
|
32
|
+
static deserialize(rawData: Buffer): EVMBtcHeader;
|
|
33
|
+
}
|
|
@@ -1,84 +1,84 @@
|
|
|
1
|
-
"use strict";
|
|
2
|
-
Object.defineProperty(exports, "__esModule", { value: true });
|
|
3
|
-
exports.EVMBtcHeader = void 0;
|
|
4
|
-
const buffer_1 = require("buffer");
|
|
5
|
-
const sha2_1 = require("@noble/hashes/sha2");
|
|
6
|
-
class EVMBtcHeader {
|
|
7
|
-
constructor(data) {
|
|
8
|
-
this.version = data.version;
|
|
9
|
-
this.previousBlockhash = data.previousBlockhash;
|
|
10
|
-
this.merkleRoot = data.merkleRoot;
|
|
11
|
-
this.timestamp = data.timestamp;
|
|
12
|
-
this.nbits = data.nbits;
|
|
13
|
-
this.nonce = data.nonce;
|
|
14
|
-
this.hash = data.hash;
|
|
15
|
-
}
|
|
16
|
-
getMerkleRoot() {
|
|
17
|
-
return this.merkleRoot;
|
|
18
|
-
}
|
|
19
|
-
getNbits() {
|
|
20
|
-
return this.nbits;
|
|
21
|
-
}
|
|
22
|
-
getNonce() {
|
|
23
|
-
return this.nonce;
|
|
24
|
-
}
|
|
25
|
-
getReversedPrevBlockhash() {
|
|
26
|
-
return this.previousBlockhash;
|
|
27
|
-
}
|
|
28
|
-
getTimestamp() {
|
|
29
|
-
return this.timestamp;
|
|
30
|
-
}
|
|
31
|
-
getVersion() {
|
|
32
|
-
return this.version;
|
|
33
|
-
}
|
|
34
|
-
getHash() {
|
|
35
|
-
return buffer_1.Buffer.from((0, sha2_1.sha256)((0, sha2_1.sha256)(this.serialize())));
|
|
36
|
-
}
|
|
37
|
-
serializeCompact() {
|
|
38
|
-
const buffer = buffer_1.Buffer.alloc(48);
|
|
39
|
-
buffer.writeUInt32LE(this.version, 0);
|
|
40
|
-
this.merkleRoot.copy(buffer, 4);
|
|
41
|
-
buffer.writeUInt32LE(this.timestamp, 36);
|
|
42
|
-
buffer.writeUInt32LE(this.nbits, 40);
|
|
43
|
-
buffer.writeUInt32LE(this.nonce, 44);
|
|
44
|
-
return buffer;
|
|
45
|
-
}
|
|
46
|
-
serialize() {
|
|
47
|
-
const buffer = buffer_1.Buffer.alloc(80);
|
|
48
|
-
buffer.writeUInt32LE(this.version, 0);
|
|
49
|
-
this.previousBlockhash.copy(buffer, 4);
|
|
50
|
-
this.merkleRoot.copy(buffer, 36);
|
|
51
|
-
buffer.writeUInt32LE(this.timestamp, 68);
|
|
52
|
-
buffer.writeUInt32LE(this.nbits, 72);
|
|
53
|
-
buffer.writeUInt32LE(this.nonce, 76);
|
|
54
|
-
return buffer;
|
|
55
|
-
}
|
|
56
|
-
static deserialize(rawData) {
|
|
57
|
-
if (rawData.length === 80) {
|
|
58
|
-
//Regular blockheader
|
|
59
|
-
const version = rawData.readUInt32LE(0);
|
|
60
|
-
const previousBlockhash = buffer_1.Buffer.alloc(32);
|
|
61
|
-
rawData.copy(previousBlockhash, 0, 4, 36);
|
|
62
|
-
const merkleRoot = buffer_1.Buffer.alloc(32);
|
|
63
|
-
rawData.copy(merkleRoot, 0, 36, 68);
|
|
64
|
-
const timestamp = rawData.readUInt32LE(68);
|
|
65
|
-
const nbits = rawData.readUInt32LE(72);
|
|
66
|
-
const nonce = rawData.readUInt32LE(76);
|
|
67
|
-
return new EVMBtcHeader({ version, previousBlockhash, merkleRoot, timestamp, nbits, nonce });
|
|
68
|
-
}
|
|
69
|
-
else if (rawData.length === 48) {
|
|
70
|
-
//Compact blockheader
|
|
71
|
-
const version = rawData.readUInt32LE(0);
|
|
72
|
-
const merkleRoot = buffer_1.Buffer.alloc(32);
|
|
73
|
-
rawData.copy(merkleRoot, 0, 4, 36);
|
|
74
|
-
const timestamp = rawData.readUInt32LE(36);
|
|
75
|
-
const nbits = rawData.readUInt32LE(40);
|
|
76
|
-
const nonce = rawData.readUInt32LE(44);
|
|
77
|
-
return new EVMBtcHeader({ version, merkleRoot, timestamp, nbits, nonce });
|
|
78
|
-
}
|
|
79
|
-
else {
|
|
80
|
-
throw new Error("Invalid byte length");
|
|
81
|
-
}
|
|
82
|
-
}
|
|
83
|
-
}
|
|
84
|
-
exports.EVMBtcHeader = EVMBtcHeader;
|
|
1
|
+
"use strict";
|
|
2
|
+
Object.defineProperty(exports, "__esModule", { value: true });
|
|
3
|
+
exports.EVMBtcHeader = void 0;
|
|
4
|
+
const buffer_1 = require("buffer");
|
|
5
|
+
const sha2_1 = require("@noble/hashes/sha2");
|
|
6
|
+
class EVMBtcHeader {
|
|
7
|
+
constructor(data) {
|
|
8
|
+
this.version = data.version;
|
|
9
|
+
this.previousBlockhash = data.previousBlockhash;
|
|
10
|
+
this.merkleRoot = data.merkleRoot;
|
|
11
|
+
this.timestamp = data.timestamp;
|
|
12
|
+
this.nbits = data.nbits;
|
|
13
|
+
this.nonce = data.nonce;
|
|
14
|
+
this.hash = data.hash;
|
|
15
|
+
}
|
|
16
|
+
getMerkleRoot() {
|
|
17
|
+
return this.merkleRoot;
|
|
18
|
+
}
|
|
19
|
+
getNbits() {
|
|
20
|
+
return this.nbits;
|
|
21
|
+
}
|
|
22
|
+
getNonce() {
|
|
23
|
+
return this.nonce;
|
|
24
|
+
}
|
|
25
|
+
getReversedPrevBlockhash() {
|
|
26
|
+
return this.previousBlockhash;
|
|
27
|
+
}
|
|
28
|
+
getTimestamp() {
|
|
29
|
+
return this.timestamp;
|
|
30
|
+
}
|
|
31
|
+
getVersion() {
|
|
32
|
+
return this.version;
|
|
33
|
+
}
|
|
34
|
+
getHash() {
|
|
35
|
+
return buffer_1.Buffer.from((0, sha2_1.sha256)((0, sha2_1.sha256)(this.serialize())));
|
|
36
|
+
}
|
|
37
|
+
serializeCompact() {
|
|
38
|
+
const buffer = buffer_1.Buffer.alloc(48);
|
|
39
|
+
buffer.writeUInt32LE(this.version, 0);
|
|
40
|
+
this.merkleRoot.copy(buffer, 4);
|
|
41
|
+
buffer.writeUInt32LE(this.timestamp, 36);
|
|
42
|
+
buffer.writeUInt32LE(this.nbits, 40);
|
|
43
|
+
buffer.writeUInt32LE(this.nonce, 44);
|
|
44
|
+
return buffer;
|
|
45
|
+
}
|
|
46
|
+
serialize() {
|
|
47
|
+
const buffer = buffer_1.Buffer.alloc(80);
|
|
48
|
+
buffer.writeUInt32LE(this.version, 0);
|
|
49
|
+
this.previousBlockhash.copy(buffer, 4);
|
|
50
|
+
this.merkleRoot.copy(buffer, 36);
|
|
51
|
+
buffer.writeUInt32LE(this.timestamp, 68);
|
|
52
|
+
buffer.writeUInt32LE(this.nbits, 72);
|
|
53
|
+
buffer.writeUInt32LE(this.nonce, 76);
|
|
54
|
+
return buffer;
|
|
55
|
+
}
|
|
56
|
+
static deserialize(rawData) {
|
|
57
|
+
if (rawData.length === 80) {
|
|
58
|
+
//Regular blockheader
|
|
59
|
+
const version = rawData.readUInt32LE(0);
|
|
60
|
+
const previousBlockhash = buffer_1.Buffer.alloc(32);
|
|
61
|
+
rawData.copy(previousBlockhash, 0, 4, 36);
|
|
62
|
+
const merkleRoot = buffer_1.Buffer.alloc(32);
|
|
63
|
+
rawData.copy(merkleRoot, 0, 36, 68);
|
|
64
|
+
const timestamp = rawData.readUInt32LE(68);
|
|
65
|
+
const nbits = rawData.readUInt32LE(72);
|
|
66
|
+
const nonce = rawData.readUInt32LE(76);
|
|
67
|
+
return new EVMBtcHeader({ version, previousBlockhash, merkleRoot, timestamp, nbits, nonce });
|
|
68
|
+
}
|
|
69
|
+
else if (rawData.length === 48) {
|
|
70
|
+
//Compact blockheader
|
|
71
|
+
const version = rawData.readUInt32LE(0);
|
|
72
|
+
const merkleRoot = buffer_1.Buffer.alloc(32);
|
|
73
|
+
rawData.copy(merkleRoot, 0, 4, 36);
|
|
74
|
+
const timestamp = rawData.readUInt32LE(36);
|
|
75
|
+
const nbits = rawData.readUInt32LE(40);
|
|
76
|
+
const nonce = rawData.readUInt32LE(44);
|
|
77
|
+
return new EVMBtcHeader({ version, merkleRoot, timestamp, nbits, nonce });
|
|
78
|
+
}
|
|
79
|
+
else {
|
|
80
|
+
throw new Error("Invalid byte length");
|
|
81
|
+
}
|
|
82
|
+
}
|
|
83
|
+
}
|
|
84
|
+
exports.EVMBtcHeader = EVMBtcHeader;
|
|
@@ -1,56 +1,56 @@
|
|
|
1
|
-
/// <reference types="node" />
|
|
2
|
-
/// <reference types="node" />
|
|
3
|
-
import { BtcStoredHeader } from "@atomiqlabs/base";
|
|
4
|
-
import { EVMBtcHeader, EVMBtcHeaderType } from "./EVMBtcHeader";
|
|
5
|
-
import { Buffer } from "buffer";
|
|
6
|
-
export type StarknetBtcStoredHeaderType = {
|
|
7
|
-
blockheader: EVMBtcHeader | EVMBtcHeaderType;
|
|
8
|
-
blockHash: Buffer;
|
|
9
|
-
chainWork: bigint;
|
|
10
|
-
blockHeight: number;
|
|
11
|
-
lastDiffAdjustment: number;
|
|
12
|
-
prevBlockTimestamps: number[];
|
|
13
|
-
};
|
|
14
|
-
export declare class EVMBtcStoredHeader implements BtcStoredHeader<EVMBtcHeader> {
|
|
15
|
-
blockheader: EVMBtcHeader;
|
|
16
|
-
blockHash: Buffer;
|
|
17
|
-
chainWork: bigint;
|
|
18
|
-
blockHeight: number;
|
|
19
|
-
lastDiffAdjustment: number;
|
|
20
|
-
prevBlockTimestamps: number[];
|
|
21
|
-
constructor(obj: StarknetBtcStoredHeaderType);
|
|
22
|
-
getBlockheight(): number;
|
|
23
|
-
getChainWork(): Buffer;
|
|
24
|
-
getHeader(): EVMBtcHeader;
|
|
25
|
-
getLastDiffAdjustment(): number;
|
|
26
|
-
getPrevBlockTimestamps(): number[];
|
|
27
|
-
getBlockHash(): Buffer;
|
|
28
|
-
/**
|
|
29
|
-
* Computes prevBlockTimestamps for a next block, shifting the old block timestamps to the left & appending
|
|
30
|
-
* this block's timestamp to the end
|
|
31
|
-
*
|
|
32
|
-
* @private
|
|
33
|
-
*/
|
|
34
|
-
private computeNextBlockTimestamps;
|
|
35
|
-
/**
|
|
36
|
-
* Computes total chain work after a new header with "nbits" is added to the chain
|
|
37
|
-
*
|
|
38
|
-
* @param nbits
|
|
39
|
-
* @private
|
|
40
|
-
*/
|
|
41
|
-
private computeNextChainWork;
|
|
42
|
-
/**
|
|
43
|
-
* Computes lastDiffAdjustment, this changes only once every DIFF_ADJUSTMENT_PERIOD blocks
|
|
44
|
-
*
|
|
45
|
-
* @param headerTimestamp
|
|
46
|
-
* @private
|
|
47
|
-
*/
|
|
48
|
-
private computeNextLastDiffAdjustment;
|
|
49
|
-
computeNext(header: EVMBtcHeader): EVMBtcStoredHeader;
|
|
50
|
-
getCommitHash(): string;
|
|
51
|
-
serialize(): Buffer;
|
|
52
|
-
serializeToStruct(): {
|
|
53
|
-
data: [string, string, string, string, string];
|
|
54
|
-
};
|
|
55
|
-
static deserialize(data: Buffer): EVMBtcStoredHeader;
|
|
56
|
-
}
|
|
1
|
+
/// <reference types="node" />
|
|
2
|
+
/// <reference types="node" />
|
|
3
|
+
import { BtcStoredHeader } from "@atomiqlabs/base";
|
|
4
|
+
import { EVMBtcHeader, EVMBtcHeaderType } from "./EVMBtcHeader";
|
|
5
|
+
import { Buffer } from "buffer";
|
|
6
|
+
export type StarknetBtcStoredHeaderType = {
|
|
7
|
+
blockheader: EVMBtcHeader | EVMBtcHeaderType;
|
|
8
|
+
blockHash: Buffer;
|
|
9
|
+
chainWork: bigint;
|
|
10
|
+
blockHeight: number;
|
|
11
|
+
lastDiffAdjustment: number;
|
|
12
|
+
prevBlockTimestamps: number[];
|
|
13
|
+
};
|
|
14
|
+
export declare class EVMBtcStoredHeader implements BtcStoredHeader<EVMBtcHeader> {
|
|
15
|
+
blockheader: EVMBtcHeader;
|
|
16
|
+
blockHash: Buffer;
|
|
17
|
+
chainWork: bigint;
|
|
18
|
+
blockHeight: number;
|
|
19
|
+
lastDiffAdjustment: number;
|
|
20
|
+
prevBlockTimestamps: number[];
|
|
21
|
+
constructor(obj: StarknetBtcStoredHeaderType);
|
|
22
|
+
getBlockheight(): number;
|
|
23
|
+
getChainWork(): Buffer;
|
|
24
|
+
getHeader(): EVMBtcHeader;
|
|
25
|
+
getLastDiffAdjustment(): number;
|
|
26
|
+
getPrevBlockTimestamps(): number[];
|
|
27
|
+
getBlockHash(): Buffer;
|
|
28
|
+
/**
|
|
29
|
+
* Computes prevBlockTimestamps for a next block, shifting the old block timestamps to the left & appending
|
|
30
|
+
* this block's timestamp to the end
|
|
31
|
+
*
|
|
32
|
+
* @private
|
|
33
|
+
*/
|
|
34
|
+
private computeNextBlockTimestamps;
|
|
35
|
+
/**
|
|
36
|
+
* Computes total chain work after a new header with "nbits" is added to the chain
|
|
37
|
+
*
|
|
38
|
+
* @param nbits
|
|
39
|
+
* @private
|
|
40
|
+
*/
|
|
41
|
+
private computeNextChainWork;
|
|
42
|
+
/**
|
|
43
|
+
* Computes lastDiffAdjustment, this changes only once every DIFF_ADJUSTMENT_PERIOD blocks
|
|
44
|
+
*
|
|
45
|
+
* @param headerTimestamp
|
|
46
|
+
* @private
|
|
47
|
+
*/
|
|
48
|
+
private computeNextLastDiffAdjustment;
|
|
49
|
+
computeNext(header: EVMBtcHeader): EVMBtcStoredHeader;
|
|
50
|
+
getCommitHash(): string;
|
|
51
|
+
serialize(): Buffer;
|
|
52
|
+
serializeToStruct(): {
|
|
53
|
+
data: [string, string, string, string, string];
|
|
54
|
+
};
|
|
55
|
+
static deserialize(data: Buffer): EVMBtcStoredHeader;
|
|
56
|
+
}
|
|
@@ -1,123 +1,123 @@
|
|
|
1
|
-
"use strict";
|
|
2
|
-
Object.defineProperty(exports, "__esModule", { value: true });
|
|
3
|
-
exports.EVMBtcStoredHeader = void 0;
|
|
4
|
-
const base_1 = require("@atomiqlabs/base");
|
|
5
|
-
const EVMBtcHeader_1 = require("./EVMBtcHeader");
|
|
6
|
-
const buffer_1 = require("buffer");
|
|
7
|
-
const ethers_1 = require("ethers");
|
|
8
|
-
class EVMBtcStoredHeader {
|
|
9
|
-
constructor(obj) {
|
|
10
|
-
this.blockheader = obj.blockheader instanceof EVMBtcHeader_1.EVMBtcHeader ? obj.blockheader : new EVMBtcHeader_1.EVMBtcHeader(obj.blockheader);
|
|
11
|
-
this.blockHash = obj.blockHash;
|
|
12
|
-
this.chainWork = obj.chainWork;
|
|
13
|
-
this.blockHeight = obj.blockHeight;
|
|
14
|
-
this.lastDiffAdjustment = obj.lastDiffAdjustment;
|
|
15
|
-
this.prevBlockTimestamps = obj.prevBlockTimestamps;
|
|
16
|
-
}
|
|
17
|
-
getBlockheight() {
|
|
18
|
-
return this.blockHeight;
|
|
19
|
-
}
|
|
20
|
-
getChainWork() {
|
|
21
|
-
return buffer_1.Buffer.from(this.chainWork.toString(16).padStart(64, "0"), "hex");
|
|
22
|
-
}
|
|
23
|
-
getHeader() {
|
|
24
|
-
return this.blockheader;
|
|
25
|
-
}
|
|
26
|
-
getLastDiffAdjustment() {
|
|
27
|
-
return this.lastDiffAdjustment;
|
|
28
|
-
}
|
|
29
|
-
getPrevBlockTimestamps() {
|
|
30
|
-
return this.prevBlockTimestamps;
|
|
31
|
-
}
|
|
32
|
-
getBlockHash() {
|
|
33
|
-
return buffer_1.Buffer.from([...this.blockHash]).reverse();
|
|
34
|
-
}
|
|
35
|
-
/**
|
|
36
|
-
* Computes prevBlockTimestamps for a next block, shifting the old block timestamps to the left & appending
|
|
37
|
-
* this block's timestamp to the end
|
|
38
|
-
*
|
|
39
|
-
* @private
|
|
40
|
-
*/
|
|
41
|
-
computeNextBlockTimestamps() {
|
|
42
|
-
const prevBlockTimestamps = [...this.prevBlockTimestamps];
|
|
43
|
-
for (let i = 1; i < 10; i++) {
|
|
44
|
-
prevBlockTimestamps[i - 1] = prevBlockTimestamps[i];
|
|
45
|
-
}
|
|
46
|
-
prevBlockTimestamps[9] = this.blockheader.getTimestamp();
|
|
47
|
-
return prevBlockTimestamps;
|
|
48
|
-
}
|
|
49
|
-
/**
|
|
50
|
-
* Computes total chain work after a new header with "nbits" is added to the chain
|
|
51
|
-
*
|
|
52
|
-
* @param nbits
|
|
53
|
-
* @private
|
|
54
|
-
*/
|
|
55
|
-
computeNextChainWork(nbits) {
|
|
56
|
-
return this.chainWork + base_1.BigIntBufferUtils.fromBuffer(base_1.StatePredictorUtils.getChainwork(nbits));
|
|
57
|
-
}
|
|
58
|
-
/**
|
|
59
|
-
* Computes lastDiffAdjustment, this changes only once every DIFF_ADJUSTMENT_PERIOD blocks
|
|
60
|
-
*
|
|
61
|
-
* @param headerTimestamp
|
|
62
|
-
* @private
|
|
63
|
-
*/
|
|
64
|
-
computeNextLastDiffAdjustment(headerTimestamp) {
|
|
65
|
-
const blockheight = this.blockHeight + 1;
|
|
66
|
-
let lastDiffAdjustment = this.lastDiffAdjustment;
|
|
67
|
-
if (blockheight % base_1.StatePredictorUtils.DIFF_ADJUSTMENT_PERIOD === 0) {
|
|
68
|
-
lastDiffAdjustment = headerTimestamp;
|
|
69
|
-
}
|
|
70
|
-
return lastDiffAdjustment;
|
|
71
|
-
}
|
|
72
|
-
computeNext(header) {
|
|
73
|
-
header.previousBlockhash = this.blockHash;
|
|
74
|
-
return new EVMBtcStoredHeader({
|
|
75
|
-
chainWork: this.computeNextChainWork(header.getNbits()),
|
|
76
|
-
prevBlockTimestamps: this.computeNextBlockTimestamps(),
|
|
77
|
-
blockHeight: this.blockHeight + 1,
|
|
78
|
-
lastDiffAdjustment: this.computeNextLastDiffAdjustment(header.getTimestamp()),
|
|
79
|
-
blockHash: header.getHash(),
|
|
80
|
-
blockheader: header
|
|
81
|
-
});
|
|
82
|
-
}
|
|
83
|
-
getCommitHash() {
|
|
84
|
-
return (0, ethers_1.keccak256)(this.serialize());
|
|
85
|
-
}
|
|
86
|
-
serialize() {
|
|
87
|
-
const buffer = buffer_1.Buffer.alloc(160);
|
|
88
|
-
this.blockheader.serialize().copy(buffer, 0, 0, 80);
|
|
89
|
-
base_1.BigIntBufferUtils.toBuffer(this.chainWork, "be", 32).copy(buffer, 80, 0, 32);
|
|
90
|
-
buffer.writeUint32BE(this.blockHeight, 112);
|
|
91
|
-
buffer.writeUint32BE(this.lastDiffAdjustment, 116);
|
|
92
|
-
for (let i = 0; i < 10; i++) {
|
|
93
|
-
buffer.writeUint32BE(this.prevBlockTimestamps[i], 120 + (i * 4));
|
|
94
|
-
}
|
|
95
|
-
return buffer;
|
|
96
|
-
}
|
|
97
|
-
serializeToStruct() {
|
|
98
|
-
const buffer = this.serialize();
|
|
99
|
-
const result = [];
|
|
100
|
-
for (let i = 0; i < 5; i++) {
|
|
101
|
-
result[i] = "0x" + buffer.subarray(i * 32, (i + 1) * 32).toString("hex");
|
|
102
|
-
}
|
|
103
|
-
return { data: result };
|
|
104
|
-
}
|
|
105
|
-
static deserialize(data) {
|
|
106
|
-
if (data.length !== 160)
|
|
107
|
-
throw new Error(`Invalid size Expected 160, got: ${data.length}!`);
|
|
108
|
-
const blockheader = EVMBtcHeader_1.EVMBtcHeader.deserialize(data.subarray(0, 80));
|
|
109
|
-
const prevBlockTimestamps = [];
|
|
110
|
-
for (let i = 0; i < 10; i++) {
|
|
111
|
-
prevBlockTimestamps[i] = data.readUint32BE(120 + (i * 4));
|
|
112
|
-
}
|
|
113
|
-
return new EVMBtcStoredHeader({
|
|
114
|
-
blockheader,
|
|
115
|
-
blockHash: blockheader.getHash(),
|
|
116
|
-
chainWork: base_1.BigIntBufferUtils.fromBuffer(data.subarray(80, 112)),
|
|
117
|
-
blockHeight: data.readUint32BE(112),
|
|
118
|
-
lastDiffAdjustment: data.readUint32BE(116),
|
|
119
|
-
prevBlockTimestamps
|
|
120
|
-
});
|
|
121
|
-
}
|
|
122
|
-
}
|
|
123
|
-
exports.EVMBtcStoredHeader = EVMBtcStoredHeader;
|
|
1
|
+
"use strict";
|
|
2
|
+
Object.defineProperty(exports, "__esModule", { value: true });
|
|
3
|
+
exports.EVMBtcStoredHeader = void 0;
|
|
4
|
+
const base_1 = require("@atomiqlabs/base");
|
|
5
|
+
const EVMBtcHeader_1 = require("./EVMBtcHeader");
|
|
6
|
+
const buffer_1 = require("buffer");
|
|
7
|
+
const ethers_1 = require("ethers");
|
|
8
|
+
class EVMBtcStoredHeader {
|
|
9
|
+
constructor(obj) {
|
|
10
|
+
this.blockheader = obj.blockheader instanceof EVMBtcHeader_1.EVMBtcHeader ? obj.blockheader : new EVMBtcHeader_1.EVMBtcHeader(obj.blockheader);
|
|
11
|
+
this.blockHash = obj.blockHash;
|
|
12
|
+
this.chainWork = obj.chainWork;
|
|
13
|
+
this.blockHeight = obj.blockHeight;
|
|
14
|
+
this.lastDiffAdjustment = obj.lastDiffAdjustment;
|
|
15
|
+
this.prevBlockTimestamps = obj.prevBlockTimestamps;
|
|
16
|
+
}
|
|
17
|
+
getBlockheight() {
|
|
18
|
+
return this.blockHeight;
|
|
19
|
+
}
|
|
20
|
+
getChainWork() {
|
|
21
|
+
return buffer_1.Buffer.from(this.chainWork.toString(16).padStart(64, "0"), "hex");
|
|
22
|
+
}
|
|
23
|
+
getHeader() {
|
|
24
|
+
return this.blockheader;
|
|
25
|
+
}
|
|
26
|
+
getLastDiffAdjustment() {
|
|
27
|
+
return this.lastDiffAdjustment;
|
|
28
|
+
}
|
|
29
|
+
getPrevBlockTimestamps() {
|
|
30
|
+
return this.prevBlockTimestamps;
|
|
31
|
+
}
|
|
32
|
+
getBlockHash() {
|
|
33
|
+
return buffer_1.Buffer.from([...this.blockHash]).reverse();
|
|
34
|
+
}
|
|
35
|
+
/**
|
|
36
|
+
* Computes prevBlockTimestamps for a next block, shifting the old block timestamps to the left & appending
|
|
37
|
+
* this block's timestamp to the end
|
|
38
|
+
*
|
|
39
|
+
* @private
|
|
40
|
+
*/
|
|
41
|
+
computeNextBlockTimestamps() {
|
|
42
|
+
const prevBlockTimestamps = [...this.prevBlockTimestamps];
|
|
43
|
+
for (let i = 1; i < 10; i++) {
|
|
44
|
+
prevBlockTimestamps[i - 1] = prevBlockTimestamps[i];
|
|
45
|
+
}
|
|
46
|
+
prevBlockTimestamps[9] = this.blockheader.getTimestamp();
|
|
47
|
+
return prevBlockTimestamps;
|
|
48
|
+
}
|
|
49
|
+
/**
|
|
50
|
+
* Computes total chain work after a new header with "nbits" is added to the chain
|
|
51
|
+
*
|
|
52
|
+
* @param nbits
|
|
53
|
+
* @private
|
|
54
|
+
*/
|
|
55
|
+
computeNextChainWork(nbits) {
|
|
56
|
+
return this.chainWork + base_1.BigIntBufferUtils.fromBuffer(base_1.StatePredictorUtils.getChainwork(nbits));
|
|
57
|
+
}
|
|
58
|
+
/**
|
|
59
|
+
* Computes lastDiffAdjustment, this changes only once every DIFF_ADJUSTMENT_PERIOD blocks
|
|
60
|
+
*
|
|
61
|
+
* @param headerTimestamp
|
|
62
|
+
* @private
|
|
63
|
+
*/
|
|
64
|
+
computeNextLastDiffAdjustment(headerTimestamp) {
|
|
65
|
+
const blockheight = this.blockHeight + 1;
|
|
66
|
+
let lastDiffAdjustment = this.lastDiffAdjustment;
|
|
67
|
+
if (blockheight % base_1.StatePredictorUtils.DIFF_ADJUSTMENT_PERIOD === 0) {
|
|
68
|
+
lastDiffAdjustment = headerTimestamp;
|
|
69
|
+
}
|
|
70
|
+
return lastDiffAdjustment;
|
|
71
|
+
}
|
|
72
|
+
computeNext(header) {
|
|
73
|
+
header.previousBlockhash = this.blockHash;
|
|
74
|
+
return new EVMBtcStoredHeader({
|
|
75
|
+
chainWork: this.computeNextChainWork(header.getNbits()),
|
|
76
|
+
prevBlockTimestamps: this.computeNextBlockTimestamps(),
|
|
77
|
+
blockHeight: this.blockHeight + 1,
|
|
78
|
+
lastDiffAdjustment: this.computeNextLastDiffAdjustment(header.getTimestamp()),
|
|
79
|
+
blockHash: header.getHash(),
|
|
80
|
+
blockheader: header
|
|
81
|
+
});
|
|
82
|
+
}
|
|
83
|
+
getCommitHash() {
|
|
84
|
+
return (0, ethers_1.keccak256)(this.serialize());
|
|
85
|
+
}
|
|
86
|
+
serialize() {
|
|
87
|
+
const buffer = buffer_1.Buffer.alloc(160);
|
|
88
|
+
this.blockheader.serialize().copy(buffer, 0, 0, 80);
|
|
89
|
+
base_1.BigIntBufferUtils.toBuffer(this.chainWork, "be", 32).copy(buffer, 80, 0, 32);
|
|
90
|
+
buffer.writeUint32BE(this.blockHeight, 112);
|
|
91
|
+
buffer.writeUint32BE(this.lastDiffAdjustment, 116);
|
|
92
|
+
for (let i = 0; i < 10; i++) {
|
|
93
|
+
buffer.writeUint32BE(this.prevBlockTimestamps[i], 120 + (i * 4));
|
|
94
|
+
}
|
|
95
|
+
return buffer;
|
|
96
|
+
}
|
|
97
|
+
serializeToStruct() {
|
|
98
|
+
const buffer = this.serialize();
|
|
99
|
+
const result = [];
|
|
100
|
+
for (let i = 0; i < 5; i++) {
|
|
101
|
+
result[i] = "0x" + buffer.subarray(i * 32, (i + 1) * 32).toString("hex");
|
|
102
|
+
}
|
|
103
|
+
return { data: result };
|
|
104
|
+
}
|
|
105
|
+
static deserialize(data) {
|
|
106
|
+
if (data.length !== 160)
|
|
107
|
+
throw new Error(`Invalid size Expected 160, got: ${data.length}!`);
|
|
108
|
+
const blockheader = EVMBtcHeader_1.EVMBtcHeader.deserialize(data.subarray(0, 80));
|
|
109
|
+
const prevBlockTimestamps = [];
|
|
110
|
+
for (let i = 0; i < 10; i++) {
|
|
111
|
+
prevBlockTimestamps[i] = data.readUint32BE(120 + (i * 4));
|
|
112
|
+
}
|
|
113
|
+
return new EVMBtcStoredHeader({
|
|
114
|
+
blockheader,
|
|
115
|
+
blockHash: blockheader.getHash(),
|
|
116
|
+
chainWork: base_1.BigIntBufferUtils.fromBuffer(data.subarray(80, 112)),
|
|
117
|
+
blockHeight: data.readUint32BE(112),
|
|
118
|
+
lastDiffAdjustment: data.readUint32BE(116),
|
|
119
|
+
prevBlockTimestamps
|
|
120
|
+
});
|
|
121
|
+
}
|
|
122
|
+
}
|
|
123
|
+
exports.EVMBtcStoredHeader = EVMBtcStoredHeader;
|