ядро платформы
Go to file
2024-02-21 19:06:39 +03:00
.gitea/workflows dev-deploy 2024-02-19 09:40:30 +03:00
.github/workflows my feed query fixed 2023-07-05 16:08:17 +02:00
orm update-redis-api 2024-02-21 16:06:24 +03:00
resolvers almost-dict 2024-02-21 19:03:49 +03:00
schema handle-shouts-paginating 2024-02-21 11:59:47 +03:00
services dictify 2024-02-21 18:51:37 +03:00
__init__.py buildsystemver-fix-2 2024-02-19 16:29:05 +03:00
.editorconfig migration, auth, refactoring, formatting 2022-09-17 21:12:14 +03:00
.gitignore all-cached-fix 2024-02-19 13:16:44 +03:00
.pre-commit-config.yaml ruff-up 2024-02-19 14:46:45 +03:00
app.json initial-delay 2024-02-21 19:06:39 +03:00
CHANGELOG.txt graphql-schema-update 2024-02-21 11:52:57 +03:00
Dockerfile fix-pjs 2024-02-19 11:13:05 +03:00
main.py batch-render-follows 2024-02-21 18:26:18 +03:00
nginx.conf.sigil dokku-conf 2024-01-11 20:23:02 +03:00
pyproject.toml cache-fixed 2024-02-21 17:37:58 +03:00
README.md readme-fix 2024-02-03 18:40:25 +03:00
server.py fmt 2024-02-21 10:27:16 +03:00
settings.py fmt 2024-02-21 10:27:16 +03:00

Техстек

  • sqlalchemy
  • redis
  • ariadne
  • starlette
  • granian

Локальная разработка

Подготовьте зависимости

osx:

brew install redis nginx postgres
brew services start redis

debian/ubuntu:

apt install redis nginx

Затем запустите postgres, redis и наш API-сервер:

mkdir .venv
python3.12 -m venv .venv
poetry env use .venv/bin/python3.12
poetry update
poetry run server.py

Подключенные сервисы

Для межсерверной коммуникации используются отдельные логики, папка services/* содержит адаптеры для использования базы данных, redis, кеширование и клиенты для запросов GraphQL.

auth.py

Задайте переменную окружения WEBHOOK_SECRET чтобы принимать запросы по адресу /new-author от сервера авторизации. Событие ожидается при создании нового пользователя. Для авторизованных запросов и мутаций фронтенд добавляет к запросу токен авторизации в заголовок Authorization.

viewed.py

Задайте переменные окружения GOOGLE_KEYFILE_PATH и GOOGLE_PROPERTY_ID для получения данных из Google Analytics.

search.py

Позволяет получать результаты пользовательских поисковых запросов в кешируемом виде от ElasticSearch с оценкой score, объединенные с запросами к базе данных, запрашиваем через GraphQL API load_shouts_search. Требует установка ELASTIC_HOST, ELASTIC_PORT, ELASTIC_USER и ELASTIC_PASSWORD.

notify.py

Отправка уведомлений по Redis PubSub каналам, согласно структуре данных, за которую отвечает сервис уведомлений

unread.py

Счетчик непрочитанных сообщений получается через Redis-запрос к данным сервиса сообщений.