Skip to content

sscotti/MWL_PDF_OrthancDemo

Folders and files

NameName
Last commit message
Last commit date

Latest commit

 

History

41 Commits
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 

Repository files navigation

TO BUILD:

  1. Clone the directory. The default setup is for "SslEnabled" : false and "DicomTlsEnabled" : false so you don't have to mess too much with certificates, but you still need to do steps 4-6.
  2. Copy sample.env to .env and configure. The defaults are probably OK, but if you want to receive e-mails using that feature you'll need to add your own maileserver credentials: PYTHON_EMAIL_HOST, PYTHON_EMAIL_USER, PYTHON_EMAIL_PASS, PYTHON_EMAIL_FRO, PYTHON_EMAIL_TO
  3. Copy sample.env_pacs to .env_pacs and configure.
  4. Use 'sh generate-tls.sh' file in the tls folder to create some server-crt.pem and server-key.pem files for SSL if you want to use that.
  5. Copy the generated crt and key to orthanc.crt and orthanc.key in the tls_dicom folder to enable DICOM TLS.
  6. Combine those in combined.crt.pem in the tls_dicom folder to enable SSL for the REST API and Explorer.
  7. There might be a way to enable the CA files as well so that the certificate verifies, or just use your own.
  8. Change to the root of the folder and execute: sudo docker-compose up --build (-d optionally).
  9. Verify no errors.

If you are building from scratch the "RIS_DB", orthanc_ris should be created and populated automatically. Otherwise, see mysql_init for the init script.

The default setup is to store generated MWL's in the DB, not the File system and to also generate responses using the DB.

Orthanc is accessible on:

https://localhost:8042 or http://localhost:8042 depending upon if you setup SSL connections.

PHPMyAdmin is accessible on:

http://localhost:11080 user: root, password: root

PGAdmin is accessible on:

http://localhost:5050 user: sscotti@sias.dev, password: postgres

Explorer2:

https://localhost:8042/ui/app/#/ or http://localhost:8042/ui/app/#/

Legacy Explorer

https://localhost:8042/app/explorer.html or http://localhost:8042/app/explorer.html

Note about MedDream and OHIF viewers:

There are docker builds for both MedDream and OHIF included with the package, and they are for the most part integrated into the Explorer2 interface, although you made need to tweak the configuration a little, particularly for MedDream. I would recommend getting a trial license if you really want to play around with that. You might to play around with the certificates in the tls folder and in the nginx.conf files to get that all setup the way you want.

Note about the orthanc_ris DB for MySQL and Postgres:

  1. This is still a work in progress, but note the following.
  2. The mml table stores data concerning MWL files that are created via the API, including the JSON and Binary DICOM format. Responses can be generated from the DB vs. the native file system method as part of the core of Orthanc.
  3. n_create and n_set are not implemented, just 'placeholders' for now.
  4. study_complete is to store some data about when a study is marked complete via the API, for instances where the RIS or EMR provide a method to do that since Orthanc mostly relies on the study being Stable for a period of time.
  5. study_first_instances stores some data about the study when the NEW_STUDY event is triggered.

You can just upload a new study via the API (Explorer 2) to see how the study_first_instances works (MySQL only for now).

The study_complete is just an API / curl call like:

curl -k -v http://localhost:8042/studies/study_complete_DB -d '{"Tech": "1:SDS", "ID": "d8cadbbc-ad5e1f78-d6361373-86f22b9f-8c0100e2"}'

To test creating a MWL from JSON use:

curl -k -X POST http://localhost:8042/mwl/create_from_json -d ' { "AccessionNumber": "CMACC00000002", "AdditionalPatientHistory": "test", "AdmittingDiagnosesDescription": "", "Allergies": "", "ImageComments": "Tech: TEST", "MedicalAlerts": "TEST", "Modality": "MR", "Occupation": "", "OperatorsName": "Tech^SDS", "PatientAddress": "^^Vienna^OS^1160^AT", "PatientBirthDate": "20010101", "PatientComments": "", "PatientID": "PatientID", "PatientName": "Person^Test^", "PatientSex": "M", "PatientSize": "", "PatientTelecomInformation": "^^^", "PatientWeight": "", "ReferringPhysicianIdentificationSequence": [{ "InstitutionName": "InstitutionName", "PersonIdentificationCodeSequence": [{ "CodeMeaning": "Local Code", "CodeValue": "0001", "CodingSchemeDesignator": "L" }], "PersonTelephoneNumbers": "^PN^^" }], "ReferringPhysicianName": "0001:Scotti^Stephen^Douglas^Dr.", "ScheduledProcedureStepSequence": [{ "Modality": "MR", "ScheduledProcedureStepDescription": "MRI BRAIN / BRAIN STEM - WITHOUT CONTRAST", "ScheduledProcedureStepID": "0001", "ScheduledProcedureStepStartDate": "20210704", "ScheduledProcedureStepStartTime": "110000", "ScheduledProtocolCodeSequence": [{ "CodeMeaning": "", "CodeValue": "70551", "CodingSchemeDesignator": "C4" }], "ScheduledStationAETitle": "NmrEsaote" }], "SpecificCharacterSet": "ISO_IR 192", "StudyInstanceUID": "StudyInstanceUID" } '

