Contributing to Orthanc

Note

Here are the main features we would like to get soon implemented as free and open-source code in the Orthanc ecosystem. To make this happen, we need your financial support!

  • Orthanc Core:
  • Stone Web viewer:
    • Save/load annotations
    • Internationalization/translations
    • MPR volume rendering
    • Viewer dedicated to nuclear medicine and radiotherapy
    • Rendering of DICOM GSPS
  • Plugins:
    • Support of ODBC driver (notably for MSSQL databases)
    • Worklist plugin to interface with REST API, HL7 or Mirth

Please get in touch with Osimis if you want to sponsor these developments.

If you find Orthanc useful and wish to contribute to its development, here are some tasks you can take in charge that would greatly help us:

  • Non-coding tasks:
  • Maintenance tasks:
    • Report problems together with sample DICOM images and possible workarounds on the dedicated issue tracker.
    • Package Orthanc and its associated plugins for more UNIX or GNU/Linux distributions (e.g. Ubuntu PPA, RHEL/EPEL, CentOS, openSUSE...).
    • Take ownership of the now-orphaned Fedora package.
    • Take care of Debian/Ubuntu backporting.
    • Share your maintenance scripts or sample code inside the “Orthanc Contributed” public GitHub repository, via pull requests.
    • Help with the integration of Orthanc together with our friend free and open-source projects, notably GNU Health, but also OpenEMR, GNUmed...
  • Coding tasks:
    • The Orthanc project will happily accept patches in the core of Orthanc and in its associated official plugins. Please read the dedicated FAQ entry.
    • Interface Orthanc with other software (e.g. 3D Slicer, Matlab/Octave, Python, Horos, dicompyler...). Check the already supported frameworks.
    • Develop C/C++/Python plugins extending the Orthanc core. Here are some ideas of possible plugins:
      • Create a more advanced Web interface than the built-in Orthanc Explorer.
      • Extend the sample modality worklist plugin so that it manages the worklists (i.e. add/remove items) with a REST API or HL7 messages, instead of reading them from some folder on the filesystem.
      • Conversion to/from NIfTI and/or BIDS, notably for neuroimaging.
      • Encapsulate a video into a DICOM file by calling some REST route, similarly to the /tools/create-dicom route to encapsulate PDF.
      • Similarly to video and PDF (cf. item above), wrap/unwrap a STL (3D mesh) to/from a DICOM file by calling some REST route. This is notably useful for dentistry (dental implants) or orthopaedics, yet even cutting-edge research about 3D-printing of organs. In complement, provide a FreeCAD extension to import/export such STL files from/to Orthanc.
      • Create a plugin to edit DICOM files (add, update or remove DICOM tags).
      • Create samples of Python plugins to take care of HL7 messages, especially for merging patients (which is a typical HL7 event to be handled by the PACS, not by the RIS). Reference: Events Axx of Chapter 3 (“Patient Administration”) in the HL7 v2.9 specification.
      • Create a DICOM proxy (to share a single connection on a PACS by several DICOM clients/viewers), or a DICOMweb proxy (to turn a DICOM-only PACS into a DICOMweb server). This could be done as a Python plugin by wrapping the C-FIND and C-MOVE callbacks in the Python API.
      • Have a look at the TODO file containing our official roadmap.
    • Always remember that he recommended way of contributing to the source code of Orthanc is by creating C/C++/Python plugins, or by creating external software that use the REST API. If the current plugin SDK is insufficient for you to develop some feature as a plugin, do not hesitate to request an extension to the Orthanc SDK on the mailing list.
  • Financial support: