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  
17  public class PractitionerRoleResourceProvider extends 
18  	JpaResourceProviderDstu3<PractitionerRole>
19  	{
20  
21  	@Override
22  	public Class<PractitionerRole> getResourceType() {
23  		return PractitionerRole.class;
24  	}
25  
26  	@Search(allowUnknownParams=true)
27  	public ca.uhn.fhir.rest.api.server.IBundleProvider search(
28  			javax.servlet.http.HttpServletRequest theServletRequest,
29  			javax.servlet.http.HttpServletResponse theServletResponse,
30  
31  			ca.uhn.fhir.rest.api.server.RequestDetails theRequestDetails,
32  			
33  			@Description(shortDefinition="Search the contents of the resource's data using a fulltext search")
34  			@OptionalParam(name=ca.uhn.fhir.rest.api.Constants.PARAM_CONTENT)
35  			StringAndListParam theFtContent, 
36  
37  			@Description(shortDefinition="Search the contents of the resource's narrative using a fulltext search")
38  			@OptionalParam(name=ca.uhn.fhir.rest.api.Constants.PARAM_TEXT)
39  			StringAndListParam theFtText, 
40  
41  			@Description(shortDefinition="Search for resources which have the given tag")
42  			@OptionalParam(name=ca.uhn.fhir.rest.api.Constants.PARAM_TAG)
43  			TokenAndListParam theSearchForTag, 
44  
45  			@Description(shortDefinition="Search for resources which have the given security labels")
46  			@OptionalParam(name=ca.uhn.fhir.rest.api.Constants.PARAM_SECURITY)
47  			TokenAndListParam theSearchForSecurity, 
48    
49  			@Description(shortDefinition="Search for resources which have the given profile")
50  			@OptionalParam(name=ca.uhn.fhir.rest.api.Constants.PARAM_PROFILE)
51  			UriAndListParam theSearchForProfile, 
52  
53  			@Description(shortDefinition="Return resources linked to by the given target")
54  			@OptionalParam(name="_has")
55  			HasAndListParam theHas, 
56  
57    
58  			@Description(shortDefinition="The ID of the resource")
59  			@OptionalParam(name="_id")
60  			TokenAndListParam the_id, 
61    
62  			@Description(shortDefinition="The language of the resource")
63  			@OptionalParam(name="_language")
64  			StringAndListParam the_language, 
65    
66  			@Description(shortDefinition="Whether this practitioner's record is in active use")
67  			@OptionalParam(name="active")
68  			TokenAndListParam theActive, 
69    
70  			@Description(shortDefinition="The period during which the practitioner is authorized to perform in these role(s)")
71  			@OptionalParam(name="date")
72  			DateRangeParam theDate, 
73    
74  			@Description(shortDefinition="A value in an email contact")
75  			@OptionalParam(name="email")
76  			TokenAndListParam theEmail, 
77    
78  			@Description(shortDefinition="Technical endpoints providing access to services operated for the practitioner with this role")
79  			@OptionalParam(name="endpoint", targetTypes={  } )
80  			ReferenceAndListParam theEndpoint, 
81    
82  			@Description(shortDefinition="A practitioner's Identifier")
83  			@OptionalParam(name="identifier")
84  			TokenAndListParam theIdentifier, 
85    
86  			@Description(shortDefinition="One of the locations at which this practitioner provides care")
87  			@OptionalParam(name="location", targetTypes={  } )
88  			ReferenceAndListParam theLocation, 
89    
90  			@Description(shortDefinition="The identity of the organization the practitioner represents / acts on behalf of")
91  			@OptionalParam(name="organization", targetTypes={  } )
92  			ReferenceAndListParam theOrganization, 
93    
94  			@Description(shortDefinition="A value in a phone contact")
95  			@OptionalParam(name="phone")
96  			TokenAndListParam thePhone, 
97    
98  			@Description(shortDefinition="Practitioner that is able to provide the defined services for the organation")
99  			@OptionalParam(name="practitioner", targetTypes={  } )
100 			ReferenceAndListParam thePractitioner, 
101   
102 			@Description(shortDefinition="The practitioner can perform this role at for the organization")
103 			@OptionalParam(name="role")
104 			TokenAndListParam theRole, 
105   
106 			@Description(shortDefinition="The list of healthcare services that this worker provides for this role's Organization/Location(s)")
107 			@OptionalParam(name="service", targetTypes={  } )
108 			ReferenceAndListParam theService, 
109   
110 			@Description(shortDefinition="The practitioner has this specialty at an organization")
111 			@OptionalParam(name="specialty")
112 			TokenAndListParam theSpecialty, 
113   
114 			@Description(shortDefinition="The value in any kind of contact")
115 			@OptionalParam(name="telecom")
116 			TokenAndListParam theTelecom, 
117 
118 			@RawParam
119 			Map<String, List<String>> theAdditionalRawParams,
120 
121 			@IncludeParam(reverse=true)
122 			Set<Include> theRevIncludes,
123 			@Description(shortDefinition="Only return resources which were last updated as specified by the given range")
124 			@OptionalParam(name="_lastUpdated")
125 			DateRangeParam theLastUpdated, 
126 
127 			@IncludeParam(allow= {
128 					"PractitionerRole:endpoint" , 					"PractitionerRole:location" , 					"PractitionerRole:organization" , 					"PractitionerRole:practitioner" , 					"PractitionerRole:service" , 						"PractitionerRole:endpoint" , 					"PractitionerRole:location" , 					"PractitionerRole:organization" , 					"PractitionerRole:practitioner" , 					"PractitionerRole:service" , 						"PractitionerRole:endpoint" , 					"PractitionerRole:location" , 					"PractitionerRole:organization" , 					"PractitionerRole:practitioner" , 					"PractitionerRole:service" , 						"PractitionerRole:endpoint" , 					"PractitionerRole:location" , 					"PractitionerRole:organization" , 					"PractitionerRole:practitioner" , 					"PractitionerRole:service" , 						"PractitionerRole:endpoint" , 					"PractitionerRole:location" , 					"PractitionerRole:organization" , 					"PractitionerRole:practitioner" , 					"PractitionerRole:service" 					, "*"
129 			}) 
130 			Set<Include> theIncludes,
131 			
132 			@Sort 
133 			SortSpec theSort,
134 			
135 			@ca.uhn.fhir.rest.annotation.Count
136 			Integer theCount
137 	) {
138 		startRequest(theServletRequest);
139 		try {
140 			SearchParameterMap paramMap = new SearchParameterMap();
141 			paramMap.add(ca.uhn.fhir.rest.api.Constants.PARAM_CONTENT, theFtContent);
142 			paramMap.add(ca.uhn.fhir.rest.api.Constants.PARAM_TEXT, theFtText);
143 			paramMap.add(ca.uhn.fhir.rest.api.Constants.PARAM_TAG, theSearchForTag);
144 			paramMap.add(ca.uhn.fhir.rest.api.Constants.PARAM_SECURITY, theSearchForSecurity);
145 			paramMap.add(ca.uhn.fhir.rest.api.Constants.PARAM_PROFILE, theSearchForProfile);
146 			paramMap.add("_has", theHas);
147 			paramMap.add("_id", the_id);
148 			paramMap.add("_language", the_language);
149 			paramMap.add("active", theActive);
150 			paramMap.add("date", theDate);
151 			paramMap.add("email", theEmail);
152 			paramMap.add("endpoint", theEndpoint);
153 			paramMap.add("identifier", theIdentifier);
154 			paramMap.add("location", theLocation);
155 			paramMap.add("organization", theOrganization);
156 			paramMap.add("phone", thePhone);
157 			paramMap.add("practitioner", thePractitioner);
158 			paramMap.add("role", theRole);
159 			paramMap.add("service", theService);
160 			paramMap.add("specialty", theSpecialty);
161 			paramMap.add("telecom", theTelecom);
162 			paramMap.setRevIncludes(theRevIncludes);
163 			paramMap.setLastUpdated(theLastUpdated);
164 			paramMap.setIncludes(theIncludes);
165 			paramMap.setSort(theSort);
166 			paramMap.setCount(theCount);
167 
168 			getDao().translateRawParameters(theAdditionalRawParams, paramMap);
169 
170 			ca.uhn.fhir.rest.api.server.IBundleProvider retVal = getDao().search(paramMap, theRequestDetails, theServletResponse);
171 			return retVal;
172 		} finally {
173 			endRequest(theServletRequest);
174 		}
175 	}
176 
177 }