‘Spring cleaning …. ‘

This commit is contained in:
jkv 2017-03-07 22:45:49 +01:00
parent fb80c79103
commit 2cb3aaa2a1
2 changed files with 43 additions and 60 deletions

View File

@ -16,12 +16,13 @@ import org.glassfish.jersey.media.sse.EventOutput;
import org.glassfish.jersey.media.sse.OutboundEvent; import org.glassfish.jersey.media.sse.OutboundEvent;
import org.glassfish.jersey.media.sse.SseBroadcaster; import org.glassfish.jersey.media.sse.SseBroadcaster;
import org.glassfish.jersey.media.sse.SseFeature; import org.glassfish.jersey.media.sse.SseFeature;
import org.hl7.fhir.dstu3.model.Bundle.BundleEntryComponent;
import org.hl7.fhir.dstu3.model.IdType; import org.hl7.fhir.dstu3.model.IdType;
import org.hl7.fhir.dstu3.model.Identifier;
import org.hl7.fhir.dstu3.model.Patient; import org.hl7.fhir.dstu3.model.Patient;
import ca.uhn.fhir.context.FhirContext; import ca.uhn.fhir.context.FhirContext;
import ca.uhn.fhir.jaxrs.server.AbstractJaxRsResourceProvider; import ca.uhn.fhir.jaxrs.server.AbstractJaxRsResourceProvider;
import ca.uhn.fhir.parser.IParser;
import ca.uhn.fhir.rest.annotation.ConditionalUrlParam; import ca.uhn.fhir.rest.annotation.ConditionalUrlParam;
import ca.uhn.fhir.rest.annotation.Create; import ca.uhn.fhir.rest.annotation.Create;
import ca.uhn.fhir.rest.annotation.RequiredParam; import ca.uhn.fhir.rest.annotation.RequiredParam;
@ -44,31 +45,6 @@ public class JaxRsPatientProvider extends AbstractJaxRsResourceProvider<Patient>
@Inject @Inject
public JaxRsPatientProvider() { public JaxRsPatientProvider() {
super(FhirContext.forDstu3(), JaxRsPatientProvider.class); super(FhirContext.forDstu3(), JaxRsPatientProvider.class);
new Thread() {
@Override
public void run() {
try {
while (true) {
Thread.sleep(1000);
final int id = patients.size() + 1;
final Patient p = new Patient();
final Identifier i = new Identifier();
i.setValue(id + "");
p.addName().setFamily("John " + i);
p.getIdentifier().add(i);
p.setId(new IdType(id));
patients.put(id + "", p);
broadcaster.broadcast(new OutboundEvent.Builder().name("patients").data(String.class, patients.size() + "").build());
}
} catch (final InterruptedException e) {
e.printStackTrace();
}
}
}.start();
} }
@Search @Search
@ -76,10 +52,10 @@ public class JaxRsPatientProvider extends AbstractJaxRsResourceProvider<Patient>
final List<Patient> result = new LinkedList<Patient>(); final List<Patient> result = new LinkedList<Patient>();
for (final Patient patient : patients.values()) { for (final Patient patient : patients.values()) {
Patient single = null; Patient single = null;
if (name == null || patient.getName().get(0).getFamilyElement().getValueNotNull() if (name == null
.equals(name.getValueNotNull())) { || patient.getName().get(0).getFamilyElement().getValueNotNull().equals(name.getValueNotNull())) {
single = patient; single = patient;
} }
if (single != null) { if (single != null) {
result.add(single); result.add(single);
} }
@ -91,13 +67,42 @@ public class JaxRsPatientProvider extends AbstractJaxRsResourceProvider<Patient>
public MethodOutcome create(@ResourceParam final Patient patient, @ConditionalUrlParam final String theConditional) public MethodOutcome create(@ResourceParam final Patient patient, @ConditionalUrlParam final String theConditional)
throws Exception { throws Exception {
patients.put(patient.getIdentifierFirstRep().getId(), patient); storePatient(patient);
final MethodOutcome result = new MethodOutcome().setCreated(true); final MethodOutcome result = new MethodOutcome().setCreated(true);
result.setResource(patient); result.setResource(patient);
result.setId(new IdType(patient.getId())); result.setId(new IdType(patient.getId()));
return result; return result;
} }
// Conceptual wrapper for storing in a db
private void storePatient(final Patient patient) {
try {
patients.put(patient.getIdentifierFirstRep().getValue(), patient);
// if storing is successful the notify the listeners that listens on
// any patient => patient/*
final String bundleToString = currentPatientsAsJsonString();
broadcaster
.broadcast(new OutboundEvent.Builder().name("patients").data(String.class, bundleToString).build());
} catch (final Exception e) {
e.printStackTrace();
}
}
private String currentPatientsAsJsonString() {
final IParser jsonParser = this.getFhirContext().newJsonParser().setPrettyPrint(true);
final org.hl7.fhir.dstu3.model.Bundle bundle = new org.hl7.fhir.dstu3.model.Bundle();
for (final Patient p : patients.values())
bundle.addEntry(new BundleEntryComponent().setResource(p));
final String bundleToString = jsonParser.encodeResourceToString(bundle);
return bundleToString;
}
@Override @Override
public ETagSupportEnum getETagSupport() { public ETagSupportEnum getETagSupport() {
return ETagSupportEnum.DISABLED; return ETagSupportEnum.DISABLED;
@ -108,14 +113,16 @@ public class JaxRsPatientProvider extends AbstractJaxRsResourceProvider<Patient>
return Patient.class; return Patient.class;
} }
@GET @GET
@Path("listen") @Path("listen")
@Produces(SseFeature.SERVER_SENT_EVENTS) @Produces(SseFeature.SERVER_SENT_EVENTS)
public EventOutput listenToBroadcast() throws IOException { public EventOutput listenToBroadcast() throws IOException {
final EventOutput eventOutput = new EventOutput(); final EventOutput eventOutput = new EventOutput();
final String bundleToString = currentPatientsAsJsonString();
eventOutput.write( eventOutput.write(
new OutboundEvent.Builder().name("patient count").data(String.class, patients.size() + "").build()); new OutboundEvent.Builder().name("patients").data(String.class, bundleToString).build());
this.broadcaster.add(eventOutput); this.broadcaster.add(eventOutput);
return eventOutput; return eventOutput;
} }

View File

@ -21,25 +21,18 @@ import java.awt.Desktop;
import java.net.URI; import java.net.URI;
import java.util.EnumSet; import java.util.EnumSet;
import java.util.List; import java.util.List;
import java.util.concurrent.ConcurrentHashMap;
import javax.servlet.DispatcherType; import javax.servlet.DispatcherType;
import org.eclipse.jetty.server.Server; import org.eclipse.jetty.server.Server;
import org.eclipse.jetty.servlet.ServletContextHandler; import org.eclipse.jetty.servlet.ServletContextHandler;
import org.hl7.fhir.dstu3.model.HumanName;
import org.hl7.fhir.dstu3.model.IdType;
import org.hl7.fhir.dstu3.model.Patient;
import org.slf4j.bridge.SLF4JBridgeHandler; import org.slf4j.bridge.SLF4JBridgeHandler;
import com.google.common.collect.Lists; import com.google.common.collect.Lists;
import com.google.inject.AbstractModule;
import com.google.inject.Guice; import com.google.inject.Guice;
import com.google.inject.Injector; import com.google.inject.Injector;
import com.google.inject.Module; import com.google.inject.Module;
import com.google.inject.Scopes;
import com.google.inject.Stage; import com.google.inject.Stage;
import com.google.inject.name.Names;
import com.google.inject.servlet.GuiceFilter; import com.google.inject.servlet.GuiceFilter;
import com.google.inject.servlet.GuiceServletContextListener; import com.google.inject.servlet.GuiceServletContextListener;
@ -52,28 +45,11 @@ public class GuiceJersey2ServletContextListener extends GuiceServletContextListe
final List<Module> modules = Lists.newArrayList(); final List<Module> modules = Lists.newArrayList();
modules.add(new AbstractModule() {
@Override
protected void configure() {
final ConcurrentHashMap<String, List<Patient>> patients = new ConcurrentHashMap<String, List<Patient>>();
for (int i = 0; i < 20; i++) {
final Patient patient = new Patient();
patient.getName().add(new HumanName().setFamily("Random Patient " + i));
patient.setId(new IdType("Patient", "" + i, "" + 1));
patients.put(String.valueOf(i), Lists.newArrayList(patient));
}
}
});
modules.add(new GuiceHk2Helper() { modules.add(new GuiceHk2Helper() {
@Override @Override
protected void configureServlets() { protected void configureServlets() {
bind(String.class).annotatedWith(Names.named("1")).toInstance("sad"); // bind(JaxRsPatientProvider.class).in(Scopes.SINGLETON);
bind(JaxRsPatientProvider.class).in(Scopes.SINGLETON);
rest("/*").packages(JaxRsPatientProvider.class); rest("/*").packages(JaxRsPatientProvider.class);
} }
}); });