001package org.hl7.fhir.r4.model.codesystems;
002
003/*-
004 * #%L
005 * org.hl7.fhir.r4
006 * %%
007 * Copyright (C) 2014 - 2019 Health Level 7
008 * %%
009 * Licensed under the Apache License, Version 2.0 (the "License");
010 * you may not use this file except in compliance with the License.
011 * You may obtain a copy of the License at
012 * 
013 *      http://www.apache.org/licenses/LICENSE-2.0
014 * 
015 * Unless required by applicable law or agreed to in writing, software
016 * distributed under the License is distributed on an "AS IS" BASIS,
017 * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
018 * See the License for the specific language governing permissions and
019 * limitations under the License.
020 * #L%
021 */
022
023
024/*
025  Copyright (c) 2011+, HL7, Inc.
026  All rights reserved.
027  
028  Redistribution and use in source and binary forms, with or without modification, 
029  are permitted provided that the following conditions are met:
030  
031   * Redistributions of source code must retain the above copyright notice, this 
032     list of conditions and the following disclaimer.
033   * Redistributions in binary form must reproduce the above copyright notice, 
034     this list of conditions and the following disclaimer in the documentation 
035     and/or other materials provided with the distribution.
036   * Neither the name of HL7 nor the names of its contributors may be used to 
037     endorse or promote products derived from this software without specific 
038     prior written permission.
039  
040  THIS SOFTWARE IS PROVIDED BY THE COPYRIGHT HOLDERS AND CONTRIBUTORS "AS IS" AND 
041  ANY EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT LIMITED TO, THE IMPLIED 
042  WARRANTIES OF MERCHANTABILITY AND FITNESS FOR A PARTICULAR PURPOSE ARE DISCLAIMED. 
043  IN NO EVENT SHALL THE COPYRIGHT HOLDER OR CONTRIBUTORS BE LIABLE FOR ANY DIRECT, 
044  INDIRECT, INCIDENTAL, SPECIAL, EXEMPLARY, OR CONSEQUENTIAL DAMAGES (INCLUDING, BUT 
045  NOT LIMITED TO, PROCUREMENT OF SUBSTITUTE GOODS OR SERVICES; LOSS OF USE, DATA, OR 
046  PROFITS; OR BUSINESS INTERRUPTION) HOWEVER CAUSED AND ON ANY THEORY OF LIABILITY, 
047  WHETHER IN CONTRACT, STRICT LIABILITY, OR TORT (INCLUDING NEGLIGENCE OR OTHERWISE) 
048  ARISING IN ANY WAY OUT OF THE USE OF THIS SOFTWARE, EVEN IF ADVISED OF THE 
049  POSSIBILITY OF SUCH DAMAGE.
050  
051*/
052
053// Generated on Wed, Jan 30, 2019 16:19-0500 for FHIR v4.0.0
054
055
056import org.hl7.fhir.exceptions.FHIRException;
057
058public enum BundleType {
059
060        /**
061         * The bundle is a document. The first resource is a Composition.
062         */
063        DOCUMENT, 
064        /**
065         * The bundle is a message. The first resource is a MessageHeader.
066         */
067        MESSAGE, 
068        /**
069         * The bundle is a transaction - intended to be processed by a server as an atomic commit.
070         */
071        TRANSACTION, 
072        /**
073         * The bundle is a transaction response. Because the response is a transaction response, the transaction has succeeded, and all responses are error free.
074         */
075        TRANSACTIONRESPONSE, 
076        /**
077         * The bundle is a set of actions - intended to be processed by a server as a group of independent actions.
078         */
079        BATCH, 
080        /**
081         * The bundle is a batch response. Note that as a batch, some responses may indicate failure and others success.
082         */
083        BATCHRESPONSE, 
084        /**
085         * The bundle is a list of resources from a history interaction on a server.
086         */
087        HISTORY, 
088        /**
089         * The bundle is a list of resources returned as a result of a search/query interaction, operation, or message.
090         */
091        SEARCHSET, 
092        /**
093         * The bundle is a set of resources collected into a single package for ease of distribution that imposes no processing obligations or behavioral rules beyond persistence.
094         */
095        COLLECTION, 
096        /**
097         * added to help the parsers
098         */
099        NULL;
100        public static BundleType fromCode(String codeString) throws FHIRException {
101            if (codeString == null || "".equals(codeString))
102                return null;
103        if ("document".equals(codeString))
104          return DOCUMENT;
105        if ("message".equals(codeString))
106          return MESSAGE;
107        if ("transaction".equals(codeString))
108          return TRANSACTION;
109        if ("transaction-response".equals(codeString))
110          return TRANSACTIONRESPONSE;
111        if ("batch".equals(codeString))
112          return BATCH;
113        if ("batch-response".equals(codeString))
114          return BATCHRESPONSE;
115        if ("history".equals(codeString))
116          return HISTORY;
117        if ("searchset".equals(codeString))
118          return SEARCHSET;
119        if ("collection".equals(codeString))
120          return COLLECTION;
121        throw new FHIRException("Unknown BundleType code '"+codeString+"'");
122        }
123        public String toCode() {
124          switch (this) {
125            case DOCUMENT: return "document";
126            case MESSAGE: return "message";
127            case TRANSACTION: return "transaction";
128            case TRANSACTIONRESPONSE: return "transaction-response";
129            case BATCH: return "batch";
130            case BATCHRESPONSE: return "batch-response";
131            case HISTORY: return "history";
132            case SEARCHSET: return "searchset";
133            case COLLECTION: return "collection";
134            default: return "?";
135          }
136        }
137        public String getSystem() {
138          return "http://hl7.org/fhir/bundle-type";
139        }
140        public String getDefinition() {
141          switch (this) {
142            case DOCUMENT: return "The bundle is a document. The first resource is a Composition.";
143            case MESSAGE: return "The bundle is a message. The first resource is a MessageHeader.";
144            case TRANSACTION: return "The bundle is a transaction - intended to be processed by a server as an atomic commit.";
145            case TRANSACTIONRESPONSE: return "The bundle is a transaction response. Because the response is a transaction response, the transaction has succeeded, and all responses are error free.";
146            case BATCH: return "The bundle is a set of actions - intended to be processed by a server as a group of independent actions.";
147            case BATCHRESPONSE: return "The bundle is a batch response. Note that as a batch, some responses may indicate failure and others success.";
148            case HISTORY: return "The bundle is a list of resources from a history interaction on a server.";
149            case SEARCHSET: return "The bundle is a list of resources returned as a result of a search/query interaction, operation, or message.";
150            case COLLECTION: return "The bundle is a set of resources collected into a single package for ease of distribution that imposes no processing obligations or behavioral rules beyond persistence.";
151            default: return "?";
152          }
153        }
154        public String getDisplay() {
155          switch (this) {
156            case DOCUMENT: return "Document";
157            case MESSAGE: return "Message";
158            case TRANSACTION: return "Transaction";
159            case TRANSACTIONRESPONSE: return "Transaction Response";
160            case BATCH: return "Batch";
161            case BATCHRESPONSE: return "Batch Response";
162            case HISTORY: return "History List";
163            case SEARCHSET: return "Search Results";
164            case COLLECTION: return "Collection";
165            default: return "?";
166          }
167    }
168
169
170}
171