using SilverLabs.Website.Components; using SilverLabs.Website.Endpoints; using SilverLabs.Website.Services; var builder = WebApplication.CreateBuilder(args); // Add services to the container. builder.Services.AddRazorComponents() .AddInteractiveServerComponents(); // HttpClient for SilverDESK (used by DeveloperApplicationService directly) builder.Services.AddHttpClient(client => { client.BaseAddress = new Uri(builder.Configuration["SilverDesk:BaseUrl"] ?? "https://silverdesk.silverlabs.uk"); var apiKey = builder.Configuration["SilverDesk:ApiKey"]; if (!string.IsNullOrEmpty(apiKey)) client.DefaultRequestHeaders.Add("X-API-Key", apiKey); }); // HttpClient for DeveloperTicketParsingService (fetches tickets from SilverDESK) builder.Services.AddHttpClient(client => { client.BaseAddress = new Uri(builder.Configuration["SilverDesk:BaseUrl"] ?? "https://silverdesk.silverlabs.uk"); var apiKey = builder.Configuration["SilverDesk:ApiKey"]; if (!string.IsNullOrEmpty(apiKey)) client.DefaultRequestHeaders.Add("X-API-Key", apiKey); }); // Named HttpClients for provisioning builder.Services.AddHttpClient("SilverDesk", client => { client.BaseAddress = new Uri(builder.Configuration["SilverDesk:BaseUrl"] ?? "https://silverdesk.silverlabs.uk"); var apiKey = builder.Configuration["SilverDesk:ApiKey"]; if (!string.IsNullOrEmpty(apiKey)) client.DefaultRequestHeaders.Add("X-API-Key", apiKey); }); builder.Services.AddHttpClient("Mattermost", client => { client.BaseAddress = new Uri(builder.Configuration["Mattermost:BaseUrl"] ?? "https://ops.silverlined.uk"); var token = builder.Configuration["Mattermost:ApiToken"]; if (!string.IsNullOrEmpty(token)) client.DefaultRequestHeaders.Add("Authorization", $"Bearer {token}"); }); builder.Services.AddHttpClient("Mailcow", client => { client.BaseAddress = new Uri(builder.Configuration["Mailcow:BaseUrl"] ?? "https://mail.silverlined.uk"); var apiKey = builder.Configuration["Mailcow:ApiKey"]; if (!string.IsNullOrEmpty(apiKey)) client.DefaultRequestHeaders.Add("X-API-Key", apiKey); }); builder.Services.AddHttpClient("Gitea", client => { client.BaseAddress = new Uri(builder.Configuration["Gitea:BaseUrl"] ?? "https://git.silverlabs.uk"); var token = builder.Configuration["Gitea:ApiToken"]; if (!string.IsNullOrEmpty(token)) client.DefaultRequestHeaders.Add("Authorization", $"token {token}"); }); builder.Services.AddScoped(); var app = builder.Build(); // Configure the HTTP request pipeline. if (!app.Environment.IsDevelopment()) { app.UseExceptionHandler("/Error", createScopeForErrors: true); // The default HSTS value is 30 days. You may want to change this for production scenarios, see https://aka.ms/aspnetcore-hsts. app.UseHsts(); } // app.UseHttpsRedirection(); // Disabled - running behind reverse proxy app.UseAntiforgery(); app.MapStaticAssets(); app.MapRazorComponents() .AddInteractiveServerRenderMode(); app.MapDeveloperEndpoints(); app.Run();