A simple Telegram bot that sends random dog pictures (and more!).
You can test the bot on Telegram, just click here: @DogPicsBot.
Currently on v3.1.1. For more information about versions and changes, refer to the changelog.
The bot runs on Python 3 (officially supporting Python 3.10 to 3.13), and depends on packages listed on the requirements.txt
file.
For ease of use, use poetry
to install dependencies with the following command:
poetry install
Simply clone this repository, install the requirements with poetry
then set a new environment variable named DPB_TG_TOKEN
with your Telegram bot API token. If you don't have a valid token, check out this guide.
You can also optionally set a new environment variable named DPB_SAD_MESSAGE_RESPONSE_PROBABILITY
with a float value between 0 and 1, to potentially limit how often the bot will respond with dog pictures to sad messages.
Note that one feature (sending dog pictures freely through group chats on certain trigger words) requires the bot's Privacy Mode to be disabled (this can be done through @BotFather).
Run the following command on a command line. It will keep the polling thread running (therefore keeping your bot alive) until you kill the process.
poetry run python bot.py
Unit tests for the bot are found in the tests.py file. You can run them with verbose output after setting up your local environment, including the 80% coverage check that is expected of the repository, with the following command:
poetry run pytest
The next features to be developed are:
- Let the dog detect and reply to images that contain dogs in them (reference)
- Replying "intelligently" to messages relating to dogs (e.g. emotions)
- Explore the use of other dog pics APIs
- And more!
Pull requests are welcome. For major changes, please open an issue first to discuss what you would like to change.
All contributions that involve changing the codebase should either include or update tests, and make sure that all tests pass before changes can be merged to the master
branch.
This project is licensed under the MIT License - see the LICENSE file for details.