Sen descrición

dependabot[bot] 8ea38e54ad build(deps-dev): bump pytest from 7.2.1 to 7.2.2 (#101) hai 1 ano
.github 377a8c4689 build(deps): bump docker/setup-buildx-action from 2.4.0 to 2.4.1 (#95) hai 1 ano
docs 225189d547 readme: added screenshots %!s(int64=3) %!d(string=hai) anos
location_guessing_game_telegram_bot db299437ee re-format code after upgrade of black to v23.1.0 hai 1 ano
tests d551dd42bd pylint: enable various optional checks/extensions %!s(int64=2) %!d(string=hai) anos
.dockerignore a1015b3d7f support image build without git history (fixes github action) %!s(int64=3) %!d(string=hai) anos
.gitignore fa44f5ac67 added gitignore list %!s(int64=3) %!d(string=hai) anos
.pylintrc d551dd42bd pylint: enable various optional checks/extensions %!s(int64=2) %!d(string=hai) anos
CHANGELOG.md 537da19ebc drop compatibility with python3.6 %!s(int64=3) %!d(string=hai) anos
COPYING ca0541b65c added GPLv3+ %!s(int64=3) %!d(string=hai) anos
Dockerfile 0e63d85627 container image: upgrade base image to debian bullseye with python3.10.0 %!s(int64=3) %!d(string=hai) anos
Makefile ca0541b65c added GPLv3+ %!s(int64=3) %!d(string=hai) anos
Pipfile 3b71f407ce dev env: add upper version constraint for isort to keep compatibility with python3.7 (has not reached end-of-life yet) hai 1 ano
Pipfile.lock 8ea38e54ad build(deps-dev): bump pytest from 7.2.1 to 7.2.2 (#101) hai 1 ano
README.md 225189d547 readme: added screenshots %!s(int64=3) %!d(string=hai) anos
ansible-playbook-example.yml 7e12a91a6d added sample playbook %!s(int64=3) %!d(string=hai) anos
docker-compose.yml bded47d485 setup docker-compose %!s(int64=3) %!d(string=hai) anos
mypy.ini d488c3918b mypy: ignore imports of python-telegram-bot %!s(int64=3) %!d(string=hai) anos
pyproject.toml 558bb9bc90 configure python package; added readme %!s(int64=3) %!d(string=hai) anos
setup.py c8ca867c7d package metadata: add version constraints for `python-telegram-bot` %!s(int64=2) %!d(string=hai) anos

README.md

Location Guessing Game Telegram Bot 🏞️ 🌍 📌

CI Pipeline Status Coverage Status Last Release Compatible Python Versions

Basic Telegram Bot Sending Random Wikimedia Commons Photos

 

Setup

  1. Download a dataset of photos via the WikiMap API, for instance:

    wget --restrict-file-names=windows 'https://wikimap.toolforge.org/api.php?cat=Images_with_annotations&lang=de&year=2010-2015&region=49|9|46|18'
    
  2. Generate a bot API token by sending /newbot to BotFather

  3. Install bot via pip3 install --user --upgrade location-guessing-game-telegram-bot (or use docker / podman, see below)

Usage

  1. Launch bot: location-guessing-game-telegram-bot --telegram-token-path file-containing-api-token --wikimap-export-path wikimap-export.json
  2. Open a chat with the bot in Telegram by searching for the bot's name previously sent to BotFather
  3. Send message /photo, wait, and repeat
  4. Optionally add the bot to a group chat.

Docker / Podman 🐳

Pre-built docker images are available at https://hub.docker.com/r/fphammerle/location-guessing-game-telegram-bot/tags

$ sudo docker run --name location_guessing_game_telegram_bot \
    -v /file/containing/api-token:/telegram-token:ro -e TELEGRAM_TOKEN_PATH=/telegram-token \
    -v /wikimap/export.json:/wikimap-export.json:ro -e WIKIMAP_EXPORT_PATH=/wikimap-export.json \
    --read-only --cap-drop ALL --security-opt no-new-privileges \
    --cpus 0.4 --memory 128M \
    docker.io/fphammerle/location-guessing-game-telegram-bot:latest

Optionally, replace sudo docker with podman.

Annotation of signed git tags docker/* contains docker image digests: https://github.com/fphammerle/location-guessing-game-telegram-bot/tags

Detached signatures of images are available at https://github.com/fphammerle/container-image-sigstore (exluding automatically built latest tag).

Docker Compose 🐙

  1. Clone this repository.
  2. Edit paths in docker-compose.yml.
  3. sudo docker-compose up --build

Ansible

See ansible-playbook-example.yml.

Trivia

Why create a Telegram bot instead of a web app?

I created this mini game for my family including my grandparents, who are comfortable using Telegram.