#89 Supprimer les méthodes de controllers inutiles, les using non utilisés. Remplacer NotFound par des redirections vers les index et des logs.

This commit is contained in:
josephine.vetu
2026-03-25 10:47:52 +01:00
parent 175a3083fe
commit bea1e21039
19 changed files with 76 additions and 158 deletions

View File

@@ -23,10 +23,10 @@ public class TitreController : Controller
/// <param name="titreRepository">Repository des titres injecte.</param>
public TitreController(ILogger<TitreController> logger, ITitreRepository titreRepository)
{
_logger = logger;
_titreRepository = titreRepository;
this._logger = logger;
this._titreRepository = titreRepository;
_logger.LogInformation("Initialisation du controleur TitreController.");
this._logger.LogInformation("Initialisation du controleur TitreController.");
}
/// <summary>
@@ -37,14 +37,14 @@ public class TitreController : Controller
[HttpGet("{id}")]
public IActionResult Details(int id)
{
_logger.LogInformation("Demande d'affichage du detail pour le titre ID {Id}.", id);
this._logger.LogInformation("Demande d'affichage du detail pour le titre ID {Id}.", id);
var titre = FindById(id);
var titre = this._titreRepository.Find(id);
if (titre == null)
{
_logger.LogWarning("Titre avec ID {Id} introuvable.", id);
return NotFound();
this._logger.LogWarning("Titre avec ID {Id} introuvable.", id);
return RedirectToAction("Index");
}
var vm = new TitreDetail
@@ -79,7 +79,7 @@ public class TitreController : Controller
[HttpGet("style/{style}")]
public IActionResult Style(string style)
{
_logger.LogInformation("Recherche des titres pour le style : {Style}.", style);
this._logger.LogInformation("Recherche des titres pour le style : {Style}.", style);
var titresFiltres = _titreRepository.SearchByStyle(style).ToList();
@@ -102,15 +102,12 @@ public class TitreController : Controller
{
this._logger.LogInformation("Ajout d'un like pour le titre ID {Id}.", model.IdTitre);
var titre = FindById(model.IdTitre); //TODO appeler directement le repository pour éviter une requête supplémentaire
var titre = this._titreRepository.Find(model.IdTitre);
// TODO faut mettre des autres cas d'erreur, ça va faire un 404
if (titre == null)
{
_logger.LogWarning("Impossible d'ajouter un like. Titre ID {Id} introuvable.", model.IdTitre);
return NotFound(); // TODO va pas faire une page d'erreur personnalisée, ça va faire un 404
// faudrait faire une page d'erreur personnalisée pour les 404, et pas juste un message d'erreur dans la console
// ou rediriger vers page accueil si le titre est pas trouvé, ça serait plus user-friendly
this._logger.LogWarning("Impossible d'ajouter un like. Titre ID {Id} introuvable.", model.IdTitre);
return RedirectToAction("Index");
}
titre.NbLikes++;
@@ -128,16 +125,16 @@ public class TitreController : Controller
{
if (!ModelState.IsValid)
{
_logger.LogWarning("Echec de validation du modele de commentaire pour le titre ID {Id}.", model.IdTitre);
this._logger.LogWarning("Echec de validation du modele de commentaire pour le titre ID {Id}.", model.IdTitre);
return RedirectToAction("Details", new { id = model.IdTitre });
}
var titre = FindById(model.IdTitre);
var titre = this._titreRepository.Find(model.IdTitre);
if (titre == null)
{
_logger.LogWarning("Impossible d'ajouter le commentaire. Titre ID {Id} introuvable.", model.IdTitre);
return NotFound();
this._logger.LogWarning("Impossible d'ajouter le commentaire. Titre ID {Id} introuvable.", model.IdTitre);
return RedirectToAction("Index");
}
var commentaire = new Commentaire
@@ -150,16 +147,11 @@ public class TitreController : Controller
titre.Commentaires.Add(commentaire);
_logger.LogInformation("Commentaire ajoute avec succes au titre ID {Id}.", model.IdTitre);
this._logger.LogInformation("Commentaire ajoute avec succes au titre ID {Id}.", model.IdTitre);
return RedirectToAction("Details", new { id = model.IdTitre });
}
private Titre? FindById(int id) // TODO virer ça vu que ça appelle directement le repository
{
return _titreRepository.Find(id);
}
private static TitreStyleItem MapTitreItem(Titre titre)
{
return new TitreStyleItem