@atomiqlabs/chain-evm 1.0.0-dev.93 → 1.0.0-dev.95

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.
Files changed (185) hide show
  1. package/LICENSE +201 -201
  2. package/dist/chains/botanix/BotanixChainType.d.ts +13 -13
  3. package/dist/chains/botanix/BotanixChainType.js +2 -2
  4. package/dist/chains/botanix/BotanixInitializer.d.ts +30 -30
  5. package/dist/chains/botanix/BotanixInitializer.js +125 -125
  6. package/dist/chains/citrea/CitreaBtcRelay.d.ts +21 -21
  7. package/dist/chains/citrea/CitreaBtcRelay.js +43 -43
  8. package/dist/chains/citrea/CitreaChainType.d.ts +13 -13
  9. package/dist/chains/citrea/CitreaChainType.js +2 -2
  10. package/dist/chains/citrea/CitreaFees.d.ts +29 -29
  11. package/dist/chains/citrea/CitreaFees.js +67 -67
  12. package/dist/chains/citrea/CitreaInitializer.d.ts +30 -30
  13. package/dist/chains/citrea/CitreaInitializer.js +132 -132
  14. package/dist/chains/citrea/CitreaSpvVaultContract.d.ts +15 -15
  15. package/dist/chains/citrea/CitreaSpvVaultContract.js +74 -74
  16. package/dist/chains/citrea/CitreaSwapContract.d.ts +22 -22
  17. package/dist/chains/citrea/CitreaSwapContract.js +96 -96
  18. package/dist/chains/citrea/CitreaTokens.d.ts +9 -9
  19. package/dist/chains/citrea/CitreaTokens.js +20 -20
  20. package/dist/evm/btcrelay/BtcRelayAbi.d.ts +198 -198
  21. package/dist/evm/btcrelay/BtcRelayAbi.js +261 -261
  22. package/dist/evm/btcrelay/BtcRelayTypechain.d.ts +172 -172
  23. package/dist/evm/btcrelay/BtcRelayTypechain.js +2 -2
  24. package/dist/evm/btcrelay/EVMBtcRelay.d.ts +197 -197
  25. package/dist/evm/btcrelay/EVMBtcRelay.js +435 -435
  26. package/dist/evm/btcrelay/headers/EVMBtcHeader.d.ts +33 -33
  27. package/dist/evm/btcrelay/headers/EVMBtcHeader.js +84 -84
  28. package/dist/evm/btcrelay/headers/EVMBtcStoredHeader.d.ts +56 -56
  29. package/dist/evm/btcrelay/headers/EVMBtcStoredHeader.js +123 -123
  30. package/dist/evm/chain/EVMChainInterface.d.ts +54 -54
  31. package/dist/evm/chain/EVMChainInterface.js +89 -89
  32. package/dist/evm/chain/EVMModule.d.ts +9 -9
  33. package/dist/evm/chain/EVMModule.js +13 -13
  34. package/dist/evm/chain/modules/ERC20Abi.d.ts +168 -168
  35. package/dist/evm/chain/modules/ERC20Abi.js +225 -225
  36. package/dist/evm/chain/modules/EVMAddresses.d.ts +10 -10
  37. package/dist/evm/chain/modules/EVMAddresses.js +30 -30
  38. package/dist/evm/chain/modules/EVMBlocks.d.ts +20 -20
  39. package/dist/evm/chain/modules/EVMBlocks.js +64 -64
  40. package/dist/evm/chain/modules/EVMEvents.d.ts +46 -46
  41. package/dist/evm/chain/modules/EVMEvents.js +151 -151
  42. package/dist/evm/chain/modules/EVMFees.d.ts +36 -36
  43. package/dist/evm/chain/modules/EVMFees.js +74 -74
  44. package/dist/evm/chain/modules/EVMSignatures.d.ts +29 -29
  45. package/dist/evm/chain/modules/EVMSignatures.js +68 -68
  46. package/dist/evm/chain/modules/EVMTokens.d.ts +70 -70
  47. package/dist/evm/chain/modules/EVMTokens.js +142 -142
  48. package/dist/evm/chain/modules/EVMTransactions.d.ts +94 -94
  49. package/dist/evm/chain/modules/EVMTransactions.js +307 -288
  50. package/dist/evm/contract/EVMContractBase.d.ts +22 -22
  51. package/dist/evm/contract/EVMContractBase.js +34 -34
  52. package/dist/evm/contract/EVMContractModule.d.ts +8 -8
  53. package/dist/evm/contract/EVMContractModule.js +11 -11
  54. package/dist/evm/contract/modules/EVMContractEvents.d.ts +42 -42
  55. package/dist/evm/contract/modules/EVMContractEvents.js +75 -75
  56. package/dist/evm/events/EVMChainEvents.d.ts +22 -22
  57. package/dist/evm/events/EVMChainEvents.js +69 -69
  58. package/dist/evm/events/EVMChainEventsBrowser.d.ts +102 -102
  59. package/dist/evm/events/EVMChainEventsBrowser.js +412 -412
  60. package/dist/evm/providers/JsonRpcProviderWithRetries.d.ts +16 -16
  61. package/dist/evm/providers/JsonRpcProviderWithRetries.js +27 -27
  62. package/dist/evm/providers/ReconnectingWebSocketProvider.d.ts +22 -22
  63. package/dist/evm/providers/ReconnectingWebSocketProvider.js +91 -91
  64. package/dist/evm/providers/SocketProvider.d.ts +111 -111
  65. package/dist/evm/providers/SocketProvider.js +336 -336
  66. package/dist/evm/providers/WebSocketProviderWithRetries.d.ts +17 -17
  67. package/dist/evm/providers/WebSocketProviderWithRetries.js +23 -23
  68. package/dist/evm/spv_swap/EVMSpvVaultContract.d.ts +107 -107
  69. package/dist/evm/spv_swap/EVMSpvVaultContract.js +578 -578
  70. package/dist/evm/spv_swap/EVMSpvVaultData.d.ts +40 -40
  71. package/dist/evm/spv_swap/EVMSpvVaultData.js +184 -184
  72. package/dist/evm/spv_swap/EVMSpvWithdrawalData.d.ts +19 -19
  73. package/dist/evm/spv_swap/EVMSpvWithdrawalData.js +55 -55
  74. package/dist/evm/spv_swap/SpvVaultContractAbi.d.ts +91 -91
  75. package/dist/evm/spv_swap/SpvVaultContractAbi.js +849 -849
  76. package/dist/evm/spv_swap/SpvVaultContractTypechain.d.ts +450 -450
  77. package/dist/evm/spv_swap/SpvVaultContractTypechain.js +2 -2
  78. package/dist/evm/swaps/EVMSwapContract.d.ts +199 -199
  79. package/dist/evm/swaps/EVMSwapContract.js +394 -394
  80. package/dist/evm/swaps/EVMSwapData.d.ts +66 -66
  81. package/dist/evm/swaps/EVMSwapData.js +260 -260
  82. package/dist/evm/swaps/EVMSwapModule.d.ts +9 -9
  83. package/dist/evm/swaps/EVMSwapModule.js +11 -11
  84. package/dist/evm/swaps/EscrowManagerAbi.d.ts +120 -120
  85. package/dist/evm/swaps/EscrowManagerAbi.js +985 -985
  86. package/dist/evm/swaps/EscrowManagerTypechain.d.ts +475 -475
  87. package/dist/evm/swaps/EscrowManagerTypechain.js +2 -2
  88. package/dist/evm/swaps/handlers/IHandler.d.ts +13 -13
  89. package/dist/evm/swaps/handlers/IHandler.js +2 -2
  90. package/dist/evm/swaps/handlers/claim/ClaimHandlers.d.ts +10 -10
  91. package/dist/evm/swaps/handlers/claim/ClaimHandlers.js +13 -13
  92. package/dist/evm/swaps/handlers/claim/HashlockClaimHandler.d.ts +20 -20
  93. package/dist/evm/swaps/handlers/claim/HashlockClaimHandler.js +39 -39
  94. package/dist/evm/swaps/handlers/claim/btc/BitcoinNoncedOutputClaimHandler.d.ts +24 -24
  95. package/dist/evm/swaps/handlers/claim/btc/BitcoinNoncedOutputClaimHandler.js +59 -59
  96. package/dist/evm/swaps/handlers/claim/btc/BitcoinOutputClaimHandler.d.ts +25 -25
  97. package/dist/evm/swaps/handlers/claim/btc/BitcoinOutputClaimHandler.js +51 -51
  98. package/dist/evm/swaps/handlers/claim/btc/BitcoinTxIdClaimHandler.d.ts +21 -21
  99. package/dist/evm/swaps/handlers/claim/btc/BitcoinTxIdClaimHandler.js +28 -28
  100. package/dist/evm/swaps/handlers/claim/btc/IBitcoinClaimHandler.d.ts +48 -48
  101. package/dist/evm/swaps/handlers/claim/btc/IBitcoinClaimHandler.js +63 -63
  102. package/dist/evm/swaps/handlers/refund/TimelockRefundHandler.d.ts +17 -17
  103. package/dist/evm/swaps/handlers/refund/TimelockRefundHandler.js +28 -28
  104. package/dist/evm/swaps/modules/EVMLpVault.d.ts +69 -69
  105. package/dist/evm/swaps/modules/EVMLpVault.js +134 -134
  106. package/dist/evm/swaps/modules/EVMSwapClaim.d.ts +54 -54
  107. package/dist/evm/swaps/modules/EVMSwapClaim.js +137 -137
  108. package/dist/evm/swaps/modules/EVMSwapInit.d.ts +88 -88
  109. package/dist/evm/swaps/modules/EVMSwapInit.js +274 -274
  110. package/dist/evm/swaps/modules/EVMSwapRefund.d.ts +62 -62
  111. package/dist/evm/swaps/modules/EVMSwapRefund.js +167 -167
  112. package/dist/evm/typechain/common.d.ts +50 -50
  113. package/dist/evm/typechain/common.js +2 -2
  114. package/dist/evm/wallet/EVMBrowserSigner.d.ts +5 -5
  115. package/dist/evm/wallet/EVMBrowserSigner.js +11 -11
  116. package/dist/evm/wallet/EVMPersistentSigner.d.ts +29 -29
  117. package/dist/evm/wallet/EVMPersistentSigner.js +230 -230
  118. package/dist/evm/wallet/EVMSigner.d.ts +11 -11
  119. package/dist/evm/wallet/EVMSigner.js +24 -24
  120. package/dist/index.d.ts +44 -44
  121. package/dist/index.js +60 -60
  122. package/dist/utils/Utils.d.ts +19 -19
  123. package/dist/utils/Utils.js +98 -98
  124. package/package.json +39 -39
  125. package/src/chains/botanix/BotanixChainType.ts +28 -28
  126. package/src/chains/botanix/BotanixInitializer.ts +175 -175
  127. package/src/chains/citrea/CitreaBtcRelay.ts +57 -57
  128. package/src/chains/citrea/CitreaChainType.ts +28 -28
  129. package/src/chains/citrea/CitreaFees.ts +77 -77
  130. package/src/chains/citrea/CitreaInitializer.ts +182 -182
  131. package/src/chains/citrea/CitreaSpvVaultContract.ts +75 -75
  132. package/src/chains/citrea/CitreaSwapContract.ts +102 -102
  133. package/src/chains/citrea/CitreaTokens.ts +21 -21
  134. package/src/evm/btcrelay/BtcRelayAbi.ts +258 -258
  135. package/src/evm/btcrelay/BtcRelayTypechain.ts +371 -371
  136. package/src/evm/btcrelay/EVMBtcRelay.ts +537 -537
  137. package/src/evm/btcrelay/headers/EVMBtcHeader.ts +109 -109
  138. package/src/evm/btcrelay/headers/EVMBtcStoredHeader.ts +152 -152
  139. package/src/evm/chain/EVMChainInterface.ts +158 -158
  140. package/src/evm/chain/EVMModule.ts +21 -21
  141. package/src/evm/chain/modules/ERC20Abi.ts +222 -222
  142. package/src/evm/chain/modules/EVMAddresses.ts +28 -28
  143. package/src/evm/chain/modules/EVMBlocks.ts +75 -75
  144. package/src/evm/chain/modules/EVMEvents.ts +182 -182
  145. package/src/evm/chain/modules/EVMFees.ts +104 -104
  146. package/src/evm/chain/modules/EVMSignatures.ts +76 -76
  147. package/src/evm/chain/modules/EVMTokens.ts +155 -155
  148. package/src/evm/chain/modules/EVMTransactions.ts +346 -327
  149. package/src/evm/contract/EVMContractBase.ts +63 -63
  150. package/src/evm/contract/EVMContractModule.ts +16 -16
  151. package/src/evm/contract/modules/EVMContractEvents.ts +102 -102
  152. package/src/evm/events/EVMChainEvents.ts +82 -82
  153. package/src/evm/events/EVMChainEventsBrowser.ts +533 -533
  154. package/src/evm/providers/JsonRpcProviderWithRetries.ts +33 -33
  155. package/src/evm/providers/ReconnectingWebSocketProvider.ts +106 -106
  156. package/src/evm/providers/SocketProvider.ts +371 -371
  157. package/src/evm/providers/WebSocketProviderWithRetries.ts +34 -34
  158. package/src/evm/spv_swap/EVMSpvVaultContract.ts +723 -723
  159. package/src/evm/spv_swap/EVMSpvVaultData.ts +228 -228
  160. package/src/evm/spv_swap/EVMSpvWithdrawalData.ts +70 -70
  161. package/src/evm/spv_swap/SpvVaultContractAbi.ts +846 -846
  162. package/src/evm/spv_swap/SpvVaultContractTypechain.ts +685 -685
  163. package/src/evm/swaps/EVMSwapContract.ts +621 -621
  164. package/src/evm/swaps/EVMSwapData.ts +378 -378
  165. package/src/evm/swaps/EVMSwapModule.ts +16 -16
  166. package/src/evm/swaps/EscrowManagerAbi.ts +982 -982
  167. package/src/evm/swaps/EscrowManagerTypechain.ts +723 -723
  168. package/src/evm/swaps/handlers/IHandler.ts +17 -17
  169. package/src/evm/swaps/handlers/claim/ClaimHandlers.ts +20 -20
  170. package/src/evm/swaps/handlers/claim/HashlockClaimHandler.ts +46 -46
  171. package/src/evm/swaps/handlers/claim/btc/BitcoinNoncedOutputClaimHandler.ts +82 -82
  172. package/src/evm/swaps/handlers/claim/btc/BitcoinOutputClaimHandler.ts +76 -76
  173. package/src/evm/swaps/handlers/claim/btc/BitcoinTxIdClaimHandler.ts +46 -46
  174. package/src/evm/swaps/handlers/claim/btc/IBitcoinClaimHandler.ts +115 -115
  175. package/src/evm/swaps/handlers/refund/TimelockRefundHandler.ts +37 -37
  176. package/src/evm/swaps/modules/EVMLpVault.ts +154 -154
  177. package/src/evm/swaps/modules/EVMSwapClaim.ts +172 -172
  178. package/src/evm/swaps/modules/EVMSwapInit.ts +328 -328
  179. package/src/evm/swaps/modules/EVMSwapRefund.ts +229 -229
  180. package/src/evm/typechain/common.ts +131 -131
  181. package/src/evm/wallet/EVMBrowserSigner.ts +11 -11
  182. package/src/evm/wallet/EVMPersistentSigner.ts +307 -307
  183. package/src/evm/wallet/EVMSigner.ts +31 -31
  184. package/src/index.ts +53 -53
  185. package/src/utils/Utils.ts +111 -111
@@ -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
  }