# HG changeset patch # User Alain Mazy # Date 1733766388 -3600 # Node ID 9a4c9e0218d9da5089c8e169963aa50567618761 # Parent 00e75c82442182182725d8af05022f68dfef0f9a get-scu diff -r 00e75c824421 -r 9a4c9e0218d9 Sphinx/source/contributing.rst --- a/Sphinx/source/contributing.rst Mon Dec 09 15:50:26 2024 +0100 +++ b/Sphinx/source/contributing.rst Mon Dec 09 18:46:28 2024 +0100 @@ -17,7 +17,6 @@ * **Orthanc Core**: - Continue improving the :ref:`Orthanc Explorer 2 ` User Interface - - Support of DICOM C-GET SCU * **Stone Web viewer**: diff -r 00e75c824421 -r 9a4c9e0218d9 Sphinx/source/dicom-guide.rst --- a/Sphinx/source/dicom-guide.rst Mon Dec 09 15:50:26 2024 +0100 +++ b/Sphinx/source/dicom-guide.rst Mon Dec 09 18:46:28 2024 +0100 @@ -665,10 +665,9 @@ $ getscu -v localhost 4242 -aec ORTHANC -k "0008,0052=STUDY" -k "0020,000d=1.2.840.113543.6.6.4.7.64067529866380271256212683512383713111129" -*Note:* As of Orthanc 1.12.4, Orthanc only implements C-Get as a -service class provider (SCP). Using C-Get as a service class user -(SCU) is not currently supported in Orthanc. - +*Note:* Orthanc only implements C-Get as a +service class provider (SCP) since version 1.7.0. +Using C-Get as a service class user (SCU) is only supported in Orthanc since version 1.12.6 (not released yet). Using HTTP instead of the DICOM protocol diff -r 00e75c824421 -r 9a4c9e0218d9 Sphinx/source/users/rest.rst --- a/Sphinx/source/users/rest.rst Mon Dec 09 15:50:26 2024 +0100 +++ b/Sphinx/source/users/rest.rst Mon Dec 09 18:46:28 2024 +0100 @@ -840,6 +840,28 @@ }' +Performing C-Get (new in Orthanc 1.12.6) +--------------------------------------- + +.. highlight:: bash + +You can perform a DICOM C-Get to retrieve a specific study from one modality. + +I.e. to move a study whose you know the ``StudyInstanceUID`` from +the modality ``sample`` to this Orthanc instance:: + + $ curl --request POST --url http://localhost:8042/modalities/samples/get \ + --data '{ + "Level" : "Study", + "Resources" : [ + { + "StudyInstanceUID": "1.2.840.113543.6.6.4.7.64067529866380271256212683512383713111129" + } + ], + "Timeout": 60 + }' + + Performing Query/Retrieve (C-Find) and Find with REST ----------------------------------------------------- @@ -978,28 +1000,49 @@ POST body: ``"ModalitiesInStudy":""`` -Performing Retrieve (C-Move) -^^^^^^^^^^^^^^^^^^^^^^^^^^^^ +Performing Retrieve +^^^^^^^^^^^^^^^^^^^ + +Starting from Orthanc 1.12.6, you may retrieve resources following +a C-Find either through C-Move (unique and default method until Orthanc 1.12.5) +or through C-Get. + +The default retrieve method is defined by the ``"DicomDefaultRetrieveMethod"`` configuration +whose default value is ``"C-MOVE"`` to keep backward compatibility with prior +Orthanc versions. + +The retrieve method can also be overriden at each modality level in the ``"RetrieveMethod"`` +field of each ``"DicomModalities"`` entry. + +Furthermore, when calling the ``/queries/../retrieve`` REST API endpoint, you may specify +the ``"RetrieveMethod"`` in the payload to force the retrieve method for this specific call. + + +Performing Retrieve (with C-Move) +^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^ .. highlight:: bash -You can perform a C-Move to retrieve all studies within the original -query using a post command and identifying the Modality (named in this -example ``Orthanc``), to be one to in the POST contents:: +If ``C-MOVE`` is the default retrieve method, you can perform a C-Move to retrieve all studies within the original +query using a post command by identifying the target modality AET (named in this +example ``ORTHANC``) directly in the POST payload:: - $ curl --request POST --url http://localhost:8042/queries/5af318ac-78fb-47ff-b0b0-0df18b0588e0/retrieve --data Orthanc + $ curl --request POST --url http://localhost:8042/queries/5af318ac-78fb-47ff-b0b0-0df18b0588e0/retrieve --data ORTHANC You are also able to perform individual C-Moves for a content item by specifying that individual content item:: - $ curl --request POST --url http://localhost:8042/queries/5af318ac-78fb-47ff-b0b0-0df18b0588e0/answers/0/retrieve --data Orthanc + $ curl --request POST --url http://localhost:8042/queries/5af318ac-78fb-47ff-b0b0-0df18b0588e0/answers/0/retrieve --data ORTHANC -If C-Moves take too long (for example, performing a C-Move of a big +If a C-Move takes too long (for example, performing a C-Move of a big study), you may run the request in :ref:`asynchronous mode `, which will create a job in Orthanc:: $ curl --request POST --url http://localhost:8042/queries/5af318ac-78fb-47ff-b0b0-0df18b0588e0/retrieve \ - --data '{"TargetAet":"Orthanc","Synchronous":false}' + --data '{ "TargetAet": "ORTHANC", \ + "RetrieveMethod": "C-MOVE", \ + "Synchronous": false \ + }' .. highlight:: bash @@ -1015,6 +1058,45 @@ +Performing Retrieve (with C-Get) +^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^ + +.. highlight:: bash + +If ``C-GET`` is the default retrieve method, you can perform a C-Get to retrieve all studies within the original +query using a POST command with an empty payload:: + + $ curl --request POST --url http://localhost:8042/queries/5af318ac-78fb-47ff-b0b0-0df18b0588e0/retrieve --data """ + + +You are also able to perform individual C-Gets for a content item by +specifying that individual content item:: + + $ curl --request POST --url http://localhost:8042/queries/5af318ac-78fb-47ff-b0b0-0df18b0588e0/answers/0/retrieve --data "" + +If a C-Get takes too long (for example, performing a C-Get of a big +study), you may run the request in :ref:`asynchronous mode `, +which will create a job in Orthanc:: + + $ curl --request POST --url http://localhost:8042/queries/5af318ac-78fb-47ff-b0b0-0df18b0588e0/retrieve \ + --data '{ "RetrieveMethod": "C-GET", \ + "Synchronous": false \ + }' + + +.. highlight:: bash + +The answer of this POST request is the job ID taking care of the +C-GET command, :ref:`whose status can be monitored ` +in order to detect failure or completion:: + + { + "ID" : "11541b16-e368-41cf-a8e9-3acf4061d238", + "Path" : "/jobs/11541b16-e368-41cf-a8e9-3acf4061d238" + } + + + .. _rest-find: Performing Finds within Orthanc