2020-01-03 17:03:09 +00:00
|
|
|
|
using System;
|
|
|
|
|
using System.Collections.Generic;
|
|
|
|
|
using System.Linq;
|
2020-04-28 22:52:20 +00:00
|
|
|
|
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);
|
2020-04-22 12:24:49 +00:00
|
|
|
|
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;
|
2021-06-02 19:27:44 +00:00
|
|
|
|
var res = handler.FindAllGames();
|
2021-07-11 10:13:33 +00:00
|
|
|
|
if (!res) return;
|
2021-06-02 19:27:44 +00:00
|
|
|
|
|
2021-03-26 11:35:27 +00:00
|
|
|
|
foreach (var game in handler.Games)
|
|
|
|
|
{
|
2021-07-16 12:10:46 +00:00
|
|
|
|
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
|
|
|
|
}
|
|
|
|
|
|
2020-04-09 18:57:02 +00:00
|
|
|
|
public AbsolutePath? TryGetGamePath(Game game)
|
2020-01-03 17:03:09 +00:00
|
|
|
|
{
|
2021-07-16 12:10:46 +00:00
|
|
|
|
if (!Games.TryGetValue(game, out var storeGame))
|
|
|
|
|
return null;
|
|
|
|
|
|
|
|
|
|
return (AbsolutePath)storeGame.Path;
|
2020-01-03 17:03:09 +00:00
|
|
|
|
}
|
2020-04-28 22:52:20 +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
|
|
|
|
}
|
|
|
|
|
}
|
|
|
|
|
}
|