* rework server responsibilities add remote configuration * start metrics only when compiled as not debug * add some more logging to discord bot * fixes of some casts * make metrics port configurable, minor fixes * add docker bullshit * md formatting * adjustments to docker stuff * fix docker json files, fix some stuff in discord bot, add /useradd for Discord bot * adjust docker configs and fix sharded.bat * fixes for logs, cache file provider repeat trying to open filestream Co-authored-by: rootdarkarchon <root.darkarchon@outlook.com>
48 lines
2.0 KiB
C#
48 lines
2.0 KiB
C#
using MareSynchronosServices;
|
|
using MareSynchronosShared.Data;
|
|
using MareSynchronosShared.Metrics;
|
|
using MareSynchronosShared.Services;
|
|
using MareSynchronosShared.Utils;
|
|
|
|
public class Program
|
|
{
|
|
public static void Main(string[] args)
|
|
{
|
|
var hostBuilder = CreateHostBuilder(args);
|
|
var host = hostBuilder.Build();
|
|
|
|
using (var scope = host.Services.CreateScope())
|
|
{
|
|
var services = scope.ServiceProvider;
|
|
using var dbContext = services.GetRequiredService<MareDbContext>();
|
|
var metrics = services.GetRequiredService<MareMetrics>();
|
|
|
|
metrics.SetGaugeTo(MetricsAPI.GaugeUsersRegistered, dbContext.Users.Count());
|
|
|
|
var options = host.Services.GetService<IConfigurationService<ServicesConfiguration>>();
|
|
var optionsServer = host.Services.GetService<IConfigurationService<ServerConfiguration>>();
|
|
var logger = host.Services.GetService<ILogger<Program>>();
|
|
logger.LogInformation("Loaded MareSynchronos Services Configuration (IsMain: {isMain})", options.IsMain);
|
|
logger.LogInformation(options.ToString());
|
|
logger.LogInformation("Loaded MareSynchronos Server Configuration (IsMain: {isMain})", optionsServer.IsMain);
|
|
logger.LogInformation(optionsServer.ToString());
|
|
}
|
|
|
|
host.Run();
|
|
}
|
|
|
|
public static IHostBuilder CreateHostBuilder(string[] args) =>
|
|
Host.CreateDefaultBuilder(args)
|
|
.UseSystemd()
|
|
.UseConsoleLifetime()
|
|
.ConfigureWebHostDefaults(webBuilder =>
|
|
{
|
|
webBuilder.UseContentRoot(AppContext.BaseDirectory);
|
|
webBuilder.ConfigureLogging((ctx, builder) =>
|
|
{
|
|
builder.AddConfiguration(ctx.Configuration.GetSection("Logging"));
|
|
builder.AddFile(o => o.RootPath = AppContext.BaseDirectory);
|
|
});
|
|
webBuilder.UseStartup<Startup>();
|
|
});
|
|
} |