GameFinder.StoreHandlers.EADesktop 2.5.0

There is a newer version of this package available.
See the version list below for details.
dotnet add package GameFinder.StoreHandlers.EADesktop --version 2.5.0                
NuGet\Install-Package GameFinder.StoreHandlers.EADesktop -Version 2.5.0                
This command is intended to be used within the Package Manager Console in Visual Studio, as it uses the NuGet module's version of Install-Package.
<PackageReference Include="GameFinder.StoreHandlers.EADesktop" Version="2.5.0" />                
For projects that support PackageReference, copy this XML node into the project file to reference the package.
paket add GameFinder.StoreHandlers.EADesktop --version 2.5.0                
#r "nuget: GameFinder.StoreHandlers.EADesktop, 2.5.0"                
#r directive can be used in F# Interactive and Polyglot Notebooks. Copy this into the interactive tool or source code of the script to reference the package.
// Install GameFinder.StoreHandlers.EADesktop as a Cake Addin
#addin nuget:?package=GameFinder.StoreHandlers.EADesktop&version=2.5.0

// Install GameFinder.StoreHandlers.EADesktop as a Cake Tool
#tool nuget:?package=GameFinder.StoreHandlers.EADesktop&version=2.5.0                

GameFinder

CI codecov

.NET library for finding games. The following launchers are supported:

The following launchers are not yet supported or support has been dropped:

If you are interested in understanding how GameFinder finds these games, check the wiki for more information.

Supported Launchers

Steam

Steam is supported on Windows and Linux. Use SteamDB to find the ID of a game.

Usage:

// use the Windows registry on Windows
// Linux doesn't have a registry
var handler = RuntimeInformation.IsOSPlatform(OSPlatform.Windows)
    ? new SteamHandler(new WindowsRegistry())
    : new SteamHandler(registry: null);

// method 1: iterate over the game-error result
foreach (var (game, error) in handler.FindAllGames())
{
    if (game is not null)
    {
        Console.WriteLine($"Found {game}");
    }
    else
    {
        Console.WriteLine($"Error: {error}");
    }
}

// method 2: use the dictionary if you need to find games by id
Dictionary<SteamGame, int> games = handler.FindAllGamesById(out string[] errors);

// method 3: find a single game by id
SteamGame? game = handler.FindOneGameById(570940, out string[] errors);

GOG Galaxy

GOG Galaxy is only supported on Windows. Use the GOG Database to find the ID of a game.

Usage:

var handler = new GOGHandler();

// method 1: iterate over the game-error result
foreach (var (game, error) in handler.FindAllGames())
{
    if (game is not null)
    {
        Console.WriteLine($"Found {game}");
    }
    else
    {
        Console.WriteLine($"Error: {error}");
    }
}

// method 2: use the dictionary if you need to find games by id
Dictionary<GOGGame, long> games = handler.FindAllGamesById(out string[] errors);

// method 3: find a single game by id
GOGGame? game = handler.FindOneGameById(1971477531, out string[] errors);

Epic Games Store

Epic Games Store is only supported on Windows.

Usage:

var handler = new EGSHandler();

// method 1: iterate over the game-error result
foreach (var (game, error) in handler.FindAllGames())
{
    if (game is not null)
    {
        Console.WriteLine($"Found {game}");
    }
    else
    {
        Console.WriteLine($"Error: {error}");
    }
}

// method 2: use the dictionary if you need to find games by id
Dictionary<EGSGame, string> games = handler.FindAllGamesById(out string[] errors);

// method 3: find a single game by id
EGSGame? game = handler.FindOneGameById("3257e06c28764231acd93049f3774ed6", out string[] errors);

Origin

Origin is only supported on Windows. Note: EA is deprecating Origin and will replace it with EA Desktop.

Usage:

var handler = new OriginHandler();

// method 1: iterate over the game-error result
foreach (var (game, error) in handler.FindAllGames())
{
    if (game is not null)
    {
        Console.WriteLine($"Found {game}");
    }
    else
    {
        Console.WriteLine($"Error: {error}");
    }
}

// method 2: use the dictionary if you need to find games by id
Dictionary<OriginGame, string> games = handler.FindAllGamesById(out string[] errors);

