blob: 9da94b14d81754c4e1490963d842cd742baf9483 [file] [log] [blame]
/*
* Licensed to the Apache Software Foundation (ASF) under one or more
* contributor license agreements. See the NOTICE file distributed with
* this work for additional information regarding copyright ownership.
* The ASF licenses this file to You under the Apache License, Version 2.0
* (the "License"); you may not use this file except in compliance with
* the License. You may obtain a copy of the License at
*
* http://www.apache.org/licenses/LICENSE-2.0
*
* Unless required by applicable law or agreed to in writing, software
* distributed under the License is distributed on an "AS IS" BASIS,
* WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
* See the License for the specific language governing permissions and
* limitations under the License.
*/
package org.apache.camel.example.fhir.osgi;
import ca.uhn.hl7v2.HL7Exception;
import ca.uhn.hl7v2.model.v24.message.ORU_R01;
import ca.uhn.hl7v2.model.v24.segment.PID;
import org.apache.camel.LoggingLevel;
import org.apache.camel.builder.RouteBuilder;
import org.apache.http.ProtocolException;
import org.hl7.fhir.dstu3.model.Patient;
public class FhirRoute extends RouteBuilder {
@Override
public void configure() {
from("file:{{input}}").routeId("fhir-example-osgi")
.onException(ProtocolException.class)
.handled(true)
.log(LoggingLevel.ERROR, "Error connecting to FHIR server with URL:{{serverUrl}}, "
+ "please check the org.apache.camel.example.fhir.osgi.configuration.cfg configuration file ${exception.message}")
.end()
.onException(HL7Exception.class)
.handled(true)
.log(LoggingLevel.ERROR, "Error unmarshalling ${file:name} ${exception.message}")
.end()
.log("Converting ${file:name}")
// unmarshall file to hl7 message
.unmarshal().hl7()
// very simple mapping from a HLV2 patient to dstu3 patient
.process(exchange -> {
ORU_R01 msg = exchange.getIn().getBody(ORU_R01.class);
final PID pid = msg.getPATIENT_RESULT().getPATIENT().getPID();
String surname = pid.getPatientName()[0].getFamilyName().getFn1_Surname().getValue();
String name = pid.getPatientName()[0].getGivenName().getValue();
String patientId = msg.getPATIENT_RESULT().getPATIENT().getPID().getPatientID().getCx1_ID().getValue();
Patient patient = new Patient();
patient.addName().addGiven(name);
patient.getNameFirstRep().setFamily(surname);
patient.setId(patientId);
exchange.getIn().setBody(patient);
})
// marshall to JSON for logging
.marshal().fhirJson("{{fhirVersion}}")
.log("Inserting Patient: ${body}")
// create Patient in our FHIR server
.to("fhir://create/resource?inBody=resourceAsString&serverUrl={{serverUrl}}&fhirVersion={{fhirVersion}}")
// log the outcome
.log("Patient created successfully: ${body.getCreated}");
}
}