mirror of
https://github.com/jellyfin/jellyfin.git
synced 2024-11-16 02:18:54 -07:00
139 lines
5.2 KiB
C#
139 lines
5.2 KiB
C#
using System;
|
|
using System.ComponentModel;
|
|
using System.Net.Http.Headers;
|
|
using Jellyfin.Api.TypeConverters;
|
|
using Jellyfin.Server.Extensions;
|
|
using Jellyfin.Server.Middleware;
|
|
using Jellyfin.Server.Models;
|
|
using MediaBrowser.Common;
|
|
using MediaBrowser.Common.Net;
|
|
using MediaBrowser.Controller;
|
|
using MediaBrowser.Controller.Configuration;
|
|
using Microsoft.AspNetCore.Builder;
|
|
using Microsoft.AspNetCore.Hosting;
|
|
using Microsoft.Extensions.DependencyInjection;
|
|
using Microsoft.Extensions.Hosting;
|
|
using Prometheus;
|
|
|
|
namespace Jellyfin.Server
|
|
{
|
|
/// <summary>
|
|
/// Startup configuration for the Kestrel webhost.
|
|
/// </summary>
|
|
public class Startup
|
|
{
|
|
private readonly IServerConfigurationManager _serverConfigurationManager;
|
|
private readonly IServerApplicationHost _serverApplicationHost;
|
|
|
|
/// <summary>
|
|
/// Initializes a new instance of the <see cref="Startup" /> class.
|
|
/// </summary>
|
|
/// <param name="serverConfigurationManager">The server configuration manager.</param>
|
|
/// <param name="serverApplicationHost">The server application host.</param>
|
|
public Startup(
|
|
IServerConfigurationManager serverConfigurationManager,
|
|
IServerApplicationHost serverApplicationHost)
|
|
{
|
|
_serverConfigurationManager = serverConfigurationManager;
|
|
_serverApplicationHost = serverApplicationHost;
|
|
}
|
|
|
|
/// <summary>
|
|
/// Configures the service collection for the webhost.
|
|
/// </summary>
|
|
/// <param name="services">The service collection.</param>
|
|
public void ConfigureServices(IServiceCollection services)
|
|
{
|
|
services.AddResponseCompression();
|
|
services.AddHttpContextAccessor();
|
|
services.AddHttpsRedirection(options =>
|
|
{
|
|
options.HttpsPort = _serverApplicationHost.HttpsPort;
|
|
});
|
|
services.AddJellyfinApi(
|
|
_serverConfigurationManager.Configuration.BaseUrl.TrimStart('/'),
|
|
_serverApplicationHost.GetApiPluginAssemblies());
|
|
|
|
services.AddJellyfinApiSwagger();
|
|
|
|
// configure custom legacy authentication
|
|
services.AddCustomAuthentication();
|
|
|
|
services.AddJellyfinApiAuthorization();
|
|
|
|
var productHeader = new ProductInfoHeaderValue(
|
|
_serverApplicationHost.Name.Replace(' ', '-'),
|
|
_serverApplicationHost.ApplicationVersionString);
|
|
services
|
|
.AddHttpClient(NamedClient.Default, c =>
|
|
{
|
|
c.DefaultRequestHeaders.UserAgent.Add(productHeader);
|
|
})
|
|
.ConfigurePrimaryHttpMessageHandler(x => new DefaultHttpClientHandler());
|
|
|
|
services.AddHttpClient(NamedClient.MusicBrainz, c =>
|
|
{
|
|
c.DefaultRequestHeaders.UserAgent.Add(productHeader);
|
|
c.DefaultRequestHeaders.UserAgent.Add(new ProductInfoHeaderValue($"({_serverApplicationHost.ApplicationUserAgentAddress})"));
|
|
})
|
|
.ConfigurePrimaryHttpMessageHandler(x => new DefaultHttpClientHandler());
|
|
}
|
|
|
|
/// <summary>
|
|
/// Configures the app builder for the webhost.
|
|
/// </summary>
|
|
/// <param name="app">The application builder.</param>
|
|
/// <param name="env">The webhost environment.</param>
|
|
/// <param name="serverApplicationHost">The server application host.</param>
|
|
public void Configure(
|
|
IApplicationBuilder app,
|
|
IWebHostEnvironment env,
|
|
IServerApplicationHost serverApplicationHost)
|
|
{
|
|
if (env.IsDevelopment())
|
|
{
|
|
app.UseDeveloperExceptionPage();
|
|
}
|
|
|
|
app.UseMiddleware<ExceptionMiddleware>();
|
|
|
|
app.UseMiddleware<ResponseTimeMiddleware>();
|
|
|
|
app.UseWebSockets();
|
|
|
|
app.UseResponseCompression();
|
|
|
|
if (_serverConfigurationManager.Configuration.RequireHttps
|
|
&& _serverApplicationHost.ListenWithHttps)
|
|
{
|
|
app.UseHttpsRedirection();
|
|
}
|
|
|
|
app.UseAuthentication();
|
|
app.UseJellyfinApiSwagger(_serverConfigurationManager);
|
|
app.UseRouting();
|
|
app.UseCors(ServerCorsPolicy.DefaultPolicyName);
|
|
app.UseAuthorization();
|
|
if (_serverConfigurationManager.Configuration.EnableMetrics)
|
|
{
|
|
// Must be registered after any middleware that could chagne HTTP response codes or the data will be bad
|
|
app.UseHttpMetrics();
|
|
}
|
|
|
|
app.Use(serverApplicationHost.ExecuteHttpHandlerAsync);
|
|
|
|
app.UseEndpoints(endpoints =>
|
|
{
|
|
endpoints.MapControllers();
|
|
if (_serverConfigurationManager.Configuration.EnableMetrics)
|
|
{
|
|
endpoints.MapMetrics(_serverConfigurationManager.Configuration.BaseUrl.TrimStart('/') + "/metrics");
|
|
}
|
|
});
|
|
|
|
// Add type descriptor for legacy datetime parsing.
|
|
TypeDescriptor.AddAttributes(typeof(DateTime?), new TypeConverterAttribute(typeof(DateTimeTypeConverter)));
|
|
}
|
|
}
|
|
}
|