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 ProvenanceAgentType {
059
060        /**
061         * A person entering the data into the originating system
062         */
063        ENTERER, 
064        /**
065         * A person, animal, organization or device that who actually and principally carries out the activity
066         */
067        PERFORMER, 
068        /**
069         * A party that originates the resource and therefore has responsibility for the information given in the resource and ownership of this resource
070         */
071        AUTHOR, 
072        /**
073         * A person who verifies the correctness and appropriateness of activity
074         */
075        VERIFIER, 
076        /**
077         * The person authenticated the content and accepted legal responsibility for its content
078         */
079        LEGAL, 
080        /**
081         * A verifier who attests to the accuracy of the resource
082         */
083        ATTESTER, 
084        /**
085         * A person who reported information that contributed to the resource
086         */
087        INFORMANT, 
088        /**
089         * The entity that is accountable for maintaining a true an accurate copy of the original record
090         */
091        CUSTODIAN, 
092        /**
093         * A device that operates independently of an author on custodian's algorithms for data extraction of existing information for purpose of generating a new artifact.
094         */
095        ASSEMBLER, 
096        /**
097         * A device used by an author to record new information, which may also be used by the author to select existing information for aggregation with newly recorded information for the purpose of generating a new artifact.
098         */
099        COMPOSER, 
100        /**
101         * added to help the parsers
102         */
103        NULL;
104        public static ProvenanceAgentType fromCode(String codeString) throws FHIRException {
105            if (codeString == null || "".equals(codeString))
106                return null;
107        if ("enterer".equals(codeString))
108          return ENTERER;
109        if ("performer".equals(codeString))
110          return PERFORMER;
111        if ("author".equals(codeString))
112          return AUTHOR;
113        if ("verifier".equals(codeString))
114          return VERIFIER;
115        if ("legal".equals(codeString))
116          return LEGAL;
117        if ("attester".equals(codeString))
118          return ATTESTER;
119        if ("informant".equals(codeString))
120          return INFORMANT;
121        if ("custodian".equals(codeString))
122          return CUSTODIAN;
123        if ("assembler".equals(codeString))
124          return ASSEMBLER;
125        if ("composer".equals(codeString))
126          return COMPOSER;
127        throw new FHIRException("Unknown ProvenanceAgentType code '"+codeString+"'");
128        }
129        public String toCode() {
130          switch (this) {
131            case ENTERER: return "enterer";
132            case PERFORMER: return "performer";
133            case AUTHOR: return "author";
134            case VERIFIER: return "verifier";
135            case LEGAL: return "legal";
136            case ATTESTER: return "attester";
137            case INFORMANT: return "informant";
138            case CUSTODIAN: return "custodian";
139            case ASSEMBLER: return "assembler";
140            case COMPOSER: return "composer";
141            default: return "?";
142          }
143        }
144        public String getSystem() {
145          return "http://terminology.hl7.org/CodeSystem/provenance-participant-type";
146        }
147        public String getDefinition() {
148          switch (this) {
149            case ENTERER: return "A person entering the data into the originating system";
150            case PERFORMER: return "A person, animal, organization or device that who actually and principally carries out the activity";
151            case AUTHOR: return "A party that originates the resource and therefore has responsibility for the information given in the resource and ownership of this resource";
152            case VERIFIER: return "A person who verifies the correctness and appropriateness of activity";
153            case LEGAL: return "The person authenticated the content and accepted legal responsibility for its content";
154            case ATTESTER: return "A verifier who attests to the accuracy of the resource";
155            case INFORMANT: return "A person who reported information that contributed to the resource";
156            case CUSTODIAN: return "The entity that is accountable for maintaining a true an accurate copy of the original record";
157            case ASSEMBLER: return "A device that operates independently of an author on custodian's algorithms for data extraction of existing information for purpose of generating a new artifact.";
158            case COMPOSER: return "A device used by an author to record new information, which may also be used by the author to select existing information for aggregation with newly recorded information for the purpose of generating a new artifact.";
159            default: return "?";
160          }
161        }
162        public String getDisplay() {
163          switch (this) {
164            case ENTERER: return "Enterer";
165            case PERFORMER: return "Performer";
166            case AUTHOR: return "Author";
167            case VERIFIER: return "Verifier";
168            case LEGAL: return "Legal Authenticator";
169            case ATTESTER: return "Attester";
170            case INFORMANT: return "Informant";
171            case CUSTODIAN: return "Custodian";
172            case ASSEMBLER: return "Assembler";
173            case COMPOSER: return "Composer";
174            default: return "?";
175          }
176    }
177
178
179}
180