Coder Social home page Coder Social logo

laravel-rest-api's Introduction

Универсальный REST API на Laravel

Позволяет работать с сущностью items как по API, так и через пользовательский интерфейс.

Установка

  1. Клонируйте репозиторий: git clone https://github.com/laravel-geek/laravel-rest-api.git
  2. Перейдите в директорию проекта: cd laravel-rest-api
  3. Установите зависимости: composer install
  4. Скопируйте файл .env.example в .env и настройте соединение с базой данных
  5. Запустите миграции: php artisan migrate
  6. Запустите сиды для заполнения таблицы тестовыми данными: php artisan db:seed

Использование

REST API

API работает со следующими методами:

Метод URI Описание
GET /api/v1/items Получить список всех items
GET /api/v1/items/{id} Получить информацию по ID
POST /api/v1/items Создать новый item
PUT/PATCH /api/v1/items/{id} Обновить информацию по ID
DELETE /api/v1/items/{id} Удалить item по ID

json

Пример запроса POST:

{
    "name": "Название элемента",
    "key": "Ключ элемента"
}

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

{
    "id": 1,
    "name": "Название элемента",
    "key": "Ключ элемента",
    "created_at": "2023-03-05T11:30:00.000000Z",
    "updated_at": "2023-03-05T11:30:00.000000Z"
}

Аутентификация, токен

Приложение использует аутентификацию с помощью Laravel Passport, поэтому для доступа к методам API необходимо получить токен. Для этого нужно отправить POST запрос на /api/login с полями email и password, и полученный токен использовать в заголовке Authorization: Bearer {token} при запросах к методам API.

composer require laravel/passport "~9.0"

В самом проекте аутентификация отключена. Для включения нужно раскомментить проверку в контроллере и зарегистрировать boot.

Истории изменений сущности

Для истории изменений сущности используется пакет Laravel Auditing - таблица audits.

composer require owen-it/laravel-auditing

Пользовательский интерфейс

Пользовательский интерфейс доступен по адресу /items.


ТЗ

REST API (CRUD) сервис

Необходимые возможности API:

  • Создание элементов
  • Обновление элементов
  • Удаление элементов
  • Получение информации об элементе
  • Валидация полей сущности

Возможное дополнение (будет плюсом, но не обязательно):

  • Пользовательский интерфейс для работы с сущностью
  • Использование token для доступа к данным
  • История изменений сущности Вводные данные:

Сущность: Item

Поля сущности:

  • id - int автоинкремент
  • name - char(255)
  • key - char(25) not null
  • created_at - datetime - дата создания элемента
  • updated_at - datetime - дата обновления элемента

PHP8, Laravel

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.