Skip to content
New issue

Have a question about this project? Sign up for a free GitHub account to open an issue and contact its maintainers and the community.

By clicking “Sign up for GitHub”, you agree to our terms of service and privacy statement. We’ll occasionally send you account related emails.

Already on GitHub? Sign in to your account

Microsoft Security Advisory CVE-2023-33170: .NET Security Feature Bypass Vulnerability #49334

Open
rbhanda opened this issue Jul 11, 2023 · 11 comments
Labels
announcement This issue is an announcement about important functionality change (prevents auto-closing) area-auth Includes: Authn, Authz, OAuth, OIDC, Bearer
Milestone

Comments

@rbhanda
Copy link

rbhanda commented Jul 11, 2023

Microsoft Security Advisory CVE-2023-33170: .NET Security Feature Bypass Vulnerability

Executive summary

Microsoft is releasing this security advisory to provide information about a vulnerability in ASP.NET Core 2.1 and above. This advisory also provides guidance on what developers can do to update their applications to remove this vulnerability.

A vulnerability exist in ASP.NET Core applications where account lockout maximum failed attempts may not be immediately updated, allowing an attacker to try more passwords.

Announcement

Announcement for this issue can be found at dotnet/announcements#264

Mitigation factors

Microsoft has not identified any mitigating factors for this vulnerability.

Affected software

  • Any ASP.NET 7.0 application running on .NET 7.0.8 or earlier.
  • Any ASP.NET 6.0 application running on .NET 6.0.19 or earlier.
  • Any ASP.NET Core 2.1 application consuming the package Microsoft.AspNetCore.Identity version 2.1.31 or earlier.

If your application uses the following package versions, ensure you update to the latest version of .NET.

ASP.NET Core 2.1

Package name Affected version Patched version
Microsoft.AspNetCore.Identity <=2.1.39 2.1.39

Microsoft.AspNet.Identity.Owin

Package name Affected version Patched version
Microsoft.AspNet.Identity.Owin <= 2.2.3 2.2.4

ASP.NET 6.0

Package name Affected version Patched version

Microsoft.AspNetCore.App.Runtime.linux-arm | <= 6.0.19 | 6.0.20
Microsoft.AspNetCore.App.Runtime.linux-arm64 | <= 6.0.19 | 6.0.20
Microsoft.AspNetCore.App.Runtime.linux-musl-arm | <= 6.0.19 | 6.0.20
Microsoft.AspNetCore.App.Runtime.linux-musl-arm64 | <= 6.0.19 | 6.0.20
Microsoft.AspNetCore.App.Runtime.linux-musl-x64 | <= 6.0.19 | 6.0.20
Microsoft.AspNetCore.App.Runtime.linux-x64 | <= 6.0.19 | 6.0.20
Microsoft.AspNetCore.App.Runtime.osx-arm64 | <= 6.0.19 | 6.0.20
Microsoft.AspNetCore.App.Runtime.osx-x64 | <= 6.0.19 | 6.0.20
Microsoft.AspNetCore.App.Runtime.win-arm | <= 6.0.19 | 6.0.20
Microsoft.AspNetCore.App.Runtime.win-arm64 | <= 6.0.19 | 6.0.20
Microsoft.AspNetCore.App.Runtime.win-x64 | <= 6.0.19 | 6.0.20
Microsoft.AspNetCore.App.Runtime.win-x86 | <= 6.0.19 | 6.0.20

ASP.NET 7.0

Package name Affected version Patched version
Microsoft.AspNetCore.App.Runtime.linux-arm <= 7.0.9 7.0.9
Microsoft.AspNetCore.App.Runtime.linux-arm64 <= 7.0.9 7.0.9
Microsoft.AspNetCore.App.Runtime.linux-musl-arm <= 7.0.9 7.0.9
Microsoft.AspNetCore.App.Runtime.linux-musl-arm64 <= 7.0.9 7.0.9
Microsoft.AspNetCore.App.Runtime.linux-musl-x64 <= 7.0.9 7.0.9
Microsoft.AspNetCore.App.Runtime.linux-x64 <= 7.0.9 7.0.9
Microsoft.AspNetCore.App.Runtime.osx-arm64 <= 7.0.9 7.0.9
Microsoft.AspNetCore.App.Runtime.osx-x64 <= 7.0.9 7.0.9
Microsoft.AspNetCore.App.Runtime.win-arm <= 7.0.9 7.0.9
Microsoft.AspNetCore.App.Runtime.win-arm64 <= 7.0.9 7.0.9
Microsoft.AspNetCore.App.Runtime.win-x64 <= 7.0.9 7.0.9
Microsoft.AspNetCore.App.Runtime.win-x86 <= 7.0.9 7.0.9

