001 002package ca.uhn.fhir.jpa.rp.r5; 003 004import java.util.*; 005 006import org.apache.commons.lang3.StringUtils; 007 008import ca.uhn.fhir.jpa.searchparam.SearchParameterMap; 009import ca.uhn.fhir.model.api.Include; 010import ca.uhn.fhir.model.api.annotation.*; 011import org.hl7.fhir.r5.model.*; 012import ca.uhn.fhir.rest.annotation.*; 013import ca.uhn.fhir.rest.param.*; 014import ca.uhn.fhir.rest.api.SortSpec; 015import ca.uhn.fhir.rest.api.SummaryEnum; 016import ca.uhn.fhir.rest.api.SearchTotalModeEnum; 017import ca.uhn.fhir.rest.api.SearchContainedModeEnum; 018 019public class LocationResourceProvider extends 020 ca.uhn.fhir.jpa.provider.BaseJpaResourceProvider<Location> 021 { 022 023 @Override 024 public Class<Location> getResourceType() { 025 return Location.class; 026 } 027 028 @Search(allowUnknownParams=true) 029 public ca.uhn.fhir.rest.api.server.IBundleProvider search( 030 javax.servlet.http.HttpServletRequest theServletRequest, 031 javax.servlet.http.HttpServletResponse theServletResponse, 032 033 ca.uhn.fhir.rest.api.server.RequestDetails theRequestDetails, 034 035 @Description(shortDefinition="Search the contents of the resource's data using a filter") 036 @OptionalParam(name=ca.uhn.fhir.rest.api.Constants.PARAM_FILTER) 037 StringAndListParam theFtFilter, 038 039 @Description(shortDefinition="Search the contents of the resource's data using a fulltext search") 040 @OptionalParam(name=ca.uhn.fhir.rest.api.Constants.PARAM_CONTENT) 041 StringAndListParam theFtContent, 042 043 @Description(shortDefinition="Search the contents of the resource's narrative using a fulltext search") 044 @OptionalParam(name=ca.uhn.fhir.rest.api.Constants.PARAM_TEXT) 045 StringAndListParam theFtText, 046 047 @Description(shortDefinition="Search for resources which have the given tag") 048 @OptionalParam(name=ca.uhn.fhir.rest.api.Constants.PARAM_TAG) 049 TokenAndListParam theSearchForTag, 050 051 @Description(shortDefinition="Search for resources which have the given security labels") 052 @OptionalParam(name=ca.uhn.fhir.rest.api.Constants.PARAM_SECURITY) 053 TokenAndListParam theSearchForSecurity, 054 055 @Description(shortDefinition="Search for resources which have the given profile") 056 @OptionalParam(name=ca.uhn.fhir.rest.api.Constants.PARAM_PROFILE) 057 UriAndListParam theSearchForProfile, 058 059 @Description(shortDefinition="Search for resources which have the given source value (Resource.meta.source)") 060 @OptionalParam(name=ca.uhn.fhir.rest.api.Constants.PARAM_SOURCE) 061 UriAndListParam theSearchForSource, 062 063 @Description(shortDefinition="Return resources linked to by the given target") 064 @OptionalParam(name="_has") 065 HasAndListParam theHas, 066 067 068 069 @Description(shortDefinition="The ID of the resource") 070 @OptionalParam(name="_id") 071 TokenAndListParam the_id, 072 073 074 @Description(shortDefinition="Search on the narrative of the resource") 075 @OptionalParam(name="_text") 076 SpecialAndListParam the_text, 077 078 079 @Description(shortDefinition="A (part of the) address of the location") 080 @OptionalParam(name="address") 081 StringAndListParam theAddress, 082 083 084 @Description(shortDefinition="A city specified in an address") 085 @OptionalParam(name="address-city") 086 StringAndListParam theAddress_city, 087 088 089 @Description(shortDefinition="A country specified in an address") 090 @OptionalParam(name="address-country") 091 StringAndListParam theAddress_country, 092 093 094 @Description(shortDefinition="A postal code specified in an address") 095 @OptionalParam(name="address-postalcode") 096 StringAndListParam theAddress_postalcode, 097 098 099 @Description(shortDefinition="A state specified in an address") 100 @OptionalParam(name="address-state") 101 StringAndListParam theAddress_state, 102 103 104 @Description(shortDefinition="A use code specified in an address") 105 @OptionalParam(name="address-use") 106 TokenAndListParam theAddress_use, 107 108 109 @Description(shortDefinition="One of the Location's characteristics") 110 @OptionalParam(name="characteristic") 111 TokenAndListParam theCharacteristic, 112 113 114 @Description(shortDefinition="Select locations that contain the specified co-ordinates") 115 @OptionalParam(name="contains") 116 SpecialAndListParam theContains, 117 118 119 @Description(shortDefinition="Technical endpoints providing access to services operated for the location") 120 @OptionalParam(name="endpoint", targetTypes={ } ) 121 ReferenceAndListParam theEndpoint, 122 123 124 @Description(shortDefinition="An identifier for the location") 125 @OptionalParam(name="identifier") 126 TokenAndListParam theIdentifier, 127 128 129 @Description(shortDefinition="A portion of the location's name or alias") 130 @OptionalParam(name="name") 131 StringAndListParam theName, 132 133 134 @Description(shortDefinition="Search for locations where the location.position is near to, or within a specified distance of, the provided coordinates expressed as [latitude]|[longitude]|[distance]|[units] (using the WGS84 datum, see notes).Servers which support the near parameter SHALL support the unit string 'km' for kilometers and SHOULD support '[mi_us]' for miles, support for other units is optional. If the units are omitted, then kms should be assumed. If the distance is omitted, then the server can use its own discretion as to what distances should be considered near (and units are irrelevant).If the server is unable to understand the units (and does support the near search parameter), it MIGHT return an OperationOutcome and fail the search with a http status 400 BadRequest. If the server does not support the near parameter, the parameter MIGHT report the unused parameter in a bundled OperationOutcome and still perform the search ignoring the near parameter.Note: The algorithm to determine the distance is not defined by the specification, and systems might have different engines that calculate things differently. They could consider geographic point to point, or path via road, or including current traffic conditions, or just simple neighboring postcodes/localities if that's all it had access to.") 135 @OptionalParam(name="near") 136 SpecialAndListParam theNear, 137 138 139 @Description(shortDefinition="Searches for locations (typically bed/room) that have an operational status (e.g. contaminated, housekeeping)") 140 @OptionalParam(name="operational-status") 141 TokenAndListParam theOperational_status, 142 143 144 @Description(shortDefinition="Searches for locations that are managed by the provided organization") 145 @OptionalParam(name="organization", targetTypes={ } ) 146 ReferenceAndListParam theOrganization, 147 148 149 @Description(shortDefinition="A location of which this location is a part") 150 @OptionalParam(name="partof", targetTypes={ } ) 151 ReferenceAndListParam thePartof, 152 153 154 @Description(shortDefinition="Searches for locations with a specific kind of status") 155 @OptionalParam(name="status") 156 TokenAndListParam theStatus, 157 158 159 @Description(shortDefinition="A code for the type of location") 160 @OptionalParam(name="type") 161 TokenAndListParam theType, 162 163 @RawParam 164 Map<String, List<String>> theAdditionalRawParams, 165 166 @Description(shortDefinition="Only return resources which were last updated as specified by the given range") 167 @OptionalParam(name="_lastUpdated") 168 DateRangeParam theLastUpdated, 169 170 @IncludeParam 171 Set<Include> theIncludes, 172 173 @IncludeParam(reverse=true) 174 Set<Include> theRevIncludes, 175 176 @Sort 177 SortSpec theSort, 178 179 @ca.uhn.fhir.rest.annotation.Count 180 Integer theCount, 181 182 @ca.uhn.fhir.rest.annotation.Offset 183 Integer theOffset, 184 185 SummaryEnum theSummaryMode, 186 187 SearchTotalModeEnum theSearchTotalMode, 188 189 SearchContainedModeEnum theSearchContainedMode 190 191 ) { 192 startRequest(theServletRequest); 193 try { 194 SearchParameterMap paramMap = new SearchParameterMap(); 195 paramMap.add(ca.uhn.fhir.rest.api.Constants.PARAM_FILTER, theFtFilter); 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(ca.uhn.fhir.rest.api.Constants.PARAM_SOURCE, theSearchForSource); 202 paramMap.add("_has", theHas); 203 paramMap.add("_id", the_id); 204 paramMap.add("_text", the_text); 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("characteristic", theCharacteristic); 212 paramMap.add("contains", theContains); 213 paramMap.add("endpoint", theEndpoint); 214 paramMap.add("identifier", theIdentifier); 215 paramMap.add("name", theName); 216 paramMap.add("near", theNear); 217 paramMap.add("operational-status", theOperational_status); 218 paramMap.add("organization", theOrganization); 219 paramMap.add("partof", thePartof); 220 paramMap.add("status", theStatus); 221 paramMap.add("type", theType); 222 paramMap.setRevIncludes(theRevIncludes); 223 paramMap.setLastUpdated(theLastUpdated); 224 paramMap.setIncludes(theIncludes); 225 paramMap.setSort(theSort); 226 paramMap.setCount(theCount); 227 paramMap.setOffset(theOffset); 228 paramMap.setSummaryMode(theSummaryMode); 229 paramMap.setSearchTotalMode(theSearchTotalMode); 230 paramMap.setSearchContainedMode(theSearchContainedMode); 231 232 getDao().translateRawParameters(theAdditionalRawParams, paramMap); 233 234 ca.uhn.fhir.rest.api.server.IBundleProvider retVal = getDao().search(paramMap, theRequestDetails, theServletResponse); 235 return retVal; 236 } finally { 237 endRequest(theServletRequest); 238 } 239 } 240 241}