Skip to content

Latest commit

 

History

History
51 lines (33 loc) · 2.85 KB

README.md

File metadata and controls

51 lines (33 loc) · 2.85 KB

JBoss Keycloak Playground

This repository contains the following common scenarios with Jboss Keycloak.

  • direct Shibboleth Service Provider inside of an Apache Httpd 2.4
  • Shibboleth Service Provider inside of an Apache Httpd 2.4 as an Authentication Proxy (planned)

Shibboleth Service Provider

Within Authentication SAML is a mature variant to choose from. Shibboleth installs as an operation system service and runs byside the apache processs.

Direct Shibboleth Service Provider

Shibboleth SP

The scenario is based upon a docker compose setup. It depends upon RFC 6761 (https://tools.ietf.org/html/rfc6761), which Chrome follows. Therefore the hostnames are set to *.localhost domains, which will automatically be resolved against the local loop back device. This eliminates the need of declaring the services as entries in /etc/hosts.

Shibboleth and Keycloak are configured to uss the POST Binding and to sign the messages.

  • Configuration of the Apache to use Shibboleth
    • The Servername determines the host of the Shibboleth SP
  • Export the SAML Metadata of the IDP´s realm
  • Configurate the shibboleth2.xml
  • Configurate the attribute-map.xml
  • Export the SAML Metadata of the SP
  • Create a SAML Client in Keycloak

Keycloak directly creates keystores for the client. The keys and certs have been extracted with : https://serverfault.com/questions/715827/how-to-generate-key-and-crt-file-from-jks-file-for-httpd-apache-server

keytool -export -alias shibboleth-sp -file mydomain.der -keystore keystore.jks
openssl x509 -inform der -in mydomain.der -out certificate.pem
keytool -importkeystore -srckeystore keystore.jks -destkeystore keystore.p12 -deststoretype PKCS12
openssl pkcs12 -in keystore.p12  -nodes -nocerts -out shibboleth-sp.key

Single Sign On

SSO is triggered when visiting http://shibboleth.localhost/secured

Single Logout

The Service Provoder initiated Logout can be triggered by visiting http://shibboleth.localhost/Shibboleth.sso/Logout Keycloak itself does not support backchannel SLO with SAML (see https://www.keycloak.org/docs/latest/server_admin/index.html#logout-all-limitations). Even a IDP initiated frontchannel logout is not supported.

13.1.1. Logout All Limitations Any SSO cookies set will now be invalid and clients that request authentication in active browser > sessions will now have to re-login. Only certain clients are notified of this logout event, specifically clients that are using the Keycloak OIDC client adapter. Other client types (i.e. SAML) will not receive a backchannel logout request. It is important to note that any outstanding access tokens are not revoked by clicking Logout all. >They have to expire naturally. You have to push a revocation policy out to clients, but that also >only works with clients using the Keycloak OIDC client adapter.