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}