Mercurial > hg > orthanc
annotate OrthancFramework/Sources/DicomFormat/DicomInstanceHasher.cpp @ 4268:0ae2ca210077
new macro TLOG() to replace VLOG() for trace logs with a category
author | Sebastien Jodogne <s.jodogne@gmail.com> |
---|---|
date | Mon, 02 Nov 2020 14:48:15 +0100 |
parents | bf7b9edf6b81 |
children | 3b70a2e6a06c |
rev | line source |
---|---|
178 | 1 /** |
2 * Orthanc - A Lightweight, RESTful DICOM Store | |
1900 | 3 * Copyright (C) 2012-2016 Sebastien Jodogne, Medical Physics |
1288
6e7e5ed91c2d
upgrade to year 2015
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
1228
diff
changeset
|
4 * Department, University Hospital of Liege, Belgium |
3640
94f4a18a79cc
upgrade to year 2020
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
3060
diff
changeset
|
5 * Copyright (C) 2017-2020 Osimis S.A., Belgium |
178 | 6 * |
7 * This program is free software: you can redistribute it and/or | |
4119
bf7b9edf6b81
re-licensing the OrthancFramework to LGPL, in order to license Stone of Orthanc under LGPL
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
4044
diff
changeset
|
8 * modify it under the terms of the GNU Lesser General Public License |
bf7b9edf6b81
re-licensing the OrthancFramework to LGPL, in order to license Stone of Orthanc under LGPL
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
4044
diff
changeset
|
9 * as published by the Free Software Foundation, either version 3 of |
bf7b9edf6b81
re-licensing the OrthancFramework to LGPL, in order to license Stone of Orthanc under LGPL
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
4044
diff
changeset
|
10 * the License, or (at your option) any later version. |
178 | 11 * |
12 * This program is distributed in the hope that it will be useful, but | |
13 * WITHOUT ANY WARRANTY; without even the implied warranty of | |
14 * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the GNU | |
4119
bf7b9edf6b81
re-licensing the OrthancFramework to LGPL, in order to license Stone of Orthanc under LGPL
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
4044
diff
changeset
|
15 * Lesser General Public License for more details. |
178 | 16 * |
4119
bf7b9edf6b81
re-licensing the OrthancFramework to LGPL, in order to license Stone of Orthanc under LGPL
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
4044
diff
changeset
|
17 * You should have received a copy of the GNU Lesser General Public |
bf7b9edf6b81
re-licensing the OrthancFramework to LGPL, in order to license Stone of Orthanc under LGPL
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
4044
diff
changeset
|
18 * License along with this program. If not, see |
bf7b9edf6b81
re-licensing the OrthancFramework to LGPL, in order to license Stone of Orthanc under LGPL
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
4044
diff
changeset
|
19 * <http://www.gnu.org/licenses/>. |
178 | 20 **/ |
21 | |
824
a811bdf8b8eb
precompiled headers
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
689
diff
changeset
|
22 |
a811bdf8b8eb
precompiled headers
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
689
diff
changeset
|
23 #include "../PrecompiledHeaders.h" |
178 | 24 #include "DicomInstanceHasher.h" |
25 | |
26 #include "../OrthancException.h" | |
27 #include "../Toolbox.h" | |
28 | |
29 namespace Orthanc | |
30 { | |
315 | 31 void DicomInstanceHasher::Setup(const std::string& patientId, |
32 const std::string& studyUid, | |
33 const std::string& seriesUid, | |
34 const std::string& instanceUid) | |
178 | 35 { |
315 | 36 patientId_ = patientId; |
37 studyUid_ = studyUid; | |
38 seriesUid_ = seriesUid; | |
39 instanceUid_ = instanceUid; | |
178 | 40 |
1228
e0f7014d39a4
Instances without PatientID are now allowed
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
824
diff
changeset
|
41 if (studyUid_.size() == 0 || |
178 | 42 seriesUid_.size() == 0 || |
179 | 43 instanceUid_.size() == 0) |
178 | 44 { |
2971 | 45 throw OrthancException(ErrorCode_BadFileFormat, "missing StudyInstanceUID, SeriesInstanceUID or SOPInstanceUID"); |
178 | 46 } |
47 } | |
48 | |
315 | 49 DicomInstanceHasher::DicomInstanceHasher(const DicomMap& instance) |
50 { | |
1228
e0f7014d39a4
Instances without PatientID are now allowed
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
824
diff
changeset
|
51 const DicomValue* patientId = instance.TestAndGetValue(DICOM_TAG_PATIENT_ID); |
e0f7014d39a4
Instances without PatientID are now allowed
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
824
diff
changeset
|
52 |
1737
ec66a16aa398
removal of DicomStringValue and DicomNullValue
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
1288
diff
changeset
|
53 Setup(patientId == NULL ? "" : patientId->GetContent(), |
ec66a16aa398
removal of DicomStringValue and DicomNullValue
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
1288
diff
changeset
|
54 instance.GetValue(DICOM_TAG_STUDY_INSTANCE_UID).GetContent(), |
ec66a16aa398
removal of DicomStringValue and DicomNullValue
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
1288
diff
changeset
|
55 instance.GetValue(DICOM_TAG_SERIES_INSTANCE_UID).GetContent(), |
ec66a16aa398
removal of DicomStringValue and DicomNullValue
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
1288
diff
changeset
|
56 instance.GetValue(DICOM_TAG_SOP_INSTANCE_UID).GetContent()); |
315 | 57 } |
58 | |
179 | 59 const std::string& DicomInstanceHasher::HashPatient() |
178 | 60 { |
179 | 61 if (patientHash_.size() == 0) |
62 { | |
63 Toolbox::ComputeSHA1(patientHash_, patientId_); | |
64 } | |
65 | |
66 return patientHash_; | |
178 | 67 } |
68 | |
179 | 69 const std::string& DicomInstanceHasher::HashStudy() |
178 | 70 { |
179 | 71 if (studyHash_.size() == 0) |
72 { | |
73 Toolbox::ComputeSHA1(studyHash_, patientId_ + "|" + studyUid_); | |
74 } | |
75 | |
76 return studyHash_; | |
178 | 77 } |
78 | |
179 | 79 const std::string& DicomInstanceHasher::HashSeries() |
178 | 80 { |
179 | 81 if (seriesHash_.size() == 0) |
82 { | |
83 Toolbox::ComputeSHA1(seriesHash_, patientId_ + "|" + studyUid_ + "|" + seriesUid_); | |
84 } | |
85 | |
86 return seriesHash_; | |
178 | 87 } |
88 | |
179 | 89 const std::string& DicomInstanceHasher::HashInstance() |
178 | 90 { |
179 | 91 if (instanceHash_.size() == 0) |
92 { | |
93 Toolbox::ComputeSHA1(instanceHash_, patientId_ + "|" + studyUid_ + "|" + seriesUid_ + "|" + instanceUid_); | |
94 } | |
95 | |
96 return instanceHash_; | |
178 | 97 } |
98 } |