11 releases (7 breaking)

0.8.0 Mar 9, 2021
0.6.1 Dec 20, 2020
0.5.1 Nov 16, 2020

#3 in #client-instance


Used in orthanc-cli

Unlicense

97KB
2K SLoC

crate doc test codecov license

orthanc-rs

orthanc-rs is a client for the REST API of Orthanc, an open-source, lightweight DICOM server.

Compatibility

Supported Orthanc versions are 1.6.x, 1.7.x, 1.8.x, 1.9.x.

Installation

To use the crate, add the dependency to your Cargo.toml:

[dependencies]
orthanc = "0.8.0"

Usage

Create an API client instance:

use orthanc::Client;
let client = Client::new("http://localhost:8042");

If authentication is enabled on the Orthanc instance:

client.auth("username", "password");

List patients:

client.patients();

Or in an expanded format:

client.patients_expanded();

Get all DICOM tags of an instance:

let instance_id = "0b62ebce-8ab7b938-e5ca1b05-04802ab3-42ee4307";
let tags = client.instance_tags(instance_id);
println!("{}", tags["PatientID"]);

Download a study:

let study_id = "9357491d-427a6c94-4080b6c8-1997f4aa-af658240";
let mut file = fs::File::create("/tmp/study.zip").unwrap();
client.study_dicom(study_id, &mut file).unwrap();

Even though the operation is not very efficient, Orthanc allows uploading DICOM files over REST API:

let data = fs::read("/tmp/instance.dcm").unwrap();
client.upload(&data).unwrap();

See tests directory for more usage examples.

Tests

orthanc-rs is covered by unit as well as integration and end-to-end tests.

To run all tests execute

$ make start_services && make test

Running specific test suits separately is described below.

Unit

To run unit tests execute

$ make unit_test

Integration

To run unit tests execute

$ make integration_test

End-to-end

Install docker-compose and jq and execute

$ make start_services && make e2e_test

This will spin up all the necessary services required for integration tests, and run the tests.

During and after the test run Orthanc web UI is available at http://localhost:8028 (username: orthanc, password: orthanc).

Containers started by start_services are left running after the test is finished. To stop them execute

$ make stop_services

TODO

  • Instance images (/instances/<id>/{preview,image-uint8,image-uint16})
  • Split/merge studies (/studies/<id>/{split,merge})
  • Tools API (/tools)
  • Log API (/changes, /exports)
  • Asynchronous requests (/jobs)

Dependencies

~5–10MB
~180K SLoC