Mercurial > hg > orthanc-book
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 |
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) |