1 2 package ca.uhn.fhir.jpa.rp.dstu3; 3 4 import java.util.*; 5 6 import org.apache.commons.lang3.StringUtils; 7 8 import ca.uhn.fhir.jpa.provider.dstu3.*; 9 import ca.uhn.fhir.jpa.searchparam.SearchParameterMap; 10 import ca.uhn.fhir.model.api.Include; 11 import ca.uhn.fhir.model.api.annotation.*; 12 import org.hl7.fhir.dstu3.model.*; 13 import ca.uhn.fhir.rest.annotation.*; 14 import ca.uhn.fhir.rest.param.*; 15 import ca.uhn.fhir.rest.api.SortSpec; 16 import ca.uhn.fhir.rest.api.SummaryEnum; 17 import ca.uhn.fhir.rest.api.SearchTotalModeEnum; 18 19 public class PatientResourceProvider extends 20 BaseJpaResourceProviderPatientDstu3 21 { 22 23 @Override 24 public Class<Patient> getResourceType() { 25 return Patient.class; 26 } 27 28 @Search(allowUnknownParams=true) 29 public ca.uhn.fhir.rest.api.server.IBundleProvider search( 30 javax.servlet.http.HttpServletRequest theServletRequest, 31 javax.servlet.http.HttpServletResponse theServletResponse, 32 33 ca.uhn.fhir.rest.api.server.RequestDetails theRequestDetails, 34 35 @Description(shortDefinition="Search the contents of the resource's data using a fulltext search") 36 @OptionalParam(name=ca.uhn.fhir.rest.api.Constants.PARAM_CONTENT) 37 StringAndListParam theFtContent, 38 39 @Description(shortDefinition="Search the contents of the resource's narrative using a fulltext search") 40 @OptionalParam(name=ca.uhn.fhir.rest.api.Constants.PARAM_TEXT) 41 StringAndListParam theFtText, 42 43 @Description(shortDefinition="Search for resources which have the given tag") 44 @OptionalParam(name=ca.uhn.fhir.rest.api.Constants.PARAM_TAG) 45 TokenAndListParam theSearchForTag, 46 47 @Description(shortDefinition="Search for resources which have the given security labels") 48 @OptionalParam(name=ca.uhn.fhir.rest.api.Constants.PARAM_SECURITY) 49 TokenAndListParam theSearchForSecurity, 50 51 @Description(shortDefinition="Search for resources which have the given profile") 52 @OptionalParam(name=ca.uhn.fhir.rest.api.Constants.PARAM_PROFILE) 53 UriAndListParam theSearchForProfile, 54 55 @Description(shortDefinition="Return resources linked to by the given target") 56 @OptionalParam(name="_has") 57 HasAndListParam theHas, 58 59 60 @Description(shortDefinition="The ID of the resource") 61 @OptionalParam(name="_id") 62 TokenAndListParam the_id, 63 64 @Description(shortDefinition="The language of the resource") 65 @OptionalParam(name="_language") 66 StringAndListParam the_language, 67 68 @Description(shortDefinition="Whether the patient record is active") 69 @OptionalParam(name="active") 70 TokenAndListParam theActive, 71 72 @Description(shortDefinition="A server defined search that may match any of the string fields in the Address, including line, city, state, country, postalCode, and/or text") 73 @OptionalParam(name="address") 74 StringAndListParam theAddress, 75 76 @Description(shortDefinition="A city specified in an address") 77 @OptionalParam(name="address-city") 78 StringAndListParam theAddress_city, 79 80 @Description(shortDefinition="A country specified in an address") 81 @OptionalParam(name="address-country") 82 StringAndListParam theAddress_country, 83 84 @Description(shortDefinition="A postalCode specified in an address") 85 @OptionalParam(name="address-postalcode") 86 StringAndListParam theAddress_postalcode, 87 88 @Description(shortDefinition="A state specified in an address") 89 @OptionalParam(name="address-state") 90 StringAndListParam theAddress_state, 91 92 @Description(shortDefinition="A use code specified in an address") 93 @OptionalParam(name="address-use") 94 TokenAndListParam theAddress_use, 95 96 @Description(shortDefinition="The breed for animal patients") 97 @OptionalParam(name="animal-breed") 98 TokenAndListParam theAnimal_breed, 99 100 @Description(shortDefinition="The species for animal patients") 101 @OptionalParam(name="animal-species") 102 TokenAndListParam theAnimal_species, 103 104 @Description(shortDefinition="The patient's date of birth") 105 @OptionalParam(name="birthdate") 106 DateRangeParam theBirthdate, 107 108 @Description(shortDefinition="The date of death has been provided and satisfies this search value") 109 @OptionalParam(name="death-date") 110 DateRangeParam theDeath_date, 111 112 @Description(shortDefinition="This patient has been marked as deceased, or as a death date entered") 113 @OptionalParam(name="deceased") 114 TokenAndListParam theDeceased, 115 116 @Description(shortDefinition="A value in an email contact") 117 @OptionalParam(name="email") 118 TokenAndListParam theEmail, 119 120 @Description(shortDefinition="A portion of the family name of the patient") 121 @OptionalParam(name="family") 122 StringAndListParam theFamily, 123 124 @Description(shortDefinition="Gender of the patient") 125 @OptionalParam(name="gender") 126 TokenAndListParam theGender, 127 128 @Description(shortDefinition="Patient's nominated general practitioner, not the organization that manages the record") 129 @OptionalParam(name="general-practitioner", targetTypes={ } ) 130 ReferenceAndListParam theGeneral_practitioner, 131 132 @Description(shortDefinition="A portion of the given name of the patient") 133 @OptionalParam(name="given") 134 StringAndListParam theGiven, 135 136 @Description(shortDefinition="A patient identifier") 137 @OptionalParam(name="identifier") 138 TokenAndListParam theIdentifier, 139 140 @Description(shortDefinition="Language code (irrespective of use value)") 141 @OptionalParam(name="language") 142 TokenAndListParam theLanguage, 143 144 @Description(shortDefinition="All patients linked to the given patient") 145 @OptionalParam(name="link", targetTypes={ } ) 146 ReferenceAndListParam theLink, 147 148 @Description(shortDefinition="A server defined search that may match any of the string fields in the HumanName, including family, give, prefix, suffix, suffix, and/or text") 149 @OptionalParam(name="name") 150 StringAndListParam theName, 151 152 @Description(shortDefinition="The organization at which this person is a patient") 153 @OptionalParam(name="organization", targetTypes={ } ) 154 ReferenceAndListParam theOrganization, 155 156 @Description(shortDefinition="A value in a phone contact") 157 @OptionalParam(name="phone") 158 TokenAndListParam thePhone, 159 160 @Description(shortDefinition="A portion of either family or given name using some kind of phonetic matching algorithm") 161 @OptionalParam(name="phonetic") 162 StringAndListParam thePhonetic, 163 164 @Description(shortDefinition="The value in any kind of telecom details of the patient") 165 @OptionalParam(name="telecom") 166 TokenAndListParam theTelecom, 167 168 @RawParam 169 Map<String, List<String>> theAdditionalRawParams, 170 171 @IncludeParam(reverse=true) 172 Set<Include> theRevIncludes, 173 @Description(shortDefinition="Only return resources which were last updated as specified by the given range") 174 @OptionalParam(name="_lastUpdated") 175 DateRangeParam theLastUpdated, 176 177 @IncludeParam(allow= { 178 "Patient:general-practitioner" , "Patient:link" , "Patient:organization" , "Patient:general-practitioner" , "Patient:link" , "Patient:organization" , "Patient:general-practitioner" , "Patient:link" , "Patient:organization" , "*" 179 }) 180 Set<Include> theIncludes, 181 182 @Sort 183 SortSpec theSort, 184 185 @ca.uhn.fhir.rest.annotation.Count 186 Integer theCount, 187 188 SummaryEnum theSummaryMode, 189 190 SearchTotalModeEnum theSearchTotalMode 191 192 ) { 193 startRequest(theServletRequest); 194 try { 195 SearchParameterMap paramMap = new SearchParameterMap(); 196 paramMap.add(ca.uhn.fhir.rest.api.Constants.PARAM_CONTENT, theFtContent); 197 paramMap.add(ca.uhn.fhir.rest.api.Constants.PARAM_TEXT, theFtText); 198 paramMap.add(ca.uhn.fhir.rest.api.Constants.PARAM_TAG, theSearchForTag); 199 paramMap.add(ca.uhn.fhir.rest.api.Constants.PARAM_SECURITY, theSearchForSecurity); 200 paramMap.add(ca.uhn.fhir.rest.api.Constants.PARAM_PROFILE, theSearchForProfile); 201 paramMap.add("_has", theHas); 202 paramMap.add("_id", the_id); 203 paramMap.add("_language", the_language); 204 paramMap.add("active", theActive); 205 paramMap.add("address", theAddress); 206 paramMap.add("address-city", theAddress_city); 207 paramMap.add("address-country", theAddress_country); 208 paramMap.add("address-postalcode", theAddress_postalcode); 209 paramMap.add("address-state", theAddress_state); 210 paramMap.add("address-use", theAddress_use); 211 paramMap.add("animal-breed", theAnimal_breed); 212 paramMap.add("animal-species", theAnimal_species); 213 paramMap.add("birthdate", theBirthdate); 214 paramMap.add("death-date", theDeath_date); 215 paramMap.add("deceased", theDeceased); 216 paramMap.add("email", theEmail); 217 paramMap.add("family", theFamily); 218 paramMap.add("gender", theGender); 219 paramMap.add("general-practitioner", theGeneral_practitioner); 220 paramMap.add("given", theGiven); 221 paramMap.add("identifier", theIdentifier); 222 paramMap.add("language", theLanguage); 223 paramMap.add("link", theLink); 224 paramMap.add("name", theName); 225 paramMap.add("organization", theOrganization); 226 paramMap.add("phone", thePhone); 227 paramMap.add("phonetic", thePhonetic); 228 paramMap.add("telecom", theTelecom); 229 paramMap.setRevIncludes(theRevIncludes); 230 paramMap.setLastUpdated(theLastUpdated); 231 paramMap.setIncludes(theIncludes); 232 paramMap.setSort(theSort); 233 paramMap.setCount(theCount); 234 paramMap.setSummaryMode(theSummaryMode); 235 paramMap.setSearchTotalMode(theSearchTotalMode); 236 237 getDao().translateRawParameters(theAdditionalRawParams, paramMap); 238 239 ca.uhn.fhir.rest.api.server.IBundleProvider retVal = getDao().search(paramMap, theRequestDetails, theServletResponse); 240 return retVal; 241 } finally { 242 endRequest(theServletRequest); 243 } 244 } 245 246 }