Skip to content

one-zero-eight/aiogram-template

Repository files navigation

Aiogram Template

Table of contents

Did you know that GitHub supports table of contents by default 🤔

About

This is the Telegram Bot.

Technologies

Development

Getting started

  1. Install Python 3.12

  2. Install Poetry

  3. Install project dependencies with Poetry.

    poetry install
  4. Set up pre-commit hooks:

    poetry run pre-commit install --install-hooks -t pre-commit -t commit-msg
  5. Set up project settings file (check settings.schema.yaml for more info).

    cp settings.example.yaml settings.yaml

    Edit settings.yaml according to your needs.

Set up PyCharm integrations

  1. Ruff (plugin). It will lint and format your code. Make sure to enable Use ruff format option in plugin settings.
  2. Pydantic (plugin). It will fix PyCharm issues with type-hinting.
  3. Conventional commits (plugin). It will help you to write conventional commits.

Run for development

  1. Run the database if you have not done it yet
  2. Run the Redis server if needed:
    docker compose up -d redis
  3. Run the bot:
    poetry run python -m src.bot

Deployment

We use Docker with Docker Compose plugin to run the service on servers.

  1. Copy the file with settings: cp settings.example.yaml settings.yaml
  2. Change settings in the settings.yaml file according to your needs (check settings.schema.yaml for more info)
  3. Install Docker with Docker Compose
  4. Build a Docker image: docker compose build --pull
  5. Run the container: docker compose up --detach
  6. Check the logs: docker compose logs -f

How to update dependencies

Project dependencies

  1. Run poetry update to update all dependencies
  2. Run poetry show --outdated to check for outdated dependencies
  3. Run poetry add <package>@latest to add a new dependency if needed

Pre-commit hooks

  1. Run poetry run pre-commit autoupdate

About

Template for Aiogram 3 long-polling bot.

Resources

License

Security policy

Stars

Watchers

Forks

Releases

No releases published

Packages

No packages published