Remove custom CORS OPTIONS handling
This commit is contained in:
parent
2f79c3095b
commit
993c46f98d
|
@ -68,16 +68,6 @@ namespace Jellyfin.Server.Extensions
|
||||||
return appBuilder.UseMiddleware<LanFilteringMiddleware>();
|
return appBuilder.UseMiddleware<LanFilteringMiddleware>();
|
||||||
}
|
}
|
||||||
|
|
||||||
/// <summary>
|
|
||||||
/// Adds CORS OPTIONS request handling to the application pipeline.
|
|
||||||
/// </summary>
|
|
||||||
/// <param name="appBuilder">The application builder.</param>
|
|
||||||
/// <returns>The updated application builder.</returns>
|
|
||||||
public static IApplicationBuilder UseCorsOptionsResponse(this IApplicationBuilder appBuilder)
|
|
||||||
{
|
|
||||||
return appBuilder.UseMiddleware<CorsOptionsResponseMiddleware>();
|
|
||||||
}
|
|
||||||
|
|
||||||
/// <summary>
|
/// <summary>
|
||||||
/// Adds base url redirection to the application pipeline.
|
/// Adds base url redirection to the application pipeline.
|
||||||
/// </summary>
|
/// </summary>
|
||||||
|
|
|
@ -1,69 +0,0 @@
|
||||||
using System;
|
|
||||||
using System.Collections.Generic;
|
|
||||||
using System.Net.Mime;
|
|
||||||
using System.Threading.Tasks;
|
|
||||||
using Microsoft.AspNetCore.Http;
|
|
||||||
using Microsoft.Extensions.Primitives;
|
|
||||||
|
|
||||||
namespace Jellyfin.Server.Middleware
|
|
||||||
{
|
|
||||||
/// <summary>
|
|
||||||
/// Middleware for handling OPTIONS requests.
|
|
||||||
/// </summary>
|
|
||||||
public class CorsOptionsResponseMiddleware
|
|
||||||
{
|
|
||||||
private readonly RequestDelegate _next;
|
|
||||||
|
|
||||||
/// <summary>
|
|
||||||
/// Initializes a new instance of the <see cref="CorsOptionsResponseMiddleware"/> class.
|
|
||||||
/// </summary>
|
|
||||||
/// <param name="next">The next delegate in the pipeline.</param>
|
|
||||||
public CorsOptionsResponseMiddleware(RequestDelegate next)
|
|
||||||
{
|
|
||||||
_next = next;
|
|
||||||
}
|
|
||||||
|
|
||||||
/// <summary>
|
|
||||||
/// Executes the middleware action.
|
|
||||||
/// </summary>
|
|
||||||
/// <param name="httpContext">The current HTTP context.</param>
|
|
||||||
/// <returns>The async task.</returns>
|
|
||||||
public async Task Invoke(HttpContext httpContext)
|
|
||||||
{
|
|
||||||
if (string.Equals(httpContext.Request.Method, HttpMethods.Options, StringComparison.OrdinalIgnoreCase))
|
|
||||||
{
|
|
||||||
httpContext.Response.StatusCode = 200;
|
|
||||||
foreach (var (key, value) in GetDefaultCorsHeaders(httpContext))
|
|
||||||
{
|
|
||||||
httpContext.Response.Headers.Add(key, value);
|
|
||||||
}
|
|
||||||
|
|
||||||
httpContext.Response.ContentType = MediaTypeNames.Text.Plain;
|
|
||||||
await httpContext.Response.WriteAsync(string.Empty, httpContext.RequestAborted).ConfigureAwait(false);
|
|
||||||
return;
|
|
||||||
}
|
|
||||||
|
|
||||||
await _next(httpContext).ConfigureAwait(false);
|
|
||||||
}
|
|
||||||
|
|
||||||
private static IDictionary<string, string> GetDefaultCorsHeaders(HttpContext httpContext)
|
|
||||||
{
|
|
||||||
var origin = httpContext.Request.Headers["Origin"];
|
|
||||||
if (origin == StringValues.Empty)
|
|
||||||
{
|
|
||||||
origin = httpContext.Request.Headers["Host"];
|
|
||||||
if (origin == StringValues.Empty)
|
|
||||||
{
|
|
||||||
origin = "*";
|
|
||||||
}
|
|
||||||
}
|
|
||||||
|
|
||||||
var headers = new Dictionary<string, string>();
|
|
||||||
headers.Add("Access-Control-Allow-Origin", origin);
|
|
||||||
headers.Add("Access-Control-Allow-Credentials", "true");
|
|
||||||
headers.Add("Access-Control-Allow-Methods", "GET, POST, PUT, DELETE, PATCH, OPTIONS");
|
|
||||||
headers.Add("Access-Control-Allow-Headers", "Content-Type, Authorization, Range, X-MediaBrowser-Token, X-Emby-Authorization, Cookie");
|
|
||||||
return headers;
|
|
||||||
}
|
|
||||||
}
|
|
||||||
}
|
|
|
@ -101,6 +101,8 @@ namespace Jellyfin.Server
|
||||||
|
|
||||||
app.UseResponseCompression();
|
app.UseResponseCompression();
|
||||||
|
|
||||||
|
app.UseCors(ServerCorsPolicy.DefaultPolicyName);
|
||||||
|
|
||||||
if (_serverConfigurationManager.Configuration.RequireHttps
|
if (_serverConfigurationManager.Configuration.RequireHttps
|
||||||
&& _serverApplicationHost.ListenWithHttps)
|
&& _serverApplicationHost.ListenWithHttps)
|
||||||
{
|
{
|
||||||
|
@ -110,7 +112,6 @@ namespace Jellyfin.Server
|
||||||
app.UseAuthentication();
|
app.UseAuthentication();
|
||||||
app.UseJellyfinApiSwagger(_serverConfigurationManager);
|
app.UseJellyfinApiSwagger(_serverConfigurationManager);
|
||||||
app.UseRouting();
|
app.UseRouting();
|
||||||
app.UseCors(ServerCorsPolicy.DefaultPolicyName);
|
|
||||||
app.UseAuthorization();
|
app.UseAuthorization();
|
||||||
if (_serverConfigurationManager.Configuration.EnableMetrics)
|
if (_serverConfigurationManager.Configuration.EnableMetrics)
|
||||||
{
|
{
|
||||||
|
@ -120,7 +121,6 @@ namespace Jellyfin.Server
|
||||||
|
|
||||||
app.UseLanFiltering();
|
app.UseLanFiltering();
|
||||||
app.UseIpBasedAccessValidation();
|
app.UseIpBasedAccessValidation();
|
||||||
app.UseCorsOptionsResponse();
|
|
||||||
app.UseBaseUrlRedirection();
|
app.UseBaseUrlRedirection();
|
||||||
app.UseWebSocketHandler();
|
app.UseWebSocketHandler();
|
||||||
app.UseServerStartupMessage();
|
app.UseServerStartupMessage();
|
||||||
|
|
Loading…
Reference in New Issue
Block a user