/** * 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 Original Code is "ExampleReceiverApplication.java". Description: * "Example Code" * * The Initial Developer of the Original Code is University Health Network. Copyright (C) * 2001. All Rights Reserved. * * Contributor(s): James Agnew * * 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.examples; import java.io.IOException; import ca.uhn.hl7v2.HL7Exception; import ca.uhn.hl7v2.app.Application; import ca.uhn.hl7v2.app.ApplicationException; import ca.uhn.hl7v2.app.DefaultApplication; import ca.uhn.hl7v2.model.Message; import ca.uhn.hl7v2.model.v22.message.ACK; import ca.uhn.hl7v2.model.v22.segment.MSH; import ca.uhn.hl7v2.parser.PipeParser; /** * Application class for receiving ADT^A01 messages */ public class ExampleReceiverApplication implements Application { /** * {@inheritDoc} */ public boolean canProcess(Message theIn) { return true; } /** * {@inheritDoc} */ public Message processMessage(Message theIn) throws ApplicationException, HL7Exception { String encodedMessage = new PipeParser().encode(theIn); System.out.println("Received message:\n" + encodedMessage + "\n\n"); // Now we need to generate a message to return. This will generally be an ACK message. MSH msh = (MSH)theIn.get("MSH"); ACK retVal; try { // This method takes in the MSH segment of an incoming message, and generates an // appropriate ACK retVal = (ACK)DefaultApplication.makeACK(msh); } catch (IOException e) { throw new HL7Exception(e); } return retVal; } }