All Downloads are FREE. Search and download functionalities are using the official Maven repository.

org.apache.camel.model.dataformat.FhirDataformat Maven / Gradle / Ivy

There is a newer version: 4.7.0
Show newest version
/**
 * Licensed to the Apache Software Foundation (ASF) under one or more
 * contributor license agreements.  See the NOTICE file distributed with
 * this work for additional information regarding copyright ownership.
 * The ASF licenses this file to You under the Apache License, Version 2.0
 * (the "License"); you may not use this file except in compliance with
 * the License.  You may obtain a copy of the License at
 *
 *      http://www.apache.org/licenses/LICENSE-2.0
 *
 * Unless required by applicable law or agreed to in writing, software
 * distributed under the License is distributed on an "AS IS" BASIS,
 * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
 * See the License for the specific language governing permissions and
 * limitations under the License.
 */
package org.apache.camel.model.dataformat;

import java.util.List;
import java.util.Set;

import javax.xml.bind.annotation.XmlAttribute;
import javax.xml.bind.annotation.XmlTransient;

import org.apache.camel.CamelContext;
import org.apache.camel.model.DataFormatDefinition;
import org.apache.camel.spi.DataFormat;
import org.apache.camel.spi.Metadata;
import org.apache.camel.util.ObjectHelper;

public abstract class FhirDataformat extends DataFormatDefinition {
    @XmlTransient
    @Metadata(label = "advanced")
    private Object fhirContext;

    @XmlAttribute
    @Metadata(enums = "DSTU2,DSTU2_HL7ORG,DSTU2_1,DSTU3,R4", defaultValue = "DSTU3")
    private String fhirVersion;

    @XmlAttribute
    private Boolean prettyPrint;

    @XmlTransient
    @Metadata(label = "advanced")
    private Object parserErrorHandler;

    @XmlTransient
    @Metadata(label = "advanced")
    private Object parserOptions;

    @XmlTransient
    @Metadata(label = "advanced")
    private Object preferTypes;

    @XmlTransient
    @Metadata(label = "advanced")
    private Object forceResourceId;

    @XmlAttribute
    @Metadata(label = "advanced")
    private String serverBaseUrl;

    @XmlAttribute
    @Metadata(label = "advanced")
    private Boolean omitResourceId;

    @XmlAttribute
    @Metadata(label = "advanced")
    private Set encodeElementsAppliesToResourceTypes;

    @XmlAttribute
    @Metadata(label = "advanced")
    private Boolean encodeElementsAppliesToChildResourcesOnly;

    @XmlAttribute
    @Metadata(label = "advanced")
    private Set encodeElements;

    @XmlAttribute
    @Metadata(label = "advanced")
    private Set dontEncodeElements;

    @XmlAttribute
    @Metadata(label = "advanced")
    private Boolean stripVersionsFromReferences;

    @XmlAttribute
    @Metadata(label = "advanced")
    private Boolean overrideResourceIdWithBundleEntryFullUrl;

    @XmlAttribute
    @Metadata(label = "advanced")
    private Boolean summaryMode;

    @XmlAttribute
    @Metadata(label = "advanced")
    private Boolean suppressNarratives;

    @XmlAttribute
    @Metadata(label = "advanced")
    private List dontStripVersionsFromReferencesAtPaths;

    protected FhirDataformat(String dataFormatName) {
        super(dataFormatName);
    }

    protected FhirDataformat() {
        // This constructor is needed by jaxb for schema generation
    }



