Mod auth openidc
OpenID Certified™ OpenID Connect and FAPI 2 Relying Party module for Apache HTTPd
*mod_auth_openidc* is an OpenID Certified™ authentication and authorization module for the Apache 2.x HTTP server that implements the OpenID Connect 1.x and FAPI 2.x Relying Party functionality. The project is written primarily in C, distributed under the Apache License 2.0 license, first published in 2014. It has gained significant community traction with 1,088 stars and 334 forks on GitHub. Key topics include: access-control, apache-httpd, authentication, c, oidc.
<img width="184" height="96" align="right" src="https://openid.net/wordpress-content/uploads/2016/05/oid-l-certification-mark-l-cmyk-150dpi-90mm.jpg" alt="OpenID Certification">
mod_auth_openidc
mod_auth_openidc is an OpenID Certified™ authentication and authorization module for the Apache 2.x
HTTP server that implements the OpenID Connect 1.x and FAPI 2.x Relying Party functionality.
Overview
This module enables an Apache 2.x web server to operate as an OpenID Connect
Relying Party (RP) towards an OpenID Connect Provider (OP). It relays end user authentication to a Provider and
receives user identity information from that Provider. It then passes on that identity information (a.k.a. claims)
to applications protected by the Apache web server and establishes an authentication session for the identified user.
The protected content, applications and services can be hosted by the Apache server itself or served from
origin server(s) residing behind it by configuring Apache as a Reverse Proxy in front of those servers. The
latter allows for adding OpenID Connect based authentication to existing applications/services/SPAs without
modifying those applications, possibly migrating them away from legacy authentication mechanisms to standards-based
OpenID Connect Single Sign On (SSO).
By default the module sets the REMOTE_USER variable to the id_token [sub] claim, concatenated with the OP's Issuer
identifier ([sub]@[iss]). Other id_token claims are passed in HTTP headers and/or environment variables together with those
(optionally) obtained from the UserInfo endpoint. The provided HTTP headers and environment variables can be consumed by
applications protected by the Apache server.
Custom fine-grained authorization rules - based on Apache's Require primitives - can be specified to match against the
set of claims provided in the id_token/ userinfo claims, see here.
Clustering for resilience and performance can be configured using one of the supported cache backends options as
listed here.
For a complete overview of all configuration options, see the file auth_openidc.conf.
This file can also serve as an include file for httpd.conf.
Installation
Preferably install one of the pre-built binary packages. On Debian/Ubuntu:
shapt install libapache2-mod-auth-openidc
Packages for other platforms are listed in the Wiki,
and release binaries are attached to the GitHub Releases.
To build from source (see INSTALL for the full dependency list):
sh./configure --with-apxs=/usr/bin/apxs2 # apxs2 may be named apxs on your platform make sudo make install
How to Use It
- install and load
mod_auth_openidc.soin your Apache server - set
OIDCRedirectURIto a "vanity" URL within a location that is protected by mod_auth_openidc - configure
OIDCProviderMetadataURLso it points to the Discovery metadata of your OpenID Connect Provider served on the.well-known/openid-configurationendpoint - register/generate a Client identifier and a secret with the OpenID Connect Provider and configure those in
OIDCClientIDandOIDCClientSecretrespectively - register the
OIDCRedirectURIconfigured above as the Redirect or Callback URI for your client at the Provider - configure your protected content/locations with
AuthType openid-connect
A minimal working configuration would look like:
apacheLoadModule auth_openidc_module modules/mod_auth_openidc.so # OIDCRedirectURI is a vanity URL that must point to a path protected by this module but must NOT point to any content OIDCRedirectURI https://<hostname>/secure/redirect_uri # required to persist sessions across restarts and share them across a cluster; # when omitted a random passphrase is generated at each restart, invalidating existing sessions OIDCCryptoPassphrase <passphrase-or-"exec:/path/to/generator"> OIDCProviderMetadataURL <issuer>/.well-known/openid-configuration OIDCClientID <client_id> OIDCClientSecret <client_secret> <Location /secure> AuthType openid-connect Require valid-user </Location>
For claims-based authorization with Require claim: directives see the Wiki page on Authorization. For details on configuring multiple providers see the Wiki.
Quickstart for specific Providers
- Keycloak
- Microsoft Entra ID (Azure AD)
- Google Accounts
- Sign in with Apple
- GLUU Server
- Curity Identity Server
and more
See the Wiki for configuration docs for other OpenID Connect Providers.
Interoperability and Supported Specifications
mod_auth_openidc is OpenID Certified™ and supports the following specifications:
- OpenID Connect Core 1.0 (Basic, Implicit, Hybrid and Refresh flows)
- RFC 7636 - Proof Key for Code Exchange by OAuth Public Clients
- FAPI 2.0 Security Profile
- FAPI 2.0 Message Signing
- RFC 9126 - OAuth 2.0 Pushed Authorization Requests
- RFC 9449 - OAuth 2.0 Demonstrating Proof of Possession (DPoP)
- OpenID Connect Discovery 1.0
- OpenID Connect Dynamic Client Registration 1.0
- OAuth 2.0 Form Post Response Mode 1.0
- OAuth 2.0 Multiple Response Type Encoding Practices 1.0
- OpenID Connect Session Management 1.0 see the Wiki for information on how to configure it)
- OpenID Connect Front-Channel Logout 1.0
- OpenID Connect Back-Channel Logout 1.0
Support
Community
Documentation can be found at the Wiki (including Frequently Asked Questions) at:
https://github.com/OpenIDC/mod_auth_openidc/wiki
For questions, issues and suggestions use the Github Discussions forum at:
https://github.com/OpenIDC/mod_auth_openidc/discussions
Security
To report a security vulnerability, please follow the process in SECURITY.md
(e-mail support@openidc.com); do not file public issues for vulnerabilities.
Commercial
Licensed builds with support for Redis/Valkey over TLS, Redis Sentinel/Cluster as well as binary packages for Microsoft Windows, EOL Red Hat, Ubuntu and Debian releases, Oracle HTTP Server and IBM HTTP Server are available under a commercial agreement.
For inquiries about commercial - subscription based - support and licensing please contact:
sales@openidc.com
License
Apache License 2.0 - see LICENSE.txt.
Disclaimer
This software is open sourced by OpenIDC, a subsidiary of ZmartZone Holding B.V. For commercial services
you can contact OpenIDC as described above in the Support section.
Contributors
Showing top 12 contributors by commit count.
