Gluu Admin UI: Backend Plugin development document - GluuFederation/gluu-admin-ui GitHub Wiki
Gluu Admin-UI is a graphical user interface for the administrators to manage configuration and other properties of Jans Auth Server. This GUI interacts with Jans Auth Server via the rest APIs layer called Jans Config Api. Both Admin-UI Frontend and Jans Config API follow a flexible plugin architecture in which the new features can be added using extensions called plugins without altering the application itself. In this section, we will discuss the steps to develop and add plugins in Jans Config API.
The plugin developer should have an understanding of the following:
- Java: The plugin developer should know the Java programming language
- Weld: Weld is the reference implementation of CDI: Contexts and Dependency Injection for the Java EE Platform
- JAX-RS: JAX-RS for creating RESTful web services.
- Maven: Maven to build projects and manage dependencies.
- Web application container (Jetty)
Jans Config API is a REST application that is developed using Weld 3.x (JSR-365) and JAX-RS. The plugin architecture implemented in Jans Config API allows the deployer to add/remove new rest APIs (plugin) without changing the core application.
A plugin contains one or more Rest API(s) packaged in a Java ARchive (jar file). It is added to Jans Config API by adding the plugin jarfile path in the external extraClasspath of the jetty context file.
To help bootstrap the plugin development, we have put together a sample plugin.
- Clone the Jans Config API project from here.
- Switch to
plugin_template
branch of this project. - Navigate under the plugins folder, there you will see a folder named
helloworld-plugin
. This folder represents and contains the code for a basic plugin with GET endpoint sendingHello World!
string response. - Take the time to explore
helloworld-plugin
which is a minimalistic plugin that showcases very basic aspects of plugin development.
The resources/META-INF/beans.xml
is the CDI deployment descriptor required in bean archive
. Deployment descriptor helps WELD to explore beans, interceptors, decorators, etc in the bean archive
. Refer WELD docs to know more about deployment descriptors.
A CDI portable extension is a mechanism by which we can implement additional functionalities on top of the CDI container. In this sample plugin, we have created an Extension HelloWorldExtension.java
implementing javax.enterprise.inject.spi.Extension
. An extension can observe lifecycle events and also can modify the container’s metamodel. Please refer WELD documentation for details.
We need to register our extension as a service provider by creating a file named resources/META-INF/services/javax.enterprise.inject.spi.Extension
(as shown below).
io.jans.configapi.plugin.helloworld.extensions.HelloWorldExtension
This class is annotated with the @ApplicationPath
annotation which identifies the application path that serves as the base URI for all resources of the plugin and is used to register JAX-RS resources and providers.
This is sample JAX-RS resource with an endpoint returning Hello World!
string as http response.
Jans Config API is offered as one of the several components of the Jans Auth Server. A plugin jar can be added to Jans Config API by following below steps.
- On an installed Jans Auth Server with Jans Config API (as component) copy plugin jar to
/opt/jans/jetty/jans-config-api/custom/libs
location. - Add the location of plugin jar inside tag with name extraClasspath (multiple plugins can be added comma separated) of
/opt/jans/jetty/jans-config-api/webapps/jans-config-api.xml
file.
<?xml version="1.0" encoding="ISO-8859-1"?>
<!DOCTYPE Configure PUBLIC "-//Jetty//Configure//EN" "http://www.eclipse.org/jetty/configure_9_0.dtd">
<Configure class="org.eclipse.jetty.webapp.WebAppContext">
<Set name="contextPath">/jans-config-api</Set>
<Set name="war">
<Property name="jetty.webapps" default="." />/jans-config-api.war
</Set>
<Set name="extractWAR">true</Set>
<Set name="extraClasspath">/opt/jans/jetty/jans-config-api/custom/libs/helloWorldjar</Set>
</Configure>
- Restart
jans-config-api
service.
systemctl restart jans-config-api.service