Skip to content

Latest commit

 

History

History
182 lines (148 loc) · 3.42 KB

README.md

File metadata and controls

182 lines (148 loc) · 3.42 KB

store-backend-test-task

License: MIT author: Alex Lapin

Database Design

Description

This project was developed as a straightforward backend assignment with the goal of securing an opportunity for a job with a company specializing in SAAS-based e-commerce platforms. The primary aim of this task was to evaluate my ability to accomplish tasks and acquire knowledge within a limited timeframe.

Installation

  1. Clone this repo
git clone [email protected]:hex0gen/store-backend-test-task.git store.local
  1. Install all dependencies trough composer
cd store.local && composer install
  1. Copy configuration example and setup APP_URL (basiclly http://store.local) & DB credentials
cp .env.example .env 
  1. Generate APP_KEY
php artisan key:
  1. Run migration
php artisan migrate 

5.Run database seeder to make placeholder data

php artisan db:seed 

Run on Docker

get image from Hub

docker pull hexogen/store-local

build image

docker build -t store-local .

run container

docker run -d -p 80:80 store-local

How to use

I used YARC! on Chrome to make requests to API. Chrome Extension

API reference

Register new user:

POST URL:

http://store.local/api/v1/register 

Payload:

{"name": "user", "email": "[email protected]", "password": "12345678", "password_confirmation": "12345678"}

User authentication:

POST URL:

http://store.local/api/v1/login 

Payload:

{"name": "user", "password": "12345678"}

Authorize ur requests with tokens

POST URL:

http://store.local/api/v1/users/list

Headers

Authorization	Bearer {authorization_token}

Products

List all products

POST URL:

http://store.local/api/v1/products/list

Create Product (admins only)

POST URL:

http://store.local/api/v1/products/create

Payload:

{
    "name": "Название продукта",
    "price": 99.99,
    "image_path": "<путь к изображению>",
    "description": "Описание продукта",
    "is_available": 1
}

Edit Product (admins only)

POST URL:

http://store.local/api/v1/products/{product_id}/edit

Payload:

{
    "name": "Название продукта",
    "price": 99.99,
    "image_path": "<путь к изображению>",
    "description": "Описание продукта",
    "is_available": 0,
    "categories": ["Category 1", "Subcategory 2"]
}

Destroy Product (admins only)

POST URL:

http://store.local/api/v1/products/{product_id}/remove

Product categories

Create Category (admins only)

POST URL:

http://store.local/api/v1/category/create

Payload:

{
    "parent_id": 1,
    "slug": "cat1",
    "display_name": "Категория 1"
}

Working with cart

Add product to cart

POST URL:

http://store.local/api/v1/cart/create

Payload:

{
    "user_id": 1,
    "data": [1, 2] 
}

Remove product from cart

POST URL:

http://store.local/api/v1/cart/{product_id}/remove

Payload:

{
    "user_id": 1,
    "data": [1, 2] 
}