trip-planner/backend/app/Infrastructure/Http/Controllers/API/Trip/TripController.php

94 lines
2.6 KiB
PHP
Raw Normal View History

2025-09-27 03:59:37 +02:00
<?php
2025-09-27 11:52:59 +02:00
namespace App\Infrastructure\Http\Controllers\API\Trip;
2025-09-27 03:59:37 +02:00
use App\Domain\Trip\Policies\TripPolicy;
2025-09-27 11:52:59 +02:00
use App\Infrastructure\Http\Controllers\Controller;
2025-09-27 03:59:37 +02:00
use App\Models\Trip;
use Illuminate\Http\Request;
use Illuminate\Http\JsonResponse;
class TripController extends Controller
{
public function __construct(
private TripPolicy $policy
) {}
2025-09-27 03:59:37 +02:00
/**
* Display a listing of the resource.
*/
public function index(Request $request): JsonResponse
{
$trips = Trip::where('created_by_user_id', $request->user()->id)
->orderBy('created_at', 'desc')
->get();
2025-09-30 08:29:17 +02:00
return response()->json(['data' => $trips]);
2025-09-27 03:59:37 +02:00
}
/**
* Store a newly created resource in storage.
*/
public function store(Request $request): JsonResponse
{
$validated = $request->validate([
'name' => 'required|string|max:255',
'description' => 'nullable|string',
'start_date' => 'nullable|date',
'end_date' => 'nullable|date|after_or_equal:start_date',
]);
$validated['created_by_user_id'] = $request->user()->id;
$trip = Trip::create($validated);
2025-09-30 08:29:17 +02:00
return response()->json(['data' => $trip], 201);
2025-09-27 03:59:37 +02:00
}
/**
* Display the specified resource.
*/
public function show(Request $request, Trip $trip): JsonResponse
2025-09-27 03:59:37 +02:00
{
if (!$this->policy->view($request->user(), $trip)) {
return response()->json(['message' => 'Forbidden'], 403);
}
2025-09-27 03:59:37 +02:00
2025-09-30 08:29:17 +02:00
return response()->json(['data' => $trip]);
2025-09-27 03:59:37 +02:00
}
/**
* Update the specified resource in storage.
*/
public function update(Request $request, Trip $trip): JsonResponse
2025-09-27 03:59:37 +02:00
{
if (!$this->policy->update($request->user(), $trip)) {
return response()->json(['message' => 'Forbidden'], 403);
}
2025-09-27 03:59:37 +02:00
$validated = $request->validate([
'name' => 'required|string|max:255',
'description' => 'nullable|string',
'start_date' => 'nullable|date',
'end_date' => 'nullable|date|after_or_equal:start_date',
]);
$trip->update($validated);
2025-09-30 08:29:17 +02:00
return response()->json(['data' => $trip]);
2025-09-27 03:59:37 +02:00
}
/**
* Remove the specified resource from storage.
*/
public function destroy(Request $request, Trip $trip): JsonResponse
2025-09-27 03:59:37 +02:00
{
if (!$this->policy->delete($request->user(), $trip)) {
return response()->json(['message' => 'Forbidden'], 403);
}
2025-09-27 03:59:37 +02:00
$trip->delete();
return response()->json(['message' => 'Trip deleted successfully']);
}
}