New-Thanasoft/thanasoft-back/app/Http/Controllers/Api/SousTraitantController.php
2026-05-22 10:01:35 +03:00

191 lines
6.7 KiB
PHP

<?php
declare(strict_types=1);
namespace App\Http\Controllers\Api;
use App\Http\Controllers\Controller;
use App\Http\Requests\StoreSousTraitantRequest;
use App\Http\Requests\UpdateSousTraitantRequest;
use App\Http\Resources\SousTraitant\SousTraitantCollection;
use App\Http\Resources\SousTraitant\SousTraitantResource;
use App\Repositories\SousTraitantRepositoryInterface;
use Illuminate\Http\JsonResponse;
use Illuminate\Http\Request;
use Illuminate\Support\Facades\Log;
class SousTraitantController extends Controller
{
public function __construct(
private readonly SousTraitantRepositoryInterface $sousTraitantRepository
) {
}
public function index(Request $request): SousTraitantCollection|JsonResponse
{
try {
$perPage = $request->get('per_page', 15);
$filters = [
'search' => $request->get('search'),
'statut' => $request->get('statut'),
'sort_by' => $request->get('sort_by', 'created_at'),
'sort_direction' => $request->get('sort_direction', 'desc'),
];
$filters = array_filter($filters, function ($value) {
return $value !== null && $value !== '';
});
$sousTraitants = $this->sousTraitantRepository->paginate($perPage, $filters);
return new SousTraitantCollection($sousTraitants);
} catch (\Exception $e) {
Log::error('Error fetching sous-traitants: ' . $e->getMessage(), [
'exception' => $e,
'trace' => $e->getTraceAsString(),
]);
return response()->json([
'message' => 'Une erreur est survenue lors de la récupération des sous-traitants.',
'error' => config('app.debug') ? $e->getMessage() : null,
], 500);
}
}
public function store(StoreSousTraitantRequest $request): SousTraitantResource|JsonResponse
{
try {
$sousTraitant = $this->sousTraitantRepository->create($request->validated());
return new SousTraitantResource($sousTraitant);
} catch (\Exception $e) {
Log::error('Error creating sous-traitant: ' . $e->getMessage(), [
'exception' => $e,
'trace' => $e->getTraceAsString(),
'data' => $request->validated(),
]);
return response()->json([
'message' => 'Une erreur est survenue lors de la création du sous-traitant.',
'error' => config('app.debug') ? $e->getMessage() : null,
], 500);
}
}
public function show(string $id): SousTraitantResource|JsonResponse
{
try {
$sousTraitant = $this->sousTraitantRepository->find($id);
if (!$sousTraitant) {
return response()->json([
'message' => 'Sous-traitant non trouvé.',
], 404);
}
return new SousTraitantResource($sousTraitant);
} catch (\Exception $e) {
Log::error('Error fetching sous-traitant: ' . $e->getMessage(), [
'exception' => $e,
'trace' => $e->getTraceAsString(),
'sous_traitant_id' => $id,
]);
return response()->json([
'message' => 'Une erreur est survenue lors de la récupération du sous-traitant.',
'error' => config('app.debug') ? $e->getMessage() : null,
], 500);
}
}
public function searchBy(Request $request): JsonResponse
{
try {
$name = $request->get('name', '');
if (empty($name)) {
return response()->json([
'message' => 'Le paramètre "name" est requis.',
], 400);
}
$sousTraitants = $this->sousTraitantRepository->searchByName($name);
return response()->json([
'data' => $sousTraitants,
'count' => $sousTraitants->count(),
'message' => $sousTraitants->count() > 0
? 'Sous-traitants trouvés avec succès.'
: 'Aucun sous-traitant trouvé.',
], 200);
} catch (\Exception $e) {
Log::error('Error searching sous-traitants by name: ' . $e->getMessage(), [
'exception' => $e,
'trace' => $e->getTraceAsString(),
]);
return response()->json([
'message' => 'Une erreur est survenue lors de la recherche des sous-traitants.',
'error' => config('app.debug') ? $e->getMessage() : null,
], 500);
}
}
public function update(UpdateSousTraitantRequest $request, string $id): SousTraitantResource|JsonResponse
{
try {
$updated = $this->sousTraitantRepository->update($id, $request->validated());
if (!$updated) {
return response()->json([
'message' => 'Sous-traitant non trouvé ou échec de la mise à jour.',
], 404);
}
$sousTraitant = $this->sousTraitantRepository->find($id);
return new SousTraitantResource($sousTraitant);
} catch (\Exception $e) {
Log::error('Error updating sous-traitant: ' . $e->getMessage(), [
'exception' => $e,
'trace' => $e->getTraceAsString(),
'sous_traitant_id' => $id,
'data' => $request->validated(),
]);
return response()->json([
'message' => 'Une erreur est survenue lors de la mise à jour du sous-traitant.',
'error' => config('app.debug') ? $e->getMessage() : null,
], 500);
}
}
public function destroy(string $id): JsonResponse
{
try {
$deleted = $this->sousTraitantRepository->delete($id);
if (!$deleted) {
return response()->json([
'message' => 'Sous-traitant non trouvé ou échec de la suppression.',
], 404);
}
return response()->json([
'message' => 'Sous-traitant supprimé avec succès.',
], 200);
} catch (\Exception $e) {
Log::error('Error deleting sous-traitant: ' . $e->getMessage(), [
'exception' => $e,
'trace' => $e->getTraceAsString(),
'sous_traitant_id' => $id,
]);
return response()->json([
'message' => 'Une erreur est survenue lors de la suppression du sous-traitant.',
'error' => config('app.debug') ? $e->getMessage() : null,
], 500);
}
}
}