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.context.support; 021 022import org.apache.commons.lang3.Validate; 023 024import java.util.Objects; 025 026/** 027 * Options for ValueSet expansion 028 * 029 * @see IValidationSupport 030 */ 031public class ValueSetExpansionOptions { 032 033 private boolean myFailOnMissingCodeSystem = true; 034 private int myCount = 1000; 035 private int myOffset = 0; 036 private boolean myIncludeHierarchy; 037 private String myFilter; 038 039 private String myDisplayLanguage; 040 041 public String getFilter() { 042 return myFilter; 043 } 044 045 public ValueSetExpansionOptions setFilter(String theFilter) { 046 myFilter = theFilter; 047 return this; 048 } 049 050 /** 051 * The number of codes to return. 052 * <p> 053 * Default is 1000 054 * </p> 055 */ 056 public int getCount() { 057 return myCount; 058 } 059 060 /** 061 * The number of codes to return. 062 * <p> 063 * Default is 1000 064 * </p> 065 */ 066 public ValueSetExpansionOptions setCount(int theCount) { 067 Validate.isTrue(theCount >= 0, "theCount must be >= 0"); 068 myCount = theCount; 069 return this; 070 } 071 072 /** 073 * The code index to start at (i.e the individual code index, not the page number) 074 */ 075 public int getOffset() { 076 return myOffset; 077 } 078 079 /** 080 * The code index to start at (i.e the individual code index, not the page number) 081 */ 082 public ValueSetExpansionOptions setOffset(int theOffset) { 083 Validate.isTrue(theOffset >= 0, "theOffset must be >= 0"); 084 myOffset = theOffset; 085 return this; 086 } 087 088 /** 089 * Should the expansion fail if a codesystem is referenced by the valueset, but 090 * it can not be found? 091 * <p> 092 * Default is <code>true</code> 093 * </p> 094 */ 095 public boolean isFailOnMissingCodeSystem() { 096 return myFailOnMissingCodeSystem; 097 } 098 099 /** 100 * Should the expansion fail if a codesystem is referenced by the valueset, but 101 * it can not be found? 102 * <p> 103 * Default is <code>true</code> 104 * </p> 105 */ 106 public ValueSetExpansionOptions setFailOnMissingCodeSystem(boolean theFailOnMissingCodeSystem) { 107 myFailOnMissingCodeSystem = theFailOnMissingCodeSystem; 108 return this; 109 } 110 111 public boolean isIncludeHierarchy() { 112 return myIncludeHierarchy; 113 } 114 115 public void setIncludeHierarchy(boolean theIncludeHierarchy) { 116 myIncludeHierarchy = theIncludeHierarchy; 117 } 118 119 public static ValueSetExpansionOptions forOffsetAndCount(int theOffset, int theCount) { 120 return new ValueSetExpansionOptions().setOffset(theOffset).setCount(theCount); 121 } 122 123 public String getTheDisplayLanguage() { 124 return myDisplayLanguage; 125 } 126 127 public ValueSetExpansionOptions setTheDisplayLanguage(String theDisplayLanguage) { 128 myDisplayLanguage = theDisplayLanguage; 129 return this; 130 } 131 132 @Override 133 public boolean equals(Object theO) { 134 if (this == theO) return true; 135 if (!(theO instanceof ValueSetExpansionOptions)) return false; 136 ValueSetExpansionOptions that = (ValueSetExpansionOptions) theO; 137 return myFailOnMissingCodeSystem == that.myFailOnMissingCodeSystem 138 && myCount == that.myCount 139 && myOffset == that.myOffset 140 && myIncludeHierarchy == that.myIncludeHierarchy 141 && Objects.equals(myFilter, that.myFilter) 142 && Objects.equals(myDisplayLanguage, that.myDisplayLanguage); 143 } 144 145 @Override 146 public int hashCode() { 147 return Objects.hash( 148 myFailOnMissingCodeSystem, myCount, myOffset, myIncludeHierarchy, myFilter, myDisplayLanguage); 149 } 150}