CrockoMan / db_api

API проекта db_api собирает отзывы пользователей на произведения.

Geek Repo:Geek Repo

Github PK Tool:Github PK Tool

db_api

Стек: Python, Django, DRF, JWT
db_api
API проекта db_api собирает отзывы пользователей на произведения.

Произведения делятся на категории, такие как «Книги», «Фильмы», «Музыка». Например, в категории «Книги» могут быть произведения «Винни-Пух и все-все-все» и «Марсианские хроники», а в категории «Музыка» — песня «Давеча» группы «Жуки» и вторая сюита Баха. Список категорий может быть расширен (например, можно добавить категорию «Изобразительное искусство» или «Ювелирка»).

Произведению может быть присвоен жанр из списка предустановленных (например, «Сказка», «Рок» или «Артхаус»). Добавлять произведения, категории и жанры может только администратор.

Благодарные или возмущённые пользователи оставляют к произведениям текстовые отзывы и ставят произведению оценку в диапазоне от одного до десяти (целое число); из пользовательских оценок формируется усреднённая оценка произведения — рейтинг (целое число). На одно произведение пользователь может оставить только один отзыв. Пользователи могут оставлять комментарии к отзывам.

Добавлять отзывы, комментарии и ставить оценки могут только аутентифицированные пользователи.

Как запустить проект:

Клонировать репозиторий и перейти в него в командной строке:

git [git@github.com:CrockoMan/api_yamdb.git](https://github.com/CrockoMan/db_api.git)
cd db_ap

Cоздать и активировать виртуальное окружение:

python3 -m venv env
source env/bin/activate

Установить зависимости из файла requirements.txt:

python3 -m pip install --upgrade pip
pip install -r requirements.txt

Выполнить миграции:

python3 manage.py migrate

Возможно загрузить предварительно подготовленные cvs файлы с данными в БД

python3 manage.py load_csv

Запустить проект:

python3 manage.py runserver

Алгоритм регистрации пользователей

Пользователь отправляет POST-запрос на добавление нового пользователя с параметрами email и username на эндпоинт http://127.0.0.1:8000/api/v1/auth/signup/.

POST
{
  "email": "user@example.com",
  "username": "string"
}

Response
{
  "email": "string",
  "username": "string"
}

YaMDB отправляет письмо с кодом подтверждения (confirmation_code) на адрес email.

Пользователь отправляет POST-запрос с параметрами username и confirmation_code на эндпоинт http://127.0.0.1:8000/api/v1/auth/token/, в ответе на запрос ему приходит token (JWT-токен).

POST
{
  "username": "string",
  "confirmation_code": "string"
}

Response
{
  "token": "string"
}

При желании пользователь отправляет PATCH-запрос на эндпоинт http://127.0.0.1:8000/api/v1/users/me/ и заполняет поля в своём профайле

Категории (типы) произведений

http://127.0.0.1:8000/api/v1/categories/

GET
{
  "count": 0,
  "next": "string",
  "previous": "string",
  "results": [
    {
      "name": "string",
      "slug": "string"
    }
  ]
}
POST
{
  "name": "string",
  "slug": "string"
}

Response
{
  "name": "string",
  "slug": "string"
}
DEL
<http://127.0.0.1:8000/api/v1/categories/{slug}/><br />

Жанры произведений

http://127.0.0.1:8000/api/v1/genres/

GET
{
  "count": 0,
  "next": "string",
  "previous": "string",
  "results": [
    {
      "name": "string",
      "slug": "string"
    }
  ]
}
POST
{
  "name": "string",
  "slug": "string"
}

Response
{
  "name": "string",
  "slug": "string"
}
DEL
<http://127.0.0.1:8000/api/v1/genres/{slug}/><br />

Произведения, к которым пишут отзывы (определённый фильм, книга или песенка).

Получить список всех объектов
http://127.0.0.1:8000/api/v1/titles/

GET
Response
{
  "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"
      }
    }
  ]
}

Добавить новое произведение. При добавлении нового произведения требуется указать уже существующие категорию и жанр.
http://127.0.0.1:8000/api/v1/titles/

POST
{
  "name": "string",
  "year": 0,
  "description": "string",
  "genre": [
    "string"
  ],
  "category": "string"
}

Response
{
  "id": 0,
  "name": "string",
  "year": 0,
  "rating": 0,
  "description": "string",
  "genre": [
    {
      "name": "string",
      "slug": "string"
    }
  ],
  "category": {
    "name": "string",
    "slug": "string"
  }
}

Работа с произведением
http://127.0.0.1:8000/api/v1/titles/{titles_id}/

Получение информации о произведении

GET

Response
{
  "id": 0,
  "name": "string",
  "year": 0,
  "rating": 0,
  "description": "string",
  "genre": [
    {
      "name": "string",
      "slug": "string"
    }
  ],
  "category": {
    "name": "string",
    "slug": "string"
  }
}

Частичное обновление информации о произведении

PATCH
{
  "name": "string",
  "year": 0,
  "description": "string",
  "genre": [
    "string"
  ],
  "category": "string"
}

Response
{
  "id": 0,
  "name": "string",
  "year": 0,
  "rating": 0,
  "description": "string",
  "genre": [
    {
      "name": "string",
      "slug": "string"
    }
  ],
  "category": {
    "name": "string",
    "slug": "string"
  }
}

