5770
|
1 /**
|
|
2 * Orthanc - A Lightweight, RESTful DICOM Store
|
|
3 * Copyright (C) 2012-2016 Sebastien Jodogne, Medical Physics
|
|
4 * Department, University Hospital of Liege, Belgium
|
|
5 * Copyright (C) 2017-2023 Osimis S.A., Belgium
|
|
6 * Copyright (C) 2024-2024 Orthanc Team SRL, Belgium
|
|
7 * Copyright (C) 2021-2024 Sebastien Jodogne, ICTEAM UCLouvain, Belgium
|
|
8 *
|
|
9 * This program is free software: you can redistribute it and/or
|
|
10 * modify it under the terms of the GNU General Public License as
|
|
11 * published by the Free Software Foundation, either version 3 of the
|
|
12 * License, or (at your option) any later version.
|
|
13 *
|
|
14 * This program is distributed in the hope that it will be useful, but
|
|
15 * WITHOUT ANY WARRANTY; without even the implied warranty of
|
|
16 * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the GNU
|
|
17 * General Public License for more details.
|
|
18 *
|
|
19 * You should have received a copy of the GNU General Public License
|
|
20 * along with this program. If not, see <http://www.gnu.org/licenses/>.
|
|
21 **/
|
|
22
|
|
23
|
|
24 #include "../PrecompiledHeadersServer.h"
|
|
25 #include "DatabaseConstraints.h"
|
|
26
|
|
27 #include "../../../OrthancFramework/Sources/OrthancException.h"
|
|
28
|
|
29 #include <boost/lexical_cast.hpp>
|
|
30 #include <cassert>
|
|
31
|
|
32
|
|
33 namespace Orthanc
|
|
34 {
|
|
35 void DatabaseConstraints::Clear()
|
|
36 {
|
|
37 for (size_t i = 0; i < constraints_.size(); i++)
|
|
38 {
|
|
39 assert(constraints_[i] != NULL);
|
|
40 delete constraints_[i];
|
|
41 }
|
|
42
|
|
43 constraints_.clear();
|
|
44 }
|
|
45
|
|
46
|
|
47 void DatabaseConstraints::AddConstraint(DatabaseConstraint* constraint)
|
|
48 {
|
|
49 if (constraint == NULL)
|
|
50 {
|
|
51 throw OrthancException(ErrorCode_NullPointer);
|
|
52 }
|
|
53 else
|
|
54 {
|
|
55 constraints_.push_back(constraint);
|
|
56 }
|
|
57 }
|
|
58
|
|
59
|
|
60 const DatabaseConstraint& DatabaseConstraints::GetConstraint(size_t index) const
|
|
61 {
|
|
62 if (index >= constraints_.size())
|
|
63 {
|
|
64 throw OrthancException(ErrorCode_ParameterOutOfRange);
|
|
65 }
|
|
66 else
|
|
67 {
|
|
68 assert(constraints_[index] != NULL);
|
|
69 return *constraints_[index];
|
|
70 }
|
|
71 }
|
|
72
|
|
73
|
|
74 std::string DatabaseConstraints::Format() const
|
|
75 {
|
|
76 std::string s;
|
|
77
|
|
78 for (size_t i = 0; i < constraints_.size(); i++)
|
|
79 {
|
|
80 assert(constraints_[i] != NULL);
|
|
81 const DatabaseConstraint& constraint = *constraints_[i];
|
|
82 s += "Constraint " + boost::lexical_cast<std::string>(i) + " at " + EnumerationToString(constraint.GetLevel()) +
|
|
83 ": " + constraint.GetTag().Format();
|
|
84
|
|
85 switch (constraint.GetConstraintType())
|
|
86 {
|
|
87 case ConstraintType_Equal:
|
|
88 s += " == " + constraint.GetSingleValue();
|
|
89 break;
|
|
90
|
|
91 case ConstraintType_SmallerOrEqual:
|
|
92 s += " <= " + constraint.GetSingleValue();
|
|
93 break;
|
|
94
|
|
95 case ConstraintType_GreaterOrEqual:
|
|
96 s += " >= " + constraint.GetSingleValue();
|
|
97 break;
|
|
98
|
|
99 case ConstraintType_Wildcard:
|
|
100 s += " ~~ " + constraint.GetSingleValue();
|
|
101 break;
|
|
102
|
|
103 case ConstraintType_List:
|
|
104 {
|
|
105 s += " in [ ";
|
|
106 bool first = true;
|
|
107 for (size_t j = 0; j < constraint.GetValuesCount(); j++)
|
|
108 {
|
|
109 if (first)
|
|
110 {
|
|
111 first = false;
|
|
112 }
|
|
113 else
|
|
114 {
|
|
115 s += ", ";
|
|
116 }
|
|
117 s += constraint.GetValue(j);
|
|
118 }
|
|
119 s += "]";
|
|
120 break;
|
|
121 }
|
|
122
|
|
123 default:
|
|
124 throw OrthancException(ErrorCode_InternalError);
|
|
125 }
|
|
126
|
|
127 s += "\n";
|
|
128 }
|
|
129
|
|
130 return s;
|
|
131 }
|
|
132 }
|