Skip to content

Alexsiiassa/api_final_yatube

Folders and files

NameName
Last commit message
Last commit date

Latest commit

 

History

10 Commits
 
 
 
 
 
 
 
 
 
 
 
 
 
 

Repository files navigation

REST API для проекта Yatube

Содержимое файла requirements: Django==2.2.16, pytest==6.2.4, pytest-pythonpath==0.7.3, pytest-django==4.4.0, djangorestframework==3.12.4, djangorestframework-simplejwt==4.7.2, Pillow==8.3.1, PyJWT==2.1.0, requests==2.26.0

Установка:

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

git clone https://github.com/Alexsiiassa/api_final_yatube cd api_final_yatube 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 Запустить проект:

python3 manage.py runserver

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

API доступен только аутентифицированным пользователям. В проекте аутентификация осуществляется по токену. Реализована аутентификация по JWT-токену.

Когда вы запустите проект, по адресу http://127.0.0.1:8000/redoc/ будет доступна документация для API Yatube. В документации описано, как как работает API. Документация представлена в формате Redoc.

Аутентифицированный пользователь авторизован на изменение и удаление своего контента; в остальных случаях доступ предоставляется только для чтения. При попытке изменить чужие данные должен возвращаться код ответа 403 Forbidden.

Эндпоинты Для взаимодействия с ресурсами:

api/v1/api-token-auth/ (POST): передаём логин и пароль, получаем токен. api/v1/posts/ (GET, POST): получаем список всех постов или создаём новый пост. api/v1/posts/{post_id}/ (GET, PUT, PATCH, DELETE): получаем, редактируем или удаляем пост по id. api/v1/groups/ (GET): получаем список всех групп. api/v1/groups/{group_id}/ (GET): получаем информацию о группе по id. api/v1/posts/{post_id}/comments/ (GET, POST): получаем список всех комментариев поста с id=post_id или создаём новый, указав id поста, который хотим прокомментировать. api/v1/posts/{post_id}/comments/{comment_id}/ (GET, PUT, PATCH,

DELETE): получаем, редактируем или удаляем комментарий по id у поста с id=post_id. В ответ на запросы POST, PUT и PATCH ваш API возвращает объект, который был добавлен или изменён.

Работа с моделью Post осуществляется через через ModelViewSet.

В проекте описана модель Follow, в ней два поля — user (кто подписан) и following (на кого подписан). Для этой модели в документации уже описан эндпоинт /follow/ и два метода:

GET — возвращает все подписки пользователя, сделавшего запрос. Возможен поиск по подпискам по параметру search POST — подписать пользователя, сделавшего запрос на пользователя, переданного в теле запроса. При попытке подписаться на самого себя, пользователь получит информативное сообщение об ошибке. Проверка должна осуществляться на уровне API. Анонимный пользователь на запросы к этому эндпоинту получает ответ с кодом 401 Unauthorized.

При запросе на изменение или удаление данных осуществляется проверка прав доступа.

Примеры запросов Пример POST-запроса с токеном: добавление нового поста. POST .../api/v1/posts/

{ "text": "Текст поста" }

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

{ "id": 1, "text": "Текст поста", "author": "newuser", "image": null, "group": 1, "pub_date": "2022-03-16 12:20:7.057939" }

Пример POST-запроса с токеном newuser: отправляем новый комментарий к посту с id=1. POST .../api/v1/posts/1/comments/

{ "text": "тест тест", }

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

{ "id": 2, "author": "anton", "post": 1, "text": "тест тест", "created": "2022-03-16 12:20:7.057939" }

Пример GET-запроса с токеном newuser: получаем информацию о группе. GET .../api/v1/groups/13/

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

{ "id": 13, "title": "Group_13", "slug": "something", "description": "Просто посты" }