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); } } }