wabbajack/Wabbajack.Common/StoreHandlers/StoreHandler.cs

122 lines
4.7 KiB
C#
Raw Normal View History

2020-01-03 17:03:09 +00:00
using System;
using System.Collections.Generic;
using System.Linq;
using System.Threading.Tasks;
2021-03-26 11:35:27 +00:00
using GameFinder;
using GameFinder.StoreHandlers.BethNet;
using GameFinder.StoreHandlers.EGS;
using GameFinder.StoreHandlers.GOG;
2021-07-11 10:13:33 +00:00
using GameFinder.StoreHandlers.Origin;
2021-03-26 11:35:27 +00:00
using GameFinder.StoreHandlers.Steam;
2021-07-11 10:13:33 +00:00
using Microsoft.Extensions.Logging;
2020-01-03 17:03:09 +00:00
namespace Wabbajack.Common.StoreHandlers
{
public class StoreHandler
{
2021-07-16 12:17:06 +00:00
2021-03-26 11:35:27 +00:00
private static readonly Lazy<StoreHandler> _instance = new(() => new StoreHandler(), isThreadSafe: true);
public static StoreHandler Instance => _instance.Value;
2020-01-03 17:03:09 +00:00
2021-07-16 12:17:06 +00:00
private static readonly Lazy<SteamHandler> SteamHandler = new(() => new SteamHandler(new StoreHandlerLogger("Steam")));
private static readonly Lazy<GOGHandler> GogHandler = new(() => new GOGHandler(new StoreHandlerLogger("GOG")));
private static readonly Lazy<BethNetHandler> BethNetHandler = new(() => new BethNetHandler(new StoreHandlerLogger("BethNet")));
private static readonly Lazy<EGSHandler> EpicGameStoreHandler = new(() => new EGSHandler(new StoreHandlerLogger("EGS")));
private static readonly Lazy<OriginHandler> OriginHandler = new(() => new OriginHandler(true, true, new StoreHandlerLogger("Origin")));
2020-01-03 17:03:09 +00:00
2021-07-11 10:13:33 +00:00
private readonly List<AStoreGame> _storeGames;
2021-03-26 11:35:27 +00:00
public Dictionary<Game, AStoreGame> Games = new();
2021-03-26 18:27:16 +00:00
private void FindGames<THandler, TGame>(Lazy<THandler> lazyHandler, string name)
2021-03-26 11:35:27 +00:00
where THandler : AStoreHandler<TGame>
where TGame : AStoreGame
2020-01-03 17:03:09 +00:00
{
2021-03-26 11:35:27 +00:00
try
2020-01-03 17:03:09 +00:00
{
2021-03-26 18:27:16 +00:00
var handler = lazyHandler.Value;
var res = handler.FindAllGames();
2021-07-11 10:13:33 +00:00
if (!res) return;
2021-03-26 11:35:27 +00:00
foreach (var game in handler.Games)
{
Utils.Log($"{handler.StoreType}: Found game {game} at \"{game.Path}\"");
2021-03-26 13:23:23 +00:00
_storeGames.Add(game);
2021-03-26 11:35:27 +00:00
}
2020-01-03 17:03:09 +00:00
}
2021-03-26 11:35:27 +00:00
catch (Exception e)
2020-04-22 12:02:58 +00:00
{
2021-03-26 18:27:16 +00:00
Utils.Error(e, $"Could not load all Games from {name}");
2020-04-22 12:02:58 +00:00
}
2021-03-26 11:35:27 +00:00
}
public StoreHandler()
{
2021-03-26 13:23:23 +00:00
_storeGames = new List<AStoreGame>();
2020-12-16 21:41:28 +00:00
2021-07-11 10:13:33 +00:00
FindGames<SteamHandler, SteamGame>(SteamHandler, "SteamHandler");
FindGames<GOGHandler, GOGGame>(GogHandler, "GOGHandler");
FindGames<BethNetHandler, BethNetGame>(BethNetHandler, "BethNetHandler");
FindGames<EGSHandler, EGSGame>(EpicGameStoreHandler, "EGSHandler");
FindGames<OriginHandler, OriginGame>(OriginHandler, "OriginHandler");
2021-03-26 11:35:27 +00:00
2021-03-26 13:23:23 +00:00
foreach (var storeGame in _storeGames)
2021-03-26 11:35:27 +00:00
{
IEnumerable<KeyValuePair<Game, GameMetaData>>? enumerable = storeGame switch
{
SteamGame steamGame => GameRegistry.Games.Where(y => y.Value.SteamIDs?.Contains(steamGame.ID) ?? false),
GOGGame gogGame => GameRegistry.Games.Where(y => y.Value.GOGIDs?.Contains(gogGame.GameID) ?? false),
BethNetGame bethNetGame => GameRegistry.Games.Where(y => y.Value.BethNetID.Equals((int)bethNetGame.ID)),
EGSGame egsGame => GameRegistry.Games.Where(y => y.Value.EpicGameStoreIDs.Contains(egsGame.CatalogItemId ?? string.Empty)),
2021-07-11 10:13:33 +00:00
OriginGame originGame => GameRegistry.Games.Where(y => y.Value.OriginIDs.Contains(originGame.Id ?? string.Empty)),
2021-03-26 11:35:27 +00:00
_ => null
};
if (enumerable == null) continue;
var list = enumerable.ToList();
if (list.Count == 0) continue;
2021-03-26 12:14:17 +00:00
var game = list.First().Key;
if (Games.ContainsKey(game)) continue;
2021-03-26 11:35:27 +00:00
2021-03-26 12:14:17 +00:00
Games.Add(game, storeGame);
2021-03-26 11:35:27 +00:00
}
2020-01-03 17:03:09 +00:00
}
public AbsolutePath? TryGetGamePath(Game game)
2020-01-03 17:03:09 +00:00
{
if (!Games.TryGetValue(game, out var storeGame))
return null;
return (AbsolutePath)storeGame.Path;
2020-01-03 17:03:09 +00:00
}
public static void Warmup()
{
Task.Run(() => _instance.Value).FireAndForget();
}
2020-01-03 17:03:09 +00:00
}
2021-07-11 10:13:33 +00:00
internal class StoreHandlerLogger : ILogger
2020-01-03 17:03:09 +00:00
{
2021-07-16 12:17:06 +00:00
private readonly string _name;
public StoreHandlerLogger(string name)
{
_name = name;
}
2021-07-11 10:13:33 +00:00
public void Log<TState>(LogLevel logLevel, EventId eventId, TState state, Exception exception, Func<TState, Exception, string> formatter)
2020-01-03 17:03:09 +00:00
{
2021-07-16 12:17:06 +00:00
Utils.Log($"{_name}: {formatter(state, exception)}");
2021-07-11 10:13:33 +00:00
}
2020-01-03 17:03:09 +00:00
2021-07-11 10:13:33 +00:00
public bool IsEnabled(LogLevel logLevel) => true;
public IDisposable BeginScope<TState>(TState state)
{
throw new NotImplementedException();
2020-01-03 17:03:09 +00:00
}
}
}