{"id":28180998,"url":"https://github.com/meteopavel/crowdfunding_api","last_synced_at":"2026-01-25T00:31:18.637Z","repository":{"id":288733187,"uuid":"969023333","full_name":"meteopavel/Crowdfunding_API","owner":"meteopavel","description":"🎉🔧 RESTful API для групповых денежных сборов. Позволяет создавать, управлять и отслеживать сборы, а также делать пожертвования.","archived":false,"fork":false,"pushed_at":"2025-04-21T12:18:38.000Z","size":57,"stargazers_count":1,"open_issues_count":0,"forks_count":0,"subscribers_count":1,"default_branch":"main","last_synced_at":"2025-05-16T03:11:54.763Z","etag":null,"topics":["celery","django","django-rest-framework","docker","nginx","pillow","postgresql","python3","redis","uvicorn"],"latest_commit_sha":null,"homepage":"","language":"Python","has_issues":true,"has_wiki":null,"has_pages":null,"mirror_url":null,"source_name":null,"license":null,"status":null,"scm":"git","pull_requests_enabled":true,"icon_url":"https://github.com/meteopavel.png","metadata":{"files":{"readme":"README.md","changelog":null,"contributing":null,"funding":null,"license":null,"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,"zenodo":null}},"created_at":"2025-04-19T07:54:16.000Z","updated_at":"2025-04-21T12:18:41.000Z","dependencies_parsed_at":"2025-04-20T14:01:35.962Z","dependency_job_id":null,"html_url":"https://github.com/meteopavel/Crowdfunding_API","commit_stats":null,"previous_names":["meteopavel/crowdfunding_api"],"tags_count":0,"template":false,"template_full_name":null,"purl":"pkg:github/meteopavel/Crowdfunding_API","repository_url":"https://repos.ecosyste.ms/api/v1/hosts/GitHub/repositories/meteopavel%2FCrowdfunding_API","tags_url":"https://repos.ecosyste.ms/api/v1/hosts/GitHub/repositories/meteopavel%2FCrowdfunding_API/tags","releases_url":"https://repos.ecosyste.ms/api/v1/hosts/GitHub/repositories/meteopavel%2FCrowdfunding_API/releases","manifests_url":"https://repos.ecosyste.ms/api/v1/hosts/GitHub/repositories/meteopavel%2FCrowdfunding_API/manifests","owner_url":"https://repos.ecosyste.ms/api/v1/hosts/GitHub/owners/meteopavel","download_url":"https://codeload.github.com/meteopavel/Crowdfunding_API/tar.gz/refs/heads/main","sbom_url":"https://repos.ecosyste.ms/api/v1/hosts/GitHub/repositories/meteopavel%2FCrowdfunding_API/sbom","scorecard":null,"host":{"name":"GitHub","url":"https://github.com","kind":"github","repositories_count":286080680,"owners_count":28739842,"icon_url":"https://github.com/github.png","version":null,"created_at":"2022-05-30T11:31:42.601Z","updated_at":"2026-01-24T22:12:27.248Z","status":"ssl_error","status_checked_at":"2026-01-24T22:12:10.529Z","response_time":89,"last_error":"SSL_connect returned=1 errno=0 peeraddr=140.82.121.6:443 state=error: unexpected eof while reading","robots_txt_status":"success","robots_txt_updated_at":"2025-07-24T06:49:26.215Z","robots_txt_url":"https://github.com/robots.txt","online":false,"can_crawl_api":true,"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","docker","nginx","pillow","postgresql","python3","redis","uvicorn"],"created_at":"2025-05-16T03:11:56.364Z","updated_at":"2026-01-25T00:31:18.623Z","avatar_url":"https://github.com/meteopavel.png","language":"Python","funding_links":[],"categories":[],"sub_categories":[],"readme":"\u003c!-- Python 3 --\u003e\u003ca href=\"https://www.python.org/downloads/release/python-31010/\"\u003e\u003cimg src=\"./images/python_3.svg\"\u003e\u003c/a\u003e\n\u003c!-- Django --\u003e\u003ca href=\"https://docs.djangoproject.com/en/5.1/releases/5.0/\"\u003e\u003cimg src=\"./images/django.svg\"\u003e\u003c/a\u003e\n\u003c!-- DRF --\u003e\u003ca href=\"https://www.django-rest-framework.org/\"\u003e\u003cimg src=\"./images/django.svg\"\u003e\u003c/a\u003e\n\u003c!-- PostgreSQL --\u003e\u003ca href=\"https://www.postgresql.org/docs/\"\u003e\u003cimg src=\"./images/postgresql.svg\"\u003e\u003c/a\u003e\n\u003cbr /\u003e\n\u003c!-- Redis --\u003e\u003ca href=\"https://redis.io/documentation\"\u003e\u003cimg src=\"./images/redis.svg\"\u003e\u003c/a\u003e\n\u003c!-- Celery --\u003e\u003ca href=\"https://docs.celeryproject.org/en/stable/\"\u003e\u003cimg src=\"./images/celery.svg\"\u003e\u003c/a\u003e\n\u003c!-- Pillow --\u003e\u003ca href=\"https://pillow.readthedocs.io/en/stable/releasenotes/10.3.0.html\"\u003e\u003cimg src=\"./images/pillow.svg\"\u003e\u003c/a\u003e\n\u003cbr /\u003e\n\u003c!-- Docker --\u003e\u003ca href=\"https://docs.docker.com/\"\u003e\u003cimg src=\"./images/docker.svg\"\u003e\u003c/a\u003e\n\u003c!-- Uvicorn --\u003e\u003ca href=\"https://www.uvicorn.org/release-notes/\"\u003e\u003cimg src=\"./images/uvicorn.svg\"\u003e\u003c/a\u003e\n\u003c!-- Nginx --\u003e\u003ca href=\"https://nginx.org/en/docs/\"\u003e\u003cimg src=\"./images/nginx.svg\"\u003e\u003c/a\u003e\n\n\n\u003cdiv align=\"center\"\u003e\n  \u003ca href=\"https://github.com/meteopavel/Crowdfunding_API\"\u003e\n    \u003cimg src=\"./images/logo.svg\" alt=\"Logo\" width=\"250\" height=\"auto\"\u003e\n  \u003c/a\u003e\n  \u003ch1 align=\"center\"\u003eCrowdfunding API 🎉\u003c/h1\u003e\n  \u003cp align=\"center\"\u003e\n    🔧 RESTful API для групповых денежных сборов. Позволяет создавать, управлять и отслеживать сборы, а также делать пожертвования.\n    \u003cbr /\u003e\u003cbr /\u003e\n    \u003ca href=\"https://crowdfunding.meteopavel.space\"\u003eДемо версия\u003c/a\u003e\n    ·\n    \u003ca href=\"https://github.com/meteopavel/Crowdfunding_API/issues/new?labels=bug\"\u003eСообщить об ошибке\u003c/a\u003e\n    ·\n    \u003ca href=\"https://github.com/meteopavel/Crowdfunding_API/issues/new?labels=enhancement\"\u003eПредложить улучшение\u003c/a\u003e\n  \u003c/p\u003e\n\u003c/div\u003e\n\n\n## Особенности ✨\n- Полноценный CRUD для управления сборами 🛠️\n- Асинхронная отправка email-уведомлений 📧\n- Поддержка загрузки изображений для обложек сборов 🖼️\n- Документация API через Swagger 📚\n- Кэширование данных с использованием Redis ⚡\n- Менеджмент-команда для загрузки моковых данных 🛠️\n- Запуск проекта в Docker 🐳\n- Расширяемая архитектура для добавления новых функций 🔧\n\n## Технологический стек 💻\n- Backend : Django 5.2, Django REST Framework\n- База данных : PostgreSQL\n- Кэширование : Redis\n- Асинхронные задачи : Celery\n- Обработка изображений : Pillow\n- Контейнеризация : Docker\n- Веб-сервер : Nginx\n- Документация : Swagger (drf-yasg)\n\n## Установка и запуск 🚀\n1. Клонируйте репозиторий:\n    ```bash\n    git clone https://github.com/meteopavel/Crowdfunding_API.git\n    cd Crowdfunding_API\n    ```\n2. Создайте .env файл:\n   - Скопируйте .env.example в .env:\n      ```bash\n      cp .env.example .env\n      ```\n   - Заполните .env файл согласно вашим настройкам (например, данные для подключения к базе данных, Redis и SMTP).\n4. Запустите проект с помощью Docker:\n    ```bash\n    docker-compose up --build\n    ```\n4. API будет доступно по адресу:\n\n    http://localhost:8000\n\n## Документация API 📚\nДля просмотра документации API перейдите по адресу:\n\nhttp://localhost:8000/swagger/\n\n## Регистрация и использование JWT-токенов в API\n### Регистрация пользователя\n1. Откройте Swagger UI\n2. Найдите эндпоинт /register/\n3. Введите данные для регистрации (например, username, email, password)\n4. Нажмите \"Execute\"\n   \nПосле успешной регистрации пользователь получит письмо на указанный email с двумя токенами:\n\n- Access Token : Используется для авторизации в API.\n- Refresh Token : Используется для обновления Access Token.\n  \n### Авторизация через Swagger\nДля выполнения запросов к защищенным эндпоинтам (например, /api/collects/ или /api/payments/) необходимо использовать Access Token.\n\nКак авторизоваться в Swagger:\n1. Откройте Swagger UI\n2. В правом верхнем углу нажмите кнопку Authorize\n3. В открывшемся окне в поле \"Value\" введите ваш Access Token в формате:\n    ```\n    Bearer \u003cваш_access_token\u003e\n    ```\n    Например:\n\n    ```\n    Bearer eyJhbGciOiJIUzI1NiIsInR5cCI6IkpXVCJ9...\n    ```\n\n4. Нажмите \"Authorize\", затем \"Close\"\n   \nТеперь вы можете выполнять запросы к защищенным эндпоинтам от имени авторизованного пользователя.\n\n## Менеджмент-команда для загрузки моковых данных 🛠️\nДобавлена команда load_mock_data, которая генерирует тестовые данные для сборов и платежей. Это удобно для тестирования API или демонстрации функционала.\n```bash\npython manage.py load_mock_data\n```\n\n## Автор\n[Павел Найденов](https://github.com/meteopavel)","project_url":"https://awesome.ecosyste.ms/api/v1/projects/github.com%2Fmeteopavel%2Fcrowdfunding_api","html_url":"https://awesome.ecosyste.ms/projects/github.com%2Fmeteopavel%2Fcrowdfunding_api","lists_url":"https://awesome.ecosyste.ms/api/v1/projects/github.com%2Fmeteopavel%2Fcrowdfunding_api/lists"}