comparison OrthancServer/ServerJobs/DicomModalityStoreJob.cpp @ 2603:988936118354 jobs

reorganization
author Sebastien Jodogne <s.jodogne@gmail.com>
date Fri, 18 May 2018 17:02:25 +0200
parents
children 714dcddeb65f
comparison
equal deleted inserted replaced
2602:c25f1a52acbc 2603:988936118354
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-2018 Osimis S.A., Belgium
6 *
7 * This program is free software: you can redistribute it and/or
8 * modify it under the terms of the GNU General Public License as
9 * published by the Free Software Foundation, either version 3 of the
10 * License, or (at your option) any later version.
11 *
12 * In addition, as a special exception, the copyright holders of this
13 * program give permission to link the code of its release with the
14 * OpenSSL project's "OpenSSL" library (or with modified versions of it
15 * that use the same license as the "OpenSSL" library), and distribute
16 * the linked executables. You must obey the GNU General Public License
17 * in all respects for all of the code used other than "OpenSSL". If you
18 * modify file(s) with this exception, you may extend this exception to
19 * your version of the file(s), but you are not obligated to do so. If
20 * you do not wish to do so, delete this exception statement from your
21 * version. If you delete this exception statement from all source files
22 * in the program, then also delete it here.
23 *
24 * This program is distributed in the hope that it will be useful, but
25 * WITHOUT ANY WARRANTY; without even the implied warranty of
26 * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the GNU
27 * General Public License for more details.
28 *
29 * You should have received a copy of the GNU General Public License
30 * along with this program. If not, see <http://www.gnu.org/licenses/>.
31 **/
32
33
34 #include "../PrecompiledHeadersServer.h"
35 #include "DicomModalityStoreJob.h"
36
37 #include "../../Core/Logging.h"
38
39 namespace Orthanc
40 {
41 void DicomModalityStoreJob::OpenConnection()
42 {
43 if (connection_.get() == NULL)
44 {
45 connection_.reset(new DicomUserConnection);
46 connection_->SetLocalApplicationEntityTitle(localAet_);
47 connection_->SetRemoteModality(remote_);
48 }
49 }
50
51
52 bool DicomModalityStoreJob::HandleInstance(const std::string& instance)
53 {
54 OpenConnection();
55
56 LOG(INFO) << "Sending instance " << instance << " to modality \""
57 << remote_.GetApplicationEntityTitle() << "\"";
58
59 std::string dicom;
60 context_.ReadDicom(dicom, instance);
61
62 if (HasMoveOriginator())
63 {
64 connection_->Store(dicom, moveOriginatorAet_, moveOriginatorId_);
65 }
66 else
67 {
68 connection_->Store(dicom);
69 }
70
71 //boost::this_thread::sleep(boost::posix_time::milliseconds(500));
72
73 return true;
74 }
75
76
77 DicomModalityStoreJob::DicomModalityStoreJob(ServerContext& context) :
78 context_(context),
79 localAet_("ORTHANC"),
80 moveOriginatorId_(0) // By default, not a C-MOVE
81 {
82 }
83
84
85 void DicomModalityStoreJob::SetLocalAet(const std::string& aet)
86 {
87 if (IsStarted())
88 {
89 throw OrthancException(ErrorCode_BadSequenceOfCalls);
90 }
91 else
92 {
93 localAet_ = aet;
94 }
95 }
96
97
98 void DicomModalityStoreJob::SetRemoteModality(const RemoteModalityParameters& remote)
99 {
100 if (IsStarted())
101 {
102 throw OrthancException(ErrorCode_BadSequenceOfCalls);
103 }
104 else
105 {
106 remote_ = remote;
107 }
108 }
109
110
111 const std::string& DicomModalityStoreJob::GetMoveOriginatorAet() const
112 {
113 if (HasMoveOriginator())
114 {
115 return moveOriginatorAet_;
116 }
117 else
118 {
119 throw OrthancException(ErrorCode_BadSequenceOfCalls);
120 }
121 }
122
123
124 uint16_t DicomModalityStoreJob::GetMoveOriginatorId() const
125 {
126 if (HasMoveOriginator())
127 {
128 return moveOriginatorId_;
129 }
130 else
131 {
132 throw OrthancException(ErrorCode_BadSequenceOfCalls);
133 }
134 }
135
136
137 void DicomModalityStoreJob::SetMoveOriginator(const std::string& aet,
138 int id)
139 {
140 if (IsStarted())
141 {
142 throw OrthancException(ErrorCode_BadSequenceOfCalls);
143 }
144 else if (id < 0 ||
145 id >= 65536)
146 {
147 throw OrthancException(ErrorCode_ParameterOutOfRange);
148 }
149 else
150 {
151 moveOriginatorId_ = static_cast<uint16_t>(id);
152 moveOriginatorAet_ = aet;
153 }
154 }
155
156 void DicomModalityStoreJob::ReleaseResources() // For pausing jobs
157 {
158 connection_.reset(NULL);
159 }
160
161
162 void DicomModalityStoreJob::GetPublicContent(Json::Value& value)
163 {
164 value["LocalAet"] = localAet_;
165 value["RemoteAet"] = remote_.GetApplicationEntityTitle();
166
167 if (HasMoveOriginator())
168 {
169 value["MoveOriginatorAET"] = GetMoveOriginatorAet();
170 value["MoveOriginatorID"] = GetMoveOriginatorId();
171 }
172
173 value["InstancesCount"] = static_cast<uint32_t>(GetInstances().size());
174 value["FailedInstancesCount"] = static_cast<uint32_t>(GetFailedInstances().size());
175 }
176 }