FHIR Client
Ruby FHIR client.
Supports:
- FHIR R5, R4B, R4, STU3 and DSTU2
- JSON and XML
- All CRUD, including version read and history
- Transactions and Batches
- Search
- Operations (e.g.
$everything
, $validate
) - Support for OAuth2
Getting Started
$ bundle install
$ bundle exec rake fhir:console
Creating a Client
client = FHIR::Client.new(url)
This client supports two modes of operation: basic and advanced. The basic mode is useful for simple operations
because it promotes an ActiveRecord-like style of interaction. The advanced mode is less developer-friendly, but is currently necessary if you would like to use the entire range of operations exposed by FHIR.
Basic Usage
Associate the client with the model:
FHIR::Model.client = client
The FHIR models can now be used to directly interact with a FHIR server.
patient = FHIR::Patient.read('example')
patient.gender = 'female'
patient.update
patient = FHIR::Patient.create(name: {given: 'John', family: 'Doe'})
patient = FHIR::Patient.new(name: {given: 'John', family: 'Doe'}).create({Prefer: "return=representation"})
results = FHIR::Patient.search(given: 'John', family: 'Doe')
results.count
patient.destroy
Advanced Usage
Changing FHIR Versions
The client defaults to R4
but can be switched to other versions. It can also attempt to autodetect the FHIR version based on the metadata
endpoint.
client = FHIR::Client.new(url)
version = client.detect_version
if version == :stu3
puts 'FHIR Client using STU3'
elsif version == :dstu2
puts 'FHIR Client using DSTU2'
elsif version == :r4
puts 'FHIR Client using R4'
elsif version == :r4b
puts 'FHIR Client using R4B'
elsif
puts 'FHIR Client using R5'
end
client.use_r4
patient = FHIR::Patient.read('example')
patient = client.read(FHIR::Patient, 'example').resource
client.use_stu3
patient = FHIR::STU3::Patient.read('example')
patient = client.read(FHIR::STU3::Patient, 'example').resource
client.use_dstu2
patient = FHIR::DSTU2::Patient.read('example')
patient = client.read(FHIR::DSTU2::Patient, 'example').resource
Changing FHIR Formats
The client defaults to json
representation of resources but can be switched to xml
representations.
client = FHIR::Client.new(url)
client.default_xml
client.default_json
Configuration
You can specify additional properties for the client
:
client.additional_headers = {Prefer: 'return=representation'}
client.proxy = 'https://your-proxy.com/'
CRUD Examples
patient = client.read(FHIR::Patient, "example").resource
patient = client.read(FHIR::Patient, "example", FHIR::Formats::FeedFormat::FEED_JSON).resource
patient = FHIR::Patient.new
patient_id = client.create(patient).id
patient.gender = 'female'
client.update(patient, patient_id)
p_identifier = FHIR::Identifier.new
p_identifier.use = 'official'
p_identifier.system = 'http://projectcrucible.org'
p_identifier.value = '123'
patient.identifier = [ p_identifier ]
searchParams = { :identifier => 'http://projectcrucible.org|123' }
client.conditional_update(patient, patient_id, searchParams)
ifNoneExist = { :identifier => 'http://projectcrucible.org|123' }
client.conditional_create(patient, ifNoneExist)
client.destroy(FHIR::Patient, patient_id)
Searching
reply = client.search(FHIR::Patient, search: {parameters: {name: 'P'}})
reply = client.search(FHIR::Patient, search: {body: {name: 'P'}})
bundle = reply.resource
patient = bundle&.entry&.first&.resource
Fetching a Bundle
reply = client.read_feed(FHIR::Patient)
bundle = reply.resource
bundle.entry.each do |entry|
patient = entry.resource
puts patient.name[0].text
end
puts reply.code
puts reply.body
Transactions
@patient = FHIR::Patient.new
@patient.id = 'temporary_id'
@observation = FHIR::Observation.new
@observation.status = 'final'
@coding = FHIR::Coding.new
@coding.system = 'http://loinc.org'
@coding.code='8302-2'
@observation.code = FHIR::CodeableConcept.new
@observation.code.coding = [ @coding ]
@quantity = FHIR::Quantity.new
@quantity.value = 170
@quantity.unit = 'cm'
@quantity.system = 'http://unitsofmeasure.org'
@observation.valueQuantity = @quantity
@reference = FHIR::Reference.new
@reference.reference = "Patient/#{@patient.id}"
@observation.subject = @reference
@client.begin_transaction
@client.add_transaction_request('POST',nil,@patient)
@client.add_transaction_request('POST',nil,@observation)
reply = @client.end_transaction
OAuth2 Support
client = FHIR::Client.new(url)
client_id = 'example'
client_secret = 'secret'
options = client.get_oauth2_metadata_from_conformance
if options.empty?
puts 'This server does not support the expected OAuth2 extensions.'
else
client.set_oauth2_auth(client_id, client_secret, options[:authorize_url] ,options[:token_url], options[:site])
reply = client.read_feed(FHIR::Patient)
puts reply.body
end
License
Copyright 2014-2022 The MITRE Corporation
Licensed 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.