001/* 002 * #%L 003 * HAPI FHIR - Core Library 004 * %% 005 * Copyright (C) 2014 - 2025 Smile CDR, Inc. 006 * %% 007 * Licensed under the Apache License, Version 2.0 (the "License"); 008 * you may not use this file except in compliance with the License. 009 * You may obtain a copy of the License at 010 * 011 * http://www.apache.org/licenses/LICENSE-2.0 012 * 013 * Unless required by applicable law or agreed to in writing, software 014 * distributed under the License is distributed on an "AS IS" BASIS, 015 * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied. 016 * See the License for the specific language governing permissions and 017 * limitations under the License. 018 * #L% 019 */ 020package ca.uhn.fhir.rest.api; 021 022import org.apache.commons.lang3.Validate; 023 024import java.util.HashMap; 025 026/** 027 * Validation mode parameter for the $validate operation (DSTU2+ only) 028 */ 029public enum ValidationModeEnum { 030 /** 031 * The server checks the content, and then checks that the content would be acceptable as a create (e.g. that the content would not validate any uniqueness constraints) 032 */ 033 CREATE("create"), 034 035 /** 036 * The server checks the content, and then checks that it would accept it as an update against the nominated specific resource (e.g. that there are no changes to immutable fields the server does not allow to change, and checking version integrity if appropriate) 037 */ 038 UPDATE("update"), 039 040 /** 041 * The server ignores the content, and checks that the nominated resource is allowed to be deleted (e.g. checking referential integrity rules) 042 */ 043 DELETE("delete"); 044 045 private static HashMap<String, ValidationModeEnum> myCodeToValue; 046 private String myCode; 047 048 static { 049 myCodeToValue = new HashMap<String, ValidationModeEnum>(); 050 for (ValidationModeEnum next : values()) { 051 myCodeToValue.put(next.getCode(), next); 052 } 053 } 054 055 public static ValidationModeEnum forCode(String theCode) { 056 Validate.notBlank(theCode, "theCode must not be blank"); 057 return myCodeToValue.get(theCode); 058 } 059 060 public String getCode() { 061 return myCode; 062 } 063 064 private ValidationModeEnum(String theCode) { 065 myCode = theCode; 066 } 067 068 // @Override 069 // public boolean isEmpty() { 070 // return false; 071 // } 072}