4643f840d7
chore(deps): get rid of unused deps ( #339 )
2022-12-06 18:02:04 -08:00
5e37ef8226
style(net): use pin_project on eceis stream ( #338 )
2022-12-06 18:02:04 -08:00
0b8d50127c
refactor(net): box ecies error ( #337 )
2022-12-06 18:02:04 -08:00
b40546b999
refactor(net): misc P2Pstream refactor ( #336 )
...
* refactor(net): misc P2Pstream refactor
* update note
2022-12-06 18:02:04 -08:00
074e69cafb
chore(net): remove unused function ( #335 )
2022-12-06 18:02:04 -08:00
a4472ca1c6
chore(clippy): make clippy happy ( #334 )
2022-12-06 18:02:04 -08:00
a68cb3f357
feat(stage): Add execution stage ( #287 )
...
* Execution stage
* StorageProviderRef. cleanup, fmt/clippy
* block inclusion
* insert blocks for execution stage
* Sanity test for execution stage
* nits
* Update crates/stages/src/stages/execution.rs
Co-authored-by: Georgios Konstantopoulos <me@gakonst.com >
* Update crates/stages/Cargo.toml
Co-authored-by: Georgios Konstantopoulos <me@gakonst.com >
* Update crates/stages/src/stages/execution.rs
Co-authored-by: Georgios Konstantopoulos <me@gakonst.com >
* Update crates/stages/src/stages/execution.rs
Co-authored-by: Georgios Konstantopoulos <me@gakonst.com >
* feat(execution) Execution change diff. (#323 )
* Insert to execution changediffs
* progress on exec stage unwind
* wip
* Remove tables:BlockBody from execution stage
* unwind passing
* Nits cleanup and refactoring
* DatabaseIntegrity errors
* KECCAK_EMPTY acc to None
* Update crates/interfaces/src/db/tables.rs
Co-authored-by: Georgios Konstantopoulos <me@gakonst.com >
* Update crates/interfaces/src/provider/block.rs
Co-authored-by: Georgios Konstantopoulos <me@gakonst.com >
* Update crates/stages/src/stages/execution.rs
Co-authored-by: Georgios Konstantopoulos <me@gakonst.com >
* nits
Co-authored-by: Georgios Konstantopoulos <me@gakonst.com >
Co-authored-by: Georgios Konstantopoulos <me@gakonst.com >
2022-12-06 18:02:04 -08:00
75879b2027
chore(ecies): remove body size check ( #328 )
...
* remove body size check
* cargo fmt
2022-12-06 18:02:04 -08:00
13df80c1d1
chore(codecs): contain [Struct]Flags in a mod and import what's necessary ( #329 )
...
* contain StructFlags in a mod with its imports
* update code generation test
2022-12-06 18:02:04 -08:00
f65969e90f
perf(net): exclude bootnodes from update stream ( #319 )
2022-12-06 18:02:04 -08:00
2b6ef0afcf
fix(eth-wire): encode p2p message id as valid rlp ( #324 )
2022-12-06 18:02:04 -08:00
1668313d55
perf(disc): instantly lookup self in DHT ( #314 )
...
* perf(disc): instantly lookup self in DHT
* Update crates/net/discv4/src/lib.rs
Co-authored-by: Georgios Konstantopoulos <me@gakonst.com >
Co-authored-by: Georgios Konstantopoulos <me@gakonst.com >
2022-12-06 18:02:04 -08:00
12212ec91a
fix(disc): set trace target correctly ( #315 )
2022-12-06 18:02:04 -08:00
5300c83a50
feat(net): send full transactions to fraction of all peers ( #272 )
...
* refactor(net): use shared objects on a per peer basis
* feat(net): send full transactions to fraction of all peers
Co-authored-by: Georgios Konstantopoulos <me@gakonst.com >
2022-12-02 04:21:23 -08:00
debc87177c
fix(eth-wire): handle 0x80 for DisconnectReason and P2PMessageID ( #313 )
...
* fix disconnect reason encoding
* move disconnect to own file
* add encoding test for 0x80 in list
* rlp([0u8]) is a good test case to have because it is the RLP encoding
of a DisconnectRequested p2p message
* fix disconnect encoding and decoding
* directly decode the disconnect id to handle the 0x80 case of
DisconnectRequested
* the previous manual snappy encoding / decoding was incorrect - a
snappy encoded disconnect message is 4 bytes, not 3 bytes. The tests
and implementation are changed to reflect this.
* fix p2p message decoding
* had a similar issue to disconnect reason decoding where it would not
handle a 0x80 message id
* make invalid rlp header case more explicit
* cargo fmt
2022-12-02 04:21:00 -08:00
743b1bd6ba
meta(txpool): fairer order function via timestamp ( #281 )
2022-12-02 03:58:21 -08:00
bb014eea25
codecs: "type specialization" for Compact on Vec<T> & Option<T> ( #297 )
...
* maybe_zero no longer necessary on bytecode_hash
* add alt impl for Compact to/from
* add some more docs
* add default vec impl on generator test
* use default trait impl
* rename from alternative to specialized
2022-12-02 01:56:08 -08:00
c7ec4512c8
feat(db): cursor insert ( #310 )
2022-12-01 19:31:32 -08:00
bc3702ec42
chore(rlp): add comment on 0x80 decoding ( #312 )
...
* add comment on 0x80 decoding
* decode 0x80 into zero explicitly
* add explicit 0x80 decoding for ethereum types
2022-12-01 21:27:33 -05:00
04105ec82b
test: add mainnet connection test ( #306 )
2022-12-01 17:59:52 +01:00
a0c35f1f48
refactor: replace reverse with HeadersDirection ( #305 )
2022-12-01 17:59:33 +01:00
53b1593849
add comment & test ( #309 )
2022-12-01 08:38:56 -08:00
3355b0c605
test(net): add e2e request body test ( #304 )
...
* test(net): add e2e request body test
* test(net): add e2e request header test
2022-12-01 15:35:14 +01:00
a267515a60
add a more complete description of the error ( #303 )
2022-12-01 01:41:09 -08:00
480097a7ca
feat(net): add eth request handler ( #293 )
...
* feat(net): add block request manager
* refactor: change ommers type to Header
* feat: impl handlers
* rename to EthRequestHandler
* impl checks
* fix: skip as step
* chore: rustfmt
2022-11-30 21:19:50 +01:00
d0e9e6fe80
feat: add header by number provider fn ( #299 )
...
* feat: add header by number provider fn
* Update crates/interfaces/src/provider/block.rs
Co-authored-by: rakita <rakita@users.noreply.github.com >
Co-authored-by: rakita <rakita@users.noreply.github.com >
2022-11-30 14:05:46 +01:00
267b857a8f
refactor: change ommers type to Header ( #292 )
2022-11-30 00:13:52 +01:00
7879389059
chore(net): deny unused and cleanup ( #289 )
2022-11-29 20:57:40 +01:00
97ea20e9d5
feat(net): add swarm mermaid diagram ( #288 )
2022-11-29 20:15:17 +01:00
e53ed8ffc2
refactor(net): use shared objects on a per peer basis ( #270 )
2022-11-29 11:43:45 +01:00
3ac52bae84
chore(sync): unwind tx by latest available ( #280 )
2022-11-28 14:49:54 -08:00
b5300aafec
feat(net): add request timeout ( #273 )
2022-11-28 14:41:39 -08:00
4d708ce8af
chore(sync): basic header response validation ( #276 )
2022-11-28 09:32:46 -08:00
96afa2d41d
chore: Noted about code origin ( #278 )
2022-11-28 09:26:36 -08:00
993123390f
perf(txpool): Arc alloc transaction event ( #279 )
2022-11-28 15:12:48 +01:00
a43a6cba8c
feat(rpc): add new engine V2 types and routes ( #274 )
2022-11-28 14:18:43 +01:00
7867c67eaa
chore(typool): clippy cleanup, docs and renames ( #277 )
2022-11-28 14:16:33 +01:00
b30e8241ce
docs(rpc): improve eth rpc docs ( #275 )
2022-11-28 14:16:19 +01:00
0e436ae543
feat(net): add missing report on bad response ( #271 )
2022-11-27 23:33:04 -08:00
3efc6ee67e
feat(db): Make TransactionSigned compactable ( #252 )
2022-11-27 23:29:30 -08:00
b02a5c4bbf
perf(net): import loop order in transactions manager ( #269 )
2022-11-26 10:44:30 -08:00
7db61eeadb
misc(net): discovery docs and renames ( #268 )
2022-11-26 14:46:57 +01:00
a744676302
misc(net): add peers commands ( #267 )
2022-11-26 14:46:49 +01:00
fd840e1c66
refactor: bodies client API ( #257 )
...
* refactor: bodies client API
* chore: fix errors
2022-11-26 10:04:42 +01:00
5d5b83d575
fix(sync): download error handling ( #260 )
2022-11-25 22:27:53 -08:00
6da140ce1b
chore(eth-wire): remove TODO about capability Ord ( #263 )
...
* chore(eth-wire): remove TODO about capability Ord
* orderings should be consistent with geth, see updated comment
* move down string doc link
2022-11-25 22:17:57 -08:00
6232505b94
fix(net): substract from correct var ( #262 )
2022-11-26 00:35:51 +01:00
b6d9fe87b9
feat(net): propagate new transactions ( #256 )
2022-11-25 22:13:20 +01:00
37809ce774
feat(net): add session limits ( #253 )
2022-11-25 18:56:49 +01:00
6e7928ab84
feat(sync): stage db helper ( #240 )
...
* feat(sync): stage db helper
* stagedb cont
* merge stage db & db container
* rename test stage db accessor methods
* clippy
* remove legacy test
2022-11-25 07:12:13 -08:00