#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

@@ -1,7 +1,5 @@
using Microsoft.AspNetCore.Mvc;
using Webzine.Entity.Fixtures;
using Webzine.WebApplication.ViewModels;
using Webzine.WebApplication.ViewModels.Artiste;
namespace Webzine.WebApplication.Controllers
{
@@ -16,7 +14,7 @@ namespace Webzine.WebApplication.Controllers
/// <param name="logger">Service de journalisation injecté pour enregistrer les événements et les erreurs.</param>
public ArtisteController(ILogger<ArtisteController> logger)
{
_logger = logger;
this._logger = logger;
this._logger.LogDebug(1, "initialisation du ArtisteController");
}
@@ -28,9 +26,13 @@ namespace Webzine.WebApplication.Controllers
[HttpGet("/artiste/{nom}")]
public IActionResult Index(string nom)
{
_logger.LogInformation("Tentative d'accès à l'artiste avec le nom : {NomArtiste}", nom);
this._logger.LogInformation("Tentative d'accès à l'artiste avec le nom : {NomArtiste}", nom);
if (string.IsNullOrEmpty(nom)) return RedirectToAction("Index", "Accueil");
if (string.IsNullOrEmpty(nom))
{
this._logger.LogWarning("Nom de l'artiste manquant dans la requête.");
return RedirectToAction("Index", "Accueil");
}
// On transforme "fatal-bazooka" en "Fatal Bazooka" pour la factory
string nomPropre = System.Globalization.CultureInfo.CurrentCulture.TextInfo
@@ -41,20 +43,13 @@ namespace Webzine.WebApplication.Controllers
if (artiste == null)
{
_logger.LogWarning("Artiste non trouvé pour le nom : {NomArtiste}", nomPropre);
return NotFound();
this._logger.LogWarning("Artiste non trouvé pour le nom : {NomArtiste}", nomPropre);
return RedirectToAction("Index");
}
_logger.LogInformation("Artiste trouvé : {NomArtiste}", nom);
this._logger.LogInformation("Artiste trouvé : {NomArtiste}", nom);
// On remplit le ViewModel
var viewModel = new ArtisteModel
{
Artiste = artiste,
Titres = artiste.Titres
};
return View(viewModel);
return View(artiste);
}
}
}

View File

@@ -16,7 +16,7 @@ namespace Webzine.WebApplication.Controllers
/// <param name="logger">Service de journalisation injecté pour enregistrer les événements et les erreurs.</param>
public ContactController(ILogger<ContactController> logger)
{
_logger = logger;
this._logger = logger;
this._logger.LogDebug(1, "initialisation du ContactController");
}

View File

@@ -13,14 +13,14 @@ public class RechercheController : Controller
public RechercheController(ILogger<RechercheController> logger, ITitreRepository titreRepository)
{
_logger = logger;
_titreRepository = titreRepository;
this._logger = logger;
this._titreRepository = titreRepository;
}
[HttpPost("")]
public IActionResult Index(string mot)
{
_logger.LogInformation("Recherche artistes/titres pour le mot : {Mot}.", mot);
this._logger.LogInformation("Recherche artistes/titres pour le mot : {Mot}.", mot);
var titres = _titreRepository.Search(mot)
.Concat(_titreRepository.SearchByStyle(mot))

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