FarPostBooks - Backend

REST API для корпоративной библиотеки FarPost, написанный с использованием FastAPI.

API Endpoints:

  • POST /users/{telegram_id} - Создание нового пользователя
  • GET /users/token - Получение токена, если пользователь зарегистрирован
  • GET /users/me - Информация о себе (scope: user)
  • PUT /users/me - Обновление информации о себе (scope: user)

  • GET /users/{telegram_id} - Информация о пользователе по его Telegram ID (scope: user)
  • PUT /users/{telegram_id} - Обновление данных пользователя по Telegram ID (scope: admin)

  • POST /books/{book_id} - Добавление новой книги по ISBN (scope: admin)
  • GET /books - Общий список книг (ограничен по limit/offset) (scope: user)
  • GET /books/{book_id} - Получение информации о книге по ISBN (scope: user)

  • GET /users/{telegram_id}/books - Общий список книг + текущая книга пользователя по Telegram ID (ограничен по limit/offset) (scope: user)
  • POST /users/me/books/{book_id} - Взятие книги по ISBN (scope: user)
  • GET /users/{telegram_id}/books/{book_id} - Подробная информация о книге пользователя по Telegram ID и ISBN (scope: user)
  • PUT /users/me/books/{book_id} - Обновление информации о книге при возвращении пользователем (timestamp, rating) (scope: user)

Список будет дополняться...

Poetry

Для запуска проекта, используя poetry:

poetry install
poetry run python -m farpostbooks_backend

Проект будет запущен на хосте, указанном в .env.

Документация: /api/docs.
Документация: /api/redoc.

Docker

Перед запуском установить плагин для Docker - Loki:

docker plugin install grafana/loki-docker-driver:latest --alias loki --grant-all-permissions

Запуск проекта, используя Docker:

docker-compose -f deploy/docker-compose.yml --project-directory . up --build

Запуск проекта для разработки в Docker с авто-перезагрузкой:

docker-compose -f deploy/docker-compose.yml -f deploy/docker-compose.dev.yml --project-directory . up

При обновлении poetry.lock или pyproject.toml требуется пересобрать image с помощью команды:

docker-compose -f deploy/docker-compose.yml --project-directory . build

Структура проекта

$ tree "farpostbooks_backend"
farpostbooks_backend
├── conftest.py  # Фикстуры для всех тестов.
├── db  # Конфигурация базы данных.
│   ├── dao  # Объекты доступа к данным. Содержит различные классы для взаимодействия с базой данных.
│   └── models  # Модели для Tortoise ORM.
├── __main__.py  # Запуск проекта, используя uvicorn.
├── services  # Взаимодействие со сторонними сервисами.
├── settings.py  # Основные параметры конфигурации проекта.
├── static  # Статика (документация).
├── tests  # Система тестирования.
└── web  # Веб-сервер. Обработчики, конфиг для запуска.
    ├── api  # Все хендлеры.
    │   └── router.py  # Главный роутер и подгрузка остальных.
    ├── application.py  # Конфигурация для FastAPI.
    └── lifetime.py  # Действия при запуске/остановке.

Конфигурация

Все переменные окружения должны начинаться с префикса FARPOSTBOOKS_BACKEND_

Настройки переменных окружения находятся в farpostbooks_backend.settings.Settings.

Pre-commit

Автоматическая проверка кода перед коммитом изменений.
Конфигурация находится в .pre-commit-config.yaml.

Проверка кода происходит с использованием:

  • black (форматирование кода);
  • mypy (валидация тайп хинтинга);
  • isort (сортировка импортов);
  • flake8 (выявление возможных ошибок);

Миграции

# Обновление БД до последней миграции (автоматически при запуске).
aerich upgrade

Откат миграций

Для отката миграций используется команда:

aerich downgrade

Генерация миграций

После обновления моделей требуется перегенерировать миграции командой:

aerich migrate

Запуск тестов

Запуск тестов в докере с помощью команды:

docker-compose -f deploy/docker-compose.yml --project-directory . run --rm api pytest -vv .
docker-compose -f deploy/docker-compose.yml --project-directory . down