#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:
@@ -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);
|
||||
}
|
||||
}
|
||||
}
|
||||
|
||||
@@ -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");
|
||||
}
|
||||
|
||||
|
||||
@@ -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))
|
||||
|
||||
@@ -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
|
||||
|
||||
Reference in New Issue
Block a user