Mercurial > hg > orthanc-authorization
annotate Plugin/AuthorizationParserBase.cpp @ 167:e406ef204e3a
new default permissions for create-dicom + stl routes
author | Alain Mazy <am@orthanc.team> |
---|---|
date | Wed, 15 May 2024 14:31:04 +0200 |
parents | 9be1ee2b8fe1 |
children | c4b908970ae4 |
rev | line source |
---|---|
1 | 1 /** |
2 * Advanced authorization plugin for Orthanc | |
68 | 3 * Copyright (C) 2017-2023 Osimis S.A., Belgium |
150 | 4 * Copyright (C) 2024-2024 Orthanc Team SRL, Belgium |
1 | 5 * |
6 * This program is free software: you can redistribute it and/or | |
7 * modify it under the terms of the GNU Affero General Public License | |
8 * as published by the Free Software Foundation, either version 3 of | |
9 * the License, or (at your option) any later version. | |
10 * | |
11 * This program is distributed in the hope that it will be useful, but | |
12 * WITHOUT ANY WARRANTY; without even the implied warranty of | |
13 * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the GNU | |
14 * Affero General Public License for more details. | |
15 * | |
16 * You should have received a copy of the GNU Affero General Public License | |
17 * along with this program. If not, see <http://www.gnu.org/licenses/>. | |
18 **/ | |
19 | |
20 #include "AuthorizationParserBase.h" | |
21 | |
32 | 22 #include <OrthancException.h> |
1 | 23 |
24 namespace OrthancPlugins | |
25 { | |
26 void AuthorizationParserBase::AddResourceInternal(AccessedResources& target, | |
27 Orthanc::ResourceType level, | |
109 | 28 const std::string& orthancId, |
29 const std::set<std::string>& labels) | |
1 | 30 { |
31 std::string dicomUid; | |
32 | |
33 if (resourceHierarchy_->LookupDicomUid(dicomUid, level, orthancId)) | |
34 { | |
109 | 35 target.push_back(AccessedResource(level, orthancId, dicomUid, labels)); |
1 | 36 } |
37 } | |
38 | |
39 | |
138
f448e8626f1a
Now handling new GET /tools/create-archive and sibling routes
Alain Mazy <am@osimis.io>
parents:
109
diff
changeset
|
40 Orthanc::ResourceType AuthorizationParserBase::AddOrthancUnknownResource(AccessedResources& target, |
f448e8626f1a
Now handling new GET /tools/create-archive and sibling routes
Alain Mazy <am@osimis.io>
parents:
109
diff
changeset
|
41 const std::string& orthancId) |
f448e8626f1a
Now handling new GET /tools/create-archive and sibling routes
Alain Mazy <am@osimis.io>
parents:
109
diff
changeset
|
42 { |
f448e8626f1a
Now handling new GET /tools/create-archive and sibling routes
Alain Mazy <am@osimis.io>
parents:
109
diff
changeset
|
43 std::string dicomId; |
f448e8626f1a
Now handling new GET /tools/create-archive and sibling routes
Alain Mazy <am@osimis.io>
parents:
109
diff
changeset
|
44 if (resourceHierarchy_->LookupDicomUid(dicomId, Orthanc::ResourceType_Study, orthancId)) |
f448e8626f1a
Now handling new GET /tools/create-archive and sibling routes
Alain Mazy <am@osimis.io>
parents:
109
diff
changeset
|
45 { |
f448e8626f1a
Now handling new GET /tools/create-archive and sibling routes
Alain Mazy <am@osimis.io>
parents:
109
diff
changeset
|
46 AddOrthancStudy(target, orthancId); |
f448e8626f1a
Now handling new GET /tools/create-archive and sibling routes
Alain Mazy <am@osimis.io>
parents:
109
diff
changeset
|
47 return Orthanc::ResourceType_Study; |
f448e8626f1a
Now handling new GET /tools/create-archive and sibling routes
Alain Mazy <am@osimis.io>
parents:
109
diff
changeset
|
48 } |
f448e8626f1a
Now handling new GET /tools/create-archive and sibling routes
Alain Mazy <am@osimis.io>
parents:
109
diff
changeset
|
49 |
f448e8626f1a
Now handling new GET /tools/create-archive and sibling routes
Alain Mazy <am@osimis.io>
parents:
109
diff
changeset
|
50 if (resourceHierarchy_->LookupDicomUid(dicomId, Orthanc::ResourceType_Patient, orthancId)) |
f448e8626f1a
Now handling new GET /tools/create-archive and sibling routes
Alain Mazy <am@osimis.io>
parents:
109
diff
changeset
|
51 { |
f448e8626f1a
Now handling new GET /tools/create-archive and sibling routes
Alain Mazy <am@osimis.io>
parents:
109
diff
changeset
|
52 AddOrthancPatient(target, orthancId); |
f448e8626f1a
Now handling new GET /tools/create-archive and sibling routes
Alain Mazy <am@osimis.io>
parents:
109
diff
changeset
|
53 return Orthanc::ResourceType_Patient; |
f448e8626f1a
Now handling new GET /tools/create-archive and sibling routes
Alain Mazy <am@osimis.io>
parents:
109
diff
changeset
|
54 } |
f448e8626f1a
Now handling new GET /tools/create-archive and sibling routes
Alain Mazy <am@osimis.io>
parents:
109
diff
changeset
|
55 |
f448e8626f1a
Now handling new GET /tools/create-archive and sibling routes
Alain Mazy <am@osimis.io>
parents:
109
diff
changeset
|
56 if (resourceHierarchy_->LookupDicomUid(dicomId, Orthanc::ResourceType_Series, orthancId)) |
f448e8626f1a
Now handling new GET /tools/create-archive and sibling routes
Alain Mazy <am@osimis.io>
parents:
109
diff
changeset
|
57 { |
f448e8626f1a
Now handling new GET /tools/create-archive and sibling routes
Alain Mazy <am@osimis.io>
parents:
109
diff
changeset
|
58 AddOrthancSeries(target, orthancId); |
f448e8626f1a
Now handling new GET /tools/create-archive and sibling routes
Alain Mazy <am@osimis.io>
parents:
109
diff
changeset
|
59 return Orthanc::ResourceType_Series; |
f448e8626f1a
Now handling new GET /tools/create-archive and sibling routes
Alain Mazy <am@osimis.io>
parents:
109
diff
changeset
|
60 } |
f448e8626f1a
Now handling new GET /tools/create-archive and sibling routes
Alain Mazy <am@osimis.io>
parents:
109
diff
changeset
|
61 |
f448e8626f1a
Now handling new GET /tools/create-archive and sibling routes
Alain Mazy <am@osimis.io>
parents:
109
diff
changeset
|
62 if (resourceHierarchy_->LookupDicomUid(dicomId, Orthanc::ResourceType_Instance, orthancId)) |
f448e8626f1a
Now handling new GET /tools/create-archive and sibling routes
Alain Mazy <am@osimis.io>
parents:
109
diff
changeset
|
63 { |
f448e8626f1a
Now handling new GET /tools/create-archive and sibling routes
Alain Mazy <am@osimis.io>
parents:
109
diff
changeset
|
64 AddOrthancInstance(target, orthancId); |
f448e8626f1a
Now handling new GET /tools/create-archive and sibling routes
Alain Mazy <am@osimis.io>
parents:
109
diff
changeset
|
65 return Orthanc::ResourceType_Instance; |
f448e8626f1a
Now handling new GET /tools/create-archive and sibling routes
Alain Mazy <am@osimis.io>
parents:
109
diff
changeset
|
66 } |
f448e8626f1a
Now handling new GET /tools/create-archive and sibling routes
Alain Mazy <am@osimis.io>
parents:
109
diff
changeset
|
67 |
f448e8626f1a
Now handling new GET /tools/create-archive and sibling routes
Alain Mazy <am@osimis.io>
parents:
109
diff
changeset
|
68 throw Orthanc::OrthancException(Orthanc::ErrorCode_UnknownResource); |
f448e8626f1a
Now handling new GET /tools/create-archive and sibling routes
Alain Mazy <am@osimis.io>
parents:
109
diff
changeset
|
69 } |
f448e8626f1a
Now handling new GET /tools/create-archive and sibling routes
Alain Mazy <am@osimis.io>
parents:
109
diff
changeset
|
70 |
f448e8626f1a
Now handling new GET /tools/create-archive and sibling routes
Alain Mazy <am@osimis.io>
parents:
109
diff
changeset
|
71 |
1 | 72 void AuthorizationParserBase::AddOrthancInstance(AccessedResources& target, |
73 const std::string& orthancId) | |
74 { | |
75 std::string patient, study, series; | |
76 if (!resourceHierarchy_->LookupInstance(patient, study, series, orthancId)) | |
77 { | |
78 throw Orthanc::OrthancException(Orthanc::ErrorCode_UnknownResource); | |
79 } | |
80 | |
109 | 81 std::set<std::string> labels; |
82 | |
83 resourceHierarchy_->GetLabels(labels, OrthancResource(Orthanc::ResourceType_Patient, patient)); | |
84 AddResourceInternal(target, Orthanc::ResourceType_Patient, patient, labels); | |
85 | |
86 resourceHierarchy_->GetLabels(labels, OrthancResource(Orthanc::ResourceType_Study, study)); | |
87 AddResourceInternal(target, Orthanc::ResourceType_Study, study, labels); | |
88 | |
89 resourceHierarchy_->GetLabels(labels, OrthancResource(Orthanc::ResourceType_Series, series)); | |
90 AddResourceInternal(target, Orthanc::ResourceType_Series, series, labels); | |
91 | |
92 resourceHierarchy_->GetLabels(labels, OrthancResource(Orthanc::ResourceType_Instance, orthancId)); | |
93 AddResourceInternal(target, Orthanc::ResourceType_Instance, orthancId, labels); | |
1 | 94 } |
95 | |
96 | |
97 void AuthorizationParserBase::AddOrthancSeries(AccessedResources& target, | |
98 const std::string& orthancId) | |
99 { | |
100 std::string patient, study; | |
101 if (!resourceHierarchy_->LookupSeries(patient, study, orthancId)) | |
102 { | |
103 throw Orthanc::OrthancException(Orthanc::ErrorCode_UnknownResource); | |
104 } | |
105 | |
109 | 106 std::set<std::string> labels; |
107 | |
108 resourceHierarchy_->GetLabels(labels, OrthancResource(Orthanc::ResourceType_Patient, patient)); | |
109 AddResourceInternal(target, Orthanc::ResourceType_Patient, patient, labels); | |
110 | |
111 resourceHierarchy_->GetLabels(labels, OrthancResource(Orthanc::ResourceType_Study, study)); | |
112 AddResourceInternal(target, Orthanc::ResourceType_Study, study, labels); | |
113 | |
114 resourceHierarchy_->GetLabels(labels, OrthancResource(Orthanc::ResourceType_Series, orthancId)); | |
115 AddResourceInternal(target, Orthanc::ResourceType_Series, orthancId, labels); | |
1 | 116 } |
117 | |
118 | |
119 void AuthorizationParserBase::AddOrthancStudy(AccessedResources& target, | |
120 const std::string& orthancId) | |
121 { | |
122 std::string patient; | |
123 if (!resourceHierarchy_->LookupStudy(patient, orthancId)) | |
124 { | |
125 throw Orthanc::OrthancException(Orthanc::ErrorCode_UnknownResource); | |
126 } | |
127 | |
109 | 128 std::set<std::string> labels; |
129 | |
130 resourceHierarchy_->GetLabels(labels, OrthancResource(Orthanc::ResourceType_Patient, patient)); | |
131 AddResourceInternal(target, Orthanc::ResourceType_Patient, patient, labels); | |
132 | |
133 resourceHierarchy_->GetLabels(labels, OrthancResource(Orthanc::ResourceType_Study, orthancId)); | |
134 AddResourceInternal(target, Orthanc::ResourceType_Study, orthancId, labels); | |
1 | 135 } |
136 | |
137 | |
138 void AuthorizationParserBase::AddOrthancPatient(AccessedResources& target, | |
139 const std::string& orthancId) | |
140 { | |
109 | 141 std::set<std::string> labels; |
142 | |
143 resourceHierarchy_->GetLabels(labels, OrthancResource(Orthanc::ResourceType_Patient, orthancId)); | |
144 AddResourceInternal(target, Orthanc::ResourceType_Patient, orthancId, labels); | |
1 | 145 } |
146 | |
147 | |
148 void AuthorizationParserBase::AddDicomStudy(AccessedResources& target, | |
149 const std::string& studyDicomUid) | |
150 { | |
151 std::string patient, study; | |
152 | |
153 if (!resourceHierarchy_->LookupOrthancId(study, Orthanc::ResourceType_Study, studyDicomUid) || | |
154 !resourceHierarchy_->LookupStudy(patient, study)) | |
155 { | |
156 throw Orthanc::OrthancException(Orthanc::ErrorCode_UnknownResource); | |
157 } | |
158 | |
109 | 159 std::set<std::string> labels; |
160 | |
161 resourceHierarchy_->GetLabels(labels, OrthancResource(Orthanc::ResourceType_Patient, patient)); | |
162 AddResourceInternal(target, Orthanc::ResourceType_Patient, patient, labels); | |
163 | |
164 resourceHierarchy_->GetLabels(labels, OrthancResource(Orthanc::ResourceType_Study, study)); | |
165 target.push_back(AccessedResource(Orthanc::ResourceType_Study, study, studyDicomUid, labels)); | |
1 | 166 } |
167 | |
77
94a9484d7f8f
fix security issues allowing to browse remote dicom servers + introduced UnitTests
Alain Mazy <am@osimis.io>
parents:
68
diff
changeset
|
168 void AuthorizationParserBase::AddDicomPatient(AccessedResources& target, |
94a9484d7f8f
fix security issues allowing to browse remote dicom servers + introduced UnitTests
Alain Mazy <am@osimis.io>
parents:
68
diff
changeset
|
169 const std::string& patientId) |
94a9484d7f8f
fix security issues allowing to browse remote dicom servers + introduced UnitTests
Alain Mazy <am@osimis.io>
parents:
68
diff
changeset
|
170 { |
94a9484d7f8f
fix security issues allowing to browse remote dicom servers + introduced UnitTests
Alain Mazy <am@osimis.io>
parents:
68
diff
changeset
|
171 std::string patient; |
94a9484d7f8f
fix security issues allowing to browse remote dicom servers + introduced UnitTests
Alain Mazy <am@osimis.io>
parents:
68
diff
changeset
|
172 |
94a9484d7f8f
fix security issues allowing to browse remote dicom servers + introduced UnitTests
Alain Mazy <am@osimis.io>
parents:
68
diff
changeset
|
173 if (!resourceHierarchy_->LookupOrthancId(patient, Orthanc::ResourceType_Patient, patientId)) |
94a9484d7f8f
fix security issues allowing to browse remote dicom servers + introduced UnitTests
Alain Mazy <am@osimis.io>
parents:
68
diff
changeset
|
174 { |
94a9484d7f8f
fix security issues allowing to browse remote dicom servers + introduced UnitTests
Alain Mazy <am@osimis.io>
parents:
68
diff
changeset
|
175 throw Orthanc::OrthancException(Orthanc::ErrorCode_UnknownResource); |
94a9484d7f8f
fix security issues allowing to browse remote dicom servers + introduced UnitTests
Alain Mazy <am@osimis.io>
parents:
68
diff
changeset
|
176 } |
94a9484d7f8f
fix security issues allowing to browse remote dicom servers + introduced UnitTests
Alain Mazy <am@osimis.io>
parents:
68
diff
changeset
|
177 |
109 | 178 std::set<std::string> labels; |
179 | |
180 resourceHierarchy_->GetLabels(labels, OrthancResource(Orthanc::ResourceType_Patient, patient)); | |
181 AddResourceInternal(target, Orthanc::ResourceType_Patient, patient, labels); | |
77
94a9484d7f8f
fix security issues allowing to browse remote dicom servers + introduced UnitTests
Alain Mazy <am@osimis.io>
parents:
68
diff
changeset
|
182 } |
1 | 183 |
184 void AuthorizationParserBase::AddDicomSeries(AccessedResources& target, | |
185 const std::string& studyDicomUid, | |
186 const std::string& seriesDicomUid) | |
187 { | |
188 std::string series; | |
189 | |
190 if (!resourceHierarchy_->LookupOrthancId(series, Orthanc::ResourceType_Series, seriesDicomUid)) | |
191 { | |
192 throw Orthanc::OrthancException(Orthanc::ErrorCode_UnknownResource); | |
193 } | |
194 | |
109 | 195 std::set<std::string> labels; |
196 | |
1 | 197 AddDicomStudy(target, studyDicomUid); |
109 | 198 |
199 resourceHierarchy_->GetLabels(labels, OrthancResource(Orthanc::ResourceType_Series, series)); | |
200 target.push_back(AccessedResource(Orthanc::ResourceType_Series, series, seriesDicomUid, labels)); | |
1 | 201 } |
202 | |
203 | |
204 void AuthorizationParserBase::AddDicomInstance(AccessedResources& target, | |
205 const std::string& studyDicomUid, | |
206 const std::string& seriesDicomUid, | |
207 const std::string& instanceDicomUid) | |
208 { | |
209 std::string instance; | |
210 | |
211 if (!resourceHierarchy_->LookupOrthancId | |
212 (instance, Orthanc::ResourceType_Instance, instanceDicomUid)) | |
213 { | |
214 throw Orthanc::OrthancException(Orthanc::ErrorCode_UnknownResource); | |
215 } | |
216 | |
109 | 217 std::set<std::string> labels; |
218 | |
1 | 219 AddDicomSeries(target, studyDicomUid, seriesDicomUid); |
109 | 220 |
221 resourceHierarchy_->GetLabels(labels, OrthancResource(Orthanc::ResourceType_Instance, instance)); | |
222 target.push_back(AccessedResource(Orthanc::ResourceType_Instance, instance, instanceDicomUid, labels)); | |
1 | 223 } |
224 | |
225 | |
29
bc0431cb6b8f
fix for compatibility with simplified OrthancPluginCppWrapper
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
22
diff
changeset
|
226 AuthorizationParserBase::AuthorizationParserBase(ICacheFactory& factory) |
1 | 227 { |
29
bc0431cb6b8f
fix for compatibility with simplified OrthancPluginCppWrapper
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
22
diff
changeset
|
228 resourceHierarchy_.reset(new ResourceHierarchyCache(factory)); |
1 | 229 |
230 if (resourceHierarchy_.get() == NULL) | |
231 { | |
232 throw Orthanc::OrthancException(Orthanc::ErrorCode_InternalError); | |
233 } | |
234 } | |
235 } | |
236 |