Mercurial > hg > orthanc-ohif
annotate Sources/Plugin.cpp @ 27:bf4e5434567c
Fixed wrong MIME type for app-config.js that prevents the OHIF viewer from loading with Orthanc 1.12.2
author | Alain Mazy <am@osimis.io> |
---|---|
date | Wed, 03 Jan 2024 10:53:48 +0100 |
parents | 4ef286d0f78e |
children | 36049c04ee27 |
rev | line source |
---|---|
0 | 1 /** |
2 * SPDX-FileCopyrightText: 2023 Sebastien Jodogne, UCLouvain, Belgium | |
3 * SPDX-License-Identifier: GPL-3.0-or-later | |
4 */ | |
5 | |
6 /** | |
7 * OHIF plugin for Orthanc | |
8 * Copyright (C) 2023 Sebastien Jodogne, UCLouvain, Belgium | |
9 * | |
10 * This program is free software: you can redistribute it and/or | |
11 * modify it under the terms of the GNU General Public License as | |
12 * published by the Free Software Foundation, either version 3 of the | |
13 * License, or (at your option) any later version. | |
14 * | |
15 * This program is distributed in the hope that it will be useful, but | |
16 * WITHOUT ANY WARRANTY; without even the implied warranty of | |
17 * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the GNU | |
18 * General Public License for more details. | |
19 * | |
20 * You should have received a copy of the GNU General Public License | |
21 * along with this program. If not, see <http://www.gnu.org/licenses/>. | |
22 **/ | |
23 | |
24 | |
25 #include "../Resources/Orthanc/Plugins/OrthancPluginCppWrapper.h" | |
26 | |
5
8c1fe0ca24f5
added the possibility to replace DICOMweb by DICOM JSON
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
4
diff
changeset
|
27 #include <Compression/GzipCompressor.h> |
8c1fe0ca24f5
added the possibility to replace DICOMweb by DICOM JSON
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
4
diff
changeset
|
28 #include <DicomFormat/DicomInstanceHasher.h> |
3
fdb8c6c420d0
skeleton for optimization
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
2
diff
changeset
|
29 #include <DicomFormat/DicomMap.h> |
0 | 30 #include <Logging.h> |
10
5d5caf89eb5b
added thread to precompute metadata
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
9
diff
changeset
|
31 #include <MultiThreading/SharedMessageQueue.h> |
4
c34ecc350b32
upgraded the node docker image
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
3
diff
changeset
|
32 #include <SerializationToolbox.h> |
0 | 33 #include <SystemToolbox.h> |
2
cbc4be362700
added configuration option "RouterBasename"
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
0
diff
changeset
|
34 #include <Toolbox.h> |
0 | 35 |
36 #include <EmbeddedResources.h> | |
37 | |
10
5d5caf89eb5b
added thread to precompute metadata
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
9
diff
changeset
|
38 #include <boost/thread.hpp> |
0 | 39 #include <boost/thread/shared_mutex.hpp> |
40 | |
3
fdb8c6c420d0
skeleton for optimization
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
2
diff
changeset
|
41 |
10
5d5caf89eb5b
added thread to precompute metadata
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
9
diff
changeset
|
42 static const std::string METADATA_OHIF = "4202"; |
5d5caf89eb5b
added thread to precompute metadata
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
9
diff
changeset
|
43 static const char* const KEY_VERSION = "Version"; |
5d5caf89eb5b
added thread to precompute metadata
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
9
diff
changeset
|
44 static const unsigned int MAX_INSTANCES_IN_QUEUE = 10000; |
9
e8dea04df69b
caching OHIF dicom-json as metadata
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
8
diff
changeset
|
45 |
11
16b9f1ff491d
added configuration option "Preload"
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
10
diff
changeset
|
46 |
16b9f1ff491d
added configuration option "Preload"
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
10
diff
changeset
|
47 enum DataSource |
16b9f1ff491d
added configuration option "Preload"
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
10
diff
changeset
|
48 { |
16b9f1ff491d
added configuration option "Preload"
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
10
diff
changeset
|
49 DataSource_DicomWeb, |
16b9f1ff491d
added configuration option "Preload"
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
10
diff
changeset
|
50 DataSource_DicomJson |
16b9f1ff491d
added configuration option "Preload"
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
10
diff
changeset
|
51 }; |
16b9f1ff491d
added configuration option "Preload"
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
10
diff
changeset
|
52 |
16b9f1ff491d
added configuration option "Preload"
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
10
diff
changeset
|
53 |
3
fdb8c6c420d0
skeleton for optimization
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
2
diff
changeset
|
54 // Reference: https://v3-docs.ohif.org/configuration/dataSources/dicom-json |
fdb8c6c420d0
skeleton for optimization
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
2
diff
changeset
|
55 |
fdb8c6c420d0
skeleton for optimization
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
2
diff
changeset
|
56 enum DataType |
fdb8c6c420d0
skeleton for optimization
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
2
diff
changeset
|
57 { |
fdb8c6c420d0
skeleton for optimization
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
2
diff
changeset
|
58 DataType_String, |
fdb8c6c420d0
skeleton for optimization
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
2
diff
changeset
|
59 DataType_Integer, |
fdb8c6c420d0
skeleton for optimization
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
2
diff
changeset
|
60 DataType_Float, |
fdb8c6c420d0
skeleton for optimization
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
2
diff
changeset
|
61 DataType_ListOfFloats, |
fdb8c6c420d0
skeleton for optimization
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
2
diff
changeset
|
62 DataType_ListOfStrings, |
fdb8c6c420d0
skeleton for optimization
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
2
diff
changeset
|
63 DataType_None |
fdb8c6c420d0
skeleton for optimization
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
2
diff
changeset
|
64 }; |
fdb8c6c420d0
skeleton for optimization
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
2
diff
changeset
|
65 |
fdb8c6c420d0
skeleton for optimization
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
2
diff
changeset
|
66 class TagInformation |
fdb8c6c420d0
skeleton for optimization
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
2
diff
changeset
|
67 { |
fdb8c6c420d0
skeleton for optimization
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
2
diff
changeset
|
68 private: |
fdb8c6c420d0
skeleton for optimization
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
2
diff
changeset
|
69 DataType type_; |
fdb8c6c420d0
skeleton for optimization
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
2
diff
changeset
|
70 std::string name_; |
fdb8c6c420d0
skeleton for optimization
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
2
diff
changeset
|
71 |
fdb8c6c420d0
skeleton for optimization
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
2
diff
changeset
|
72 public: |
fdb8c6c420d0
skeleton for optimization
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
2
diff
changeset
|
73 TagInformation() : |
fdb8c6c420d0
skeleton for optimization
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
2
diff
changeset
|
74 type_(DataType_None) |
fdb8c6c420d0
skeleton for optimization
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
2
diff
changeset
|
75 { |
fdb8c6c420d0
skeleton for optimization
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
2
diff
changeset
|
76 } |
fdb8c6c420d0
skeleton for optimization
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
2
diff
changeset
|
77 |
fdb8c6c420d0
skeleton for optimization
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
2
diff
changeset
|
78 TagInformation(DataType type, |
fdb8c6c420d0
skeleton for optimization
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
2
diff
changeset
|
79 const std::string& name) : |
fdb8c6c420d0
skeleton for optimization
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
2
diff
changeset
|
80 type_(type), |
fdb8c6c420d0
skeleton for optimization
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
2
diff
changeset
|
81 name_(name) |
fdb8c6c420d0
skeleton for optimization
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
2
diff
changeset
|
82 { |
fdb8c6c420d0
skeleton for optimization
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
2
diff
changeset
|
83 } |
fdb8c6c420d0
skeleton for optimization
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
2
diff
changeset
|
84 |
fdb8c6c420d0
skeleton for optimization
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
2
diff
changeset
|
85 DataType GetType() const |
fdb8c6c420d0
skeleton for optimization
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
2
diff
changeset
|
86 { |
fdb8c6c420d0
skeleton for optimization
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
2
diff
changeset
|
87 return type_; |
fdb8c6c420d0
skeleton for optimization
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
2
diff
changeset
|
88 } |
fdb8c6c420d0
skeleton for optimization
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
2
diff
changeset
|
89 |
fdb8c6c420d0
skeleton for optimization
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
2
diff
changeset
|
90 const std::string& GetName() const |
fdb8c6c420d0
skeleton for optimization
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
2
diff
changeset
|
91 { |
fdb8c6c420d0
skeleton for optimization
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
2
diff
changeset
|
92 return name_; |
fdb8c6c420d0
skeleton for optimization
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
2
diff
changeset
|
93 } |
fdb8c6c420d0
skeleton for optimization
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
2
diff
changeset
|
94 |
fdb8c6c420d0
skeleton for optimization
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
2
diff
changeset
|
95 bool operator== (const TagInformation& other) const |
fdb8c6c420d0
skeleton for optimization
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
2
diff
changeset
|
96 { |
fdb8c6c420d0
skeleton for optimization
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
2
diff
changeset
|
97 return (type_ == other.type_ && |
fdb8c6c420d0
skeleton for optimization
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
2
diff
changeset
|
98 name_ == other.name_); |
fdb8c6c420d0
skeleton for optimization
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
2
diff
changeset
|
99 } |
fdb8c6c420d0
skeleton for optimization
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
2
diff
changeset
|
100 }; |
fdb8c6c420d0
skeleton for optimization
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
2
diff
changeset
|
101 |
fdb8c6c420d0
skeleton for optimization
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
2
diff
changeset
|
102 typedef std::map<Orthanc::DicomTag, TagInformation> TagsDictionary; |
fdb8c6c420d0
skeleton for optimization
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
2
diff
changeset
|
103 |
fdb8c6c420d0
skeleton for optimization
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
2
diff
changeset
|
104 static TagsDictionary ohifStudyTags_, ohifSeriesTags_, ohifInstanceTags_, allTags_; |
fdb8c6c420d0
skeleton for optimization
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
2
diff
changeset
|
105 |
8
cc4c81d08bf0
added missing tags for PET
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
7
diff
changeset
|
106 |
cc4c81d08bf0
added missing tags for PET
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
7
diff
changeset
|
107 static const Orthanc::DicomTag RADIOPHARMACEUTICAL_INFORMATION_SEQUENCE(0x0054, 0x0016); |
cc4c81d08bf0
added missing tags for PET
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
7
diff
changeset
|
108 |
3
fdb8c6c420d0
skeleton for optimization
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
2
diff
changeset
|
109 static void InitializeOhifTags() |
fdb8c6c420d0
skeleton for optimization
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
2
diff
changeset
|
110 { |
7
eab054ee7537
added modal in Orthanc Explorer to choose between the OHIF viewers
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
6
diff
changeset
|
111 /** |
eab054ee7537
added modal in Orthanc Explorer to choose between the OHIF viewers
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
6
diff
changeset
|
112 * Those are the tags that are found in the documentation of the |
eab054ee7537
added modal in Orthanc Explorer to choose between the OHIF viewers
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
6
diff
changeset
|
113 * "DICOM JSON" data source: |
eab054ee7537
added modal in Orthanc Explorer to choose between the OHIF viewers
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
6
diff
changeset
|
114 * https://docs.ohif.org/configuration/dataSources/dicom-json |
eab054ee7537
added modal in Orthanc Explorer to choose between the OHIF viewers
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
6
diff
changeset
|
115 **/ |
3
fdb8c6c420d0
skeleton for optimization
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
2
diff
changeset
|
116 ohifStudyTags_[Orthanc::DICOM_TAG_STUDY_INSTANCE_UID] = TagInformation(DataType_String, "StudyInstanceUID"); |
fdb8c6c420d0
skeleton for optimization
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
2
diff
changeset
|
117 ohifStudyTags_[Orthanc::DICOM_TAG_STUDY_DATE] = TagInformation(DataType_String, "StudyDate"); |
fdb8c6c420d0
skeleton for optimization
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
2
diff
changeset
|
118 ohifStudyTags_[Orthanc::DICOM_TAG_STUDY_TIME] = TagInformation(DataType_String, "StudyTime"); |
5
8c1fe0ca24f5
added the possibility to replace DICOMweb by DICOM JSON
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
4
diff
changeset
|
119 ohifStudyTags_[Orthanc::DICOM_TAG_STUDY_DESCRIPTION] = TagInformation(DataType_String, "StudyDescription"); |
3
fdb8c6c420d0
skeleton for optimization
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
2
diff
changeset
|
120 ohifStudyTags_[Orthanc::DICOM_TAG_PATIENT_NAME] = TagInformation(DataType_String, "PatientName"); |
fdb8c6c420d0
skeleton for optimization
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
2
diff
changeset
|
121 ohifStudyTags_[Orthanc::DICOM_TAG_PATIENT_ID] = TagInformation(DataType_String, "PatientID"); |
fdb8c6c420d0
skeleton for optimization
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
2
diff
changeset
|
122 ohifStudyTags_[Orthanc::DICOM_TAG_ACCESSION_NUMBER] = TagInformation(DataType_String, "AccessionNumber"); |
fdb8c6c420d0
skeleton for optimization
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
2
diff
changeset
|
123 ohifStudyTags_[Orthanc::DicomTag(0x0010, 0x1010)] = TagInformation(DataType_String, "PatientAge"); |
fdb8c6c420d0
skeleton for optimization
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
2
diff
changeset
|
124 ohifStudyTags_[Orthanc::DICOM_TAG_PATIENT_SEX] = TagInformation(DataType_String, "PatientSex"); |
fdb8c6c420d0
skeleton for optimization
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
2
diff
changeset
|
125 |
fdb8c6c420d0
skeleton for optimization
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
2
diff
changeset
|
126 ohifSeriesTags_[Orthanc::DICOM_TAG_SERIES_INSTANCE_UID] = TagInformation(DataType_String, "SeriesInstanceUID"); |
fdb8c6c420d0
skeleton for optimization
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
2
diff
changeset
|
127 ohifSeriesTags_[Orthanc::DICOM_TAG_SERIES_NUMBER] = TagInformation(DataType_Integer, "SeriesNumber"); |
5
8c1fe0ca24f5
added the possibility to replace DICOMweb by DICOM JSON
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
4
diff
changeset
|
128 ohifSeriesTags_[Orthanc::DICOM_TAG_SERIES_DESCRIPTION] = TagInformation(DataType_String, "SeriesDescription"); |
3
fdb8c6c420d0
skeleton for optimization
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
2
diff
changeset
|
129 ohifSeriesTags_[Orthanc::DICOM_TAG_MODALITY] = TagInformation(DataType_String, "Modality"); |
fdb8c6c420d0
skeleton for optimization
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
2
diff
changeset
|
130 ohifSeriesTags_[Orthanc::DICOM_TAG_SLICE_THICKNESS] = TagInformation(DataType_Float, "SliceThickness"); |
fdb8c6c420d0
skeleton for optimization
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
2
diff
changeset
|
131 |
fdb8c6c420d0
skeleton for optimization
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
2
diff
changeset
|
132 ohifInstanceTags_[Orthanc::DICOM_TAG_COLUMNS] = TagInformation(DataType_Integer, "Columns"); |
fdb8c6c420d0
skeleton for optimization
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
2
diff
changeset
|
133 ohifInstanceTags_[Orthanc::DICOM_TAG_ROWS] = TagInformation(DataType_Integer, "Rows"); |
fdb8c6c420d0
skeleton for optimization
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
2
diff
changeset
|
134 ohifInstanceTags_[Orthanc::DICOM_TAG_INSTANCE_NUMBER] = TagInformation(DataType_Integer, "InstanceNumber"); |
fdb8c6c420d0
skeleton for optimization
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
2
diff
changeset
|
135 ohifInstanceTags_[Orthanc::DICOM_TAG_SOP_CLASS_UID] = TagInformation(DataType_String, "SOPClassUID"); |
fdb8c6c420d0
skeleton for optimization
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
2
diff
changeset
|
136 ohifInstanceTags_[Orthanc::DICOM_TAG_PHOTOMETRIC_INTERPRETATION] = TagInformation(DataType_String, "PhotometricInterpretation"); |
fdb8c6c420d0
skeleton for optimization
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
2
diff
changeset
|
137 ohifInstanceTags_[Orthanc::DICOM_TAG_BITS_ALLOCATED] = TagInformation(DataType_Integer, "BitsAllocated"); |
fdb8c6c420d0
skeleton for optimization
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
2
diff
changeset
|
138 ohifInstanceTags_[Orthanc::DICOM_TAG_BITS_STORED] = TagInformation(DataType_Integer, "BitsStored"); |
fdb8c6c420d0
skeleton for optimization
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
2
diff
changeset
|
139 ohifInstanceTags_[Orthanc::DICOM_TAG_PIXEL_REPRESENTATION] = TagInformation(DataType_Integer, "PixelRepresentation"); |
fdb8c6c420d0
skeleton for optimization
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
2
diff
changeset
|
140 ohifInstanceTags_[Orthanc::DICOM_TAG_SAMPLES_PER_PIXEL] = TagInformation(DataType_Integer, "SamplesPerPixel"); |
fdb8c6c420d0
skeleton for optimization
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
2
diff
changeset
|
141 ohifInstanceTags_[Orthanc::DICOM_TAG_PIXEL_SPACING] = TagInformation(DataType_ListOfFloats, "PixelSpacing"); |
fdb8c6c420d0
skeleton for optimization
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
2
diff
changeset
|
142 ohifInstanceTags_[Orthanc::DICOM_TAG_HIGH_BIT] = TagInformation(DataType_Integer, "HighBit"); |
fdb8c6c420d0
skeleton for optimization
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
2
diff
changeset
|
143 ohifInstanceTags_[Orthanc::DICOM_TAG_IMAGE_ORIENTATION_PATIENT] = TagInformation(DataType_ListOfFloats, "ImageOrientationPatient"); |
fdb8c6c420d0
skeleton for optimization
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
2
diff
changeset
|
144 ohifInstanceTags_[Orthanc::DICOM_TAG_IMAGE_POSITION_PATIENT] = TagInformation(DataType_ListOfFloats, "ImagePositionPatient"); |
fdb8c6c420d0
skeleton for optimization
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
2
diff
changeset
|
145 ohifInstanceTags_[Orthanc::DICOM_TAG_FRAME_OF_REFERENCE_UID] = TagInformation(DataType_String, "FrameOfReferenceUID"); |
fdb8c6c420d0
skeleton for optimization
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
2
diff
changeset
|
146 ohifInstanceTags_[Orthanc::DicomTag(0x0008, 0x0008)] = TagInformation(DataType_ListOfStrings, "ImageType"); |
fdb8c6c420d0
skeleton for optimization
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
2
diff
changeset
|
147 ohifInstanceTags_[Orthanc::DICOM_TAG_MODALITY] = TagInformation(DataType_String, "Modality"); |
fdb8c6c420d0
skeleton for optimization
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
2
diff
changeset
|
148 ohifInstanceTags_[Orthanc::DICOM_TAG_SOP_INSTANCE_UID] = TagInformation(DataType_String, "SOPInstanceUID"); |
fdb8c6c420d0
skeleton for optimization
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
2
diff
changeset
|
149 ohifInstanceTags_[Orthanc::DICOM_TAG_SERIES_INSTANCE_UID] = TagInformation(DataType_String, "SeriesInstanceUID"); |
fdb8c6c420d0
skeleton for optimization
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
2
diff
changeset
|
150 ohifInstanceTags_[Orthanc::DICOM_TAG_STUDY_INSTANCE_UID] = TagInformation(DataType_String, "StudyInstanceUID"); |
fdb8c6c420d0
skeleton for optimization
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
2
diff
changeset
|
151 ohifInstanceTags_[Orthanc::DICOM_TAG_WINDOW_CENTER] = TagInformation(DataType_Float, "WindowCenter"); |
fdb8c6c420d0
skeleton for optimization
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
2
diff
changeset
|
152 ohifInstanceTags_[Orthanc::DICOM_TAG_WINDOW_WIDTH] = TagInformation(DataType_Float, "WindowWidth"); |
fdb8c6c420d0
skeleton for optimization
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
2
diff
changeset
|
153 ohifInstanceTags_[Orthanc::DICOM_TAG_SERIES_DATE] = TagInformation(DataType_String, "SeriesDate"); |
fdb8c6c420d0
skeleton for optimization
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
2
diff
changeset
|
154 |
7
eab054ee7537
added modal in Orthanc Explorer to choose between the OHIF viewers
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
6
diff
changeset
|
155 /** |
eab054ee7537
added modal in Orthanc Explorer to choose between the OHIF viewers
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
6
diff
changeset
|
156 * The items below are related to PET scans. Their list can be found |
eab054ee7537
added modal in Orthanc Explorer to choose between the OHIF viewers
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
6
diff
changeset
|
157 * by looking for "required metadata are missing" in |
eab054ee7537
added modal in Orthanc Explorer to choose between the OHIF viewers
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
6
diff
changeset
|
158 * "extensions/default/src/getPTImageIdInstanceMetadata.ts" |
eab054ee7537
added modal in Orthanc Explorer to choose between the OHIF viewers
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
6
diff
changeset
|
159 **/ |
8
cc4c81d08bf0
added missing tags for PET
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
7
diff
changeset
|
160 ohifInstanceTags_[Orthanc::DICOM_TAG_ACQUISITION_DATE] = TagInformation(DataType_String, "AcquisitionDate"); |
cc4c81d08bf0
added missing tags for PET
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
7
diff
changeset
|
161 ohifInstanceTags_[Orthanc::DICOM_TAG_ACQUISITION_TIME] = TagInformation(DataType_String, "AcquisitionTime"); |
cc4c81d08bf0
added missing tags for PET
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
7
diff
changeset
|
162 ohifInstanceTags_[Orthanc::DICOM_TAG_SERIES_TIME] = TagInformation(DataType_String, "SeriesTime"); |
cc4c81d08bf0
added missing tags for PET
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
7
diff
changeset
|
163 ohifInstanceTags_[Orthanc::DicomTag(0x0010, 0x1020)] = TagInformation(DataType_Float, "PatientSize"); |
cc4c81d08bf0
added missing tags for PET
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
7
diff
changeset
|
164 ohifInstanceTags_[Orthanc::DicomTag(0x0010, 0x1030)] = TagInformation(DataType_Float, "PatientWeight"); |
cc4c81d08bf0
added missing tags for PET
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
7
diff
changeset
|
165 ohifInstanceTags_[Orthanc::DicomTag(0x0018, 0x1242)] = TagInformation(DataType_Integer, "ActualFrameDuration"); |
cc4c81d08bf0
added missing tags for PET
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
7
diff
changeset
|
166 ohifInstanceTags_[Orthanc::DicomTag(0x0028, 0x0051)] = TagInformation(DataType_ListOfStrings, "CorrectedImage"); |
cc4c81d08bf0
added missing tags for PET
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
7
diff
changeset
|
167 ohifInstanceTags_[Orthanc::DicomTag(0x0054, 0x1001)] = TagInformation(DataType_String, "Units"); |
cc4c81d08bf0
added missing tags for PET
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
7
diff
changeset
|
168 ohifInstanceTags_[Orthanc::DicomTag(0x0054, 0x1102)] = TagInformation(DataType_String, "DecayCorrection"); |
cc4c81d08bf0
added missing tags for PET
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
7
diff
changeset
|
169 ohifInstanceTags_[Orthanc::DicomTag(0x0054, 0x1300)] = TagInformation(DataType_Float, "FrameReferenceTime"); |
cc4c81d08bf0
added missing tags for PET
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
7
diff
changeset
|
170 ohifInstanceTags_[RADIOPHARMACEUTICAL_INFORMATION_SEQUENCE] = TagInformation(DataType_None, "RadiopharmaceuticalInformationSequence"); |
cc4c81d08bf0
added missing tags for PET
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
7
diff
changeset
|
171 |
cc4c81d08bf0
added missing tags for PET
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
7
diff
changeset
|
172 // UNTESTED |
cc4c81d08bf0
added missing tags for PET
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
7
diff
changeset
|
173 ohifInstanceTags_[Orthanc::DicomTag(0x7053, 0x1000)] = TagInformation(DataType_Float, "70531000"); // Philips SUVScaleFactor |
cc4c81d08bf0
added missing tags for PET
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
7
diff
changeset
|
174 ohifInstanceTags_[Orthanc::DicomTag(0x7053, 0x1009)] = TagInformation(DataType_Float, "70531009"); // Philips ActivityConcentrationScaleFactor |
cc4c81d08bf0
added missing tags for PET
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
7
diff
changeset
|
175 ohifInstanceTags_[Orthanc::DicomTag(0x0009, 0x100d)] = TagInformation(DataType_String, "0009100d"); // GE PrivatePostInjectionDateTime |
7
eab054ee7537
added modal in Orthanc Explorer to choose between the OHIF viewers
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
6
diff
changeset
|
176 |
3
fdb8c6c420d0
skeleton for optimization
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
2
diff
changeset
|
177 for (TagsDictionary::const_iterator it = ohifStudyTags_.begin(); it != ohifStudyTags_.end(); ++it) |
fdb8c6c420d0
skeleton for optimization
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
2
diff
changeset
|
178 { |
fdb8c6c420d0
skeleton for optimization
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
2
diff
changeset
|
179 assert(allTags_.find(it->first) == allTags_.end() || |
fdb8c6c420d0
skeleton for optimization
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
2
diff
changeset
|
180 allTags_[it->first] == it->second); |
fdb8c6c420d0
skeleton for optimization
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
2
diff
changeset
|
181 allTags_[it->first] = it->second; |
fdb8c6c420d0
skeleton for optimization
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
2
diff
changeset
|
182 } |
fdb8c6c420d0
skeleton for optimization
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
2
diff
changeset
|
183 |
fdb8c6c420d0
skeleton for optimization
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
2
diff
changeset
|
184 for (TagsDictionary::const_iterator it = ohifSeriesTags_.begin(); it != ohifSeriesTags_.end(); ++it) |
fdb8c6c420d0
skeleton for optimization
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
2
diff
changeset
|
185 { |
fdb8c6c420d0
skeleton for optimization
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
2
diff
changeset
|
186 assert(allTags_.find(it->first) == allTags_.end() || |
fdb8c6c420d0
skeleton for optimization
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
2
diff
changeset
|
187 allTags_[it->first] == it->second); |
fdb8c6c420d0
skeleton for optimization
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
2
diff
changeset
|
188 allTags_[it->first] = it->second; |
fdb8c6c420d0
skeleton for optimization
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
2
diff
changeset
|
189 } |
fdb8c6c420d0
skeleton for optimization
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
2
diff
changeset
|
190 |
fdb8c6c420d0
skeleton for optimization
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
2
diff
changeset
|
191 for (TagsDictionary::const_iterator it = ohifInstanceTags_.begin(); it != ohifInstanceTags_.end(); ++it) |
fdb8c6c420d0
skeleton for optimization
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
2
diff
changeset
|
192 { |
fdb8c6c420d0
skeleton for optimization
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
2
diff
changeset
|
193 assert(allTags_.find(it->first) == allTags_.end() || |
fdb8c6c420d0
skeleton for optimization
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
2
diff
changeset
|
194 allTags_[it->first] == it->second); |
fdb8c6c420d0
skeleton for optimization
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
2
diff
changeset
|
195 allTags_[it->first] = it->second; |
fdb8c6c420d0
skeleton for optimization
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
2
diff
changeset
|
196 } |
fdb8c6c420d0
skeleton for optimization
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
2
diff
changeset
|
197 } |
fdb8c6c420d0
skeleton for optimization
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
2
diff
changeset
|
198 |
fdb8c6c420d0
skeleton for optimization
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
2
diff
changeset
|
199 |
0 | 200 // Forward declaration |
201 void ReadStaticAsset(std::string& target, | |
202 const std::string& path); | |
203 | |
204 | |
205 /** | |
206 * As the OHIF static assets are gzipped by the "EmbedStaticAssets.py" | |
207 * script, we use a cache to maintain the uncompressed assets in order | |
208 * to avoid multiple gzip decodings. | |
209 **/ | |
210 class ResourcesCache : public boost::noncopyable | |
211 { | |
212 private: | |
213 typedef std::map<std::string, std::string*> Content; | |
214 | |
215 boost::shared_mutex mutex_; | |
216 Content content_; | |
217 | |
218 public: | |
219 ~ResourcesCache() | |
220 { | |
221 for (Content::iterator it = content_.begin(); it != content_.end(); ++it) | |
222 { | |
223 assert(it->second != NULL); | |
224 delete it->second; | |
225 } | |
226 } | |
227 | |
228 void Answer(OrthancPluginContext* context, | |
229 OrthancPluginRestOutput* output, | |
230 const std::string& path) | |
231 { | |
232 const std::string mime = Orthanc::EnumerationToString(Orthanc::SystemToolbox::AutodetectMimeType(path)); | |
233 | |
234 { | |
235 // Check whether the cache already contains the resource | |
236 boost::shared_lock<boost::shared_mutex> lock(mutex_); | |
237 | |
238 Content::const_iterator found = content_.find(path); | |
239 | |
240 if (found != content_.end()) | |
241 { | |
242 assert(found->second != NULL); | |
243 OrthancPluginAnswerBuffer(context, output, found->second->c_str(), found->second->size(), mime.c_str()); | |
244 return; | |
245 } | |
246 } | |
247 | |
248 // This resource has not been cached yet | |
249 | |
250 std::unique_ptr<std::string> item(new std::string); | |
251 ReadStaticAsset(*item, path); | |
252 OrthancPluginAnswerBuffer(context, output, item->c_str(), item->size(), mime.c_str()); | |
253 | |
254 { | |
255 // Store the resource into the cache | |
256 boost::unique_lock<boost::shared_mutex> lock(mutex_); | |
257 | |
258 if (content_.find(path) == content_.end()) | |
259 { | |
260 content_[path] = item.release(); | |
261 } | |
262 } | |
263 } | |
264 }; | |
265 | |
266 | |
8
cc4c81d08bf0
added missing tags for PET
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
7
diff
changeset
|
267 static bool ParseTagFromOrthanc(Json::Value& target, |
cc4c81d08bf0
added missing tags for PET
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
7
diff
changeset
|
268 const Orthanc::DicomTag& tag, |
cc4c81d08bf0
added missing tags for PET
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
7
diff
changeset
|
269 const std::string& name, |
cc4c81d08bf0
added missing tags for PET
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
7
diff
changeset
|
270 DataType type, |
cc4c81d08bf0
added missing tags for PET
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
7
diff
changeset
|
271 const Json::Value& source) |
cc4c81d08bf0
added missing tags for PET
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
7
diff
changeset
|
272 { |
cc4c81d08bf0
added missing tags for PET
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
7
diff
changeset
|
273 const std::string formattedTag = tag.Format(); |
cc4c81d08bf0
added missing tags for PET
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
7
diff
changeset
|
274 |
cc4c81d08bf0
added missing tags for PET
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
7
diff
changeset
|
275 if (source.isMember(formattedTag)) |
cc4c81d08bf0
added missing tags for PET
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
7
diff
changeset
|
276 { |
cc4c81d08bf0
added missing tags for PET
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
7
diff
changeset
|
277 const Json::Value& value = source[formattedTag]; |
cc4c81d08bf0
added missing tags for PET
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
7
diff
changeset
|
278 |
cc4c81d08bf0
added missing tags for PET
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
7
diff
changeset
|
279 /** |
cc4c81d08bf0
added missing tags for PET
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
7
diff
changeset
|
280 * The cases below derive from "Toolbox::SimplifyDicomAsJson()" |
cc4c81d08bf0
added missing tags for PET
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
7
diff
changeset
|
281 * with "DicomToJsonFormat_Short", which is invoked by the REST |
cc4c81d08bf0
added missing tags for PET
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
7
diff
changeset
|
282 * API call to "/instances/.../tags?short". |
cc4c81d08bf0
added missing tags for PET
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
7
diff
changeset
|
283 **/ |
cc4c81d08bf0
added missing tags for PET
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
7
diff
changeset
|
284 |
cc4c81d08bf0
added missing tags for PET
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
7
diff
changeset
|
285 switch (value.type()) |
cc4c81d08bf0
added missing tags for PET
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
7
diff
changeset
|
286 { |
cc4c81d08bf0
added missing tags for PET
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
7
diff
changeset
|
287 case Json::nullValue: |
cc4c81d08bf0
added missing tags for PET
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
7
diff
changeset
|
288 return false; |
cc4c81d08bf0
added missing tags for PET
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
7
diff
changeset
|
289 |
cc4c81d08bf0
added missing tags for PET
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
7
diff
changeset
|
290 case Json::arrayValue: |
cc4c81d08bf0
added missing tags for PET
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
7
diff
changeset
|
291 // This should never happen, as this would correspond to a sequence |
cc4c81d08bf0
added missing tags for PET
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
7
diff
changeset
|
292 return false; |
cc4c81d08bf0
added missing tags for PET
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
7
diff
changeset
|
293 |
cc4c81d08bf0
added missing tags for PET
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
7
diff
changeset
|
294 case Json::stringValue: |
cc4c81d08bf0
added missing tags for PET
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
7
diff
changeset
|
295 { |
cc4c81d08bf0
added missing tags for PET
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
7
diff
changeset
|
296 switch (type) |
cc4c81d08bf0
added missing tags for PET
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
7
diff
changeset
|
297 { |
cc4c81d08bf0
added missing tags for PET
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
7
diff
changeset
|
298 case DataType_String: |
cc4c81d08bf0
added missing tags for PET
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
7
diff
changeset
|
299 target[name] = value; |
cc4c81d08bf0
added missing tags for PET
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
7
diff
changeset
|
300 return true; |
cc4c81d08bf0
added missing tags for PET
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
7
diff
changeset
|
301 |
cc4c81d08bf0
added missing tags for PET
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
7
diff
changeset
|
302 case DataType_Integer: |
cc4c81d08bf0
added missing tags for PET
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
7
diff
changeset
|
303 { |
cc4c81d08bf0
added missing tags for PET
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
7
diff
changeset
|
304 int32_t v; |
cc4c81d08bf0
added missing tags for PET
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
7
diff
changeset
|
305 if (Orthanc::SerializationToolbox::ParseInteger32(v, value.asString())) |
cc4c81d08bf0
added missing tags for PET
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
7
diff
changeset
|
306 { |
cc4c81d08bf0
added missing tags for PET
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
7
diff
changeset
|
307 target[name] = v; |
cc4c81d08bf0
added missing tags for PET
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
7
diff
changeset
|
308 } |
cc4c81d08bf0
added missing tags for PET
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
7
diff
changeset
|
309 return true; |
cc4c81d08bf0
added missing tags for PET
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
7
diff
changeset
|
310 } |
cc4c81d08bf0
added missing tags for PET
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
7
diff
changeset
|
311 |
cc4c81d08bf0
added missing tags for PET
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
7
diff
changeset
|
312 case DataType_Float: |
cc4c81d08bf0
added missing tags for PET
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
7
diff
changeset
|
313 { |
cc4c81d08bf0
added missing tags for PET
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
7
diff
changeset
|
314 float v; |
cc4c81d08bf0
added missing tags for PET
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
7
diff
changeset
|
315 if (Orthanc::SerializationToolbox::ParseFloat(v, value.asString())) |
cc4c81d08bf0
added missing tags for PET
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
7
diff
changeset
|
316 { |
cc4c81d08bf0
added missing tags for PET
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
7
diff
changeset
|
317 target[name] = v; |
cc4c81d08bf0
added missing tags for PET
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
7
diff
changeset
|
318 } |
cc4c81d08bf0
added missing tags for PET
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
7
diff
changeset
|
319 return true; |
cc4c81d08bf0
added missing tags for PET
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
7
diff
changeset
|
320 } |
cc4c81d08bf0
added missing tags for PET
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
7
diff
changeset
|
321 |
cc4c81d08bf0
added missing tags for PET
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
7
diff
changeset
|
322 case DataType_ListOfStrings: |
cc4c81d08bf0
added missing tags for PET
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
7
diff
changeset
|
323 { |
cc4c81d08bf0
added missing tags for PET
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
7
diff
changeset
|
324 std::vector<std::string> tokens; |
cc4c81d08bf0
added missing tags for PET
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
7
diff
changeset
|
325 Orthanc::Toolbox::TokenizeString(tokens, value.asString(), '\\'); |
cc4c81d08bf0
added missing tags for PET
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
7
diff
changeset
|
326 target[name] = Json::arrayValue; |
cc4c81d08bf0
added missing tags for PET
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
7
diff
changeset
|
327 for (size_t i = 0; i < tokens.size(); i++) |
cc4c81d08bf0
added missing tags for PET
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
7
diff
changeset
|
328 { |
cc4c81d08bf0
added missing tags for PET
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
7
diff
changeset
|
329 target[name].append(tokens[i]); |
cc4c81d08bf0
added missing tags for PET
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
7
diff
changeset
|
330 } |
cc4c81d08bf0
added missing tags for PET
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
7
diff
changeset
|
331 return true; |
cc4c81d08bf0
added missing tags for PET
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
7
diff
changeset
|
332 } |
cc4c81d08bf0
added missing tags for PET
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
7
diff
changeset
|
333 |
cc4c81d08bf0
added missing tags for PET
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
7
diff
changeset
|
334 case DataType_ListOfFloats: |
cc4c81d08bf0
added missing tags for PET
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
7
diff
changeset
|
335 { |
cc4c81d08bf0
added missing tags for PET
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
7
diff
changeset
|
336 std::vector<std::string> tokens; |
cc4c81d08bf0
added missing tags for PET
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
7
diff
changeset
|
337 Orthanc::Toolbox::TokenizeString(tokens, value.asString(), '\\'); |
cc4c81d08bf0
added missing tags for PET
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
7
diff
changeset
|
338 target[name] = Json::arrayValue; |
cc4c81d08bf0
added missing tags for PET
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
7
diff
changeset
|
339 for (size_t i = 0; i < tokens.size(); i++) |
cc4c81d08bf0
added missing tags for PET
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
7
diff
changeset
|
340 { |
cc4c81d08bf0
added missing tags for PET
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
7
diff
changeset
|
341 float v; |
cc4c81d08bf0
added missing tags for PET
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
7
diff
changeset
|
342 if (Orthanc::SerializationToolbox::ParseFloat(v, tokens[i])) |
cc4c81d08bf0
added missing tags for PET
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
7
diff
changeset
|
343 { |
cc4c81d08bf0
added missing tags for PET
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
7
diff
changeset
|
344 target[name].append(v); |
cc4c81d08bf0
added missing tags for PET
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
7
diff
changeset
|
345 } |
cc4c81d08bf0
added missing tags for PET
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
7
diff
changeset
|
346 } |
cc4c81d08bf0
added missing tags for PET
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
7
diff
changeset
|
347 return true; |
cc4c81d08bf0
added missing tags for PET
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
7
diff
changeset
|
348 } |
cc4c81d08bf0
added missing tags for PET
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
7
diff
changeset
|
349 |
cc4c81d08bf0
added missing tags for PET
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
7
diff
changeset
|
350 default: |
cc4c81d08bf0
added missing tags for PET
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
7
diff
changeset
|
351 throw Orthanc::OrthancException(Orthanc::ErrorCode_NotImplemented); |
cc4c81d08bf0
added missing tags for PET
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
7
diff
changeset
|
352 } |
cc4c81d08bf0
added missing tags for PET
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
7
diff
changeset
|
353 } |
cc4c81d08bf0
added missing tags for PET
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
7
diff
changeset
|
354 |
cc4c81d08bf0
added missing tags for PET
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
7
diff
changeset
|
355 default: |
cc4c81d08bf0
added missing tags for PET
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
7
diff
changeset
|
356 // This should never happen |
cc4c81d08bf0
added missing tags for PET
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
7
diff
changeset
|
357 return false; |
cc4c81d08bf0
added missing tags for PET
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
7
diff
changeset
|
358 } |
cc4c81d08bf0
added missing tags for PET
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
7
diff
changeset
|
359 } |
cc4c81d08bf0
added missing tags for PET
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
7
diff
changeset
|
360 else |
cc4c81d08bf0
added missing tags for PET
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
7
diff
changeset
|
361 { |
cc4c81d08bf0
added missing tags for PET
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
7
diff
changeset
|
362 return false; |
cc4c81d08bf0
added missing tags for PET
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
7
diff
changeset
|
363 } |
cc4c81d08bf0
added missing tags for PET
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
7
diff
changeset
|
364 } |
cc4c81d08bf0
added missing tags for PET
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
7
diff
changeset
|
365 |
cc4c81d08bf0
added missing tags for PET
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
7
diff
changeset
|
366 |
9
e8dea04df69b
caching OHIF dicom-json as metadata
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
8
diff
changeset
|
367 static bool EncodeOhifInstance(Json::Value& target, |
e8dea04df69b
caching OHIF dicom-json as metadata
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
8
diff
changeset
|
368 const std::string& instanceId) |
3
fdb8c6c420d0
skeleton for optimization
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
2
diff
changeset
|
369 { |
fdb8c6c420d0
skeleton for optimization
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
2
diff
changeset
|
370 Json::Value source; |
fdb8c6c420d0
skeleton for optimization
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
2
diff
changeset
|
371 if (!OrthancPlugins::RestApiGet(source, "/instances/" + instanceId + "/tags?short", false)) |
fdb8c6c420d0
skeleton for optimization
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
2
diff
changeset
|
372 { |
5
8c1fe0ca24f5
added the possibility to replace DICOMweb by DICOM JSON
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
4
diff
changeset
|
373 return false; |
3
fdb8c6c420d0
skeleton for optimization
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
2
diff
changeset
|
374 } |
9
e8dea04df69b
caching OHIF dicom-json as metadata
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
8
diff
changeset
|
375 else if (source.type() != Json::objectValue) |
3
fdb8c6c420d0
skeleton for optimization
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
2
diff
changeset
|
376 { |
fdb8c6c420d0
skeleton for optimization
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
2
diff
changeset
|
377 throw Orthanc::OrthancException(Orthanc::ErrorCode_InternalError); |
fdb8c6c420d0
skeleton for optimization
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
2
diff
changeset
|
378 } |
9
e8dea04df69b
caching OHIF dicom-json as metadata
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
8
diff
changeset
|
379 else |
e8dea04df69b
caching OHIF dicom-json as metadata
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
8
diff
changeset
|
380 { |
e8dea04df69b
caching OHIF dicom-json as metadata
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
8
diff
changeset
|
381 target[KEY_VERSION] = static_cast<int>(METADATA_VERSION); |
e8dea04df69b
caching OHIF dicom-json as metadata
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
8
diff
changeset
|
382 |
e8dea04df69b
caching OHIF dicom-json as metadata
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
8
diff
changeset
|
383 for (TagsDictionary::const_iterator it = allTags_.begin(); it != allTags_.end(); ++it) |
e8dea04df69b
caching OHIF dicom-json as metadata
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
8
diff
changeset
|
384 { |
e8dea04df69b
caching OHIF dicom-json as metadata
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
8
diff
changeset
|
385 ParseTagFromOrthanc(target, it->first, it->first.Format(), it->second.GetType(), source); |
e8dea04df69b
caching OHIF dicom-json as metadata
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
8
diff
changeset
|
386 } |
3
fdb8c6c420d0
skeleton for optimization
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
2
diff
changeset
|
387 |
9
e8dea04df69b
caching OHIF dicom-json as metadata
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
8
diff
changeset
|
388 /** |
e8dea04df69b
caching OHIF dicom-json as metadata
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
8
diff
changeset
|
389 * This is a sequence for PET scans that is manually injected, to be |
e8dea04df69b
caching OHIF dicom-json as metadata
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
8
diff
changeset
|
390 * used in function "getPTImageIdInstanceMetadata()" of |
e8dea04df69b
caching OHIF dicom-json as metadata
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
8
diff
changeset
|
391 * "extensions/default/src/getPTImageIdInstanceMetadata.ts" |
e8dea04df69b
caching OHIF dicom-json as metadata
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
8
diff
changeset
|
392 **/ |
e8dea04df69b
caching OHIF dicom-json as metadata
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
8
diff
changeset
|
393 static const Orthanc::DicomTag RADIONUCLIDE_HALF_LIFE(0x0018, 0x1075); |
e8dea04df69b
caching OHIF dicom-json as metadata
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
8
diff
changeset
|
394 static const Orthanc::DicomTag RADIONUCLIDE_TOTAL_DOSE(0x0018, 0x1074); |
e8dea04df69b
caching OHIF dicom-json as metadata
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
8
diff
changeset
|
395 static const Orthanc::DicomTag RADIOPHARMACEUTICAL_START_DATETIME(0x0018, 0x1078); |
e8dea04df69b
caching OHIF dicom-json as metadata
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
8
diff
changeset
|
396 static const Orthanc::DicomTag RADIOPHARMACEUTICAL_START_TIME(0x0018, 0x1072); |
e8dea04df69b
caching OHIF dicom-json as metadata
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
8
diff
changeset
|
397 |
e8dea04df69b
caching OHIF dicom-json as metadata
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
8
diff
changeset
|
398 if (source.isMember(RADIOPHARMACEUTICAL_INFORMATION_SEQUENCE.Format())) |
e8dea04df69b
caching OHIF dicom-json as metadata
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
8
diff
changeset
|
399 { |
e8dea04df69b
caching OHIF dicom-json as metadata
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
8
diff
changeset
|
400 const Json::Value& pharma = source[RADIOPHARMACEUTICAL_INFORMATION_SEQUENCE.Format()]; |
e8dea04df69b
caching OHIF dicom-json as metadata
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
8
diff
changeset
|
401 if (pharma.type() == Json::arrayValue && |
e8dea04df69b
caching OHIF dicom-json as metadata
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
8
diff
changeset
|
402 pharma.size() > 0 && |
e8dea04df69b
caching OHIF dicom-json as metadata
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
8
diff
changeset
|
403 pharma[0].type() == Json::objectValue) |
e8dea04df69b
caching OHIF dicom-json as metadata
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
8
diff
changeset
|
404 { |
e8dea04df69b
caching OHIF dicom-json as metadata
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
8
diff
changeset
|
405 Json::Value info; |
e8dea04df69b
caching OHIF dicom-json as metadata
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
8
diff
changeset
|
406 if (ParseTagFromOrthanc(info, RADIONUCLIDE_HALF_LIFE, "RadionuclideHalfLife", DataType_Float, pharma[0]) && |
e8dea04df69b
caching OHIF dicom-json as metadata
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
8
diff
changeset
|
407 ParseTagFromOrthanc(info, RADIONUCLIDE_TOTAL_DOSE, "RadionuclideTotalDose", DataType_Float, pharma[0]) && |
e8dea04df69b
caching OHIF dicom-json as metadata
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
8
diff
changeset
|
408 (ParseTagFromOrthanc(info, RADIOPHARMACEUTICAL_START_DATETIME, "RadiopharmaceuticalStartDateTime", DataType_String, pharma[0]) || |
e8dea04df69b
caching OHIF dicom-json as metadata
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
8
diff
changeset
|
409 ParseTagFromOrthanc(info, RADIOPHARMACEUTICAL_START_TIME, "RadiopharmaceuticalStartTime", DataType_String, pharma[0]))) |
e8dea04df69b
caching OHIF dicom-json as metadata
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
8
diff
changeset
|
410 { |
e8dea04df69b
caching OHIF dicom-json as metadata
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
8
diff
changeset
|
411 Json::Value sequence = Json::arrayValue; |
e8dea04df69b
caching OHIF dicom-json as metadata
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
8
diff
changeset
|
412 sequence.append(info); |
e8dea04df69b
caching OHIF dicom-json as metadata
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
8
diff
changeset
|
413 |
e8dea04df69b
caching OHIF dicom-json as metadata
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
8
diff
changeset
|
414 target[RADIOPHARMACEUTICAL_INFORMATION_SEQUENCE.Format()] = sequence; |
e8dea04df69b
caching OHIF dicom-json as metadata
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
8
diff
changeset
|
415 } |
e8dea04df69b
caching OHIF dicom-json as metadata
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
8
diff
changeset
|
416 } |
e8dea04df69b
caching OHIF dicom-json as metadata
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
8
diff
changeset
|
417 } |
e8dea04df69b
caching OHIF dicom-json as metadata
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
8
diff
changeset
|
418 |
e8dea04df69b
caching OHIF dicom-json as metadata
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
8
diff
changeset
|
419 return true; |
e8dea04df69b
caching OHIF dicom-json as metadata
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
8
diff
changeset
|
420 } |
e8dea04df69b
caching OHIF dicom-json as metadata
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
8
diff
changeset
|
421 } |
e8dea04df69b
caching OHIF dicom-json as metadata
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
8
diff
changeset
|
422 |
e8dea04df69b
caching OHIF dicom-json as metadata
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
8
diff
changeset
|
423 |
e8dea04df69b
caching OHIF dicom-json as metadata
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
8
diff
changeset
|
424 static std::string GetCacheUri(const std::string& instanceId) |
e8dea04df69b
caching OHIF dicom-json as metadata
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
8
diff
changeset
|
425 { |
e8dea04df69b
caching OHIF dicom-json as metadata
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
8
diff
changeset
|
426 return "/instances/" + instanceId + "/metadata/" + METADATA_OHIF; |
e8dea04df69b
caching OHIF dicom-json as metadata
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
8
diff
changeset
|
427 } |
e8dea04df69b
caching OHIF dicom-json as metadata
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
8
diff
changeset
|
428 |
e8dea04df69b
caching OHIF dicom-json as metadata
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
8
diff
changeset
|
429 |
e8dea04df69b
caching OHIF dicom-json as metadata
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
8
diff
changeset
|
430 static void CacheAsMetadata(const Json::Value& instanceTags, |
e8dea04df69b
caching OHIF dicom-json as metadata
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
8
diff
changeset
|
431 const std::string& instanceId) |
e8dea04df69b
caching OHIF dicom-json as metadata
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
8
diff
changeset
|
432 { |
e8dea04df69b
caching OHIF dicom-json as metadata
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
8
diff
changeset
|
433 std::string uncompressed; |
e8dea04df69b
caching OHIF dicom-json as metadata
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
8
diff
changeset
|
434 Orthanc::Toolbox::WriteFastJson(uncompressed, instanceTags); |
e8dea04df69b
caching OHIF dicom-json as metadata
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
8
diff
changeset
|
435 |
e8dea04df69b
caching OHIF dicom-json as metadata
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
8
diff
changeset
|
436 std::string compressed; |
e8dea04df69b
caching OHIF dicom-json as metadata
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
8
diff
changeset
|
437 Orthanc::GzipCompressor compressor; |
e8dea04df69b
caching OHIF dicom-json as metadata
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
8
diff
changeset
|
438 Orthanc::IBufferCompressor::Compress(compressed, compressor, uncompressed); |
e8dea04df69b
caching OHIF dicom-json as metadata
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
8
diff
changeset
|
439 |
e8dea04df69b
caching OHIF dicom-json as metadata
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
8
diff
changeset
|
440 std::string metadata; |
e8dea04df69b
caching OHIF dicom-json as metadata
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
8
diff
changeset
|
441 Orthanc::Toolbox::EncodeBase64(metadata, compressed); |
e8dea04df69b
caching OHIF dicom-json as metadata
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
8
diff
changeset
|
442 |
e8dea04df69b
caching OHIF dicom-json as metadata
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
8
diff
changeset
|
443 Json::Value answer; |
e8dea04df69b
caching OHIF dicom-json as metadata
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
8
diff
changeset
|
444 OrthancPlugins::RestApiPut(answer, GetCacheUri(instanceId), metadata.c_str(), metadata.size(), false); |
e8dea04df69b
caching OHIF dicom-json as metadata
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
8
diff
changeset
|
445 } |
e8dea04df69b
caching OHIF dicom-json as metadata
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
8
diff
changeset
|
446 |
e8dea04df69b
caching OHIF dicom-json as metadata
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
8
diff
changeset
|
447 |
e8dea04df69b
caching OHIF dicom-json as metadata
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
8
diff
changeset
|
448 static bool GetOhifInstance(Json::Value& target, |
e8dea04df69b
caching OHIF dicom-json as metadata
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
8
diff
changeset
|
449 const std::string& instanceId) |
e8dea04df69b
caching OHIF dicom-json as metadata
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
8
diff
changeset
|
450 { |
e8dea04df69b
caching OHIF dicom-json as metadata
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
8
diff
changeset
|
451 const std::string uri = GetCacheUri(instanceId); |
e8dea04df69b
caching OHIF dicom-json as metadata
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
8
diff
changeset
|
452 |
e8dea04df69b
caching OHIF dicom-json as metadata
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
8
diff
changeset
|
453 std::string metadata; |
e8dea04df69b
caching OHIF dicom-json as metadata
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
8
diff
changeset
|
454 |
e8dea04df69b
caching OHIF dicom-json as metadata
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
8
diff
changeset
|
455 if (OrthancPlugins::RestApiGetString(metadata, uri, false)) |
3
fdb8c6c420d0
skeleton for optimization
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
2
diff
changeset
|
456 { |
9
e8dea04df69b
caching OHIF dicom-json as metadata
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
8
diff
changeset
|
457 try |
e8dea04df69b
caching OHIF dicom-json as metadata
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
8
diff
changeset
|
458 { |
e8dea04df69b
caching OHIF dicom-json as metadata
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
8
diff
changeset
|
459 std::string compressed; |
e8dea04df69b
caching OHIF dicom-json as metadata
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
8
diff
changeset
|
460 Orthanc::Toolbox::DecodeBase64(compressed, metadata); |
e8dea04df69b
caching OHIF dicom-json as metadata
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
8
diff
changeset
|
461 |
e8dea04df69b
caching OHIF dicom-json as metadata
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
8
diff
changeset
|
462 std::string uncompressed; |
e8dea04df69b
caching OHIF dicom-json as metadata
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
8
diff
changeset
|
463 Orthanc::GzipCompressor compressor; |
e8dea04df69b
caching OHIF dicom-json as metadata
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
8
diff
changeset
|
464 Orthanc::IBufferCompressor::Uncompress(uncompressed, compressor, compressed); |
e8dea04df69b
caching OHIF dicom-json as metadata
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
8
diff
changeset
|
465 |
e8dea04df69b
caching OHIF dicom-json as metadata
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
8
diff
changeset
|
466 if (Orthanc::Toolbox::ReadJson(target, uncompressed) && |
e8dea04df69b
caching OHIF dicom-json as metadata
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
8
diff
changeset
|
467 target.isMember(KEY_VERSION) && |
e8dea04df69b
caching OHIF dicom-json as metadata
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
8
diff
changeset
|
468 target[KEY_VERSION].type() == Json::intValue && |
e8dea04df69b
caching OHIF dicom-json as metadata
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
8
diff
changeset
|
469 target[KEY_VERSION].asInt() == METADATA_VERSION) |
e8dea04df69b
caching OHIF dicom-json as metadata
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
8
diff
changeset
|
470 { |
e8dea04df69b
caching OHIF dicom-json as metadata
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
8
diff
changeset
|
471 // Success, we can reuse the cached value |
e8dea04df69b
caching OHIF dicom-json as metadata
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
8
diff
changeset
|
472 return true; |
e8dea04df69b
caching OHIF dicom-json as metadata
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
8
diff
changeset
|
473 } |
e8dea04df69b
caching OHIF dicom-json as metadata
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
8
diff
changeset
|
474 } |
e8dea04df69b
caching OHIF dicom-json as metadata
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
8
diff
changeset
|
475 catch (Orthanc::OrthancException&) |
e8dea04df69b
caching OHIF dicom-json as metadata
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
8
diff
changeset
|
476 { |
e8dea04df69b
caching OHIF dicom-json as metadata
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
8
diff
changeset
|
477 } |
e8dea04df69b
caching OHIF dicom-json as metadata
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
8
diff
changeset
|
478 |
e8dea04df69b
caching OHIF dicom-json as metadata
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
8
diff
changeset
|
479 // Remove corrupted or metadata with an earlier version |
e8dea04df69b
caching OHIF dicom-json as metadata
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
8
diff
changeset
|
480 OrthancPlugins::RestApiDelete(uri, false); |
8
cc4c81d08bf0
added missing tags for PET
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
7
diff
changeset
|
481 } |
3
fdb8c6c420d0
skeleton for optimization
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
2
diff
changeset
|
482 |
9
e8dea04df69b
caching OHIF dicom-json as metadata
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
8
diff
changeset
|
483 if (EncodeOhifInstance(target, instanceId)) |
8
cc4c81d08bf0
added missing tags for PET
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
7
diff
changeset
|
484 { |
9
e8dea04df69b
caching OHIF dicom-json as metadata
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
8
diff
changeset
|
485 CacheAsMetadata(target, instanceId); |
e8dea04df69b
caching OHIF dicom-json as metadata
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
8
diff
changeset
|
486 return true; |
3
fdb8c6c420d0
skeleton for optimization
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
2
diff
changeset
|
487 } |
9
e8dea04df69b
caching OHIF dicom-json as metadata
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
8
diff
changeset
|
488 else |
e8dea04df69b
caching OHIF dicom-json as metadata
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
8
diff
changeset
|
489 { |
e8dea04df69b
caching OHIF dicom-json as metadata
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
8
diff
changeset
|
490 return false; |
e8dea04df69b
caching OHIF dicom-json as metadata
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
8
diff
changeset
|
491 } |
3
fdb8c6c420d0
skeleton for optimization
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
2
diff
changeset
|
492 } |
fdb8c6c420d0
skeleton for optimization
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
2
diff
changeset
|
493 |
fdb8c6c420d0
skeleton for optimization
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
2
diff
changeset
|
494 |
10
5d5caf89eb5b
added thread to precompute metadata
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
9
diff
changeset
|
495 static ResourcesCache cache_; |
12
6115cfbece79
added option "Configuration"
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
11
diff
changeset
|
496 static std::string userConfiguration_; |
10
5d5caf89eb5b
added thread to precompute metadata
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
9
diff
changeset
|
497 static std::string routerBasename_; |
11
16b9f1ff491d
added configuration option "Preload"
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
10
diff
changeset
|
498 static DataSource dataSource_; |
16b9f1ff491d
added configuration option "Preload"
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
10
diff
changeset
|
499 static bool preload_; |
10
5d5caf89eb5b
added thread to precompute metadata
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
9
diff
changeset
|
500 static boost::thread metadataThread_; |
5d5caf89eb5b
added thread to precompute metadata
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
9
diff
changeset
|
501 static Orthanc::SharedMessageQueue pendingInstances_; |
5d5caf89eb5b
added thread to precompute metadata
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
9
diff
changeset
|
502 static bool continueThread_; |
0 | 503 |
504 void ServeFile(OrthancPluginRestOutput* output, | |
505 const char* url, | |
506 const OrthancPluginHttpRequest* request) | |
507 { | |
508 OrthancPluginContext* context = OrthancPlugins::GetGlobalContext(); | |
509 | |
510 // The next 3 HTTP headers are required to enable SharedArrayBuffer | |
511 // (https://web.dev/coop-coep/) | |
512 OrthancPluginSetHttpHeader(context, output, "Cross-Origin-Embedder-Policy", "require-corp"); | |
513 OrthancPluginSetHttpHeader(context, output, "Cross-Origin-Opener-Policy", "same-origin"); | |
514 OrthancPluginSetHttpHeader(context, output, "Cross-Origin-Resource-Policy", "same-origin"); | |
515 | |
6
e8e7ba4371e3
fix access to OHIF study list
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
5
diff
changeset
|
516 std::string uri; |
e8e7ba4371e3
fix access to OHIF study list
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
5
diff
changeset
|
517 if (request->groupsCount > 0) |
e8e7ba4371e3
fix access to OHIF study list
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
5
diff
changeset
|
518 { |
e8e7ba4371e3
fix access to OHIF study list
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
5
diff
changeset
|
519 uri = request->groups[0]; |
e8e7ba4371e3
fix access to OHIF study list
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
5
diff
changeset
|
520 } |
0 | 521 |
522 if (uri == "app-config.js") | |
523 { | |
12
6115cfbece79
added option "Configuration"
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
11
diff
changeset
|
524 std::string system; |
0 | 525 Orthanc::EmbeddedResources::GetFileResource(system, Orthanc::EmbeddedResources::APP_CONFIG_SYSTEM); |
12
6115cfbece79
added option "Configuration"
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
11
diff
changeset
|
526 |
2
cbc4be362700
added configuration option "RouterBasename"
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
0
diff
changeset
|
527 std::map<std::string, std::string> dictionary; |
cbc4be362700
added configuration option "RouterBasename"
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
0
diff
changeset
|
528 dictionary["ROUTER_BASENAME"] = routerBasename_; |
11
16b9f1ff491d
added configuration option "Preload"
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
10
diff
changeset
|
529 dictionary["USE_DICOM_WEB"] = (dataSource_ == DataSource_DicomWeb ? "true" : "false"); |
2
cbc4be362700
added configuration option "RouterBasename"
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
0
diff
changeset
|
530 |
cbc4be362700
added configuration option "RouterBasename"
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
0
diff
changeset
|
531 system = Orthanc::Toolbox::SubstituteVariables(system, dictionary); |
cbc4be362700
added configuration option "RouterBasename"
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
0
diff
changeset
|
532 |
12
6115cfbece79
added option "Configuration"
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
11
diff
changeset
|
533 std::string s = (userConfiguration_ + "\n" + system); |
27
bf4e5434567c
Fixed wrong MIME type for app-config.js that prevents the OHIF viewer from loading with Orthanc 1.12.2
Alain Mazy <am@osimis.io>
parents:
13
diff
changeset
|
534 OrthancPluginAnswerBuffer(context, output, s.c_str(), s.size(), "text/javascript"); |
0 | 535 } |
6
e8e7ba4371e3
fix access to OHIF study list
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
5
diff
changeset
|
536 else if (uri == "" || // Study list |
e8e7ba4371e3
fix access to OHIF study list
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
5
diff
changeset
|
537 uri == "tmtv" || // Total metabolic tumor volume |
e8e7ba4371e3
fix access to OHIF study list
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
5
diff
changeset
|
538 uri == "viewer") // Default viewer (including MPR) |
e8e7ba4371e3
fix access to OHIF study list
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
5
diff
changeset
|
539 { |
e8e7ba4371e3
fix access to OHIF study list
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
5
diff
changeset
|
540 // Those correspond to the different modes of the OHIF platform: |
e8e7ba4371e3
fix access to OHIF study list
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
5
diff
changeset
|
541 // https://v3-docs.ohif.org/platform/modes/ |
0 | 542 cache_.Answer(context, output, "index.html"); |
543 } | |
544 else | |
545 { | |
546 cache_.Answer(context, output, uri); | |
547 } | |
548 } | |
549 | |
550 | |
5
8c1fe0ca24f5
added the possibility to replace DICOMweb by DICOM JSON
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
4
diff
changeset
|
551 static void GenerateOhifStudy(Json::Value& target, |
8c1fe0ca24f5
added the possibility to replace DICOMweb by DICOM JSON
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
4
diff
changeset
|
552 const std::string& studyId) |
8c1fe0ca24f5
added the possibility to replace DICOMweb by DICOM JSON
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
4
diff
changeset
|
553 { |
8c1fe0ca24f5
added the possibility to replace DICOMweb by DICOM JSON
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
4
diff
changeset
|
554 // https://v3-docs.ohif.org/configuration/dataSources/dicom-json |
8c1fe0ca24f5
added the possibility to replace DICOMweb by DICOM JSON
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
4
diff
changeset
|
555 static const char* const KEY_ID = "ID"; |
8c1fe0ca24f5
added the possibility to replace DICOMweb by DICOM JSON
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
4
diff
changeset
|
556 const std::string KEY_PATIENT_ID = Orthanc::DICOM_TAG_PATIENT_ID.Format(); |
8c1fe0ca24f5
added the possibility to replace DICOMweb by DICOM JSON
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
4
diff
changeset
|
557 const std::string KEY_STUDY_INSTANCE_UID = Orthanc::DICOM_TAG_STUDY_INSTANCE_UID.Format(); |
8c1fe0ca24f5
added the possibility to replace DICOMweb by DICOM JSON
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
4
diff
changeset
|
558 const std::string KEY_SERIES_INSTANCE_UID = Orthanc::DICOM_TAG_SERIES_INSTANCE_UID.Format(); |
8c1fe0ca24f5
added the possibility to replace DICOMweb by DICOM JSON
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
4
diff
changeset
|
559 const std::string KEY_SOP_INSTANCE_UID = Orthanc::DICOM_TAG_SOP_INSTANCE_UID.Format(); |
8c1fe0ca24f5
added the possibility to replace DICOMweb by DICOM JSON
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
4
diff
changeset
|
560 |
8c1fe0ca24f5
added the possibility to replace DICOMweb by DICOM JSON
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
4
diff
changeset
|
561 Json::Value instancesIds; |
8c1fe0ca24f5
added the possibility to replace DICOMweb by DICOM JSON
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
4
diff
changeset
|
562 if (!OrthancPlugins::RestApiGet(instancesIds, "/studies/" + studyId + "/instances", false)) |
8c1fe0ca24f5
added the possibility to replace DICOMweb by DICOM JSON
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
4
diff
changeset
|
563 { |
8c1fe0ca24f5
added the possibility to replace DICOMweb by DICOM JSON
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
4
diff
changeset
|
564 throw Orthanc::OrthancException(Orthanc::ErrorCode_UnknownResource); |
8c1fe0ca24f5
added the possibility to replace DICOMweb by DICOM JSON
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
4
diff
changeset
|
565 } |
8c1fe0ca24f5
added the possibility to replace DICOMweb by DICOM JSON
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
4
diff
changeset
|
566 |
8c1fe0ca24f5
added the possibility to replace DICOMweb by DICOM JSON
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
4
diff
changeset
|
567 if (instancesIds.type() != Json::arrayValue) |
8c1fe0ca24f5
added the possibility to replace DICOMweb by DICOM JSON
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
4
diff
changeset
|
568 { |
8c1fe0ca24f5
added the possibility to replace DICOMweb by DICOM JSON
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
4
diff
changeset
|
569 throw Orthanc::OrthancException(Orthanc::ErrorCode_InternalError); |
8c1fe0ca24f5
added the possibility to replace DICOMweb by DICOM JSON
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
4
diff
changeset
|
570 } |
8c1fe0ca24f5
added the possibility to replace DICOMweb by DICOM JSON
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
4
diff
changeset
|
571 |
8c1fe0ca24f5
added the possibility to replace DICOMweb by DICOM JSON
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
4
diff
changeset
|
572 std::vector<Json::Value> instancesTags; |
8c1fe0ca24f5
added the possibility to replace DICOMweb by DICOM JSON
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
4
diff
changeset
|
573 instancesTags.reserve(instancesIds.size()); |
8c1fe0ca24f5
added the possibility to replace DICOMweb by DICOM JSON
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
4
diff
changeset
|
574 |
8c1fe0ca24f5
added the possibility to replace DICOMweb by DICOM JSON
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
4
diff
changeset
|
575 for (Json::ArrayIndex i = 0; i < instancesIds.size(); i++) |
8c1fe0ca24f5
added the possibility to replace DICOMweb by DICOM JSON
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
4
diff
changeset
|
576 { |
8c1fe0ca24f5
added the possibility to replace DICOMweb by DICOM JSON
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
4
diff
changeset
|
577 if (instancesIds[i].type() != Json::objectValue || |
8c1fe0ca24f5
added the possibility to replace DICOMweb by DICOM JSON
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
4
diff
changeset
|
578 !instancesIds[i].isMember(KEY_ID) || |
8c1fe0ca24f5
added the possibility to replace DICOMweb by DICOM JSON
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
4
diff
changeset
|
579 instancesIds[i][KEY_ID].type() != Json::stringValue) |
8c1fe0ca24f5
added the possibility to replace DICOMweb by DICOM JSON
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
4
diff
changeset
|
580 { |
8c1fe0ca24f5
added the possibility to replace DICOMweb by DICOM JSON
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
4
diff
changeset
|
581 throw Orthanc::OrthancException(Orthanc::ErrorCode_InternalError); |
8c1fe0ca24f5
added the possibility to replace DICOMweb by DICOM JSON
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
4
diff
changeset
|
582 } |
8c1fe0ca24f5
added the possibility to replace DICOMweb by DICOM JSON
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
4
diff
changeset
|
583 |
8c1fe0ca24f5
added the possibility to replace DICOMweb by DICOM JSON
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
4
diff
changeset
|
584 Json::Value t; |
9
e8dea04df69b
caching OHIF dicom-json as metadata
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
8
diff
changeset
|
585 if (GetOhifInstance(t, instancesIds[i][KEY_ID].asString())) |
5
8c1fe0ca24f5
added the possibility to replace DICOMweb by DICOM JSON
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
4
diff
changeset
|
586 { |
8c1fe0ca24f5
added the possibility to replace DICOMweb by DICOM JSON
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
4
diff
changeset
|
587 instancesTags.push_back(t); |
8c1fe0ca24f5
added the possibility to replace DICOMweb by DICOM JSON
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
4
diff
changeset
|
588 } |
8c1fe0ca24f5
added the possibility to replace DICOMweb by DICOM JSON
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
4
diff
changeset
|
589 } |
8c1fe0ca24f5
added the possibility to replace DICOMweb by DICOM JSON
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
4
diff
changeset
|
590 |
8c1fe0ca24f5
added the possibility to replace DICOMweb by DICOM JSON
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
4
diff
changeset
|
591 typedef std::list<const Json::Value*> ListOfResources; |
8c1fe0ca24f5
added the possibility to replace DICOMweb by DICOM JSON
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
4
diff
changeset
|
592 typedef std::map<std::string, ListOfResources> MapOfResources; |
8c1fe0ca24f5
added the possibility to replace DICOMweb by DICOM JSON
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
4
diff
changeset
|
593 |
8c1fe0ca24f5
added the possibility to replace DICOMweb by DICOM JSON
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
4
diff
changeset
|
594 MapOfResources studies; |
8c1fe0ca24f5
added the possibility to replace DICOMweb by DICOM JSON
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
4
diff
changeset
|
595 for (Json::ArrayIndex i = 0; i < instancesTags.size(); i++) |
8c1fe0ca24f5
added the possibility to replace DICOMweb by DICOM JSON
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
4
diff
changeset
|
596 { |
8c1fe0ca24f5
added the possibility to replace DICOMweb by DICOM JSON
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
4
diff
changeset
|
597 if (instancesTags[i].isMember(KEY_STUDY_INSTANCE_UID)) |
8c1fe0ca24f5
added the possibility to replace DICOMweb by DICOM JSON
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
4
diff
changeset
|
598 { |
8c1fe0ca24f5
added the possibility to replace DICOMweb by DICOM JSON
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
4
diff
changeset
|
599 if (instancesTags[i][KEY_STUDY_INSTANCE_UID].type() != Json::stringValue) |
8c1fe0ca24f5
added the possibility to replace DICOMweb by DICOM JSON
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
4
diff
changeset
|
600 { |
8c1fe0ca24f5
added the possibility to replace DICOMweb by DICOM JSON
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
4
diff
changeset
|
601 throw Orthanc::OrthancException(Orthanc::ErrorCode_InternalError); |
8c1fe0ca24f5
added the possibility to replace DICOMweb by DICOM JSON
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
4
diff
changeset
|
602 } |
8c1fe0ca24f5
added the possibility to replace DICOMweb by DICOM JSON
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
4
diff
changeset
|
603 else |
8c1fe0ca24f5
added the possibility to replace DICOMweb by DICOM JSON
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
4
diff
changeset
|
604 { |
8c1fe0ca24f5
added the possibility to replace DICOMweb by DICOM JSON
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
4
diff
changeset
|
605 const std::string& studyInstanceUid = instancesTags[i][KEY_STUDY_INSTANCE_UID].asString(); |
8c1fe0ca24f5
added the possibility to replace DICOMweb by DICOM JSON
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
4
diff
changeset
|
606 studies[studyInstanceUid].push_back(&instancesTags[i]); |
8c1fe0ca24f5
added the possibility to replace DICOMweb by DICOM JSON
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
4
diff
changeset
|
607 } |
8c1fe0ca24f5
added the possibility to replace DICOMweb by DICOM JSON
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
4
diff
changeset
|
608 } |
8c1fe0ca24f5
added the possibility to replace DICOMweb by DICOM JSON
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
4
diff
changeset
|
609 } |
8c1fe0ca24f5
added the possibility to replace DICOMweb by DICOM JSON
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
4
diff
changeset
|
610 |
8c1fe0ca24f5
added the possibility to replace DICOMweb by DICOM JSON
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
4
diff
changeset
|
611 target["studies"] = Json::arrayValue; |
8c1fe0ca24f5
added the possibility to replace DICOMweb by DICOM JSON
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
4
diff
changeset
|
612 |
8c1fe0ca24f5
added the possibility to replace DICOMweb by DICOM JSON
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
4
diff
changeset
|
613 for (MapOfResources::const_iterator it = studies.begin(); it != studies.end(); ++it) |
8c1fe0ca24f5
added the possibility to replace DICOMweb by DICOM JSON
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
4
diff
changeset
|
614 { |
8c1fe0ca24f5
added the possibility to replace DICOMweb by DICOM JSON
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
4
diff
changeset
|
615 if (!it->second.empty()) |
8c1fe0ca24f5
added the possibility to replace DICOMweb by DICOM JSON
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
4
diff
changeset
|
616 { |
8c1fe0ca24f5
added the possibility to replace DICOMweb by DICOM JSON
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
4
diff
changeset
|
617 assert(it->second.front() != NULL); |
8c1fe0ca24f5
added the possibility to replace DICOMweb by DICOM JSON
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
4
diff
changeset
|
618 const Json::Value& firstInstanceInStudy = *it->second.front(); |
8c1fe0ca24f5
added the possibility to replace DICOMweb by DICOM JSON
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
4
diff
changeset
|
619 |
8c1fe0ca24f5
added the possibility to replace DICOMweb by DICOM JSON
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
4
diff
changeset
|
620 Json::Value study = Json::objectValue; |
8c1fe0ca24f5
added the possibility to replace DICOMweb by DICOM JSON
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
4
diff
changeset
|
621 for (TagsDictionary::const_iterator tag = ohifStudyTags_.begin(); tag != ohifStudyTags_.end(); ++tag) |
8c1fe0ca24f5
added the possibility to replace DICOMweb by DICOM JSON
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
4
diff
changeset
|
622 { |
8c1fe0ca24f5
added the possibility to replace DICOMweb by DICOM JSON
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
4
diff
changeset
|
623 if (firstInstanceInStudy.isMember(tag->first.Format())) |
8c1fe0ca24f5
added the possibility to replace DICOMweb by DICOM JSON
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
4
diff
changeset
|
624 { |
8c1fe0ca24f5
added the possibility to replace DICOMweb by DICOM JSON
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
4
diff
changeset
|
625 study[tag->second.GetName()] = firstInstanceInStudy[tag->first.Format()]; |
8c1fe0ca24f5
added the possibility to replace DICOMweb by DICOM JSON
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
4
diff
changeset
|
626 } |
8c1fe0ca24f5
added the possibility to replace DICOMweb by DICOM JSON
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
4
diff
changeset
|
627 } |
8c1fe0ca24f5
added the possibility to replace DICOMweb by DICOM JSON
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
4
diff
changeset
|
628 |
8c1fe0ca24f5
added the possibility to replace DICOMweb by DICOM JSON
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
4
diff
changeset
|
629 MapOfResources seriesInStudy; |
8c1fe0ca24f5
added the possibility to replace DICOMweb by DICOM JSON
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
4
diff
changeset
|
630 for (ListOfResources::const_iterator it2 = it->second.begin(); it2 != it->second.end(); ++it2) |
8c1fe0ca24f5
added the possibility to replace DICOMweb by DICOM JSON
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
4
diff
changeset
|
631 { |
8c1fe0ca24f5
added the possibility to replace DICOMweb by DICOM JSON
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
4
diff
changeset
|
632 assert(*it2 != NULL); |
8c1fe0ca24f5
added the possibility to replace DICOMweb by DICOM JSON
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
4
diff
changeset
|
633 const Json::Value& instanceInStudy = **it2; |
8c1fe0ca24f5
added the possibility to replace DICOMweb by DICOM JSON
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
4
diff
changeset
|
634 |
8c1fe0ca24f5
added the possibility to replace DICOMweb by DICOM JSON
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
4
diff
changeset
|
635 if (instanceInStudy.isMember(KEY_SERIES_INSTANCE_UID)) |
8c1fe0ca24f5
added the possibility to replace DICOMweb by DICOM JSON
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
4
diff
changeset
|
636 { |
8c1fe0ca24f5
added the possibility to replace DICOMweb by DICOM JSON
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
4
diff
changeset
|
637 if (instanceInStudy[KEY_SERIES_INSTANCE_UID].type() != Json::stringValue) |
8c1fe0ca24f5
added the possibility to replace DICOMweb by DICOM JSON
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
4
diff
changeset
|
638 { |
8c1fe0ca24f5
added the possibility to replace DICOMweb by DICOM JSON
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
4
diff
changeset
|
639 throw Orthanc::OrthancException(Orthanc::ErrorCode_InternalError); |
8c1fe0ca24f5
added the possibility to replace DICOMweb by DICOM JSON
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
4
diff
changeset
|
640 } |
8c1fe0ca24f5
added the possibility to replace DICOMweb by DICOM JSON
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
4
diff
changeset
|
641 else |
8c1fe0ca24f5
added the possibility to replace DICOMweb by DICOM JSON
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
4
diff
changeset
|
642 { |
8c1fe0ca24f5
added the possibility to replace DICOMweb by DICOM JSON
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
4
diff
changeset
|
643 const std::string& seriesInstanceUid = instanceInStudy[KEY_SERIES_INSTANCE_UID].asString(); |
8c1fe0ca24f5
added the possibility to replace DICOMweb by DICOM JSON
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
4
diff
changeset
|
644 seriesInStudy[seriesInstanceUid].push_back(&instanceInStudy); |
8c1fe0ca24f5
added the possibility to replace DICOMweb by DICOM JSON
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
4
diff
changeset
|
645 } |
8c1fe0ca24f5
added the possibility to replace DICOMweb by DICOM JSON
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
4
diff
changeset
|
646 } |
8c1fe0ca24f5
added the possibility to replace DICOMweb by DICOM JSON
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
4
diff
changeset
|
647 } |
8c1fe0ca24f5
added the possibility to replace DICOMweb by DICOM JSON
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
4
diff
changeset
|
648 |
8c1fe0ca24f5
added the possibility to replace DICOMweb by DICOM JSON
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
4
diff
changeset
|
649 study["series"] = Json::arrayValue; |
8c1fe0ca24f5
added the possibility to replace DICOMweb by DICOM JSON
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
4
diff
changeset
|
650 |
8c1fe0ca24f5
added the possibility to replace DICOMweb by DICOM JSON
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
4
diff
changeset
|
651 for (MapOfResources::const_iterator it3 = seriesInStudy.begin(); it3 != seriesInStudy.end(); ++it3) |
8c1fe0ca24f5
added the possibility to replace DICOMweb by DICOM JSON
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
4
diff
changeset
|
652 { |
8c1fe0ca24f5
added the possibility to replace DICOMweb by DICOM JSON
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
4
diff
changeset
|
653 if (!it3->second.empty()) |
8c1fe0ca24f5
added the possibility to replace DICOMweb by DICOM JSON
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
4
diff
changeset
|
654 { |
8c1fe0ca24f5
added the possibility to replace DICOMweb by DICOM JSON
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
4
diff
changeset
|
655 assert(it3->second.front() != NULL); |
8c1fe0ca24f5
added the possibility to replace DICOMweb by DICOM JSON
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
4
diff
changeset
|
656 const Json::Value& firstInstanceInSeries = *it3->second.front(); |
8c1fe0ca24f5
added the possibility to replace DICOMweb by DICOM JSON
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
4
diff
changeset
|
657 |
8c1fe0ca24f5
added the possibility to replace DICOMweb by DICOM JSON
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
4
diff
changeset
|
658 Json::Value series = Json::objectValue; |
8c1fe0ca24f5
added the possibility to replace DICOMweb by DICOM JSON
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
4
diff
changeset
|
659 for (TagsDictionary::const_iterator tag = ohifSeriesTags_.begin(); tag != ohifSeriesTags_.end(); ++tag) |
8c1fe0ca24f5
added the possibility to replace DICOMweb by DICOM JSON
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
4
diff
changeset
|
660 { |
8c1fe0ca24f5
added the possibility to replace DICOMweb by DICOM JSON
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
4
diff
changeset
|
661 if (firstInstanceInSeries.isMember(tag->first.Format())) |
8c1fe0ca24f5
added the possibility to replace DICOMweb by DICOM JSON
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
4
diff
changeset
|
662 { |
8c1fe0ca24f5
added the possibility to replace DICOMweb by DICOM JSON
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
4
diff
changeset
|
663 series[tag->second.GetName()] = firstInstanceInSeries[tag->first.Format()]; |
8c1fe0ca24f5
added the possibility to replace DICOMweb by DICOM JSON
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
4
diff
changeset
|
664 } |
8c1fe0ca24f5
added the possibility to replace DICOMweb by DICOM JSON
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
4
diff
changeset
|
665 } |
8c1fe0ca24f5
added the possibility to replace DICOMweb by DICOM JSON
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
4
diff
changeset
|
666 |
8c1fe0ca24f5
added the possibility to replace DICOMweb by DICOM JSON
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
4
diff
changeset
|
667 series["instances"] = Json::arrayValue; |
8c1fe0ca24f5
added the possibility to replace DICOMweb by DICOM JSON
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
4
diff
changeset
|
668 |
8c1fe0ca24f5
added the possibility to replace DICOMweb by DICOM JSON
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
4
diff
changeset
|
669 for (ListOfResources::const_iterator it4 = it3->second.begin(); it4 != it3->second.end(); ++it4) |
8c1fe0ca24f5
added the possibility to replace DICOMweb by DICOM JSON
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
4
diff
changeset
|
670 { |
8c1fe0ca24f5
added the possibility to replace DICOMweb by DICOM JSON
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
4
diff
changeset
|
671 assert(*it4 != NULL); |
8c1fe0ca24f5
added the possibility to replace DICOMweb by DICOM JSON
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
4
diff
changeset
|
672 const Json::Value& instanceInSeries = **it4; |
8c1fe0ca24f5
added the possibility to replace DICOMweb by DICOM JSON
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
4
diff
changeset
|
673 |
8c1fe0ca24f5
added the possibility to replace DICOMweb by DICOM JSON
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
4
diff
changeset
|
674 Json::Value metadata; |
8c1fe0ca24f5
added the possibility to replace DICOMweb by DICOM JSON
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
4
diff
changeset
|
675 for (TagsDictionary::const_iterator tag = ohifInstanceTags_.begin(); tag != ohifInstanceTags_.end(); ++tag) |
8c1fe0ca24f5
added the possibility to replace DICOMweb by DICOM JSON
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
4
diff
changeset
|
676 { |
8c1fe0ca24f5
added the possibility to replace DICOMweb by DICOM JSON
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
4
diff
changeset
|
677 if (instanceInSeries.isMember(tag->first.Format())) |
8c1fe0ca24f5
added the possibility to replace DICOMweb by DICOM JSON
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
4
diff
changeset
|
678 { |
8c1fe0ca24f5
added the possibility to replace DICOMweb by DICOM JSON
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
4
diff
changeset
|
679 metadata[tag->second.GetName()] = instanceInSeries[tag->first.Format()]; |
8c1fe0ca24f5
added the possibility to replace DICOMweb by DICOM JSON
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
4
diff
changeset
|
680 } |
8c1fe0ca24f5
added the possibility to replace DICOMweb by DICOM JSON
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
4
diff
changeset
|
681 } |
8c1fe0ca24f5
added the possibility to replace DICOMweb by DICOM JSON
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
4
diff
changeset
|
682 |
8c1fe0ca24f5
added the possibility to replace DICOMweb by DICOM JSON
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
4
diff
changeset
|
683 Orthanc::DicomInstanceHasher hasher(instanceInSeries[KEY_PATIENT_ID].asString(), |
8c1fe0ca24f5
added the possibility to replace DICOMweb by DICOM JSON
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
4
diff
changeset
|
684 instanceInSeries[KEY_STUDY_INSTANCE_UID].asString(), |
8c1fe0ca24f5
added the possibility to replace DICOMweb by DICOM JSON
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
4
diff
changeset
|
685 instanceInSeries[KEY_SERIES_INSTANCE_UID].asString(), |
8c1fe0ca24f5
added the possibility to replace DICOMweb by DICOM JSON
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
4
diff
changeset
|
686 instanceInSeries[KEY_SOP_INSTANCE_UID].asString()); |
8c1fe0ca24f5
added the possibility to replace DICOMweb by DICOM JSON
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
4
diff
changeset
|
687 |
8c1fe0ca24f5
added the possibility to replace DICOMweb by DICOM JSON
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
4
diff
changeset
|
688 Json::Value instance = Json::objectValue; |
8c1fe0ca24f5
added the possibility to replace DICOMweb by DICOM JSON
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
4
diff
changeset
|
689 instance["metadata"] = metadata; |
8c1fe0ca24f5
added the possibility to replace DICOMweb by DICOM JSON
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
4
diff
changeset
|
690 instance["url"] = "dicomweb:../instances/" + hasher.HashInstance() + "/file"; |
8c1fe0ca24f5
added the possibility to replace DICOMweb by DICOM JSON
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
4
diff
changeset
|
691 |
8c1fe0ca24f5
added the possibility to replace DICOMweb by DICOM JSON
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
4
diff
changeset
|
692 series["instances"].append(instance); |
8c1fe0ca24f5
added the possibility to replace DICOMweb by DICOM JSON
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
4
diff
changeset
|
693 } |
8c1fe0ca24f5
added the possibility to replace DICOMweb by DICOM JSON
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
4
diff
changeset
|
694 |
8c1fe0ca24f5
added the possibility to replace DICOMweb by DICOM JSON
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
4
diff
changeset
|
695 study["series"].append(series); |
8c1fe0ca24f5
added the possibility to replace DICOMweb by DICOM JSON
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
4
diff
changeset
|
696 } |
8c1fe0ca24f5
added the possibility to replace DICOMweb by DICOM JSON
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
4
diff
changeset
|
697 } |
8c1fe0ca24f5
added the possibility to replace DICOMweb by DICOM JSON
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
4
diff
changeset
|
698 |
8c1fe0ca24f5
added the possibility to replace DICOMweb by DICOM JSON
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
4
diff
changeset
|
699 target["studies"].append(study); |
8c1fe0ca24f5
added the possibility to replace DICOMweb by DICOM JSON
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
4
diff
changeset
|
700 } |
8c1fe0ca24f5
added the possibility to replace DICOMweb by DICOM JSON
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
4
diff
changeset
|
701 } |
8c1fe0ca24f5
added the possibility to replace DICOMweb by DICOM JSON
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
4
diff
changeset
|
702 } |
8c1fe0ca24f5
added the possibility to replace DICOMweb by DICOM JSON
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
4
diff
changeset
|
703 |
8c1fe0ca24f5
added the possibility to replace DICOMweb by DICOM JSON
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
4
diff
changeset
|
704 |
8c1fe0ca24f5
added the possibility to replace DICOMweb by DICOM JSON
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
4
diff
changeset
|
705 void GetOhifStudy(OrthancPluginRestOutput* output, |
8c1fe0ca24f5
added the possibility to replace DICOMweb by DICOM JSON
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
4
diff
changeset
|
706 const char* url, |
8c1fe0ca24f5
added the possibility to replace DICOMweb by DICOM JSON
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
4
diff
changeset
|
707 const OrthancPluginHttpRequest* request) |
8c1fe0ca24f5
added the possibility to replace DICOMweb by DICOM JSON
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
4
diff
changeset
|
708 { |
8c1fe0ca24f5
added the possibility to replace DICOMweb by DICOM JSON
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
4
diff
changeset
|
709 OrthancPluginContext* context = OrthancPlugins::GetGlobalContext(); |
8c1fe0ca24f5
added the possibility to replace DICOMweb by DICOM JSON
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
4
diff
changeset
|
710 |
8c1fe0ca24f5
added the possibility to replace DICOMweb by DICOM JSON
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
4
diff
changeset
|
711 const std::string studyId = request->groups[0]; |
8c1fe0ca24f5
added the possibility to replace DICOMweb by DICOM JSON
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
4
diff
changeset
|
712 |
8c1fe0ca24f5
added the possibility to replace DICOMweb by DICOM JSON
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
4
diff
changeset
|
713 Json::Value v; |
8c1fe0ca24f5
added the possibility to replace DICOMweb by DICOM JSON
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
4
diff
changeset
|
714 GenerateOhifStudy(v, studyId); |
8c1fe0ca24f5
added the possibility to replace DICOMweb by DICOM JSON
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
4
diff
changeset
|
715 |
8c1fe0ca24f5
added the possibility to replace DICOMweb by DICOM JSON
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
4
diff
changeset
|
716 std::string s; |
8c1fe0ca24f5
added the possibility to replace DICOMweb by DICOM JSON
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
4
diff
changeset
|
717 Orthanc::Toolbox::WriteFastJson(s, v); |
8c1fe0ca24f5
added the possibility to replace DICOMweb by DICOM JSON
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
4
diff
changeset
|
718 |
8c1fe0ca24f5
added the possibility to replace DICOMweb by DICOM JSON
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
4
diff
changeset
|
719 OrthancPluginAnswerBuffer(context, output, s.c_str(), s.size(), "application/json"); |
8c1fe0ca24f5
added the possibility to replace DICOMweb by DICOM JSON
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
4
diff
changeset
|
720 } |
8c1fe0ca24f5
added the possibility to replace DICOMweb by DICOM JSON
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
4
diff
changeset
|
721 |
8c1fe0ca24f5
added the possibility to replace DICOMweb by DICOM JSON
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
4
diff
changeset
|
722 |
10
5d5caf89eb5b
added thread to precompute metadata
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
9
diff
changeset
|
723 static void MetadataThread() |
5d5caf89eb5b
added thread to precompute metadata
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
9
diff
changeset
|
724 { |
5d5caf89eb5b
added thread to precompute metadata
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
9
diff
changeset
|
725 while (continueThread_) |
5d5caf89eb5b
added thread to precompute metadata
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
9
diff
changeset
|
726 { |
5d5caf89eb5b
added thread to precompute metadata
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
9
diff
changeset
|
727 std::unique_ptr<Orthanc::IDynamicObject> instance(pendingInstances_.Dequeue(100)); |
5d5caf89eb5b
added thread to precompute metadata
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
9
diff
changeset
|
728 if (instance.get() != NULL) |
5d5caf89eb5b
added thread to precompute metadata
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
9
diff
changeset
|
729 { |
5d5caf89eb5b
added thread to precompute metadata
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
9
diff
changeset
|
730 const std::string instanceId = dynamic_cast<Orthanc::SingleValueObject<std::string>&>(*instance).GetValue(); |
5d5caf89eb5b
added thread to precompute metadata
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
9
diff
changeset
|
731 const std::string uri = GetCacheUri(instanceId); |
5d5caf89eb5b
added thread to precompute metadata
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
9
diff
changeset
|
732 |
5d5caf89eb5b
added thread to precompute metadata
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
9
diff
changeset
|
733 Json::Value instanceTags; |
5d5caf89eb5b
added thread to precompute metadata
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
9
diff
changeset
|
734 std::string metadata; |
5d5caf89eb5b
added thread to precompute metadata
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
9
diff
changeset
|
735 if (!OrthancPlugins::RestApiGetString(metadata, uri, false) && |
5d5caf89eb5b
added thread to precompute metadata
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
9
diff
changeset
|
736 EncodeOhifInstance(instanceTags, instanceId)) |
5d5caf89eb5b
added thread to precompute metadata
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
9
diff
changeset
|
737 { |
5d5caf89eb5b
added thread to precompute metadata
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
9
diff
changeset
|
738 CacheAsMetadata(instanceTags, instanceId); |
5d5caf89eb5b
added thread to precompute metadata
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
9
diff
changeset
|
739 } |
5d5caf89eb5b
added thread to precompute metadata
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
9
diff
changeset
|
740 } |
5d5caf89eb5b
added thread to precompute metadata
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
9
diff
changeset
|
741 } |
5d5caf89eb5b
added thread to precompute metadata
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
9
diff
changeset
|
742 } |
5d5caf89eb5b
added thread to precompute metadata
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
9
diff
changeset
|
743 |
5d5caf89eb5b
added thread to precompute metadata
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
9
diff
changeset
|
744 |
0 | 745 OrthancPluginErrorCode OnChangeCallback(OrthancPluginChangeType changeType, |
746 OrthancPluginResourceType resourceType, | |
747 const char* resourceId) | |
748 { | |
749 try | |
750 { | |
10
5d5caf89eb5b
added thread to precompute metadata
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
9
diff
changeset
|
751 switch (changeType) |
0 | 752 { |
10
5d5caf89eb5b
added thread to precompute metadata
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
9
diff
changeset
|
753 case OrthancPluginChangeType_OrthancStarted: |
5
8c1fe0ca24f5
added the possibility to replace DICOMweb by DICOM JSON
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
4
diff
changeset
|
754 { |
10
5d5caf89eb5b
added thread to precompute metadata
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
9
diff
changeset
|
755 continueThread_ = true; |
5d5caf89eb5b
added thread to precompute metadata
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
9
diff
changeset
|
756 |
11
16b9f1ff491d
added configuration option "Preload"
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
10
diff
changeset
|
757 switch (dataSource_) |
5
8c1fe0ca24f5
added the possibility to replace DICOMweb by DICOM JSON
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
4
diff
changeset
|
758 { |
11
16b9f1ff491d
added configuration option "Preload"
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
10
diff
changeset
|
759 case DataSource_DicomWeb: |
10
5d5caf89eb5b
added thread to precompute metadata
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
9
diff
changeset
|
760 { |
11
16b9f1ff491d
added configuration option "Preload"
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
10
diff
changeset
|
761 Json::Value info; |
16b9f1ff491d
added configuration option "Preload"
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
10
diff
changeset
|
762 if (!OrthancPlugins::RestApiGet(info, "/plugins/dicom-web", false)) |
16b9f1ff491d
added configuration option "Preload"
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
10
diff
changeset
|
763 { |
16b9f1ff491d
added configuration option "Preload"
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
10
diff
changeset
|
764 throw Orthanc::OrthancException( |
16b9f1ff491d
added configuration option "Preload"
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
10
diff
changeset
|
765 Orthanc::ErrorCode_InternalError, |
16b9f1ff491d
added configuration option "Preload"
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
10
diff
changeset
|
766 "The OHIF plugin requires the DICOMweb plugin to be installed"); |
16b9f1ff491d
added configuration option "Preload"
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
10
diff
changeset
|
767 } |
16b9f1ff491d
added configuration option "Preload"
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
10
diff
changeset
|
768 |
16b9f1ff491d
added configuration option "Preload"
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
10
diff
changeset
|
769 if (info.type() != Json::objectValue || |
16b9f1ff491d
added configuration option "Preload"
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
10
diff
changeset
|
770 !info.isMember("ID") || |
16b9f1ff491d
added configuration option "Preload"
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
10
diff
changeset
|
771 !info.isMember("Version") || |
16b9f1ff491d
added configuration option "Preload"
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
10
diff
changeset
|
772 info["ID"].type() != Json::stringValue || |
16b9f1ff491d
added configuration option "Preload"
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
10
diff
changeset
|
773 info["Version"].type() != Json::stringValue || |
16b9f1ff491d
added configuration option "Preload"
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
10
diff
changeset
|
774 info["ID"].asString() != "dicom-web") |
16b9f1ff491d
added configuration option "Preload"
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
10
diff
changeset
|
775 { |
16b9f1ff491d
added configuration option "Preload"
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
10
diff
changeset
|
776 throw Orthanc::OrthancException(Orthanc::ErrorCode_InternalError, |
16b9f1ff491d
added configuration option "Preload"
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
10
diff
changeset
|
777 "The DICOMweb plugin is required by OHIF, but is not properly installed"); |
16b9f1ff491d
added configuration option "Preload"
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
10
diff
changeset
|
778 } |
16b9f1ff491d
added configuration option "Preload"
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
10
diff
changeset
|
779 |
16b9f1ff491d
added configuration option "Preload"
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
10
diff
changeset
|
780 break; |
10
5d5caf89eb5b
added thread to precompute metadata
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
9
diff
changeset
|
781 } |
5d5caf89eb5b
added thread to precompute metadata
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
9
diff
changeset
|
782 |
11
16b9f1ff491d
added configuration option "Preload"
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
10
diff
changeset
|
783 case DataSource_DicomJson: |
10
5d5caf89eb5b
added thread to precompute metadata
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
9
diff
changeset
|
784 { |
11
16b9f1ff491d
added configuration option "Preload"
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
10
diff
changeset
|
785 if (preload_) |
16b9f1ff491d
added configuration option "Preload"
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
10
diff
changeset
|
786 { |
16b9f1ff491d
added configuration option "Preload"
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
10
diff
changeset
|
787 metadataThread_ = boost::thread(MetadataThread); |
16b9f1ff491d
added configuration option "Preload"
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
10
diff
changeset
|
788 LOG(INFO) << "Started the OHIF preload thread"; |
16b9f1ff491d
added configuration option "Preload"
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
10
diff
changeset
|
789 } |
16b9f1ff491d
added configuration option "Preload"
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
10
diff
changeset
|
790 else |
16b9f1ff491d
added configuration option "Preload"
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
10
diff
changeset
|
791 { |
16b9f1ff491d
added configuration option "Preload"
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
10
diff
changeset
|
792 LOG(INFO) << "The OHIF preload thread was not started, as indicated in the configuration file"; |
16b9f1ff491d
added configuration option "Preload"
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
10
diff
changeset
|
793 } |
16b9f1ff491d
added configuration option "Preload"
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
10
diff
changeset
|
794 break; |
10
5d5caf89eb5b
added thread to precompute metadata
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
9
diff
changeset
|
795 } |
11
16b9f1ff491d
added configuration option "Preload"
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
10
diff
changeset
|
796 |
16b9f1ff491d
added configuration option "Preload"
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
10
diff
changeset
|
797 default: |
16b9f1ff491d
added configuration option "Preload"
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
10
diff
changeset
|
798 throw Orthanc::OrthancException(Orthanc::ErrorCode_ParameterOutOfRange); |
10
5d5caf89eb5b
added thread to precompute metadata
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
9
diff
changeset
|
799 } |
11
16b9f1ff491d
added configuration option "Preload"
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
10
diff
changeset
|
800 |
10
5d5caf89eb5b
added thread to precompute metadata
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
9
diff
changeset
|
801 break; |
5d5caf89eb5b
added thread to precompute metadata
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
9
diff
changeset
|
802 } |
5d5caf89eb5b
added thread to precompute metadata
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
9
diff
changeset
|
803 |
5d5caf89eb5b
added thread to precompute metadata
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
9
diff
changeset
|
804 case OrthancPluginChangeType_OrthancStopped: |
5d5caf89eb5b
added thread to precompute metadata
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
9
diff
changeset
|
805 { |
5d5caf89eb5b
added thread to precompute metadata
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
9
diff
changeset
|
806 continueThread_ = false; |
5d5caf89eb5b
added thread to precompute metadata
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
9
diff
changeset
|
807 |
5d5caf89eb5b
added thread to precompute metadata
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
9
diff
changeset
|
808 if (metadataThread_.joinable()) |
5d5caf89eb5b
added thread to precompute metadata
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
9
diff
changeset
|
809 { |
11
16b9f1ff491d
added configuration option "Preload"
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
10
diff
changeset
|
810 LOG(INFO) << "Stopping the OHIF preload thread"; |
10
5d5caf89eb5b
added thread to precompute metadata
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
9
diff
changeset
|
811 metadataThread_.join(); |
5d5caf89eb5b
added thread to precompute metadata
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
9
diff
changeset
|
812 } |
5d5caf89eb5b
added thread to precompute metadata
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
9
diff
changeset
|
813 break; |
5d5caf89eb5b
added thread to precompute metadata
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
9
diff
changeset
|
814 } |
5d5caf89eb5b
added thread to precompute metadata
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
9
diff
changeset
|
815 |
5d5caf89eb5b
added thread to precompute metadata
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
9
diff
changeset
|
816 case OrthancPluginChangeType_NewInstance: |
5d5caf89eb5b
added thread to precompute metadata
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
9
diff
changeset
|
817 { |
5d5caf89eb5b
added thread to precompute metadata
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
9
diff
changeset
|
818 if (metadataThread_.joinable() && |
11
16b9f1ff491d
added configuration option "Preload"
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
10
diff
changeset
|
819 pendingInstances_.GetSize() < MAX_INSTANCES_IN_QUEUE) /* avoid overwhelming Orthanc */ |
10
5d5caf89eb5b
added thread to precompute metadata
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
9
diff
changeset
|
820 { |
5d5caf89eb5b
added thread to precompute metadata
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
9
diff
changeset
|
821 pendingInstances_.Enqueue(new Orthanc::SingleValueObject<std::string>(resourceId)); |
5
8c1fe0ca24f5
added the possibility to replace DICOMweb by DICOM JSON
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
4
diff
changeset
|
822 } |
4
c34ecc350b32
upgraded the node docker image
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
3
diff
changeset
|
823 |
10
5d5caf89eb5b
added thread to precompute metadata
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
9
diff
changeset
|
824 break; |
0 | 825 } |
10
5d5caf89eb5b
added thread to precompute metadata
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
9
diff
changeset
|
826 |
5d5caf89eb5b
added thread to precompute metadata
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
9
diff
changeset
|
827 default: |
5d5caf89eb5b
added thread to precompute metadata
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
9
diff
changeset
|
828 break; |
0 | 829 } |
830 } | |
831 catch (Orthanc::OrthancException& e) | |
832 { | |
833 LOG(ERROR) << "Exception: " << e.What(); | |
834 return static_cast<OrthancPluginErrorCode>(e.GetErrorCode()); | |
835 } | |
836 | |
837 return OrthancPluginErrorCode_Success; | |
838 } | |
839 | |
840 | |
841 extern "C" | |
842 { | |
843 ORTHANC_PLUGINS_API int32_t OrthancPluginInitialize(OrthancPluginContext* context) | |
844 { | |
845 OrthancPlugins::SetGlobalContext(context); | |
846 | |
847 /* Check the version of the Orthanc core */ | |
848 if (OrthancPluginCheckVersion(context) == 0) | |
849 { | |
850 char info[1024]; | |
851 sprintf(info, "Your version of Orthanc (%s) must be above %d.%d.%d to run this plugin", | |
852 context->orthancVersion, | |
853 ORTHANC_PLUGINS_MINIMAL_MAJOR_NUMBER, | |
854 ORTHANC_PLUGINS_MINIMAL_MINOR_NUMBER, | |
855 ORTHANC_PLUGINS_MINIMAL_REVISION_NUMBER); | |
856 OrthancPluginLogError(context, info); | |
857 return -1; | |
858 } | |
859 | |
860 #if ORTHANC_FRAMEWORK_VERSION_IS_ABOVE(1, 7, 2) | |
861 Orthanc::Logging::InitializePluginContext(context); | |
862 #else | |
863 Orthanc::Logging::Initialize(context); | |
864 #endif | |
865 | |
11
16b9f1ff491d
added configuration option "Preload"
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
10
diff
changeset
|
866 try |
16b9f1ff491d
added configuration option "Preload"
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
10
diff
changeset
|
867 { |
16b9f1ff491d
added configuration option "Preload"
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
10
diff
changeset
|
868 InitializeOhifTags(); |
3
fdb8c6c420d0
skeleton for optimization
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
2
diff
changeset
|
869 |
11
16b9f1ff491d
added configuration option "Preload"
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
10
diff
changeset
|
870 OrthancPlugins::OrthancConfiguration configuration; |
2
cbc4be362700
added configuration option "RouterBasename"
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
0
diff
changeset
|
871 |
11
16b9f1ff491d
added configuration option "Preload"
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
10
diff
changeset
|
872 { |
16b9f1ff491d
added configuration option "Preload"
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
10
diff
changeset
|
873 OrthancPlugins::OrthancConfiguration globalConfiguration; |
16b9f1ff491d
added configuration option "Preload"
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
10
diff
changeset
|
874 globalConfiguration.GetSection(configuration, "OHIF"); |
16b9f1ff491d
added configuration option "Preload"
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
10
diff
changeset
|
875 } |
16b9f1ff491d
added configuration option "Preload"
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
10
diff
changeset
|
876 |
12
6115cfbece79
added option "Configuration"
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
11
diff
changeset
|
877 routerBasename_ = configuration.GetStringValue("RouterBasename", "/ohif/"); |
11
16b9f1ff491d
added configuration option "Preload"
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
10
diff
changeset
|
878 std::string s = configuration.GetStringValue("DataSource", "dicom-json"); |
13
4ef286d0f78e
renamed "Configuration" as "UserConfiguration"
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
12
diff
changeset
|
879 std::string userConfigurationPath = configuration.GetStringValue("UserConfiguration", ""); |
11
16b9f1ff491d
added configuration option "Preload"
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
10
diff
changeset
|
880 preload_ = configuration.GetBooleanValue("Preload", true); |
2
cbc4be362700
added configuration option "RouterBasename"
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
0
diff
changeset
|
881 |
11
16b9f1ff491d
added configuration option "Preload"
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
10
diff
changeset
|
882 if (s == "dicom-web") |
16b9f1ff491d
added configuration option "Preload"
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
10
diff
changeset
|
883 { |
16b9f1ff491d
added configuration option "Preload"
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
10
diff
changeset
|
884 dataSource_ = DataSource_DicomWeb; |
16b9f1ff491d
added configuration option "Preload"
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
10
diff
changeset
|
885 } |
16b9f1ff491d
added configuration option "Preload"
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
10
diff
changeset
|
886 else if (s == "dicom-json") |
16b9f1ff491d
added configuration option "Preload"
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
10
diff
changeset
|
887 { |
16b9f1ff491d
added configuration option "Preload"
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
10
diff
changeset
|
888 dataSource_ = DataSource_DicomJson; |
16b9f1ff491d
added configuration option "Preload"
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
10
diff
changeset
|
889 } |
16b9f1ff491d
added configuration option "Preload"
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
10
diff
changeset
|
890 else |
16b9f1ff491d
added configuration option "Preload"
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
10
diff
changeset
|
891 { |
16b9f1ff491d
added configuration option "Preload"
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
10
diff
changeset
|
892 throw Orthanc::OrthancException(Orthanc::ErrorCode_ParameterOutOfRange, |
16b9f1ff491d
added configuration option "Preload"
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
10
diff
changeset
|
893 "Configuration option \"OHIF.DataSource\" must be either " |
16b9f1ff491d
added configuration option "Preload"
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
10
diff
changeset
|
894 "\"dicomweb\" or \"dicom-json\", but found: " + s); |
16b9f1ff491d
added configuration option "Preload"
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
10
diff
changeset
|
895 } |
6
e8e7ba4371e3
fix access to OHIF study list
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
5
diff
changeset
|
896 |
12
6115cfbece79
added option "Configuration"
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
11
diff
changeset
|
897 if (userConfigurationPath.empty()) |
6115cfbece79
added option "Configuration"
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
11
diff
changeset
|
898 { |
6115cfbece79
added option "Configuration"
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
11
diff
changeset
|
899 Orthanc::EmbeddedResources::GetFileResource(userConfiguration_, Orthanc::EmbeddedResources::APP_CONFIG_USER); |
6115cfbece79
added option "Configuration"
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
11
diff
changeset
|
900 } |
6115cfbece79
added option "Configuration"
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
11
diff
changeset
|
901 else |
6115cfbece79
added option "Configuration"
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
11
diff
changeset
|
902 { |
6115cfbece79
added option "Configuration"
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
11
diff
changeset
|
903 Orthanc::SystemToolbox::ReadFile(userConfiguration_, userConfigurationPath); |
6115cfbece79
added option "Configuration"
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
11
diff
changeset
|
904 } |
6115cfbece79
added option "Configuration"
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
11
diff
changeset
|
905 |
11
16b9f1ff491d
added configuration option "Preload"
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
10
diff
changeset
|
906 // Make sure that the router basename ends with a trailing slash |
16b9f1ff491d
added configuration option "Preload"
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
10
diff
changeset
|
907 if (routerBasename_.empty() || |
16b9f1ff491d
added configuration option "Preload"
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
10
diff
changeset
|
908 routerBasename_[routerBasename_.size() - 1] != '/') |
16b9f1ff491d
added configuration option "Preload"
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
10
diff
changeset
|
909 { |
16b9f1ff491d
added configuration option "Preload"
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
10
diff
changeset
|
910 routerBasename_ += "/"; |
16b9f1ff491d
added configuration option "Preload"
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
10
diff
changeset
|
911 } |
16b9f1ff491d
added configuration option "Preload"
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
10
diff
changeset
|
912 |
16b9f1ff491d
added configuration option "Preload"
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
10
diff
changeset
|
913 OrthancPluginSetDescription(context, "OHIF plugin for Orthanc."); |
16b9f1ff491d
added configuration option "Preload"
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
10
diff
changeset
|
914 |
16b9f1ff491d
added configuration option "Preload"
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
10
diff
changeset
|
915 OrthancPlugins::RegisterRestCallback<ServeFile>("/ohif", true); |
16b9f1ff491d
added configuration option "Preload"
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
10
diff
changeset
|
916 OrthancPlugins::RegisterRestCallback<ServeFile>("/ohif/(.*)", true); |
16b9f1ff491d
added configuration option "Preload"
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
10
diff
changeset
|
917 OrthancPlugins::RegisterRestCallback<GetOhifStudy>("/studies/([0-9a-f-]+)/ohif-dicom-json", true); |
0 | 918 |
11
16b9f1ff491d
added configuration option "Preload"
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
10
diff
changeset
|
919 OrthancPluginRegisterOnChangeCallback(context, OnChangeCallback); |
16b9f1ff491d
added configuration option "Preload"
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
10
diff
changeset
|
920 |
16b9f1ff491d
added configuration option "Preload"
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
10
diff
changeset
|
921 { |
16b9f1ff491d
added configuration option "Preload"
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
10
diff
changeset
|
922 // Extend the default Orthanc Explorer with custom JavaScript for OHIF |
16b9f1ff491d
added configuration option "Preload"
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
10
diff
changeset
|
923 std::string explorer; |
16b9f1ff491d
added configuration option "Preload"
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
10
diff
changeset
|
924 Orthanc::EmbeddedResources::GetFileResource(explorer, Orthanc::EmbeddedResources::ORTHANC_EXPLORER); |
0 | 925 |
11
16b9f1ff491d
added configuration option "Preload"
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
10
diff
changeset
|
926 std::map<std::string, std::string> dictionary; |
16b9f1ff491d
added configuration option "Preload"
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
10
diff
changeset
|
927 dictionary["USE_DICOM_WEB"] = (dataSource_ == DataSource_DicomWeb ? "true" : "false"); |
16b9f1ff491d
added configuration option "Preload"
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
10
diff
changeset
|
928 explorer = Orthanc::Toolbox::SubstituteVariables(explorer, dictionary); |
16b9f1ff491d
added configuration option "Preload"
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
10
diff
changeset
|
929 |
16b9f1ff491d
added configuration option "Preload"
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
10
diff
changeset
|
930 OrthancPluginExtendOrthancExplorer(context, explorer.c_str()); |
16b9f1ff491d
added configuration option "Preload"
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
10
diff
changeset
|
931 } |
16b9f1ff491d
added configuration option "Preload"
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
10
diff
changeset
|
932 } |
16b9f1ff491d
added configuration option "Preload"
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
10
diff
changeset
|
933 catch (Orthanc::OrthancException& e) |
5
8c1fe0ca24f5
added the possibility to replace DICOMweb by DICOM JSON
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
4
diff
changeset
|
934 { |
11
16b9f1ff491d
added configuration option "Preload"
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
10
diff
changeset
|
935 return -1; |
5
8c1fe0ca24f5
added the possibility to replace DICOMweb by DICOM JSON
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
4
diff
changeset
|
936 } |
0 | 937 |
938 return 0; | |
939 } | |
940 | |
941 | |
942 ORTHANC_PLUGINS_API void OrthancPluginFinalize() | |
943 { | |
944 } | |
945 | |
946 | |
947 ORTHANC_PLUGINS_API const char* OrthancPluginGetName() | |
948 { | |
949 return "ohif"; | |
950 } | |
951 | |
952 | |
953 ORTHANC_PLUGINS_API const char* OrthancPluginGetVersion() | |
954 { | |
955 return ORTHANC_OHIF_VERSION; | |
956 } | |
957 } |