Compare commits
2 Commits
| Author | SHA1 | Date | |
|---|---|---|---|
| f5a69de0a0 | |||
| 40a5f94941 |
@@ -137,8 +137,17 @@ public static class Api
|
|||||||
private static void CheckSameSite(HttpContext httpContext, CookieOptions options)
|
private static void CheckSameSite(HttpContext httpContext, CookieOptions options)
|
||||||
{
|
{
|
||||||
if (options.SameSite == SameSiteMode.None)
|
if (options.SameSite == SameSiteMode.None)
|
||||||
if (!httpContext.Request.IsHttps && httpContext.Request.Headers["X-Forwarded-Proto"] != "https")
|
{
|
||||||
options.SameSite = SameSiteMode.Unspecified;
|
bool isSecure = httpContext.Request.IsHttps;
|
||||||
|
|
||||||
|
if (!isSecure && httpContext.Request.Headers.TryGetValue("X-Forwarded-Proto", out var proto))
|
||||||
|
isSecure = string.Equals(proto, "https", StringComparison.OrdinalIgnoreCase);
|
||||||
|
|
||||||
|
if (!isSecure && httpContext.Request.Headers.TryGetValue("Forwarded", out var forwarded))
|
||||||
|
isSecure = forwarded.ToString().Contains("proto=https", StringComparison.OrdinalIgnoreCase);
|
||||||
|
|
||||||
|
if (!isSecure) options.SameSite = SameSiteMode.Unspecified;
|
||||||
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
public static IServiceCollection AddLiteCharmsApiSecurity(this IServiceCollection services, IConfiguration configuration)
|
public static IServiceCollection AddLiteCharmsApiSecurity(this IServiceCollection services, IConfiguration configuration)
|
||||||
|
|||||||
Reference in New Issue
Block a user