001package ca.cdr.api.pub.hl7v2;
002
003/*-
004 * #%L
005 * Smile CDR - CDR
006 * %%
007 * Copyright (C) 2016 - 2025 Smile CDR, Inc.
008 * %%
009 * All rights reserved.
010 * #L%
011 */
012
013import ca.cdr.api.pub.hl7v2.model.MappingContext;
014import ca.cdr.api.pub.hl7v2.model.MappingResult;
015import ca.uhn.hl7v2.HL7Exception;
016import ca.uhn.hl7v2.model.Message;
017
018/**
019 * An HL7 v2 Message mapper is used to translate messages from one
020 * format to another when sending or receiving them. This can be used
021 * to provide mappings from a source system format to a format that
022 * Smile CDR understands.
023 */
024public interface IHl7V2MessageMapper {
025
026        /**
027         * Returns the input message type for this translator
028         */
029        Class<? extends Message> getInputType();
030
031        /**
032         * Returns the output message type for this translator
033         */
034        Class<? extends Message> getOutputType();
035
036        /**
037         * This method should return <code>true</code> if the
038         * mapper should process this message
039         */
040        boolean applies(String theMessageType, String theMessageTrigger);
041
042        /**
043         * Translate a message
044         *
045         * @param theInput
046         *            The source message
047         * @param theContext
048         *            An object containing context information
049         * @return A result containing the output of the mapping
050         */
051        MappingResult map(Message theInput, MappingContext theContext) throws HL7Exception;
052}