mirror of
https://github.com/wabbajack-tools/wabbajack.git
synced 2024-08-30 18:42:17 +00:00
Implemented the full stack of Steam 2FA and logins and the like
This commit is contained in:
parent
cd324905dd
commit
bf843f9289
@ -11,6 +11,7 @@ using Octokit;
|
||||
using Wabbajack.CLI.TypeConverters;
|
||||
using Wabbajack.CLI.Verbs;
|
||||
using Wabbajack.DTOs.GitHub;
|
||||
using Wabbajack.DTOs.Interventions;
|
||||
using Wabbajack.Networking.Http;
|
||||
using Wabbajack.Networking.Http.Interfaces;
|
||||
using Wabbajack.Networking.WabbajackClientApi;
|
||||
@ -63,6 +64,9 @@ internal class Program
|
||||
services.AddSingleton<IVerb, GenerateMetricsReports>();
|
||||
services.AddSingleton<IVerb, ForceHeal>();
|
||||
services.AddSingleton<IVerb, MirrorFile>();
|
||||
services.AddSingleton<IVerb, SteamLogin>();
|
||||
|
||||
services.AddSingleton<IUserInterventionHandler, UserInterventionHandler>();
|
||||
}).Build();
|
||||
|
||||
var service = host.Services.GetService<CommandLineBuilder>();
|
||||
|
27
Wabbajack.CLI/UserInterventionHandler.cs
Normal file
27
Wabbajack.CLI/UserInterventionHandler.cs
Normal file
@ -0,0 +1,27 @@
|
||||
using System;
|
||||
using Wabbajack.DTOs.Interventions;
|
||||
using Wabbajack.Networking.Steam.UserInterventions;
|
||||
|
||||
namespace Wabbajack.CLI;
|
||||
|
||||
public class UserInterventionHandler : IUserInterventionHandler
|
||||
{
|
||||
public void Raise(IUserIntervention intervention)
|
||||
{
|
||||
if (intervention is GetAuthCode gac)
|
||||
{
|
||||
switch (gac.Type)
|
||||
{
|
||||
case GetAuthCode.AuthType.EmailCode:
|
||||
Console.WriteLine("Please enter the Steam code that was just emailed to you");
|
||||
break;
|
||||
case GetAuthCode.AuthType.TwoFactorAuth:
|
||||
Console.WriteLine("Please enter your 2FA code for Steam");
|
||||
break;
|
||||
default:
|
||||
throw new ArgumentOutOfRangeException();
|
||||
}
|
||||
gac.Finish(Console.ReadLine()!.Trim());
|
||||
}
|
||||
}
|
||||
}
|
58
Wabbajack.CLI/Verbs/SteamLogin.cs
Normal file
58
Wabbajack.CLI/Verbs/SteamLogin.cs
Normal file
@ -0,0 +1,58 @@
|
||||
using System;
|
||||
using System.CommandLine;
|
||||
using System.CommandLine.Invocation;
|
||||
using System.Threading.Tasks;
|
||||
using Microsoft.Extensions.Logging;
|
||||
using Wabbajack.Networking.Http.Interfaces;
|
||||
using Wabbajack.Networking.Steam;
|
||||
using Wabbajack.Paths;
|
||||
|
||||
namespace Wabbajack.CLI.Verbs;
|
||||
|
||||
public class SteamLogin : IVerb
|
||||
{
|
||||
private readonly ILogger<SteamLogin> _logger;
|
||||
private readonly Client _client;
|
||||
private readonly ITokenProvider<SteamLoginState> _token;
|
||||
|
||||
public SteamLogin(ILogger<SteamLogin> logger, Client steamClient, ITokenProvider<SteamLoginState> token)
|
||||
{
|
||||
_logger = logger;
|
||||
_client = steamClient;
|
||||
_token = token;
|
||||
}
|
||||
public Command MakeCommand()
|
||||
{
|
||||
var command = new Command("steam-login");
|
||||
command.Description = "Logs into Steam via interactive prompts";
|
||||
|
||||
command.Add(new Option<string>(new[] {"-u", "-user"}, "Username for login"));
|
||||
command.Handler = CommandHandler.Create(Run);
|
||||
return command;
|
||||
}
|
||||
|
||||
public async Task<int> Run(string user)
|
||||
{
|
||||
var token = await _token.Get();
|
||||
|
||||
if (token == null || token.User != user || string.IsNullOrWhiteSpace(token.Password))
|
||||
{
|
||||
Console.WriteLine("Please enter password");
|
||||
var password = Console.ReadLine() ?? "";
|
||||
|
||||
await _token.SetToken(new SteamLoginState
|
||||
{
|
||||
User = user,
|
||||
Password = password.Trim()
|
||||
});
|
||||
}
|
||||
|
||||
_logger.LogInformation("Attempting login");
|
||||
await _client.Login();
|
||||
|
||||
await Task.Delay(10000);
|
||||
|
||||
return 0;
|
||||
}
|
||||
|
||||
}
|
38
Wabbajack.DTOs/Interventions/AUserIntervention.cs
Normal file
38
Wabbajack.DTOs/Interventions/AUserIntervention.cs
Normal file
@ -0,0 +1,38 @@
|
||||
using System;
|
||||
using System.Threading;
|
||||
using System.Threading.Tasks;
|
||||
|
||||
namespace Wabbajack.DTOs.Interventions;
|
||||
|
||||
public class AUserIntervention<T> : IUserIntervention
|
||||
{
|
||||
private readonly TaskCompletionSource<T> _tcs;
|
||||
private readonly CancellationTokenSource _ct;
|
||||
|
||||
protected AUserIntervention()
|
||||
{
|
||||
_tcs = new TaskCompletionSource<T>();
|
||||
_ct = new CancellationTokenSource();
|
||||
}
|
||||
public void Cancel()
|
||||
{
|
||||
_ct.Cancel();
|
||||
_tcs.SetCanceled(Token);
|
||||
}
|
||||
|
||||
public bool Handled => _tcs.Task.IsCompleted;
|
||||
public CancellationToken Token => _ct.Token;
|
||||
public Task<T> Task => _tcs.Task;
|
||||
|
||||
public void Finish(T value)
|
||||
{
|
||||
_tcs.SetResult(value);
|
||||
_ct.Cancel();
|
||||
}
|
||||
|
||||
public void SetException(Exception exception)
|
||||
{
|
||||
_ct.Cancel();
|
||||
_tcs.SetException(exception);
|
||||
}
|
||||
}
|
@ -3,11 +3,16 @@ using System.Threading;
|
||||
|
||||
namespace Wabbajack.DTOs.Interventions;
|
||||
|
||||
|
||||
public interface IUserIntervention
|
||||
{
|
||||
|
||||
}
|
||||
/// <summary>
|
||||
/// Defines a message that requires user interaction. The user must perform some action
|
||||
/// or make a choice.
|
||||
/// </summary>
|
||||
public interface IUserIntervention
|
||||
public interface IUserIntervention<TRet> : IUserIntervention
|
||||
{
|
||||
/// <summary>
|
||||
/// The user didn't make a choice, so this action should be aborted
|
||||
|
36
Wabbajack.Networking.Steam.Test/ClientTests.cs
Normal file
36
Wabbajack.Networking.Steam.Test/ClientTests.cs
Normal file
@ -0,0 +1,36 @@
|
||||
using System.Threading.Tasks;
|
||||
using Wabbajack.DTOs.Interventions;
|
||||
using Wabbajack.Networking.Http.Interfaces;
|
||||
using Xunit;
|
||||
|
||||
namespace Wabbajack.Networking.Steam.Test;
|
||||
|
||||
public class ClientTests
|
||||
{
|
||||
private readonly ITokenProvider<SteamLoginState> _token;
|
||||
private readonly Client _steamClient;
|
||||
private readonly IUserInterventionHandler _userInterventionHandler;
|
||||
|
||||
public ClientTests(ITokenProvider<SteamLoginState> token, Client client, IUserInterventionHandler userInterventionHandler)
|
||||
{
|
||||
_token = token;
|
||||
_steamClient = client;
|
||||
_userInterventionHandler = userInterventionHandler;
|
||||
}
|
||||
|
||||
[Fact]
|
||||
public async Task CanGetLogin()
|
||||
{
|
||||
var token = await _token.Get();
|
||||
Assert.NotNull(token);
|
||||
Assert.NotEmpty(token!.User);
|
||||
}
|
||||
|
||||
[Fact]
|
||||
public async Task CanLogin()
|
||||
{
|
||||
await _steamClient.Connect();
|
||||
await _steamClient.Login();
|
||||
|
||||
}
|
||||
}
|
20
Wabbajack.Networking.Steam.Test/Startup.cs
Normal file
20
Wabbajack.Networking.Steam.Test/Startup.cs
Normal file
@ -0,0 +1,20 @@
|
||||
using Microsoft.Extensions.DependencyInjection;
|
||||
using Microsoft.Extensions.Logging;
|
||||
using Wabbajack.Services.OSIntegrated;
|
||||
using Xunit.DependencyInjection;
|
||||
using Xunit.DependencyInjection.Logging;
|
||||
|
||||
namespace Wabbajack.Networking.Steam.Test;
|
||||
|
||||
public class Startup
|
||||
{
|
||||
public void ConfigureServices(IServiceCollection service)
|
||||
{
|
||||
service.AddOSIntegrated();
|
||||
}
|
||||
|
||||
public void Configure(ILoggerFactory loggerFactory, ITestOutputHelperAccessor accessor)
|
||||
{
|
||||
loggerFactory.AddProvider(new XunitTestOutputLoggerProvider(accessor, delegate { return true; }));
|
||||
}
|
||||
}
|
@ -0,0 +1,28 @@
|
||||
<Project Sdk="Microsoft.NET.Sdk">
|
||||
|
||||
<PropertyGroup>
|
||||
<TargetFramework>net6.0</TargetFramework>
|
||||
<Nullable>enable</Nullable>
|
||||
|
||||
<IsPackable>false</IsPackable>
|
||||
</PropertyGroup>
|
||||
|
||||
<ItemGroup>
|
||||
<PackageReference Include="Microsoft.Extensions.DependencyInjection.Abstractions" Version="6.0.0" />
|
||||
<PackageReference Include="Microsoft.NET.Test.Sdk" Version="16.11.0" />
|
||||
<PackageReference Include="xunit" Version="2.4.1" />
|
||||
<PackageReference Include="xunit.runner.visualstudio" Version="2.4.3">
|
||||
<IncludeAssets>runtime; build; native; contentfiles; analyzers; buildtransitive</IncludeAssets>
|
||||
<PrivateAssets>all</PrivateAssets>
|
||||
</PackageReference>
|
||||
<PackageReference Include="coverlet.collector" Version="3.1.0">
|
||||
<IncludeAssets>runtime; build; native; contentfiles; analyzers; buildtransitive</IncludeAssets>
|
||||
<PrivateAssets>all</PrivateAssets>
|
||||
</PackageReference>
|
||||
</ItemGroup>
|
||||
|
||||
<ItemGroup>
|
||||
<ProjectReference Include="..\Wabbajack.Services.OSIntegrated\Wabbajack.Services.OSIntegrated.csproj" />
|
||||
</ItemGroup>
|
||||
|
||||
</Project>
|
229
Wabbajack.Networking.Steam/Client.cs
Normal file
229
Wabbajack.Networking.Steam/Client.cs
Normal file
@ -0,0 +1,229 @@
|
||||
using System.Security;
|
||||
using Microsoft.Extensions.Logging;
|
||||
using SteamKit2;
|
||||
using Wabbajack.DTOs.Interventions;
|
||||
using Wabbajack.Networking.Http.Interfaces;
|
||||
using Wabbajack.Networking.Steam.UserInterventions;
|
||||
|
||||
namespace Wabbajack.Networking.Steam;
|
||||
|
||||
public class Client : IDisposable
|
||||
{
|
||||
private readonly ILogger<Client> _logger;
|
||||
private readonly HttpClient _httpClient;
|
||||
private readonly SteamClient _client;
|
||||
private readonly SteamUser _steamUser;
|
||||
private readonly CallbackManager _manager;
|
||||
private readonly ITokenProvider<SteamLoginState> _token;
|
||||
private TaskCompletionSource _loginTask;
|
||||
private TaskCompletionSource _connectTask;
|
||||
private readonly CancellationTokenSource _cancellationSource;
|
||||
|
||||
private string? _twoFactorCode;
|
||||
private string? _authCode;
|
||||
private readonly IUserInterventionHandler _interventionHandler;
|
||||
private bool _isConnected;
|
||||
private bool _isLoggedIn;
|
||||
private bool _haveSigFile;
|
||||
|
||||
public Client(ILogger<Client> logger, HttpClient client, ITokenProvider<SteamLoginState> token,
|
||||
IUserInterventionHandler interventionHandler)
|
||||
{
|
||||
_logger = logger;
|
||||
_httpClient = client;
|
||||
_interventionHandler = interventionHandler;
|
||||
_client = new SteamClient(SteamConfiguration.Create(c =>
|
||||
{
|
||||
c.WithHttpClientFactory(() => client);
|
||||
c.WithProtocolTypes(ProtocolTypes.WebSocket);
|
||||
c.WithUniverse(EUniverse.Public);
|
||||
}));
|
||||
|
||||
|
||||
_cancellationSource = new CancellationTokenSource();
|
||||
|
||||
_token = token;
|
||||
|
||||
_manager = new CallbackManager(_client);
|
||||
|
||||
_steamUser = _client.GetHandler<SteamUser>()!;
|
||||
|
||||
_manager.Subscribe<SteamClient.ConnectedCallback>( OnConnected );
|
||||
_manager.Subscribe<SteamClient.DisconnectedCallback>( OnDisconnected );
|
||||
|
||||
_manager.Subscribe<SteamUser.LoggedOnCallback>( OnLoggedOn );
|
||||
_manager.Subscribe<SteamUser.LoggedOffCallback>( OnLoggedOff );
|
||||
|
||||
_manager.Subscribe<SteamUser.UpdateMachineAuthCallback>( OnUpdateMachineAuthCallback );
|
||||
|
||||
_isConnected = false;
|
||||
_isLoggedIn = false;
|
||||
_haveSigFile = false;
|
||||
|
||||
new Thread(() =>
|
||||
{
|
||||
while (!_cancellationSource.IsCancellationRequested)
|
||||
{
|
||||
_manager.RunWaitCallbacks(TimeSpan.FromMilliseconds(250));
|
||||
}
|
||||
})
|
||||
{
|
||||
Name = "Steam Client callback runner",
|
||||
IsBackground = true
|
||||
}
|
||||
.Start();
|
||||
}
|
||||
|
||||
private void OnUpdateMachineAuthCallback(SteamUser.UpdateMachineAuthCallback callback)
|
||||
{
|
||||
Task.Run(async () =>
|
||||
{
|
||||
int fileSize;
|
||||
byte[] sentryHash;
|
||||
|
||||
var token = await _token.Get();
|
||||
|
||||
var ms = new MemoryStream();
|
||||
|
||||
if (token?.SentryFile != null)
|
||||
await ms.WriteAsync(token.SentryFile);
|
||||
|
||||
ms.Seek(callback.Offset, SeekOrigin.Begin);
|
||||
ms.Write(callback.Data, 0, callback.BytesToWrite);
|
||||
fileSize = (int) ms.Length;
|
||||
|
||||
token!.SentryFile = ms.ToArray();
|
||||
sentryHash = CryptoHelper.SHAHash(token.SentryFile);
|
||||
|
||||
await _token.SetToken(token);
|
||||
|
||||
|
||||
_steamUser.SendMachineAuthResponse(new SteamUser.MachineAuthDetails
|
||||
{
|
||||
JobID = callback.JobID,
|
||||
FileName = callback.FileName,
|
||||
|
||||
BytesWritten = callback.BytesToWrite,
|
||||
FileSize = token.SentryFile.Length,
|
||||
Offset = callback.Offset,
|
||||
Result = EResult.OK,
|
||||
LastError = 0,
|
||||
OneTimePassword = callback.OneTimePassword,
|
||||
SentryFileHash = sentryHash
|
||||
});
|
||||
|
||||
_haveSigFile = true;
|
||||
_loginTask.TrySetResult();
|
||||
});
|
||||
}
|
||||
|
||||
private void OnLoggedOff(SteamUser.LoggedOffCallback obj)
|
||||
{
|
||||
_isLoggedIn = false;
|
||||
}
|
||||
|
||||
private void OnLoggedOn(SteamUser.LoggedOnCallback callback)
|
||||
{
|
||||
Task.Run(async () =>
|
||||
{
|
||||
var isSteamGuard = callback.Result == EResult.AccountLogonDenied;
|
||||
var is2FA = callback.Result == EResult.AccountLoginDeniedNeedTwoFactor;
|
||||
|
||||
if (isSteamGuard || is2FA)
|
||||
{
|
||||
_logger.LogInformation("Account is SteamGuard protected");
|
||||
if (is2FA)
|
||||
{
|
||||
var intervention = new GetAuthCode(GetAuthCode.AuthType.TwoFactorAuth);
|
||||
_interventionHandler.Raise(intervention);
|
||||
_twoFactorCode = await intervention.Task;
|
||||
}
|
||||
else
|
||||
{
|
||||
var intervention = new GetAuthCode(GetAuthCode.AuthType.EmailCode);
|
||||
_interventionHandler.Raise(intervention);
|
||||
_authCode = await intervention.Task;
|
||||
}
|
||||
|
||||
var tcs = Login(_loginTask);
|
||||
return;
|
||||
}
|
||||
|
||||
if (callback.Result != EResult.OK)
|
||||
{
|
||||
_loginTask.SetException(new SteamException("Unable to log in", callback.Result, callback.ExtendedResult));
|
||||
return;
|
||||
}
|
||||
|
||||
_isLoggedIn = true;
|
||||
_logger.LogInformation("Logged into Steam");
|
||||
if (_haveSigFile)
|
||||
_loginTask.SetResult();
|
||||
});
|
||||
}
|
||||
|
||||
private void OnDisconnected(SteamClient.DisconnectedCallback obj)
|
||||
{
|
||||
_isConnected = false;
|
||||
_logger.LogInformation("Logged out");
|
||||
}
|
||||
|
||||
private void OnConnected(SteamClient.ConnectedCallback obj)
|
||||
{
|
||||
Task.Run(async () =>
|
||||
{
|
||||
var state = (await _token.Get())!;
|
||||
_logger.LogInformation("Connected to Steam, logging in as {User}", state.User);
|
||||
|
||||
byte[]? sentryHash = null;
|
||||
|
||||
|
||||
if (state.SentryFile != null)
|
||||
{
|
||||
_logger.LogInformation("Existing login keys found, reusing");
|
||||
sentryHash = CryptoHelper.SHAHash(state.SentryFile);
|
||||
_haveSigFile = true;
|
||||
}
|
||||
else
|
||||
{
|
||||
_haveSigFile = false;
|
||||
}
|
||||
|
||||
|
||||
_isConnected = true;
|
||||
|
||||
_steamUser.LogOn(new SteamUser.LogOnDetails()
|
||||
{
|
||||
Username = state.User,
|
||||
Password = state.Password,
|
||||
AuthCode = _authCode,
|
||||
TwoFactorCode = _twoFactorCode,
|
||||
SentryFileHash = sentryHash
|
||||
});
|
||||
});
|
||||
}
|
||||
|
||||
public Task Connect()
|
||||
{
|
||||
_connectTask = new TaskCompletionSource();
|
||||
|
||||
_client.Connect();
|
||||
return _connectTask.Task;
|
||||
}
|
||||
|
||||
public void Dispose()
|
||||
{
|
||||
_httpClient.Dispose();
|
||||
_cancellationSource.Cancel();
|
||||
_cancellationSource.Dispose();
|
||||
}
|
||||
|
||||
public Task Login(TaskCompletionSource? tcs = null)
|
||||
{
|
||||
_loginTask = tcs ?? new TaskCompletionSource();
|
||||
_logger.LogInformation("Attempting login");
|
||||
_client.Connect();
|
||||
|
||||
return _loginTask.Task;
|
||||
}
|
||||
}
|
16
Wabbajack.Networking.Steam/SteamException.cs
Normal file
16
Wabbajack.Networking.Steam/SteamException.cs
Normal file
@ -0,0 +1,16 @@
|
||||
using SteamKit2;
|
||||
|
||||
namespace Wabbajack.Networking.Steam;
|
||||
|
||||
public class SteamException : Exception
|
||||
{
|
||||
public EResult Result { get; }
|
||||
public EResult ExtendedResult { get; }
|
||||
|
||||
public SteamException(string message, EResult result, EResult extendedResult) : base($"{message} {result} / {extendedResult}")
|
||||
{
|
||||
Result = result;
|
||||
ExtendedResult = extendedResult;
|
||||
}
|
||||
|
||||
}
|
8
Wabbajack.Networking.Steam/SteamLoginState.cs
Normal file
8
Wabbajack.Networking.Steam/SteamLoginState.cs
Normal file
@ -0,0 +1,8 @@
|
||||
namespace Wabbajack.Networking.Steam;
|
||||
|
||||
public class SteamLoginState
|
||||
{
|
||||
public byte[]? SentryFile { get; set; }
|
||||
public string User { get; set; }
|
||||
public string Password { get; set; }
|
||||
}
|
14
Wabbajack.Networking.Steam/UserInterventions/GetAuthCode.cs
Normal file
14
Wabbajack.Networking.Steam/UserInterventions/GetAuthCode.cs
Normal file
@ -0,0 +1,14 @@
|
||||
using Wabbajack.DTOs.Interventions;
|
||||
|
||||
namespace Wabbajack.Networking.Steam.UserInterventions;
|
||||
|
||||
public class GetAuthCode : AUserIntervention<string>
|
||||
{
|
||||
public enum AuthType
|
||||
{
|
||||
TwoFactorAuth,
|
||||
EmailCode
|
||||
}
|
||||
public GetAuthCode(AuthType type) => Type = type;
|
||||
public AuthType Type { get; }
|
||||
}
|
@ -0,0 +1,19 @@
|
||||
using Wabbajack.DTOs.Interventions;
|
||||
|
||||
namespace Wabbajack.Networking.Steam.UserInterventions;
|
||||
|
||||
public class GetUsernameAndPassword : IUserIntervention
|
||||
{
|
||||
public void Cancel()
|
||||
{
|
||||
throw new NotImplementedException();
|
||||
}
|
||||
|
||||
public bool Handled { get; }
|
||||
public CancellationToken Token { get; }
|
||||
|
||||
public void SetException(Exception exception)
|
||||
{
|
||||
throw new NotImplementedException();
|
||||
}
|
||||
}
|
19
Wabbajack.Networking.Steam/Wabbajack.Networking.Steam.csproj
Normal file
19
Wabbajack.Networking.Steam/Wabbajack.Networking.Steam.csproj
Normal file
@ -0,0 +1,19 @@
|
||||
<Project Sdk="Microsoft.NET.Sdk">
|
||||
|
||||
<PropertyGroup>
|
||||
<TargetFramework>net6.0</TargetFramework>
|
||||
<ImplicitUsings>enable</ImplicitUsings>
|
||||
<Nullable>enable</Nullable>
|
||||
</PropertyGroup>
|
||||
|
||||
<ItemGroup>
|
||||
<PackageReference Include="Microsoft.Extensions.Logging.Abstractions" Version="6.0.0" />
|
||||
<PackageReference Include="SteamKit2" Version="2.4.0" />
|
||||
</ItemGroup>
|
||||
|
||||
<ItemGroup>
|
||||
<ProjectReference Include="..\Wabbajack.DTOs\Wabbajack.DTOs.csproj" />
|
||||
<ProjectReference Include="..\Wabbajack.Networking.Http.Interfaces\Wabbajack.Networking.Http.Interfaces.csproj" />
|
||||
</ItemGroup>
|
||||
|
||||
</Project>
|
@ -41,13 +41,21 @@ public class LoggingRateLimiterReporter : IDisposable
|
||||
var report = NextReport();
|
||||
var sb = new StringBuilder();
|
||||
sb.Append($"[#{_reportNumber}] ");
|
||||
|
||||
var found = false;
|
||||
foreach (var (prev, next, limiter) in _prevReport.Zip(report, _limiters))
|
||||
{
|
||||
var throughput = next.Transferred - prev.Transferred;
|
||||
sb.Append($"{limiter.Name}: [{next.Running}/{next.Pending}] {throughput.ToFileSizeString()}/sec ");
|
||||
if (throughput > 0)
|
||||
{
|
||||
found = true;
|
||||
sb.Append($"{limiter.Name}: [{next.Running}/{next.Pending}] {throughput.ToFileSizeString()}/sec ");
|
||||
}
|
||||
}
|
||||
|
||||
_logger.LogInformation(sb.ToString());
|
||||
if (found)
|
||||
_logger.LogInformation(sb.ToString());
|
||||
|
||||
_prevReport = report;
|
||||
}
|
||||
}
|
@ -15,13 +15,14 @@ using Wabbajack.Networking.Discord;
|
||||
using Wabbajack.Networking.Http;
|
||||
using Wabbajack.Networking.Http.Interfaces;
|
||||
using Wabbajack.Networking.NexusApi;
|
||||
using Wabbajack.Networking.WabbajackClientApi;
|
||||
using Wabbajack.Networking.Steam;
|
||||
using Wabbajack.Paths;
|
||||
using Wabbajack.Paths.IO;
|
||||
using Wabbajack.RateLimiter;
|
||||
using Wabbajack.Services.OSIntegrated.Services;
|
||||
using Wabbajack.Services.OSIntegrated.TokenProviders;
|
||||
using Wabbajack.VFS;
|
||||
using Client = Wabbajack.Networking.WabbajackClientApi.Client;
|
||||
|
||||
namespace Wabbajack.Services.OSIntegrated;
|
||||
|
||||
@ -106,6 +107,8 @@ public static class ServiceExtensions
|
||||
service.AddSingleton<HttpClient>();
|
||||
service.AddAllSingleton<IHttpDownloader, SingleThreadedDownloader>();
|
||||
|
||||
service.AddSingleton<Wabbajack.Networking.Steam.Client>();
|
||||
|
||||
service.AddSingleton<Client>();
|
||||
service.AddSingleton<WriteOnlyClient>();
|
||||
|
||||
@ -118,6 +121,10 @@ public static class ServiceExtensions
|
||||
.AddAllSingleton<ITokenProvider<VectorPlexusLoginState>, EncryptedJsonTokenProvider<VectorPlexusLoginState>,
|
||||
VectorPlexusTokenProvider>();
|
||||
|
||||
service
|
||||
.AddAllSingleton<ITokenProvider<SteamLoginState>, EncryptedJsonTokenProvider<SteamLoginState>,
|
||||
SteamTokenProvider>();
|
||||
|
||||
service.AddAllSingleton<ITokenProvider<WabbajackApiState>, WabbajackApiTokenProvider>();
|
||||
|
||||
service
|
||||
|
@ -0,0 +1,13 @@
|
||||
using Microsoft.Extensions.Logging;
|
||||
using Wabbajack.DTOs.JsonConverters;
|
||||
using Wabbajack.Networking.Steam;
|
||||
|
||||
namespace Wabbajack.Services.OSIntegrated.TokenProviders;
|
||||
|
||||
public class SteamTokenProvider : EncryptedJsonTokenProvider<SteamLoginState>
|
||||
{
|
||||
public SteamTokenProvider(ILogger<SteamTokenProvider> logger, DTOSerializer dtos) : base(logger, dtos,
|
||||
"steam-login")
|
||||
{
|
||||
}
|
||||
}
|
@ -21,6 +21,7 @@
|
||||
<ProjectReference Include="..\Wabbajack.Downloaders.Dispatcher\Wabbajack.Downloaders.Dispatcher.csproj" />
|
||||
<ProjectReference Include="..\Wabbajack.Installer\Wabbajack.Installer.csproj" />
|
||||
<ProjectReference Include="..\Wabbajack.Networking.Discord\Wabbajack.Networking.Discord.csproj" />
|
||||
<ProjectReference Include="..\Wabbajack.Networking.Steam\Wabbajack.Networking.Steam.csproj" />
|
||||
<ProjectReference Include="..\Wabbajack.VFS\Wabbajack.VFS.csproj" />
|
||||
</ItemGroup>
|
||||
|
||||
|
@ -116,6 +116,10 @@ Project("{FAE04EC0-301F-11D3-BF4B-00C04F79EFBC}") = "Wabbajack.Launcher", "Wabba
|
||||
EndProject
|
||||
Project("{FAE04EC0-301F-11D3-BF4B-00C04F79EFBC}") = "Wabbajack.App.Wpf", "Wabbajack.App.Wpf\Wabbajack.App.Wpf.csproj", "{372B2DD2-EAA3-4E18-98A7-B9838C7B41F4}"
|
||||
EndProject
|
||||
Project("{FAE04EC0-301F-11D3-BF4B-00C04F79EFBC}") = "Wabbajack.Networking.Steam", "Wabbajack.Networking.Steam\Wabbajack.Networking.Steam.csproj", "{AB9A5C22-10CC-4EE0-A808-FB1DC9E24247}"
|
||||
EndProject
|
||||
Project("{FAE04EC0-301F-11D3-BF4B-00C04F79EFBC}") = "Wabbajack.Networking.Steam.Test", "Wabbajack.Networking.Steam.Test\Wabbajack.Networking.Steam.Test.csproj", "{D6351587-CAF6-4CB6-A2BD-5368E69F297C}"
|
||||
EndProject
|
||||
Global
|
||||
GlobalSection(SolutionConfigurationPlatforms) = preSolution
|
||||
Debug|Any CPU = Debug|Any CPU
|
||||
@ -322,6 +326,14 @@ Global
|
||||
{372B2DD2-EAA3-4E18-98A7-B9838C7B41F4}.Debug|Any CPU.Build.0 = Debug|x64
|
||||
{372B2DD2-EAA3-4E18-98A7-B9838C7B41F4}.Release|Any CPU.ActiveCfg = Release|x64
|
||||
{372B2DD2-EAA3-4E18-98A7-B9838C7B41F4}.Release|Any CPU.Build.0 = Release|x64
|
||||
{AB9A5C22-10CC-4EE0-A808-FB1DC9E24247}.Debug|Any CPU.ActiveCfg = Debug|Any CPU
|
||||
{AB9A5C22-10CC-4EE0-A808-FB1DC9E24247}.Debug|Any CPU.Build.0 = Debug|Any CPU
|
||||
{AB9A5C22-10CC-4EE0-A808-FB1DC9E24247}.Release|Any CPU.ActiveCfg = Release|Any CPU
|
||||
{AB9A5C22-10CC-4EE0-A808-FB1DC9E24247}.Release|Any CPU.Build.0 = Release|Any CPU
|
||||
{D6351587-CAF6-4CB6-A2BD-5368E69F297C}.Debug|Any CPU.ActiveCfg = Debug|Any CPU
|
||||
{D6351587-CAF6-4CB6-A2BD-5368E69F297C}.Debug|Any CPU.Build.0 = Debug|Any CPU
|
||||
{D6351587-CAF6-4CB6-A2BD-5368E69F297C}.Release|Any CPU.ActiveCfg = Release|Any CPU
|
||||
{D6351587-CAF6-4CB6-A2BD-5368E69F297C}.Release|Any CPU.Build.0 = Release|Any CPU
|
||||
EndGlobalSection
|
||||
GlobalSection(NestedProjects) = preSolution
|
||||
{4057B668-8595-44FE-9805-007B284A838F} = {98B731EE-4FC0-4482-A069-BCBA25497871}
|
||||
@ -358,5 +370,7 @@ Global
|
||||
{29AC8A68-D5EC-43F5-B2CC-72A75545E418} = {98B731EE-4FC0-4482-A069-BCBA25497871}
|
||||
{DEB4B073-4EAA-49FD-9D43-F0F8CB930E7A} = {F01F8595-5FD7-4506-8469-F4A5522DACC1}
|
||||
{4F252332-CA77-41DE-95A8-9DF38A81D675} = {98B731EE-4FC0-4482-A069-BCBA25497871}
|
||||
{AB9A5C22-10CC-4EE0-A808-FB1DC9E24247} = {F01F8595-5FD7-4506-8469-F4A5522DACC1}
|
||||
{D6351587-CAF6-4CB6-A2BD-5368E69F297C} = {F01F8595-5FD7-4506-8469-F4A5522DACC1}
|
||||
EndGlobalSection
|
||||
EndGlobal
|
||||
|
Loading…
Reference in New Issue
Block a user