Advisory FAQ

How do I know if I am affected?

If you have a runtime or SDK with a version listed, or an affected package listed in affected software, you're exposed to the vulnerability.

How do I fix the issue?

  • To fix the issue please install the latest version of .NET 6.0 or .NET 7.0. If you have installed one or more .NET SDKs through Visual Studio, Visual Studio will prompt you to update Visual Studio, which will also update your .NET SDKs.
  • If you are using one of the affected packages, please update to the patched version listed above.
  • If you have .NET 6.0 or greater installed, you can list the versions you have installed by running the dotnet --info command. You will see output like the following;
.NET Core SDK (reflecting any global.json):

 Version:   6.0.300
 Commit:    8473146e7d

Runtime Environment:

 OS Name:     Windows
 OS Version:  10.0.18363
 OS Platform: Windows
 RID:         win10-x64
 Base Path:   C:\Program Files\dotnet\sdk\6.0.300\

Host (useful for support):

  Version: 6.0.5
  Commit:  8473146e7d

.NET Core SDKs installed:

  6.0.300 [C:\Program Files\dotnet\sdk]

.NET Core runtimes installed:

  Microsoft.AspNetCore.App 6.0.5 [C:\Program Files\dotnet\shared\Microsoft.AspNetCore.App]
  Microsoft.NETCore.App 6.0.5 [C:\Program Files\dotnet\shared\Microsoft.NETCore.App]
  Microsoft.WindowsDesktop.App 6.0.5 [C:\Program Files\dotnet\shared\Microsoft.WindowsDesktop.App]

To install additional .NET Core runtimes or SDKs:
  https://aka.ms/dotnet-download

.NET 6.0 and and .NET 7.0 updates are also available from Microsoft Update. To access this either type "Check for updates" in your Windows search, or open Settings, choose Update & Security and then click Check for Updates.

Once you have installed the updated runtime or SDK, restart your apps for the update to take effect.

Additionally, if you've deployed self-contained applications targeting any of the impacted versions, these applications are also vulnerable and must be recompiled and redeployed.

Other Information

Reporting Security Issues

If you have found a potential security issue in .NET 6.0 or .NET 7.0, please email details to secure@microsoft.com. Reports may qualify for the Microsoft .NET Core & .NET 5 Bounty. Details of the Microsoft .NET Bounty Program including terms and conditions are at https://aka.ms/corebounty.

Support

You can ask questions about this issue on GitHub in the .NET GitHub organization. The main repos are located at https://github.com/dotnet/runtime and https://github.com/dotnet/aspnet/. The Announcements repo (https://github.com/dotnet/Announcements) will contain this bulletin as an issue and will include a link to a discussion issue. You can ask questions in the linked discussion issue.

Disclaimer

The information provided in this advisory is provided "as is" without warranty of any kind. Microsoft disclaims all warranties, either express or implied, including the warranties of merchantability and fitness for a particular purpose. In no event shall Microsoft Corporation or its suppliers be liable for any damages whatsoever including direct, indirect, incidental, consequential, loss of business profits or special damages, even if Microsoft Corporation or its suppliers have been advised of the possibility of such damages. Some states do not allow the exclusion or limitation of liability for consequential or incidental damages so the foregoing limitation may not apply.

External Links

CVE-2023-33170

Revisions

V1.0 (July 11, 2023): Advisory published.

Version 1.0

Last Updated 2023-07-11

@dotnet-issue-labeler dotnet-issue-labeler bot added the needs-area-label Used by the dotnet-issue-labeler to label those issues which couldn't be triaged automatically label Jul 11, 2023
@johnkors
Copy link

Affected software

Any ASP.NET 7.0 application running on .NET 7.0.8 or earlier.

If you're using .NET 7.0, you should download and install Runtime 7.0.7

🤔

@danmoseley
Copy link
Member

🤔

I believe I corrected the post -- @rbhanda please confirm.

@Kahbazi
Copy link
Member

Kahbazi commented Jul 12, 2023

