Spring Boot support

Spring Boot is a framework to create stand-alone, production-grade Spring based applications very easily, thanks to its convention over configuration mechanism that allows Spring Boot to pre-configure applications in an opinionated way whenever possible.

All of this auto-configuration is driven by the concept of starters and conditional annotations that Spring Boot provides.

A starter is basically a dependency descriptor that you can use in your application in order to add all the related dependencies involved in a technology with a minimal specification. Additionally, a starter typically contains auto-configuration classes. Auto-configuration instantiates a default set of Spring beans that implement the functionality of the starter module depending on corresponding configuration properties found on the classpath. All beans can be overridden in case the default is not sufficient.

IPF provides Spring Boot starter modules for bootstrapping basic IPF infrastructure such as mapping as well as for HL7- or IHE-related components. The IPF starter modules also depend on Camel Spring Boot, which sets up a configurable Camel infrastructure for your project.

Dependencies on the IPF starter modules are established through regular Maven dependencies, e.g. for the IHE XDS starter:

    <dependency>
        <groupId>org.openehealth.ipf.boot</groupId>
        <artifactId>ipf-xds-spring-boot-starter</artifactId>
    </dependency>

Apart from ipf-spring-boot-starter, the available starter modules are:

Starter module Purpose
ipf-atna-spring-boot-starter set up ATNA infrastructure
ipf-hl7-spring-boot-starter for HL7v2/MLLP-based IHE transactions
ipf-hl7v3-spring-boot-starter for HL7v3/SOAP-based IHE transactions
ipf-xds-spring-boot-starter for XDS/SOAP-based IHE transactions
ipf-fhir-spring-boot-starter for FHIR/REST-based IHE transactions
ipf-hpd-spring-boot-starter for DSML/SOAP-based IHE transactions
ipf-xacml20-spring-boot-starter for XACML20-based IHE transactions

These IPF starter modules transitively depend on ipf-spring-boot-starter, so there is no need to explicitly depend on this module. IPF 3.7 removed this dependency for ipf-atna-spring-boot-starter.

ipf-spring-boot-starter auto-configures org.openehealth.ipf.commons.spring.map.SpringBidiMappingService and provides Spring beans for picking up any org.openehealth.ipf.commons.map.config.CustomMappings.

See here for details on Custom Mappings.

The starter further sets up a bean of type org.openehealth.ipf.commons.core.config.SpringRegistry.

In addition, if the properties server.ssl.enabled and ipf.commons.reuse-ssl-config are set to true, a bean of type org.apache.camel.support.jsse.SSLContextParameters with name bootSslContextParameters is provided, so you can reuse the Spring Boot security configuration for FHIR, MLLP and Web Service IHE transaction endpoints supported by IPF.

ipf-spring-boot-starter provides the following application properties:

Property (ipf.commons.) Default Description
reuse-ssl-config false Whether to set up a bootSslContextParameters bean derived from Spring Boot SSL settings