Skip to content
/ adit Public
forked from openradx/adit

ADIT (Automated DICOM Transfer) is a swiss army knife to exchange DICOM data between various systems by using a convenient web frontend.

License

Notifications You must be signed in to change notification settings

CCI-Bonn/adit

 
 

Folders and files

NameName
Last commit message
Last commit date

Latest commit

 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 

Repository files navigation

ADIT

About

ADIT (Automated DICOM Transfer) is a Swiss army knife to exchange DICOM data between various systems by using a convenient web frontend.

Features

  • Transfer DICOM data between DICOM-compatible servers
  • Download DICOM data to a specified folder
  • Pseudonymize DICOM data on the fly
  • Specify a trial name for the transferred data (stored in the DICOM header)
  • Easy web interface to select which studies to transfer or download
  • Upload a batch file to make multiple queries on a DICOM server
  • Upload a batch file to transfer or download multiple studies
  • A REST API and API client to manage transfers programmatically by an external script (see below)
  • Define when transfers should happen (for example, more workers at night to reduce server load on a PACS)
  • Fine-grained control of what users can or can't do and what they can access
  • Help modals with detailed information for the most important features

Upcoming features

  • An upload portal to upload DICOM images through a web interface that can be pseudonymized on the client (before the transfer happens)

API Client

ADIT Client is a Python library to query, retrieve and upload DICOM images programmatically from a Python script. Thereby it can interact with DICOM (e.g. PACS) servers connected to an ADIT server.

Screenshots

Screenshot1

Screenshot2

Screenshot3

Screenshot4

Screenshot5

Architectural overview

The backend of ADIT is built using the Django web framework, and data is stored in a PostgreSQL database. For DICOM transfer pynetdicom of the pydicom project is used.

A transfer job contains one or more transfer tasks that describe what studies or series to transfer. A task contains how to transfer it (source, destination, pseudonym). A transfer task is processed by a background worker running in its own Docker container and that is constantly polling queued pending tasks from the database.

When the DICOM data to transfer needs to be modified (e.g. pseudonymized) it is downloaded temporarily to the ADIT web server, then transformed and uploaded to the destination server resp. moved to the destination folder.

Downloading data from a DICOM server can done by using a DIMSE operation or by using DICOMweb REST calls. When using DIMSE operations C-GET is prioritized over C-MOVE as a worker can fetch the DICOM data directly from the server. When downloading data using a C-MOVE operation, ADIT commands the source DICOM server to send the data to a C-STORE SCP server of ADIT running in a separate container (Receiver) that receives the DICOM data and sends it back to the worker using a TCP Socket connection (FileTransmitter).

Contributors

medihack mdebic hummerichsander

Disclaimer

ADIT is not a certified medical product. So use at your own risk.

License

  • AGPL 3.0 or later

About

ADIT (Automated DICOM Transfer) is a swiss army knife to exchange DICOM data between various systems by using a convenient web frontend.

Resources

License

Stars

Watchers

Forks

Releases

No releases published

Packages

No packages published

Languages

  • Python 87.3%
  • HTML 8.8%
  • Jupyter Notebook 2.5%
  • Other 1.4%