Skip to content

JeffersonLab/workmap

Repository files navigation

workmap CI Docker

A Java EE 8 web application for geographical work coordination at Jefferson Lab.

Screenshot



Overview

The accelerator task list work map provides geographical context to the accelerator task list calendar and ATLis.

Quick Start with Compose

  1. Grab project
git clone https://github.com/JeffersonLab/workmap
cd workmap
  1. Launch Compose
docker compose up
  1. Navigate to page
http://localhost:8080/workmap

Note: Login with demo username "tbrown" and password "password".

See: Docker Compose Strategy

Install

This application requires a Java 11+ JVM and standard library to run, plus a Java EE 8+ application server (developed with Wildfly).

  1. Install service dependencies
  2. Download Wildfly 26.1.3
  3. Configure Wildfly and start it
  4. Download workmap.war and deploy it to Wildfly
  5. Navigate your web browser to localhost:8080/workmap

Configure

Configtime

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.

Runtime

Uses a subset of the Smoothness Environment Variables including:

  • BACKEND_SERVER_URL
  • FRONTEND_SERVER_URL
  • PUPPET_SHOW_SERVER_URL

The following application specific envs are also used:

Name Description
CALENDAR_URL ATLis SAD Calendar URL

Database

The application requires an Oracle 18+ database with the following schema installed. The application server hosting the app must also be configured with a JNDI datasource.

Build

This project is built with Java 17 (compiled to Java 11 bytecode), and uses the Gradle 7 build tool to automatically download dependencies and build the project from source:

git clone https://github.com/JeffersonLab/workmap
cd workmap
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

Develop

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.yml 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.

Release

  1. Bump the release date and version number in build.gradle and commit and push to GitHub (using Semantic Versioning).
  2. Create a new release on the GitHub Releases page corresponding to the same version in the build.gradle. The release should enumerate changes and link issues. A war artifact can be attached to the release to facilitate easy install by users.
  3. Publish to DockerHub GitHub Action should run automatically.
  4. Bump and commit quick start image version

Deploy

At JLab this app is found at ace.jlab.org/workmap and internally at acctest.acc.jlab.org/workmap. However, those servers are proxies for wildfly6.acc.jlab.org and wildflytest6.acc.jlab.org respectively. A deploy script is provided to automate wget and deploy. Example:

/root/setup/deploy.sh workmap v1.2.3

JLab Internal Docs: InstallGuideWildflyRHEL9

See Also