123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136 |
- using System;
- using System.Collections.Generic;
- using System.IO;
- using System.Net;
- using System.Security.Cryptography.X509Certificates;
- using Jellyfin.Server.Helpers;
- using MediaBrowser.Common.Configuration;
- using MediaBrowser.Controller.Extensions;
- using MediaBrowser.Model.Net;
- using Microsoft.AspNetCore.Hosting;
- using Microsoft.AspNetCore.Server.Kestrel.Core;
- using Microsoft.Extensions.Configuration;
- using Microsoft.Extensions.Hosting;
- using Microsoft.Extensions.Logging;
- namespace Jellyfin.Server.Extensions;
- /// <summary>
- /// Extensions for configuring the web host builder.
- /// </summary>
- public static class WebHostBuilderExtensions
- {
- /// <summary>
- /// Configure the web host builder.
- /// </summary>
- /// <param name="builder">The builder to configure.</param>
- /// <param name="appHost">The application host.</param>
- /// <param name="startupConfig">The application configuration.</param>
- /// <param name="appPaths">The application paths.</param>
- /// <param name="logger">The logger.</param>
- /// <returns>The configured web host builder.</returns>
- public static IWebHostBuilder ConfigureWebHostBuilder(
- this IWebHostBuilder builder,
- CoreAppHost appHost,
- IConfiguration startupConfig,
- IApplicationPaths appPaths,
- ILogger logger)
- {
- return builder
- .UseKestrel((builderContext, options) =>
- {
- SetupJellyfinWebServer(
- appHost.NetManager.GetAllBindInterfaces(false),
- appHost.HttpPort,
- appHost.ListenWithHttps ? appHost.HttpsPort : null,
- appHost.Certificate,
- startupConfig,
- appPaths,
- logger,
- builderContext,
- options);
- })
- .UseStartup(context => new Startup(appHost, context.Configuration));
- }
- /// <summary>
- /// Configures a Kestrel type webServer to bind to the specific arguments.
- /// </summary>
- /// <param name="addresses">The IP addresses that should be listend to.</param>
- /// <param name="httpPort">The http port.</param>
- /// <param name="httpsPort">If set the https port. If set you must also set the certificate.</param>
- /// <param name="certificate">The certificate used for https port.</param>
- /// <param name="startupConfig">The startup config.</param>
- /// <param name="appPaths">The app paths.</param>
- /// <param name="logger">A logger.</param>
- /// <param name="builderContext">The kestrel build pipeline context.</param>
- /// <param name="options">The kestrel server options.</param>
- /// <exception cref="InvalidOperationException">Will be thrown when a https port is set but no or an invalid certificate is provided.</exception>
- public static void SetupJellyfinWebServer(
- IReadOnlyList<IPData> addresses,
- int httpPort,
- int? httpsPort,
- X509Certificate2? certificate,
- IConfiguration startupConfig,
- IApplicationPaths appPaths,
- ILogger logger,
- WebHostBuilderContext builderContext,
- KestrelServerOptions options)
- {
- bool flagged = false;
- foreach (var netAdd in addresses)
- {
- var address = netAdd.Address;
- logger.LogInformation("Kestrel is listening on {Address}", address.Equals(IPAddress.IPv6Any) ? "all interfaces" : address);
- options.Listen(netAdd.Address, httpPort);
- if (httpsPort.HasValue)
- {
- if (builderContext.HostingEnvironment.IsDevelopment())
- {
- try
- {
- options.Listen(
- address,
- httpsPort.Value,
- listenOptions => listenOptions.UseHttps());
- }
- catch (InvalidOperationException)
- {
- if (!flagged)
- {
- logger.LogWarning("Failed to listen to HTTPS using the ASP.NET Core HTTPS development certificate. Please ensure it has been installed and set as trusted");
- flagged = true;
- }
- }
- }
- else
- {
- if (certificate is null)
- {
- throw new InvalidOperationException("Cannot run jellyfin with https without setting a valid certificate.");
- }
- options.Listen(
- address,
- httpsPort.Value,
- listenOptions => listenOptions.UseHttps(certificate));
- }
- }
- }
- // Bind to unix socket (only on unix systems)
- if (startupConfig.UseUnixSocket() && Environment.OSVersion.Platform == PlatformID.Unix)
- {
- var socketPath = StartupHelpers.GetUnixSocketPath(startupConfig, appPaths);
- // Workaround for https://github.com/aspnet/AspNetCore/issues/14134
- if (File.Exists(socketPath))
- {
- File.Delete(socketPath);
- }
- options.ListenUnixSocket(socketPath);
- logger.LogInformation("Kestrel listening to unix socket {SocketPath}", socketPath);
- }
- }
- }
|