- schema for cart and product - define relationship, DTO, Resource and API collections - Add post and get endpoint for cart api
29 lines
1.1 KiB
PHP
29 lines
1.1 KiB
PHP
<?php
|
|
|
|
use App\Http\Controllers\AuthenticatedUserController;
|
|
use App\Http\Controllers\CartController;
|
|
use App\Http\Controllers\FavouriteProductController;
|
|
use App\Http\Controllers\ProductCategoryController;
|
|
use App\Http\Controllers\ProductController;
|
|
use App\Http\Controllers\ProductImagesController;
|
|
use App\Http\Controllers\RegisteredUserController;
|
|
use Illuminate\Support\Facades\Route;
|
|
|
|
Route::middleware('guest')->group(function () {
|
|
Route::post('/register', RegisteredUserController::class);
|
|
});
|
|
|
|
Route::middleware('auth:sanctum')->group(function () {
|
|
Route::get('/user', [AuthenticatedUserController::class, 'show']);
|
|
Route::post('/logout', [AuthenticatedUserController::class, 'destroy']);
|
|
Route::post('/upload/images', action: [ProductImagesController::class, 'store']);
|
|
|
|
// Favorites
|
|
Route::post('/products/{product}/favorite', [FavouriteProductController::class, 'toggle']);
|
|
|
|
Route::post('/cart', [CartController::class, 'store']);
|
|
Route::get('/cart', [CartController::class, 'show']);
|
|
});
|
|
Route::get('/categories', [ProductCategoryController::class, 'index']);
|
|
Route::apiResource('products', ProductController::class);
|