namespace Webzine.WebApplication.Controllers
{
using Microsoft.AspNetCore.Mvc;
using Webzine.Repository.Contracts;
using Webzine.WebApplication.ViewModels.Artiste;
///
///
///
public class ArtisteController : Controller
{
// Injection du logger via le constructeur
private readonly ILogger logger;
private readonly IArtisteRepository artisteRepository;
///
/// Initializes a new instance of the class.
/// Initialise une nouvelle instance du . avec un service de journalisation injecté.
///
/// Service de journalisation injecté pour enregistrer les événements et les erreurs.
///
public ArtisteController(
ILogger logger,
IArtisteRepository artisteRepository)
{
this.logger = logger;
this.logger.LogDebug("Initialisation du ArtisteController");
this.artisteRepository = artisteRepository;
}
///
/// Prend en paramètre le nom de l'artiste (ex: "fatal-bazooka"), utilise la factory pour trouver l'artiste correspondant, et affiche sa page dédiée.
///
/// Le nom de l'artiste à rechercher, formaté en kebab-case (ex: "fatal-bazooka").
/// La vue de l'artiste avec son ViewModel, ou une redirection vers l'accueil si le nom est vide, ou une erreur 404 si l'artiste n'est pas trouvé.
public IActionResult Index(string nom)
{
this.logger.LogInformation("Tentative d'accès à l'artiste avec le nom : {NomArtiste}", nom);
if (string.IsNullOrEmpty(nom))
{
this.logger.LogWarning("Nom de l'artiste manquant dans la requête.");
return this.RedirectToAction("Index", "Accueil");
}
// On transforme "fatal-bazooka" en "Fatal Bazooka" pour la factory
string nomPropre = System.Globalization.CultureInfo.CurrentCulture.TextInfo
.ToTitleCase(nom.Replace("-", " "));
// On appelle la factory pour obtenir l'artiste unique
var artiste = this.artisteRepository.FindByName(nomPropre);
// Check if artiste was found
if (artiste == null)
{
this.logger.LogWarning("Artiste non trouvé avec le nom : {NomArtiste}", nomPropre);
return this.RedirectToAction("Index", "Accueil");
}
var viewModel = new ArtisteDetailsViewModel
{
IdArtiste = artiste.IdArtiste,
Nom = artiste.Nom,
Biographie = artiste.Biographie,
AlbumsGroupes = artiste.Titres
.OrderBy(t => t.Libelle)
.GroupBy(t => t.Album)
.OrderBy(g => g.Key),
};
this.logger.LogInformation("Artiste trouvé : {NomArtiste}", nom);
return this.View(viewModel);
}
}
}