    @Override
    protected void configureDataFormat(DataFormat dataFormat, CamelContext camelContext) {
        if (getContentTypeHeader() != null) {
            setProperty(camelContext, dataFormat, "contentTypeHeader", getContentTypeHeader());
        }
        if (getFhirContext() != null) {
            setProperty(camelContext, dataFormat, "fhirContext", getFhirContext());
        }
        if (getFhirVersion() != null) {
            setProperty(camelContext, dataFormat, "fhirVersion", getFhirVersion());
        }
        if (ObjectHelper.isNotEmpty(getDontStripVersionsFromReferencesAtPaths())) {
            setProperty(camelContext, dataFormat, "dontStripVersionsFromReferencesAtPaths", getDontStripVersionsFromReferencesAtPaths());
        }
        if (ObjectHelper.isNotEmpty(getDontEncodeElements())) {
            setProperty(camelContext, dataFormat, "dontEncodeElements", getDontEncodeElements());
        }
        if (ObjectHelper.isNotEmpty(getEncodeElements())) {
            setProperty(camelContext, dataFormat, "encodeElements", getEncodeElements());
        }
        if (ObjectHelper.isNotEmpty(getEncodeElementsAppliesToResourceTypes())) {
            setProperty(camelContext, dataFormat, "encodeElementsAppliesToResourceTypes", getEncodeElementsAppliesToResourceTypes());
        }
        if (ObjectHelper.isNotEmpty(getServerBaseUrl())) {
            setProperty(camelContext, dataFormat, "serverBaseUrl", getServerBaseUrl());
        }
        if (ObjectHelper.isNotEmpty(getForceResourceId())) {
            setProperty(camelContext, dataFormat, "forceResourceId", getForceResourceId());
        }
        if (ObjectHelper.isNotEmpty(getPreferTypes())) {
            setProperty(camelContext, dataFormat, "preferTypes", getPreferTypes());
        }
        if (ObjectHelper.isNotEmpty(getParserOptions())) {
            setProperty(camelContext, dataFormat, "parserOptions", getParserOptions());
        }
        if (ObjectHelper.isNotEmpty(getParserErrorHandler())) {
            setProperty(camelContext, dataFormat, "parserErrorHandler", getParserErrorHandler());
        }

        Boolean answer = ObjectHelper.toBoolean(isEncodeElementsAppliesToChildResourcesOnly());
        if (answer != null) {
            setProperty(camelContext, dataFormat, "encodeElementsAppliesToChildResourcesOnly", answer);
        }
        answer = ObjectHelper.toBoolean(isOmitResourceId());
        if (answer != null) {
            setProperty(camelContext, dataFormat, "omitResourceId", answer);
        }
        answer = ObjectHelper.toBoolean(isPrettyPrint());
        if (answer != null) {
            setProperty(camelContext, dataFormat, "prettyPrint", answer);
        }
        answer = ObjectHelper.toBoolean(isSuppressNarratives());
        if (answer != null) {
            setProperty(camelContext, dataFormat, "suppressNarratives", answer);
        }
        answer = ObjectHelper.toBoolean(isSummaryMode());
        if (answer != null) {
            setProperty(camelContext, dataFormat, "summaryMode", answer);
        }
        answer = ObjectHelper.toBoolean(getOverrideResourceIdWithBundleEntryFullUrl());
        if (answer != null) {
            setProperty(camelContext, dataFormat, "overrideResourceIdWithBundleEntryFullUrl", answer);
        }
        answer = ObjectHelper.toBoolean(getStripVersionsFromReferences());
        if (answer != null) {
            setProperty(camelContext, dataFormat, "stripVersionsFromReferences", answer);
        }
    }

    public Object getFhirContext() {
        return fhirContext;
    }

    public void setFhirContext(Object fhirContext) {
        this.fhirContext = fhirContext;
    }

    public String getFhirVersion() {
        return fhirVersion;
    }

    /**
     * The version of FHIR to use. Possible values are: DSTU2,DSTU2_HL7ORG,DSTU2_1,DSTU3,R4
     */
    public void setFhirVersion(String fhirVersion) {
        this.fhirVersion = fhirVersion;
    }

    public Boolean isPrettyPrint() {
        return prettyPrint;
    }

    /**
     * Sets the "pretty print" flag, meaning that the parser will encode resources with human-readable spacing and
     * newlines between elements instead of condensing output as much as possible.
     *
     * @param prettyPrint The flag
     */
    public void setPrettyPrint(Boolean prettyPrint) {
        this.prettyPrint = prettyPrint;
    }

    public Object getParserErrorHandler() {
        return parserErrorHandler;
    }

    /**
     * Registers an error handler which will be invoked when any parse errors are found
     *
     * @param parserErrorHandler The error handler to set. Must not be null.
     */
    public void setParserErrorHandler(Object parserErrorHandler) {
        this.parserErrorHandler = parserErrorHandler;
    }

    public Object getParserOptions() {
        return parserOptions;
    }

