@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,110 +1,110 @@
|
|
|
1
|
-
import {BtcHeader} from "@atomiqlabs/base";
|
|
2
|
-
import {Buffer} from "buffer";
|
|
3
|
-
import {sha256} from "@noble/hashes/sha2";
|
|
4
|
-
|
|
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
|
-
|
|
15
|
-
export class EVMBtcHeader implements BtcHeader {
|
|
16
|
-
|
|
17
|
-
version: number;
|
|
18
|
-
previousBlockhash: Buffer;
|
|
19
|
-
merkleRoot: Buffer;
|
|
20
|
-
timestamp: number;
|
|
21
|
-
nbits: number;
|
|
22
|
-
nonce: number;
|
|
23
|
-
hash?: Buffer;
|
|
24
|
-
|
|
25
|
-
constructor(data: EVMBtcHeaderType) {
|
|
26
|
-
this.version = data.version;
|
|
27
|
-
this.previousBlockhash = data.previousBlockhash;
|
|
28
|
-
this.merkleRoot = data.merkleRoot;
|
|
29
|
-
this.timestamp = data.timestamp;
|
|
30
|
-
this.nbits = data.nbits;
|
|
31
|
-
this.nonce = data.nonce;
|
|
32
|
-
this.hash = data.hash;
|
|
33
|
-
}
|
|
34
|
-
|
|
35
|
-
getMerkleRoot(): Buffer {
|
|
36
|
-
return this.merkleRoot;
|
|
37
|
-
}
|
|
38
|
-
|
|
39
|
-
getNbits(): number {
|
|
40
|
-
return this.nbits;
|
|
41
|
-
}
|
|
42
|
-
|
|
43
|
-
getNonce(): number {
|
|
44
|
-
return this.nonce;
|
|
45
|
-
}
|
|
46
|
-
|
|
47
|
-
getReversedPrevBlockhash(): Buffer {
|
|
48
|
-
return this.previousBlockhash;
|
|
49
|
-
}
|
|
50
|
-
|
|
51
|
-
getTimestamp(): number {
|
|
52
|
-
return this.timestamp;
|
|
53
|
-
}
|
|
54
|
-
|
|
55
|
-
getVersion(): number {
|
|
56
|
-
return this.version;
|
|
57
|
-
}
|
|
58
|
-
|
|
59
|
-
getHash(): Buffer {
|
|
60
|
-
return Buffer.from(sha256(sha256(this.serialize())));
|
|
61
|
-
}
|
|
62
|
-
|
|
63
|
-
serializeCompact(): Buffer {
|
|
64
|
-
const buffer = Buffer.alloc(48);
|
|
65
|
-
buffer.writeUInt32LE(this.version, 0);
|
|
66
|
-
this.merkleRoot.copy(buffer, 4);
|
|
67
|
-
buffer.writeUInt32LE(this.timestamp, 36);
|
|
68
|
-
buffer.writeUInt32LE(this.nbits, 40);
|
|
69
|
-
buffer.writeUInt32LE(this.nonce, 44);
|
|
70
|
-
return buffer;
|
|
71
|
-
}
|
|
72
|
-
|
|
73
|
-
serialize(): Buffer {
|
|
74
|
-
const buffer = Buffer.alloc(80);
|
|
75
|
-
buffer.writeUInt32LE(this.version, 0);
|
|
76
|
-
this.previousBlockhash.copy(buffer, 4);
|
|
77
|
-
this.merkleRoot.copy(buffer, 36);
|
|
78
|
-
buffer.writeUInt32LE(this.timestamp, 68);
|
|
79
|
-
buffer.writeUInt32LE(this.nbits, 72);
|
|
80
|
-
buffer.writeUInt32LE(this.nonce, 76);
|
|
81
|
-
return buffer;
|
|
82
|
-
}
|
|
83
|
-
|
|
84
|
-
static deserialize(rawData: Buffer): EVMBtcHeader {
|
|
85
|
-
if(rawData.length===80) {
|
|
86
|
-
//Regular blockheader
|
|
87
|
-
const version = rawData.readUInt32LE(0);
|
|
88
|
-
const previousBlockhash = Buffer.alloc(32);
|
|
89
|
-
rawData.copy(previousBlockhash, 0, 4, 36);
|
|
90
|
-
const merkleRoot = Buffer.alloc(32);
|
|
91
|
-
rawData.copy(merkleRoot, 0, 36, 68);
|
|
92
|
-
const timestamp = rawData.readUInt32LE(68);
|
|
93
|
-
const nbits = rawData.readUInt32LE(72);
|
|
94
|
-
const nonce = rawData.readUInt32LE(76);
|
|
95
|
-
return new EVMBtcHeader({version, previousBlockhash, merkleRoot, timestamp, nbits, nonce});
|
|
96
|
-
} else if(rawData.length===48) {
|
|
97
|
-
//Compact blockheader
|
|
98
|
-
const version = rawData.readUInt32LE(0);
|
|
99
|
-
const merkleRoot = Buffer.alloc(32);
|
|
100
|
-
rawData.copy(merkleRoot, 0, 4, 36);
|
|
101
|
-
const timestamp = rawData.readUInt32LE(36);
|
|
102
|
-
const nbits = rawData.readUInt32LE(40);
|
|
103
|
-
const nonce = rawData.readUInt32LE(44);
|
|
104
|
-
return new EVMBtcHeader({version, merkleRoot, timestamp, nbits, nonce});
|
|
105
|
-
} else {
|
|
106
|
-
throw new Error("Invalid byte length");
|
|
107
|
-
}
|
|
108
|
-
}
|
|
109
|
-
|
|
1
|
+
import {BtcHeader} from "@atomiqlabs/base";
|
|
2
|
+
import {Buffer} from "buffer";
|
|
3
|
+
import {sha256} from "@noble/hashes/sha2";
|
|
4
|
+
|
|
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
|
+
|
|
15
|
+
export class EVMBtcHeader implements BtcHeader {
|
|
16
|
+
|
|
17
|
+
version: number;
|
|
18
|
+
previousBlockhash: Buffer;
|
|
19
|
+
merkleRoot: Buffer;
|
|
20
|
+
timestamp: number;
|
|
21
|
+
nbits: number;
|
|
22
|
+
nonce: number;
|
|
23
|
+
hash?: Buffer;
|
|
24
|
+
|
|
25
|
+
constructor(data: EVMBtcHeaderType) {
|
|
26
|
+
this.version = data.version;
|
|
27
|
+
this.previousBlockhash = data.previousBlockhash;
|
|
28
|
+
this.merkleRoot = data.merkleRoot;
|
|
29
|
+
this.timestamp = data.timestamp;
|
|
30
|
+
this.nbits = data.nbits;
|
|
31
|
+
this.nonce = data.nonce;
|
|
32
|
+
this.hash = data.hash;
|
|
33
|
+
}
|
|
34
|
+
|
|
35
|
+
getMerkleRoot(): Buffer {
|
|
36
|
+
return this.merkleRoot;
|
|
37
|
+
}
|
|
38
|
+
|
|
39
|
+
getNbits(): number {
|
|
40
|
+
return this.nbits;
|
|
41
|
+
}
|
|
42
|
+
|
|
43
|
+
getNonce(): number {
|
|
44
|
+
return this.nonce;
|
|
45
|
+
}
|
|
46
|
+
|
|
47
|
+
getReversedPrevBlockhash(): Buffer {
|
|
48
|
+
return this.previousBlockhash;
|
|
49
|
+
}
|
|
50
|
+
|
|
51
|
+
getTimestamp(): number {
|
|
52
|
+
return this.timestamp;
|
|
53
|
+
}
|
|
54
|
+
|
|
55
|
+
getVersion(): number {
|
|
56
|
+
return this.version;
|
|
57
|
+
}
|
|
58
|
+
|
|
59
|
+
getHash(): Buffer {
|
|
60
|
+
return Buffer.from(sha256(sha256(this.serialize())));
|
|
61
|
+
}
|
|
62
|
+
|
|
63
|
+
serializeCompact(): Buffer {
|
|
64
|
+
const buffer = Buffer.alloc(48);
|
|
65
|
+
buffer.writeUInt32LE(this.version, 0);
|
|
66
|
+
this.merkleRoot.copy(buffer, 4);
|
|
67
|
+
buffer.writeUInt32LE(this.timestamp, 36);
|
|
68
|
+
buffer.writeUInt32LE(this.nbits, 40);
|
|
69
|
+
buffer.writeUInt32LE(this.nonce, 44);
|
|
70
|
+
return buffer;
|
|
71
|
+
}
|
|
72
|
+
|
|
73
|
+
serialize(): Buffer {
|
|
74
|
+
const buffer = Buffer.alloc(80);
|
|
75
|
+
buffer.writeUInt32LE(this.version, 0);
|
|
76
|
+
this.previousBlockhash.copy(buffer, 4);
|
|
77
|
+
this.merkleRoot.copy(buffer, 36);
|
|
78
|
+
buffer.writeUInt32LE(this.timestamp, 68);
|
|
79
|
+
buffer.writeUInt32LE(this.nbits, 72);
|
|
80
|
+
buffer.writeUInt32LE(this.nonce, 76);
|
|
81
|
+
return buffer;
|
|
82
|
+
}
|
|
83
|
+
|
|
84
|
+
static deserialize(rawData: Buffer): EVMBtcHeader {
|
|
85
|
+
if(rawData.length===80) {
|
|
86
|
+
//Regular blockheader
|
|
87
|
+
const version = rawData.readUInt32LE(0);
|
|
88
|
+
const previousBlockhash = Buffer.alloc(32);
|
|
89
|
+
rawData.copy(previousBlockhash, 0, 4, 36);
|
|
90
|
+
const merkleRoot = Buffer.alloc(32);
|
|
91
|
+
rawData.copy(merkleRoot, 0, 36, 68);
|
|
92
|
+
const timestamp = rawData.readUInt32LE(68);
|
|
93
|
+
const nbits = rawData.readUInt32LE(72);
|
|
94
|
+
const nonce = rawData.readUInt32LE(76);
|
|
95
|
+
return new EVMBtcHeader({version, previousBlockhash, merkleRoot, timestamp, nbits, nonce});
|
|
96
|
+
} else if(rawData.length===48) {
|
|
97
|
+
//Compact blockheader
|
|
98
|
+
const version = rawData.readUInt32LE(0);
|
|
99
|
+
const merkleRoot = Buffer.alloc(32);
|
|
100
|
+
rawData.copy(merkleRoot, 0, 4, 36);
|
|
101
|
+
const timestamp = rawData.readUInt32LE(36);
|
|
102
|
+
const nbits = rawData.readUInt32LE(40);
|
|
103
|
+
const nonce = rawData.readUInt32LE(44);
|
|
104
|
+
return new EVMBtcHeader({version, merkleRoot, timestamp, nbits, nonce});
|
|
105
|
+
} else {
|
|
106
|
+
throw new Error("Invalid byte length");
|
|
107
|
+
}
|
|
108
|
+
}
|
|
109
|
+
|
|
110
110
|
}
|
|
@@ -1,153 +1,153 @@
|
|
|
1
|
-
import {BigIntBufferUtils, BtcStoredHeader, StatePredictorUtils} from "@atomiqlabs/base";
|
|
2
|
-
import {EVMBtcHeader, EVMBtcHeaderType} from "./EVMBtcHeader";
|
|
3
|
-
import {Buffer} from "buffer";
|
|
4
|
-
import {keccak256} from "ethers";
|
|
5
|
-
|
|
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
|
-
|
|
15
|
-
export class EVMBtcStoredHeader implements BtcStoredHeader<EVMBtcHeader> {
|
|
16
|
-
|
|
17
|
-
blockheader: EVMBtcHeader;
|
|
18
|
-
blockHash: Buffer;
|
|
19
|
-
chainWork: bigint;
|
|
20
|
-
blockHeight: number;
|
|
21
|
-
lastDiffAdjustment: number;
|
|
22
|
-
prevBlockTimestamps: number[];
|
|
23
|
-
|
|
24
|
-
constructor(obj: StarknetBtcStoredHeaderType) {
|
|
25
|
-
this.blockheader = obj.blockheader instanceof EVMBtcHeader ? obj.blockheader : new EVMBtcHeader(obj.blockheader);
|
|
26
|
-
this.blockHash = obj.blockHash;
|
|
27
|
-
this.chainWork = obj.chainWork;
|
|
28
|
-
this.blockHeight = obj.blockHeight;
|
|
29
|
-
this.lastDiffAdjustment = obj.lastDiffAdjustment;
|
|
30
|
-
this.prevBlockTimestamps = obj.prevBlockTimestamps;
|
|
31
|
-
}
|
|
32
|
-
|
|
33
|
-
getBlockheight(): number {
|
|
34
|
-
return this.blockHeight;
|
|
35
|
-
}
|
|
36
|
-
|
|
37
|
-
getChainWork(): Buffer {
|
|
38
|
-
return Buffer.from(this.chainWork.toString(16).padStart(64, "0"), "hex");
|
|
39
|
-
}
|
|
40
|
-
|
|
41
|
-
getHeader(): EVMBtcHeader {
|
|
42
|
-
return this.blockheader;
|
|
43
|
-
}
|
|
44
|
-
|
|
45
|
-
getLastDiffAdjustment(): number {
|
|
46
|
-
return this.lastDiffAdjustment;
|
|
47
|
-
}
|
|
48
|
-
|
|
49
|
-
getPrevBlockTimestamps(): number[] {
|
|
50
|
-
return this.prevBlockTimestamps;
|
|
51
|
-
}
|
|
52
|
-
|
|
53
|
-
getBlockHash(): Buffer {
|
|
54
|
-
return Buffer.from([...this.blockHash]).reverse();
|
|
55
|
-
}
|
|
56
|
-
|
|
57
|
-
/**
|
|
58
|
-
* Computes prevBlockTimestamps for a next block, shifting the old block timestamps to the left & appending
|
|
59
|
-
* this block's timestamp to the end
|
|
60
|
-
*
|
|
61
|
-
* @private
|
|
62
|
-
*/
|
|
63
|
-
private computeNextBlockTimestamps(): number[] {
|
|
64
|
-
const prevBlockTimestamps = [...this.prevBlockTimestamps];
|
|
65
|
-
for(let i=1;i<10;i++) {
|
|
66
|
-
prevBlockTimestamps[i-1] = prevBlockTimestamps[i];
|
|
67
|
-
}
|
|
68
|
-
prevBlockTimestamps[9] = this.blockheader.getTimestamp();
|
|
69
|
-
return prevBlockTimestamps;
|
|
70
|
-
}
|
|
71
|
-
|
|
72
|
-
/**
|
|
73
|
-
* Computes total chain work after a new header with "nbits" is added to the chain
|
|
74
|
-
*
|
|
75
|
-
* @param nbits
|
|
76
|
-
* @private
|
|
77
|
-
*/
|
|
78
|
-
private computeNextChainWork(nbits: number): bigint {
|
|
79
|
-
return this.chainWork + BigIntBufferUtils.fromBuffer(StatePredictorUtils.getChainwork(nbits));
|
|
80
|
-
}
|
|
81
|
-
|
|
82
|
-
/**
|
|
83
|
-
* Computes lastDiffAdjustment, this changes only once every DIFF_ADJUSTMENT_PERIOD blocks
|
|
84
|
-
*
|
|
85
|
-
* @param headerTimestamp
|
|
86
|
-
* @private
|
|
87
|
-
*/
|
|
88
|
-
private computeNextLastDiffAdjustment(headerTimestamp: number) {
|
|
89
|
-
const blockheight = this.blockHeight+1;
|
|
90
|
-
|
|
91
|
-
let lastDiffAdjustment = this.lastDiffAdjustment;
|
|
92
|
-
if(blockheight % StatePredictorUtils.DIFF_ADJUSTMENT_PERIOD === 0) {
|
|
93
|
-
lastDiffAdjustment = headerTimestamp;
|
|
94
|
-
}
|
|
95
|
-
|
|
96
|
-
return lastDiffAdjustment;
|
|
97
|
-
}
|
|
98
|
-
|
|
99
|
-
computeNext(header: EVMBtcHeader): EVMBtcStoredHeader {
|
|
100
|
-
header.previousBlockhash = this.blockHash;
|
|
101
|
-
return new EVMBtcStoredHeader({
|
|
102
|
-
chainWork: this.computeNextChainWork(header.getNbits()),
|
|
103
|
-
prevBlockTimestamps: this.computeNextBlockTimestamps(),
|
|
104
|
-
blockHeight: this.blockHeight+1,
|
|
105
|
-
lastDiffAdjustment: this.computeNextLastDiffAdjustment(header.getTimestamp()),
|
|
106
|
-
blockHash: header.getHash(),
|
|
107
|
-
blockheader: header
|
|
108
|
-
});
|
|
109
|
-
}
|
|
110
|
-
|
|
111
|
-
getCommitHash(): string {
|
|
112
|
-
return keccak256(this.serialize());
|
|
113
|
-
}
|
|
114
|
-
|
|
115
|
-
serialize(): Buffer {
|
|
116
|
-
const buffer = Buffer.alloc(160);
|
|
117
|
-
this.blockheader.serialize().copy(buffer, 0, 0, 80);
|
|
118
|
-
BigIntBufferUtils.toBuffer(this.chainWork, "be", 32).copy(buffer, 80, 0, 32);
|
|
119
|
-
buffer.writeUint32BE(this.blockHeight, 112);
|
|
120
|
-
buffer.writeUint32BE(this.lastDiffAdjustment, 116);
|
|
121
|
-
for(let i=0;i<10;i++) {
|
|
122
|
-
buffer.writeUint32BE(this.prevBlockTimestamps[i], 120 + (i*4));
|
|
123
|
-
}
|
|
124
|
-
return buffer;
|
|
125
|
-
}
|
|
126
|
-
|
|
127
|
-
serializeToStruct(): {data: [string, string, string, string, string]} {
|
|
128
|
-
const buffer = this.serialize();
|
|
129
|
-
const result: string[] = [];
|
|
130
|
-
for(let i=0;i<5;i++) {
|
|
131
|
-
result[i] = "0x"+buffer.subarray(i*32, (i+1)*32).toString("hex");
|
|
132
|
-
}
|
|
133
|
-
return {data: result as any};
|
|
134
|
-
}
|
|
135
|
-
|
|
136
|
-
static deserialize(data: Buffer): EVMBtcStoredHeader {
|
|
137
|
-
if(data.length!==160) throw new Error(`Invalid size Expected 160, got: ${data.length}!`);
|
|
138
|
-
const blockheader = EVMBtcHeader.deserialize(data.subarray(0, 80));
|
|
139
|
-
const prevBlockTimestamps: number[] = [];
|
|
140
|
-
for(let i=0;i<10;i++) {
|
|
141
|
-
prevBlockTimestamps[i] = data.readUint32BE(120 + (i*4));
|
|
142
|
-
}
|
|
143
|
-
return new EVMBtcStoredHeader({
|
|
144
|
-
blockheader,
|
|
145
|
-
blockHash: blockheader.getHash(),
|
|
146
|
-
chainWork: BigIntBufferUtils.fromBuffer(data.subarray(80, 112)),
|
|
147
|
-
blockHeight: data.readUint32BE(112),
|
|
148
|
-
lastDiffAdjustment: data.readUint32BE(116),
|
|
149
|
-
prevBlockTimestamps
|
|
150
|
-
});
|
|
151
|
-
}
|
|
152
|
-
|
|
1
|
+
import {BigIntBufferUtils, BtcStoredHeader, StatePredictorUtils} from "@atomiqlabs/base";
|
|
2
|
+
import {EVMBtcHeader, EVMBtcHeaderType} from "./EVMBtcHeader";
|
|
3
|
+
import {Buffer} from "buffer";
|
|
4
|
+
import {keccak256} from "ethers";
|
|
5
|
+
|
|
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
|
+
|
|
15
|
+
export class EVMBtcStoredHeader implements BtcStoredHeader<EVMBtcHeader> {
|
|
16
|
+
|
|
17
|
+
blockheader: EVMBtcHeader;
|
|
18
|
+
blockHash: Buffer;
|
|
19
|
+
chainWork: bigint;
|
|
20
|
+
blockHeight: number;
|
|
21
|
+
lastDiffAdjustment: number;
|
|
22
|
+
prevBlockTimestamps: number[];
|
|
23
|
+
|
|
24
|
+
constructor(obj: StarknetBtcStoredHeaderType) {
|
|
25
|
+
this.blockheader = obj.blockheader instanceof EVMBtcHeader ? obj.blockheader : new EVMBtcHeader(obj.blockheader);
|
|
26
|
+
this.blockHash = obj.blockHash;
|
|
27
|
+
this.chainWork = obj.chainWork;
|
|
28
|
+
this.blockHeight = obj.blockHeight;
|
|
29
|
+
this.lastDiffAdjustment = obj.lastDiffAdjustment;
|
|
30
|
+
this.prevBlockTimestamps = obj.prevBlockTimestamps;
|
|
31
|
+
}
|
|
32
|
+
|
|
33
|
+
getBlockheight(): number {
|
|
34
|
+
return this.blockHeight;
|
|
35
|
+
}
|
|
36
|
+
|
|
37
|
+
getChainWork(): Buffer {
|
|
38
|
+
return Buffer.from(this.chainWork.toString(16).padStart(64, "0"), "hex");
|
|
39
|
+
}
|
|
40
|
+
|
|
41
|
+
getHeader(): EVMBtcHeader {
|
|
42
|
+
return this.blockheader;
|
|
43
|
+
}
|
|
44
|
+
|
|
45
|
+
getLastDiffAdjustment(): number {
|
|
46
|
+
return this.lastDiffAdjustment;
|
|
47
|
+
}
|
|
48
|
+
|
|
49
|
+
getPrevBlockTimestamps(): number[] {
|
|
50
|
+
return this.prevBlockTimestamps;
|
|
51
|
+
}
|
|
52
|
+
|
|
53
|
+
getBlockHash(): Buffer {
|
|
54
|
+
return Buffer.from([...this.blockHash]).reverse();
|
|
55
|
+
}
|
|
56
|
+
|
|
57
|
+
/**
|
|
58
|
+
* Computes prevBlockTimestamps for a next block, shifting the old block timestamps to the left & appending
|
|
59
|
+
* this block's timestamp to the end
|
|
60
|
+
*
|
|
61
|
+
* @private
|
|
62
|
+
*/
|
|
63
|
+
private computeNextBlockTimestamps(): number[] {
|
|
64
|
+
const prevBlockTimestamps = [...this.prevBlockTimestamps];
|
|
65
|
+
for(let i=1;i<10;i++) {
|
|
66
|
+
prevBlockTimestamps[i-1] = prevBlockTimestamps[i];
|
|
67
|
+
}
|
|
68
|
+
prevBlockTimestamps[9] = this.blockheader.getTimestamp();
|
|
69
|
+
return prevBlockTimestamps;
|
|
70
|
+
}
|
|
71
|
+
|
|
72
|
+
/**
|
|
73
|
+
* Computes total chain work after a new header with "nbits" is added to the chain
|
|
74
|
+
*
|
|
75
|
+
* @param nbits
|
|
76
|
+
* @private
|
|
77
|
+
*/
|
|
78
|
+
private computeNextChainWork(nbits: number): bigint {
|
|
79
|
+
return this.chainWork + BigIntBufferUtils.fromBuffer(StatePredictorUtils.getChainwork(nbits));
|
|
80
|
+
}
|
|
81
|
+
|
|
82
|
+
/**
|
|
83
|
+
* Computes lastDiffAdjustment, this changes only once every DIFF_ADJUSTMENT_PERIOD blocks
|
|
84
|
+
*
|
|
85
|
+
* @param headerTimestamp
|
|
86
|
+
* @private
|
|
87
|
+
*/
|
|
88
|
+
private computeNextLastDiffAdjustment(headerTimestamp: number) {
|
|
89
|
+
const blockheight = this.blockHeight+1;
|
|
90
|
+
|
|
91
|
+
let lastDiffAdjustment = this.lastDiffAdjustment;
|
|
92
|
+
if(blockheight % StatePredictorUtils.DIFF_ADJUSTMENT_PERIOD === 0) {
|
|
93
|
+
lastDiffAdjustment = headerTimestamp;
|
|
94
|
+
}
|
|
95
|
+
|
|
96
|
+
return lastDiffAdjustment;
|
|
97
|
+
}
|
|
98
|
+
|
|
99
|
+
computeNext(header: EVMBtcHeader): EVMBtcStoredHeader {
|
|
100
|
+
header.previousBlockhash = this.blockHash;
|
|
101
|
+
return new EVMBtcStoredHeader({
|
|
102
|
+
chainWork: this.computeNextChainWork(header.getNbits()),
|
|
103
|
+
prevBlockTimestamps: this.computeNextBlockTimestamps(),
|
|
104
|
+
blockHeight: this.blockHeight+1,
|
|
105
|
+
lastDiffAdjustment: this.computeNextLastDiffAdjustment(header.getTimestamp()),
|
|
106
|
+
blockHash: header.getHash(),
|
|
107
|
+
blockheader: header
|
|
108
|
+
});
|
|
109
|
+
}
|
|
110
|
+
|
|
111
|
+
getCommitHash(): string {
|
|
112
|
+
return keccak256(this.serialize());
|
|
113
|
+
}
|
|
114
|
+
|
|
115
|
+
serialize(): Buffer {
|
|
116
|
+
const buffer = Buffer.alloc(160);
|
|
117
|
+
this.blockheader.serialize().copy(buffer, 0, 0, 80);
|
|
118
|
+
BigIntBufferUtils.toBuffer(this.chainWork, "be", 32).copy(buffer, 80, 0, 32);
|
|
119
|
+
buffer.writeUint32BE(this.blockHeight, 112);
|
|
120
|
+
buffer.writeUint32BE(this.lastDiffAdjustment, 116);
|
|
121
|
+
for(let i=0;i<10;i++) {
|
|
122
|
+
buffer.writeUint32BE(this.prevBlockTimestamps[i], 120 + (i*4));
|
|
123
|
+
}
|
|
124
|
+
return buffer;
|
|
125
|
+
}
|
|
126
|
+
|
|
127
|
+
serializeToStruct(): {data: [string, string, string, string, string]} {
|
|
128
|
+
const buffer = this.serialize();
|
|
129
|
+
const result: string[] = [];
|
|
130
|
+
for(let i=0;i<5;i++) {
|
|
131
|
+
result[i] = "0x"+buffer.subarray(i*32, (i+1)*32).toString("hex");
|
|
132
|
+
}
|
|
133
|
+
return {data: result as any};
|
|
134
|
+
}
|
|
135
|
+
|
|
136
|
+
static deserialize(data: Buffer): EVMBtcStoredHeader {
|
|
137
|
+
if(data.length!==160) throw new Error(`Invalid size Expected 160, got: ${data.length}!`);
|
|
138
|
+
const blockheader = EVMBtcHeader.deserialize(data.subarray(0, 80));
|
|
139
|
+
const prevBlockTimestamps: number[] = [];
|
|
140
|
+
for(let i=0;i<10;i++) {
|
|
141
|
+
prevBlockTimestamps[i] = data.readUint32BE(120 + (i*4));
|
|
142
|
+
}
|
|
143
|
+
return new EVMBtcStoredHeader({
|
|
144
|
+
blockheader,
|
|
145
|
+
blockHash: blockheader.getHash(),
|
|
146
|
+
chainWork: BigIntBufferUtils.fromBuffer(data.subarray(80, 112)),
|
|
147
|
+
blockHeight: data.readUint32BE(112),
|
|
148
|
+
lastDiffAdjustment: data.readUint32BE(116),
|
|
149
|
+
prevBlockTimestamps
|
|
150
|
+
});
|
|
151
|
+
}
|
|
152
|
+
|
|
153
153
|
}
|