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 PractitionerResourceProvider extends 
20  	JpaResourceProviderDstu3<Practitioner>
21  	{
22  
23  	@Override
24  	public Class<Practitioner> getResourceType() {
25  		return Practitioner.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="Whether the practitioner record is active")
69  			@OptionalParam(name="active")
70  			TokenAndListParam theActive,
71    
72  			@Description(shortDefinition="A server defined search that may match any of the string fields in the Address, including line, city, state, country, postalCode, and/or text")
73  			@OptionalParam(name="address")
74  			StringAndListParam theAddress, 
75    
76  			@Description(shortDefinition="A city specified in an address")
77  			@OptionalParam(name="address-city")
78  			StringAndListParam theAddress_city, 
79    
80  			@Description(shortDefinition="A country specified in an address")
81  			@OptionalParam(name="address-country")
82  			StringAndListParam theAddress_country, 
83    
84  			@Description(shortDefinition="A postalCode specified in an address")
85  			@OptionalParam(name="address-postalcode")
86  			StringAndListParam theAddress_postalcode, 
87    
88  			@Description(shortDefinition="A state specified in an address")
89  			@OptionalParam(name="address-state")
90  			StringAndListParam theAddress_state, 
91    
92  			@Description(shortDefinition="A use code specified in an address")
93  			@OptionalParam(name="address-use")
94  			TokenAndListParam theAddress_use,
95    
96  			@Description(shortDefinition="One of the languages that the practitioner can communicate with")
97  			@OptionalParam(name="communication")
98  			TokenAndListParam theCommunication,
99    
100 			@Description(shortDefinition="A value in an email contact")
101 			@OptionalParam(name="email")
102 			TokenAndListParam theEmail,
103   
104 			@Description(shortDefinition="A portion of the family name")
105 			@OptionalParam(name="family")
106 			StringAndListParam theFamily, 
107   
108 			@Description(shortDefinition="Gender of the practitioner")
109 			@OptionalParam(name="gender")
110 			TokenAndListParam theGender,
111   
112 			@Description(shortDefinition="A portion of the given name")
113 			@OptionalParam(name="given")
114 			StringAndListParam theGiven, 
115   
116 			@Description(shortDefinition="A practitioner's Identifier")
117 			@OptionalParam(name="identifier")
118 			TokenAndListParam theIdentifier,
119   
120 			@Description(shortDefinition="A server defined search that may match any of the string fields in the HumanName, including family, give, prefix, suffix, suffix, and/or text")
121 			@OptionalParam(name="name")
122 			StringAndListParam theName, 
123   
124 			@Description(shortDefinition="A value in a phone contact")
125 			@OptionalParam(name="phone")
126 			TokenAndListParam thePhone,
127   
128 			@Description(shortDefinition="A portion of either family or given name using some kind of phonetic matching algorithm")
129 			@OptionalParam(name="phonetic")
130 			StringAndListParam thePhonetic, 
131   
132 			@Description(shortDefinition="The value in any kind of contact")
133 			@OptionalParam(name="telecom")
134 			TokenAndListParam theTelecom,
135 
136 			@RawParam
137 			Map<String, List<String>> theAdditionalRawParams,
138 
139 			@IncludeParam(reverse=true)
140 			Set<Include> theRevIncludes,
141 			@Description(shortDefinition="Only return resources which were last updated as specified by the given range")
142 			@OptionalParam(name="_lastUpdated")
143 			DateRangeParam theLastUpdated, 
144 
145 			@IncludeParam(allow= {
146 				"*"
147 			}) 
148 			Set<Include> theIncludes,
149 			
150 			@Sort 
151 			SortSpec theSort,
152 			
153 			@ca.uhn.fhir.rest.annotation.Count
154 			Integer theCount,
155 
156 			SummaryEnum theSummaryMode,
157 
158 			SearchTotalModeEnum theSearchTotalMode
159 
160 			) {
161 		startRequest(theServletRequest);
162 		try {
163 			SearchParameterMap paramMap = new SearchParameterMap();
164 			paramMap.add(ca.uhn.fhir.rest.api.Constants.PARAM_CONTENT, theFtContent);
165 			paramMap.add(ca.uhn.fhir.rest.api.Constants.PARAM_TEXT, theFtText);
166 			paramMap.add(ca.uhn.fhir.rest.api.Constants.PARAM_TAG, theSearchForTag);
167 			paramMap.add(ca.uhn.fhir.rest.api.Constants.PARAM_SECURITY, theSearchForSecurity);
168 			paramMap.add(ca.uhn.fhir.rest.api.Constants.PARAM_PROFILE, theSearchForProfile);
169 			paramMap.add("_has", theHas);
170 			paramMap.add("_id", the_id);
171 			paramMap.add("_language", the_language);
172 			paramMap.add("active", theActive);
173 			paramMap.add("address", theAddress);
174 			paramMap.add("address-city", theAddress_city);
175 			paramMap.add("address-country", theAddress_country);
176 			paramMap.add("address-postalcode", theAddress_postalcode);
177 			paramMap.add("address-state", theAddress_state);
178 			paramMap.add("address-use", theAddress_use);
179 			paramMap.add("communication", theCommunication);
180 			paramMap.add("email", theEmail);
181 			paramMap.add("family", theFamily);
182 			paramMap.add("gender", theGender);
183 			paramMap.add("given", theGiven);
184 			paramMap.add("identifier", theIdentifier);
185 			paramMap.add("name", theName);
186 			paramMap.add("phone", thePhone);
187 			paramMap.add("phonetic", thePhonetic);
188 			paramMap.add("telecom", theTelecom);
189 			paramMap.setRevIncludes(theRevIncludes);
190 			paramMap.setLastUpdated(theLastUpdated);
191 			paramMap.setIncludes(theIncludes);
192 			paramMap.setSort(theSort);
193 			paramMap.setCount(theCount);
194 			paramMap.setSummaryMode(theSummaryMode);
195 			paramMap.setSearchTotalMode(theSearchTotalMode);
196 
197 			getDao().translateRawParameters(theAdditionalRawParams, paramMap);
198 
199 			ca.uhn.fhir.rest.api.server.IBundleProvider retVal = getDao().search(paramMap, theRequestDetails, theServletResponse);
200 			return retVal;
201 		} finally {
202 			endRequest(theServletRequest);
203 		}
204 	}
205 
206 }