After a while, experiments made some publication events time-out. Increasing the timeout just in case, although it i likely to be a mere symptom but the core fault.
|4 weeks ago|
|app||4 weeks ago|
|src||1 month ago|
|test||2 months ago|
|.gitignore||5 months ago|
|.hlint.yaml||4 months ago|
|CHANGELOG.md||5 months ago|
|FediChord.asn1||2 months ago|
|Hash2Pub.cabal||1 month ago|
|LICENSE||5 months ago|
|Readme.md||1 month ago|
|Setup.hs||5 months ago|
|cabal.project.renameinfuture||3 months ago|
|default.nix||1 month ago|
|democlient.hs||5 months ago|
|demoserver.hs||5 months ago|
|hashtest.hs||5 months ago|
|shell-minimal.nix||2 months ago|
|shell.nix||2 months ago|
|stylish.sh||5 months ago|
This is heavily WIP and does not provide any useful functionality yet.
I aim for always having the master branch at a state where it builds and tests pass.
A fully-decentralised relay for global hashtag federation in ActivityPub based on a distributed hash table. It allows querying and subscribing to all posts of a certain hashtag and is implemented in Haskell.
This is the practical implementation of the concept presented in the paper Decentralised Hashtag Search and Subscription for Federated Social Networks. A 30 minutes introduction talk is available as well.
The ASN.1 module schema used for DHT messages can be found in
The project and its developent environment are built with Nix.
The development environment can be entered with
nix-shell shell-minimal.nix. Then the project can be built with
cabal build from within the environment, or using
nix-shell --command "cabal build" shell-minimal.nix to do both steps at once.
shell-minimal.nix environment contains everything necessary for building and testing this project, the
shell.nix additionally contains the Haskell IDE engine hie and the documentation for all used Haskell packages for more convenient development.
Be aware that these need to be build from source and can take a very long time to build.