mirror of Generic LitePub relay (works with all LitePub consumers and Mastodon) at https://git.pleroma.social/pleroma/relay
Vous ne pouvez pas sélectionner plus de 25 sujets Les noms de sujets doivent commencer par une lettre ou un nombre, peuvent contenir des tirets ('-') et peuvent comporter jusqu'à 35 caractères.
Izalia Mae 5c5f212d70 Merge branch 'asyncio-3.10' into 'master' il y a 2 mois
installation add caddyfile and systemd service il y a 3 ans
relay fix DeprecationWarnings on 3.10 il y a 3 mois
.gitignore Add config file to gitignore il y a 2 ans
Dockerfile Add the whole directory in the workdir il y a 2 ans
LICENSE Initial commit il y a 3 ans
README.md update README with new install directions il y a 3 mois
pyproject.toml add packaging il y a 3 mois
relay.yaml.example make software blocklist configurable il y a 1 an
setup.cfg add packaging il y a 3 mois
setup.py add packaging il y a 3 mois



A generic LitePub message relay.


ActivityRelay is copyrighted, but free software, licensed under the terms of the GNU Affero General Public License version 3 (AGPLv3) license. You can find a copy of it in this package as the LICENSE file.


You need at least Python 3.6 (latest version of 3.x recommended) to make use of this software. It simply will not run on older Python versions.

Download the project and install with pip (pip3 install .).

Copy relay.yaml.example to relay.yaml and edit it as appropriate:

$ cp relay.yaml.example relay.yaml
$ $EDITOR relay.yaml

Finally, you can launch the relay:

$ python3 -m relay

It is suggested to run this under some sort of supervisor, such as runit, daemontools, s6 or systemd. Configuration of the supervisor is not covered here, as it is different depending on which system you have available.

The bot runs a webserver, internally, on localhost at port 8080. This needs to be forwarded by nginx or similar. The webserver is used to receive ActivityPub messages, and needs to be secured with an SSL certificate inside nginx or similar. Configuration of your webserver is not discussed here, but any guide explaining how to configure a modern non-PHP web application should cover it.

Getting Started

Normally, you would direct your LitePub instance software to follow the LitePub actor found on the relay. In Pleroma this would be something like:

$ MIX_ENV=prod mix relay_follow https://your.relay.hostname/actor

Mastodon uses an entirely different relay protocol but supports LitePub relay protocol as well when the Mastodon relay handshake is used. In these cases, Mastodon relay clients should follow http://your.relay.hostname/inbox as they would with Mastodon’s own relay software.


Performance is very good, with all data being stored in memory and serialized to a JSON-LD object graph. Worker coroutines are spawned in the background to distribute the messages in a scatter-gather pattern. Performance is comparable to, if not superior to, the Mastodon relay software, with improved memory efficiency.


You can perform a few management tasks such as peering or depeering other relays by invoking the relay.manage module.

This will show the available management tasks:

$ python3 -m relay.manage

When following remote relays, you should use the /actor endpoint as you would in Pleroma and other LitePub-compliant software.


You can run ActivityRelay with docker. Edit relay.yaml so that the database location is set to ./data/relay.jsonld and then build and run the docker image :

$ docker volume create activityrelay-data
$ docker build -t activityrelay .
$ docker run -d -p 8080:8080 -v activityrelay-data:/workdir/data activityrelay