Star 历史趋势
数据来源: GitHub API · 生成自 Stargazers.cn
README.md

OpenIddict

The OpenID Connect stack you'll be addicted to.

What is OpenIddict?

OpenIddict aims at providing a versatile solution to implement OpenID Connect client, server and token validation support in .NET applications.

[!TIP] While the client, server and token validation features can be used in any ASP.NET 4.6.2+ or ASP.NET Core 2.3+ web application, the client feature can also be used in Android, iOS, Linux, Mac Catalyst, macOS and Windows applications to integrate with OpenIddict-based identity providers or any other OAuth 2.0/OpenID Connect-compliant implementation.

OpenIddict fully supports the code/implicit/hybrid flows, the client credentials/resource owner password grants, the device authorization flow and the token exchange grant.

OpenIddict natively supports Entity Framework Core, Entity Framework 6 and MongoDB out-of-the-box and custom stores can be implemented to support other providers.


Getting started

To implement a custom OpenID Connect server using OpenIddict, read Getting started.

Samples demonstrating how to use OpenIddict with the different OAuth 2.0/OpenID Connect flows can be found in the dedicated repository.

Developers looking for a simple and turnkey solution are strongly encouraged to evaluate Volo.OpenIddict.Pro, which is based on OpenIddict, supports all the common OAuth 2.0/OpenID Connect flows and offers a powerful applications/scopes management GUI.

[!TIP] Looking to integrate with a SAML2P Identity Provider (IDP) or Service Provider (SP)? Rock Solid Knowledge, a sponsor of OpenIddict, is developing a range of identity components to enhance your OpenIddict solution. The first of these is their popular SAML2P component.


Certification

Unlike many other identity providers, OpenIddict is not a turnkey solution but a framework that requires writing custom code to be operational (typically, at least an authorization controller), making it a poor candidate for the certification program.

While a reference implementation could be submitted as-is, this wouldn't guarantee that implementations deployed by OpenIddict users would be standard-compliant.

Instead, developers are encouraged to execute the conformance tests against their own deployment once they've implemented their own logic.

[!TIP] The samples repository contains a dedicated sample specially designed to be used with the OpenID Connect Provider Certification tool and demonstrate that OpenIddict can be easily used in a certified implementation. To allow executing the certification tests as fast as possible, that sample doesn't include any membership or consent feature (two hardcoded identities are proposed for tests that require switching between identities).


Resources

Looking for additional resources to help you get started with OpenIddict? Don't miss these interesting blog posts:

OpenIddict-based projects maintained by third parties:


Security policy

Security issues and bugs should be reported privately by emailing security@openiddict.com. You should receive a response within 24 hours. If for some reason you do not, please follow up via email to ensure we received your original message.


Support policy

If you need support, please first make sure you're sponsoring the project or are a regular contributor: GitHub tickets opened by users who haven't contributed to the project or don't actively sponsor it will be automatically closed.

[!TIP] Depending on the tier you selected, you can open a GitHub ticket or send an email to contact@openiddict.com for private support.

Alternatively, you can also post your question on Gitter.

Support is only offered for the latest stable version of OpenIddict. There are, however, two exceptions to this policy:

  • ABP Framework users receive patches for OpenIddict for as long as ABP Framework itself is supported by Volosoft (typically a year following the release of a major ABP version), whether they have a commercial ABP license or just use the free packages:
OpenIddict branchABP Framework branchEnd of support date (estimated)
5.x8.xNovember 19, 2025
6.x9.xCurrently supported
7.x (current)Not supported yetNot supported yet
  • OpenIddict sponsors are offered extended support depending on the selected sponsorship tier:
    • Tier 6 sponsors get full support for the previous version 1 month following the release of a new major version.
    • Tier 7 sponsors get full support for the previous version 6 months following the release of a new major version.
    • Tier 8 sponsors get full support for the previous version 12 months following the release of a new major version.
    • Tier 9 sponsors get full support for the previous version 24 months following the release of a new major version.
OpenIddict branchSponsorship tierEnd of support date
5.xTier 6January 17, 2025
5.xTier 7June 17, 2025
5.xTier 8December 17, 2025
5.xTier 9December 17, 2026
6.xTier 6August 7, 2025
6.xTier 7January 7, 2026
6.xTier 8July 7, 2026
6.xTier 9July 7, 2027
7.x (current)AnyCurrently supported

[!TIP] For more information on the different tiers and the benefits they offer, visit GitHub Sponsors.


Nightly builds

If you want to try out the latest features and bug fixes, there is a MyGet feed with nightly builds of OpenIddict. To reference the OpenIddict MyGet feed, create a NuGet.config file (at the root of your solution):

<?xml version="1.0" encoding="utf-8"?> <configuration> <packageSources> <add key="nuget" value="https://api.nuget.org/v3/index.json" /> <add key="openiddict" value="https://www.myget.org/F/openiddict/api/v3/index.json" /> </packageSources> </configuration>

Contributors

OpenIddict is actively maintained by Kévin Chalet. Contributions are welcome and can be submitted using pull requests.

Special thanks to our sponsors for their incredible support:

Volosoft logo

OpenIddict Components logo

User avatar: Sébastien RosUser avatar: Schmitt ChristianUser avatar: Sebastian StehleUser avatar: Communicatie CockpitUser avatar: User avatar: Jasmin SavardUser avatar: ThomasUser avatar: User avatar: EYERIDE Fleet Management SystemUser avatar: Ravindu LiyanapathiranaUser avatar: Corentin BrossuttiUser avatar: Barry DorransUser avatar: DevQ S.r.l.User avatar: User avatar: ForterroUser avatar: MarcelUser avatar: Jens WillmerUser avatar: Blauhaus Technology (Pty) LtdUser avatar: Jan TrejbalUser avatar: Aviationexam s.r.o.User avatar: Jeroen BaidenmannUser avatar: Lombiq Technologies Ltd.User avatar: Andrew BabbittUser avatar: Steven KuhnUser avatar: softaware gmbhUser avatar: Singular SystemsUser avatar: SCP-srlUser avatar: Realisable SoftwareUser avatar: Sipke SchoorstraUser avatar: James HoughUser avatar: User avatar: User avatar: ArwinUser avatar: ZUNDA Inc.User avatar: Antony Petras

License

This project is licensed under the Apache License. This means that you can use, modify and distribute it freely. See http://www.apache.org/licenses/LICENSE-2.0.html for more details.

关于 About

Flexible and versatile OAuth 2.0/OpenID Connect stack for .NET
aspnetcoredotnetoauth2openidconnect

语言 Languages

C#80.4%
HTML6.9%
JavaScript5.7%
PowerShell1.9%
Shell1.7%
Less1.6%
CSS1.4%
CMake0.1%
Python0.1%
PHP0.0%
CoffeeScript0.0%
Batchfile0.0%
ASP.NET0.0%

提交活跃度 Commit Activity

代码提交热力图
过去 52 周的开发活跃度
111
Total Commits
峰值: 12次/周
Less
More

核心贡献者 Contributors