- api - REST API
- billing - основное приложение связанное с биллингом
- config - конфигурация проекта
- users - приложение с пользователями
- billing-gateway.json - файл для Insomnia
- линия 120 символов
- Account:
- валютный счет для юзера
- может быть несколько счетов в одной и той же валюте для одного юзера
- существуют "технические" счета - к примеру, для внешних переводов
- технические счета используются, когда юзер пополняет баланс банковским переводом, к примеру.
- технические счета позволяют фильтровать внешние операции - к примеру, можно узнать, сколько мы взяли комиссии или сколько было пополнений через банковский перевод или когда выводит деньги с лицевого счета на электронный кошелек.
- Operation:
- стандартная бухгалтерская проводка по счетам
- используется для двойного начисления
- операции идут относительно текущего аккаунта
- в базовой реализации, операции бывают двух типов - перевод и комиссия
- Payment:
- по-сути, является объединяющей сущностью для операций
- показывает кто кому переводил, сколько и с какой комиссией
- также, активно используется для фоновой проводки платежа (отдаем клиенту Payment.id, далее он может поллить либо соединиться через WebSocket, дожидаясь обработки платежа)
- если во время обработки платежа что-то пошло не так - можно добавить воркера, который по-расписанию будет обрабатывать платежи в INITIATED и будет переводить их в COMPLETED либо в FAILED
- только 1 авторизационный токен на юзера
- не сделано подтверждение аккаунта
- не сделана конвертацию валют между разными счетами
- фильтрация и сортировка не по всем полям
- избыточность в связях Payment - Operation
- не оптимизированы запросы к БД
- инлайновый импорт в задачах
- много дефолтных коментов django
- большой размер образа
- реализован подход с фоновой обработкой долгих задач
- маленькая, но расширяемая схема моделей
- использована кастомная модель пользователя
- приложение и среда докеризованы и готовы к деплою
- соблюден PEP8
- можно добавить разные валюты для счетов (если потребуется - можно создать даже отдельную модель)
- можно сделать конвертацию валюты (модель с 3-мя полями: from, to, rate)