Цей темплейт використовується для розробки Telegram ботів з використанням бібліотеки aiogram v3.0+
.
В коді є приклади таблички User з використанням SQLAlchemy 2.0, та скрипти для алембіку (ініціалізація алембік, створення та застосування міграцій).
Але, якщо ви з цими інструментами ніколи не працювали, то зверніться до документації і дізнайтесь про ці інструменти. Також, в мене є англомовний курс по цим інструментам на Udemy.
- Скопіюйте
.env.dist
в.env
і заповніть необхідні дані. - Створіть нові хендлери.
- Docker:
- Можете одразу запускати проєкт із Docker, а якщо в вас його немає, то завантажте, та встановіть.
- Запустіть проєкт з команди
docker-compose up
- Без Docker:
- Створіть venv
- Встановить залежності із requirements.txt:
pip install -r requirements.txt --pre
- Запустіть проєкт з команди
python3 bot.py
Створюєте модуль you_name.py
у папці handlers
.
Створюєте роутер у you_name.py
.
from aiogram import Router
user_router = Router()
Можна робити декілька роутерів в одному модулі, та на кожний з них навішувати хендлери. Можна реєструвати хендлери декораторами:
@user_router.message(commands=["start"])
async def user_start(message):
await message.reply("Вітаю, звичайний користувач!")
Заходимо у файл handlers/__init__.py
і додаємо всі роутери в нього:
from .admin import admin_router
from .echo import echo_router
from .user import user_router
...
routers_list = [
admin_router,
user_router,
echo_router, # echo_router must be last
]
Переходимо до файлу bot.py
та розпаковуємо наші хендлери:
from tgbot.handlers import routers_list
...
async def main():
...
dp.include_routers(*routers_list)
...
-
Перейдіть до
.env
файлу та заповніть дані для бази даних, якщо ви не зробили цього раніше. -
Перейдіть до файлу
docker-compose.yml
та розкоментуйте секції:api
,pg_database
іvolumes
, щоб розпочати роботу. -
Перейдіть до
config.py
та виконайтеTODO
в функціїconstruct_sqlalchemy_url
. Також знайдіть розділ функціїload_config
і розкоментуйте рядок, що відповідає ініціалізації конфігурації бази данихdb=DbConfig.from_env(env)
, щоб активувати підключення до бази даних. -
Тепер можемо перезапустити Docker з новими контейнерами, використовуючи команду:
docker-compose up --build.
-
Все готово! Тепер можемо провести міграцію! Відкрийте термінал та введіть наступну команду:
docker-compose exec api alembic upgrade head
Відосів поки що немає, але @Groosha вже почав робити свій підручник.