View Javadoc
1   /**
2    * The contents of this file are subject to the Mozilla Public License Version 1.1
3    * (the "License"); you may not use this file except in compliance with the License.
4    * You may obtain a copy of the License at http://www.mozilla.org/MPL/
5    * Software distributed under the License is distributed on an "AS IS" basis,
6    * WITHOUT WARRANTY OF ANY KIND, either express or implied. See the License for the
7    * specific language governing rights and limitations under the License.
8    *
9    * The Original Code is ""  Description:
10   * ""
11   *
12   * The Initial Developer of the Original Code is University Health Network. Copyright (C)
13   * 2001.  All Rights Reserved.
14   *
15   * Contributor(s): ______________________________________.
16   *
17   * Alternatively, the contents of this file may be used under the terms of the
18   * GNU General Public License (the  "GPL"), in which case the provisions of the GPL are
19   * applicable instead of those above.  If you wish to allow use of your version of this
20   * file only under the terms of the GPL and not to allow others to use your version
21   * of this file under the MPL, indicate your decision by deleting  the provisions above
22   * and replace  them with the notice and other provisions required by the GPL License.
23   * If you do not delete the provisions above, a recipient may use your version of
24   * this file under either the MPL or the GPL.
25   */
26  package ca.uhn.hl7v2.testpanel.model.msg;
27  
28  import java.beans.PropertyVetoException;
29  import java.util.UUID;
30  
31  import ca.uhn.hl7v2.testpanel.model.AbstractModelClass;
32  import ca.uhn.hl7v2.testpanel.xsd.MessageDefinition;
33  
34  public abstract class AbstractMessage<T> extends AbstractModelClass {
35  
36  	public static final String PARSED_MESSAGE_PROPERTY = AbstractMessage.class.getName() + "PARSED_MESSAGE_PROPERTY";
37  	public static final String SOURCE_MESSAGE_PROPERTY = AbstractMessage.class.getName() + "SOURCE_MESSAGE_PROPERTY";
38  
39  	private String myId;
40  
41  	/**
42  	 * Constructor
43  	 */
44  	public AbstractMessage() {
45  		super();
46  		myId = UUID.randomUUID().toString();
47  	}
48  
49  	public AbstractMessage(MessageDefinition theConfig) {
50  		myId = theConfig.getId();
51  	}
52  
53  	public AbstractMessage(String theId) {
54  		myId = theId;
55  	}
56  
57  	/**
58  	 * {@inheritDoc}
59  	 */
60  	@Override
61  	public final boolean equals(Object theObj) {
62  		return this == theObj;
63  	}
64  
65  	/**
66  	 * Subclasses should make use of this method to export AbstractInterface
67  	 * properties into the return value for {@link #exportConfigToXml()}
68  	 */
69  	protected MessageDefinition exportConfig(MessageDefinition theConfig) {
70  		return theConfig;
71  	}
72  
73  	/**
74  	 * Declare a concrete type for subclass implementations of this method
75  	 */
76  	@Override
77  	public abstract MessageDefinition exportConfigToXml();
78  
79  	public String getId() {
80  		return myId;
81  	}
82  
83  	// ~ Methods
84  	// --------------------------------------------------------------------------------------------------------
85  
86  	public abstract Class<? extends T> getMessageClass();
87  
88  	public abstract T getParsedMessage();
89  
90  	public abstract String getSourceMessage();
91  
92  	/**
93  	 * {@inheritDoc}
94  	 */
95  	@Override
96  	public final int hashCode() {
97  		return super.hashCode();
98  	}
99  
100 	/**
101 	 * On successful completion, should fire {@link #SOURCE_MESSAGE_PROPERTY}
102 	 */
103 	public abstract void setSourceMessage(String theSourceMessage) throws PropertyVetoException;
104 
105 }