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.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 AdverseEventResourceProvider extends 
20  	JpaResourceProviderDstu3<AdverseEvent>
21  	{
22  
23  	@Override
24  	public Class<AdverseEvent> getResourceType() {
25  		return AdverseEvent.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="AE | PAE An adverse event is an event that caused harm to a patient,  an adverse reaction is a something that is a subject-specific event that is a result of an exposure to a medication, food, device or environmental substance, a potential adverse event is something that occurred and that could have caused harm to a patient but did not")
69  			@OptionalParam(name="category")
70  			TokenAndListParam theCategory,
71    
72  			@Description(shortDefinition="When the event occurred")
73  			@OptionalParam(name="date")
74  			DateRangeParam theDate, 
75    
76  			@Description(shortDefinition="Location where adverse event occurred")
77  			@OptionalParam(name="location", targetTypes={  } )
78  			ReferenceAndListParam theLocation, 
79    
80  			@Description(shortDefinition="Adverse Reaction Events linked to exposure to substance")
81  			@OptionalParam(name="reaction", targetTypes={  } )
82  			ReferenceAndListParam theReaction, 
83    
84  			@Description(shortDefinition="Who recorded the adverse event")
85  			@OptionalParam(name="recorder", targetTypes={  } )
86  			ReferenceAndListParam theRecorder, 
87    
88  			@Description(shortDefinition="Mild | Moderate | Severe")
89  			@OptionalParam(name="seriousness")
90  			TokenAndListParam theSeriousness,
91    
92  			@Description(shortDefinition="AdverseEvent.study")
93  			@OptionalParam(name="study", targetTypes={  } )
94  			ReferenceAndListParam theStudy, 
95    
96  			@Description(shortDefinition="Subject or group impacted by event")
97  			@OptionalParam(name="subject", targetTypes={  } )
98  			ReferenceAndListParam theSubject, 
99    
100 			@Description(shortDefinition="Refers to the specific entity that caused the adverse event")
101 			@OptionalParam(name="substance", targetTypes={  } )
102 			ReferenceAndListParam theSubstance, 
103   
104 			@Description(shortDefinition="actual | potential")
105 			@OptionalParam(name="type")
106 			TokenAndListParam theType,
107 
108 			@RawParam
109 			Map<String, List<String>> theAdditionalRawParams,
110 
111 			@IncludeParam(reverse=true)
112 			Set<Include> theRevIncludes,
113 			@Description(shortDefinition="Only return resources which were last updated as specified by the given range")
114 			@OptionalParam(name="_lastUpdated")
115 			DateRangeParam theLastUpdated, 
116 
117 			@IncludeParam(allow= {
118 					"AdverseEvent:location" , 					"AdverseEvent:reaction" , 					"AdverseEvent:recorder" , 					"AdverseEvent:study" , 					"AdverseEvent:subject" , 					"AdverseEvent:substance" , 						"AdverseEvent:location" , 					"AdverseEvent:reaction" , 					"AdverseEvent:recorder" , 					"AdverseEvent:study" , 					"AdverseEvent:subject" , 					"AdverseEvent:substance" , 						"AdverseEvent:location" , 					"AdverseEvent:reaction" , 					"AdverseEvent:recorder" , 					"AdverseEvent:study" , 					"AdverseEvent:subject" , 					"AdverseEvent:substance" , 						"AdverseEvent:location" , 					"AdverseEvent:reaction" , 					"AdverseEvent:recorder" , 					"AdverseEvent:study" , 					"AdverseEvent:subject" , 					"AdverseEvent:substance" , 						"AdverseEvent:location" , 					"AdverseEvent:reaction" , 					"AdverseEvent:recorder" , 					"AdverseEvent:study" , 					"AdverseEvent:subject" , 					"AdverseEvent:substance" , 						"AdverseEvent:location" , 					"AdverseEvent:reaction" , 					"AdverseEvent:recorder" , 					"AdverseEvent:study" , 					"AdverseEvent:subject" , 					"AdverseEvent:substance" 					, "*"
119 			}) 
120 			Set<Include> theIncludes,
121 			
122 			@Sort 
123 			SortSpec theSort,
124 			
125 			@ca.uhn.fhir.rest.annotation.Count
126 			Integer theCount,
127 
128 			SummaryEnum theSummaryMode,
129 
130 			SearchTotalModeEnum theSearchTotalMode
131 
132 			) {
133 		startRequest(theServletRequest);
134 		try {
135 			SearchParameterMap paramMap = new SearchParameterMap();
136 			paramMap.add(ca.uhn.fhir.rest.api.Constants.PARAM_CONTENT, theFtContent);
137 			paramMap.add(ca.uhn.fhir.rest.api.Constants.PARAM_TEXT, theFtText);
138 			paramMap.add(ca.uhn.fhir.rest.api.Constants.PARAM_TAG, theSearchForTag);
139 			paramMap.add(ca.uhn.fhir.rest.api.Constants.PARAM_SECURITY, theSearchForSecurity);
140 			paramMap.add(ca.uhn.fhir.rest.api.Constants.PARAM_PROFILE, theSearchForProfile);
141 			paramMap.add("_has", theHas);
142 			paramMap.add("_id", the_id);
143 			paramMap.add("_language", the_language);
144 			paramMap.add("category", theCategory);
145 			paramMap.add("date", theDate);
146 			paramMap.add("location", theLocation);
147 			paramMap.add("reaction", theReaction);
148 			paramMap.add("recorder", theRecorder);
149 			paramMap.add("seriousness", theSeriousness);
150 			paramMap.add("study", theStudy);
151 			paramMap.add("subject", theSubject);
152 			paramMap.add("substance", theSubstance);
153 			paramMap.add("type", theType);
154 			paramMap.setRevIncludes(theRevIncludes);
155 			paramMap.setLastUpdated(theLastUpdated);
156 			paramMap.setIncludes(theIncludes);
157 			paramMap.setSort(theSort);
158 			paramMap.setCount(theCount);
159 			paramMap.setSummaryMode(theSummaryMode);
160 			paramMap.setSearchTotalMode(theSearchTotalMode);
161 
162 			getDao().translateRawParameters(theAdditionalRawParams, paramMap);
163 
164 			ca.uhn.fhir.rest.api.server.IBundleProvider retVal = getDao().search(paramMap, theRequestDetails, theServletResponse);
165 			return retVal;
166 		} finally {
167 			endRequest(theServletRequest);
168 		}
169 	}
170 
171 }