Recreated plugin with new project template. Started implementing server system daemon

This commit is contained in:
2026-03-01 21:09:29 +01:00
parent f6b71f4de6
commit 52dbd13fb5
350 changed files with 2795 additions and 21553 deletions

View File

@@ -1,5 +1,59 @@
using MoonlightServers.Daemon;
using Microsoft.Extensions.Logging.Console;
using MoonlightServers.Daemon.Helpers;
using MoonlightServers.Daemon.ServerSystem;
using MoonlightServers.Daemon.ServerSystem.Implementations.Docker;
using MoonlightServers.Daemon.ServerSystem.Implementations.Local;
using MoonlightServers.Daemon.Services;
var startup = new Startup();
var builder = WebApplication.CreateBuilder(args);
await startup.RunAsync(args);
// Configure logging
builder.Logging.ClearProviders();
builder.Logging.AddConsole(options => { options.FormatterName = nameof(AppConsoleFormatter); });
builder.Logging.AddConsoleFormatter<AppConsoleFormatter, ConsoleFormatterOptions>();
builder.Services.AddSingleton<ServerConfigurationService>();
builder.Services.AddSingleton<ServerFactory>();
builder.Services.AddDockerServices();
builder.Services.AddLocalServices();
builder.Services.AddControllers();
var app = builder.Build();
app.UseAuthorization();
app.MapControllers();
Task.Run(async () =>
{
Console.ReadLine();
try
{
var factory = app.Services.GetRequiredService<ServerFactory>();
var server = await factory.CreateAsync("a0e3ddb4-2c72-4f4c-bc49-35650a4bc5c0");
await server.InitializeAsync();
Console.WriteLine($"Server: {server.State}");
Console.ReadLine();
if (server.State == ServerState.Offline)
await server.StartAsync();
else
await server.StopAsync();
Console.ReadLine();
await server.DisposeAsync();
}
catch (Exception e)
{
Console.WriteLine(e);
throw;
}
});
app.Run();