Ecosyste.ms: Awesome
An open API service indexing awesome lists of open source software.
https://github.com/vpro/magnolia-module-vpro-keycloak
Magnolia Module to make it possible to login into Magnolia using Keycloak
https://github.com/vpro/magnolia-module-vpro-keycloak
keycloak magnolia-cms magnolia-component sso
Last synced: 28 days ago
JSON representation
Magnolia Module to make it possible to login into Magnolia using Keycloak
- Host: GitHub
- URL: https://github.com/vpro/magnolia-module-vpro-keycloak
- Owner: vpro
- License: gpl-3.0
- Created: 2017-06-08T08:35:57.000Z (over 7 years ago)
- Default Branch: main
- Last Pushed: 2023-07-31T08:40:37.000Z (over 1 year ago)
- Last Synced: 2024-03-25T22:57:06.180Z (10 months ago)
- Topics: keycloak, magnolia-cms, magnolia-component, sso
- Language: Java
- Size: 128 KB
- Stars: 5
- Watchers: 13
- Forks: 0
- Open Issues: 0
-
Metadata Files:
- Readme: README.adoc
- License: LICENSE
Awesome Lists containing this project
README
= magnolia-module-vpro-keycloak
:toc:image:https://github.com/vpro/magnolia-module-vpro-keycloak/workflows/build/badge.svg?[Build Status,link=https://github.com/vpro/magnolia-module-vpro-keycloak/actions?query=workflow%3Abuild]
image:https://maven-badges.herokuapp.com/maven-central/nl.vpro.magnolia/magnolia-module-vpro-keycloak/badge.svg?style=plastic[Maven Central,link=https://maven-badges.herokuapp.com/maven-central/nl.vpro.magnolia/magnolia-module-vpro-keycloak]
image:http://www.javadoc.io/badge/nl.vpro.magnolia/magnolia-module-vpro-keycloak.svg?color=blue[javadoc,link=http://www.javadoc.io/doc/nl.vpro.magnolia/magnolia-module-vpro-keycloak]
image:https://img.shields.io/nexus/s/https/oss.sonatype.org/nl.vpro.magnolia/magnolia-module-vpro-keycloak.svg[snapshots,link=https://oss.sonatype.org/content/repositories/snapshots/nl/vpro/magnolia/magnolia-module-vpro-keycloak/]Magnolia Module to make it possible to login into Magnolia using Keycloak
== Installation
To use it you need to install this module as you do normally in Magnolia.
(see https://documentation.magnolia-cms.com/display/DOCS/Installing+a+module[Installing a module])For this module the dependency is:
----
nl.vpro.magnolia
magnolia-module-vpro-keycloak
1.9----
== Configuration
You need to configure a realm in Keycloak to use for your Magnolia instances.
=== Registering clients
To be able to use keycloak in Magnolia it is necessary to register a client for each instance in your Keycloak installation.
Use the following settings:
- Client Protocol is openid-connect
- Access Type is confidential=== Magnolia configuration
Make sure to set the root url to the url of your Magnolia instance.
Do note that https is required to make logins work.Also add the following parameters to your magnolia.properties :
----
keycloak.realm=example-realm
keycloak.client.id=example-client-id
keycloak.auth.url=https://keycloakserver.example.com/auth
keycloak.credentials.secret=234234-234234-234234
keycloak.principal.attribute=email
keycloak.logout.url=${keycloak.auth.url}/realms/${keycloak.realm}/protocol/openid-connect/logout
keycloak.thisServer.sslPort=443
----The values of these settings can be found on the client information pages.
Except for the last one which is the ssl port your server is accessible on. It defaults to the ssl port off 443, in development instances this is most likely 8443The setting _keycloak.principal.attribute_ depends on your realm configuration and how you want
users to login into your application. See Keycloaks https://keycloak.gitbooks.io/documentation/securing_apps/topics/oidc/java/java-adapter-config.html[Java Adapters Config] for more information.
The value is used as the principal on the Magnolia side and used to resolve further user information in the Jaas Chain (magnolia-sso) that is configuredSo in case of email link:mailto:[email protected]_[[email protected]_] would be used as the principal value in the jaas chain to lookup the user.
=== Single signout support
By default keycloak when a user logs send a logout request to all clients which have a session active for that user.
This request does not have that users session associated with it so it requires the code to acquire the session through other
means. For that a SessionListener is used.So to enable single signout, you need to add the session listener to your web.xml :
----
nl.vpro.magnolia.module.keycloak.session.KeycloakSessionListener
----