    /**
     * Sets the parser options object which will be used to supply default
     * options to newly created parsers.
     *
     * @param parserOptions The parser options object
     */
    public void setParserOptions(Object parserOptions) {
        this.parserOptions = parserOptions;
    }

    public Object getPreferTypes() {
        return preferTypes;
    }

    /**
     * If set, when parsing resources the parser will try to use the given types when possible, in
     * the order that they are provided (from highest to lowest priority). For example, if a custom
     * type which declares to implement the Patient resource is passed in here, and the
     * parser is parsing a Bundle containing a Patient resource, the parser will use the given
     * custom type.
     *
     * @param preferTypes The preferred types, or null
     */
    public void setPreferTypes(Object preferTypes) {
        this.preferTypes = preferTypes;
    }

    public Object getForceResourceId() {
        return forceResourceId;
    }

    /**
     * When encoding, force this resource ID to be encoded as the resource ID
     */
    public void setForceResourceId(Object forceResourceId) {
        this.forceResourceId = forceResourceId;
    }

    public String getServerBaseUrl() {
        return serverBaseUrl;
    }

    /**
     * Sets the server's base URL used by this parser. If a value is set, resource references will be turned into
     * relative references if they are provided as absolute URLs but have a base matching the given base.
     *
     * @param serverBaseUrl The base URL, e.g. "http://example.com/base"
     */
    public void setServerBaseUrl(String serverBaseUrl) {
        this.serverBaseUrl = serverBaseUrl;
    }

    public Boolean isOmitResourceId() {
        return omitResourceId;
    }

    /**
     * If set to true (default is false) the ID of any resources being encoded will not be
     * included in the output. Note that this does not apply to contained resources, only to root resources. In other
     * words, if this is set to true, contained resources will still have local IDs but the outer/containing
     * ID will not have an ID.
     *
     * @param omitResourceId Should resource IDs be omitted
     */
    public void setOmitResourceId(Boolean omitResourceId) {
        this.omitResourceId = omitResourceId;
    }

    public Set getEncodeElementsAppliesToResourceTypes() {
        return encodeElementsAppliesToResourceTypes;
    }

    /**
     * If provided, tells the parse which resource types to apply {@link #setEncodeElements(Set) encode elements} to. Any
     * resource types not specified here will be encoded completely, with no elements excluded.
     *
     * @param encodeElementsAppliesToResourceTypes resouce types
     */
    public void setEncodeElementsAppliesToResourceTypes(Set encodeElementsAppliesToResourceTypes) {
        this.encodeElementsAppliesToResourceTypes = encodeElementsAppliesToResourceTypes;
    }

    public Boolean isEncodeElementsAppliesToChildResourcesOnly() {
        return encodeElementsAppliesToChildResourcesOnly;
    }

    /**
     * If set to true (default is false), the values supplied
     * to {@link #setEncodeElements(Set)} will not be applied to the root
     * resource (typically a Bundle), but will be applied to any sub-resources
     * contained within it (i.e. search result resources in that bundle)
     */
    public void setEncodeElementsAppliesToChildResourcesOnly(Boolean encodeElementsAppliesToChildResourcesOnly) {
        this.encodeElementsAppliesToChildResourcesOnly = encodeElementsAppliesToChildResourcesOnly;
    }

    public Set getEncodeElements() {
        return encodeElements;
    }

