Generating import-package MANIFEST entries
The Filevault content package maven plugin can analyze the classpath of the compiled classes, derived from the content and create an import-package
MANIFEST entry. Although this is rather something to be expected in the OSGi world, declaring the java packages that the content potentially needs can help detecting deployment errors early.
How it works
(todo: add more detailed explanation)
The generation of the import-package
entry is performed in 3 steps:
1. generate classes
- JSP or HTL plugin transpile the scripts
- Maven compiler plugin compiles the generated java sources
2. analyze classes
The classpath analysis is done in the analyze-classes
goal:
- scan the java classes and extract the used java packages
- scan the dependencies and extract package version information from the MANIFEST if present
- cross reference the packages with the version information from the bundles
- write preliminary
import-package
entry to${vault.generatedImportPackage}
3. post-process and merge with project properties
The final step is performed in the package
goal:
- read
${vault.generatedImportPackage}
- merge with instructions in
<importPackage>
- add
import-package
entry toMETA-INF/MANIFEST.MF
Working with JSPs
(todo)
Working with HTL
Where as the HTL use classes provided through bundles or via java classes in the content are simple to handle, the HTL scripts needs more treatment. similar to the JSPs, the HTL maven plugin can be used to transpile the scripts to java and then the maven compiler will create the classes.
Note on the analyzed packages
The transpiled HTL scripts will contain some sightly compiler and runtime references, which are not true dependencies of the scripts. Nevertheless, they are needed to compile the scripts for the validation and will end up in the analyzed packages. by default, the following packages are excluded from the final import-package
:
org.apache.sling.scripting.sightly.compiler.expression.nodes
org.apache.sling.scripting.sightly.java.compiler
org.apache.sling.scripting.sightly.render
Note: The excludes are present in the default value of the <importPackage>
property and are lost if it is defined in the project. In this cases they need to be added manually.
Example configuration for HTL
<build>
<sourceDirectory>src/content/jcr_root</sourceDirectory>
<plugins>
<plugin>
<groupId>org.apache.jackrabbit</groupId>
<artifactId>filevault-package-maven-plugin</artifactId>
<version>1.4.0-SNAPSHOT</version>
<extensions>true</extensions>
<configuration>
<filterSource>/Users/konradwindszus/git/jackrabbit/filevault-package-maven-plugin/src/content/META-INF/vault/filter.xml</filterSource>
</configuration>
</plugin>
<plugin>
<groupId>org.apache.sling</groupId>
<artifactId>htl-maven-plugin</artifactId>
<version>1.1.0</version>
<executions>
<execution>
<id>validate-scripts</id>
<goals>
<goal>validate</goal>
</goals>
<phase>generate-sources</phase>
<configuration>
<sourceDirectory>src/content/jcr_root</sourceDirectory>
<includes>
<include>**/*.html</include>
</includes>
<failOnWarnings>true</failOnWarnings>
<generateJavaClasses>true</generateJavaClasses>
</configuration>
</execution>
</executions>
</plugin>
</plugins>
</build>
<dependencies>
<!-- needed for HTL compilation validation -->
<dependency>
<groupId>org.apache.sling</groupId>
<artifactId>org.apache.sling.scripting.sightly.compiler</artifactId>
<version>1.0.14</version>
<scope>provided</scope>
</dependency>
<dependency>
<groupId>org.apache.sling</groupId>
<artifactId>org.apache.sling.scripting.sightly.compiler.java</artifactId>
<version>1.0.16</version>
<scope>provided</scope>
</dependency>
</dependencies>