View Javadoc
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.dao.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 MedicationAdministrationResourceProvider extends 
20  	JpaResourceProviderDstu3<MedicationAdministration>
21  	{
22  
23  	@Override
24  	public Class<MedicationAdministration> getResourceType() {
25  		return MedicationAdministration.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="Return administrations of this medication code")
69  			@OptionalParam(name="code")
70  			TokenAndListParam theCode,
71    
72  			@Description(shortDefinition="Return administrations that share this encounter or episode of care")
73  			@OptionalParam(name="context", targetTypes={  } )
74  			ReferenceAndListParam theContext, 
75    
76  			@Description(shortDefinition="Return administrations with this administration device identity")
77  			@OptionalParam(name="device", targetTypes={  } )
78  			ReferenceAndListParam theDevice, 
79    
80  			@Description(shortDefinition="Date administration happened (or did not happen)")
81  			@OptionalParam(name="effective-time")
82  			DateRangeParam theEffective_time, 
83    
84  			@Description(shortDefinition="Return administrations with this external identifier")
85  			@OptionalParam(name="identifier")
86  			TokenAndListParam theIdentifier,
87    
88  			@Description(shortDefinition="Return administrations of this medication resource")
89  			@OptionalParam(name="medication", targetTypes={  } )
90  			ReferenceAndListParam theMedication, 
91    
92  			@Description(shortDefinition="Administrations that were not made")
93  			@OptionalParam(name="not-given")
94  			TokenAndListParam theNot_given,
95    
96  			@Description(shortDefinition="The identity of a patient to list administrations  for")
97  			@OptionalParam(name="patient", targetTypes={  } )
98  			ReferenceAndListParam thePatient, 
99    
100 			@Description(shortDefinition="The identify of the individual who administered the medication")
101 			@OptionalParam(name="performer", targetTypes={  } )
102 			ReferenceAndListParam thePerformer, 
103   
104 			@Description(shortDefinition="The identity of a prescription to list administrations from")
105 			@OptionalParam(name="prescription", targetTypes={  } )
106 			ReferenceAndListParam thePrescription, 
107   
108 			@Description(shortDefinition="Reasons for administering the medication")
109 			@OptionalParam(name="reason-given")
110 			TokenAndListParam theReason_given,
111   
112 			@Description(shortDefinition="Reasons for not administering the medication")
113 			@OptionalParam(name="reason-not-given")
114 			TokenAndListParam theReason_not_given,
115   
116 			@Description(shortDefinition="MedicationAdministration event status (for example one of active/paused/completed/nullified)")
117 			@OptionalParam(name="status")
118 			TokenAndListParam theStatus,
119   
120 			@Description(shortDefinition="The identify of the individual or group to list administrations for")
121 			@OptionalParam(name="subject", targetTypes={  } )
122 			ReferenceAndListParam theSubject, 
123 
124 			@RawParam
125 			Map<String, List<String>> theAdditionalRawParams,
126 
127 			@IncludeParam(reverse=true)
128 			Set<Include> theRevIncludes,
129 			@Description(shortDefinition="Only return resources which were last updated as specified by the given range")
130 			@OptionalParam(name="_lastUpdated")
131 			DateRangeParam theLastUpdated, 
132 
133 			@IncludeParam(allow= {
134 					"MedicationAdministration:context" , 					"MedicationAdministration:device" , 					"MedicationAdministration:medication" , 					"MedicationAdministration:patient" , 					"MedicationAdministration:performer" , 					"MedicationAdministration:prescription" , 					"MedicationAdministration:subject" , 						"MedicationAdministration:context" , 					"MedicationAdministration:device" , 					"MedicationAdministration:medication" , 					"MedicationAdministration:patient" , 					"MedicationAdministration:performer" , 					"MedicationAdministration:prescription" , 					"MedicationAdministration:subject" , 						"MedicationAdministration:context" , 					"MedicationAdministration:device" , 					"MedicationAdministration:medication" , 					"MedicationAdministration:patient" , 					"MedicationAdministration:performer" , 					"MedicationAdministration:prescription" , 					"MedicationAdministration:subject" , 						"MedicationAdministration:context" , 					"MedicationAdministration:device" , 					"MedicationAdministration:medication" , 					"MedicationAdministration:patient" , 					"MedicationAdministration:performer" , 					"MedicationAdministration:prescription" , 					"MedicationAdministration:subject" , 						"MedicationAdministration:context" , 					"MedicationAdministration:device" , 					"MedicationAdministration:medication" , 					"MedicationAdministration:patient" , 					"MedicationAdministration:performer" , 					"MedicationAdministration:prescription" , 					"MedicationAdministration:subject" , 						"MedicationAdministration:context" , 					"MedicationAdministration:device" , 					"MedicationAdministration:medication" , 					"MedicationAdministration:patient" , 					"MedicationAdministration:performer" , 					"MedicationAdministration:prescription" , 					"MedicationAdministration:subject" , 						"MedicationAdministration:context" , 					"MedicationAdministration:device" , 					"MedicationAdministration:medication" , 					"MedicationAdministration:patient" , 					"MedicationAdministration:performer" , 					"MedicationAdministration:prescription" , 					"MedicationAdministration:subject" 					, "*"
135 			}) 
136 			Set<Include> theIncludes,
137 			
138 			@Sort 
139 			SortSpec theSort,
140 			
141 			@ca.uhn.fhir.rest.annotation.Count
142 			Integer theCount,
143 
144 			SummaryEnum theSummaryMode,
145 
146 			SearchTotalModeEnum theSearchTotalMode
147 
148 			) {
149 		startRequest(theServletRequest);
150 		try {
151 			SearchParameterMap paramMap = new SearchParameterMap();
152 			paramMap.add(ca.uhn.fhir.rest.api.Constants.PARAM_CONTENT, theFtContent);
153 			paramMap.add(ca.uhn.fhir.rest.api.Constants.PARAM_TEXT, theFtText);
154 			paramMap.add(ca.uhn.fhir.rest.api.Constants.PARAM_TAG, theSearchForTag);
155 			paramMap.add(ca.uhn.fhir.rest.api.Constants.PARAM_SECURITY, theSearchForSecurity);
156 			paramMap.add(ca.uhn.fhir.rest.api.Constants.PARAM_PROFILE, theSearchForProfile);
157 			paramMap.add("_has", theHas);
158 			paramMap.add("_id", the_id);
159 			paramMap.add("_language", the_language);
160 			paramMap.add("code", theCode);
161 			paramMap.add("context", theContext);
162 			paramMap.add("device", theDevice);
163 			paramMap.add("effective-time", theEffective_time);
164 			paramMap.add("identifier", theIdentifier);
165 			paramMap.add("medication", theMedication);
166 			paramMap.add("not-given", theNot_given);
167 			paramMap.add("patient", thePatient);
168 			paramMap.add("performer", thePerformer);
169 			paramMap.add("prescription", thePrescription);
170 			paramMap.add("reason-given", theReason_given);
171 			paramMap.add("reason-not-given", theReason_not_given);
172 			paramMap.add("status", theStatus);
173 			paramMap.add("subject", theSubject);
174 			paramMap.setRevIncludes(theRevIncludes);
175 			paramMap.setLastUpdated(theLastUpdated);
176 			paramMap.setIncludes(theIncludes);
177 			paramMap.setSort(theSort);
178 			paramMap.setCount(theCount);
179 			paramMap.setSummaryMode(theSummaryMode);
180 			paramMap.setSearchTotalMode(theSearchTotalMode);
181 
182 			getDao().translateRawParameters(theAdditionalRawParams, paramMap);
183 
184 			ca.uhn.fhir.rest.api.server.IBundleProvider retVal = getDao().search(paramMap, theRequestDetails, theServletResponse);
185 			return retVal;
186 		} finally {
187 			endRequest(theServletRequest);
188 		}
189 	}
190 
191 }