133 lines
4.4 KiB
C#
133 lines
4.4 KiB
C#
using System.Collections;
|
|
using System.Net.NetworkInformation;
|
|
using System.Reflection;
|
|
using System.Text;
|
|
using Microsoft.AspNetCore.Server.Kestrel.Core;
|
|
using Microsoft.EntityFrameworkCore;
|
|
using SCHALE.Common.Crypto;
|
|
using SCHALE.Common.Database;
|
|
using SCHALE.GameServer.Commands;
|
|
using SCHALE.GameServer.Controllers.Api.ProtocolHandlers;
|
|
using SCHALE.GameServer.Services;
|
|
using SCHALE.GameServer.Services.Irc;
|
|
using SCHALE.GameServer.Utils;
|
|
using Serilog;
|
|
using Serilog.Events;
|
|
|
|
namespace SCHALE.GameServer
|
|
{
|
|
public class GameServer
|
|
{
|
|
public static async Task Main(string[] args)
|
|
{
|
|
var config = new ConfigurationBuilder()
|
|
.SetBasePath(Path.GetDirectoryName(AppContext.BaseDirectory)!)
|
|
.AddJsonFile("appsettings.json")
|
|
.AddJsonFile(
|
|
$"appsettings.{Environment.GetEnvironmentVariable("ASPNETCORE_ENVIRONMENT") ?? "Production"}.json",
|
|
true
|
|
)
|
|
.AddJsonFile("appsettings.Local.json", true)
|
|
.Build();
|
|
|
|
{
|
|
var logFilePath = Path.Combine(
|
|
Path.GetDirectoryName(AppContext.BaseDirectory)!,
|
|
"logs",
|
|
"log.txt"
|
|
);
|
|
|
|
if (File.Exists(logFilePath))
|
|
{
|
|
var prevLogFilePath = Path.Combine(
|
|
Path.GetDirectoryName(logFilePath)!,
|
|
"log-prev.txt"
|
|
);
|
|
if (File.Exists(prevLogFilePath))
|
|
File.Delete(prevLogFilePath);
|
|
|
|
File.Move(logFilePath, prevLogFilePath);
|
|
}
|
|
|
|
Log.Logger = new LoggerConfiguration()
|
|
.WriteTo.Console()
|
|
.WriteTo.File(
|
|
logFilePath,
|
|
restrictedToMinimumLevel: LogEventLevel.Verbose,
|
|
shared: true
|
|
)
|
|
.ReadFrom.Configuration(config)
|
|
.CreateBootstrapLogger();
|
|
}
|
|
|
|
Log.Information("Starting...");
|
|
try
|
|
{
|
|
// Load Config
|
|
Config.Load();
|
|
|
|
// Load Excels
|
|
await ExcelTableService.LoadExcels();
|
|
|
|
// Load Commands
|
|
CommandFactory.LoadCommands();
|
|
|
|
|
|
var builder = WebApplication.CreateBuilder(args);
|
|
|
|
builder.Services.Configure<KestrelServerOptions>(op =>
|
|
op.AllowSynchronousIO = true
|
|
);
|
|
builder.Host.UseSerilog();
|
|
|
|
// Add services to the container.
|
|
builder.Services.AddSQLServerProvider(
|
|
config.GetConnectionString("SQLServer")
|
|
?? throw new ArgumentNullException(
|
|
"ConnectionStrings/SQLServer in appsettings is missing"
|
|
)
|
|
);
|
|
builder.Services.AddControllers();
|
|
builder.Services.AddProtocolHandlerFactory();
|
|
builder.Services.AddMemorySessionKeyService();
|
|
builder.Services.AddExcelTableService();
|
|
builder.Services.AddIrcService();
|
|
|
|
// Add all Handler Groups
|
|
var handlerGroups = Assembly
|
|
.GetExecutingAssembly()
|
|
.GetTypes()
|
|
.Where(t => t.IsSubclassOf(typeof(ProtocolHandlerBase)));
|
|
|
|
foreach (var handlerGroup in handlerGroups)
|
|
builder.Services.AddProtocolHandlerGroupByType(handlerGroup);
|
|
|
|
var app = builder.Build();
|
|
|
|
using (var scope = app.Services.CreateScope())
|
|
{
|
|
var context = scope.ServiceProvider.GetRequiredService<SCHALEContext>();
|
|
if (context.Database.GetPendingMigrations().Any())
|
|
context.Database.Migrate();
|
|
}
|
|
|
|
// Configure the HTTP request pipeline.
|
|
app.UseAuthorization();
|
|
app.UseSerilogRequestLogging();
|
|
|
|
app.MapControllers();
|
|
|
|
app.Run();
|
|
}
|
|
catch (Exception ex)
|
|
{
|
|
Log.Fatal(ex, "An unhandled exception occurred during runtime");
|
|
}
|
|
finally
|
|
{
|
|
Log.CloseAndFlush();
|
|
}
|
|
}
|
|
}
|
|
}
|