001 002package ca.uhn.fhir.jpa.rp.r4b; 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.r4b.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 AppointmentResourceProvider extends 020 ca.uhn.fhir.jpa.provider.BaseJpaResourceProvider<Appointment> 021 { 022 023 @Override 024 public Class<Appointment> getResourceType() { 025 return Appointment.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 StringAndListParam the_text, 077 078 079 @Description(shortDefinition="Any one of the individuals participating in the appointment") 080 @OptionalParam(name="actor", targetTypes={ } ) 081 ReferenceAndListParam theActor, 082 083 084 @Description(shortDefinition="The style of appointment or patient that has been booked in the slot (not service type)") 085 @OptionalParam(name="appointment-type") 086 TokenAndListParam theAppointment_type, 087 088 089 @Description(shortDefinition="The service request this appointment is allocated to assess") 090 @OptionalParam(name="based-on", targetTypes={ } ) 091 ReferenceAndListParam theBased_on, 092 093 094 @Description(shortDefinition="Appointment date/time.") 095 @OptionalParam(name="date") 096 DateRangeParam theDate, 097 098 099 @Description(shortDefinition="An Identifier of the Appointment") 100 @OptionalParam(name="identifier") 101 TokenAndListParam theIdentifier, 102 103 104 @Description(shortDefinition="This location is listed in the participants of the appointment") 105 @OptionalParam(name="location", targetTypes={ } ) 106 ReferenceAndListParam theLocation, 107 108 109 @Description(shortDefinition="The Participation status of the subject, or other participant on the appointment. Can be used to locate participants that have not responded to meeting requests.") 110 @OptionalParam(name="part-status") 111 TokenAndListParam thePart_status, 112 113 114 @Description(shortDefinition="One of the individuals of the appointment is this patient") 115 @OptionalParam(name="patient", targetTypes={ } ) 116 ReferenceAndListParam thePatient, 117 118 119 @Description(shortDefinition="One of the individuals of the appointment is this practitioner") 120 @OptionalParam(name="practitioner", targetTypes={ } ) 121 ReferenceAndListParam thePractitioner, 122 123 124 @Description(shortDefinition="Coded reason this appointment is scheduled") 125 @OptionalParam(name="reason-code") 126 TokenAndListParam theReason_code, 127 128 129 @Description(shortDefinition="Reason the appointment is to take place (resource)") 130 @OptionalParam(name="reason-reference", targetTypes={ } ) 131 ReferenceAndListParam theReason_reference, 132 133 134 @Description(shortDefinition="A broad categorization of the service that is to be performed during this appointment") 135 @OptionalParam(name="service-category") 136 TokenAndListParam theService_category, 137 138 139 @Description(shortDefinition="The specific service that is to be performed during this appointment") 140 @OptionalParam(name="service-type") 141 TokenAndListParam theService_type, 142 143 144 @Description(shortDefinition="The slots that this appointment is filling") 145 @OptionalParam(name="slot", targetTypes={ } ) 146 ReferenceAndListParam theSlot, 147 148 149 @Description(shortDefinition="The specialty of a practitioner that would be required to perform the service requested in this appointment") 150 @OptionalParam(name="specialty") 151 TokenAndListParam theSpecialty, 152 153 154 @Description(shortDefinition="The overall status of the appointment") 155 @OptionalParam(name="status") 156 TokenAndListParam theStatus, 157 158 159 @Description(shortDefinition="Additional information to support the appointment") 160 @OptionalParam(name="supporting-info", targetTypes={ } ) 161 ReferenceAndListParam theSupporting_info, 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("actor", theActor); 206 paramMap.add("appointment-type", theAppointment_type); 207 paramMap.add("based-on", theBased_on); 208 paramMap.add("date", theDate); 209 paramMap.add("identifier", theIdentifier); 210 paramMap.add("location", theLocation); 211 paramMap.add("part-status", thePart_status); 212 paramMap.add("patient", thePatient); 213 paramMap.add("practitioner", thePractitioner); 214 paramMap.add("reason-code", theReason_code); 215 paramMap.add("reason-reference", theReason_reference); 216 paramMap.add("service-category", theService_category); 217 paramMap.add("service-type", theService_type); 218 paramMap.add("slot", theSlot); 219 paramMap.add("specialty", theSpecialty); 220 paramMap.add("status", theStatus); 221 paramMap.add("supporting-info", theSupporting_info); 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}