@rbhanda The link for the announcement is the wrong issue. I believe this is the correct one. dotnet/announcements#264

@rbhanda
Copy link
Author

rbhanda commented Jul 12, 2023

@rbhanda The link for the announcement is the wrong issue. I believe this is the correct one. dotnet/announcements#264

Sorry about that. I corrected the links and the text in the announcement and this issue

@mkArtakMSFT mkArtakMSFT added area-auth Includes: Authn, Authz, OAuth, OIDC, Bearer announcement This issue is an announcement about important functionality change (prevents auto-closing) and removed needs-area-label Used by the dotnet-issue-labeler to label those issues which couldn't be triaged automatically labels Jul 12, 2023
@mkArtakMSFT mkArtakMSFT added this to the Discussions milestone Jul 12, 2023
@phenning
Copy link
Contributor

phenning commented Jul 12, 2023

@rbhanda Can you confirm whether this vulnerability exists in Microsoft.AspNet.Identity.Owin when targeting .NET Framework TFMS (non NET Core)?

It's not super clear in the bullet points under affected software, even though it is listed in the table below.

@rbhanda
Copy link
Author

rbhanda commented Jul 12, 2023

@rbhanda Can you confirm whether this vulnerability exists in Microsoft.AspNet.Identity.Owin when targeting .NET Framework TFMS (non NET Core)?

It's not super clear in the bullet points under affected software, even though it is listed in the table below.

@GrabYourPitchforks @halter73

@halter73
Copy link
Member

Yes. It affects any consumer of Microsoft.AspNet.Identity.Owin using the account lockout feature including but not limited to full framework.

@phenning
Copy link
Contributor

Yes. It affects any consumer of Microsoft.AspNet.Identity.Owin using the account lockout feature including but not limited to full framework.

Thanks Stephen, wanted to make sure before we started updating the .NET Framework templates in Visual Studio to use the new version.

@11qqaazzqwerty
Copy link

Is it really fixed in version 6.0.20?
Microsoft Defender for Cloud treat this version as affected:
image

@peterlukerow
Copy link

peterlukerow commented Aug 2, 2023

@halter73

Yes. It affects any consumer of Microsoft.AspNet.Identity.Owin using the account lockout feature including but not limited to full framework.

I'm still not clear on this, it's all a little confusing. I'm using .NET 4.8 which is not listed as one of the affect .NETs. Here you state it doesn't matter which framework you are on it's the version of Microsoft.AspNet.Identity.Owin.

However, on [(https://github.com/github/advisory-database/pull/2496)] it says that for Microsoft.AspNet.Identity.Owin you need at least version 7.0.9, however in VS 2019 when managing nugets for the solution we are using v2.2.3 and it says that v2.2.4 is the latest stable, there is no v7.0.9 to upgrade to, thus my confusion.

In a recent external pen test of our web app and on anecdotal evidence an account is always locked out after the number of times configured in our SQL DB, i.e. after 5 invalid attempts, 6th attempt fails even if you use valid credentials.

@halter73
Copy link
Member

halter73 commented Aug 2, 2023

v2.2.4 is the latest stable. github/advisory-database#2496 is an outdated PR between feature branches. If you take a look at what's currently in the main branch, that indicates 2.2.4 is the patched version just like the announcement at dotnet/announcements#264.

@dotnet-policy-service dotnet-policy-service bot added the pending-ci-rerun When assigned to a PR indicates that the CI checks should be rerun label Feb 6, 2024
@wtgodbe wtgodbe removed the pending-ci-rerun When assigned to a PR indicates that the CI checks should be rerun label Feb 6, 2024
@dotnet-policy-service dotnet-policy-service bot added the pending-ci-rerun When assigned to a PR indicates that the CI checks should be rerun label Feb 6, 2024
@wtgodbe wtgodbe removed the pending-ci-rerun When assigned to a PR indicates that the CI checks should be rerun label Feb 13, 2024
@dotnet dotnet deleted a comment from dotnet-policy-service bot Feb 13, 2024
@dotnet dotnet deleted a comment from dotnet-policy-service bot Feb 13, 2024
Sign up for free to join this conversation on GitHub. Already have an account? Sign in to comment
Labels
announcement This issue is an announcement about important functionality change (prevents auto-closing) area-auth Includes: Authn, Authz, OAuth, OIDC, Bearer
Projects
None yet
Development

No branches or pull requests

10 participants