Цей темплейт використовується для розробки 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 вже почав робити свій підручник.
