Skip to content

rakhbari/app-parent

Folders and files

NameName
Last commit message
Last commit date

Latest commit

 

History

7 Commits
 
 
 
 
 
 
 
 

Repository files navigation

app-parent

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.

Build & Use

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.

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!

Git Build Info File

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.

About

No description, website, or topics provided.

Resources

License

Stars

Watchers

Forks

Releases

No releases published

Packages

No packages published