generate-domino-update-site
This tool allows the generation of a p2 site from a Domino installation folder, similar to the official IBM Domino Update Site for Build Management, as well as the Mavenization of a p2 site generated in that way. This is useful to compile code that targets a newer release of Domino than the one packaged officially.
To use the tool from the command line, either add the OpenNTF Maven repository (https://artifactory.openntf.org/openntf) as a plugin repository to your Maven configuration or install the Maven project
Requirements
- A Notes/Domino installation accessible on the running computer, or Domino Docker container/image on the local Docker daemon.
- Maven 3+
- Java 8+
generateUpdateSite Mojo
What It Does
The tool performs several tasks to generate its result:
- Copies the features and plugins from the  osgi/rcp/eclipeandosgi/shared/eclipsedirectories, converting unpacked folder artifacts back into Jar files. IndotsOnlymode, it copiesosgi-dots/rcp/eclipseandosgi-dots/shared/eclipsedirectories.
- If pointed to a Windows Notes installation directory, it will do the same with the frameworkdirectory, which contains UI-specific plugins
- Generates com.ibm.notes.java.apiandcom.ibm.notes.java.api.win32.linuxbundles using Domino's Notes.jar with a version matching today's date, if needed
- Generates a com.ibm.xsp.http.bootstrapbundle in similar fashion, when the JAR is available in the source
- Downloads source bundles for open-source components found in Eclipse's compatible repository
- Creates a basic site.xml file
- Generates artifacts.jar and content.jar files
Command Line Use
Add the OpenNTF Maven server to your ~/.m2/settings.xml file. For example:
<?xml version="1.0"?>
<settings xmlns="http://maven.apache.org/SETTINGS/1.0.0"
    xmlns:xsi="http://www.w3.org/2001/XMLSchema-instance"
    xsi:schemaLocation="http://maven.apache.org/SETTINGS/1.0.0 http://maven.apache.org/xsd/settings-1.0.0.xsd">
    <profiles>
        <profile>
            <id>openntf</id>
            <pluginRepositories>
                <pluginRepository>
                    <id>artifactory.openntf.org</id>
                    <name>artifactory.openntf.org</name>
                    <url>https://artifactory.openntf.org/openntf</url>
                </pluginRepository>
            </pluginRepositories>
        </profile>
    </profiles>
    <activeProfiles>
        <activeProfile>openntf</activeProfile>
    </activeProfiles>
</settings>
Execute the plugin with properties to point to the base of your Domino installation and the target folder. For example:
$ mvn org.openntf.p2:generate-domino-update-site:6.0.0:generateUpdateSite \
    -Dsrc="/Volumes/C/Program Files/IBM/Domino" \
    -Ddest="/Users/someuser/Desktop/UpdateSite" \
    -DflattenEmbeds=false # optional
    -DonlyDots=true # optional
- srcis the location of Domino. On Windows, this might be “C:\Program Files\IBM\Domino”. If unspecified, the Mojo will attempt to find a Domino or Notes installation based on common locations
- destis where you want to save it to. For the Extension Library, this was historically “C:\UpdateSite”, but it can be anywhere
- flattenEmbedswill look for embedded JARs named with Bundle-ClassPath and expand their contents out into the main bundle
- onlyDotswill generate an update site for DOTS plugins.
Alternatively, Docker container/image can be used to generate update site.
$ mvn org.openntf.p2:generate-domino-update-site:6.0.0:generateUpdateSite \
    -DsrcContainer="domino-container" # Either srcContainer or srcImageId should be used
    -DsrcImageId="Domino:latest"
    -DdockerDominoDir="/opt/hcl/domino/notes/latest/linux"
    -Ddest="/Users/someuser/Desktop/UpdateSite" \
    -DflattenEmbeds=false # optional
    -DonlyDots=true # optional
- srcContaineris the container to be used as the source. Will be ignored if an image id provided.
- srcImageIdis the image id to be used as the source. When given, mojo will create a temporary container with the image and remove when it's done.
- dockerDominoDiris the directory to the domino installation inside the container. Default value (- /opt/hcl/domino/notes/latest/linux) will be used if omitted. Mojo will pull necessary files to a temporary directory.
Note: the flattenEmbeds option strips signature files and makes no attempt to merge conflicts between same-named files. Accordingly, the result bundles may not behave the same way as their original versions.
Programmatic Use
To incorporate the tool into another program, create a new object of class org.openntf.p2.domino.updatesite.tasks.GenerateUpdateSiteTask with the same parameters as via the command line and execute its run method (or provide it to any executor that can take a Runnable).
mavenizeBundles Mojo
p2-layout-resolver
Though this Mojo still exists in this plugin, you should consider using the p2-layout-resolver plugin instead.
What It Does
This tool processes a p2 site (or a bundles directory directly) and installs the contents into the local Maven repository. It derives its Maven information from the configuration bundle's manifest:
- The groupIdcan be set with the “groupId” parameter, and defaults to “com.ibm.xsp”
- The artifactIdis the bundle's symbolic name
- The versionis the bundle version
- The organizationis theBundle-Vendorvalue, if present
- The dependenciesare other created bundles based on theRequire-Bundlevalue
Additionally, this installs any embedded JARs as attached entities with the classifier matching their base name. For example, Notes.jar from the 9.0.1 release can be accessed like:
<dependency>
  <groupId>com.ibm.xsp</groupId>
  <artifactId>com.ibm.notes.java.api.win32.linux</artifactId>
  <version>[9.0.1,)</version>
  <classifier>Notes</classifier>
  <scope>provided</scope>
</dependency>
Command Line Use
Execute the plugin with properties to point to the base of your Domino installation and the target folder. For example:
$ mvn org.openntf.p2:generate-domino-update-site:6.0.0:mavenizeBundles \
    -Dsrc="/Users/someuser/Desktop/UpdateSite" \
    -DgroupId=some.group.id # Optional
    -DoptionalDependencies=false # Optional
    -DlocalRepositoryPath=/foo/bar # Optional
- srcis the location of the Update Site
- groupIdis an optional group ID to use for the installed bundles. It defaults to “com.ibm.xsp”
- optionalDependenciessets whether inter-bundle dependencies should be marked as- <optional>true</optional>
- localRepositoryPathsets a local repository directory to use instead of the default
mavenizeAndDeployBundles Mojo
This mojo is similar to the mavenizeBundles mojo, but deploys the bundles to a remote repository.
Command Line Usage
It has the same options and behavior as mavenizeBundles, with the exception of localRepositoryPath. Instead, it requires deploymentRepository in the same format as altDeploymentRepository in the maven-install-plugin:deploy goal. For example:
$ mvn org.openntf.p2:generate-domino-update-site:6.0.0:mavenizeAndDeployBundles \
    -Dsrc="/Users/someuser/Desktop/UpdateSite" \
    -DdeploymentRepository=some.repo::default::https://some.repo/path
    -DgroupId=some.group.id # Optional
    -DoptionalDependencies=false # Optional