d4science-keycloak-themes/README.md

3.5 KiB

D4Science Keycloak Themes

D4Science Keycloak Themes repository collects the implementations of base D4Science theme and a set of specific per gateway themes implementations.

Each Keycloak theme is made of a set of Freemarker templates.

Structure of the project

The source code is present in src folder. The themes are in src/themes subfolder. The src/utils subfolder contains some utility test scripts to create Keycloak clients that uses a specific theme.

Built With

Not applicable.

Documentation

For details see Theme section of Keycloak develover docs.

As specified in Deploying Themes section of documentation, themes can be deployed to Keycloak by copying the theme directory to themes or it can be deployed as an archive.

In a future release of this project, when themes have been full tested, it will be implemented a script to build themes archive. For now to deploy themes in a Keycloak we are applying the first approach.

In development phase you have to disable themes caching in Keycloak configuration file first. To do this edit standalone.xml. For theme set staticMaxAge to -1 and both cacheTemplates and cacheThemes to false.

Then we suggest to clone this repo somewhere and create a symbolic link for each theme you want to deploy:

mkdir /opt/git
cd /opt/git
git clone https://code-repo.d4science.org/gCubeSystem/d4science-keycloak-themes.git

cd /opt/keycloak/themes
ln -s /opt/git/d4science-keycloak-themes/src/themes/d4science/ 
ln -s /opt/git/d4science-keycloak-themes/src/themes/dev4.d4science.org/
ln -s /opt/git/d4science-keycloak-themes/src/themes/next.d4science.org/

If you was logged-in in Keycloak administration console already you have to logout them re-login. Then you can set one of the new themes per Keycloak Realm or for a specific Keycloak Client in the realm.

Change log

See Releases.

Authors

License

This project is licensed under the EUPL V.1.1 License - see the LICENSE.md file for details.

About the gCube Framework

This software is part of the gCubeFramework: an open-source software toolkit used for building and operating Hybrid Data Infrastructures enabling the dynamic deployment of Virtual Research Environments by favouring the realisation of reuse oriented policies.

The projects leading to this software have received funding from a series of European Union programmes including:

  • the Sixth Framework Programme for Research and Technological Development
    • DILIGENT (grant no. 004260);
  • the Seventh Framework Programme for research, technological development and demonstration
    • D4Science (grant no. 212488), D4Science-II (grant no.239019), ENVRI (grant no. 283465), EUBrazilOpenBio (grant no. 288754), iMarine(grant no. 283644);
  • the H2020 research and innovation programme
    • BlueBRIDGE (grant no. 675680), EGIEngage (grant no. 654142), ENVRIplus (grant no. 654182), Parthenos (grant no. 654119), SoBigData (grant no. 654024),DESIRA (grant no. 818194), ARIADNEplus (grant no. 823914), RISIS2 (grant no. 824091), PerformFish (grant no. 727610), AGINFRAplus (grant no. 731001);