Discord bot for Easter.
Project description
Description
Discord bot for Easter.
Documentation
Documentation is available on https://dashstrom.github.io/easterobot
Prerequisite
For using easterobot you will need a token, you can follow the discord.py Guide for get one.
Usage as CLI
You can install easterobot using uv
from PyPI.
pip install uv
uv tool install easterobot
# or uv tool install git+https://github.com/Dashstrom/easterobot
Once installed, you can use it directly.
easterobot run -t YOU_MUST_PUT_YOUR_TOKEN_HERE
Or you can generate a custom configuration for your own needs !
easterobot generate -i data
easterobot run -c data/config.yml
Usage with Docker
You can install easterobot using uv
from PyPI
git clone https://github.com/Dashstrom/easterobot
cd easterobot
echo "DISCORD_TOKEN=YOU_MUST_PUT_YOUR_TOKEN_HERE" > .env
# Can be unsafe (and for each update)
chmod -R 700 . && mkdir data -p && chmod 777 data
# Run the docker container
docker compose up -d
# Stop it
docker compose stop
# Remove the container (not the data)
docker compose down --rmi all
# Update
git reset --hard HEAD && git pull
# One-line update
docker compose down --rmi all && git reset --hard HEAD && git pull && chmod -R 700 . && mkdir data -p && chmod 777 data && docker compose up -d
Configuration directory
data Root directory
├── .gitignore Avoid pushing sensitive data
├── config.yml Configuration file
├── easterobot.db Database
├── logs Logging directory
│ ├── easterobot.log Latest log file
│ └── easterobot.log.1 Rotating log file
└── resources Resource directory
├── config.example.yml An example of config
├── credits.txt Credits of emotes
├── emotes Directory loaded as application emotes
│ ├── eggs Directory for eggs
│ | └── egg_01.png Emoji to use for egg
│ └── icons Misc emotes to load
│ └── arrow.png Emoji used in messages
├── logging.conf Logging configuration
├── alembic.ini Configure for alembic
└── logo.png Logo used by the bot
Development
Contributing
Contributions are very welcome. Tests can be run with poe check, please
ensure the coverage at least stays the same before you submit a pull request.
Setup
You need to install uv and Git for work with this project.
git clone https://github.com/Dashstrom/easterobot
cd easterobot
uv sync
uv run poe setup
Poe
Poe is available for help you to run tasks.
test Run test suite.
lint Run linters: ruff checker and ruff formatter and mypy.
format Run linters in fix mode.
check Run all checks: lint, test and docs.
check-tag Check if the current tag match the version.
cov Run coverage for generate report and html.
open-cov Open html coverage report in webbrowser.
docs Build documentation.
open-docs Open documentation in webbrowser.
setup Setup pre-commit.
pre-commit Run pre-commit.
commit Test, commit and push.
clean Clean cache files.
Skip commit verification
If the linting is not successful, you can’t commit. For forcing the commit you can use the next command :
git commit --no-verify -m 'MESSAGE'
Commit with commitizen
To respect commit conventions, this repository uses Commitizen.
cz c
How to add dependency
uv add 'PACKAGE'
Ignore illegitimate warnings
To ignore illegitimate warnings you can add :
# noqa: ERROR_CODE on the same line for ruff.
# type: ignore[ERROR_CODE] on the same line for mypy.
# pragma: no cover on the same line to ignore line for coverage.
# doctest: +SKIP on the same line for doctest.
Uninstall
pipx uninstall easterobot
License
This work is licensed under MIT.
Project details
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
Filter files by name, interpreter, ABI, and platform.
If you're not sure about the file name format, learn more about wheel file names.
Copy a direct link to the current filters
File details
Details for the file easterobot-1.3.1.tar.gz.
File metadata
- Download URL: easterobot-1.3.1.tar.gz
- Upload date:
- Size: 2.4 MB
- Tags: Source
- Uploaded using Trusted Publishing? Yes
- Uploaded via: twine/6.1.0 CPython/3.12.9
File hashes
| Algorithm | Hash digest | |
|---|---|---|
| SHA256 |
10255afc7af900e603f373c3b0971eec068c0a2c2fe47ff9348b0423bf78bff5
|
|
| MD5 |
ebde15f50e4cb4a8fb46c78eb118c897
|
|
| BLAKE2b-256 |
8b43e25786ab426cb4ae892e6419a82729203da93d25ddbb7de840465ae79192
|
Provenance
The following attestation bundles were made for easterobot-1.3.1.tar.gz:
Publisher:
publish.yml on Dashstrom/easterobot
-
Statement:
-
Statement type:
https://in-toto.io/Statement/v1 -
Predicate type:
https://docs.pypi.org/attestations/publish/v1 -
Subject name:
easterobot-1.3.1.tar.gz -
Subject digest:
10255afc7af900e603f373c3b0971eec068c0a2c2fe47ff9348b0423bf78bff5 - Sigstore transparency entry: 200249190
- Sigstore integration time:
-
Permalink:
Dashstrom/easterobot@99fb7db6d2a5b578172c37ee012b42525ca8525c -
Branch / Tag:
refs/tags/v1.3.1 - Owner: https://github.com/Dashstrom
-
Access:
public
-
Token Issuer:
https://token.actions.githubusercontent.com -
Runner Environment:
github-hosted -
Publication workflow:
publish.yml@99fb7db6d2a5b578172c37ee012b42525ca8525c -
Trigger Event:
push
-
Statement type:
File details
Details for the file easterobot-1.3.1-py3-none-any.whl.
File metadata
- Download URL: easterobot-1.3.1-py3-none-any.whl
- Upload date:
- Size: 2.3 MB
- Tags: Python 3
- Uploaded using Trusted Publishing? Yes
- Uploaded via: twine/6.1.0 CPython/3.12.9
File hashes
| Algorithm | Hash digest | |
|---|---|---|
| SHA256 |
ea246ae2c1cbb6d015e510fe3fd9cd9364d1b65b71ef26f67eb73b1b7bc0bccd
|
|
| MD5 |
260bc15e608e5b6cd2c2a90f021639aa
|
|
| BLAKE2b-256 |
8d915ec5f60eceed3e76f02d9ebcd5b8caffed0c059987001efe5c8522b340cd
|
Provenance
The following attestation bundles were made for easterobot-1.3.1-py3-none-any.whl:
Publisher:
publish.yml on Dashstrom/easterobot
-
Statement:
-
Statement type:
https://in-toto.io/Statement/v1 -
Predicate type:
https://docs.pypi.org/attestations/publish/v1 -
Subject name:
easterobot-1.3.1-py3-none-any.whl -
Subject digest:
ea246ae2c1cbb6d015e510fe3fd9cd9364d1b65b71ef26f67eb73b1b7bc0bccd - Sigstore transparency entry: 200249194
- Sigstore integration time:
-
Permalink:
Dashstrom/easterobot@99fb7db6d2a5b578172c37ee012b42525ca8525c -
Branch / Tag:
refs/tags/v1.3.1 - Owner: https://github.com/Dashstrom
-
Access:
public
-
Token Issuer:
https://token.actions.githubusercontent.com -
Runner Environment:
github-hosted -
Publication workflow:
publish.yml@99fb7db6d2a5b578172c37ee012b42525ca8525c -
Trigger Event:
push
-
Statement type: