TrueMain

Projet personnel autour de League of Legends : agréger et fiabiliser les statistiques de champions des meilleurs joueurs (top OTP, mains uniques) afin de proposer des recommandations de builds basées sur les vraies pratiques pro/high-elo plutôt que sur des moyennes globales. Développé en solo depuis février 2026, c'est l'occasion de monter une stack moderne complète : .NET 10, ASP.NET Core, un Worker Service pour ingérer en continu l'API Riot Games, PostgreSQL via Entity Framework Core, et un front Nuxt 4. Le tout conteneurisé avec Docker pour un déploiement simple.
février 2026League of Legends.NET 10ASP.NET CoreWorker ServiceNuxt 4PostgreSQLDocker

Projet personnel autour de League of Legends : agréger et fiabiliser les statistiques de champions des meilleurs joueurs (top OTP, mains uniques) afin de proposer des recommandations de builds basées sur les vraies pratiques pro/high-elo plutôt que sur des moyennes globales. Développé en solo depuis février 2026, c'est l'occasion de monter une stack moderne complète : .NET 10, ASP.NET Core, un Worker Service pour ingérer en continu l'API Riot Games, PostgreSQL via Entity Framework Core, et un front Nuxt 4. Le tout conteneurisé avec Docker pour un déploiement simple.

février 2026 Stage → Alternance

Points clés

  • Architecture découpée : API ASP.NET Core (REST), Worker Service pour l'ingestion asynchrone et front Nuxt 4 pour la consultation.
  • Persistance PostgreSQL pilotée par Entity Framework Core (migrations, requêtes typées, indexation des matchs et builds).
  • Conteneurisation Docker (API, Worker, base) pour un environnement reproductible en dev comme en déploiement.

Stack

.NET 10ASP.NET CoreWorker ServiceEntity Framework CorePostgreSQLNuxt 4TypeScriptDocker

Backend ASP.NET Core

  • API REST pour exposer joueurs, champions, builds et statistiques agrégées.
  • Authentification et limites d'usage gérées proprement, documentation Swagger.

Worker Service d'ingestion

  • Consommation continue de l'API Riot Games avec respect des quotas (rate limiting).
  • Pipeline de mise à jour incrémentale des matchs et de calcul des statistiques par champion.

Front Nuxt 4

  • Pages de recherche de joueurs et de comparaison de builds par champion.
  • Composants typés en TypeScript, SSR pour le SEO.

Infrastructure

  • docker-compose pour orchestrer API + Worker + PostgreSQL.
  • Migrations EF Core versionnées et reproductibles.

Performance & rate limiting

  • Anticipation des quotas Riot Games (app rate limit + method rate limit) : mutualisation des appels, file d'attente, back-off exponentiel.
  • Estimation de la montée en charge sur l'ingestion : nombre de matchs / minute, taille moyenne du payload, capacité visée de la base.
  • Tableau de suivi des métriques d'ingestion (matchs traités/min, latence p95) pour piloter les ajustements.

Profilage & optimisation

  • Profilage des requêtes EF Core : analyse du SQL généré, ajout d'index ciblés (matchs par joueur, builds par champion).
  • Mise en cache mémoire des appels lecture les plus chauds pour absorber les pics de trafic front.
  • Justification documentée des choix d'optimisation dans le README technique.
© 2026 Ilyan Fraimbault