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 Wed, Jan 30, 2019 16:19-0500 for FHIR v4.0.0
033
034import org.hl7.fhir.exceptions.FHIRException;
035
036public enum RepositoryType {
037
038  /**
039   * When URL is clicked, the resource can be seen directly (by webpage or by
040   * download link format).
041   */
042  DIRECTLINK,
043  /**
044   * When the API method (e.g. [base_url]/[parameter]) related with the URL of the
045   * website is executed, the resource can be seen directly (usually in JSON or
046   * XML format).
047   */
048  OPENAPI,
049  /**
050   * When logged into the website, the resource can be seen.
051   */
052  LOGIN,
053  /**
054   * When logged in and follow the API in the website related with URL, the
055   * resource can be seen.
056   */
057  OAUTH,
058  /**
059   * Some other complicated or particular way to get resource from URL.
060   */
061  OTHER,
062  /**
063   * added to help the parsers
064   */
065  NULL;
066
067  public static RepositoryType fromCode(String codeString) throws FHIRException {
068    if (codeString == null || "".equals(codeString))
069      return null;
070    if ("directlink".equals(codeString))
071      return DIRECTLINK;
072    if ("openapi".equals(codeString))
073      return OPENAPI;
074    if ("login".equals(codeString))
075      return LOGIN;
076    if ("oauth".equals(codeString))
077      return OAUTH;
078    if ("other".equals(codeString))
079      return OTHER;
080    throw new FHIRException("Unknown RepositoryType code '" + codeString + "'");
081  }
082
083  public String toCode() {
084    switch (this) {
085    case DIRECTLINK:
086      return "directlink";
087    case OPENAPI:
088      return "openapi";
089    case LOGIN:
090      return "login";
091    case OAUTH:
092      return "oauth";
093    case OTHER:
094      return "other";
095    case NULL:
096      return null;
097    default:
098      return "?";
099    }
100  }
101
102  public String getSystem() {
103    return "http://hl7.org/fhir/repository-type";
104  }
105
106  public String getDefinition() {
107    switch (this) {
108    case DIRECTLINK:
109      return "When URL is clicked, the resource can be seen directly (by webpage or by download link format).";
110    case OPENAPI:
111      return "When the API method (e.g. [base_url]/[parameter]) related with the URL of the website is executed, the resource can be seen directly (usually in JSON or XML format).";
112    case LOGIN:
113      return "When logged into the website, the resource can be seen.";
114    case OAUTH:
115      return "When logged in and  follow the API in the website related with URL, the resource can be seen.";
116    case OTHER:
117      return "Some other complicated or particular way to get resource from URL.";
118    case NULL:
119      return null;
120    default:
121      return "?";
122    }
123  }
124
125  public String getDisplay() {
126    switch (this) {
127    case DIRECTLINK:
128      return "Click and see";
129    case OPENAPI:
130      return "The URL is the RESTful or other kind of API that can access to the result.";
131    case LOGIN:
132      return "Result cannot be access unless an account is logged in";
133    case OAUTH:
134      return "Result need to be fetched with API and need LOGIN( or cookies are required when visiting the link of resource)";
135    case OTHER:
136      return "Some other complicated or particular way to get resource from URL.";
137    case NULL:
138      return null;
139    default:
140      return "?";
141    }
142  }
143
144}