Mercurial > hg > orthanc
annotate OrthancServer/Sources/ServerJobs/Operations/StorePeerOperation.cpp @ 4154:6e7c842679ec
improved log
author | Sebastien Jodogne <s.jodogne@gmail.com> |
---|---|
date | Sun, 23 Aug 2020 12:40:04 +0200 |
parents | 05b8fd21089c |
children | 2ae905070221 |
rev | line source |
---|---|
2605 | 1 /** |
2 * Orthanc - A Lightweight, RESTful DICOM Store | |
3 * Copyright (C) 2012-2016 Sebastien Jodogne, Medical Physics | |
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 |
2605 | 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 | |
2641 | 34 #include "../../PrecompiledHeadersServer.h" |
2605 | 35 #include "StorePeerOperation.h" |
36 | |
37 #include "DicomInstanceOperationValue.h" | |
38 | |
4045 | 39 #include "../../../../OrthancFramework/Sources/Logging.h" |
40 #include "../../../../OrthancFramework/Sources/OrthancException.h" | |
41 #include "../../../../OrthancFramework/Sources/HttpClient.h" | |
42 #include "../../../../OrthancFramework/Sources/SerializationToolbox.h" | |
2605 | 43 |
44 namespace Orthanc | |
45 { | |
46 void StorePeerOperation::Apply(JobOperationValues& outputs, | |
3851
6498739a3c3c
refactoring: TimeoutDicomConnectionManager is now only used by Lua
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
3850
diff
changeset
|
47 const JobOperationValue& input) |
2605 | 48 { |
49 // Configure the HTTP client | |
50 HttpClient client(peer_, "instances"); | |
51 client.SetMethod(HttpMethod_Post); | |
52 | |
53 if (input.GetType() != JobOperationValue::Type_DicomInstance) | |
54 { | |
55 throw OrthancException(ErrorCode_BadParameterType); | |
56 } | |
57 | |
2608
25225f0b4f33
simplification wrt. dicom connection manager
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
2606
diff
changeset
|
58 const DicomInstanceOperationValue& instance = |
25225f0b4f33
simplification wrt. dicom connection manager
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
2606
diff
changeset
|
59 dynamic_cast<const DicomInstanceOperationValue&>(input); |
2605 | 60 |
61 LOG(INFO) << "Lua: Sending instance " << instance.GetId() << " to Orthanc peer \"" | |
62 << peer_.GetUrl() << "\""; | |
63 | |
64 try | |
65 { | |
2651
1da5a052c777
testing value serialization
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
2641
diff
changeset
|
66 instance.ReadDicom(client.GetBody()); |
2605 | 67 |
68 std::string answer; | |
69 if (!client.Apply(answer)) | |
70 { | |
2608
25225f0b4f33
simplification wrt. dicom connection manager
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
2606
diff
changeset
|
71 LOG(ERROR) << "Lua: Unable to send instance " << instance.GetId() |
25225f0b4f33
simplification wrt. dicom connection manager
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
2606
diff
changeset
|
72 << " to Orthanc peer \"" << peer_.GetUrl(); |
2605 | 73 } |
74 } | |
75 catch (OrthancException& e) | |
76 { | |
2608
25225f0b4f33
simplification wrt. dicom connection manager
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
2606
diff
changeset
|
77 LOG(ERROR) << "Lua: Unable to send instance " << instance.GetId() |
25225f0b4f33
simplification wrt. dicom connection manager
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
2606
diff
changeset
|
78 << " to Orthanc peer \"" << peer_.GetUrl() << "\": " << e.What(); |
2605 | 79 } |
2609
f7a84b551ee4
switch Lua to new jobs engine
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
2608
diff
changeset
|
80 |
f7a84b551ee4
switch Lua to new jobs engine
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
2608
diff
changeset
|
81 outputs.Append(input.Clone()); |
2605 | 82 } |
2616
2f3007bf0708
event queues in Lua, serialization of sequence of operations
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
2609
diff
changeset
|
83 |
2f3007bf0708
event queues in Lua, serialization of sequence of operations
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
2609
diff
changeset
|
84 |
2f3007bf0708
event queues in Lua, serialization of sequence of operations
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
2609
diff
changeset
|
85 void StorePeerOperation::Serialize(Json::Value& result) const |
2f3007bf0708
event queues in Lua, serialization of sequence of operations
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
2609
diff
changeset
|
86 { |
2654 | 87 result = Json::objectValue; |
2616
2f3007bf0708
event queues in Lua, serialization of sequence of operations
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
2609
diff
changeset
|
88 result["Type"] = "StorePeer"; |
2800
dc7330089736
"OrthancPeers" configuration option now allows to specify HTTP headers
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
2657
diff
changeset
|
89 peer_.Serialize(result["Peer"], |
dc7330089736
"OrthancPeers" configuration option now allows to specify HTTP headers
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
2657
diff
changeset
|
90 true /* force advanced format */, |
dc7330089736
"OrthancPeers" configuration option now allows to specify HTTP headers
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
2657
diff
changeset
|
91 true /* include passwords */); |
2655 | 92 } |
93 | |
94 | |
95 StorePeerOperation::StorePeerOperation(const Json::Value& serialized) | |
96 { | |
2656
a6d3e45eeff5
SerializationToolbox
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
2655
diff
changeset
|
97 if (SerializationToolbox::ReadString(serialized, "Type") != "StorePeer" || |
2655 | 98 !serialized.isMember("Peer")) |
99 { | |
100 throw OrthancException(ErrorCode_BadFileFormat); | |
101 } | |
102 | |
103 peer_ = WebServiceParameters(serialized["Peer"]); | |
2616
2f3007bf0708
event queues in Lua, serialization of sequence of operations
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
2609
diff
changeset
|
104 } |
2605 | 105 } |