annotate OrthancServer/Plugins/Samples/DbOptimizer/Plugin.cpp @ 4961:1b76853e1797 more-tags

DbOptimizer plugin
author Alain Mazy <am@osimis.io>
date Wed, 23 Mar 2022 11:56:28 +0100
parents
children
Ignore whitespace changes - Everywhere: Within whitespace: At end of lines:
rev   line source
4961
1b76853e1797 DbOptimizer plugin
Alain Mazy <am@osimis.io>
parents:
diff changeset
1 /**
1b76853e1797 DbOptimizer plugin
Alain Mazy <am@osimis.io>
parents:
diff changeset
2 * Orthanc - A Lightweight, RESTful DICOM Store
1b76853e1797 DbOptimizer plugin
Alain Mazy <am@osimis.io>
parents:
diff changeset
3 * Copyright (C) 2012-2016 Sebastien Jodogne, Medical Physics
1b76853e1797 DbOptimizer plugin
Alain Mazy <am@osimis.io>
parents:
diff changeset
4 * Department, University Hospital of Liege, Belgium
1b76853e1797 DbOptimizer plugin
Alain Mazy <am@osimis.io>
parents:
diff changeset
5 * Copyright (C) 2017-2022 Osimis S.A., Belgium
1b76853e1797 DbOptimizer plugin
Alain Mazy <am@osimis.io>
parents:
diff changeset
6 * Copyright (C) 2021-2022 Sebastien Jodogne, ICTEAM UCLouvain, Belgium
1b76853e1797 DbOptimizer plugin
Alain Mazy <am@osimis.io>
parents:
diff changeset
7 *
1b76853e1797 DbOptimizer plugin
Alain Mazy <am@osimis.io>
parents:
diff changeset
8 * This program is free software: you can redistribute it and/or
1b76853e1797 DbOptimizer plugin
Alain Mazy <am@osimis.io>
parents:
diff changeset
9 * modify it under the terms of the GNU General Public License as
1b76853e1797 DbOptimizer plugin
Alain Mazy <am@osimis.io>
parents:
diff changeset
10 * published by the Free Software Foundation, either version 3 of the
1b76853e1797 DbOptimizer plugin
Alain Mazy <am@osimis.io>
parents:
diff changeset
11 * License, or (at your option) any later version.
1b76853e1797 DbOptimizer plugin
Alain Mazy <am@osimis.io>
parents:
diff changeset
12 *
1b76853e1797 DbOptimizer plugin
Alain Mazy <am@osimis.io>
parents:
diff changeset
13 * This program is distributed in the hope that it will be useful, but
1b76853e1797 DbOptimizer plugin
Alain Mazy <am@osimis.io>
parents:
diff changeset
14 * WITHOUT ANY WARRANTY; without even the implied warranty of
1b76853e1797 DbOptimizer plugin
Alain Mazy <am@osimis.io>
parents:
diff changeset
15 * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the GNU
1b76853e1797 DbOptimizer plugin
Alain Mazy <am@osimis.io>
parents:
diff changeset
16 * General Public License for more details.
1b76853e1797 DbOptimizer plugin
Alain Mazy <am@osimis.io>
parents:
diff changeset
17 *
1b76853e1797 DbOptimizer plugin
Alain Mazy <am@osimis.io>
parents:
diff changeset
18 * You should have received a copy of the GNU General Public License
1b76853e1797 DbOptimizer plugin
Alain Mazy <am@osimis.io>
parents:
diff changeset
19 * along with this program. If not, see <http://www.gnu.org/licenses/>.
1b76853e1797 DbOptimizer plugin
Alain Mazy <am@osimis.io>
parents:
diff changeset
20 **/
1b76853e1797 DbOptimizer plugin
Alain Mazy <am@osimis.io>
parents:
diff changeset
21
1b76853e1797 DbOptimizer plugin
Alain Mazy <am@osimis.io>
parents:
diff changeset
22
1b76853e1797 DbOptimizer plugin
Alain Mazy <am@osimis.io>
parents:
diff changeset
23 #include "../../../../OrthancFramework/Sources/Compatibility.h"
1b76853e1797 DbOptimizer plugin
Alain Mazy <am@osimis.io>
parents:
diff changeset
24 #include "../Common/OrthancPluginCppWrapper.h"
1b76853e1797 DbOptimizer plugin
Alain Mazy <am@osimis.io>
parents:
diff changeset
25
1b76853e1797 DbOptimizer plugin
Alain Mazy <am@osimis.io>
parents:
diff changeset
26 #include <boost/thread.hpp>
1b76853e1797 DbOptimizer plugin
Alain Mazy <am@osimis.io>
parents:
diff changeset
27 #include <json/value.h>
1b76853e1797 DbOptimizer plugin
Alain Mazy <am@osimis.io>
parents:
diff changeset
28 #include <json/writer.h>
1b76853e1797 DbOptimizer plugin
Alain Mazy <am@osimis.io>
parents:
diff changeset
29 #include <string.h>
1b76853e1797 DbOptimizer plugin
Alain Mazy <am@osimis.io>
parents:
diff changeset
30 #include <iostream>
1b76853e1797 DbOptimizer plugin
Alain Mazy <am@osimis.io>
parents:
diff changeset
31 #include <algorithm>
1b76853e1797 DbOptimizer plugin
Alain Mazy <am@osimis.io>
parents:
diff changeset
32 #include <map>
1b76853e1797 DbOptimizer plugin
Alain Mazy <am@osimis.io>
parents:
diff changeset
33
1b76853e1797 DbOptimizer plugin
Alain Mazy <am@osimis.io>
parents:
diff changeset
34 static int globalPropertyId_ = 0;
1b76853e1797 DbOptimizer plugin
Alain Mazy <am@osimis.io>
parents:
diff changeset
35 static bool force_ = false;
1b76853e1797 DbOptimizer plugin
Alain Mazy <am@osimis.io>
parents:
diff changeset
36 static uint throttleDelay_ = 0;
1b76853e1797 DbOptimizer plugin
Alain Mazy <am@osimis.io>
parents:
diff changeset
37 static std::unique_ptr<boost::thread> workerThread_;
1b76853e1797 DbOptimizer plugin
Alain Mazy <am@osimis.io>
parents:
diff changeset
38 static bool workerThreadShouldStop = false;
1b76853e1797 DbOptimizer plugin
Alain Mazy <am@osimis.io>
parents:
diff changeset
39
1b76853e1797 DbOptimizer plugin
Alain Mazy <am@osimis.io>
parents:
diff changeset
40 struct DbConfiguration
1b76853e1797 DbOptimizer plugin
Alain Mazy <am@osimis.io>
parents:
diff changeset
41 {
1b76853e1797 DbOptimizer plugin
Alain Mazy <am@osimis.io>
parents:
diff changeset
42 std::string orthancVersion;
1b76853e1797 DbOptimizer plugin
Alain Mazy <am@osimis.io>
parents:
diff changeset
43 std::map<OrthancPluginResourceType, std::string> mainDicomTagsSignature;
1b76853e1797 DbOptimizer plugin
Alain Mazy <am@osimis.io>
parents:
diff changeset
44
1b76853e1797 DbOptimizer plugin
Alain Mazy <am@osimis.io>
parents:
diff changeset
45 DbConfiguration()
1b76853e1797 DbOptimizer plugin
Alain Mazy <am@osimis.io>
parents:
diff changeset
46 {
1b76853e1797 DbOptimizer plugin
Alain Mazy <am@osimis.io>
parents:
diff changeset
47 }
1b76853e1797 DbOptimizer plugin
Alain Mazy <am@osimis.io>
parents:
diff changeset
48
1b76853e1797 DbOptimizer plugin
Alain Mazy <am@osimis.io>
parents:
diff changeset
49 bool IsDefined() const
1b76853e1797 DbOptimizer plugin
Alain Mazy <am@osimis.io>
parents:
diff changeset
50 {
1b76853e1797 DbOptimizer plugin
Alain Mazy <am@osimis.io>
parents:
diff changeset
51 return !orthancVersion.empty() && mainDicomTagsSignature.size() == 4;
1b76853e1797 DbOptimizer plugin
Alain Mazy <am@osimis.io>
parents:
diff changeset
52 }
1b76853e1797 DbOptimizer plugin
Alain Mazy <am@osimis.io>
parents:
diff changeset
53
1b76853e1797 DbOptimizer plugin
Alain Mazy <am@osimis.io>
parents:
diff changeset
54 void Clear()
1b76853e1797 DbOptimizer plugin
Alain Mazy <am@osimis.io>
parents:
diff changeset
55 {
1b76853e1797 DbOptimizer plugin
Alain Mazy <am@osimis.io>
parents:
diff changeset
56 orthancVersion.clear();
1b76853e1797 DbOptimizer plugin
Alain Mazy <am@osimis.io>
parents:
diff changeset
57 mainDicomTagsSignature.clear();
1b76853e1797 DbOptimizer plugin
Alain Mazy <am@osimis.io>
parents:
diff changeset
58 }
1b76853e1797 DbOptimizer plugin
Alain Mazy <am@osimis.io>
parents:
diff changeset
59
1b76853e1797 DbOptimizer plugin
Alain Mazy <am@osimis.io>
parents:
diff changeset
60 void ToJson(Json::Value& target)
1b76853e1797 DbOptimizer plugin
Alain Mazy <am@osimis.io>
parents:
diff changeset
61 {
1b76853e1797 DbOptimizer plugin
Alain Mazy <am@osimis.io>
parents:
diff changeset
62 if (!IsDefined())
1b76853e1797 DbOptimizer plugin
Alain Mazy <am@osimis.io>
parents:
diff changeset
63 {
1b76853e1797 DbOptimizer plugin
Alain Mazy <am@osimis.io>
parents:
diff changeset
64 target = Json::nullValue;
1b76853e1797 DbOptimizer plugin
Alain Mazy <am@osimis.io>
parents:
diff changeset
65 }
1b76853e1797 DbOptimizer plugin
Alain Mazy <am@osimis.io>
parents:
diff changeset
66 else
1b76853e1797 DbOptimizer plugin
Alain Mazy <am@osimis.io>
parents:
diff changeset
67 {
1b76853e1797 DbOptimizer plugin
Alain Mazy <am@osimis.io>
parents:
diff changeset
68 Json::Value signatures;
1b76853e1797 DbOptimizer plugin
Alain Mazy <am@osimis.io>
parents:
diff changeset
69
1b76853e1797 DbOptimizer plugin
Alain Mazy <am@osimis.io>
parents:
diff changeset
70 target = Json::objectValue;
1b76853e1797 DbOptimizer plugin
Alain Mazy <am@osimis.io>
parents:
diff changeset
71
1b76853e1797 DbOptimizer plugin
Alain Mazy <am@osimis.io>
parents:
diff changeset
72 // default main dicom tags signature are the one from Orthanc 1.4.2 (last time the list was changed):
1b76853e1797 DbOptimizer plugin
Alain Mazy <am@osimis.io>
parents:
diff changeset
73 signatures["Patient"] = mainDicomTagsSignature[OrthancPluginResourceType_Patient];
1b76853e1797 DbOptimizer plugin
Alain Mazy <am@osimis.io>
parents:
diff changeset
74 signatures["Study"] = mainDicomTagsSignature[OrthancPluginResourceType_Study];
1b76853e1797 DbOptimizer plugin
Alain Mazy <am@osimis.io>
parents:
diff changeset
75 signatures["Series"] = mainDicomTagsSignature[OrthancPluginResourceType_Series];
1b76853e1797 DbOptimizer plugin
Alain Mazy <am@osimis.io>
parents:
diff changeset
76 signatures["Instance"] = mainDicomTagsSignature[OrthancPluginResourceType_Instance];
1b76853e1797 DbOptimizer plugin
Alain Mazy <am@osimis.io>
parents:
diff changeset
77
1b76853e1797 DbOptimizer plugin
Alain Mazy <am@osimis.io>
parents:
diff changeset
78 target["MainDicomTagsSignature"] = signatures;
1b76853e1797 DbOptimizer plugin
Alain Mazy <am@osimis.io>
parents:
diff changeset
79 target["OrthancVersion"] = orthancVersion;
1b76853e1797 DbOptimizer plugin
Alain Mazy <am@osimis.io>
parents:
diff changeset
80 }
1b76853e1797 DbOptimizer plugin
Alain Mazy <am@osimis.io>
parents:
diff changeset
81 }
1b76853e1797 DbOptimizer plugin
Alain Mazy <am@osimis.io>
parents:
diff changeset
82
1b76853e1797 DbOptimizer plugin
Alain Mazy <am@osimis.io>
parents:
diff changeset
83 void FromJson(Json::Value& source)
1b76853e1797 DbOptimizer plugin
Alain Mazy <am@osimis.io>
parents:
diff changeset
84 {
1b76853e1797 DbOptimizer plugin
Alain Mazy <am@osimis.io>
parents:
diff changeset
85 if (!source.isNull())
1b76853e1797 DbOptimizer plugin
Alain Mazy <am@osimis.io>
parents:
diff changeset
86 {
1b76853e1797 DbOptimizer plugin
Alain Mazy <am@osimis.io>
parents:
diff changeset
87 orthancVersion = source["OrthancVersion"].asString();
1b76853e1797 DbOptimizer plugin
Alain Mazy <am@osimis.io>
parents:
diff changeset
88
1b76853e1797 DbOptimizer plugin
Alain Mazy <am@osimis.io>
parents:
diff changeset
89 const Json::Value& signatures = source["MainDicomTagsSignature"];
1b76853e1797 DbOptimizer plugin
Alain Mazy <am@osimis.io>
parents:
diff changeset
90 mainDicomTagsSignature[OrthancPluginResourceType_Patient] = signatures["Patient"].asString();
1b76853e1797 DbOptimizer plugin
Alain Mazy <am@osimis.io>
parents:
diff changeset
91 mainDicomTagsSignature[OrthancPluginResourceType_Study] = signatures["Study"].asString();
1b76853e1797 DbOptimizer plugin
Alain Mazy <am@osimis.io>
parents:
diff changeset
92 mainDicomTagsSignature[OrthancPluginResourceType_Series] = signatures["Series"].asString();
1b76853e1797 DbOptimizer plugin
Alain Mazy <am@osimis.io>
parents:
diff changeset
93 mainDicomTagsSignature[OrthancPluginResourceType_Instance] = signatures["Instance"].asString();
1b76853e1797 DbOptimizer plugin
Alain Mazy <am@osimis.io>
parents:
diff changeset
94 }
1b76853e1797 DbOptimizer plugin
Alain Mazy <am@osimis.io>
parents:
diff changeset
95 }
1b76853e1797 DbOptimizer plugin
Alain Mazy <am@osimis.io>
parents:
diff changeset
96 };
1b76853e1797 DbOptimizer plugin
Alain Mazy <am@osimis.io>
parents:
diff changeset
97
1b76853e1797 DbOptimizer plugin
Alain Mazy <am@osimis.io>
parents:
diff changeset
98 struct PluginStatus
1b76853e1797 DbOptimizer plugin
Alain Mazy <am@osimis.io>
parents:
diff changeset
99 {
1b76853e1797 DbOptimizer plugin
Alain Mazy <am@osimis.io>
parents:
diff changeset
100 int statusVersion;
1b76853e1797 DbOptimizer plugin
Alain Mazy <am@osimis.io>
parents:
diff changeset
101 int64_t lastProcessedChange;
1b76853e1797 DbOptimizer plugin
Alain Mazy <am@osimis.io>
parents:
diff changeset
102 int64_t lastChangeToProcess;
1b76853e1797 DbOptimizer plugin
Alain Mazy <am@osimis.io>
parents:
diff changeset
103
1b76853e1797 DbOptimizer plugin
Alain Mazy <am@osimis.io>
parents:
diff changeset
104 DbConfiguration currentlyProcessingConfiguration; // last configuration being processed (has not reached last change yet)
1b76853e1797 DbOptimizer plugin
Alain Mazy <am@osimis.io>
parents:
diff changeset
105 DbConfiguration lastProcessedConfiguration; // last configuration that has been fully processed (till last change)
1b76853e1797 DbOptimizer plugin
Alain Mazy <am@osimis.io>
parents:
diff changeset
106
1b76853e1797 DbOptimizer plugin
Alain Mazy <am@osimis.io>
parents:
diff changeset
107 PluginStatus()
1b76853e1797 DbOptimizer plugin
Alain Mazy <am@osimis.io>
parents:
diff changeset
108 : statusVersion(1),
1b76853e1797 DbOptimizer plugin
Alain Mazy <am@osimis.io>
parents:
diff changeset
109 lastProcessedChange(-1),
1b76853e1797 DbOptimizer plugin
Alain Mazy <am@osimis.io>
parents:
diff changeset
110 lastChangeToProcess(-1)
1b76853e1797 DbOptimizer plugin
Alain Mazy <am@osimis.io>
parents:
diff changeset
111 {
1b76853e1797 DbOptimizer plugin
Alain Mazy <am@osimis.io>
parents:
diff changeset
112 }
1b76853e1797 DbOptimizer plugin
Alain Mazy <am@osimis.io>
parents:
diff changeset
113
1b76853e1797 DbOptimizer plugin
Alain Mazy <am@osimis.io>
parents:
diff changeset
114 void ToJson(Json::Value& target)
1b76853e1797 DbOptimizer plugin
Alain Mazy <am@osimis.io>
parents:
diff changeset
115 {
1b76853e1797 DbOptimizer plugin
Alain Mazy <am@osimis.io>
parents:
diff changeset
116 target = Json::objectValue;
1b76853e1797 DbOptimizer plugin
Alain Mazy <am@osimis.io>
parents:
diff changeset
117
1b76853e1797 DbOptimizer plugin
Alain Mazy <am@osimis.io>
parents:
diff changeset
118 target["Version"] = statusVersion;
1b76853e1797 DbOptimizer plugin
Alain Mazy <am@osimis.io>
parents:
diff changeset
119 target["LastProcessedChange"] = Json::Value::Int64(lastProcessedChange);
1b76853e1797 DbOptimizer plugin
Alain Mazy <am@osimis.io>
parents:
diff changeset
120 target["LastChangeToProcess"] = Json::Value::Int64(lastChangeToProcess);
1b76853e1797 DbOptimizer plugin
Alain Mazy <am@osimis.io>
parents:
diff changeset
121
1b76853e1797 DbOptimizer plugin
Alain Mazy <am@osimis.io>
parents:
diff changeset
122 currentlyProcessingConfiguration.ToJson(target["CurrentlyProcessingConfiguration"]);
1b76853e1797 DbOptimizer plugin
Alain Mazy <am@osimis.io>
parents:
diff changeset
123 lastProcessedConfiguration.ToJson(target["LastProcessedConfiguration"]);
1b76853e1797 DbOptimizer plugin
Alain Mazy <am@osimis.io>
parents:
diff changeset
124 }
1b76853e1797 DbOptimizer plugin
Alain Mazy <am@osimis.io>
parents:
diff changeset
125
1b76853e1797 DbOptimizer plugin
Alain Mazy <am@osimis.io>
parents:
diff changeset
126 void FromJson(Json::Value& source)
1b76853e1797 DbOptimizer plugin
Alain Mazy <am@osimis.io>
parents:
diff changeset
127 {
1b76853e1797 DbOptimizer plugin
Alain Mazy <am@osimis.io>
parents:
diff changeset
128 statusVersion = source["Version"].asInt();
1b76853e1797 DbOptimizer plugin
Alain Mazy <am@osimis.io>
parents:
diff changeset
129 lastProcessedChange = source["LastProcessedChange"].asInt64();
1b76853e1797 DbOptimizer plugin
Alain Mazy <am@osimis.io>
parents:
diff changeset
130 lastChangeToProcess = source["LastChangeToProcess"].asInt64();
1b76853e1797 DbOptimizer plugin
Alain Mazy <am@osimis.io>
parents:
diff changeset
131
1b76853e1797 DbOptimizer plugin
Alain Mazy <am@osimis.io>
parents:
diff changeset
132 Json::Value& current = source["CurrentlyProcessingConfiguration"];
1b76853e1797 DbOptimizer plugin
Alain Mazy <am@osimis.io>
parents:
diff changeset
133 Json::Value& last = source["LastProcessedConfiguration"];
1b76853e1797 DbOptimizer plugin
Alain Mazy <am@osimis.io>
parents:
diff changeset
134
1b76853e1797 DbOptimizer plugin
Alain Mazy <am@osimis.io>
parents:
diff changeset
135 currentlyProcessingConfiguration.FromJson(current);
1b76853e1797 DbOptimizer plugin
Alain Mazy <am@osimis.io>
parents:
diff changeset
136 lastProcessedConfiguration.FromJson(last);
1b76853e1797 DbOptimizer plugin
Alain Mazy <am@osimis.io>
parents:
diff changeset
137 }
1b76853e1797 DbOptimizer plugin
Alain Mazy <am@osimis.io>
parents:
diff changeset
138 };
1b76853e1797 DbOptimizer plugin
Alain Mazy <am@osimis.io>
parents:
diff changeset
139
1b76853e1797 DbOptimizer plugin
Alain Mazy <am@osimis.io>
parents:
diff changeset
140
1b76853e1797 DbOptimizer plugin
Alain Mazy <am@osimis.io>
parents:
diff changeset
141 static void ReadStatusFromDb(PluginStatus& pluginStatus)
1b76853e1797 DbOptimizer plugin
Alain Mazy <am@osimis.io>
parents:
diff changeset
142 {
1b76853e1797 DbOptimizer plugin
Alain Mazy <am@osimis.io>
parents:
diff changeset
143 OrthancPlugins::OrthancString globalPropertyContent;
1b76853e1797 DbOptimizer plugin
Alain Mazy <am@osimis.io>
parents:
diff changeset
144
1b76853e1797 DbOptimizer plugin
Alain Mazy <am@osimis.io>
parents:
diff changeset
145 globalPropertyContent.Assign(OrthancPluginGetGlobalProperty(OrthancPlugins::GetGlobalContext(),
1b76853e1797 DbOptimizer plugin
Alain Mazy <am@osimis.io>
parents:
diff changeset
146 globalPropertyId_,
1b76853e1797 DbOptimizer plugin
Alain Mazy <am@osimis.io>
parents:
diff changeset
147 ""));
1b76853e1797 DbOptimizer plugin
Alain Mazy <am@osimis.io>
parents:
diff changeset
148
1b76853e1797 DbOptimizer plugin
Alain Mazy <am@osimis.io>
parents:
diff changeset
149 if (!globalPropertyContent.IsNullOrEmpty())
1b76853e1797 DbOptimizer plugin
Alain Mazy <am@osimis.io>
parents:
diff changeset
150 {
1b76853e1797 DbOptimizer plugin
Alain Mazy <am@osimis.io>
parents:
diff changeset
151 Json::Value jsonStatus;
1b76853e1797 DbOptimizer plugin
Alain Mazy <am@osimis.io>
parents:
diff changeset
152 globalPropertyContent.ToJson(jsonStatus);
1b76853e1797 DbOptimizer plugin
Alain Mazy <am@osimis.io>
parents:
diff changeset
153 pluginStatus.FromJson(jsonStatus);
1b76853e1797 DbOptimizer plugin
Alain Mazy <am@osimis.io>
parents:
diff changeset
154 }
1b76853e1797 DbOptimizer plugin
Alain Mazy <am@osimis.io>
parents:
diff changeset
155 else
1b76853e1797 DbOptimizer plugin
Alain Mazy <am@osimis.io>
parents:
diff changeset
156 {
1b76853e1797 DbOptimizer plugin
Alain Mazy <am@osimis.io>
parents:
diff changeset
157 // default config
1b76853e1797 DbOptimizer plugin
Alain Mazy <am@osimis.io>
parents:
diff changeset
158 pluginStatus.statusVersion = 1;
1b76853e1797 DbOptimizer plugin
Alain Mazy <am@osimis.io>
parents:
diff changeset
159 pluginStatus.lastProcessedChange = -1;
1b76853e1797 DbOptimizer plugin
Alain Mazy <am@osimis.io>
parents:
diff changeset
160 pluginStatus.lastChangeToProcess = -1;
1b76853e1797 DbOptimizer plugin
Alain Mazy <am@osimis.io>
parents:
diff changeset
161
1b76853e1797 DbOptimizer plugin
Alain Mazy <am@osimis.io>
parents:
diff changeset
162 pluginStatus.currentlyProcessingConfiguration.orthancVersion = "1.9.0"; // when we don't know, we assume some files were stored with Orthanc 1.9.0 (last version saving the dicom-as-json files)
1b76853e1797 DbOptimizer plugin
Alain Mazy <am@osimis.io>
parents:
diff changeset
163
1b76853e1797 DbOptimizer plugin
Alain Mazy <am@osimis.io>
parents:
diff changeset
164 // default main dicom tags signature are the one from Orthanc 1.4.2 (last time the list was changed):
1b76853e1797 DbOptimizer plugin
Alain Mazy <am@osimis.io>
parents:
diff changeset
165 pluginStatus.currentlyProcessingConfiguration.mainDicomTagsSignature[OrthancPluginResourceType_Patient] = "0010,0010;0010,0020;0010,0030;0010,0040;0010,1000";
1b76853e1797 DbOptimizer plugin
Alain Mazy <am@osimis.io>
parents:
diff changeset
166 pluginStatus.currentlyProcessingConfiguration.mainDicomTagsSignature[OrthancPluginResourceType_Study] = "0008,0020;0008,0030;0008,0050;0008,0080;0008,0090;0008,1030;0020,000d;0020,0010;0032,1032;0032,1060";
1b76853e1797 DbOptimizer plugin
Alain Mazy <am@osimis.io>
parents:
diff changeset
167 pluginStatus.currentlyProcessingConfiguration.mainDicomTagsSignature[OrthancPluginResourceType_Series] = "0008,0021;0008,0031;0008,0060;0008,0070;0008,1010;0008,103e;0008,1070;0018,0010;0018,0015;0018,0024;0018,1030;0018,1090;0018,1400;0020,000e;0020,0011;0020,0037;0020,0105;0020,1002;0040,0254;0054,0081;0054,0101;0054,1000";
1b76853e1797 DbOptimizer plugin
Alain Mazy <am@osimis.io>
parents:
diff changeset
168 pluginStatus.currentlyProcessingConfiguration.mainDicomTagsSignature[OrthancPluginResourceType_Instance] = "0008,0012;0008,0013;0008,0018;0020,0012;0020,0013;0020,0032;0020,0037;0020,0100;0020,4000;0028,0008;0054,1330";
1b76853e1797 DbOptimizer plugin
Alain Mazy <am@osimis.io>
parents:
diff changeset
169 }
1b76853e1797 DbOptimizer plugin
Alain Mazy <am@osimis.io>
parents:
diff changeset
170 }
1b76853e1797 DbOptimizer plugin
Alain Mazy <am@osimis.io>
parents:
diff changeset
171
1b76853e1797 DbOptimizer plugin
Alain Mazy <am@osimis.io>
parents:
diff changeset
172 static void SaveStatusInDb(PluginStatus& pluginStatus)
1b76853e1797 DbOptimizer plugin
Alain Mazy <am@osimis.io>
parents:
diff changeset
173 {
1b76853e1797 DbOptimizer plugin
Alain Mazy <am@osimis.io>
parents:
diff changeset
174 Json::Value jsonStatus;
1b76853e1797 DbOptimizer plugin
Alain Mazy <am@osimis.io>
parents:
diff changeset
175 pluginStatus.ToJson(jsonStatus);
1b76853e1797 DbOptimizer plugin
Alain Mazy <am@osimis.io>
parents:
diff changeset
176
1b76853e1797 DbOptimizer plugin
Alain Mazy <am@osimis.io>
parents:
diff changeset
177 Json::StreamWriterBuilder builder;
1b76853e1797 DbOptimizer plugin
Alain Mazy <am@osimis.io>
parents:
diff changeset
178 builder.settings_["indentation"] = " ";
1b76853e1797 DbOptimizer plugin
Alain Mazy <am@osimis.io>
parents:
diff changeset
179 std::string serializedStatus = Json::writeString(builder, jsonStatus);
1b76853e1797 DbOptimizer plugin
Alain Mazy <am@osimis.io>
parents:
diff changeset
180
1b76853e1797 DbOptimizer plugin
Alain Mazy <am@osimis.io>
parents:
diff changeset
181 OrthancPluginSetGlobalProperty(OrthancPlugins::GetGlobalContext(),
1b76853e1797 DbOptimizer plugin
Alain Mazy <am@osimis.io>
parents:
diff changeset
182 globalPropertyId_,
1b76853e1797 DbOptimizer plugin
Alain Mazy <am@osimis.io>
parents:
diff changeset
183 serializedStatus.c_str());
1b76853e1797 DbOptimizer plugin
Alain Mazy <am@osimis.io>
parents:
diff changeset
184 }
1b76853e1797 DbOptimizer plugin
Alain Mazy <am@osimis.io>
parents:
diff changeset
185
1b76853e1797 DbOptimizer plugin
Alain Mazy <am@osimis.io>
parents:
diff changeset
186 static void GetCurrentDbConfiguration(DbConfiguration& configuration)
1b76853e1797 DbOptimizer plugin
Alain Mazy <am@osimis.io>
parents:
diff changeset
187 {
1b76853e1797 DbOptimizer plugin
Alain Mazy <am@osimis.io>
parents:
diff changeset
188 Json::Value signatures;
1b76853e1797 DbOptimizer plugin
Alain Mazy <am@osimis.io>
parents:
diff changeset
189 Json::Value systemInfo;
1b76853e1797 DbOptimizer plugin
Alain Mazy <am@osimis.io>
parents:
diff changeset
190
1b76853e1797 DbOptimizer plugin
Alain Mazy <am@osimis.io>
parents:
diff changeset
191 OrthancPlugins::RestApiGet(systemInfo, "/system", false);
1b76853e1797 DbOptimizer plugin
Alain Mazy <am@osimis.io>
parents:
diff changeset
192 configuration.mainDicomTagsSignature[OrthancPluginResourceType_Patient] = systemInfo["MainDicomTags"]["Patient"].asString();
1b76853e1797 DbOptimizer plugin
Alain Mazy <am@osimis.io>
parents:
diff changeset
193 configuration.mainDicomTagsSignature[OrthancPluginResourceType_Study] = systemInfo["MainDicomTags"]["Study"].asString();
1b76853e1797 DbOptimizer plugin
Alain Mazy <am@osimis.io>
parents:
diff changeset
194 configuration.mainDicomTagsSignature[OrthancPluginResourceType_Series] = systemInfo["MainDicomTags"]["Series"].asString();
1b76853e1797 DbOptimizer plugin
Alain Mazy <am@osimis.io>
parents:
diff changeset
195 configuration.mainDicomTagsSignature[OrthancPluginResourceType_Instance] = systemInfo["MainDicomTags"]["Instance"].asString();
1b76853e1797 DbOptimizer plugin
Alain Mazy <am@osimis.io>
parents:
diff changeset
196
1b76853e1797 DbOptimizer plugin
Alain Mazy <am@osimis.io>
parents:
diff changeset
197 configuration.orthancVersion = OrthancPlugins::GetGlobalContext()->orthancVersion;
1b76853e1797 DbOptimizer plugin
Alain Mazy <am@osimis.io>
parents:
diff changeset
198 }
1b76853e1797 DbOptimizer plugin
Alain Mazy <am@osimis.io>
parents:
diff changeset
199
1b76853e1797 DbOptimizer plugin
Alain Mazy <am@osimis.io>
parents:
diff changeset
200 static bool NeedsProcessing(const DbConfiguration& current, const DbConfiguration& last)
1b76853e1797 DbOptimizer plugin
Alain Mazy <am@osimis.io>
parents:
diff changeset
201 {
1b76853e1797 DbOptimizer plugin
Alain Mazy <am@osimis.io>
parents:
diff changeset
202 if (!last.IsDefined())
1b76853e1797 DbOptimizer plugin
Alain Mazy <am@osimis.io>
parents:
diff changeset
203 {
1b76853e1797 DbOptimizer plugin
Alain Mazy <am@osimis.io>
parents:
diff changeset
204 return true;
1b76853e1797 DbOptimizer plugin
Alain Mazy <am@osimis.io>
parents:
diff changeset
205 }
1b76853e1797 DbOptimizer plugin
Alain Mazy <am@osimis.io>
parents:
diff changeset
206
1b76853e1797 DbOptimizer plugin
Alain Mazy <am@osimis.io>
parents:
diff changeset
207 const char* lastVersion = last.orthancVersion.c_str();
1b76853e1797 DbOptimizer plugin
Alain Mazy <am@osimis.io>
parents:
diff changeset
208 const std::map<OrthancPluginResourceType, std::string>& lastTags = last.mainDicomTagsSignature;
1b76853e1797 DbOptimizer plugin
Alain Mazy <am@osimis.io>
parents:
diff changeset
209 const std::map<OrthancPluginResourceType, std::string>& currentTags = current.mainDicomTagsSignature;
1b76853e1797 DbOptimizer plugin
Alain Mazy <am@osimis.io>
parents:
diff changeset
210 bool needsProcessing = false;
1b76853e1797 DbOptimizer plugin
Alain Mazy <am@osimis.io>
parents:
diff changeset
211
1b76853e1797 DbOptimizer plugin
Alain Mazy <am@osimis.io>
parents:
diff changeset
212 if (!OrthancPlugins::CheckMinimalVersion(lastVersion, 1, 9, 1))
1b76853e1797 DbOptimizer plugin
Alain Mazy <am@osimis.io>
parents:
diff changeset
213 {
1b76853e1797 DbOptimizer plugin
Alain Mazy <am@osimis.io>
parents:
diff changeset
214 OrthancPlugins::LogWarning("DbOptimizer: your storage might still contain some dicom-as-json files -> will reconstruct DB");
1b76853e1797 DbOptimizer plugin
Alain Mazy <am@osimis.io>
parents:
diff changeset
215 needsProcessing = true;
1b76853e1797 DbOptimizer plugin
Alain Mazy <am@osimis.io>
parents:
diff changeset
216 }
1b76853e1797 DbOptimizer plugin
Alain Mazy <am@osimis.io>
parents:
diff changeset
217
1b76853e1797 DbOptimizer plugin
Alain Mazy <am@osimis.io>
parents:
diff changeset
218 if (lastTags.at(OrthancPluginResourceType_Patient) != currentTags.at(OrthancPluginResourceType_Patient))
1b76853e1797 DbOptimizer plugin
Alain Mazy <am@osimis.io>
parents:
diff changeset
219 {
1b76853e1797 DbOptimizer plugin
Alain Mazy <am@osimis.io>
parents:
diff changeset
220 OrthancPlugins::LogWarning("DbOptimizer: Patient main dicom tags have changed, -> will reconstruct DB");
1b76853e1797 DbOptimizer plugin
Alain Mazy <am@osimis.io>
parents:
diff changeset
221 needsProcessing = true;
1b76853e1797 DbOptimizer plugin
Alain Mazy <am@osimis.io>
parents:
diff changeset
222 }
1b76853e1797 DbOptimizer plugin
Alain Mazy <am@osimis.io>
parents:
diff changeset
223
1b76853e1797 DbOptimizer plugin
Alain Mazy <am@osimis.io>
parents:
diff changeset
224 if (lastTags.at(OrthancPluginResourceType_Study) != currentTags.at(OrthancPluginResourceType_Study))
1b76853e1797 DbOptimizer plugin
Alain Mazy <am@osimis.io>
parents:
diff changeset
225 {
1b76853e1797 DbOptimizer plugin
Alain Mazy <am@osimis.io>
parents:
diff changeset
226 OrthancPlugins::LogWarning("DbOptimizer: Study main dicom tags have changed, -> will reconstruct DB");
1b76853e1797 DbOptimizer plugin
Alain Mazy <am@osimis.io>
parents:
diff changeset
227 needsProcessing = true;
1b76853e1797 DbOptimizer plugin
Alain Mazy <am@osimis.io>
parents:
diff changeset
228 }
1b76853e1797 DbOptimizer plugin
Alain Mazy <am@osimis.io>
parents:
diff changeset
229
1b76853e1797 DbOptimizer plugin
Alain Mazy <am@osimis.io>
parents:
diff changeset
230 if (lastTags.at(OrthancPluginResourceType_Series) != currentTags.at(OrthancPluginResourceType_Series))
1b76853e1797 DbOptimizer plugin
Alain Mazy <am@osimis.io>
parents:
diff changeset
231 {
1b76853e1797 DbOptimizer plugin
Alain Mazy <am@osimis.io>
parents:
diff changeset
232 OrthancPlugins::LogWarning("DbOptimizer: Series main dicom tags have changed, -> will reconstruct DB");
1b76853e1797 DbOptimizer plugin
Alain Mazy <am@osimis.io>
parents:
diff changeset
233 needsProcessing = true;
1b76853e1797 DbOptimizer plugin
Alain Mazy <am@osimis.io>
parents:
diff changeset
234 }
1b76853e1797 DbOptimizer plugin
Alain Mazy <am@osimis.io>
parents:
diff changeset
235
1b76853e1797 DbOptimizer plugin
Alain Mazy <am@osimis.io>
parents:
diff changeset
236 if (lastTags.at(OrthancPluginResourceType_Instance) != currentTags.at(OrthancPluginResourceType_Instance))
1b76853e1797 DbOptimizer plugin
Alain Mazy <am@osimis.io>
parents:
diff changeset
237 {
1b76853e1797 DbOptimizer plugin
Alain Mazy <am@osimis.io>
parents:
diff changeset
238 OrthancPlugins::LogWarning("DbOptimizer: Instance main dicom tags have changed, -> will reconstruct DB");
1b76853e1797 DbOptimizer plugin
Alain Mazy <am@osimis.io>
parents:
diff changeset
239 needsProcessing = true;
1b76853e1797 DbOptimizer plugin
Alain Mazy <am@osimis.io>
parents:
diff changeset
240 }
1b76853e1797 DbOptimizer plugin
Alain Mazy <am@osimis.io>
parents:
diff changeset
241
1b76853e1797 DbOptimizer plugin
Alain Mazy <am@osimis.io>
parents:
diff changeset
242 return needsProcessing;
1b76853e1797 DbOptimizer plugin
Alain Mazy <am@osimis.io>
parents:
diff changeset
243 }
1b76853e1797 DbOptimizer plugin
Alain Mazy <am@osimis.io>
parents:
diff changeset
244
1b76853e1797 DbOptimizer plugin
Alain Mazy <am@osimis.io>
parents:
diff changeset
245 static bool ProcessChanges(PluginStatus& pluginStatus, const DbConfiguration& currentDbConfiguration)
1b76853e1797 DbOptimizer plugin
Alain Mazy <am@osimis.io>
parents:
diff changeset
246 {
1b76853e1797 DbOptimizer plugin
Alain Mazy <am@osimis.io>
parents:
diff changeset
247 Json::Value changes;
1b76853e1797 DbOptimizer plugin
Alain Mazy <am@osimis.io>
parents:
diff changeset
248
1b76853e1797 DbOptimizer plugin
Alain Mazy <am@osimis.io>
parents:
diff changeset
249 pluginStatus.currentlyProcessingConfiguration = currentDbConfiguration;
1b76853e1797 DbOptimizer plugin
Alain Mazy <am@osimis.io>
parents:
diff changeset
250
1b76853e1797 DbOptimizer plugin
Alain Mazy <am@osimis.io>
parents:
diff changeset
251 OrthancPlugins::RestApiGet(changes, "/changes?since=" + boost::lexical_cast<std::string>(pluginStatus.lastProcessedChange) + "&limit=100", false);
1b76853e1797 DbOptimizer plugin
Alain Mazy <am@osimis.io>
parents:
diff changeset
252
1b76853e1797 DbOptimizer plugin
Alain Mazy <am@osimis.io>
parents:
diff changeset
253 for (Json::ArrayIndex i = 0; i < changes["Changes"].size(); i++)
1b76853e1797 DbOptimizer plugin
Alain Mazy <am@osimis.io>
parents:
diff changeset
254 {
1b76853e1797 DbOptimizer plugin
Alain Mazy <am@osimis.io>
parents:
diff changeset
255 const Json::Value& change = changes["Changes"][i];
1b76853e1797 DbOptimizer plugin
Alain Mazy <am@osimis.io>
parents:
diff changeset
256 int64_t seq = change["Seq"].asInt64();
1b76853e1797 DbOptimizer plugin
Alain Mazy <am@osimis.io>
parents:
diff changeset
257
1b76853e1797 DbOptimizer plugin
Alain Mazy <am@osimis.io>
parents:
diff changeset
258 if (change["ChangeType"] == "NewStudy") // some StableStudy might be missing if orthanc was shutdown during a StableAge -> consider only the NewStudy events that can not be missed
1b76853e1797 DbOptimizer plugin
Alain Mazy <am@osimis.io>
parents:
diff changeset
259 {
1b76853e1797 DbOptimizer plugin
Alain Mazy <am@osimis.io>
parents:
diff changeset
260 Json::Value result;
1b76853e1797 DbOptimizer plugin
Alain Mazy <am@osimis.io>
parents:
diff changeset
261 OrthancPlugins::RestApiPost(result, "/studies/" + change["ID"].asString() + "/reconstruct", std::string(""), false);
1b76853e1797 DbOptimizer plugin
Alain Mazy <am@osimis.io>
parents:
diff changeset
262 boost::this_thread::sleep(boost::posix_time::milliseconds(throttleDelay_*1000));
1b76853e1797 DbOptimizer plugin
Alain Mazy <am@osimis.io>
parents:
diff changeset
263 }
1b76853e1797 DbOptimizer plugin
Alain Mazy <am@osimis.io>
parents:
diff changeset
264
1b76853e1797 DbOptimizer plugin
Alain Mazy <am@osimis.io>
parents:
diff changeset
265 if (seq >= pluginStatus.lastChangeToProcess) // we are done !
1b76853e1797 DbOptimizer plugin
Alain Mazy <am@osimis.io>
parents:
diff changeset
266 {
1b76853e1797 DbOptimizer plugin
Alain Mazy <am@osimis.io>
parents:
diff changeset
267 return true;
1b76853e1797 DbOptimizer plugin
Alain Mazy <am@osimis.io>
parents:
diff changeset
268 }
1b76853e1797 DbOptimizer plugin
Alain Mazy <am@osimis.io>
parents:
diff changeset
269
1b76853e1797 DbOptimizer plugin
Alain Mazy <am@osimis.io>
parents:
diff changeset
270 pluginStatus.lastProcessedChange = seq;
1b76853e1797 DbOptimizer plugin
Alain Mazy <am@osimis.io>
parents:
diff changeset
271 }
1b76853e1797 DbOptimizer plugin
Alain Mazy <am@osimis.io>
parents:
diff changeset
272
1b76853e1797 DbOptimizer plugin
Alain Mazy <am@osimis.io>
parents:
diff changeset
273 return false;
1b76853e1797 DbOptimizer plugin
Alain Mazy <am@osimis.io>
parents:
diff changeset
274 }
1b76853e1797 DbOptimizer plugin
Alain Mazy <am@osimis.io>
parents:
diff changeset
275
1b76853e1797 DbOptimizer plugin
Alain Mazy <am@osimis.io>
parents:
diff changeset
276
1b76853e1797 DbOptimizer plugin
Alain Mazy <am@osimis.io>
parents:
diff changeset
277 static void WorkerThread()
1b76853e1797 DbOptimizer plugin
Alain Mazy <am@osimis.io>
parents:
diff changeset
278 {
1b76853e1797 DbOptimizer plugin
Alain Mazy <am@osimis.io>
parents:
diff changeset
279 PluginStatus pluginStatus;
1b76853e1797 DbOptimizer plugin
Alain Mazy <am@osimis.io>
parents:
diff changeset
280 DbConfiguration currentDbConfiguration;
1b76853e1797 DbOptimizer plugin
Alain Mazy <am@osimis.io>
parents:
diff changeset
281
1b76853e1797 DbOptimizer plugin
Alain Mazy <am@osimis.io>
parents:
diff changeset
282 OrthancPluginLogWarning(OrthancPlugins::GetGlobalContext(), "Starting DB optimizer worker thread");
1b76853e1797 DbOptimizer plugin
Alain Mazy <am@osimis.io>
parents:
diff changeset
283
1b76853e1797 DbOptimizer plugin
Alain Mazy <am@osimis.io>
parents:
diff changeset
284 ReadStatusFromDb(pluginStatus);
1b76853e1797 DbOptimizer plugin
Alain Mazy <am@osimis.io>
parents:
diff changeset
285 GetCurrentDbConfiguration(currentDbConfiguration);
1b76853e1797 DbOptimizer plugin
Alain Mazy <am@osimis.io>
parents:
diff changeset
286
1b76853e1797 DbOptimizer plugin
Alain Mazy <am@osimis.io>
parents:
diff changeset
287 if (!NeedsProcessing(currentDbConfiguration, pluginStatus.lastProcessedConfiguration))
1b76853e1797 DbOptimizer plugin
Alain Mazy <am@osimis.io>
parents:
diff changeset
288 {
1b76853e1797 DbOptimizer plugin
Alain Mazy <am@osimis.io>
parents:
diff changeset
289 OrthancPlugins::LogWarning("DbOptimizer: everything has been processed already !");
1b76853e1797 DbOptimizer plugin
Alain Mazy <am@osimis.io>
parents:
diff changeset
290 return;
1b76853e1797 DbOptimizer plugin
Alain Mazy <am@osimis.io>
parents:
diff changeset
291 }
1b76853e1797 DbOptimizer plugin
Alain Mazy <am@osimis.io>
parents:
diff changeset
292
1b76853e1797 DbOptimizer plugin
Alain Mazy <am@osimis.io>
parents:
diff changeset
293 if (force_ || NeedsProcessing(currentDbConfiguration, pluginStatus.currentlyProcessingConfiguration))
1b76853e1797 DbOptimizer plugin
Alain Mazy <am@osimis.io>
parents:
diff changeset
294 {
1b76853e1797 DbOptimizer plugin
Alain Mazy <am@osimis.io>
parents:
diff changeset
295 if (force_)
1b76853e1797 DbOptimizer plugin
Alain Mazy <am@osimis.io>
parents:
diff changeset
296 {
1b76853e1797 DbOptimizer plugin
Alain Mazy <am@osimis.io>
parents:
diff changeset
297 OrthancPlugins::LogWarning("DbOptimizer: forcing execution -> will reconstruct DB");
1b76853e1797 DbOptimizer plugin
Alain Mazy <am@osimis.io>
parents:
diff changeset
298 }
1b76853e1797 DbOptimizer plugin
Alain Mazy <am@osimis.io>
parents:
diff changeset
299 else
1b76853e1797 DbOptimizer plugin
Alain Mazy <am@osimis.io>
parents:
diff changeset
300 {
1b76853e1797 DbOptimizer plugin
Alain Mazy <am@osimis.io>
parents:
diff changeset
301 OrthancPlugins::LogWarning("DbOptimizer: the DB configuration has changed since last run, will reprocess the whole DB !");
1b76853e1797 DbOptimizer plugin
Alain Mazy <am@osimis.io>
parents:
diff changeset
302 }
1b76853e1797 DbOptimizer plugin
Alain Mazy <am@osimis.io>
parents:
diff changeset
303
1b76853e1797 DbOptimizer plugin
Alain Mazy <am@osimis.io>
parents:
diff changeset
304 Json::Value changes;
1b76853e1797 DbOptimizer plugin
Alain Mazy <am@osimis.io>
parents:
diff changeset
305 OrthancPlugins::RestApiGet(changes, "/changes?last", false);
1b76853e1797 DbOptimizer plugin
Alain Mazy <am@osimis.io>
parents:
diff changeset
306
1b76853e1797 DbOptimizer plugin
Alain Mazy <am@osimis.io>
parents:
diff changeset
307 pluginStatus.lastProcessedChange = 0;
1b76853e1797 DbOptimizer plugin
Alain Mazy <am@osimis.io>
parents:
diff changeset
308 pluginStatus.lastChangeToProcess = changes["Last"].asInt64(); // the last change is the last change at the time we start. We assume that every new ingested file will be constructed correctly
1b76853e1797 DbOptimizer plugin
Alain Mazy <am@osimis.io>
parents:
diff changeset
309 }
1b76853e1797 DbOptimizer plugin
Alain Mazy <am@osimis.io>
parents:
diff changeset
310 else
1b76853e1797 DbOptimizer plugin
Alain Mazy <am@osimis.io>
parents:
diff changeset
311 {
1b76853e1797 DbOptimizer plugin
Alain Mazy <am@osimis.io>
parents:
diff changeset
312 OrthancPlugins::LogWarning("DbOptimizer: the DB configuration has not changed since last run, will continue processing changes");
1b76853e1797 DbOptimizer plugin
Alain Mazy <am@osimis.io>
parents:
diff changeset
313 }
1b76853e1797 DbOptimizer plugin
Alain Mazy <am@osimis.io>
parents:
diff changeset
314
1b76853e1797 DbOptimizer plugin
Alain Mazy <am@osimis.io>
parents:
diff changeset
315 bool completed = pluginStatus.lastChangeToProcess == 0; // if the DB is empty at start, no need to process anyting
1b76853e1797 DbOptimizer plugin
Alain Mazy <am@osimis.io>
parents:
diff changeset
316 while (!workerThreadShouldStop && !completed)
1b76853e1797 DbOptimizer plugin
Alain Mazy <am@osimis.io>
parents:
diff changeset
317 {
1b76853e1797 DbOptimizer plugin
Alain Mazy <am@osimis.io>
parents:
diff changeset
318 completed = ProcessChanges(pluginStatus, currentDbConfiguration);
1b76853e1797 DbOptimizer plugin
Alain Mazy <am@osimis.io>
parents:
diff changeset
319 SaveStatusInDb(pluginStatus);
1b76853e1797 DbOptimizer plugin
Alain Mazy <am@osimis.io>
parents:
diff changeset
320
1b76853e1797 DbOptimizer plugin
Alain Mazy <am@osimis.io>
parents:
diff changeset
321 if (!completed)
1b76853e1797 DbOptimizer plugin
Alain Mazy <am@osimis.io>
parents:
diff changeset
322 {
1b76853e1797 DbOptimizer plugin
Alain Mazy <am@osimis.io>
parents:
diff changeset
323 OrthancPlugins::LogInfo("DbOptimizer: processed changes " +
1b76853e1797 DbOptimizer plugin
Alain Mazy <am@osimis.io>
parents:
diff changeset
324 boost::lexical_cast<std::string>(pluginStatus.lastProcessedChange) +
1b76853e1797 DbOptimizer plugin
Alain Mazy <am@osimis.io>
parents:
diff changeset
325 " / " + boost::lexical_cast<std::string>(pluginStatus.lastChangeToProcess));
1b76853e1797 DbOptimizer plugin
Alain Mazy <am@osimis.io>
parents:
diff changeset
326
1b76853e1797 DbOptimizer plugin
Alain Mazy <am@osimis.io>
parents:
diff changeset
327 boost::this_thread::sleep(boost::posix_time::milliseconds(throttleDelay_*100)); // wait 1/10 of the delay between changes
1b76853e1797 DbOptimizer plugin
Alain Mazy <am@osimis.io>
parents:
diff changeset
328 }
1b76853e1797 DbOptimizer plugin
Alain Mazy <am@osimis.io>
parents:
diff changeset
329 }
1b76853e1797 DbOptimizer plugin
Alain Mazy <am@osimis.io>
parents:
diff changeset
330
1b76853e1797 DbOptimizer plugin
Alain Mazy <am@osimis.io>
parents:
diff changeset
331 if (completed)
1b76853e1797 DbOptimizer plugin
Alain Mazy <am@osimis.io>
parents:
diff changeset
332 {
1b76853e1797 DbOptimizer plugin
Alain Mazy <am@osimis.io>
parents:
diff changeset
333 pluginStatus.lastProcessedConfiguration = currentDbConfiguration;
1b76853e1797 DbOptimizer plugin
Alain Mazy <am@osimis.io>
parents:
diff changeset
334 pluginStatus.currentlyProcessingConfiguration.Clear();
1b76853e1797 DbOptimizer plugin
Alain Mazy <am@osimis.io>
parents:
diff changeset
335
1b76853e1797 DbOptimizer plugin
Alain Mazy <am@osimis.io>
parents:
diff changeset
336 pluginStatus.lastProcessedChange = -1;
1b76853e1797 DbOptimizer plugin
Alain Mazy <am@osimis.io>
parents:
diff changeset
337 pluginStatus.lastChangeToProcess = -1;
1b76853e1797 DbOptimizer plugin
Alain Mazy <am@osimis.io>
parents:
diff changeset
338
1b76853e1797 DbOptimizer plugin
Alain Mazy <am@osimis.io>
parents:
diff changeset
339 SaveStatusInDb(pluginStatus);
1b76853e1797 DbOptimizer plugin
Alain Mazy <am@osimis.io>
parents:
diff changeset
340
1b76853e1797 DbOptimizer plugin
Alain Mazy <am@osimis.io>
parents:
diff changeset
341 OrthancPluginLogWarning(OrthancPlugins::GetGlobalContext(), "DbOptimizer: finished processing all changes");
1b76853e1797 DbOptimizer plugin
Alain Mazy <am@osimis.io>
parents:
diff changeset
342 }
1b76853e1797 DbOptimizer plugin
Alain Mazy <am@osimis.io>
parents:
diff changeset
343 }
1b76853e1797 DbOptimizer plugin
Alain Mazy <am@osimis.io>
parents:
diff changeset
344
1b76853e1797 DbOptimizer plugin
Alain Mazy <am@osimis.io>
parents:
diff changeset
345 extern "C"
1b76853e1797 DbOptimizer plugin
Alain Mazy <am@osimis.io>
parents:
diff changeset
346 {
1b76853e1797 DbOptimizer plugin
Alain Mazy <am@osimis.io>
parents:
diff changeset
347 OrthancPluginErrorCode OnChangeCallback(OrthancPluginChangeType changeType,
1b76853e1797 DbOptimizer plugin
Alain Mazy <am@osimis.io>
parents:
diff changeset
348 OrthancPluginResourceType resourceType,
1b76853e1797 DbOptimizer plugin
Alain Mazy <am@osimis.io>
parents:
diff changeset
349 const char* resourceId)
1b76853e1797 DbOptimizer plugin
Alain Mazy <am@osimis.io>
parents:
diff changeset
350 {
1b76853e1797 DbOptimizer plugin
Alain Mazy <am@osimis.io>
parents:
diff changeset
351 switch (changeType)
1b76853e1797 DbOptimizer plugin
Alain Mazy <am@osimis.io>
parents:
diff changeset
352 {
1b76853e1797 DbOptimizer plugin
Alain Mazy <am@osimis.io>
parents:
diff changeset
353 case OrthancPluginChangeType_OrthancStarted:
1b76853e1797 DbOptimizer plugin
Alain Mazy <am@osimis.io>
parents:
diff changeset
354 {
1b76853e1797 DbOptimizer plugin
Alain Mazy <am@osimis.io>
parents:
diff changeset
355 OrthancPluginLogWarning(OrthancPlugins::GetGlobalContext(), "Starting DB Optmizer worker thread");
1b76853e1797 DbOptimizer plugin
Alain Mazy <am@osimis.io>
parents:
diff changeset
356 workerThread_.reset(new boost::thread(WorkerThread));
1b76853e1797 DbOptimizer plugin
Alain Mazy <am@osimis.io>
parents:
diff changeset
357 return OrthancPluginErrorCode_Success;
1b76853e1797 DbOptimizer plugin
Alain Mazy <am@osimis.io>
parents:
diff changeset
358 }
1b76853e1797 DbOptimizer plugin
Alain Mazy <am@osimis.io>
parents:
diff changeset
359 case OrthancPluginChangeType_OrthancStopped:
1b76853e1797 DbOptimizer plugin
Alain Mazy <am@osimis.io>
parents:
diff changeset
360 {
1b76853e1797 DbOptimizer plugin
Alain Mazy <am@osimis.io>
parents:
diff changeset
361 if (workerThread_ && workerThread_->joinable())
1b76853e1797 DbOptimizer plugin
Alain Mazy <am@osimis.io>
parents:
diff changeset
362 {
1b76853e1797 DbOptimizer plugin
Alain Mazy <am@osimis.io>
parents:
diff changeset
363 workerThreadShouldStop = true;
1b76853e1797 DbOptimizer plugin
Alain Mazy <am@osimis.io>
parents:
diff changeset
364 workerThread_->join();
1b76853e1797 DbOptimizer plugin
Alain Mazy <am@osimis.io>
parents:
diff changeset
365 }
1b76853e1797 DbOptimizer plugin
Alain Mazy <am@osimis.io>
parents:
diff changeset
366 }
1b76853e1797 DbOptimizer plugin
Alain Mazy <am@osimis.io>
parents:
diff changeset
367 default:
1b76853e1797 DbOptimizer plugin
Alain Mazy <am@osimis.io>
parents:
diff changeset
368 return OrthancPluginErrorCode_Success;
1b76853e1797 DbOptimizer plugin
Alain Mazy <am@osimis.io>
parents:
diff changeset
369 }
1b76853e1797 DbOptimizer plugin
Alain Mazy <am@osimis.io>
parents:
diff changeset
370 }
1b76853e1797 DbOptimizer plugin
Alain Mazy <am@osimis.io>
parents:
diff changeset
371
1b76853e1797 DbOptimizer plugin
Alain Mazy <am@osimis.io>
parents:
diff changeset
372 ORTHANC_PLUGINS_API int32_t OrthancPluginInitialize(OrthancPluginContext* c)
1b76853e1797 DbOptimizer plugin
Alain Mazy <am@osimis.io>
parents:
diff changeset
373 {
1b76853e1797 DbOptimizer plugin
Alain Mazy <am@osimis.io>
parents:
diff changeset
374 OrthancPlugins::SetGlobalContext(c);
1b76853e1797 DbOptimizer plugin
Alain Mazy <am@osimis.io>
parents:
diff changeset
375
1b76853e1797 DbOptimizer plugin
Alain Mazy <am@osimis.io>
parents:
diff changeset
376 /* Check the version of the Orthanc core */
1b76853e1797 DbOptimizer plugin
Alain Mazy <am@osimis.io>
parents:
diff changeset
377 if (OrthancPluginCheckVersion(c) == 0)
1b76853e1797 DbOptimizer plugin
Alain Mazy <am@osimis.io>
parents:
diff changeset
378 {
1b76853e1797 DbOptimizer plugin
Alain Mazy <am@osimis.io>
parents:
diff changeset
379 OrthancPlugins::ReportMinimalOrthancVersion(ORTHANC_PLUGINS_MINIMAL_MAJOR_NUMBER,
1b76853e1797 DbOptimizer plugin
Alain Mazy <am@osimis.io>
parents:
diff changeset
380 ORTHANC_PLUGINS_MINIMAL_MINOR_NUMBER,
1b76853e1797 DbOptimizer plugin
Alain Mazy <am@osimis.io>
parents:
diff changeset
381 ORTHANC_PLUGINS_MINIMAL_REVISION_NUMBER);
1b76853e1797 DbOptimizer plugin
Alain Mazy <am@osimis.io>
parents:
diff changeset
382 return -1;
1b76853e1797 DbOptimizer plugin
Alain Mazy <am@osimis.io>
parents:
diff changeset
383 }
1b76853e1797 DbOptimizer plugin
Alain Mazy <am@osimis.io>
parents:
diff changeset
384
1b76853e1797 DbOptimizer plugin
Alain Mazy <am@osimis.io>
parents:
diff changeset
385 OrthancPlugins::LogWarning("DB Optimizer plugin is initializing");
1b76853e1797 DbOptimizer plugin
Alain Mazy <am@osimis.io>
parents:
diff changeset
386 OrthancPluginSetDescription(c, "Optimizes your DB and storage.");
1b76853e1797 DbOptimizer plugin
Alain Mazy <am@osimis.io>
parents:
diff changeset
387
1b76853e1797 DbOptimizer plugin
Alain Mazy <am@osimis.io>
parents:
diff changeset
388 OrthancPlugins::OrthancConfiguration configuration;
1b76853e1797 DbOptimizer plugin
Alain Mazy <am@osimis.io>
parents:
diff changeset
389
1b76853e1797 DbOptimizer plugin
Alain Mazy <am@osimis.io>
parents:
diff changeset
390 OrthancPlugins::OrthancConfiguration dbOptimizer;
1b76853e1797 DbOptimizer plugin
Alain Mazy <am@osimis.io>
parents:
diff changeset
391 configuration.GetSection(dbOptimizer, "DbOptimizer");
1b76853e1797 DbOptimizer plugin
Alain Mazy <am@osimis.io>
parents:
diff changeset
392
1b76853e1797 DbOptimizer plugin
Alain Mazy <am@osimis.io>
parents:
diff changeset
393 bool enabled = dbOptimizer.GetBooleanValue("Enable", false);
1b76853e1797 DbOptimizer plugin
Alain Mazy <am@osimis.io>
parents:
diff changeset
394 if (enabled)
1b76853e1797 DbOptimizer plugin
Alain Mazy <am@osimis.io>
parents:
diff changeset
395 {
1b76853e1797 DbOptimizer plugin
Alain Mazy <am@osimis.io>
parents:
diff changeset
396 globalPropertyId_ = dbOptimizer.GetIntegerValue("GlobalPropertyId", 1025);
1b76853e1797 DbOptimizer plugin
Alain Mazy <am@osimis.io>
parents:
diff changeset
397 force_ = dbOptimizer.GetBooleanValue("Force", false);
1b76853e1797 DbOptimizer plugin
Alain Mazy <am@osimis.io>
parents:
diff changeset
398 throttleDelay_ = dbOptimizer.GetUnsignedIntegerValue("ThrottleDelay", 0);
1b76853e1797 DbOptimizer plugin
Alain Mazy <am@osimis.io>
parents:
diff changeset
399 OrthancPluginRegisterOnChangeCallback(c, OnChangeCallback);
1b76853e1797 DbOptimizer plugin
Alain Mazy <am@osimis.io>
parents:
diff changeset
400 }
1b76853e1797 DbOptimizer plugin
Alain Mazy <am@osimis.io>
parents:
diff changeset
401 else
1b76853e1797 DbOptimizer plugin
Alain Mazy <am@osimis.io>
parents:
diff changeset
402 {
1b76853e1797 DbOptimizer plugin
Alain Mazy <am@osimis.io>
parents:
diff changeset
403 OrthancPlugins::LogWarning("DB Optimizer plugin is disabled by the configuration file");
1b76853e1797 DbOptimizer plugin
Alain Mazy <am@osimis.io>
parents:
diff changeset
404 }
1b76853e1797 DbOptimizer plugin
Alain Mazy <am@osimis.io>
parents:
diff changeset
405
1b76853e1797 DbOptimizer plugin
Alain Mazy <am@osimis.io>
parents:
diff changeset
406 return 0;
1b76853e1797 DbOptimizer plugin
Alain Mazy <am@osimis.io>
parents:
diff changeset
407 }
1b76853e1797 DbOptimizer plugin
Alain Mazy <am@osimis.io>
parents:
diff changeset
408
1b76853e1797 DbOptimizer plugin
Alain Mazy <am@osimis.io>
parents:
diff changeset
409
1b76853e1797 DbOptimizer plugin
Alain Mazy <am@osimis.io>
parents:
diff changeset
410 ORTHANC_PLUGINS_API void OrthancPluginFinalize()
1b76853e1797 DbOptimizer plugin
Alain Mazy <am@osimis.io>
parents:
diff changeset
411 {
1b76853e1797 DbOptimizer plugin
Alain Mazy <am@osimis.io>
parents:
diff changeset
412 OrthancPlugins::LogWarning("DB Optimizer plugin is finalizing");
1b76853e1797 DbOptimizer plugin
Alain Mazy <am@osimis.io>
parents:
diff changeset
413 }
1b76853e1797 DbOptimizer plugin
Alain Mazy <am@osimis.io>
parents:
diff changeset
414
1b76853e1797 DbOptimizer plugin
Alain Mazy <am@osimis.io>
parents:
diff changeset
415
1b76853e1797 DbOptimizer plugin
Alain Mazy <am@osimis.io>
parents:
diff changeset
416 ORTHANC_PLUGINS_API const char* OrthancPluginGetName()
1b76853e1797 DbOptimizer plugin
Alain Mazy <am@osimis.io>
parents:
diff changeset
417 {
1b76853e1797 DbOptimizer plugin
Alain Mazy <am@osimis.io>
parents:
diff changeset
418 return "db-optimizer";
1b76853e1797 DbOptimizer plugin
Alain Mazy <am@osimis.io>
parents:
diff changeset
419 }
1b76853e1797 DbOptimizer plugin
Alain Mazy <am@osimis.io>
parents:
diff changeset
420
1b76853e1797 DbOptimizer plugin
Alain Mazy <am@osimis.io>
parents:
diff changeset
421
1b76853e1797 DbOptimizer plugin
Alain Mazy <am@osimis.io>
parents:
diff changeset
422 ORTHANC_PLUGINS_API const char* OrthancPluginGetVersion()
1b76853e1797 DbOptimizer plugin
Alain Mazy <am@osimis.io>
parents:
diff changeset
423 {
1b76853e1797 DbOptimizer plugin
Alain Mazy <am@osimis.io>
parents:
diff changeset
424 return DB_OPTIMIZER_VERSION;
1b76853e1797 DbOptimizer plugin
Alain Mazy <am@osimis.io>
parents:
diff changeset
425 }
1b76853e1797 DbOptimizer plugin
Alain Mazy <am@osimis.io>
parents:
diff changeset
426 }