Minimal parent project for any Java app (or service) that needs to be packaged in a fat-jar (using Maven shade plugin). It also produced a build info file so your code can report on its build time info.
To build this project do this:
$ mvn clean install
To use it just place the following at the top of your own pom.xml
:
<parent>
<groupId>org.public</groupId>
<artifactId>app-parent</artifactId>
<version>1.0.0</version>
</parent>
Once you've done this, every time you build your app will end up as a far JAR under your project's /target
directory. Please read below about your app's main class.
You have to explicitly define your app's main class (fully qualified) in your app's pom.xml
inside a <properties>
section:
<app.main.class>com.mycompany.myapp.MyAppMain</app.main.class>
This is the property key this project's shaded JAR plugin will use to set the Main-Class:
attribute in your app's JAR MANIFEST.MF file.
NOTE: Failure to do this will leave your app's fat JAR un-executable!
This parent POM uses the maven-git-commit-id-plugin
. Please refer to that plugin's github page for full instructions.
But in short, you include a git.properties
as a template in your project's /src/main/resources
directory and this plugin generates a file of the exact same name with all the available git & build time info under your project's /target/classes
.
You can then read that git.properties
file at runtime and provide a /admin/build-info
(or something similar) to your users.