A framework to automate reacting to ActivityStreams events.
Project description
Mechanical Bull
Mechanical Bull is an ActivityPub Client application build based on bovine. It's main goal is to provide a platform for automating activities undertaking in the FediVerse. Furthermore, it serves as a demonstration how ActivityPub Clients can be build with bovine.
Installation
One can simply install mechanical_bull with pip via
pip install mechanical-bull
Once can then add a new user by running
python -m mechanical_bull.add_user [--accept] name hostname
This will then prompt you to add a new did:key to your ActivityPub Actor. This did:key will be used to authenticate mechanical_bull against your server. Once you have added the key, press enter, and mechanical_bull is running. This method of authentication is called Moo-Auth-1 and described here.
The configuration is saved in config.toml
. bovine also supports authentication through private keys and HTTP signatures. For the details on how to configure this, please consult bovine. You can add further automations there.
Then you should be able to run mechanical bull via
python -m mechanical_bull.run
Configuration
First by adding log_file = "mechanical_bull.log"
to your config.toml
you can make mechanical_bull write log entries to a file. Second, the config file has the following format
logfile = "mechanical_bull.log"
[cow]
private_key = "z3u2Yxcowsarethebestcowsarethebestcowsarethebest"
host = "cows.rocks"
[cow.handlers]
"mechanical_bull.actions.reject_follow_request" = true
# "mechanical_bull.actions.accept_follow_request" = true
"mechanical_bull.actions.log_to_file" = { filename = "cow.txt" }
The listed handlers are provided by mechanical_bull. They allow to accept / reject follow requests automatically, and the final one logs all traffic on the event source to "cow.txt".
Writing automations
The examples of mechanical_bull.actions.accept_follow_request
and mechanical_bull.actions.log_to_file
should show how to write a new automation. The basic idea is that each file contains a function handle with signature
async def handle(client: BovineClient, data: dict, **kwargs):
return
here the kwargs are the dict given by the definiton in the handler block, i.e.
[user.handlers]
"my.package" = { arg1 = "value1", arg2 = "value2 }
Contibuting
Please report bugs, etc. to the issue tracker. Contributings in the form of pull requests are welcome. You can also contact me on the FediVerse at @helge@mymath.rocks
.
Finally, I plan a multi-user "server" version of this project called mechanical_herd. The functionality should be similar, but updating the configuration should not require a restart. One might also think hooking into the redis from bovine_pubsub for this. mechanical_herd will probably be part of the bovine user management interface.
Project details
Release history Release notifications | RSS feed
Download files
Download the file for your platform. If you're not sure which to choose, learn more about installing packages.
Source Distribution
Built Distribution
File details
Details for the file mechanical_bull-0.2.1.tar.gz
.
File metadata
- Download URL: mechanical_bull-0.2.1.tar.gz
- Upload date:
- Size: 11.9 kB
- Tags: Source
- Uploaded using Trusted Publishing? No
- Uploaded via: poetry/1.4.2 CPython/3.11.3 Linux/6.1.0-0.deb11.6-amd64
File hashes
Algorithm | Hash digest | |
---|---|---|
SHA256 | ebd07b507ecd28f3715fa7f38a7dd4101327a8d6e26f82b47f061ae713c13252 |
|
MD5 | 32f7d37f04bd0888dd31e831bf4a20f5 |
|
BLAKE2b-256 | d74eece800de05a6a9e9932d18a7a865d29b0fda1e6fbeb95d152d0fbaf66fb5 |
File details
Details for the file mechanical_bull-0.2.1-py3-none-any.whl
.
File metadata
- Download URL: mechanical_bull-0.2.1-py3-none-any.whl
- Upload date:
- Size: 11.1 kB
- Tags: Python 3
- Uploaded using Trusted Publishing? No
- Uploaded via: poetry/1.4.2 CPython/3.11.3 Linux/6.1.0-0.deb11.6-amd64
File hashes
Algorithm | Hash digest | |
---|---|---|
SHA256 | 41f16e3e50fdf535c6342ba87dc0b47fbb357149857aef594d924facc3943422 |
|
MD5 | 9982068e0c2984260aef5352bdecbf9c |
|
BLAKE2b-256 | 0f0940fea6959dab278dd0bac83d25290dbb2d2f7d3e9effd19e643eae2f1bd7 |