001package org.hl7.fhir.r4.model.codesystems;
002
003/*
004  Copyright (c) 2011+, HL7, Inc.
005  All rights reserved.
006  
007  Redistribution and use in source and binary forms, with or without modification, 
008  are permitted provided that the following conditions are met:
009  
010   * Redistributions of source code must retain the above copyright notice, this 
011     list of conditions and the following disclaimer.
012   * Redistributions in binary form must reproduce the above copyright notice, 
013     this list of conditions and the following disclaimer in the documentation 
014     and/or other materials provided with the distribution.
015   * Neither the name of HL7 nor the names of its contributors may be used to 
016     endorse or promote products derived from this software without specific 
017     prior written permission.
018  
019  THIS SOFTWARE IS PROVIDED BY THE COPYRIGHT HOLDERS AND CONTRIBUTORS "AS IS" AND 
020  ANY EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT LIMITED TO, THE IMPLIED 
021  WARRANTIES OF MERCHANTABILITY AND FITNESS FOR A PARTICULAR PURPOSE ARE DISCLAIMED. 
022  IN NO EVENT SHALL THE COPYRIGHT HOLDER OR CONTRIBUTORS BE LIABLE FOR ANY DIRECT, 
023  INDIRECT, INCIDENTAL, SPECIAL, EXEMPLARY, OR CONSEQUENTIAL DAMAGES (INCLUDING, BUT 
024  NOT LIMITED TO, PROCUREMENT OF SUBSTITUTE GOODS OR SERVICES; LOSS OF USE, DATA, OR 
025  PROFITS; OR BUSINESS INTERRUPTION) HOWEVER CAUSED AND ON ANY THEORY OF LIABILITY, 
026  WHETHER IN CONTRACT, STRICT LIABILITY, OR TORT (INCLUDING NEGLIGENCE OR OTHERWISE) 
027  ARISING IN ANY WAY OUT OF THE USE OF THIS SOFTWARE, EVEN IF ADVISED OF THE 
028  POSSIBILITY OF SUCH DAMAGE.
029  
030*/
031
032// Generated on Sun, May 6, 2018 17:51-0400 for FHIR v3.4.0
033
034
035import org.hl7.fhir.exceptions.FHIRException;
036
037public enum SubscriptionChannelType {
038
039        /**
040         * The channel is executed by making a post to the URI. If a payload is included, the URL is interpreted as the service base, and an update (PUT) is made.
041         */
042        RESTHOOK, 
043        /**
044         * The channel is executed by sending a packet across a web socket connection maintained by the client. The URL identifies the websocket, and the client binds to this URL.
045         */
046        WEBSOCKET, 
047        /**
048         * The channel is executed by sending an email to the email addressed in the URI (which must be a mailto:).
049         */
050        EMAIL, 
051        /**
052         * The channel is executed by sending an SMS message to the phone number identified in the URL (tel:).
053         */
054        SMS, 
055        /**
056         * The channel is executed by sending a message (e.g. a Bundle with a MessageHeader resource etc.) to the application identified in the URI.
057         */
058        MESSAGE, 
059        /**
060         * added to help the parsers
061         */
062        NULL;
063        public static SubscriptionChannelType fromCode(String codeString) throws FHIRException {
064            if (codeString == null || "".equals(codeString))
065                return null;
066        if ("rest-hook".equals(codeString))
067          return RESTHOOK;
068        if ("websocket".equals(codeString))
069          return WEBSOCKET;
070        if ("email".equals(codeString))
071          return EMAIL;
072        if ("sms".equals(codeString))
073          return SMS;
074        if ("message".equals(codeString))
075          return MESSAGE;
076        throw new FHIRException("Unknown SubscriptionChannelType code '"+codeString+"'");
077        }
078        public String toCode() {
079          switch (this) {
080            case RESTHOOK: return "rest-hook";
081            case WEBSOCKET: return "websocket";
082            case EMAIL: return "email";
083            case SMS: return "sms";
084            case MESSAGE: return "message";
085            default: return "?";
086          }
087        }
088        public String getSystem() {
089          return "http://hl7.org/fhir/subscription-channel-type";
090        }
091        public String getDefinition() {
092          switch (this) {
093            case RESTHOOK: return "The channel is executed by making a post to the URI. If a payload is included, the URL is interpreted as the service base, and an update (PUT) is made.";
094            case WEBSOCKET: return "The channel is executed by sending a packet across a web socket connection maintained by the client. The URL identifies the websocket, and the client binds to this URL.";
095            case EMAIL: return "The channel is executed by sending an email to the email addressed in the URI (which must be a mailto:).";
096            case SMS: return "The channel is executed by sending an SMS message to the phone number identified in the URL (tel:).";
097            case MESSAGE: return "The channel is executed by sending a message (e.g. a Bundle with a MessageHeader resource etc.) to the application identified in the URI.";
098            default: return "?";
099          }
100        }
101        public String getDisplay() {
102          switch (this) {
103            case RESTHOOK: return "Rest Hook";
104            case WEBSOCKET: return "Websocket";
105            case EMAIL: return "Email";
106            case SMS: return "SMS";
107            case MESSAGE: return "Message";
108            default: return "?";
109          }
110    }
111
112
113}
114