Files
NebulaLauncher/Nebula.Runner/App.cs

61 lines
1.7 KiB
C#
Raw Normal View History

2025-06-27 21:31:38 +03:00
using Nebula.Runner.Services;
2025-01-05 17:05:23 +03:00
using Nebula.Shared;
2025-01-07 17:01:00 +03:00
using Nebula.Shared.Models;
2025-01-05 17:05:23 +03:00
using Nebula.Shared.Services;
2025-08-17 21:40:31 +03:00
using Nebula.Shared.Services.Logging;
2025-01-07 17:01:00 +03:00
using Nebula.Shared.Utils;
using Robust.LoaderApi;
2025-01-05 17:05:23 +03:00
namespace Nebula.Runner;
[ServiceRegister]
2025-08-17 21:40:31 +03:00
public sealed class App(RunnerService runnerService, ContentService contentService, DebugService debugService)
2025-01-14 22:10:16 +03:00
: IRedialApi
2025-01-05 17:05:23 +03:00
{
2025-08-17 21:40:31 +03:00
public ILogger logger = debugService.GetLogger("Runner");
2025-01-14 22:10:16 +03:00
public void Redial(Uri uri, string text = "")
{
}
2025-01-07 17:01:00 +03:00
public async Task Run(string[] args1)
{
var login = Environment.GetEnvironmentVariable("AUTH_LOGIN") ?? "Alexandra";
var urlraw = Environment.GetEnvironmentVariable("GAME_URL") ?? "ss14://localhost";
var url = urlraw.ToRobustUrl();
2025-08-17 21:40:31 +03:00
try
{
using var cancelTokenSource = new CancellationTokenSource();
var buildInfo = await contentService.GetBuildInfo(url, cancelTokenSource.Token);
2025-01-07 17:01:00 +03:00
2025-01-14 22:10:16 +03:00
2025-08-17 21:40:31 +03:00
var args = new List<string>
{
"--username", login,
"--cvar", "launch.launcher=true"
};
2025-01-07 17:01:00 +03:00
2025-08-17 21:40:31 +03:00
var connectionString = url.ToString();
if (!string.IsNullOrEmpty(buildInfo.BuildInfo.ConnectAddress))
connectionString = buildInfo.BuildInfo.ConnectAddress;
2025-06-28 14:05:19 +03:00
2025-08-17 21:40:31 +03:00
args.Add("--launcher");
2025-01-07 17:01:00 +03:00
2025-08-17 21:40:31 +03:00
args.Add("--connect-address");
args.Add(connectionString);
2025-01-07 17:01:00 +03:00
2025-08-17 21:40:31 +03:00
args.Add("--ss14-address");
args.Add(url.ToString());
2025-01-05 17:05:23 +03:00
2025-08-17 21:40:31 +03:00
await runnerService.Run(args.ToArray(), buildInfo, this, new ConsoleLoadingHandler(), cancelTokenSource.Token);
}
catch (Exception e)
{
logger.Error(e);
throw;
}
2025-01-08 18:00:06 +03:00
}
}