mirror of
https://github.com/hapifhir/hapi-fhir.git
synced 2025-02-17 18:35:50 +00:00
Fix #242 - Allow compartment and read method to coexist for server
This commit is contained in:
parent
d838a2bd4b
commit
8d515feb6d
@ -1,5 +1,7 @@
|
|||||||
package ca.uhn.fhir.rest.method;
|
package ca.uhn.fhir.rest.method;
|
||||||
|
|
||||||
|
import static org.apache.commons.lang3.StringUtils.isNotBlank;
|
||||||
|
|
||||||
/*
|
/*
|
||||||
* #%L
|
* #%L
|
||||||
* HAPI FHIR - Core Library
|
* HAPI FHIR - Core Library
|
||||||
@ -138,6 +140,9 @@ public class ReadMethodBinding extends BaseResourceReturningMethodBinding implem
|
|||||||
return false;
|
return false;
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
if (isNotBlank(theRequest.getCompartmentName())) {
|
||||||
|
return false;
|
||||||
|
}
|
||||||
if (theRequest.getRequestType() != RequestTypeEnum.GET) {
|
if (theRequest.getRequestType() != RequestTypeEnum.GET) {
|
||||||
ourLog.trace("Method {} doesn't match because request type is not GET: {}", theRequest.getId(), theRequest.getRequestType());
|
ourLog.trace("Method {} doesn't match because request type is not GET: {}", theRequest.getId(), theRequest.getRequestType());
|
||||||
return false;
|
return false;
|
||||||
@ -198,6 +203,9 @@ public class ReadMethodBinding extends BaseResourceReturningMethodBinding implem
|
|||||||
return resource;
|
return resource;
|
||||||
case BUNDLE_PROVIDER:
|
case BUNDLE_PROVIDER:
|
||||||
return new SimpleBundleProvider(resource);
|
return new SimpleBundleProvider(resource);
|
||||||
|
case BUNDLE_RESOURCE:
|
||||||
|
case METHOD_OUTCOME:
|
||||||
|
break;
|
||||||
}
|
}
|
||||||
|
|
||||||
throw new IllegalStateException("" + getMethodReturnType()); // should not happen
|
throw new IllegalStateException("" + getMethodReturnType()); // should not happen
|
||||||
|
@ -55,4 +55,4 @@ public class IndexNonDeletedInterceptor implements EntityIndexingInterceptor<Res
|
|||||||
public IndexingOverride onCollectionUpdate(ResourceTable entity) {
|
public IndexingOverride onCollectionUpdate(ResourceTable entity) {
|
||||||
return IndexingOverride.APPLY_DEFAULT;
|
return IndexingOverride.APPLY_DEFAULT;
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
@ -59,4 +59,4 @@ public class BigDecimalNumericFieldBridge implements TwoWayFieldBridge {
|
|||||||
protected void applyToLuceneOptions(LuceneOptions luceneOptions, String name, Number value, Document document) {
|
protected void applyToLuceneOptions(LuceneOptions luceneOptions, String name, Number value, Document document) {
|
||||||
luceneOptions.addNumericFieldToDocument(name, value, document);
|
luceneOptions.addNumericFieldToDocument(name, value, document);
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
@ -0,0 +1,187 @@
|
|||||||
|
package ca.uhn.fhir.rest.server;
|
||||||
|
|
||||||
|
import static org.hamcrest.Matchers.contains;
|
||||||
|
import static org.hamcrest.Matchers.containsString;
|
||||||
|
import static org.hamcrest.Matchers.startsWith;
|
||||||
|
import static org.junit.Assert.assertEquals;
|
||||||
|
import static org.junit.Assert.assertNull;
|
||||||
|
import static org.junit.Assert.assertThat;
|
||||||
|
import static org.junit.Assert.assertTrue;
|
||||||
|
|
||||||
|
import java.util.ArrayList;
|
||||||
|
import java.util.Collection;
|
||||||
|
import java.util.List;
|
||||||
|
import java.util.concurrent.TimeUnit;
|
||||||
|
|
||||||
|
import org.apache.commons.io.IOUtils;
|
||||||
|
import org.apache.http.HttpResponse;
|
||||||
|
import org.apache.http.client.methods.HttpGet;
|
||||||
|
import org.apache.http.client.methods.HttpPost;
|
||||||
|
import org.apache.http.entity.ContentType;
|
||||||
|
import org.apache.http.entity.StringEntity;
|
||||||
|
import org.apache.http.impl.client.CloseableHttpClient;
|
||||||
|
import org.apache.http.impl.client.HttpClientBuilder;
|
||||||
|
import org.apache.http.impl.conn.PoolingHttpClientConnectionManager;
|
||||||
|
import org.eclipse.jetty.server.Server;
|
||||||
|
import org.eclipse.jetty.servlet.ServletHandler;
|
||||||
|
import org.eclipse.jetty.servlet.ServletHolder;
|
||||||
|
import org.junit.After;
|
||||||
|
import org.junit.AfterClass;
|
||||||
|
import org.junit.Before;
|
||||||
|
import org.junit.BeforeClass;
|
||||||
|
import org.junit.Test;
|
||||||
|
|
||||||
|
import ca.uhn.fhir.context.FhirContext;
|
||||||
|
import ca.uhn.fhir.model.api.IResource;
|
||||||
|
import ca.uhn.fhir.model.dstu2.composite.ResourceReferenceDt;
|
||||||
|
import ca.uhn.fhir.model.dstu2.resource.Encounter;
|
||||||
|
import ca.uhn.fhir.model.dstu2.resource.Observation;
|
||||||
|
import ca.uhn.fhir.model.dstu2.resource.Patient;
|
||||||
|
import ca.uhn.fhir.model.primitive.IdDt;
|
||||||
|
import ca.uhn.fhir.model.primitive.StringDt;
|
||||||
|
import ca.uhn.fhir.rest.annotation.ConditionalUrlParam;
|
||||||
|
import ca.uhn.fhir.rest.annotation.Create;
|
||||||
|
import ca.uhn.fhir.rest.annotation.IdParam;
|
||||||
|
import ca.uhn.fhir.rest.annotation.OptionalParam;
|
||||||
|
import ca.uhn.fhir.rest.annotation.Read;
|
||||||
|
import ca.uhn.fhir.rest.annotation.ResourceParam;
|
||||||
|
import ca.uhn.fhir.rest.annotation.Search;
|
||||||
|
import ca.uhn.fhir.rest.api.MethodOutcome;
|
||||||
|
import ca.uhn.fhir.util.PortUtil;
|
||||||
|
|
||||||
|
/**
|
||||||
|
* Created by dsotnikov on 2/25/2014.
|
||||||
|
*/
|
||||||
|
public class CompartmentDstu2Test {
|
||||||
|
private static CloseableHttpClient ourClient;
|
||||||
|
|
||||||
|
private static final org.slf4j.Logger ourLog = org.slf4j.LoggerFactory.getLogger(CompartmentDstu2Test.class);
|
||||||
|
private static int ourPort;
|
||||||
|
private static Server ourServer;
|
||||||
|
private static String ourLastMethod;
|
||||||
|
private static FhirContext ourCtx = FhirContext.forDstu2();
|
||||||
|
private static IdDt ourLastId;
|
||||||
|
|
||||||
|
@Before
|
||||||
|
public void before() {
|
||||||
|
ourLastMethod = null;
|
||||||
|
ourLastId = null;
|
||||||
|
}
|
||||||
|
|
||||||
|
|
||||||
|
@Test
|
||||||
|
public void testReadFirst() throws Exception {
|
||||||
|
init(new TempPatientResourceProvider());
|
||||||
|
|
||||||
|
HttpGet httpGet = new HttpGet("http://localhost:" + ourPort + "/Patient/123");
|
||||||
|
HttpResponse status = ourClient.execute(httpGet);
|
||||||
|
String responseContent = IOUtils.toString(status.getEntity().getContent());
|
||||||
|
IOUtils.closeQuietly(status.getEntity().getContent());
|
||||||
|
ourLog.info("Response was:\n{}", responseContent);
|
||||||
|
assertEquals("read", ourLastMethod);
|
||||||
|
assertEquals("Patient", ourLastId.getResourceType());
|
||||||
|
assertEquals("123", ourLastId.getIdPart());
|
||||||
|
assertThat(responseContent, startsWith("<Patient"));
|
||||||
|
}
|
||||||
|
|
||||||
|
@Test
|
||||||
|
public void testCompartmentSecond() throws Exception {
|
||||||
|
init(new TempPatientResourceProvider());
|
||||||
|
|
||||||
|
HttpGet httpGet = new HttpGet("http://localhost:" + ourPort + "/Patient/123/Encounter");
|
||||||
|
HttpResponse status = ourClient.execute(httpGet);
|
||||||
|
String responseContent = IOUtils.toString(status.getEntity().getContent());
|
||||||
|
IOUtils.closeQuietly(status.getEntity().getContent());
|
||||||
|
ourLog.info("Response was:\n{}", responseContent);
|
||||||
|
assertEquals("searchEncounterCompartment", ourLastMethod);
|
||||||
|
assertEquals("Patient", ourLastId.getResourceType());
|
||||||
|
assertEquals("123", ourLastId.getIdPart());
|
||||||
|
assertThat(responseContent, startsWith("<Bundle"));
|
||||||
|
assertThat(responseContent, containsString("<Encounter"));
|
||||||
|
}
|
||||||
|
|
||||||
|
@Test
|
||||||
|
public void testCompartmentSecond2() throws Exception {
|
||||||
|
init(new TempPatientResourceProvider());
|
||||||
|
|
||||||
|
HttpGet httpGet = new HttpGet("http://localhost:" + ourPort + "/Patient/123/Observation");
|
||||||
|
HttpResponse status = ourClient.execute(httpGet);
|
||||||
|
String responseContent = IOUtils.toString(status.getEntity().getContent());
|
||||||
|
IOUtils.closeQuietly(status.getEntity().getContent());
|
||||||
|
ourLog.info("Response was:\n{}", responseContent);
|
||||||
|
assertEquals("searchObservationCompartment", ourLastMethod);
|
||||||
|
assertEquals("Patient", ourLastId.getResourceType());
|
||||||
|
assertEquals("123", ourLastId.getIdPart());
|
||||||
|
assertThat(responseContent, startsWith("<Bundle"));
|
||||||
|
assertThat(responseContent, containsString("<Observation"));
|
||||||
|
}
|
||||||
|
|
||||||
|
@After
|
||||||
|
public void after() throws Exception {
|
||||||
|
ourServer.stop();
|
||||||
|
ourClient.close();
|
||||||
|
}
|
||||||
|
|
||||||
|
public void init(IResourceProvider... theProviders) throws Exception {
|
||||||
|
ourPort = PortUtil.findFreePort();
|
||||||
|
ourServer = new Server(ourPort);
|
||||||
|
|
||||||
|
ServletHandler proxyHandler = new ServletHandler();
|
||||||
|
RestfulServer servlet = new RestfulServer(ourCtx);
|
||||||
|
servlet.setResourceProviders(theProviders);
|
||||||
|
ServletHolder servletHolder = new ServletHolder(servlet);
|
||||||
|
proxyHandler.addServletWithMapping(servletHolder, "/*");
|
||||||
|
ourServer.setHandler(proxyHandler);
|
||||||
|
ourServer.start();
|
||||||
|
|
||||||
|
PoolingHttpClientConnectionManager connectionManager = new PoolingHttpClientConnectionManager(5000, TimeUnit.MILLISECONDS);
|
||||||
|
HttpClientBuilder builder = HttpClientBuilder.create();
|
||||||
|
builder.setConnectionManager(connectionManager);
|
||||||
|
ourClient = builder.build();
|
||||||
|
|
||||||
|
}
|
||||||
|
|
||||||
|
public static class TempPatientResourceProvider implements IResourceProvider {
|
||||||
|
@Override
|
||||||
|
public Class<Patient> getResourceType() {
|
||||||
|
return Patient.class;
|
||||||
|
}
|
||||||
|
|
||||||
|
@Read()
|
||||||
|
public Patient method1Read(final @IdParam IdDt theId) {
|
||||||
|
ourLastMethod = "read";
|
||||||
|
ourLastId = theId;
|
||||||
|
Patient patient = new Patient();
|
||||||
|
patient.setId(theId);
|
||||||
|
return patient;
|
||||||
|
}
|
||||||
|
|
||||||
|
@Search(compartmentName = "Encounter")
|
||||||
|
public List<Encounter> method2SearchCompartment(final @IdParam IdDt theId) {
|
||||||
|
ourLastId = theId;
|
||||||
|
ourLastMethod = "searchEncounterCompartment";
|
||||||
|
System.out.println("Encounter compartment search");
|
||||||
|
List<Encounter> encounters = new ArrayList<Encounter>();
|
||||||
|
Encounter encounter = new Encounter();
|
||||||
|
encounter.setId("1");
|
||||||
|
encounter.setPatient(new ResourceReferenceDt(theId));
|
||||||
|
encounters.add(encounter);
|
||||||
|
return encounters;
|
||||||
|
}
|
||||||
|
|
||||||
|
@Search(compartmentName = "Observation")
|
||||||
|
public List<Observation> method2SearchCompartment2(final @IdParam IdDt theId) {
|
||||||
|
ourLastId = theId;
|
||||||
|
ourLastMethod = "searchObservationCompartment";
|
||||||
|
System.out.println("Encounter compartment search");
|
||||||
|
List<Observation> encounters = new ArrayList<Observation>();
|
||||||
|
Observation obs = new Observation();
|
||||||
|
obs.setId("1");
|
||||||
|
obs.setSubject(new ResourceReferenceDt(theId));
|
||||||
|
encounters.add(obs);
|
||||||
|
return encounters;
|
||||||
|
}
|
||||||
|
|
||||||
|
}
|
||||||
|
|
||||||
|
}
|
@ -192,6 +192,11 @@
|
|||||||
JPA server maximumn length for a URI search parameter has been reduced from
|
JPA server maximumn length for a URI search parameter has been reduced from
|
||||||
256 to 255 in order to accomodate MySQL's indexing requirements
|
256 to 255 in order to accomodate MySQL's indexing requirements
|
||||||
</action>
|
</action>
|
||||||
|
<action type="fix" issue="242">
|
||||||
|
Server failed to respond correctly to compartment search operations
|
||||||
|
if the same provider also contained a read operation. Thanks to GitHub user
|
||||||
|
@am202 for reporting!
|
||||||
|
</action>
|
||||||
</release>
|
</release>
|
||||||
<release version="1.2" date="2015-09-18">
|
<release version="1.2" date="2015-09-18">
|
||||||
<action type="add">
|
<action type="add">
|
||||||
|
2
vagrant/Vagrantfile
vendored
2
vagrant/Vagrantfile
vendored
@ -86,7 +86,7 @@ Vagrant.configure(VAGRANTFILE_API_VERSION) do |config|
|
|||||||
proxy_port: 80,
|
proxy_port: 80,
|
||||||
# ssl_port: 443,
|
# ssl_port: 443,
|
||||||
authbind: 'yes',
|
authbind: 'yes',
|
||||||
java_options: '-Dfhir.logdir=/var/log/fhir -Dfhir.db.location=/var/fhirdb'
|
java_options: '-Dfhir.logdir=/var/log/fhir -Dfhir.db.location=/var/fhirdb -Dfhir.db.location.dstu2=/var/fhirdb2 -Dfhir.lucene.location.dstu2=/var/fhirlucene2'
|
||||||
},
|
},
|
||||||
mysql: {
|
mysql: {
|
||||||
version: '5.6',
|
version: '5.6',
|
||||||
|
Loading…
x
Reference in New Issue
Block a user