Commit Graph

209 Commits

Author SHA1 Message Date
c3ba67ea87 Remove locks in PubsubNotifee
- Change `open_memory_channel(0)` to `open_memory_channel(math.inf)`, to
avoid `peer_queue.send` and `dead_peer_queue.send` blocking. This allows
us to remove the locks.
- Only catch `trio.BrokenResourceError`, which is caused by Pubsub when
it's closing.
2020-01-27 14:30:44 +08:00
92ea35e147 Fix IPubsub and add IPubsub.wait_until_ready 2020-01-27 00:10:33 +08:00
e3a1dd62e4 Use new type hinting for trio channel 2020-01-26 23:56:19 +08:00
6c7aa30191 Add events in Pubsub
To ensure `handle_peer_queue` and `handle_dead_peer_queue` are indeed
run before the tests finish. Previously, we get errors when performing
`iter_dag` after cancellation. This is because `handle_peer_queue` or
`handle_dead_peer_queue` is not actually run before the Service is
cancelled.
2020-01-18 00:17:30 +08:00
94f0fcb6ad Iterate dead_peer_receive_channel with async for 2019-12-26 20:44:32 +08:00
53dbb0aff1 Fix pubsub_notifee.py
For wrong syntax and import
2019-12-24 18:37:59 +08:00
573c049d0f Catch expections in PubsubNotifee
Also, add lock to avoid resource race condition
2019-12-24 18:31:39 +08:00
ce5663705f Merge branch 'master' into feature/porting-to-trio 2019-12-24 02:19:43 +08:00
3c75c85d7f Fix extra white space 2019-12-19 23:07:20 +08:00
cb80cfc50b Update libp2p/pubsub/gossipsub.py
Co-Authored-By: Chih Cheng Liang <chihchengliang@gmail.com>
2019-12-19 16:33:56 +08:00
74092c1371 Apply PR feedback: update error msg 2019-12-19 16:26:37 +08:00
e51d376d5e Combine peers_gossipsub and peers_floodsub 2019-12-19 14:44:49 +08:00
6cd3eb8fae Apply PR feedback:
change param type and remove check before `discard`
2019-12-19 14:15:51 +08:00
f3732f9480 Fix tests 2019-12-18 12:37:04 +08:00
19ce8a2140 Fix mypy 2019-12-17 21:56:02 +08:00
474ed41652 Remove dead peer if floodsub write stream fail 2019-12-17 18:48:25 +08:00
009df257bc Check peer id exist in dict before access 2019-12-17 18:47:58 +08:00
47d10e186f Add SubscriptionAPI
And `TrioSubscriptionAPI`, to make subscription io-agnostic.
2019-12-17 18:17:28 +08:00
f10e3099cb Change type of peers in pubsub from list to set 2019-12-17 17:55:13 +08:00
b4bd997932 Fix mypy 2019-12-17 17:49:49 +08:00
65766ec9ac Change type of local peers var from list to set 2019-12-17 17:36:15 +08:00
f1d58ef8ff Change type of peers from list to set:
`peers_gossipsub`, `peers_floodsub` and mesh/fanout peers
2019-12-17 17:30:24 +08:00
7d6daa8e10 Minor cleanup:
- remove outdated comment
- add new peer at the end
- turn peers to send from list to set
2019-12-17 17:17:03 +08:00
fb0519129d Refine Mplex.close and SwarmConn.close
Ensure `close` cleans up things and cancel the service finally.
2019-12-17 15:50:55 +08:00
733b1d08b6 Merge pull request #372 from ralexstokes/add-py36-compatibility
Add py36 compatibility
2019-12-10 17:28:49 -08:00
a675da52ee Update libp2p/pubsub/gossipsub.py
Co-Authored-By: Kevin Mai-Husan Chia <mhchia@users.noreply.github.com>
2019-12-07 15:46:42 +08:00
837a249552 Fix security module 2019-12-07 00:14:01 +08:00
2d3bfc8184 Apply PR feedback:
use defaultdict and init control message
2019-12-06 23:42:31 +08:00
1929f307fb Fix all modules except for security 2019-12-06 17:06:37 +08:00
db0017ddbb Fix lint after applying suggestion 2019-12-05 17:33:07 +08:00
b4900d53da Apply suggestions from code review
Co-Authored-By: Chih Cheng Liang <chihchengliang@gmail.com>
2019-12-05 15:21:09 +08:00
67f02c512a Remove unnecessary check and fix test 2019-12-05 15:10:04 +08:00
e6813da5f5 Refactor _get_peers_to_send 2019-12-05 14:35:34 +08:00
c08b2375e1 Fix: should not remove topic if no peers 2019-12-03 23:10:47 +08:00
a9abf1e3dd Fix list deletion and add list remove check 2019-12-03 22:37:49 +08:00
bb15c817b1 Fix var access before assignment 2019-12-03 22:14:45 +08:00
ea6cd30a16 Add back some comment and TODO. Add comment to tests 2019-12-03 18:45:33 +08:00
e9ab0646e3 Fix Pubsub 2019-12-03 17:27:49 +08:00
5efdf4c703 Group messages for peer in heartbeat 2019-12-03 15:48:23 +08:00
ab1500c708 Remove unneccessary check in gossip heartbeat 2019-12-03 15:03:06 +08:00
63fd531ed0 Fixes to add python 3.6 compatibility 2019-12-02 16:33:32 -08:00
920cf646ef Fix lint and add check in fanout heartbeat 2019-12-02 22:49:27 +08:00
a7e0c5d737 Add missing cleanup in gossipsub remove_peer 2019-12-02 22:41:49 +08:00
357341e0d8 Remove unneccessary filter and check in gossipsub 2019-12-02 22:40:35 +08:00
c2d88962c7 Add gossipsub heartbeat_initial_delay 2019-12-02 16:55:16 +08:00
0672f5ae6d Fix: move heartbeat delay to heartbeat 2019-12-02 16:38:48 +08:00
50fd0acf41 Cleanup outdated TODOs in gossipsub 2019-11-30 20:19:17 +08:00
0a52a05375 Del entry if no more peers subscribe to the topic 2019-11-30 20:02:11 +08:00
e59ac6a250 Cleanup TODOs in pubsub 2019-11-30 17:12:37 +08:00
658a0ae156 Apply PR feedback:
move signature validation logic into signature validator
2019-11-29 19:37:48 +08:00