61 lines
1.4 KiB
PHP
61 lines
1.4 KiB
PHP
<?php
|
|
|
|
namespace App\Http\Controllers;
|
|
|
|
use App\Http\Requests\StoreCategoryRequest;
|
|
use App\Http\Requests\UpdateCategoryRequest;
|
|
use App\Http\Resources\CategoryResource;
|
|
use App\Models\Category;
|
|
|
|
class CategoryController extends Controller
|
|
{
|
|
/**
|
|
* Display a listing of the resource.
|
|
*/
|
|
public function index()
|
|
{
|
|
return CategoryResource::collection(Category::all());
|
|
}
|
|
|
|
/**
|
|
* Store a newly created resource in storage.
|
|
*/
|
|
public function store(StoreCategoryRequest $request)
|
|
{
|
|
return new CategoryResource(Category::create($request->validated()));
|
|
}
|
|
|
|
/**
|
|
* Display the specified resource.
|
|
*/
|
|
public function show(Category $category)
|
|
{
|
|
return new CategoryResource($category);
|
|
}
|
|
|
|
/**
|
|
* Update the specified resource in storage.
|
|
*/
|
|
public function update(UpdateCategoryRequest $request, Category $category)
|
|
{
|
|
$category->update($request->validated());
|
|
|
|
return new CategoryResource($category);
|
|
}
|
|
|
|
/**
|
|
* Remove the specified resource from storage.
|
|
*/
|
|
public function destroy(Category $category)
|
|
{
|
|
$user = auth()->user();
|
|
|
|
if (! $user || $user->email !== config('app.admin_email')) {
|
|
return response()->json(['message' => 'Forbidden'], 403);
|
|
}
|
|
|
|
$category->delete();
|
|
|
|
return response()->noContent();
|
|
}
|
|
}
|