Code Monkey home page Code Monkey logo

brahimmade / foodgram-project-react Goto Github PK

View Code? Open in Web Editor NEW

This project forked from mikhailsoldatkin/foodgram-project-react

0.0 0.0 0.0 2.1 MB

Сервис для публикации кулинарных рецептов с возможностью формирования списка продуктов для нужных рецептов

Home Page: https://foodgramproject.ru

Shell 0.04% JavaScript 52.82% Python 11.07% CSS 35.38% HTML 0.60% Dockerfile 0.09%

foodgram-project-react's Introduction

Проект Foodgram

workflow

Foodgram - продуктовый помощник с базой кулинарных рецептов. Позволяет публиковать рецепты, сохранять избранные, а также формировать список покупок для выбранных рецептов. Можно подписываться на любимых авторов.

Проект доступен по адресу

Документация к API доступна здесь

В документации описаны возможные запросы к API и структура ожидаемых ответов. Для каждого запроса указаны уровни прав доступа.

Технологии:

Python, Django, Django Rest Framework, Docker, Gunicorn, NGINX, PostgreSQL, Yandex Cloud, Continuous Integration, Continuous Deployment

Развернуть проект на удаленном сервере:

  • Клонировать репозиторий:
https://github.com/mikhailsoldatkin/foodgram-project-react.git
  • Установить на сервере Docker, Docker Compose:
sudo apt install curl                                   # установка утилиты для скачивания файлов
curl -fsSL https://get.docker.com -o get-docker.sh      # скачать скрипт для установки
sh get-docker.sh                                        # запуск скрипта
sudo apt-get install docker-compose-plugin              # последняя версия docker compose
  • Скопировать на сервер файлы docker-compose.yml, nginx.conf из папки infra (команды выполнять находясь в папке infra):
scp docker-compose.yml nginx.conf username@IP:/home/username/   # username - имя пользователя на сервере
                                                                # IP - публичный IP сервера
  • Для работы с GitHub Actions необходимо в репозитории в разделе Secrets > Actions создать переменные окружения:
SECRET_KEY              # секретный ключ Django проекта
DOCKER_PASSWORD         # пароль от Docker Hub
DOCKER_USERNAME         # логин Docker Hub
HOST                    # публичный IP сервера
USER                    # имя пользователя на сервере
PASSPHRASE              # *если ssh-ключ защищен паролем
SSH_KEY                 # приватный ssh-ключ
TELEGRAM_TO             # ID телеграм-аккаунта для посылки сообщения
TELEGRAM_TOKEN          # токен бота, посылающего сообщение

DB_ENGINE               # django.db.backends.postgresql
DB_NAME                 # postgres
POSTGRES_USER           # postgres
POSTGRES_PASSWORD       # postgres
DB_HOST                 # db
DB_PORT                 # 5432 (порт по умолчанию)
  • Создать и запустить контейнеры Docker, выполнить команду на сервере (версии команд "docker compose" или "docker-compose" отличаются в зависимости от установленной версии Docker Compose):
sudo docker compose up -d
  • После успешной сборки выполнить миграции:
sudo docker compose exec backend python manage.py migrate
  • Создать суперпользователя:
sudo docker compose exec backend python manage.py createsuperuser
  • Собрать статику:
sudo docker compose exec backend python manage.py collectstatic --noinput
  • Наполнить базу данных содержимым из файла ingredients.json:
sudo docker compose exec backend python manage.py loaddata ingredients.json
  • Для остановки контейнеров Docker:
sudo docker compose down -v      # с их удалением
sudo docker compose stop         # без удаления

После каждого обновления репозитория (push в ветку master) будет происходить:

  1. Проверка кода на соответствие стандарту PEP8 (с помощью пакета flake8)
  2. Сборка и доставка докер-образов frontend и backend на Docker Hub
  3. Разворачивание проекта на удаленном сервере
  4. Отправка сообщения в Telegram в случае успеха

Запуск проекта на локальной машине:

  • Клонировать репозиторий:
https://github.com/mikhailsoldatkin/foodgram-project-react.git
  • В директории infra файл example.env переименовать в .env и заполнить своими данными:
DB_ENGINE=django.db.backends.postgresql
DB_NAME=postgres
POSTGRES_USER=postgres
POSTGRES_PASSWORD=postgres
DB_HOST=db
DB_PORT=5432
SECRET_KEY='секретный ключ Django'
  • Создать и запустить контейнеры Docker, как указано выше.

  • После запуска проект будут доступен по адресу: http://localhost/

  • Документация будет доступна по адресу: http://localhost/api/docs/

Автор backend'а:

Михаил Солдаткин (c) 2022

foodgram-project-react's People

Contributors

mikhailsoldatkin avatar

Recommend Projects

  • React photo React

    A declarative, efficient, and flexible JavaScript library for building user interfaces.

  • Vue.js photo Vue.js

    🖖 Vue.js is a progressive, incrementally-adoptable JavaScript framework for building UI on the web.

  • Typescript photo Typescript

    TypeScript is a superset of JavaScript that compiles to clean JavaScript output.

  • TensorFlow photo TensorFlow

    An Open Source Machine Learning Framework for Everyone

  • Django photo Django

    The Web framework for perfectionists with deadlines.

  • D3 photo D3

    Bring data to life with SVG, Canvas and HTML. 📊📈🎉

Recommend Topics

  • javascript

    JavaScript (JS) is a lightweight interpreted programming language with first-class functions.

  • web

    Some thing interesting about web. New door for the world.

  • server

    A server is a program made to process requests and deliver data to clients.

  • Machine learning

    Machine learning is a way of modeling and interpreting data that allows a piece of software to respond intelligently.

  • Game

    Some thing interesting about game, make everyone happy.

Recommend Org

  • Facebook photo Facebook

    We are working to build community through open source technology. NB: members must have two-factor auth.

  • Microsoft photo Microsoft

    Open source projects and samples from Microsoft.

  • Google photo Google

    Google ❤️ Open Source for everyone.

  • D3 photo D3

    Data-Driven Documents codes.