Implementing common application headers using Maven Overlay
Many web applications these days are not really a single deployed instances, they are a set of applications (.ear files) deployed in different application server instances. Typically the developers divide them based on the tabs or functionality. For example, the landing or overview is one deployment, where as, billing and reports could be separate deployment and so on.
But one thing which will be common in all these individual applications would be the application header (i'm not talking about http headers) which shows the page navigation. This header can have multi-level navigation structure. When user click on say Billing tab which is deployed in different app server instance, the request goes to that new server, new session gets created and page will be rendered with its own headers. The look n feel of this Billing page header would be kept same as Overview page, to make this transition unnoticeable to user.
For the above purpose, the developers end up in implementing the same header code in all the projects (each application instance), which has the following concerns:
- Redundant code. All the JSPs, associated CSS & Javascript, any 3rd javascript frameworks, Java code if any backend logic has to be processed, should be replicated in all projects.
- Changes to the headers in project has to manually merged into other project header codes also. Which is cumbersome or possibility of forgetting.
We have Maven Overlay to rescue us here.
The idea hear is, all the header related code (Java, Jsp, Html, CSS, Javascript n others) will be kept in a single Web project (preferably a separate project). Then this project is dymically included into the main projects during build time. The advantanges of this apporach are :
- The main projects (Overview, Billing etc) doesnt have to have any header code.
- All the header codes are under single project, so either code or code changes does not have to be replicated.
- Compiled once, copied to other projects, means quicker builds.
The same concept can be applied to Footers. For that matter, this can be used in any functionality of the app which remains same in multiple domains.
Enough of theory right, now let us get our hands dirty:
Here is the CommonHeaderProject structure.
This projects contains all the header n footer jsps. Here i used Navigation.xml to define the navigation structure and using XSL to render the html header.
Now let us have a look at the maven pom.xml for this CommonHeaderProject.
Note that this project is built as War.
Here is the pom.xml excerpt from one of the main projects (OverviewWeb).
The overlay tag above instructs maven build to look for project mybiz-header dependency for the given groupId. Maven overlay provides us the option to include and exclude files.
When OverviewWeb is built using maven, maven bring the included files from mybiz-header war and copies them into the OverviewWeb target. Maven retains the same package structure for the files brought.
Here is the OverviewWeb target after maven build. You may see the files from CommonHeaderProject are copied to this target.
Similarly for other projects to use the same header, just have to add overlays to their pom. Thats it, as simple as that.
But one thing which will be common in all these individual applications would be the application header (i'm not talking about http headers) which shows the page navigation. This header can have multi-level navigation structure. When user click on say Billing tab which is deployed in different app server instance, the request goes to that new server, new session gets created and page will be rendered with its own headers. The look n feel of this Billing page header would be kept same as Overview page, to make this transition unnoticeable to user.
For the above purpose, the developers end up in implementing the same header code in all the projects (each application instance), which has the following concerns:
- Redundant code. All the JSPs, associated CSS & Javascript, any 3rd javascript frameworks, Java code if any backend logic has to be processed, should be replicated in all projects.
- Changes to the headers in project has to manually merged into other project header codes also. Which is cumbersome or possibility of forgetting.
We have Maven Overlay to rescue us here.
The idea hear is, all the header related code (Java, Jsp, Html, CSS, Javascript n others) will be kept in a single Web project (preferably a separate project). Then this project is dymically included into the main projects during build time. The advantanges of this apporach are :
- The main projects (Overview, Billing etc) doesnt have to have any header code.
- All the header codes are under single project, so either code or code changes does not have to be replicated.
- Compiled once, copied to other projects, means quicker builds.
The same concept can be applied to Footers. For that matter, this can be used in any functionality of the app which remains same in multiple domains.
Enough of theory right, now let us get our hands dirty:
Here is the CommonHeaderProject structure.
This projects contains all the header n footer jsps. Here i used Navigation.xml to define the navigation structure and using XSL to render the html header.
Now let us have a look at the maven pom.xml for this CommonHeaderProject.
<modelVersion>4.0.0</modelVersion>
<groupId>com.sudheer.mybiz</groupId>
<artifactId>commonHeaderProject</artifactId>
<packaging>war</packaging>
<version>3.0.0-SNAPSHOT</version>
<name>mybiz-header</name>
<url>http://maven.apache.org</url>
Note that this project is built as War.
Here is the pom.xml excerpt from one of the main projects (OverviewWeb).
<build>
<finalName>OverviewWeb</finalName>
<plugins>
<plugin>
<groupId>org.apache.maven.plugins</groupId>
<artifactId>maven-war-plugin</artifactId>
<version>2.1-beta-1</version>
<configuration>
<archive>
<manifest>
<addDefaultImplementationEntries>true</addDefaultImplementationEntries>
<addDefaultSpecificationEntries>true</addDefaultSpecificationEntries>
</manifest>
</archive>
<attachClasses>true</attachClasses>
<overlays>
<overlay>
<groupId>com.sudheer.mybiz</groupId>
<artifactId>mybiz-header</artifactId>
<includes>
<include>jsp/includes/*</include>
</includes>
</overlay>
</overlays>
<filteringDeploymentDescriptors>true</filteringDeploymentDescriptors>
</configuration>
</plugin>
</plugins>
</build>
The overlay tag above instructs maven build to look for project mybiz-header dependency for the given groupId. Maven overlay provides us the option to include and exclude files.
When OverviewWeb is built using maven, maven bring the included files from mybiz-header war and copies them into the OverviewWeb target. Maven retains the same package structure for the files brought.
Here is the OverviewWeb target after maven build. You may see the files from CommonHeaderProject are copied to this target.
Similarly for other projects to use the same header, just have to add overlays to their pom. Thats it, as simple as that.
Comments