Удаление произведения

DEL

Отзывы

<http://127.0.0.1:8000/api/v1/titles/{title_id}/reviews/

Получение списка всех отзывов

GET

Respone
{
  "count": 0,
  "next": "string",
  "previous": "string",
  "results": [
    {
      "id": 0,
      "text": "string",
      "author": "string",
      "score": 1,
      "pub_date": "2019-08-24T14:15:22Z"
    }
  ]
}

Добавить новый отзыв.

POST
{
  "text": "string",
  "score": 1
}

Response
{
  "id": 0,
  "text": "string",
  "author": "string",
  "score": 1,
  "pub_date": "2019-08-24T14:15:22Z"
}

Получить отзыв по id для указанного произведения
<http://127.0.0.1:8000/api/v1/titles/{title_id}/reviews/{review_id}/

GET

Response
{
  "id": 0,
  "text": "string",
  "author": "string",
  "score": 1,
  "pub_date": "2019-08-24T14:15:22Z"
}

Частично обновить отзыв по id
<http://127.0.0.1:8000/api/v1/titles/{title_id}/reviews/{review_id}/

PATCH
{
  "text": "string",
  "score": 1
}

Response
{
  "id": 0,
  "text": "string",
  "author": "string",
  "score": 1,
  "pub_date": "2019-08-24T14:15:22Z"
}

Удаление отзыва по id
<http://127.0.0.1:8000/api/v1/titles/{title_id}/reviews/{review_id}/

DEL

Комментарии к отзывам

<http://127.0.0.1:8000/api/v1/titles/{title_id}/reviews/{review_id}/comments/

GET

Response
{
  "count": 0,
  "next": "string",
  "previous": "string",
  "results": [
    {
      "id": 0,
      "text": "string",
      "author": "string",
      "pub_date": "2019-08-24T14:15:22Z"
    }
  ]
}

Добавление комментария к отзыву
<http://127.0.0.1:8000/api/v1/titles/{title_id}/reviews/{review_id}/comments/

POST
{
  "text": "string"
}

Response
{
  "id": 0,
  "text": "string",
  "author": "string",
  "pub_date": "2019-08-24T14:15:22Z"
}

Получить комментарий для отзыва по id
<http://127.0.0.1:8000/api/v1/titles/{title_id}/reviews/{review_id}/comments/{comment_id}/

GET

Response
{
  "id": 0,
  "text": "string",
  "author": "string",
  "pub_date": "2019-08-24T14:15:22Z"
}

Частично обновить комментарий к отзыву по id
<http://127.0.0.1:8000/api/v1/titles/{title_id}/reviews/{review_id}/comments/{comment_id}/

PATCH
{
  "text": "string"
}

Response
{
  "id": 0,
  "text": "string",
  "author": "string",
  "pub_date": "2019-08-24T14:15:22Z"
}

Удалить комментарий к отзыву по id
<http://127.0.0.1:8000/api/v1/titles/{title_id}/reviews/{review_id}/comments/{comment_id}/

DELETE

Работа с пользователями

http://127.0.0.1:8000/api/v1/users/

Получить список всех пользователей.

GET

Response
{
  "count": 0,
  "next": "string",
  "previous": "string",
  "results": [
    {
      "username": "string",
      "email": "user@example.com",
      "first_name": "string",
      "last_name": "string",
      "bio": "string",
      "role": "user"
    }
  ]
}

Добавить нового пользователя
http://127.0.0.1:8000/api/v1/users/

POST
{
  "username": "string",
  "email": "user@example.com",
  "first_name": "string",
  "last_name": "string",
  "bio": "string",
  "role": "user"
}

Response
{
  "username": "string",
  "email": "user@example.com",
  "first_name": "string",
  "last_name": "string",
  "bio": "string",
  "role": "user"
}

Получить пользователя по username.
http://127.0.0.1:8000/api/v1/users/{username}/

GET

Response
{
  "username": "string",
  "email": "user@example.com",
  "first_name": "string",
  "last_name": "string",
  "bio": "string",
  "role": "user"
}

Изменить данные пользователя по username.
http://127.0.0.1:8000/api/v1/users/{username}/

PATCH
{
  "username": "string",
  "email": "user@example.com",
  "first_name": "string",
  "last_name": "string",
  "bio": "string",
  "role": "user"
}

Response
{
  "username": "string",
  "email": "user@example.com",
  "first_name": "string",
  "last_name": "string",
  "bio": "string",
  "role": "user"
}

Удалить пользователя по username
http://127.0.0.1:8000/api/v1/users/{username}/

DELETE

Изменить данные своей учетной записи
http://127.0.0.1:8000/api/v1/users/{username}/

PATCH
{
  "username": "string",
  "email": "user@example.com",
  "first_name": "string",
  "last_name": "string",
  "bio": "string"
}

Response
{
  "username": "string",
  "email": "user@example.com",
  "first_name": "string",
  "last_name": "string",
  "bio": "string",
  "role": "user"
}

Документация доступна по адресу http://127.0.0.1:8000/redoc/

Автор: К.Гурашкин А.Копнин М.Плевин

About

API проекта db_api собирает отзывы пользователей на произведения.


Languages

Language:Python 99.0%Language:Shell 0.6%Language:HTML 0.4%