Commit Graph

48 Commits (080f8edc8ea77d95b773aff9b85eb071d7288220)

Author SHA1 Message Date
Nguyễn Gia Phong 080f8edc8e Use trio.lowlevel instead of trio.hazmat
Since trio 0.15.0, hazmat has been deprecated.

trio-typing and mypy are bumped to support newer trio and each other.
2021-02-23 22:02:34 +07:00
mhchia ce5663705f
Merge branch 'master' into feature/porting-to-trio 2019-12-24 02:19:43 +08:00
NIC619 474ed41652
Remove dead peer if floodsub write stream fail 2019-12-17 18:48:25 +08:00
NIC619 009df257bc
Check peer id exist in dict before access 2019-12-17 18:47:58 +08:00
mhchia 47d10e186f
Add `SubscriptionAPI`
And `TrioSubscriptionAPI`, to make subscription io-agnostic.
2019-12-17 18:17:28 +08:00
NIC619 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
mhchia 1929f307fb
Fix all modules except for security 2019-12-06 17:06:37 +08:00
mhchia e9ab0646e3
Fix Pubsub 2019-12-03 17:27:49 +08:00
NIC619 9be9b4bbfc
Handle `StreamClosed` in pub/gossip/flood-sub 2019-11-16 16:56:59 +08:00
Dominik Muhs bafdd8512d Enforce pre-summary newline in docstrings 2019-10-24 20:10:45 +02:00
Dominik Muhs eef505f2d9 Add automatic docstring formatter and apply 2019-10-24 08:41:10 +02:00
Moshe Malawach 986a852e7e Remove forced debug level 2019-10-01 11:17:05 +02:00
NIC619 9bad7a61f0
Add some loggings to pubsub 2019-09-14 21:54:26 +08:00
mhchia 7385a7a677
Add `is_gossipsub` fixture in interop test
To use the same code to test against both routers: floodsub and
gossipsub.
2019-09-03 16:49:00 +08:00
mhchia 1b5d064a8d
Add utility functions for libp2p bindings
To prepare for pubsub interop test
2019-09-02 14:30:25 +08:00
Alex Stokes 3debd2c808
Run `black` and `isort` w/ the new config 2019-08-13 14:36:42 -07:00
Chih Cheng Liang 28f6de37ee
Fix the rest of the typing hints (#232)
* ignore kad

* fix swarm, and minor

* fix init and swarm

* ignore pb

* enable mypy

* fix basic host

* fix tcp

* fix mplex

* add typing for pb

* skip format pyi

* [mypy] no need to ignore pb now

* add typing to chat
2019-08-11 16:47:54 +08:00
Alex Stokes 7477b29508 run black w/ extended line length 2019-08-04 12:37:41 +08:00
mhchia 2e94fcf56c
Remove pylint:disable 2019-08-02 23:26:06 +08:00
NIC619 cd684aad9e
Update peer_id to type peer.ID in pubsub folder 2019-08-02 14:45:23 +08:00
NIC619 b928bdb356
Convert from base58/pubkey/privkey to class method 2019-08-02 14:42:10 +08:00
Alex Stokes 0ae9840928
Run `black` over repo 2019-07-31 15:00:12 -07:00
NIC619 c4105688d1
Fix after rebase 2019-07-30 17:31:08 +08:00
NIC619 a4a0d79f6d
Improve import layout 2019-07-30 16:27:29 +08:00
NIC619 d716e90e17
Fix on type hints 2019-07-30 16:25:33 +08:00
NIC619 b2f496d081
Fix type hints except pb msg in pubsub folder 2019-07-30 16:24:34 +08:00
NIC619 63014eeaae
Add type hints to floodsub.py 2019-07-30 16:20:47 +08:00
mhchia f02d38c0ee
Reflect PR feedback
* Rename `src` to `msg_forwarder` in pubsub/floodsub/gossipsub
* Rename Variables
* Sort imports
* Clean up
2019-07-29 12:09:35 +08:00
mhchia 74d831d4e2
Reflect PR feedback 2019-07-28 18:06:38 +08:00
Kevin Mai-Husan Chia 70c5c84f32
Update libp2p/pubsub/floodsub.py
Co-Authored-By: NIC Lin <twedusuck@gmail.com>
2019-07-28 16:09:01 +08:00
Kevin Mai-Husan Chia a1e20caebe
Update libp2p/pubsub/floodsub.py
Co-Authored-By: NIC Lin <twedusuck@gmail.com>
2019-07-28 16:07:11 +08:00
Kevin Mai-Husan Chia ffb3920468
Update libp2p/pubsub/floodsub.py
Co-Authored-By: NIC Lin <twedusuck@gmail.com>
2019-07-28 16:06:03 +08:00
mhchia 65aedcb25a
Fix several tests 2019-07-26 18:35:25 +08:00
mhchia 035d08b8bd
Fix `test_floodsub.py` 2019-07-25 23:11:27 +08:00
mhchia cae4f34034
Refactor `floodsub.publish`
Passed the first test of floodsub
2019-07-25 14:08:16 +08:00
mhchia 93cf5a2c32
A roughly skeleton of `floodsub.publish`
Still need to ensure when to deliver to ourselves
2019-07-24 22:33:32 +08:00
mhchia b528c211b9
Temp modified publish 2019-07-24 21:55:57 +08:00
mhchia d3a948be47
Fix error: Change params floodsub.publish back 2019-07-24 16:24:14 +08:00
mhchia d6c19e71a6
Add typing and notes in pubsub 2019-07-24 14:54:30 +08:00
Robert Zajac 9052e8f8bd
The Gossipsub PR (#162)
* Add handle_rpc call to pubsub

* Scaffold gossipsub functions

* Add timer

* Implement most of mesh construction

* Implement emit and handle

* Implement fanout heartbeat

* Refactor emit

* some gossipsub cleanup and test

* minor lint stuff, more to come

* Implement publish

* Fix comment

* Modify pubsub/gossipsub so that floodsub tests pass using gossipsub router

* Add floodsub tests to gossipsub

* Handle case where select_from_minus, num_to_select > size(pool-minus)

* Add topic membership

* Implement handle ihave

* Implement most of iwant

* Add mcache.add and comments

* Refactor handle_ihave

* Implement stream write in handle_iwant

* Implement gossip heartbeat

* unresolved vars

* initial mcache code

* documenting mcache

* writing test/debugging mcache

* finished mcache test and debugged

* Make gossipsub backward compatibility its own file

* remove mcache prints

* DEBUGGING

* Add sender_peer_id to handle_rpc to get gossip test passing

* Modify gossipsub to make fanout work

* fanout maintenance test

* debugging gsub GOSSIP

* DEBUGGING

* debugged sender seen cachce

* adding lru, removing prints

* pylint cleanup

* Fix github comments in PR

* minor floodsub possible bugfix
2019-05-06 23:44:13 -04:00
Stuckinaboot 686c55b09c Remove unnecessary print #146 2019-04-05 17:38:29 -04:00
zixuanzh 7d3a8b5e77 clean up 2019-04-03 15:13:56 -04:00
zixuanzh bc6a27a762 fix all tests 2019-04-03 15:13:56 -04:00
zixuanzh fb5b3e4a24 reworked floodsub logic 2019-04-03 15:13:56 -04:00
zixuanzh 3836aa65f1 fix encoding issue 2019-04-03 15:13:56 -04:00
zixuanzh 35a587f72a remove message.py 2019-04-03 15:13:56 -04:00
Alex Haynes 83de4f2972 RPC conversion progress 2019-04-03 15:13:56 -04:00
stuckinaboot 9c6d441f9f [WIP] PubSub and FloodSub development (#133)
* Add notifee interface

* Add notify function to network interface

* Implement notify feature

* Add tests for notify

* Make notifee functions all async

* Fix linting issue

* Fix linting issue

* Scaffold pubsub router interface

* Scaffold pubsub directory

* Store peer_id in muxed connection

* Implement pubsub notifee

* Remove outdated files

* Implement pubsub first attempt

* Prepare pubsub for floodsub

* Add mplex conn to net stream and add conn in notify tests

* Implement floodsub

* Use NetStream in generic protocol handler

* Debugging async issues

* Modify test to perform proper assert. Test passes

* Remove callbacks. Reduce sleep time

* Add simple three node test

* Clean up code. Add message classes

* Add test for two topics

* Add conn to net stream and conn tests

* Refactor test setup to remove duplicate code

* Fix linting issues

* Fix linting issue

* Fix linting issue

* Fix outstanding unrelated lint issue in multiselect_client

* Add connect function

* Remove debug prints

* Remove debug prints from floodsub

* Use MessageTalk in place of direct message breakdown

* Remove extra prints

* Remove outdated function

* Add message to queues for all topics in message

* Debugging

* Add message self delivery

* Increase read timeout to 5 to get pubsub tests passing

* Refactor testing helper func. Add tests

* Add tests and increase timeout to get tests passing

* Add dummy account demo scaffolding

* Attempt to use threads. Test fails

* Implement basic dummy node tests using threads

* Add generic testing function

* Add simple seven node tree test

* Add more complex seven node tree tests

* Add five node ring tests

* Remove unnecessary get_message_type func

* Add documentation to classes

* Add message id to messages

* Add documentation to test helper func

* Add docs to dummy account node helper func

* Add more docs to dummy account node test helper func

* fixed linting errors in floodsub

* small notify bugfix

* move pubsub into libp2p

* fixed pubsub linting

* fixing pubsub test failures

* linting
2019-04-03 15:13:56 -04:00