aspnetcore
aspnetcore copied to clipboard
OIDC NonceCookie/CorrelationCookie not accepted by latest Chrome/Edge in some cases
Is there an existing issue for this?
- [X] I have searched the existing issues
Describe the bug
I have a website that uses OpenID Connect with the Microsoft.IdentityModel.Protocols.OpenIdConnect
library. It runs on HTTP behind an Azure App Serivice (reverse proxy), which communicates via the browser over HTTPS.
The OIDC middleware creates two cookies, .AspNetCore.OpenIdConnect.Nonce...
and .AspNetCore.Correlation...
. Because ASP.NET Core thinks it is running on HTTP (no Forwarded Headers Middleware), it doesn't set the Secure flag of the cookie. But it still declares it as SameSite=None
which makes Chrome/Edge 107 ignore the Set-Cookie header. Which always causes a failed login. Current Firefox accepts the cookie.
Workaround:
builder.AddOpenIdConnect((OpenIdConnectOptions options) =>
{
// your settings...
options.NonceCookie.SecurePolicy = CookieSecurePolicy.Always;
options.CorrelationCookie.SecurePolicy = CookieSecurePolicy.Always;
});
Screenshot of the Edge dev tools. The exclamation mark shows a message like: This attempt to set a cookie via a Set-Cookie header was blicked because it had the "SameSite=None" attribute but did not have the "Secure" attribute, which is required in order to use "SameSite=None"
data:image/s3,"s3://crabby-images/48555/485553e085bacf36dc7a5e876bf4e3c101d4a946" alt="Screenshot 2022-11-02 194338"
Expected Behavior
The default for the cookie builder should either be SameSite=Lax
or SameSite=None, Secure=true
. It anyway doesn't make a lot of sense to allow OIDC via an insecure HTTP connection.
https://github.com/dotnet/aspnetcore/blob/0f517603dc0cf996f58ccd67fd12b513794de5a4/src/Security/Authentication/OpenIdConnect/src/OpenIdConnectOptions.cs#L68-L76
Steps To Reproduce
No response
Exceptions (if any)
No response
.NET Version
7.0.100-rc.2.22477.23
Anything else?
asp.net core 7.0 rc2
Because ASP.NET Core thinks it is running on HTTP (no Forwarded Headers Middleware), it doesn't set the Secure flag of the cookie.
You need to get the request scheme set right (HTTPS) for several reasons, fixing only this issue likely won't fix your whole scenario. The main issue is that your redirect uri will also be HTTP and the IDP will likely reject that.
True, but we're setting the redirect URL via a config parameter (for some other reasons).
I know this is an edge case. But in my opinion it doesn't make a lot of sense that the default configuration can issues cookies that are rejected by major browsers.
Are you interested in sending a PR to change SecurePolicy to CookieSecurePolicy.Always for all places where we use SameSite=None? It will mostly involve updating tests.
Thanks for contacting us.
We're moving this issue to the .NET 8 Planning
milestone for future evaluation / consideration. We would like to keep this around to collect more feedback, which can help us with prioritizing this work. We will re-evaluate this issue, during our next planning meeting(s).
If we later determine, that the issue has no community involvement, or it's very rare and low-impact issue, we will close it - so that the team can focus on more important and high impact issues.
To learn more about what to expect next and how this issue will be handled you can read more about our triage process here.
@Tratcher I have dig into the code and figure out that we are calling at SameSite = SameSiteMode.None at 2 places
a) https://github.com/dotnet/aspnetcore/blob/0f517603dc0cf996f58ccd67fd12b513794de5a4/src/Security/Authentication/OpenIdConnect/src/OpenIdConnectOptions.cs#L68-L76 b)https://github.com/dotnet/aspnetcore/blob/0f517603dc0cf996f58ccd67fd12b513794de5a4/src/Security/Authentication/Core/src/RemoteAuthenticationOptions.cs#L22-L32
I will make the changes for SecurePolicy as below. Also I will fix the unit test which is failing. Please let me know if I miss anything.
public RemoteAuthenticationOptions()
{
_correlationCookieBuilder = new CorrelationCookieBuilder(this)
{
Name = CorrelationPrefix,
HttpOnly = true,
SameSite = SameSiteMode.None,
SecurePolicy = CookieSecurePolicy.Always,
IsEssential = true,
};
}
Sounds good.