To test an MWL query using findscu use the following.

Add +tla -ic if using Dicom TLS

findscu localhost 4242 -W -v -d -k "AccessionNumber"
-k "Modality"
-k "InstitutionName"
-k "ReferringPhysicianName"
-k "ReferencedStudySequence[0]"
-k "ReferencedPatientSequence[0]"
-k "PatientName"
-k "PatientID"
-k "PatientBirthDate"
-k "PatientSex"
-k "PatientAge"
-k "PatientWeight"
-k "MedicalAlerts"
-k "Allergies"
-k "PregnancyStatus"
-k "StudyInstanceUID"
-k "StudyID"
-k "RequestingPhysician"
-k "RequestedProcedureDescription"
-k "RequestedProcedureCodeSequence[0]"
-k "AdmissionID"
-k "SpecialNeeds"
-k "CurrentPatientLocation"
-k "PatientState"
-k "ScheduledProcedureStepSequence[0]"
-k "RequestedProcedureID"
-k "RequestedProcedurePriority"
-k "PatientTransportArrangements"
-k "ConfidentialityConstraintOnPatientDataDescription"

To Store a PDF using BASE64 or HTML: Replace the studyuuid with the one that you want to operate on and use the commands below:

Hello World base64 PDF:

curl -k http://localhost:8042/pdfkit/htmltopdf -d '{ "method":"base64", "title":"BASE64 TO PDF", "author": "Stephen D. Scotti", "studyuuid":"d8cadbbc-ad5e1f78-d6361373-86f22b9f-8c0100e2", "base64":"JVBERi0xLjcKCjEgMCBvYmogICUgZW50cnkgcG9pbnQKPDwKICAvVHlwZSAvQ2F0YWxvZwogIC9QYWdlcyAyIDAgUgo+PgplbmRvYmoKCjIgMCBvYmoKPDwKICAvVHlwZSAvUGFnZXMKICAvTWVkaWFCb3ggWyAwIDAgMjAwIDIwMCBdCiAgL0NvdW50IDEKICAvS2lkcyBbIDMgMCBSIF0KPj4KZW5kb2JqCgozIDAgb2JqCjw8CiAgL1R5cGUgL1BhZ2UKICAvUGFyZW50IDIgMCBSCiAgL1Jlc291cmNlcyA8PAogICAgL0ZvbnQgPDwKICAgICAgL0YxIDQgMCBSIAogICAgPj4KICA+PgogIC9Db250ZW50cyA1IDAgUgo+PgplbmRvYmoKCjQgMCBvYmoKPDwKICAvVHlwZSAvRm9udAogIC9TdWJ0eXBlIC9UeXBlMQogIC9CYXNlRm9udCAvVGltZXMtUm9tYW4KPj4KZW5kb2JqCgo1IDAgb2JqICAlIHBhZ2UgY29udGVudAo8PAogIC9MZW5ndGggNDQKPj4Kc3RyZWFtCkJUCjcwIDUwIFRECi9GMSAxMiBUZgooSGVsbG8sIHdvcmxkISkgVGoKRVQKZW5kc3RyZWFtCmVuZG9iagoKeHJlZgowIDYKMDAwMDAwMDAwMCA2NTUzNSBmIAowMDAwMDAwMDEwIDAwMDAwIG4gCjAwMDAwMDAwNzkgMDAwMDAgbiAKMDAwMDAwMDE3MyAwMDAwMCBuIAowMDAwMDAwMzAxIDAwMDAwIG4gCjAwMDAwMDAzODAgMDAwMDAgbiAKdHJhaWxlcgo8PAogIC9TaXplIDYKICAvUm9vdCAxIDAgUgo+PgpzdGFydHhyZWYKNDkyCiUlRU9G","return":1,"attach":1 }'

curl -k http://localhost:8042/pdfkit/htmltopdf -d '{ "method":"html","title":"HTML To PDF", "author": "Stephen D. Scotti", "studyuuid":"d8cadbbc-ad5e1f78-d6361373-86f22b9f-8c0100e2", "html":"Basically put any valid HTML, including CSS that can be rendered by wkhtmltopdf", "return":1, "attach":1 }'

To test Key Image, replace the StudyInstanceUID with one on your server. If there is no KEY_IMAGE series it will create one. If there already is one it will add an instance to the series.

There does seem to be an issue with running this in the Python Plug-in. I've implemented the same from PHP via an API and that works better as there are no 'hangs'. I've experienced Orthanc hanging sometimes in some of my setups when the study for which a key image is being made is concurrently being modified by Orthanc, or when Orthanc is conccurrently receiving studies from a modality via the DICOM protocol.

curl -k http://localhost:8042/make_key_image -d '{ "StudyInstanceUID": "1.3.6.1.4.1.5962.1.2.1.20040119072730.12322", "ImageComments": "TEST", "data_url" : "" }'

Custom Archive called as usual:

curl -k -v http://localhost:8042/studies/orthanc_uuid/archive > Study.zip

The Python Plug-in is configured to create a custom archive having the Radiant Viewer and the archive in a single .zip file

About

Docker with Orthanc, MWL/MPPS, RIS and Portal

Resources

Stars

Watchers

Forks

Releases

No releases published

Packages

No packages published