mirror of https://github.com/Squidex/squidex.git
You can not select more than 25 topics
Topics must start with a letter or number, can include dashes ('-') and can be up to 35 characters long.
86 lines
2.8 KiB
86 lines
2.8 KiB
// ==========================================================================
|
|
// Squidex Headless CMS
|
|
// ==========================================================================
|
|
// Copyright (c) Squidex UG (haftungsbeschraenkt)
|
|
// All rights reserved. Licensed under the MIT license.
|
|
// ==========================================================================
|
|
|
|
using System;
|
|
using System.Threading.Tasks;
|
|
using Microsoft.AspNetCore.Http;
|
|
using Microsoft.Extensions.Options;
|
|
using Microsoft.Net.Http.Headers;
|
|
using Squidex.Infrastructure;
|
|
using Squidex.Infrastructure.Security;
|
|
|
|
namespace Squidex.Web.Pipeline
|
|
{
|
|
public sealed class CachingKeysMiddleware
|
|
{
|
|
private readonly CachingOptions cachingOptions;
|
|
private readonly CachingManager cachingManager;
|
|
private readonly RequestDelegate next;
|
|
|
|
public CachingKeysMiddleware(CachingManager cachingManager, IOptions<CachingOptions> cachingOptions, RequestDelegate next)
|
|
{
|
|
Guard.NotNull(cachingManager, nameof(cachingManager));
|
|
Guard.NotNull(cachingOptions, nameof(cachingOptions));
|
|
Guard.NotNull(next, nameof(next));
|
|
|
|
this.cachingOptions = cachingOptions.Value;
|
|
this.cachingManager = cachingManager;
|
|
|
|
this.next = next;
|
|
}
|
|
|
|
public async Task InvokeAsync(HttpContext context)
|
|
{
|
|
cachingManager.Start(context);
|
|
|
|
AppendAuthHeaders(context);
|
|
|
|
context.Response.OnStarting(x =>
|
|
{
|
|
var httpContext = (HttpContext)x;
|
|
|
|
if (httpContext.Response.Headers.TryGetString(HeaderNames.ETag, out var etag))
|
|
{
|
|
if (!cachingOptions.StrongETag && IsWeakEtag(etag))
|
|
{
|
|
httpContext.Response.Headers[HeaderNames.ETag] = ToWeakEtag(etag);
|
|
}
|
|
}
|
|
|
|
cachingManager.Finish(httpContext);
|
|
|
|
return Task.CompletedTask;
|
|
}, context);
|
|
|
|
await next(context);
|
|
}
|
|
|
|
private void AppendAuthHeaders(HttpContext httpContext)
|
|
{
|
|
cachingManager.AddHeader("Auth-State");
|
|
|
|
if (!string.IsNullOrWhiteSpace(httpContext.User.OpenIdSubject()))
|
|
{
|
|
cachingManager.AddHeader(HeaderNames.Authorization);
|
|
}
|
|
else if (!string.IsNullOrWhiteSpace(httpContext.User.OpenIdClientId()))
|
|
{
|
|
cachingManager.AddHeader("Auth-ClientId");
|
|
}
|
|
}
|
|
|
|
private static string ToWeakEtag(string? etag)
|
|
{
|
|
return $"W/{etag}";
|
|
}
|
|
|
|
private static bool IsWeakEtag(string etag)
|
|
{
|
|
return !etag.StartsWith("W/", StringComparison.OrdinalIgnoreCase);
|
|
}
|
|
}
|
|
}
|
|
|