Smash test
test debug Result Disctinct by selector Refactoring Smash/Challonge Test Resultat Html for Kiouze
This commit is contained in:
23
LaDOSE.Src/LaDOSE.Service/Helper/DistinctBy.cs
Normal file
23
LaDOSE.Src/LaDOSE.Service/Helper/DistinctBy.cs
Normal file
@@ -0,0 +1,23 @@
|
||||
using System;
|
||||
using System.Collections;
|
||||
using System.Collections.Generic;
|
||||
|
||||
namespace LaDOSE.Business.Helper
|
||||
{
|
||||
public static class DataHelper
|
||||
{
|
||||
public static IEnumerable<T> DistinctBy<T,TKey>(this IEnumerable<T> lst,Func<T,TKey> dist)
|
||||
{
|
||||
var seen = new HashSet<TKey>();
|
||||
foreach (var e in lst)
|
||||
{
|
||||
|
||||
if (!seen.Contains(dist(e)))
|
||||
{
|
||||
seen.Add(dist(e));
|
||||
yield return e;
|
||||
}
|
||||
}
|
||||
}
|
||||
}
|
||||
}
|
||||
@@ -18,4 +18,5 @@ namespace LaDOSE.Business.Interface
|
||||
Task<ChallongeTournament> GetTournament(int idTournament);
|
||||
Task<ChallongeTournament> GetTournament(string urlTournament);
|
||||
}
|
||||
|
||||
}
|
||||
15
LaDOSE.Src/LaDOSE.Service/Interface/ISmashProvider.cs
Normal file
15
LaDOSE.Src/LaDOSE.Service/Interface/ISmashProvider.cs
Normal file
@@ -0,0 +1,15 @@
|
||||
using System;
|
||||
using System.Collections.Generic;
|
||||
using System.Threading.Tasks;
|
||||
using LaDOSE.Business.Provider.SmashProvider;
|
||||
using LaDOSE.Entity.Challonge;
|
||||
|
||||
namespace LaDOSE.Business.Interface
|
||||
{
|
||||
public interface ISmashProvider
|
||||
{
|
||||
Task<List<ChallongeTournament>> GetTournaments(DateTime? start, DateTime? end);
|
||||
Task<ResponseType> GetTournament(string sludge);
|
||||
|
||||
}
|
||||
}
|
||||
@@ -1,6 +1,7 @@
|
||||
using System;
|
||||
using System.Collections.Generic;
|
||||
using System.Threading.Tasks;
|
||||
using LaDOSE.Business.Provider.SmashProvider;
|
||||
using LaDOSE.Entity.Challonge;
|
||||
|
||||
namespace LaDOSE.Business.Interface
|
||||
@@ -10,5 +11,6 @@ namespace LaDOSE.Business.Interface
|
||||
Task<List<ChallongeTournament>> GetTournaments(DateTime? start, DateTime? end);
|
||||
|
||||
Task<TournamentsResult> GetTournamentsResult(List<int> ids);
|
||||
Task<TournamentsResult> GetSmashResult(string tournamentSlug);
|
||||
}
|
||||
}
|
||||
@@ -7,6 +7,11 @@
|
||||
<Platforms>AnyCPU;x64</Platforms>
|
||||
</PropertyGroup>
|
||||
|
||||
<ItemGroup>
|
||||
<PackageReference Include="GraphQL.Client" Version="4.0.2" />
|
||||
<PackageReference Include="GraphQL.Client.Serializer.Newtonsoft" Version="4.0.2" />
|
||||
</ItemGroup>
|
||||
|
||||
<ItemGroup>
|
||||
<ProjectReference Include="..\LaDOSE.Entity\LaDOSE.Entity.csproj" />
|
||||
</ItemGroup>
|
||||
|
||||
@@ -10,7 +10,7 @@ using ChallongeCSharpDriver.Core.Results;
|
||||
using LaDOSE.Business.Interface;
|
||||
using LaDOSE.Entity.Challonge;
|
||||
|
||||
namespace LaDOSE.Business.Provider
|
||||
namespace LaDOSE.Business.Provider.ChallongProvider
|
||||
{
|
||||
public class ChallongeProvider : IChallongeProvider
|
||||
{
|
||||
@@ -30,9 +30,9 @@ namespace LaDOSE.Business.Provider
|
||||
DernierTournois = "Aucun tournois.";
|
||||
}
|
||||
|
||||
public async Task<TournamentResult> CreateTournament(string name, string url,DateTime? startAt = null)
|
||||
public async Task<TournamentResult> CreateTournament(string name, string url, DateTime? startAt = null)
|
||||
{
|
||||
var result = await new CreateTournamentQuery(name, startAt , TournamentType.Double_Elimination, url).call(ApiCaller);
|
||||
var result = await new CreateTournamentQuery(name, startAt, TournamentType.Double_Elimination, url).call(ApiCaller);
|
||||
return result;
|
||||
|
||||
|
||||
@@ -50,13 +50,13 @@ namespace LaDOSE.Business.Provider
|
||||
{
|
||||
|
||||
List<TournamentResult> tournamentResultList = await new TournamentsQuery()
|
||||
{
|
||||
state = TournamentState.Ended,
|
||||
createdAfter = start,
|
||||
createdBefore = DateTime.Now,
|
||||
{
|
||||
state = TournamentState.Ended,
|
||||
createdAfter = start,
|
||||
createdBefore = DateTime.Now,
|
||||
|
||||
|
||||
}
|
||||
}
|
||||
.call(this.ApiCaller);
|
||||
List<ChallongeTournament> tournaments = new List<ChallongeTournament>();
|
||||
tournamentResultList.ForEach(w => tournaments.Add(new ChallongeTournament()
|
||||
@@ -70,7 +70,7 @@ namespace LaDOSE.Business.Provider
|
||||
|
||||
public async Task<List<ChallongeParticipent>> GetParticipents(int idTournament)
|
||||
{
|
||||
var participentResults = await new ParticipantsQuery(){tournamentID = idTournament }.call(ApiCaller);
|
||||
var participentResults = await new ParticipantsQuery() { tournamentID = idTournament }.call(ApiCaller);
|
||||
|
||||
List<ChallongeParticipent> participants = new List<ChallongeParticipent>();
|
||||
participentResults.ForEach(w =>
|
||||
@@ -86,7 +86,7 @@ namespace LaDOSE.Business.Provider
|
||||
IsMember = false,
|
||||
});
|
||||
}
|
||||
|
||||
|
||||
});
|
||||
return participants;
|
||||
}
|
||||
@@ -102,7 +102,7 @@ namespace LaDOSE.Business.Provider
|
||||
Name = tournamentResult.name,
|
||||
Url = tournamentResult.url,
|
||||
Participents = new List<ChallongeParticipent>()
|
||||
|
||||
|
||||
};
|
||||
|
||||
}
|
||||
@@ -136,7 +136,7 @@ namespace LaDOSE.Business.Provider
|
||||
|
||||
|
||||
var lastDate = tournamentResultList.Max(e => e.completed_at);
|
||||
|
||||
|
||||
if (lastDate.HasValue)
|
||||
{
|
||||
var lastRankingDate = new DateTime(lastDate.Value.Year, lastDate.Value.Month, lastDate.Value.Day);
|
||||
@@ -0,0 +1,120 @@
|
||||
using System;
|
||||
using System.Collections.Generic;
|
||||
using System.Threading.Tasks;
|
||||
using GraphQL;
|
||||
using GraphQL.Client.Http;
|
||||
using GraphQL.Client.Serializer.Newtonsoft;
|
||||
using LaDOSE.Business.Interface;
|
||||
using LaDOSE.Entity.Challonge;
|
||||
|
||||
namespace LaDOSE.Business.Provider.SmashProvider
|
||||
{
|
||||
public class SmashProvider : ISmashProvider
|
||||
{
|
||||
public string ApiKey { get; set; }
|
||||
public SmashProvider(string apiKey)
|
||||
{
|
||||
this.ApiKey = apiKey;
|
||||
}
|
||||
|
||||
public Task<List<ChallongeTournament>> GetTournaments(DateTime? start, DateTime? end)
|
||||
{
|
||||
var list = new List<ChallongeTournament>();
|
||||
var personAndFilmsRequest = new GraphQLRequest
|
||||
{
|
||||
Query = @"
|
||||
query TournamentsByOwner($perPage: Int!, $ownerId: ID!) {
|
||||
tournaments(query: {
|
||||
perPage: $perPage
|
||||
filter: {
|
||||
ownerId: $ownerId
|
||||
}
|
||||
}) {
|
||||
nodes {
|
||||
id
|
||||
name
|
||||
slug
|
||||
}
|
||||
}
|
||||
}",
|
||||
|
||||
OperationName = "PersonAndFilms",
|
||||
Variables = new
|
||||
{
|
||||
|
||||
ownerId = "161429",
|
||||
perPage = "4"
|
||||
|
||||
}
|
||||
};
|
||||
|
||||
|
||||
return Task.FromResult(list);
|
||||
}
|
||||
|
||||
public async Task<ResponseType> GetTournament(string slug)
|
||||
{
|
||||
var graphQLClient = new GraphQLHttpClient("https://api.smash.gg/gql/alpha", new NewtonsoftJsonSerializer());
|
||||
graphQLClient.HttpClient.DefaultRequestHeaders.Add("Authorization", $"Bearer {ApiKey}");
|
||||
var Event = new GraphQLRequest
|
||||
{
|
||||
Query = @"query TournamentQuery($slug: String) {
|
||||
tournament(slug: $slug){
|
||||
id
|
||||
name
|
||||
events {
|
||||
id
|
||||
name,
|
||||
state,
|
||||
videogame {
|
||||
id,
|
||||
name,
|
||||
displayName
|
||||
}
|
||||
standings(query: {page:0,perPage:500}){
|
||||
nodes{
|
||||
id,
|
||||
player{
|
||||
id,
|
||||
gamerTag,
|
||||
user {
|
||||
id,
|
||||
name,
|
||||
player {
|
||||
id
|
||||
}
|
||||
}
|
||||
}
|
||||
placement
|
||||
}
|
||||
|
||||
}
|
||||
}
|
||||
|
||||
}
|
||||
}",
|
||||
OperationName = "TournamentQuery",
|
||||
Variables = new
|
||||
{
|
||||
slug = slug,
|
||||
}
|
||||
};
|
||||
|
||||
//GraphQLHttpRequest preprocessedRequest = await graphQLClient.Options.PreprocessRequest(Event, graphQLClient);
|
||||
//var x = preprocessedRequest.ToHttpRequestMessage(graphQLClient.Options, new NewtonsoftJsonSerializer());
|
||||
//System.Diagnostics.Trace.WriteLine(x.Content.ReadAsStringAsync().Result);
|
||||
//var sendAsync = await graphQLClient.HttpClient.SendAsync(x);
|
||||
//System.Diagnostics.Trace.WriteLine(sendAsync.Content.ReadAsStringAsync().Result);
|
||||
|
||||
var graphQLResponse = await graphQLClient.SendQueryAsync<ResponseType>(Event);
|
||||
if (graphQLResponse.Errors != null)
|
||||
{
|
||||
//Event not done ?
|
||||
//throw new Exception("Error");
|
||||
}
|
||||
System.Diagnostics.Trace.Write(graphQLResponse.Data.Tournament.Name);
|
||||
|
||||
return graphQLResponse.Data;
|
||||
}
|
||||
}
|
||||
}
|
||||
@@ -0,0 +1,66 @@
|
||||
using System.Collections.Generic;
|
||||
|
||||
namespace LaDOSE.Business.Provider.SmashProvider
|
||||
{
|
||||
public class ResponseType
|
||||
{
|
||||
public TournamentType Tournament { get; set; }
|
||||
public class TournamentType
|
||||
{
|
||||
public int id { get; set; }
|
||||
|
||||
public string Name { get; set; }
|
||||
|
||||
public List<Event> Events { get; set; }
|
||||
|
||||
}
|
||||
|
||||
public class Event
|
||||
{
|
||||
public int id { get; set; }
|
||||
|
||||
public string name { get; set; }
|
||||
public string state { get; set; }
|
||||
|
||||
public VideoGame videogame { get; set; }
|
||||
public Node<Standing> standings { get; set; }
|
||||
}
|
||||
|
||||
public class VideoGame
|
||||
{
|
||||
public int id { get; set; }
|
||||
public string Name { get; set; }
|
||||
}
|
||||
|
||||
public class Node<T>
|
||||
{
|
||||
public List<T> nodes { get; set; }
|
||||
|
||||
}
|
||||
public class Standing
|
||||
{
|
||||
public int id { get; set; }
|
||||
|
||||
public int placement { get; set; }
|
||||
|
||||
public Player player { get; set; }
|
||||
}
|
||||
public class Player
|
||||
{
|
||||
public int id { get; set; }
|
||||
public string gamerTag { get; set; }
|
||||
public User user { get; set; }
|
||||
}
|
||||
public class User
|
||||
{
|
||||
public int id { get; set; }
|
||||
public string name { get; set; }
|
||||
|
||||
}
|
||||
|
||||
}
|
||||
|
||||
|
||||
|
||||
|
||||
}
|
||||
@@ -2,7 +2,9 @@
|
||||
using System.Collections.Generic;
|
||||
using System.Linq;
|
||||
using System.Threading.Tasks;
|
||||
using LaDOSE.Business.Helper;
|
||||
using LaDOSE.Business.Interface;
|
||||
using LaDOSE.Business.Provider.SmashProvider;
|
||||
using LaDOSE.Entity;
|
||||
using LaDOSE.Entity.Challonge;
|
||||
using LaDOSE.Entity.Context;
|
||||
@@ -50,12 +52,16 @@ namespace LaDOSE.Business.Service
|
||||
new Rules(16, 32, 12, 8, 5, 3, 2),
|
||||
new Rules(32, Int32.MaxValue, 18, 12, 8, 5, 3),
|
||||
};
|
||||
|
||||
private ISmashProvider _smashProvider;
|
||||
|
||||
#endregion
|
||||
|
||||
public TournamentService(LaDOSEDbContext context, IChallongeProvider challongeProvider) : base(context)
|
||||
public TournamentService(LaDOSEDbContext context, IChallongeProvider challongeProvider, ISmashProvider _smashProvider) : base(context)
|
||||
{
|
||||
this._context = context;
|
||||
this._challongeProvider = challongeProvider;
|
||||
this._smashProvider = _smashProvider;
|
||||
}
|
||||
|
||||
public async Task<List<ChallongeTournament>> GetTournaments(DateTime? start, DateTime? end)
|
||||
@@ -147,6 +153,89 @@ namespace LaDOSE.Business.Service
|
||||
return result;
|
||||
}
|
||||
|
||||
public async Task<TournamentsResult> GetSmashResult(string tournamentSlug)
|
||||
{
|
||||
var tournaments = await _smashProvider.GetTournament(tournamentSlug);
|
||||
var players = tournaments.Tournament.Events.Where(e=>e.standings != null ).SelectMany(e => e.standings.nodes.Select(e => e.player)).ToList();
|
||||
var distinctp = players.DistinctBy(e=>new {e.user.id}).ToList();
|
||||
var games = _context.Game.ToList();
|
||||
|
||||
TournamentsResult result = new TournamentsResult();
|
||||
result.Results = new List<Result>();
|
||||
result.Games = new List<Game>();
|
||||
result.Participents = new List<ChallongeParticipent>();
|
||||
distinctp.ForEach(e =>
|
||||
{
|
||||
var x = new ChallongeParticipent()
|
||||
{
|
||||
Name = e.gamerTag,
|
||||
ChallongeId = e.id,
|
||||
Id = e.id
|
||||
};
|
||||
result.Participents.Add(x);
|
||||
});
|
||||
games.ForEach(e =>
|
||||
{
|
||||
e.Id = e.SmashId ?? e.Id;
|
||||
result.Games.Add(e);
|
||||
});
|
||||
|
||||
foreach (var tournament in tournaments.Tournament.Events.Where(e=>e.standings!=null).ToList())
|
||||
{
|
||||
|
||||
|
||||
var playerCount = tournament.standings.nodes.Count;
|
||||
var lesSacs = tournament.standings.nodes;
|
||||
var currentRule = TournamentRules.FirstOrDefault(rules =>
|
||||
rules.PlayerMin < playerCount && rules.PlayerMax >= playerCount
|
||||
);
|
||||
if (currentRule == null)
|
||||
{
|
||||
throw new Exception("Unable to find rules");
|
||||
}
|
||||
|
||||
var first = tournament.standings.nodes.First(p => p.placement == 1);
|
||||
var second = tournament.standings.nodes.First(p => p.placement == 2);
|
||||
var thirdFourth = tournament.standings.nodes.Where(p => p.placement == 3 || p.placement == 4).ToList();
|
||||
var Top8 = tournament.standings.nodes.Where(p => p.placement > 4 && p.placement < 9).ToList();
|
||||
var Top16 = tournament.standings.nodes.Where(p => p.placement > 8 && p.placement <= 16).ToList();
|
||||
|
||||
result.Results.Add(new Result(first.player.gamerTag, tournament.videogame.id, tournament.id, tournament.name, currentRule.FirstPoint, first.placement));
|
||||
lesSacs.Remove(first);
|
||||
result.Results.Add(new Result(second.player.gamerTag, tournament.videogame.id, tournament.id, tournament.name, currentRule.SecondPoint, second.placement));
|
||||
lesSacs.Remove(second);
|
||||
thirdFourth.ForEach(r =>
|
||||
result.Results.Add(new Result(r.player.gamerTag, tournament.videogame.id, tournament.id, tournament.name,
|
||||
currentRule.ThirdFourthPoint, r.placement)));
|
||||
thirdFourth.ForEach(p => lesSacs.Remove(p));
|
||||
if (currentRule.Top8Point != 0)
|
||||
{
|
||||
Top8.ForEach(r =>
|
||||
result.Results.Add(new Result(r.player.gamerTag, tournament.videogame.id, tournament.id, tournament.name,
|
||||
currentRule.ThirdFourthPoint, r.placement)));
|
||||
Top8.ForEach(p => lesSacs.Remove(p));
|
||||
}
|
||||
|
||||
if (currentRule.Top16Point != 0)
|
||||
{
|
||||
Top16.ForEach(r =>
|
||||
result.Results.Add(
|
||||
new Result(r.player.gamerTag, tournament.videogame.id, tournament.id, tournament.name,
|
||||
currentRule.ThirdFourthPoint, r.placement)));
|
||||
Top16.ForEach(p => lesSacs.Remove(p));
|
||||
}
|
||||
|
||||
lesSacs.ForEach(r =>
|
||||
result.Results.Add(new Result(r.player.gamerTag, tournament.videogame.id, tournament.id, tournament.name,
|
||||
currentRule.ThirdFourthPoint, r.placement)));
|
||||
|
||||
}
|
||||
|
||||
|
||||
|
||||
return await Task.FromResult(result);
|
||||
}
|
||||
|
||||
/// <summary>
|
||||
/// Check if the tournament exist in database otherwise call Challonge.
|
||||
/// </summary>
|
||||
|
||||
Reference in New Issue
Block a user