annotate Sphinx/source/plugins/python/received-instance-callback.py @ 814:b14dbbb8eda9

fix sample of ReceivedInstanceCallback for Python
author Sebastien Jodogne <s.jodogne@gmail.com>
date Wed, 23 Feb 2022 08:38:50 +0100
parents ecf431e1bd44
children a56c4128c9a2
Ignore whitespace changes - Everywhere: Within whitespace: At end of lines:
rev   line source
799
ecf431e1bd44 python sample for ReceivedInstanceCallback
Alain Mazy <am@osimis.io>
parents:
diff changeset
1 from io import BytesIO
ecf431e1bd44 python sample for ReceivedInstanceCallback
Alain Mazy <am@osimis.io>
parents:
diff changeset
2
ecf431e1bd44 python sample for ReceivedInstanceCallback
Alain Mazy <am@osimis.io>
parents:
diff changeset
3 from pydicom import dcmread, dcmwrite
ecf431e1bd44 python sample for ReceivedInstanceCallback
Alain Mazy <am@osimis.io>
parents:
diff changeset
4 from pydicom.filebase import DicomFileLike
ecf431e1bd44 python sample for ReceivedInstanceCallback
Alain Mazy <am@osimis.io>
parents:
diff changeset
5
814
b14dbbb8eda9 fix sample of ReceivedInstanceCallback for Python
Sebastien Jodogne <s.jodogne@gmail.com>
parents: 799
diff changeset
6 import orthanc
799
ecf431e1bd44 python sample for ReceivedInstanceCallback
Alain Mazy <am@osimis.io>
parents:
diff changeset
7
ecf431e1bd44 python sample for ReceivedInstanceCallback
Alain Mazy <am@osimis.io>
parents:
diff changeset
8 # from https://pydicom.github.io/pydicom/stable/auto_examples/memory_dataset.html
ecf431e1bd44 python sample for ReceivedInstanceCallback
Alain Mazy <am@osimis.io>
parents:
diff changeset
9 def write_dataset_to_bytes(dataset):
ecf431e1bd44 python sample for ReceivedInstanceCallback
Alain Mazy <am@osimis.io>
parents:
diff changeset
10 with BytesIO() as buffer:
ecf431e1bd44 python sample for ReceivedInstanceCallback
Alain Mazy <am@osimis.io>
parents:
diff changeset
11 memory_dataset = DicomFileLike(buffer)
ecf431e1bd44 python sample for ReceivedInstanceCallback
Alain Mazy <am@osimis.io>
parents:
diff changeset
12 dcmwrite(memory_dataset, dataset)
ecf431e1bd44 python sample for ReceivedInstanceCallback
Alain Mazy <am@osimis.io>
parents:
diff changeset
13 memory_dataset.seek(0)
ecf431e1bd44 python sample for ReceivedInstanceCallback
Alain Mazy <am@osimis.io>
parents:
diff changeset
14 return memory_dataset.read()
ecf431e1bd44 python sample for ReceivedInstanceCallback
Alain Mazy <am@osimis.io>
parents:
diff changeset
15
ecf431e1bd44 python sample for ReceivedInstanceCallback
Alain Mazy <am@osimis.io>
parents:
diff changeset
16 def ReceivedInstanceCallback(receivedDicom):
ecf431e1bd44 python sample for ReceivedInstanceCallback
Alain Mazy <am@osimis.io>
parents:
diff changeset
17 dataset = dcmread(BytesIO(receivedDicom))
ecf431e1bd44 python sample for ReceivedInstanceCallback
Alain Mazy <am@osimis.io>
parents:
diff changeset
18
ecf431e1bd44 python sample for ReceivedInstanceCallback
Alain Mazy <am@osimis.io>
parents:
diff changeset
19 if dataset.PatientID.startswith('001-'):
814
b14dbbb8eda9 fix sample of ReceivedInstanceCallback for Python
Sebastien Jodogne <s.jodogne@gmail.com>
parents: 799
diff changeset
20 orthanc.LogWarning('Discard instance')
799
ecf431e1bd44 python sample for ReceivedInstanceCallback
Alain Mazy <am@osimis.io>
parents:
diff changeset
21 return orthanc.ReceivedInstanceCallbackResult.DISCARD, None
ecf431e1bd44 python sample for ReceivedInstanceCallback
Alain Mazy <am@osimis.io>
parents:
diff changeset
22
814
b14dbbb8eda9 fix sample of ReceivedInstanceCallback for Python
Sebastien Jodogne <s.jodogne@gmail.com>
parents: 799
diff changeset
23 elif dataset.PatientID.startswith('002-'):
b14dbbb8eda9 fix sample of ReceivedInstanceCallback for Python
Sebastien Jodogne <s.jodogne@gmail.com>
parents: 799
diff changeset
24 orthanc.LogWarning('Store source instance as it is')
799
ecf431e1bd44 python sample for ReceivedInstanceCallback
Alain Mazy <am@osimis.io>
parents:
diff changeset
25 return orthanc.ReceivedInstanceCallbackResult.KEEP_AS_IS, None
ecf431e1bd44 python sample for ReceivedInstanceCallback
Alain Mazy <am@osimis.io>
parents:
diff changeset
26
814
b14dbbb8eda9 fix sample of ReceivedInstanceCallback for Python
Sebastien Jodogne <s.jodogne@gmail.com>
parents: 799
diff changeset
27 else:
b14dbbb8eda9 fix sample of ReceivedInstanceCallback for Python
Sebastien Jodogne <s.jodogne@gmail.com>
parents: 799
diff changeset
28 orthanc.LogWarning('Modify the source instance')
b14dbbb8eda9 fix sample of ReceivedInstanceCallback for Python
Sebastien Jodogne <s.jodogne@gmail.com>
parents: 799
diff changeset
29 dataset.PatientName = str(dataset.PatientName).upper()
b14dbbb8eda9 fix sample of ReceivedInstanceCallback for Python
Sebastien Jodogne <s.jodogne@gmail.com>
parents: 799
diff changeset
30 dataset.PatientID = '002-' + dataset.PatientID
b14dbbb8eda9 fix sample of ReceivedInstanceCallback for Python
Sebastien Jodogne <s.jodogne@gmail.com>
parents: 799
diff changeset
31 dataset.InstitutionName = "MY INSTITUTION"
b14dbbb8eda9 fix sample of ReceivedInstanceCallback for Python
Sebastien Jodogne <s.jodogne@gmail.com>
parents: 799
diff changeset
32 return orthanc.ReceivedInstanceCallbackResult.MODIFIED, write_dataset_to_bytes(dataset)
799
ecf431e1bd44 python sample for ReceivedInstanceCallback
Alain Mazy <am@osimis.io>
parents:
diff changeset
33
ecf431e1bd44 python sample for ReceivedInstanceCallback
Alain Mazy <am@osimis.io>
parents:
diff changeset
34 orthanc.RegisterReceivedInstanceCallback(ReceivedInstanceCallback)