5d2d4ff560
Otherwise, this doesn't seem to build on arm64 |
||
---|---|---|
data | ||
.gitignore | ||
apitypes.py | ||
config.json.example | ||
create_task.py | ||
docker-compose.yml | ||
Dockerfile | ||
list_signal_groups.py | ||
main.py | ||
models.py | ||
README.md | ||
requirements.txt |
Lab signal bot
Starting
Configuration
Create a config:
cp config.json.example config.json
vi config.json
(Inside the docker container, "http://signal-cli-rest-api:8080" can be resolved to the host of the other docker container. Outside not.)
Link the signal-cli bot
Start containers:
docker compose up -d
In the beginning, this will only start the signal-cli-rest-api
docker container. The other container will fail, since the signal-cli
is not linked to the account. If you already activated the phone number with another signal device, you can register the new device.
Join the docker:
docker exec -it lab-signal-bot-signal-cli-rest-api-1 /bin/bash
Change user:
su signal-api
Link the new device:
signal-cli --config /home/.local/share/signal-cli link
Now, register the shown URL in your other signal app. If the process is finished, exit the docker shell.
Restart docker container:
docker restart lab-signal-bot-signal-cli-rest-api-1
Configure lab_cleaning_signal_base_group
From host, list signal groups:
python list_signal_groups.py --api-url http://localhost:8081/ -i
Now, you can set the identifier of the group you want in the config.json:
vi config.json
Rebuild containers:
docker compose up --build -d
Prepare host access (outside of docker)
Change the ownership of the db, such that the host user 1000 can write it:
sudo chown -R 1000 data/
Install venv outside of docker:
pip -m venv venv
. venv/bin/activate
pip install -r requirements.txt
Creating a task
Create a task:
python create_task.py "Küche aufräumen" 3 "in 40 minutes" --pad-template-url "https://pad.leinelab.org/bEvDjtyyQIGgZso_B7RIpw"
This:
- Creates a task called "Küche aufräumen".
- Requests 3 people from the base group for it.
- The task starts in 40 minutes.
- A detailed description of the tasks is found in the hedgedoc pad with url https://pad.leinelab.org/bEvDjtyyQIGgZso_B7RIpw. It will be used as a template for a new pad.
Implicitly, this means:
- People have 1 day to answer their participation requests for the task until the next person is asked. If a different timeout is desired,
--timeout-seconds X
can be specified for the task creation.