mirror of
https://github.com/hapifhir/hapi-fhir.git
synced 2025-02-08 14:05:02 +00:00
Merge branch 'master' of github.com:jamesagnew/hapi-fhir
This commit is contained in:
commit
fd4efd638f
@ -24,6 +24,7 @@ import static org.apache.commons.lang3.StringUtils.isBlank;
|
|||||||
import java.util.*;
|
import java.util.*;
|
||||||
import java.util.Map.Entry;
|
import java.util.Map.Entry;
|
||||||
|
|
||||||
|
import ca.uhn.fhir.jpa.provider.dstu3.JpaSystemProviderDstu3;
|
||||||
import org.springframework.beans.factory.annotation.Autowired;
|
import org.springframework.beans.factory.annotation.Autowired;
|
||||||
import org.springframework.beans.factory.annotation.Qualifier;
|
import org.springframework.beans.factory.annotation.Qualifier;
|
||||||
|
|
||||||
@ -47,7 +48,7 @@ public class JpaSystemProviderDstu2 extends BaseJpaSystemProviderDstu2Plus<Bundl
|
|||||||
@Qualifier("mySystemDaoDstu2")
|
@Qualifier("mySystemDaoDstu2")
|
||||||
private IFhirSystemDao<Bundle, MetaDt> mySystemDao;
|
private IFhirSystemDao<Bundle, MetaDt> mySystemDao;
|
||||||
|
|
||||||
@Autowired
|
@Autowired(required = false)
|
||||||
private IFulltextSearchSvc mySearchDao;
|
private IFulltextSearchSvc mySearchDao;
|
||||||
|
|
||||||
//@formatter:off
|
//@formatter:off
|
||||||
@ -178,6 +179,7 @@ public class JpaSystemProviderDstu2 extends BaseJpaSystemProviderDstu2Plus<Bundl
|
|||||||
@OperationParam(name="searchParam", min=1, max=1) String theSearchParam,
|
@OperationParam(name="searchParam", min=1, max=1) String theSearchParam,
|
||||||
@OperationParam(name="text", min=1, max=1) String theText
|
@OperationParam(name="text", min=1, max=1) String theText
|
||||||
) {
|
) {
|
||||||
|
JpaSystemProviderDstu3.validateFulltextSearchEnabled(mySearchDao);
|
||||||
|
|
||||||
if (isBlank(theContext)) {
|
if (isBlank(theContext)) {
|
||||||
throw new InvalidRequestException("Parameter 'context' must be provided");
|
throw new InvalidRequestException("Parameter 'context' must be provided");
|
||||||
@ -193,11 +195,9 @@ public class JpaSystemProviderDstu2 extends BaseJpaSystemProviderDstu2Plus<Bundl
|
|||||||
|
|
||||||
Parameters retVal = new Parameters();
|
Parameters retVal = new Parameters();
|
||||||
for (Suggestion next : keywords) {
|
for (Suggestion next : keywords) {
|
||||||
//@formatter:off
|
|
||||||
retVal.addParameter()
|
retVal.addParameter()
|
||||||
.addPart(new Parameter().setName("keyword").setValue(new StringDt(next.getTerm())))
|
.addPart(new Parameter().setName("keyword").setValue(new StringDt(next.getTerm())))
|
||||||
.addPart(new Parameter().setName("score").setValue(new DecimalDt(next.getScore())));
|
.addPart(new Parameter().setName("score").setValue(new DecimalDt(next.getScore())));
|
||||||
//@formatter:on
|
|
||||||
}
|
}
|
||||||
|
|
||||||
return retVal;
|
return retVal;
|
||||||
|
@ -1,5 +1,27 @@
|
|||||||
package ca.uhn.fhir.jpa.provider.dstu3;
|
package ca.uhn.fhir.jpa.provider.dstu3;
|
||||||
|
|
||||||
|
import ca.uhn.fhir.jpa.dao.FulltextSearchSvcImpl.Suggestion;
|
||||||
|
import ca.uhn.fhir.jpa.dao.IFhirSystemDao;
|
||||||
|
import ca.uhn.fhir.jpa.dao.IFulltextSearchSvc;
|
||||||
|
import ca.uhn.fhir.jpa.provider.BaseJpaSystemProviderDstu2Plus;
|
||||||
|
import ca.uhn.fhir.model.api.annotation.Description;
|
||||||
|
import ca.uhn.fhir.rest.annotation.Operation;
|
||||||
|
import ca.uhn.fhir.rest.annotation.OperationParam;
|
||||||
|
import ca.uhn.fhir.rest.annotation.Transaction;
|
||||||
|
import ca.uhn.fhir.rest.annotation.TransactionParam;
|
||||||
|
import ca.uhn.fhir.rest.api.server.RequestDetails;
|
||||||
|
import ca.uhn.fhir.rest.server.exceptions.InvalidRequestException;
|
||||||
|
import ca.uhn.fhir.rest.server.servlet.ServletRequestDetails;
|
||||||
|
import org.hl7.fhir.dstu3.model.*;
|
||||||
|
import org.hl7.fhir.dstu3.model.Parameters.ParametersParameterComponent;
|
||||||
|
import org.springframework.beans.factory.annotation.Autowired;
|
||||||
|
import org.springframework.beans.factory.annotation.Qualifier;
|
||||||
|
|
||||||
|
import java.util.List;
|
||||||
|
import java.util.Map;
|
||||||
|
import java.util.Map.Entry;
|
||||||
|
import java.util.TreeMap;
|
||||||
|
|
||||||
import static org.apache.commons.lang3.StringUtils.isBlank;
|
import static org.apache.commons.lang3.StringUtils.isBlank;
|
||||||
|
|
||||||
/*
|
/*
|
||||||
@ -21,23 +43,6 @@ import static org.apache.commons.lang3.StringUtils.isBlank;
|
|||||||
* limitations under the License.
|
* limitations under the License.
|
||||||
* #L%
|
* #L%
|
||||||
*/
|
*/
|
||||||
import java.util.*;
|
|
||||||
import java.util.Map.Entry;
|
|
||||||
|
|
||||||
import org.hl7.fhir.dstu3.model.*;
|
|
||||||
import org.hl7.fhir.dstu3.model.Parameters.ParametersParameterComponent;
|
|
||||||
import org.springframework.beans.factory.annotation.Autowired;
|
|
||||||
import org.springframework.beans.factory.annotation.Qualifier;
|
|
||||||
|
|
||||||
import ca.uhn.fhir.jpa.dao.FulltextSearchSvcImpl.Suggestion;
|
|
||||||
import ca.uhn.fhir.jpa.dao.IFhirSystemDao;
|
|
||||||
import ca.uhn.fhir.jpa.dao.IFulltextSearchSvc;
|
|
||||||
import ca.uhn.fhir.jpa.provider.BaseJpaSystemProviderDstu2Plus;
|
|
||||||
import ca.uhn.fhir.model.api.annotation.Description;
|
|
||||||
import ca.uhn.fhir.rest.annotation.*;
|
|
||||||
import ca.uhn.fhir.rest.api.server.RequestDetails;
|
|
||||||
import ca.uhn.fhir.rest.server.exceptions.InvalidRequestException;
|
|
||||||
import ca.uhn.fhir.rest.server.servlet.ServletRequestDetails;
|
|
||||||
|
|
||||||
public class JpaSystemProviderDstu3 extends BaseJpaSystemProviderDstu2Plus<Bundle, Meta> {
|
public class JpaSystemProviderDstu3 extends BaseJpaSystemProviderDstu2Plus<Bundle, Meta> {
|
||||||
|
|
||||||
@ -45,106 +50,106 @@ public class JpaSystemProviderDstu3 extends BaseJpaSystemProviderDstu2Plus<Bundl
|
|||||||
@Qualifier("mySystemDaoDstu3")
|
@Qualifier("mySystemDaoDstu3")
|
||||||
private IFhirSystemDao<Bundle, Meta> mySystemDao;
|
private IFhirSystemDao<Bundle, Meta> mySystemDao;
|
||||||
|
|
||||||
@Autowired
|
@Autowired(required = false)
|
||||||
private IFulltextSearchSvc mySearchDao;
|
private IFulltextSearchSvc mySearchDao;
|
||||||
|
|
||||||
//@formatter:off
|
//@formatter:off
|
||||||
// This is generated by hand:
|
// This is generated by hand:
|
||||||
// ls hapi-fhir-structures-dstu2/target/generated-sources/tinder/ca/uhn/fhir/model/dstu2/resource/ | sort | sed "s/.java//" | sed "s/^/@OperationParam(name=\"/" | sed "s/$/\", type=IntegerType.class, min=0, max=1),/"
|
// ls hapi-fhir-structures-dstu2/target/generated-sources/tinder/ca/uhn/fhir/model/dstu2/resource/ | sort | sed "s/.java//" | sed "s/^/@OperationParam(name=\"/" | sed "s/$/\", type=IntegerType.class, min=0, max=1),/"
|
||||||
@Operation(name="$get-resource-counts", idempotent=true, returnParameters= {
|
@Operation(name = "$get-resource-counts", idempotent = true, returnParameters = {
|
||||||
@OperationParam(name="AllergyIntolerance", type=IntegerType.class, min=0, max=1),
|
@OperationParam(name = "AllergyIntolerance", type = IntegerType.class, min = 0, max = 1),
|
||||||
@OperationParam(name="Appointment", type=IntegerType.class, min=0, max=1),
|
@OperationParam(name = "Appointment", type = IntegerType.class, min = 0, max = 1),
|
||||||
@OperationParam(name="AppointmentResponse", type=IntegerType.class, min=0, max=1),
|
@OperationParam(name = "AppointmentResponse", type = IntegerType.class, min = 0, max = 1),
|
||||||
@OperationParam(name="AuditEvent", type=IntegerType.class, min=0, max=1),
|
@OperationParam(name = "AuditEvent", type = IntegerType.class, min = 0, max = 1),
|
||||||
@OperationParam(name="Basic", type=IntegerType.class, min=0, max=1),
|
@OperationParam(name = "Basic", type = IntegerType.class, min = 0, max = 1),
|
||||||
@OperationParam(name="Binary", type=IntegerType.class, min=0, max=1),
|
@OperationParam(name = "Binary", type = IntegerType.class, min = 0, max = 1),
|
||||||
@OperationParam(name="BodySite", type=IntegerType.class, min=0, max=1),
|
@OperationParam(name = "BodySite", type = IntegerType.class, min = 0, max = 1),
|
||||||
@OperationParam(name="Bundle", type=IntegerType.class, min=0, max=1),
|
@OperationParam(name = "Bundle", type = IntegerType.class, min = 0, max = 1),
|
||||||
@OperationParam(name="CarePlan", type=IntegerType.class, min=0, max=1),
|
@OperationParam(name = "CarePlan", type = IntegerType.class, min = 0, max = 1),
|
||||||
@OperationParam(name="CarePlan2", type=IntegerType.class, min=0, max=1),
|
@OperationParam(name = "CarePlan2", type = IntegerType.class, min = 0, max = 1),
|
||||||
@OperationParam(name="Claim", type=IntegerType.class, min=0, max=1),
|
@OperationParam(name = "Claim", type = IntegerType.class, min = 0, max = 1),
|
||||||
@OperationParam(name="ClaimResponse", type=IntegerType.class, min=0, max=1),
|
@OperationParam(name = "ClaimResponse", type = IntegerType.class, min = 0, max = 1),
|
||||||
@OperationParam(name="ClinicalImpression", type=IntegerType.class, min=0, max=1),
|
@OperationParam(name = "ClinicalImpression", type = IntegerType.class, min = 0, max = 1),
|
||||||
@OperationParam(name="Communication", type=IntegerType.class, min=0, max=1),
|
@OperationParam(name = "Communication", type = IntegerType.class, min = 0, max = 1),
|
||||||
@OperationParam(name="CommunicationRequest", type=IntegerType.class, min=0, max=1),
|
@OperationParam(name = "CommunicationRequest", type = IntegerType.class, min = 0, max = 1),
|
||||||
@OperationParam(name="Composition", type=IntegerType.class, min=0, max=1),
|
@OperationParam(name = "Composition", type = IntegerType.class, min = 0, max = 1),
|
||||||
@OperationParam(name="ConceptMap", type=IntegerType.class, min=0, max=1),
|
@OperationParam(name = "ConceptMap", type = IntegerType.class, min = 0, max = 1),
|
||||||
@OperationParam(name="Condition", type=IntegerType.class, min=0, max=1),
|
@OperationParam(name = "Condition", type = IntegerType.class, min = 0, max = 1),
|
||||||
@OperationParam(name="Conformance", type=IntegerType.class, min=0, max=1),
|
@OperationParam(name = "Conformance", type = IntegerType.class, min = 0, max = 1),
|
||||||
@OperationParam(name="Contract", type=IntegerType.class, min=0, max=1),
|
@OperationParam(name = "Contract", type = IntegerType.class, min = 0, max = 1),
|
||||||
@OperationParam(name="Contraindication", type=IntegerType.class, min=0, max=1),
|
@OperationParam(name = "Contraindication", type = IntegerType.class, min = 0, max = 1),
|
||||||
@OperationParam(name="Coverage", type=IntegerType.class, min=0, max=1),
|
@OperationParam(name = "Coverage", type = IntegerType.class, min = 0, max = 1),
|
||||||
@OperationParam(name="DataElement", type=IntegerType.class, min=0, max=1),
|
@OperationParam(name = "DataElement", type = IntegerType.class, min = 0, max = 1),
|
||||||
@OperationParam(name="Device", type=IntegerType.class, min=0, max=1),
|
@OperationParam(name = "Device", type = IntegerType.class, min = 0, max = 1),
|
||||||
@OperationParam(name="DeviceComponent", type=IntegerType.class, min=0, max=1),
|
@OperationParam(name = "DeviceComponent", type = IntegerType.class, min = 0, max = 1),
|
||||||
@OperationParam(name="DeviceMetric", type=IntegerType.class, min=0, max=1),
|
@OperationParam(name = "DeviceMetric", type = IntegerType.class, min = 0, max = 1),
|
||||||
@OperationParam(name="DeviceUseRequest", type=IntegerType.class, min=0, max=1),
|
@OperationParam(name = "DeviceUseRequest", type = IntegerType.class, min = 0, max = 1),
|
||||||
@OperationParam(name="DeviceUseStatement", type=IntegerType.class, min=0, max=1),
|
@OperationParam(name = "DeviceUseStatement", type = IntegerType.class, min = 0, max = 1),
|
||||||
@OperationParam(name="DiagnosticOrder", type=IntegerType.class, min=0, max=1),
|
@OperationParam(name = "DiagnosticOrder", type = IntegerType.class, min = 0, max = 1),
|
||||||
@OperationParam(name="DiagnosticReport", type=IntegerType.class, min=0, max=1),
|
@OperationParam(name = "DiagnosticReport", type = IntegerType.class, min = 0, max = 1),
|
||||||
@OperationParam(name="DocumentManifest", type=IntegerType.class, min=0, max=1),
|
@OperationParam(name = "DocumentManifest", type = IntegerType.class, min = 0, max = 1),
|
||||||
@OperationParam(name="DocumentReference", type=IntegerType.class, min=0, max=1),
|
@OperationParam(name = "DocumentReference", type = IntegerType.class, min = 0, max = 1),
|
||||||
@OperationParam(name="EligibilityRequest", type=IntegerType.class, min=0, max=1),
|
@OperationParam(name = "EligibilityRequest", type = IntegerType.class, min = 0, max = 1),
|
||||||
@OperationParam(name="EligibilityResponse", type=IntegerType.class, min=0, max=1),
|
@OperationParam(name = "EligibilityResponse", type = IntegerType.class, min = 0, max = 1),
|
||||||
@OperationParam(name="Encounter", type=IntegerType.class, min=0, max=1),
|
@OperationParam(name = "Encounter", type = IntegerType.class, min = 0, max = 1),
|
||||||
@OperationParam(name="EnrollmentRequest", type=IntegerType.class, min=0, max=1),
|
@OperationParam(name = "EnrollmentRequest", type = IntegerType.class, min = 0, max = 1),
|
||||||
@OperationParam(name="EnrollmentResponse", type=IntegerType.class, min=0, max=1),
|
@OperationParam(name = "EnrollmentResponse", type = IntegerType.class, min = 0, max = 1),
|
||||||
@OperationParam(name="EpisodeOfCare", type=IntegerType.class, min=0, max=1),
|
@OperationParam(name = "EpisodeOfCare", type = IntegerType.class, min = 0, max = 1),
|
||||||
@OperationParam(name="ExplanationOfBenefit", type=IntegerType.class, min=0, max=1),
|
@OperationParam(name = "ExplanationOfBenefit", type = IntegerType.class, min = 0, max = 1),
|
||||||
@OperationParam(name="FamilyMemberHistory", type=IntegerType.class, min=0, max=1),
|
@OperationParam(name = "FamilyMemberHistory", type = IntegerType.class, min = 0, max = 1),
|
||||||
@OperationParam(name="Flag", type=IntegerType.class, min=0, max=1),
|
@OperationParam(name = "Flag", type = IntegerType.class, min = 0, max = 1),
|
||||||
@OperationParam(name="Goal", type=IntegerType.class, min=0, max=1),
|
@OperationParam(name = "Goal", type = IntegerType.class, min = 0, max = 1),
|
||||||
@OperationParam(name="Group", type=IntegerType.class, min=0, max=1),
|
@OperationParam(name = "Group", type = IntegerType.class, min = 0, max = 1),
|
||||||
@OperationParam(name="HealthcareService", type=IntegerType.class, min=0, max=1),
|
@OperationParam(name = "HealthcareService", type = IntegerType.class, min = 0, max = 1),
|
||||||
@OperationParam(name="ImagingObjectSelection", type=IntegerType.class, min=0, max=1),
|
@OperationParam(name = "ImagingObjectSelection", type = IntegerType.class, min = 0, max = 1),
|
||||||
@OperationParam(name="ImagingStudy", type=IntegerType.class, min=0, max=1),
|
@OperationParam(name = "ImagingStudy", type = IntegerType.class, min = 0, max = 1),
|
||||||
@OperationParam(name="Immunization", type=IntegerType.class, min=0, max=1),
|
@OperationParam(name = "Immunization", type = IntegerType.class, min = 0, max = 1),
|
||||||
@OperationParam(name="ImmunizationRecommendation", type=IntegerType.class, min=0, max=1),
|
@OperationParam(name = "ImmunizationRecommendation", type = IntegerType.class, min = 0, max = 1),
|
||||||
@OperationParam(name="ListResource", type=IntegerType.class, min=0, max=1),
|
@OperationParam(name = "ListResource", type = IntegerType.class, min = 0, max = 1),
|
||||||
@OperationParam(name="Location", type=IntegerType.class, min=0, max=1),
|
@OperationParam(name = "Location", type = IntegerType.class, min = 0, max = 1),
|
||||||
@OperationParam(name="Media", type=IntegerType.class, min=0, max=1),
|
@OperationParam(name = "Media", type = IntegerType.class, min = 0, max = 1),
|
||||||
@OperationParam(name="Medication", type=IntegerType.class, min=0, max=1),
|
@OperationParam(name = "Medication", type = IntegerType.class, min = 0, max = 1),
|
||||||
@OperationParam(name="MedicationAdministration", type=IntegerType.class, min=0, max=1),
|
@OperationParam(name = "MedicationAdministration", type = IntegerType.class, min = 0, max = 1),
|
||||||
@OperationParam(name="MedicationDispense", type=IntegerType.class, min=0, max=1),
|
@OperationParam(name = "MedicationDispense", type = IntegerType.class, min = 0, max = 1),
|
||||||
@OperationParam(name="MedicationPrescription", type=IntegerType.class, min=0, max=1),
|
@OperationParam(name = "MedicationPrescription", type = IntegerType.class, min = 0, max = 1),
|
||||||
@OperationParam(name="MedicationStatement", type=IntegerType.class, min=0, max=1),
|
@OperationParam(name = "MedicationStatement", type = IntegerType.class, min = 0, max = 1),
|
||||||
@OperationParam(name="MessageHeader", type=IntegerType.class, min=0, max=1),
|
@OperationParam(name = "MessageHeader", type = IntegerType.class, min = 0, max = 1),
|
||||||
@OperationParam(name="NamingSystem", type=IntegerType.class, min=0, max=1),
|
@OperationParam(name = "NamingSystem", type = IntegerType.class, min = 0, max = 1),
|
||||||
@OperationParam(name="NutritionOrder", type=IntegerType.class, min=0, max=1),
|
@OperationParam(name = "NutritionOrder", type = IntegerType.class, min = 0, max = 1),
|
||||||
@OperationParam(name="Observation", type=IntegerType.class, min=0, max=1),
|
@OperationParam(name = "Observation", type = IntegerType.class, min = 0, max = 1),
|
||||||
@OperationParam(name="OperationDefinition", type=IntegerType.class, min=0, max=1),
|
@OperationParam(name = "OperationDefinition", type = IntegerType.class, min = 0, max = 1),
|
||||||
@OperationParam(name="OperationOutcome", type=IntegerType.class, min=0, max=1),
|
@OperationParam(name = "OperationOutcome", type = IntegerType.class, min = 0, max = 1),
|
||||||
@OperationParam(name="Order", type=IntegerType.class, min=0, max=1),
|
@OperationParam(name = "Order", type = IntegerType.class, min = 0, max = 1),
|
||||||
@OperationParam(name="OrderResponse", type=IntegerType.class, min=0, max=1),
|
@OperationParam(name = "OrderResponse", type = IntegerType.class, min = 0, max = 1),
|
||||||
@OperationParam(name="Organization", type=IntegerType.class, min=0, max=1),
|
@OperationParam(name = "Organization", type = IntegerType.class, min = 0, max = 1),
|
||||||
@OperationParam(name="Parameters", type=IntegerType.class, min=0, max=1),
|
@OperationParam(name = "Parameters", type = IntegerType.class, min = 0, max = 1),
|
||||||
@OperationParam(name="Patient", type=IntegerType.class, min=0, max=1),
|
@OperationParam(name = "Patient", type = IntegerType.class, min = 0, max = 1),
|
||||||
@OperationParam(name="PaymentNotice", type=IntegerType.class, min=0, max=1),
|
@OperationParam(name = "PaymentNotice", type = IntegerType.class, min = 0, max = 1),
|
||||||
@OperationParam(name="PaymentReconciliation", type=IntegerType.class, min=0, max=1),
|
@OperationParam(name = "PaymentReconciliation", type = IntegerType.class, min = 0, max = 1),
|
||||||
@OperationParam(name="Person", type=IntegerType.class, min=0, max=1),
|
@OperationParam(name = "Person", type = IntegerType.class, min = 0, max = 1),
|
||||||
@OperationParam(name="Practitioner", type=IntegerType.class, min=0, max=1),
|
@OperationParam(name = "Practitioner", type = IntegerType.class, min = 0, max = 1),
|
||||||
@OperationParam(name="Procedure", type=IntegerType.class, min=0, max=1),
|
@OperationParam(name = "Procedure", type = IntegerType.class, min = 0, max = 1),
|
||||||
@OperationParam(name="ProcedureRequest", type=IntegerType.class, min=0, max=1),
|
@OperationParam(name = "ProcedureRequest", type = IntegerType.class, min = 0, max = 1),
|
||||||
@OperationParam(name="ProcessRequest", type=IntegerType.class, min=0, max=1),
|
@OperationParam(name = "ProcessRequest", type = IntegerType.class, min = 0, max = 1),
|
||||||
@OperationParam(name="ProcessResponse", type=IntegerType.class, min=0, max=1),
|
@OperationParam(name = "ProcessResponse", type = IntegerType.class, min = 0, max = 1),
|
||||||
@OperationParam(name="Provenance", type=IntegerType.class, min=0, max=1),
|
@OperationParam(name = "Provenance", type = IntegerType.class, min = 0, max = 1),
|
||||||
@OperationParam(name="Questionnaire", type=IntegerType.class, min=0, max=1),
|
@OperationParam(name = "Questionnaire", type = IntegerType.class, min = 0, max = 1),
|
||||||
@OperationParam(name="QuestionnaireAnswers", type=IntegerType.class, min=0, max=1),
|
@OperationParam(name = "QuestionnaireAnswers", type = IntegerType.class, min = 0, max = 1),
|
||||||
@OperationParam(name="ReferralRequest", type=IntegerType.class, min=0, max=1),
|
@OperationParam(name = "ReferralRequest", type = IntegerType.class, min = 0, max = 1),
|
||||||
@OperationParam(name="RelatedPerson", type=IntegerType.class, min=0, max=1),
|
@OperationParam(name = "RelatedPerson", type = IntegerType.class, min = 0, max = 1),
|
||||||
@OperationParam(name="RiskAssessment", type=IntegerType.class, min=0, max=1),
|
@OperationParam(name = "RiskAssessment", type = IntegerType.class, min = 0, max = 1),
|
||||||
@OperationParam(name="Schedule", type=IntegerType.class, min=0, max=1),
|
@OperationParam(name = "Schedule", type = IntegerType.class, min = 0, max = 1),
|
||||||
@OperationParam(name="SearchParameter", type=IntegerType.class, min=0, max=1),
|
@OperationParam(name = "SearchParameter", type = IntegerType.class, min = 0, max = 1),
|
||||||
@OperationParam(name="Slot", type=IntegerType.class, min=0, max=1),
|
@OperationParam(name = "Slot", type = IntegerType.class, min = 0, max = 1),
|
||||||
@OperationParam(name="Specimen", type=IntegerType.class, min=0, max=1),
|
@OperationParam(name = "Specimen", type = IntegerType.class, min = 0, max = 1),
|
||||||
@OperationParam(name="StructureDefinition", type=IntegerType.class, min=0, max=1),
|
@OperationParam(name = "StructureDefinition", type = IntegerType.class, min = 0, max = 1),
|
||||||
@OperationParam(name="Subscription", type=IntegerType.class, min=0, max=1),
|
@OperationParam(name = "Subscription", type = IntegerType.class, min = 0, max = 1),
|
||||||
@OperationParam(name="Substance", type=IntegerType.class, min=0, max=1),
|
@OperationParam(name = "Substance", type = IntegerType.class, min = 0, max = 1),
|
||||||
@OperationParam(name="Supply", type=IntegerType.class, min=0, max=1),
|
@OperationParam(name = "Supply", type = IntegerType.class, min = 0, max = 1),
|
||||||
@OperationParam(name="ValueSet", type=IntegerType.class, min=0, max=1),
|
@OperationParam(name = "ValueSet", type = IntegerType.class, min = 0, max = 1),
|
||||||
@OperationParam(name="VisionPrescription", type=IntegerType.class, min=0, max=1)
|
@OperationParam(name = "VisionPrescription", type = IntegerType.class, min = 0, max = 1)
|
||||||
})
|
})
|
||||||
@Description(shortDefinition="Provides the number of resources currently stored on the server, broken down by resource type")
|
@Description(shortDefinition = "Provides the number of resources currently stored on the server, broken down by resource type")
|
||||||
//@formatter:on
|
//@formatter:on
|
||||||
public Parameters getResourceCounts() {
|
public Parameters getResourceCounts() {
|
||||||
Parameters retVal = new Parameters();
|
Parameters retVal = new Parameters();
|
||||||
@ -159,8 +164,8 @@ public class JpaSystemProviderDstu3 extends BaseJpaSystemProviderDstu2Plus<Bundl
|
|||||||
}
|
}
|
||||||
|
|
||||||
//@formatter:off
|
//@formatter:off
|
||||||
@Operation(name="$meta", idempotent=true, returnParameters= {
|
@Operation(name = "$meta", idempotent = true, returnParameters = {
|
||||||
@OperationParam(name="return", type=Meta.class)
|
@OperationParam(name = "return", type = Meta.class)
|
||||||
})
|
})
|
||||||
//@formatter:on
|
//@formatter:on
|
||||||
public Parameters meta(RequestDetails theRequestDetails) {
|
public Parameters meta(RequestDetails theRequestDetails) {
|
||||||
@ -169,12 +174,13 @@ public class JpaSystemProviderDstu3 extends BaseJpaSystemProviderDstu2Plus<Bundl
|
|||||||
return parameters;
|
return parameters;
|
||||||
}
|
}
|
||||||
|
|
||||||
@Operation(name="$suggest-keywords", idempotent=true)
|
@Operation(name = "$suggest-keywords", idempotent = true)
|
||||||
public Parameters suggestKeywords(
|
public Parameters suggestKeywords(
|
||||||
@OperationParam(name="context", min=1, max=1) String theContext,
|
@OperationParam(name = "context", min = 1, max = 1) String theContext,
|
||||||
@OperationParam(name="searchParam", min=1, max=1) String theSearchParam,
|
@OperationParam(name = "searchParam", min = 1, max = 1) String theSearchParam,
|
||||||
@OperationParam(name="text", min=1, max=1) String theText
|
@OperationParam(name = "text", min = 1, max = 1) String theText
|
||||||
) {
|
) {
|
||||||
|
JpaSystemProviderDstu3.validateFulltextSearchEnabled(mySearchDao);
|
||||||
|
|
||||||
if (isBlank(theContext)) {
|
if (isBlank(theContext)) {
|
||||||
throw new InvalidRequestException("Parameter 'context' must be provided");
|
throw new InvalidRequestException("Parameter 'context' must be provided");
|
||||||
@ -192,8 +198,8 @@ public class JpaSystemProviderDstu3 extends BaseJpaSystemProviderDstu2Plus<Bundl
|
|||||||
for (Suggestion next : keywords) {
|
for (Suggestion next : keywords) {
|
||||||
//@formatter:off
|
//@formatter:off
|
||||||
retVal.addParameter()
|
retVal.addParameter()
|
||||||
.addPart(new ParametersParameterComponent().setName("keyword").setValue(new StringType(next.getTerm())))
|
.addPart(new ParametersParameterComponent().setName("keyword").setValue(new StringType(next.getTerm())))
|
||||||
.addPart(new ParametersParameterComponent().setName("score").setValue(new DecimalType(next.getScore())));
|
.addPart(new ParametersParameterComponent().setName("score").setValue(new DecimalType(next.getScore())));
|
||||||
//@formatter:on
|
//@formatter:on
|
||||||
}
|
}
|
||||||
|
|
||||||
@ -210,4 +216,10 @@ public class JpaSystemProviderDstu3 extends BaseJpaSystemProviderDstu2Plus<Bundl
|
|||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
|
public static void validateFulltextSearchEnabled(IFulltextSearchSvc theSearchDao) {
|
||||||
|
if (theSearchDao == null || theSearchDao.isDisabled()) {
|
||||||
|
throw new InvalidRequestException("Fulltext searching is disabled on this server");
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
}
|
}
|
||||||
|
@ -120,7 +120,7 @@ public abstract class BaseJpaDstu2Test extends BaseJpaTest {
|
|||||||
protected Object myResourceProviders;
|
protected Object myResourceProviders;
|
||||||
@Autowired
|
@Autowired
|
||||||
protected ISearchCoordinatorSvc mySearchCoordinatorSvc;
|
protected ISearchCoordinatorSvc mySearchCoordinatorSvc;
|
||||||
@Autowired
|
@Autowired(required = false)
|
||||||
protected IFulltextSearchSvc mySearchDao;
|
protected IFulltextSearchSvc mySearchDao;
|
||||||
@Autowired
|
@Autowired
|
||||||
protected ISearchParamPresenceSvc mySearchParamPresenceSvc;
|
protected ISearchParamPresenceSvc mySearchParamPresenceSvc;
|
||||||
|
@ -172,7 +172,7 @@ public abstract class BaseJpaDstu3Test extends BaseJpaTest {
|
|||||||
protected IResourceTagDao myResourceTagDao;
|
protected IResourceTagDao myResourceTagDao;
|
||||||
@Autowired
|
@Autowired
|
||||||
protected ISearchCoordinatorSvc mySearchCoordinatorSvc;
|
protected ISearchCoordinatorSvc mySearchCoordinatorSvc;
|
||||||
@Autowired
|
@Autowired(required = false)
|
||||||
protected IFulltextSearchSvc mySearchDao;
|
protected IFulltextSearchSvc mySearchDao;
|
||||||
@Autowired
|
@Autowired
|
||||||
protected ISearchDao mySearchEntityDao;
|
protected ISearchDao mySearchEntityDao;
|
||||||
|
@ -181,7 +181,7 @@ public abstract class BaseJpaR4Test extends BaseJpaTest {
|
|||||||
protected IResourceTagDao myResourceTagDao;
|
protected IResourceTagDao myResourceTagDao;
|
||||||
@Autowired
|
@Autowired
|
||||||
protected ISearchCoordinatorSvc mySearchCoordinatorSvc;
|
protected ISearchCoordinatorSvc mySearchCoordinatorSvc;
|
||||||
@Autowired
|
@Autowired(required = false)
|
||||||
protected IFulltextSearchSvc mySearchDao;
|
protected IFulltextSearchSvc mySearchDao;
|
||||||
@Autowired
|
@Autowired
|
||||||
protected ISearchDao mySearchEntityDao;
|
protected ISearchDao mySearchEntityDao;
|
||||||
|
7
pom.xml
7
pom.xml
@ -1646,7 +1646,6 @@
|
|||||||
<artifactId>maven-scm-api</artifactId>
|
<artifactId>maven-scm-api</artifactId>
|
||||||
<version>1.9.5</version>
|
<version>1.9.5</version>
|
||||||
</dependency>
|
</dependency>
|
||||||
<!-- <dependency> <groupId>org.apache.maven.doxia</groupId> <artifactId>doxia-core</artifactId> <version>1.7</version> </dependency> -->
|
|
||||||
<dependency>
|
<dependency>
|
||||||
<groupId>org.apache.maven.doxia</groupId>
|
<groupId>org.apache.maven.doxia</groupId>
|
||||||
<artifactId>doxia-module-markdown</artifactId>
|
<artifactId>doxia-module-markdown</artifactId>
|
||||||
@ -1686,17 +1685,11 @@
|
|||||||
</execution>
|
</execution>
|
||||||
</executions>
|
</executions>
|
||||||
</plugin>
|
</plugin>
|
||||||
<!-- <plugin> <groupId>com.github.github</groupId> <artifactId>site-maven-plugin</artifactId> <version>0.12</version> <configuration> <message>Building site for ${project.version}</message> <server>github</server>
|
|
||||||
</configuration> <executions> <execution> <goals> <goal>site</goal> </goals> <phase>site-deploy</phase> </execution> </executions> </plugin> -->
|
|
||||||
</plugins>
|
</plugins>
|
||||||
</build>
|
</build>
|
||||||
|
|
||||||
<reporting>
|
<reporting>
|
||||||
<plugins>
|
<plugins>
|
||||||
<!-- <plugin> <groupId>org.apache.maven.plugins</groupId> <artifactId>maven-checkstyle-plugin</artifactId> <reportSets> <reportSet> <reports><report>checkstyle-aggregate</report></reports> </reportSet>
|
|
||||||
</reportSets> <configuration> <configLocation>config/sun_checks.xml</configLocation> <includes> hapi-fhir-base/src/main/java/**/*.java </includes> </configuration> </plugin> -->
|
|
||||||
<!-- <plugin> <groupId>org.jacoco</groupId> <artifactId>jacoco-maven-plugin</artifactId> <version>0.7.7.201606060606</version> <reportSets> <reportSet> <reports> <report>report</report> </reports> <configuration>
|
|
||||||
<dataFileIncludes>${baseDir}/hapi-fhir-base/target/jacoco.exec</dataFileIncludes> </configuration> </reportSet> </reportSets> </plugin> -->
|
|
||||||
<plugin>
|
<plugin>
|
||||||
<groupId>org.apache.maven.plugins</groupId>
|
<groupId>org.apache.maven.plugins</groupId>
|
||||||
<artifactId>maven-changes-plugin</artifactId>
|
<artifactId>maven-changes-plugin</artifactId>
|
||||||
|
@ -7,6 +7,17 @@
|
|||||||
</properties>
|
</properties>
|
||||||
<body>
|
<body>
|
||||||
<release version="3.1.0" date="TBD">
|
<release version="3.1.0" date="TBD">
|
||||||
|
<action type="fix">
|
||||||
|
The Android client module has been restored to working order, and no longer
|
||||||
|
requires a special classifier or an XML parser to be present in order to
|
||||||
|
work. This means that the hapi-fhir-android library is much less likely
|
||||||
|
to cause conflicts with other libraries imported into an Android application
|
||||||
|
via Gradle.
|
||||||
|
<![CDATA[<br/><br/>]]>
|
||||||
|
See the
|
||||||
|
<![CDATA[<a href="http://hapifhir.io/doc_android.html">HAPI FHIR Android Documentation</a>]]>
|
||||||
|
for more information.
|
||||||
|
</action>
|
||||||
<action type="add">
|
<action type="add">
|
||||||
A performance to the JPA server has been made which reduces the number
|
A performance to the JPA server has been made which reduces the number
|
||||||
of writes to index tables when updating a resource with contents that
|
of writes to index tables when updating a resource with contents that
|
||||||
|
@ -11,16 +11,32 @@
|
|||||||
<section name="Android Client Development">
|
<section name="Android Client Development">
|
||||||
|
|
||||||
<p>
|
<p>
|
||||||
HAPI now has a specially built binary (JAR) which can be used on Android. Android developers
|
HAPI now has a specially built module for use on Android. Android developers
|
||||||
may use this JAR to take advantage of the FHIR model classes, and the FHIR client (running a FHIR server
|
may use this JAR to take advantage of the FHIR model classes, and the FHIR client (running a FHIR server
|
||||||
on Android is not yet supported. Help wanted!)
|
on Android is not yet supported. Get in touch if this is something you are interested in working on!)
|
||||||
</p>
|
</p>
|
||||||
|
|
||||||
<p>
|
<p>
|
||||||
The Android JAR ships as a "shade JAR", meaning it is a single JAR containing all of the
|
As of HAPI FHIR 3.1.0, the <code>hapi-fhir-android</code> module has been streamlined in order
|
||||||
dependencies required in order to use HAPI FHIR. You should not need to include any other
|
to reduce its footprint. Previous versions of the library included both an XML and a JSON parser
|
||||||
libraries.
|
but this has been streamlined to only include JSON support in order to reduce the number of
|
||||||
|
libraries required in an Android build.
|
||||||
</p>
|
</p>
|
||||||
|
|
||||||
|
<p>
|
||||||
|
When using the HAPI FHIR Android client, the client will request only JSON responses
|
||||||
|
(via the HTTP <code>Accept</code> header) and will not be able to communicate
|
||||||
|
with FHIR servers that support only XML encoding (few, if any, servers actually exist
|
||||||
|
with this limitation that we are aware of).
|
||||||
|
</p>
|
||||||
|
|
||||||
|
<p>
|
||||||
|
The Android client also uses the <code>hapi-fhir-client-okhttp</code> module,
|
||||||
|
which is an HTTP client based on the OkHttp library. This library has proven to be
|
||||||
|
more powerful and less likely to cause issues on Android than the Apache HttpClient
|
||||||
|
implementation which is bundled by default.
|
||||||
|
</p>
|
||||||
|
|
||||||
<p>
|
<p>
|
||||||
Note that the Android JAR is still new and hasn't received as much testing as other
|
Note that the Android JAR is still new and hasn't received as much testing as other
|
||||||
parts of the library. We would greatly appreciate feedback, testing, etc. Also note that
|
parts of the library. We would greatly appreciate feedback, testing, etc. Also note that
|
||||||
@ -34,24 +50,32 @@
|
|||||||
<subsection name="Get the Android JAR">
|
<subsection name="Get the Android JAR">
|
||||||
|
|
||||||
<p>
|
<p>
|
||||||
To add the HAPI library via Gradle, use the following
|
To add the HAPI library via Gradle, you should add the
|
||||||
dependency. Note the following things:
|
<a href="http://search.maven.org/#search%7Cga%7C1%7Chapi-fhir-android">hapi-fhir-android</a>
|
||||||
|
library to your Gradle file, as well as a structures library for the appropriate
|
||||||
|
version of FHIR that you want to support, e.g.
|
||||||
|
<a href="http://search.maven.org/#search%7Cga%7C1%7Chapi-fhir-structures">hapi-fhir-structures-dstu3</a>.
|
||||||
</p>
|
</p>
|
||||||
<ul>
|
|
||||||
<li>The classifier should be set to the version of FHIR you want to support.</li>
|
|
||||||
<li>
|
|
||||||
You need to excluded a few things in order to get this to work. This is
|
|
||||||
a quirk because the way HAPI is built and will hopefully be resolved in a future
|
|
||||||
release.
|
|
||||||
</li>
|
|
||||||
</ul>
|
|
||||||
<source><![CDATA[dependencies {
|
<source><![CDATA[dependencies {
|
||||||
compile "ca.uhn.hapi.fhir:hapi-fhir-android:2.2:dstu2@jar"
|
compile "ca.uhn.hapi.fhir:hapi-fhir-android:3.1.0-SNAPSHOT"
|
||||||
|
compile "ca.uhn.hapi.fhir:hapi-fhir-structures-dstu2:3.1.0-SNAPSHOT"
|
||||||
}]]></source>
|
}]]></source>
|
||||||
|
|
||||||
<p>
|
<p>
|
||||||
You may also download a copy from the GitHub
|
Uou will also need to manually exclude the Woodstox StAX library from
|
||||||
<a href="https://github.com/jamesagnew/hapi-fhir/releases">Releases</a> page.
|
inclusion, as this library uses namespaces which are prohibited on Android. You should also
|
||||||
|
exclude
|
||||||
|
</p>
|
||||||
|
<source><![CDATA[configurations {
|
||||||
|
all*.exclude group: 'org.codehaus.woodstox'
|
||||||
|
all*.exclude group: 'org.apache.httpcomponents'
|
||||||
|
}</source>
|
||||||
|
|
||||||
|
<p>
|
||||||
|
To see a sample Gradle file for a working Android project
|
||||||
|
using HAPI FHIR, see the
|
||||||
|
<a href="https://github.com/hapifhir/hapi-fhir-android-integration-test">Android Integration Test</a>
|
||||||
|
project.
|
||||||
</p>
|
</p>
|
||||||
</subsection>
|
</subsection>
|
||||||
</section>
|
</section>
|
||||||
@ -59,7 +83,7 @@
|
|||||||
<section name="Performance">
|
<section name="Performance">
|
||||||
<p>
|
<p>
|
||||||
On mobile devices, performance problems are particularly noticeable. This
|
On mobile devices, performance problems are particularly noticeable. This
|
||||||
is made worse by the fact that some Android devices have much slower performance
|
is made worse by the fact that some economy Android devices have much slower performance
|
||||||
than modern desktop computers. See the
|
than modern desktop computers. See the
|
||||||
<a href="./doc_rest_client_http_config.html#performance">Client Configuration Performance</a>
|
<a href="./doc_rest_client_http_config.html#performance">Client Configuration Performance</a>
|
||||||
page for some tips on how to improve client performance.
|
page for some tips on how to improve client performance.
|
||||||
|
Loading…
x
Reference in New Issue
Block a user