- Описание проекта
- Технические подробности и требования
- Процесс «инвестирования»
- Инструкция по развёртыванию проекта
- Python
- FastAPI
- Google API
- Uvicorn
- SQLAlchemy
- Alembic
Фонд собирает пожертвования на различные целевые проекты:
- на медицинское обслуживание нуждающихся хвостатых
- на обустройство кошачьей колонии в подвале
- на корм оставшимся без попечения кошкам
- на любые цели, связанные с поддержкой кошачьей популяции
В приложении QRKot есть возможность формирования отчёта в гугл-таблице. В ней указаны закрытые проекты, отсортированные по скорости сбора средств — от тех, что закрылись быстрее всего, до тех, что долго собирали нужную сумму.
В Фонде QRKot может быть открыто несколько целевых проектов. У каждого проекта есть название, описание и сумма, которую планируется собрать. После того, как нужная сумма собрана — проект закрывается.
Пожертвования в проекты поступают по принципу First In, First Out: все пожертвования идут в проект, открытый раньше других; когда этот проект набирает необходимую сумму и закрывается — пожертвования начинают поступать в следующий проект.
Каждый пользователь может сделать пожертвование и сопроводить его комментарием. Пожертвования не целевые: они вносятся в фонд, а не в конкретный проект. Каждое полученное пожертвование автоматически добавляется в первый открытый проект, который ещё не набрал нужную сумму. Если пожертвование больше нужной суммы или же в Фонде нет открытых проектов — оставшиеся деньги ждут открытия следующего проекта. При создании нового проекта все неинвестированные пожертвования автоматически вкладываются в новый проект.
Целевые проекты создаются администраторами сайта.
Любой пользователь может видеть список всех проектов, включая требуемые и уже внесенные суммы. Это касается всех проектов — и открытых, и закрытых.
Зарегистрированные пользователи могут отправлять пожертвования и просматривать список своих пожертвований.
Для просмотра документации загрузите файл openapi.json на сайт https://redocly.github.io/redoc/. Вверху страницы есть кнопка Upload a file, нажмите её и загрузите скачанный файл.
В приложении три модели:
- Пользователи
- Проекты
- Пожертвования
- Используется библиотека FastAPI Users.
- В настройках указан транспорт Bearer и стратегию JWT.
- Подключены роутеры Auth Router, Register Router, Users Router.
- Установлен запрет на удаление пользователей.
Столбцы таблицы charityproject
:
id
— первичный ключname
— уникальное название проекта, обязательное строковое поле; допустимая длина строки — от 1 до 100 символов включительноdescription
— описание, обязательное поле, текст; не менее одного символаfull_amount
— требуемая сумма, целочисленное поле; больше 0invested_amount
— внесённая сумма, целочисленное поле; значение по умолчанию — 0fully_invested
— булево значение, указывающее на то, собрана ли нужная сумма для проекта (закрыт ли проект); значение по умолчанию — Falsecreate_date
— дата создания проекта, тип DateTime, должно добавляться автоматически в момент создания проектаclose_date
— дата закрытия проекта, DateTime, проставляется автоматически в момент набора нужной суммы
Любой посетитель сайта (в том числе неавторизованный) может посмотреть список всех проектов
Суперпользователь может:
- создавать проекты
- удалять проекты, в которые не было внесено средств
- изменять название и описание существующего проекта, устанавливать для него новую требуемую сумму (но не меньше уже внесённой)
Никто не может менять через API размер внесённых средств, удалять или модифицировать закрытые проекты, изменять даты создания и закрытия проектов
Любой зарегистрированный пользователь может сделать пожертвование
Зарегистрированный пользователь может просматривать только свои пожертвования, при этом ему выводится только четыре поля:
id
comment
full_amount
create_date
Информация о том, инвестировано пожертвование в какой-то проект или нет, обычному пользователю недоступна
Суперпользователь может просматривать список всех пожертвований, при этом ему выводятся все поля модели
Редактировать или удалять пожертвования не может никто
Столбцы таблицы donation
:
id
— первичный ключuser_id
— id пользователя, сделавшего пожертвование. Foreign Key на поле user.id из таблицы пользователейcomment
— необязательное текстовое полеfull_amount
— сумма пожертвования, целочисленное поле; больше 0invested_amount
— сумма из пожертвования, которая распределена по проектам; значение по умолчанию равно 0fully_invested
— булево значение, указывающее на то, все ли деньги из пожертвования были переведены в тот или иной проект; по умолчанию равно Falsecreate_date
— дата пожертвования; тип DateTime; добавляется автоматически в момент поступления пожертвованияclose_date
— дата, когда вся сумма пожертвования была распределена по проектам; тип DateTime; добавляется автоматически в момент выполнения условия
Сразу после создания нового проекта или пожертвования должен запускаться процесс «инвестирования» (увеличение invested_amount
как в пожертвованиях, так и в проектах, установка значений fully_invested
и close_date
, при необходимости).
Если создан новый проект, а в базе были «свободные» (не распределённые по проектам) суммы пожертвований — они автоматически должны инвестироваться в новый проект, и в ответе API эти суммы должны быть учтены. То же касается и создания пожертвований: если в момент пожертвования есть открытые проекты, эти пожертвования должны автоматически зачислиться на их счета.
- Клонировать репозиторий и перейти в него в командной строке
git clone [email protected]:SemenovY/QRkot_spreadsheets
- создание виртуального окружения
python3 -m venv venv
- запуск виртуального окружения
. venv/bin/activate
- установить зависимости из файла requirements.txt
pip install -r requirements.txt
- запуск сервера
uvicorn main:app
- запуск сервера с автоматическим рестартом
uvicorn main:app --reload
- инициализируем Alembic в проекте
alembic init --template async alembic
- создание файла миграции
alembic revision --autogenerate -m "migration name"
- применение миграций
alembic upgrade head
- отмена миграций
alembic downgrade
- запуск тестов
pytest
- Python 3.9
- FastAPI 0.7.0
- SQLAlchemy 1.4
Над проектом работал:
- Семёнов Юрий | GitHub: SemenovY | Python developer.