ca.uhn.hl7v2.parser.AbstractModelClassFactory Maven / Gradle / Ivy
/**
The contents of this file are subject to the Mozilla Public License Version 1.1
(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.mozilla.org/MPL/
Software distributed under the License is distributed on an "AS IS" basis,
WITHOUT WARRANTY OF ANY KIND, either express or implied. See the License for the
specific language governing rights and limitations under the License.
The Initial Developer of the Original Code is University Health Network. Copyright (C)
2001. All Rights Reserved.
Contributor(s): ______________________________________.
Alternatively, the contents of this file may be used under the terms of the
GNU General Public License (the "GPL"), in which case the provisions of the GPL are
applicable instead of those above. If you wish to allow use of your version of this
file only under the terms of the GPL and not to allow others to use your version
of this file under the MPL, indicate your decision by deleting the provisions above
and replace them with the notice and other provisions required by the GPL License.
If you do not delete the provisions above, a recipient may use your version of
this file under either the MPL or the GPL.
*/
package ca.uhn.hl7v2.parser;
import java.io.IOException;
import java.io.InputStream;
import java.util.Collections;
import java.util.HashMap;
import java.util.Map;
import java.util.Properties;
import ca.uhn.hl7v2.HL7Exception;
import ca.uhn.hl7v2.Version;
import org.slf4j.Logger;
import org.slf4j.LoggerFactory;
/**
* Abstract base class for {@link ModelClassFactory} implementations that read event maps from the
* file system.
*
* The directory can be set using {@link #setEventMapDirectory(String)} and defaults to
* ca/uhn/hl7v2/parser/eventmap/
. The file itself is a property file named after the
* HL7 version (e.g. 2.4.properties
).
*
*
*
* @author Christian Ohr
*/
@SuppressWarnings("serial")
public abstract class AbstractModelClassFactory implements ModelClassFactory {
protected static final String DEFAULT_EVENT_MAP_DIRECTORY = "ca/uhn/hl7v2/parser/eventmap/";
private static final Logger LOG = LoggerFactory.getLogger(AbstractModelClassFactory.class);
private String eventMapDirectory = DEFAULT_EVENT_MAP_DIRECTORY;
private Map> eventMap;
/**
* @return the directory where to read the eventmap file from
*/
public String getEventMapDirectory() {
return eventMapDirectory;
}
/**
* @param eventMapPrefix the directory where to read the eventmap file from
*/
public void setEventMapDirectory(String eventMapPrefix) {
this.eventMapDirectory = eventMapPrefix;
}
/**
* @see ca.uhn.hl7v2.parser.ModelClassFactory#getMessageStructureForEvent(java.lang.String,
* ca.uhn.hl7v2.Version)
*/
public String getMessageStructureForEvent(String name, Version version) throws HL7Exception {
Map p = getEventMapForVersion(version);
if (p == null) {
// Instead of throwing an Exception, Allow to parse as generic message if the structure library
// (and the contained event map) are not on the classpath.
LOG.debug("No event map found for version " + version);
return name;
// before:
// throw new HL7Exception("No map found for version " + version
// + ". Only the following are available: " + getEventMap().keySet());
} else {
return p.get(name);
}
}
/**
* Returns the event map for a given HL7 version. In this map, the key is a message
* type and trigger event in the form [type]_[trigger]
, for example:
* ADT_A04
, and the values are the corresponding structure for this trigger,
* for example: ADT_A01
.
*
* @param version the HL7 version
* @return Returns null
if no event map is found for the given version
* @throws HL7Exception if the HL7 version is unknown
*/
public Map getEventMapForVersion(Version version) throws HL7Exception {
return getEventMap().get(version);
}
/**
* Initializes the event map once and returns it.
*
* This method is package private for testing reasons.
*
* @return the event map
* @throws HL7Exception
*/
synchronized Map> getEventMap() throws HL7Exception {
if (eventMap == null) {
try {
eventMap = loadMessageStructures();
} catch (IOException e) {
throw new HL7Exception("Could not load event map", e);
}
}
return eventMap;
}
/**
* Load event map from a external resource
*
* @return the event map
* @throws IOException
*/
protected Map> loadMessageStructures() throws IOException {
Map> map = new HashMap>();
for (Version v : Version.values()) {
String resource = getEventMapDirectory() + v.getVersion() + ".properties";
InputStream in = getResource(resource);
if (in != null) {
try {
Properties structures = new Properties();
structures.load(in);
Map structureMap = new HashMap();
for(Map.Entry