// method 3: find a single game by id
OriginGame? game = handler.FindOneGameById("Origin.OFR.50.0001456", out string[] errors);

EA Desktop

EA Desktop is the replacement for Origin: See EA is deprecating Origin. This is by far, the most complicated Store Handler. You should read the wiki entry. My implementation decrypts the encrypted file, created by EA Desktop. You should be aware that the key used to encrypt the file is derived from hardware information. If the user changes their hardware, the decryption process might fail because they key has changed.

Usage:

var handler = new EADesktopHandler();

// method 1: iterate over the game-error result
foreach (var (game, error) in handler.FindAllGames())
{
    if (game is not null)
    {
        Console.WriteLine($"Found {game}");
    }
    else
    {
        Console.WriteLine($"Error: {error}");
    }
}

// method 2: use the dictionary if you need to find games by id
Dictionary<EADesktopGame, string> games = handler.FindAllGamesById(out string[] errors);

// method 3: find a single game by id
EADesktopGame? game = handler.FindOneGameById("Origin.SFT.50.0000532", out string[] errors);

Bethesda.net

As of May 11, 2022, the Bethesda.net launcher is no longer in use. The package GameFinder.StoreHandlers.BethNet has been deprecated and marked as legacy.

Xbox Game Pass

The package GameFinder.StoreHandlers.Xbox has been deprecated and marked as legacy. I no longer maintain this package because it never got used. I initially made GameFinder for Wabbajack and other modding tools however, you can't mod games installed with the Xbox App on Windows. These games are installed as UWP apps, which makes them protected and hard to modify. Another issue is the fact that you can't distinguish between normal UWP apps and Xbox games, meaning your calculator will show up as an Xbox game.

The final issue is related to actual code: in order to find all UWP apps I used the Windows SDK, which was a pain to integrate. The CI had to be on Windows, the .NET target framework had to be a Windows specific version (net6.0-windows-XXXXXXXXXX), and it was overall not nice to use.

The package is still available on NuGet and should still work, but it's marked as deprecated and won't receive any updates.

Contributing

See CONTRIBUTING for more information.

License

See LICENSE for more information.

Product Compatible and additional computed target framework versions.
.NET net6.0 is compatible.  net6.0-android was computed.  net6.0-ios was computed.  net6.0-maccatalyst was computed.  net6.0-macos was computed.  net6.0-tvos was computed.  net6.0-windows was computed.  net7.0 is compatible.  net7.0-android was computed.  net7.0-ios was computed.  net7.0-maccatalyst was computed.  net7.0-macos was computed.  net7.0-tvos was computed.  net7.0-windows was computed.  net8.0 was computed.  net8.0-android was computed.  net8.0-browser was computed.  net8.0-ios was computed.  net8.0-maccatalyst was computed.  net8.0-macos was computed.  net8.0-tvos was computed.  net8.0-windows was computed. 
Compatible target framework(s)
Included target framework(s) (in package)
Learn more about Target Frameworks and .NET Standard.

NuGet packages (2)

Showing the top 2 NuGet packages that depend on GameFinder.StoreHandlers.EADesktop:

Package Downloads
GameFinder

Package Description

Wabbajack.Downloaders.GameFile

Package Description

GitHub repositories (1)

Showing the top 1 popular GitHub repositories that depend on GameFinder.StoreHandlers.EADesktop:

Repository Stars
wabbajack-tools/wabbajack
An automated Modlist installer for various games.
Version Downloads Last updated
4.3.3 1,818 10/31/2024
4.3.2 1,844 10/7/2024
4.3.1 806 10/1/2024
4.3.0 292 9/28/2024
4.2.4 11,276 7/4/2024
4.2.3 139 6/25/2024
4.2.2 4,413 6/6/2024
4.2.1 100 6/5/2024
4.2.0 10,781 1/28/2024
4.1.0 3,568 1/8/2024
4.0.0 3,366 9/3/2023
3.2.2 1,210 8/11/2023
3.2.1 821 7/25/2023
3.2.0 210 7/25/2023
3.1.0 1,265 5/23/2023
3.0.2 227 5/10/2023
3.0.1 170 5/10/2023
3.0.0 206 5/9/2023
2.6.0 237 3/7/2023
2.5.0 1,923 1/17/2023