OPLogout
File(s): conf/relying-party.xml, conf/oidc.properties
Format: Native Spring, Spring Properties
Overview
Since OP version 4.1, the OIDC.Logout profile configuration bean enables support for the OIDC logout specifications that cover the two halves:
Responding to requests from RP (OIDC RP-initiated logout)
Propagating logout to an RP (OIDC front- and back-channel logout)
Similarly to the SAML logout, the propagation step works in the same way regardless of how the logout is initiated (see LogoutConfiguration ).
Configuration
Profile configurations
In addition to the OIDC.Logout bean, make sure to include/reference the OAUTH2.Revocation profile bean to enable token revocation during the logout process (see documentation for the revokeTokens -property below).
Required IdP properties
Similarly to the SAML logout, the following global configuration properties need to be set to true:
idp.session.trackSPSession
idp.session.secondaryServiceIndex
Metadata items
In addition to the configuration options below, the following items at the RP metadata are needed for specific features:
post_logout_redirect_uris: the set of redirection URIs that may be used with the OIDC RP-initiated logout
backchannel_logout_uri: the URI used with the back-channel logout propagation
backchannel_logout_session_required: the flag to indicate that sid-parameter should be included in the back-channel logout request
frontchannel_logout_uri: the URI used with the front-channel logout propagation
frontchannel_logout_session_required: the flag to indicate that sid-parameter should be included in the front-channel logout request
Either backchannel_logout_uri or frontchannel_logout_uri needs to be included in the RP metadata to activate the propagation support.
Logout views in IdP 5.0
With IdP 5.0, the logout-propagate.vm
and logout-complete.vm
views need to be modified to contain the following iframe inside the if-clause:
<!-- If OIDC logout, complete the flow by adding a hidden iframe. -->
#if ($profileRequestContext.getProfileId().contains("oidc/logout"))
<iframe style="display:none" src="$flowExecutionUrl&_eventId=proceed"></iframe>
#end
The snippet is needed to close the logout process and free up the resources on the IdP-side. In the cases when RP-initiated logout was used to initiate the logout process and the logout request message contained the post_logout_redirect_uri -parameter, this iframe will also call that post logout redirection URI via HTTP 302 redirect.
From IdP 5.1 onwards, no changes to the default logout views are needed.
Profile configuration options
Virtually all the configuration options below can be set via two different properties: a static property that explicitly sets the value to use and a lookup strategy or predicate property that takes a Function or Predicate and returns the value to use. The dynamic property is generally named "propertyNamePredicate" or "propertyNameLookupStrategy" for Boolean- and non-Boolean-valued properties respectively.