Skip to content

Latest commit

 

History

History

schemas

Maven module containing schema plugins

Schema Plugin Definition

  1. src/main/plugin/<folder> contents:

    • schema-ident.xml required configuration file
    • schema definition xsd files
    • transformations xsl files

    See GeoNetwork Manual

  2. src/main/java providing:

  • Optional: SchemaPlugin bean
  • Optional: ApplicationListener to auto install plugin
  1. Schema plugin pom.xml are asked to bundle their src/main/plugin into a zip:

       <!-- package up plugin folder as a zip -->
       <plugin>
         <artifactId>maven-assembly-plugin</artifactId>
         <executions>
           <execution>
             <id>plugin-assembly</id>
             <phase>package</phase>
             <goals><goal>single</goal></goals>
             <inherited>false</inherited>
             <configuration>
              <appendAssemblyId>false</appendAssemblyId>
              <descriptors>
               <descriptor>src/assembly/schema-plugin.xml</descriptor>
              </descriptors>
             </configuration>
           </execution>
         </executions>
       </plugin>
  2. Using a src/assembly/schema-plugin.xml assembly:

    <assembly xmlns="http://maven.apache.org/ASSEMBLY/2.1.0"
        xmlns:xsi="http://www.w3.org/2001/XMLSchema-instance"
        xsi:schemaLocation="http://maven.apache.org/ASSEMBLY/2.1.0 http://maven.apache.org/xsd/assembly-2.1.0.xsd">
      <id>plugin</id>
      <includeBaseDirectory>false</includeBaseDirectory>
      <formats>
        <format>zip</format>
      </formats>
      <fileSets>
        <fileSet>
          <directory>src/main/plugin/</directory>
          <outputDirectory></outputDirectory>
          <useDefaultExcludes>true</useDefaultExcludes>
        </fileSet>
      </fileSets>
    </assembly>
  3. If you need to depend on any geonetwork modules please make use of project.version property:

    <dependency>
      <groupId>org.geonetwork-opensource</groupId>
      <artifactId>common</artifactId>
      <version>${project.version}</version>
    </dependency>
  4. The use of project.version is also required for schemas modules:

    <dependencies>
      <dependency>
        <groupId>org.geonetwork-opensource.schemas</groupId>
        <artifactId>schema-core</artifactId>
        <version>${project.version}</version>
      </dependency>
      <dependency>
        <groupId>org.geonetwork-opensource.schemas</groupId>
        <artifactId>schema-iso19139</artifactId>
        <version>${project.version}</version>
      </dependency>
    </dependencies>
  5. Use mvn install to install your schema plugin in your local repository.

Optional: Add a plugin to the build

While schema plugins can be built independently, they can be conditionally included in the build:

  1. Add schema plugin:

    • As a folder, using .gitignore to avoid accidentally committing:

      iso19139.xyz
      
    • As a git submodule if you are making a fork `

  2. Use a profile (activated by your schema plugin folder being present) to include your schema plugin to the list of modules in pom.xml.

    <profiles>
      <profile>
        <id>schema-iso19139.xyz</id>
        <activation>
        <file>
          <exists>iso19139.xyz</exists>
        </file>
        </activation>
        <modules>
          <module>iso19139.xyz</module>
        </modules>
      </profile>
    </profiles>
  3. The add-schema.sh script automates these changes.