{"id":19964020,"url":"https://github.com/vladislavyar/cash_fees","last_synced_at":"2026-04-11T01:12:19.228Z","repository":{"id":236277073,"uuid":"792284823","full_name":"VladislavYar/cash_fees","owner":"VladislavYar","description":"Rest API для веб-сервиса групповых денежных сборов.","archived":false,"fork":false,"pushed_at":"2024-05-18T02:44:22.000Z","size":666,"stargazers_count":1,"open_issues_count":0,"forks_count":0,"subscribers_count":1,"default_branch":"main","last_synced_at":"2025-01-12T08:21:52.555Z","etag":null,"topics":["celery","django","django-rest-framework","djoser","poetry","postgresql","python","redis","yookassa"],"latest_commit_sha":null,"homepage":"","language":"Python","has_issues":true,"has_wiki":null,"has_pages":null,"mirror_url":null,"source_name":null,"license":"mit","status":null,"scm":"git","pull_requests_enabled":true,"icon_url":"https://github.com/VladislavYar.png","metadata":{"files":{"readme":"README.md","changelog":null,"contributing":null,"funding":null,"license":"LICENSE","code_of_conduct":null,"threat_model":null,"audit":null,"citation":null,"codeowners":null,"security":null,"support":null,"governance":null,"roadmap":null,"authors":null,"dei":null,"publiccode":null,"codemeta":null}},"created_at":"2024-04-26T10:58:15.000Z","updated_at":"2024-07-15T22:57:01.000Z","dependencies_parsed_at":null,"dependency_job_id":"b7403e6b-fd40-43de-9aa9-669746b2a9d0","html_url":"https://github.com/VladislavYar/cash_fees","commit_stats":null,"previous_names":["vladislavyar/cash_fees"],"tags_count":0,"template":false,"template_full_name":null,"repository_url":"https://repos.ecosyste.ms/api/v1/hosts/GitHub/repositories/VladislavYar%2Fcash_fees","tags_url":"https://repos.ecosyste.ms/api/v1/hosts/GitHub/repositories/VladislavYar%2Fcash_fees/tags","releases_url":"https://repos.ecosyste.ms/api/v1/hosts/GitHub/repositories/VladislavYar%2Fcash_fees/releases","manifests_url":"https://repos.ecosyste.ms/api/v1/hosts/GitHub/repositories/VladislavYar%2Fcash_fees/manifests","owner_url":"https://repos.ecosyste.ms/api/v1/hosts/GitHub/owners/VladislavYar","download_url":"https://codeload.github.com/VladislavYar/cash_fees/tar.gz/refs/heads/main","host":{"name":"GitHub","url":"https://github.com","kind":"github","repositories_count":241396776,"owners_count":19956408,"icon_url":"https://github.com/github.png","version":null,"created_at":"2022-05-30T11:31:42.601Z","updated_at":"2022-07-04T15:15:14.044Z","host_url":"https://repos.ecosyste.ms/api/v1/hosts/GitHub","repositories_url":"https://repos.ecosyste.ms/api/v1/hosts/GitHub/repositories","repository_names_url":"https://repos.ecosyste.ms/api/v1/hosts/GitHub/repository_names","owners_url":"https://repos.ecosyste.ms/api/v1/hosts/GitHub/owners"}},"keywords":["celery","django","django-rest-framework","djoser","poetry","postgresql","python","redis","yookassa"],"created_at":"2024-11-13T02:18:50.095Z","updated_at":"2026-04-11T01:12:19.173Z","avatar_url":"https://github.com/VladislavYar.png","language":"Python","funding_links":[],"categories":[],"sub_categories":[],"readme":"\u003cdiv align=\"center\"\u003e\n  \u003ch1\u003ecash_fees\u003c/h1\u003e\n  \u003ch3\u003eОписание\u003c/h3\u003e\n  \u003cp\u003eRest API для веб-сервиса групповых денежных сборов.\u003c/p\u003e\n  \u003chr\u003e\n  \u003ch3\u003eПримечания\u003c/h3\u003e\n\u003c/div\u003e\n  \u003cp align=\"center\"\u003eПлатежи интегрированы через сервис \u003ca href=\"https://yookassa.ru/\"\u003eЮKassa\u003c/a\u003e, \u003ca href=\"https://github.com/yoomoney/yookassa-sdk-python\"\u003eссылка на SDK\u003c/a\u003e.\u003c/p\u003e\n  \u003cp align=\"center\"\u003eВ проекте доступна swagger-документация по адресу \u003ccode\u003e/api/v1/docs/\u003c/code\u003e.\u003c/p\u003e\n  \u003cp align=\"center\"\u003eЭндпоинты пользователя ограничены для простоты восприятия.\u003c/p\u003e\n  \u003cp align=\"center\"\u003eПоле \u003ccode\u003ecover\u003c/code\u003e может принимать как \u003ccode\u003ebase64-строку\u003c/code\u003e, так и \u003ccode\u003eslug\u003c/code\u003e \u003ci\u003eдефолтной обложки\u003c/i\u003e.\u003c/p\u003e\n  \u003cp align=\"center\"\u003eЭндпоинт \u003ccode\u003eDELETE: /api/v1/collectings/{slug}/\u003c/code\u003e не удаляет объект, а делает его неактивным.\u003c/p\u003e\n\u003chr\u003e\n\n\u003ch3 align=\"center\"\u003eКак запустить\u003c/h3\u003e\n\u003cdetails\u003e\n  \u003cp align=\"center\"\u003e\u003csummary align=\"center\"\u003e\u003cins\u003eЧерез Docker\u003c/ins\u003e\u003c/summary\u003e\u003c/p\u003e\n  \u003cul\u003e\n    \u003cli align=\"center\"\u003e1. Создать и заполнить файл \u003ccode\u003e.env\u003c/code\u003e в папке \n      \u003ca href=\"https://github.com/VladislavYar/cash_fees/tree/main/infra\"\u003e\u003ccode\u003einfra\u003c/code\u003e\u003c/a\u003e по шаблону \n        \u003ca href=\"https://github.com/VladislavYar/cash_fees/blob/main/infra/.env.example\"\u003e\u003ccode\u003e.env.example\u003c/code\u003e\u003c/a\u003e.\n    \u003c/li\u003e\n    \u003cli align=\"center\"\u003e\n      \u003cp\u003e2. Если имеется утилита \u003ccode\u003eMake\u003c/code\u003e, в корне проекта выполнить команду \u003ccode\u003emake project-init\u003c/code\u003e,\u003c/p\u003e\n      \u003cp\u003eиначе\u003c/p\u003e\n      \u003cp\u003eвыполнить команду \u003ccode\u003edocker compose -f ./infra/docker-compose.yml --env-file ./infra/.env up -d\u003c/code\u003e.\u003c/p\u003e\n      \u003cp\u003e\u003ccode\u003eDocker\u003c/code\u003e соберёт контейнеры с \u003ccode\u003epostgreSQL\u003c/code\u003e, \u003ccode\u003eСelery\u003c/code\u003e, \u003cb\u003eприложением\u003c/b\u003e, выполнит миграцию,\u003c/p\u003e\n      \u003cp\u003eзаполнит БД тестовыми \u003ci\u003eплатежами\u003c/i\u003e, \u003ci\u003eгрупповыми сборами\u003c/i\u003e, \u003ci\u003eдефолтными обложками\u003c/i\u003e, \u003ci\u003eповодами для сбора\u003c/i\u003e, \u003ci\u003eнекоммерческими организациями\u003c/i\u003e, \u003ci\u003eрегионами\u003c/i\u003e, \u003ci\u003eрешаемыми проблемами\u003c/i\u003e и \u003ci\u003eпользователями\u003c/i\u003e, создаст superuser-a.\u003c/p\u003e\n      \u003cp\u003eПосле сервер будет доступен по адрессу: \u003ccode\u003ehttp://127.0.0.1:8000/\u003c/code\u003e.\u003c/p\u003e\n    \u003c/li\u003e\n    \u003cli align=\"center\"\u003e\n      \u003cp\u003e\u003cb\u003eПримечание\u003c/b\u003e\u003c/p\u003e\n      \u003cp\u003e3. В контейнер с приложением проброшен \u003ccode\u003evolume\u003c/code\u003e с кодом, изменение кода в проекте обновляет его в контейнере и перезапускает сервер.\u003c/p\u003e\n      \u003cp\u003eВ mock-данныx генерируются изображения, на слабой вычислительной машине это может затянуть сбор контейнера.\u003c/p\u003e\n      \u003cp\u003eДля корректировки данной ситуации уменьшите количество/размер изображений в \u003ca href=\"https://github.com/VladislavYar/cash_fees/blob/main/src/core/management/commands/test_data.py\"\u003e\u003ccode\u003emanagement command\u003c/code\u003e\u003c/a\u003e.\u003c/p\u003e\n    \u003c/li\u003e\n    \u003cli align=\"center\"\u003e\n      \u003cp\u003e4. Последующие запуски проекта осуществляются через команду \u003ccode\u003emake project-start\u003c/code\u003e\u003c/p\u003e\n      \u003cp\u003eили\u003c/p\u003e\n      \u003cp\u003e\u003ccode\u003edocker compose -f ./infra/docker-compose-start.yml --env-file ./infra/.env up -d\u003c/code\u003e\u003c/p\u003e\n    \u003c/li\u003e\n  \u003c/ul\u003e\n\u003c/details\u003e\n\n\u003cdetails\u003e\n  \u003cp align=\"center\"\u003e\u003csummary align=\"center\"\u003e\u003cins\u003eЧерез консоль\u003c/ins\u003e\u003c/summary\u003e\u003c/p\u003e\n  \u003cul\u003e\n    \u003cli align=\"center\"\u003e1. Создать и заполнить файл \u003ccode\u003e.env\u003c/code\u003e в папке \n      \u003ca href=\"https://github.com/VladislavYar/cash_fees/tree/main/infra\"\u003e\u003ccode\u003einfra\u003c/code\u003e\u003c/a\u003e по шаблону \n        \u003ca href=\"https://github.com/VladislavYar/cash_fees/blob/main/infra/.env.example\"\u003e\u003ccode\u003e.env.example\u003c/code\u003e\u003c/a\u003e.\n    \u003c/li\u003e\n    \u003cli align=\"center\"\u003e\n      \u003cp\u003e2. Создать БД в \u003ccode\u003epostgreSQL\u003c/code\u003e.\u003c/p\u003e\n    \u003c/li\u003e\n    \u003cli align=\"center\"\u003e\n      \u003cp\u003e3. Установить poetry \u003ccode\u003epip install poetry\u003c/code\u003e.\u003c/p\u003e\n    \u003c/li\u003e\n    \u003cli align=\"center\"\u003e\n      \u003cp\u003e4. Создать и активировать виртуальную оболочку \u003ccode\u003epoetry shell\u003c/code\u003e.\u003c/p\u003e\n    \u003c/li\u003e\n    \u003cli align=\"center\"\u003e\n      \u003cp\u003e5. Установить зависимости \u003ccode\u003epoetry install\u003c/code\u003e.\u003c/p\u003e\n    \u003c/li\u003e\n    \u003cli align=\"center\"\u003e\n      \u003cp\u003e6. Выполнить миграцию БД \u003ccode\u003epython src/manage.py migrate\u003c/code\u003e.\u003c/p\u003e\n    \u003c/li\u003e\n        \u003cli align=\"center\"\u003e\n      \u003cp\u003e7. Создать superuser-a \u003ccode\u003epython src/manage.py createsuperuser --noinput\u003c/code\u003e.\u003c/p\u003e\n    \u003c/li\u003e\n    \u003c/li\u003e\n        \u003cli align=\"center\"\u003e\n      \u003cp\u003e8. Заполнить БД тестовыми данными(\u003ci\u003eплатежи, групповые сборы, дефолтные обложки, поводы для сбора, некоммерческие организации, регионы, решаемые проблемы и пользователи\u003c/i\u003e) \u003ccode\u003epython src/manage.py test_data\u003c/code\u003e.\u003c/p\u003e\n    \u003c/li\u003e\n    \u003cli align=\"center\"\u003e\n      \u003cp\u003e\u003cb\u003eПримечание\u003c/b\u003e\u003c/p\u003e\n      \u003cp\u003eВ mock-данныx генерируются изображения, на слабой вычислительной машине это может быть продолжительно.\u003c/p\u003e\n      \u003cp\u003eДля корректировки данной ситуации уменьшите количество/размер изображений в \u003ca href=\"https://github.com/VladislavYar/cash_fees/blob/main/src/core/management/commands/test_data.py\"\u003e\u003ccode\u003emanagement command\u003c/code\u003e\u003c/a\u003e.\u003c/p\u003e\n      \u003cp\u003eВ проекте брокером сообщений и хранилищем для кэша используется \u003ccode\u003eRedis\u003c/code\u003e.\u003c/p\u003e\n    \u003c/li\u003e\n    \u003c/li\u003e\n        \u003cli align=\"center\"\u003e\n      \u003cp\u003e9. Запустить сервер \u003ccode\u003epython src/manage.py runserver\u003c/code\u003e.\u003c/p\u003e\n    \u003c/li\u003e\n    \u003cli align=\"center\"\u003e\n      \u003cp\u003e10. Сервер будет доступен по адрессу: \u003ccode\u003ehttp://127.0.0.1:8000/\u003c/code\u003e.\u003c/p\u003e\n    \u003c/li\u003e\n    \u003cli align=\"center\"\u003e\n      \u003cp\u003e11. В новой консоле запустить worker \u003ccode\u003ecd src/ \u0026\u0026 celery -A config worker -l debug --without-gossip --without-mingle --without-heartbeat -Ofair --pool=solo\u003c/code\u003e.\u003c/p\u003e\n    \u003c/li\u003e\n    \u003cli align=\"center\"\u003e\n      \u003cp\u003e12. В новой консоле запустить beat \u003ccode\u003ecd src/ \u0026\u0026 celery -A config beat --loglevel=DEBUG\u003c/code\u003e.\u003c/p\u003e\n    \u003c/li\u003e\n  \u003c/ul\u003e\n\u003c/details\u003e\n\u003chr\u003e\n\n\u003ch3 align=\"center\"\u003eСтек\u003c/h3\u003e\n\u003cp align=\"center\"\u003e\n  \u003cimg src=\"https://img.shields.io/badge/Python-3.12.3-red?style=flat\u0026logo=python\u0026logoColor=white\"\u003e\n  \u003cimg src=\"https://img.shields.io/badge/Django-5.0.4-red?style=flat\u0026logo=django\u0026logoColor=white\"\u003e\n  \u003cimg src=\"https://img.shields.io/badge/Celery-5.4.0-red?style=flat\u0026logo=celery\u0026logoColor=white\"\u003e\n  \u003cimg src=\"https://img.shields.io/badge/DjangoRestFramework-3.15.1-red?style=flat\"\u003e\n  \u003cimg src=\"https://img.shields.io/badge/PostgreSQL-Latest-red?style=flat\u0026logo=postgresql\u0026logoColor=white\"\u003e\n  \u003cimg src=\"https://img.shields.io/badge/Redis-Latest-red?style=flat\u0026logo=redis\u0026logoColor=white\"\u003e\n  \u003cimg src=\"https://img.shields.io/badge/Docker-Latest-red?style=flat\u0026logo=docker\u0026logoColor=white\"\u003e\n  \u003cimg src=\"https://img.shields.io/badge/Swagger-Latest-red?style=flat\u0026logo=swagger\u0026logoColor=white\"\u003e\n  \u003cimg src=\"https://img.shields.io/badge/Poetry-Latest-red?style=flat\u0026logo=poetry\u0026logoColor=white\"\u003e\n  \u003cimg src=\"https://img.shields.io/badge/YookassaSdkPython-Latest-red?style=flat\"\u003e\n\u003c/p\u003e\n\u003chr\u003e\n","project_url":"https://awesome.ecosyste.ms/api/v1/projects/github.com%2Fvladislavyar%2Fcash_fees","html_url":"https://awesome.ecosyste.ms/projects/github.com%2Fvladislavyar%2Fcash_fees","lists_url":"https://awesome.ecosyste.ms/api/v1/projects/github.com%2Fvladislavyar%2Fcash_fees/lists"}