    /**
     * If provided, specifies the elements which should be encoded, to the exclusion of all others. Valid values for this
     * field would include:
     * 
    *
  • Patient - Encode patient and all its children
  • *
  • Patient.name - Encode only the patient's name
  • *
  • Patient.name.family - Encode only the patient's family name
  • *
  • *.text - Encode the text element on any resource (only the very first position may contain a * wildcard)
  • *
  • *.(mandatory) - This is a special case which causes any mandatory fields (min > 0) to be encoded
  • *
* * @param encodeElements The elements to encode * @see #setDontEncodeElements(Set) */ public void setEncodeElements(Set encodeElements) { this.encodeElements = encodeElements; } public Set getDontEncodeElements() { return dontEncodeElements; } /** * If provided, specifies the elements which should NOT be encoded. Valid values for this * field would include: *
    *
  • Patient - Don't encode patient and all its children
  • *
  • Patient.name - Don't encode the patient's name
  • *
  • Patient.name.family - Don't encode the patient's family name
  • *
  • *.text - Don't encode the text element on any resource (only the very first position may contain a * wildcard)
  • *
*

* DSTU2 note: Note that values including meta, such as Patient.meta * will work for DSTU2 parsers, but values with subelements on meta such * as Patient.meta.lastUpdated will only work in * DSTU3+ mode. *

* * @param dontEncodeElements The elements to encode * @see #setEncodeElements(Set) */ public void setDontEncodeElements(Set dontEncodeElements) { this.dontEncodeElements = dontEncodeElements; } public Boolean getStripVersionsFromReferences() { return stripVersionsFromReferences; } /** * If set to true (which is the default), resource references containing a version * will have the version removed when the resource is encoded. This is generally good behaviour because * in most situations, references from one resource to another should be to the resource by ID, not * by ID and version. In some cases though, it may be desirable to preserve the version in resource * links. In that case, this value should be set to false. *

* This method provides the ability to globally disable reference encoding. If finer-grained * control is needed, use {@link #setDontStripVersionsFromReferencesAtPaths(List)} *

* * @param stripVersionsFromReferences Set this to false to prevent the parser from removing resource versions * from references (or null to apply the default setting from the {@link #setParserOptions(Object)} * @see #setDontStripVersionsFromReferencesAtPaths(List) */ public void setStripVersionsFromReferences(Boolean stripVersionsFromReferences) { this.stripVersionsFromReferences = stripVersionsFromReferences; } public Boolean getOverrideResourceIdWithBundleEntryFullUrl() { return overrideResourceIdWithBundleEntryFullUrl; } /** * If set to true (which is the default), the Bundle.entry.fullUrl will override the Bundle.entry.resource's * resource id if the fullUrl is defined. This behavior happens when parsing the source data into a Bundle object. Set this * to false if this is not the desired behavior (e.g. the client code wishes to perform additional * validation checks between the fullUrl and the resource id). * * @param overrideResourceIdWithBundleEntryFullUrl * Set this to false to prevent the parser from overriding resource ids with the * Bundle.entry.fullUrl (or null to apply the default setting from the {@link #setParserOptions(Object)}) */ public void setOverrideResourceIdWithBundleEntryFullUrl(Boolean overrideResourceIdWithBundleEntryFullUrl) { this.overrideResourceIdWithBundleEntryFullUrl = overrideResourceIdWithBundleEntryFullUrl; } public Boolean isSummaryMode() { return summaryMode; } /** * If set to true (default is false) only elements marked by the FHIR specification as * being "summary elements" will be included. */ public void setSummaryMode(Boolean summaryMode) { this.summaryMode = summaryMode; } public Boolean isSuppressNarratives() { return suppressNarratives; } /** * If set to true (default is false), narratives will not be included in the encoded * values. */ public void setSuppressNarratives(Boolean suppressNarratives) { this.suppressNarratives = suppressNarratives; } public List getDontStripVersionsFromReferencesAtPaths() { return dontStripVersionsFromReferencesAtPaths; } /** * If supplied value(s), any resource references at the specified paths will have their * resource versions encoded instead of being automatically stripped during the encoding * process. This setting has no effect on the parsing process. *

* This method provides a finer-grained level of control than {@link #setStripVersionsFromReferences(Boolean)} * and any paths specified by this method will be encoded even if {@link #setStripVersionsFromReferences(Boolean)} * has been set to true (which is the default) *

* * @param dontStripVersionsFromReferencesAtPaths * A collection of paths for which the resource versions will not be removed automatically * when serializing, e.g. "Patient.managingOrganization" or "AuditEvent.object.reference". Note that * only resource name and field names with dots separating is allowed here (no repetition * indicators, FluentPath expressions, etc.). Set to null to use the value * set in the {@link #setParserOptions(Object)} * @see #setStripVersionsFromReferences(Boolean) */ public void setDontStripVersionsFromReferencesAtPaths(List dontStripVersionsFromReferencesAtPaths) { this.dontStripVersionsFromReferencesAtPaths = dontStripVersionsFromReferencesAtPaths; } }