GameFinder.StoreHandlers.Steam 2.6.0

There is a newer version of this package available.
See the version list below for details.
dotnet add package GameFinder.StoreHandlers.Steam --version 2.6.0                
NuGet\Install-Package GameFinder.StoreHandlers.Steam -Version 2.6.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.Steam" Version="2.6.0" />                
For projects that support PackageReference, copy this XML node into the project file to reference the package.
paket add GameFinder.StoreHandlers.Steam --version 2.6.0                
#r "nuget: GameFinder.StoreHandlers.Steam, 2.6.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.Steam as a Cake Addin
#addin nuget:?package=GameFinder.StoreHandlers.Steam&version=2.6.0

// Install GameFinder.StoreHandlers.Steam as a Cake Tool
#tool nuget:?package=GameFinder.StoreHandlers.Steam&version=2.6.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.

Additionally, the following Linux tools are supported:

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.

Linux tools

Wine

GameFinder.Wine implements a IWinePrefixManager for finding Wineprefixes.

Usage:

var prefixManager = new DefaultWinePrefixManager(new FileSystem());

foreach (var result in prefixManager.FindPrefixes())
{
    result.Switch(prefix =>
    {
        Console.WriteLine($"Found wine prefix at {prefix.ConfigurationDirectory}");
    }, error =>
    {
        Console.WriteLine(error.Value);
    });
}

Bottles

GameFinder.Wine implements a IWinePrefixManager for finding Wine prefixes managed by Bottles.

Usage:

var prefixManager = new BottlesWinePrefixManager(new FileSystem());

foreach (var result in prefixManager.FindPrefixes())
{
    result.Switch(prefix =>
    {
        Console.WriteLine($"Found wine prefix at {prefix.ConfigurationDirectory}");
    }, error =>
    {
        Console.WriteLine(error.Value);
    });
}

Proton

Valve's Proton is a compatibility tool for Steam and is mostly based on Wine. The Wine prefixes managed by Proton are in the compatdata directory of the steam library where the game itself is installed. Since the path is relative to the game itself and requires the app id, I've decided to put this functionality in GameFinder.StoreHandlers.Steam:

SteamGame? steamGame = steamHandler.FindOneGameById(1237970, out var errors);
ProtonWinePrefix? protonPrefix = steamGame?.GetProtonPrefix();
var protonPrefixDirectory = protonPrefix?.ProtonDirectory;

if (protonDirectory is not null && Directory.Exists(protonDirectory))
{
    Console.WriteLine($"Proton prefix is at {protonDirectory}");
}

Contributing

See CONTRIBUTING for more information.

License

See LICENSE for more information.

Product Compatible and additional computed target framework versions.
.NET 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.  net9.0 was computed.  net9.0-android was computed.  net9.0-browser was computed.  net9.0-ios was computed.  net9.0-maccatalyst was computed.  net9.0-macos was computed.  net9.0-tvos was computed.  net9.0-windows was computed. 
Compatible target framework(s)
Included target framework(s) (in package)
Learn more about Target Frameworks and .NET Standard.

NuGet packages (7)

Showing the top 5 NuGet packages that depend on GameFinder.StoreHandlers.Steam:

Package Downloads
Mutagen.Bethesda.Core

A C# library for manipulating, creating, and analyzing Bethesda mods. Contains only the core components without the generated records.

GameFinder

Package Description

Mutagen.Bethesda.Core.Windows

A C# library for Mutagen features that only work on windows

PGCG.commonItems

Package Description

Wabbajack.Downloaders.GameFile

Package Description

GitHub repositories (2)

Showing the top 2 popular GitHub repositories that depend on GameFinder.StoreHandlers.Steam:

Repository Stars
wabbajack-tools/wabbajack
An automated Modlist installer for various games.
Mutagen-Modding/Mutagen
A .NET library for analyzing, creating, and manipulating Bethesda mods
Version Downloads Last updated
4.4.0 3,553 12/10/2024
4.3.3 14,771 10/31/2024
4.3.2 3,204 10/7/2024
4.3.1 981 10/1/2024
4.3.0 403 9/28/2024
4.2.4 33,161 7/4/2024
4.2.3 956 6/25/2024
4.2.2 6,071 6/6/2024
4.2.1 239 6/5/2024
4.2.0 13,486 1/28/2024
4.1.0 3,854 1/8/2024
4.0.0 7,820 9/3/2023
3.2.2 2,406 8/11/2023
3.2.1 1,673 7/25/2023
3.2.0 553 7/25/2023
3.1.0 2,698 5/23/2023
3.0.2 925 5/10/2023
3.0.1 493 5/10/2023
3.0.0 552 5/9/2023
2.6.0 2,108 3/7/2023
2.5.0 3,566 1/17/2023
2.4.0 124,457 1/13/2023
2.3.0 1,674 12/16/2022
2.2.2 7,875 11/11/2022
2.2.1 31,352 10/21/2022
2.2.0 742 10/21/2022
2.1.0 625 10/21/2022
2.0.1 642 10/19/2022
2.0.0 1,040 10/15/2022
1.8.0 16,949 6/27/2022
1.7.3 84,993 5/14/2022
1.7.2 63,747 11/10/2021
1.7.1 24,379 8/19/2021
1.7.0 31,557 8/9/2021
1.6.4 656 8/3/2021
1.6.3 1,562 7/30/2021
1.6.2 626 7/17/2021
1.6.1 1,054 7/10/2021
1.5.3 25,452 6/13/2021
1.5.2 525 6/9/2021
1.5.1 525 6/6/2021
1.5.0 16,458 5/29/2021
1.4.1 37,303 3/26/2021
1.4.0 553 3/26/2021
1.3.1 551 3/14/2021
1.3.0 601 3/13/2021
1.2.0 589 3/13/2021