forked from PGR/ascnet
66 lines
2.1 KiB
C#
66 lines
2.1 KiB
C#
|
namespace AscNet.SDKServer
|
||
|
{
|
||
|
public class SDKServer
|
||
|
{
|
||
|
public static readonly Common.Util.Logger c = new(nameof(SDKServer), ConsoleColor.Green);
|
||
|
|
||
|
public static void Main(string[] args)
|
||
|
{
|
||
|
var builder = WebApplication.CreateBuilder(args);
|
||
|
|
||
|
// Disables default logger
|
||
|
builder.Logging.ClearProviders();
|
||
|
|
||
|
var app = builder.Build();
|
||
|
|
||
|
app.Urls.Add("http://*:80");
|
||
|
app.Urls.Add("https://*:443");
|
||
|
|
||
|
IEnumerable<Type> controllers = AppDomain.CurrentDomain.GetAssemblies()
|
||
|
.SelectMany(s => s.GetTypes())
|
||
|
.Where(p => typeof(IRegisterable).IsAssignableFrom(p) && !p.IsInterface)
|
||
|
.Select(x => x);
|
||
|
|
||
|
foreach (Type controller in controllers)
|
||
|
{
|
||
|
controller.GetMethod(nameof(IRegisterable.Register))!.Invoke(null, new object[] { app });
|
||
|
#if DEBUG
|
||
|
c.Log($"Registered HTTP controller '{controller.Name}'");
|
||
|
#endif
|
||
|
}
|
||
|
|
||
|
app.UseMiddleware<RequestLoggingMiddleware>();
|
||
|
|
||
|
new Thread(() => app.Run()).Start();
|
||
|
c.Log($"{nameof(SDKServer)} started in port {string.Join(", ", app.Urls.Select(x => x.Split(':').Last()))}!");
|
||
|
}
|
||
|
|
||
|
private class RequestLoggingMiddleware
|
||
|
{
|
||
|
private readonly RequestDelegate _next;
|
||
|
private static readonly string[] SurpressedRoutes = new string[] { "/report", "/sdk/dataUpload" };
|
||
|
|
||
|
public RequestLoggingMiddleware(RequestDelegate next)
|
||
|
{
|
||
|
_next = next;
|
||
|
}
|
||
|
|
||
|
public async Task Invoke(HttpContext context)
|
||
|
{
|
||
|
try
|
||
|
{
|
||
|
await _next(context);
|
||
|
}
|
||
|
finally
|
||
|
{
|
||
|
c.Log($"{context.Response.StatusCode} {context.Request.Method.ToUpper()} {context.Request.Path + context.Request.QueryString}");
|
||
|
}
|
||
|
}
|
||
|
}
|
||
|
}
|
||
|
|
||
|
public interface IRegisterable
|
||
|
{
|
||
|
public abstract static void Register(WebApplication app);
|
||
|
}
|
||
|
}
|