A Jakarta EE 10 web application repo template, relying on the Smoothness web lib.
A Repo Template for web apps at JLab. This repo is intended to be used at new repository creation time to bootstrap new web app projects. Once a new repo is created from this one, a bunch of search and replace is used to rename everything needed for the new app. When viewing this repo in GitHub, click the "Use this template" button to create a new repo. More Template Usage
- Grab project
git clone https://github.com/JeffersonLab/smoothness-template
cd smoothenss-template
- Launch Compose
docker compose up
- Navigate to page
http://localhost:8080/smoothness-template
Note: Login with demo username "tbrown" and password "password".
This application requires a Java 17+ JVM and standard library to run, plus a Jakarta EE 10 application server (developed with Wildfly).
- Install service dependencies
- Download Wildfly 37.0.1
- Configure Wildfly and start it
- Download template.war and deploy it to Wildfly
- Navigate your web browser to localhost:8080/template
Wildfly must be pre-configured before the first deployment of the app. The wildfly bash scripts can be used to accomplish this. See the Dockerfile for an example.
Uses the Smoothness Environment Variables.
This application requires an Oracle 19+ database with the following schema installed. The application server hosting this app must also be configured with a JNDI datasource.
This project is built with Java 21 (compiled to Java 17 bytecode), and uses the Gradle 9 build tool to automatically download dependencies and build the project from source:
git clone https://github.com/JeffersonLab/smoothness-template
cd smoothness-template
gradlew build
Note: If you do not already have Gradle installed, it will be installed automatically by the wrapper script included in the source
Note for JLab On-Site Users: Jefferson Lab has an intercepting proxy
See: Docker Development Quick Reference
In order to iterate rapidly when making changes it's often useful to run the app directly on the local workstation, perhaps leveraging an IDE. In this scenario run the service dependencies with:
docker compose -f deps.yaml up
Note: The local install of Wildfly should be configured to proxy connections to services via localhost and therefore the environment variables should contain:
KEYCLOAK_BACKEND_SERVER_URL=http://localhost:8081
FRONTEND_SERVER_URL=https://localhost:8443
Further, the local DataSource must also leverage localhost port forwarding so the standalone.xml
connection-url field should be: jdbc:oracle:thin:@//localhost:1521/xepdb1
.
The server and app setup scripts can be used to setup a local instance of Wildfly.
- Bump the version number in the VERSION file and commit and push to GitHub (using Semantic Versioning).
- The CD GitHub Action should run automatically invoking:
- The Create release GitHub Action to tag the source and create release notes summarizing any pull requests. Edit the release notes to add any missing details. A war file artifact is attached to the release.
- The Publish docker image GitHub Action to create a new demo Docker image.
- The Deploy to JLab GitHub Action to deploy to the JLab test environment.
The deploy to JLab's acctest is handled automatically via the release workflow.
At JLab this app is found internally at acctest.acc.jlab.org/template. However, the server is a proxy for wildflytest3.acc.jlab.org
. A deploy script is provided on each server to automate wget and deploy. Example:
/opt/wildfly/cd/deploy.sh template v1.2.3
JLab Internal Docs: RHEL9 Wildfly