Iceshrimp.NET/Iceshrimp.Backend/Startup.cs
2024-01-22 21:07:33 +01:00

72 lines
No EOL
2.9 KiB
C#

using Asp.Versioning;
using Iceshrimp.Backend.Core.Configuration;
using Iceshrimp.Backend.Core.Database;
using Iceshrimp.Backend.Core.Helpers;
using Microsoft.EntityFrameworkCore;
using Vite.AspNetCore.Extensions;
using StringExtensions = AngleSharp.Text.StringExtensions;
var builder = WebApplication.CreateBuilder(args);
builder.Configuration.Sources.Clear();
builder.Configuration
.AddIniFile(Environment.GetEnvironmentVariable("ICESHRIMP_CONFIG") ?? "configuration.ini",
false, true);
builder.Configuration
.AddIniFile(Environment.GetEnvironmentVariable("ICESHRIMP_CONFIG_OVERRIDES") ?? "configuration.overrides.ini",
true, true);
builder.Services.AddControllers().AddNewtonsoftJson();
builder.Services.AddApiVersioning(options => {
options.DefaultApiVersion = new ApiVersion(1);
options.ReportApiVersions = true;
options.UnsupportedApiVersionStatusCode = 501;
});
builder.Services.AddEndpointsApiExplorer();
builder.Services.AddSwaggerGen();
builder.Services.AddRazorPages();
builder.Services.AddViteServices(options => {
options.PackageDirectory = "../Iceshrimp.Frontend";
options.PackageManager = "yarn";
options.Server.AutoRun = false; //TODO: Fix script generation on macOS
options.Server.UseFullDevUrl = true;
});
//TODO: single line only if there's no \n in the log msg (otherwise stacktraces don't work)
builder.Services.AddLogging(logging => logging.AddSimpleConsole(options => { options.SingleLine = true; }));
builder.Services.AddDbContext<DatabaseContext>();
builder.Services.AddServices();
builder.Services.ConfigureServices(builder.Configuration);
var app = builder.Build();
var instanceConfig = app.Configuration.GetSection("Instance").Get<Config.InstanceSection>() ??
throw new Exception("Failed to read Instance config section");
app.Logger.LogInformation("Iceshrimp.NET v{version} ({domain})", instanceConfig.Version, instanceConfig.AccountDomain);
if (args.Contains("--migrate") || args.Contains("--migrate-and-start")) {
app.Logger.LogInformation("Running migrations...");
var provider = app.Services.CreateScope();
var context = provider.ServiceProvider.GetService<DatabaseContext>();
if (context == null) throw new NullReferenceException("Failed to get database context");
context.Database.Migrate();
if (args.Contains("--migrate")) Environment.Exit(0);
}
app.Logger.LogInformation("Initializing, please wait...");
app.UseSwagger();
app.UseSwaggerUI(options => { options.DocumentTitle = "Iceshrimp API documentation"; });
app.UseStaticFiles();
app.UseAuthorization();
app.MapControllers();
app.MapFallbackToController("/api/{**slug}", "FallbackAction", "Fallback");
app.MapRazorPages();
app.MapFallbackToPage("/Shared/FrontendSPA");
if (app.Environment.IsDevelopment()) app.UseViteDevMiddleware();
app.Urls.Clear();
app.Urls.Add($"http://{instanceConfig.WebDomain}:{instanceConfig.ListenPort}");
app.Run();