Coder Social home page Coder Social logo

alekseikoznov / yamdb Goto Github PK

View Code? Open in Web Editor NEW
0.0 1.0 0.0 28 KB

YaMDb - это каталог рейтингов и отзывов о художественных произведениях, написанный с помощью Django Rest Framework. Проект развертывается с использованием Docker контейнеров.

Python 97.70% Dockerfile 0.49% HTML 1.81%

yamdb's Introduction

Проект YAMDB

Описание проекта:

Проект YAMDB представляет собой платформу, которая функционирует как цифровой каталог, содержащий разнообразные художественные произведения. В этом каталоге разделены на несколько основных категорий, таких как "Книги", "Фильмы" и "Музыка".

Основной функциональностью YaMDb является возможность оценивания и обсуждения произведений. Пользователи могут оценивать произведения, выставлять им рейтинги и оставлять отзывы. Кроме того, к отзывам также можно добавлять комментарии. Проект предоставляет удобную среду для обмена мнениями и рецензиями на различные художественные работы.

Проект упакован в Docker контейнеры:

  • Контейнер для Django-проекта использует образ python:3.7-slim.
  • Контейнер для базы данных Postgres использует образ postgres:13.0-alpine.
  • Контейнер для веб-сервера Nginx использует образ nginx:1.21.3-alpine.

Документация проекта:

После запуска сервиса докуменация доступна по адресу: http://localhost/redoc

Технологии проекта:

  • Python 3.7
  • Django 2.2.16
  • Django rest framework 3.12.4
  • Gunicorn 20.0.4
  • Psycopg2 binary 2.9.3

Запуск приложения в контейнерах:

Для запуска приложения в контейнерах необходимо:

  1. Клонировать репозиторий и перейти в директорию с файлом docker-compose.yaml:
git clone [email protected]:alekseikoznov/yamdb.git
cd yamdb/infra
  1. Создать файл .env с переменными окружения. Пример наполнения:
DB_ENGINE=django.db.backends.postgresql
DB_NAME=postgres
POSTGRES_USER=postgres
POSTGRES_PASSWORD=password123
DB_HOST=db
DB_PORT=5432
  1. Открыть терминал и запустить docker-compose с ключом -d:
docker-compose up -d
  1. Выполнить миграции, создать суперюзера, собрать статику:
docker-compose exec web python manage.py migrate
docker-compose exec web python manage.py createsuperuser
docker-compose exec web python manage.py collectstatic --no-input
  1. После успешного запуска проект станет доступен по адресу:
    http://localhost/

Примеры запросов к API:

Получение списка всех произведений: GET http://localhost/api/v1/titles/

Пример ответа:

{
  [
  {
    "count": 0,
    "next": "string",
    "previous": "string",
    "results": [
      {
        "id": 0,
        "name": "string",
        "year": 0,
        "rating": 0,
        "description": "string",
        "genre": [
          {
            "name": "string",
            "slug": "string"
          }
        ],
        "category": {
          "name": "string",
          "slug": "string"
        }
      }
    ]
  }
]
}

Добавление новой категории: POST http://localhost/api/v1/categories/

{
  "name": "string",
  "slug": "string"
}

Пример ответа:

{
  "name": "string",
  "slug": "string"
}

yamdb's People

Contributors

alekseikoznov avatar

Watchers

 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.