Mercurial > hg > orthanc-stone
annotate Platforms/Generic/WebServiceGetCommand.cpp @ 247:3d523c9a8f0d am
trying to use boost::signals2 even more.
author | am@osimis.io |
---|---|
date | Mon, 02 Jul 2018 12:32:02 +0200 |
parents | 5470b15f7cf2 |
children |
rev | line source |
---|---|
80 | 1 /** |
2 * Stone of Orthanc | |
3 * Copyright (C) 2012-2016 Sebastien Jodogne, Medical Physics | |
4 * Department, University Hospital of Liege, Belgium | |
135
e2fe9352f240
upgrade to year 2018
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
123
diff
changeset
|
5 * Copyright (C) 2017-2018 Osimis S.A., Belgium |
80 | 6 * |
7 * This program is free software: you can redistribute it and/or | |
8 * modify it under the terms of the GNU Affero General Public License | |
9 * as published by the Free Software Foundation, either version 3 of | |
10 * the License, or (at your option) any later version. | |
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 | |
15 * Affero General Public License for more details. | |
16 * | |
17 * You should have received a copy of the GNU Affero General Public License | |
18 * along with this program. If not, see <http://www.gnu.org/licenses/>. | |
19 **/ | |
20 | |
21 | |
22 #include "WebServiceGetCommand.h" | |
23 | |
212
5412adf19980
resort to OrthancFramework
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
201
diff
changeset
|
24 #include <Core/HttpClient.h> |
80 | 25 |
26 namespace OrthancStone | |
27 { | |
247 | 28 WebServiceGetCommand::WebServiceGetCommand(IWebService::IWebServiceObserver* observer, |
29 boost::shared_ptr<boost::noncopyable> tracker,const Orthanc::WebServiceParameters& parameters, | |
80 | 30 const std::string& uri, |
31 Orthanc::IDynamicObject* payload /* takes ownership */) : | |
247 | 32 observer_(observer), |
80 | 33 parameters_(parameters), |
34 uri_(uri), | |
35 payload_(payload) | |
36 { | |
247 | 37 // connect the signals and track the deletion of the observer |
38 SignalSuccess.connect(IWebService::IWebServiceObserver::SignalSuccessType::slot_type(&IWebService::IWebServiceObserver::OnRequestSuccess, observer_, _1, _2, _3, _4).track(tracker)); | |
39 SignalError.connect(IWebService::IWebServiceObserver::SignalErrorType::slot_type(&IWebService::IWebServiceObserver::OnRequestError, observer_, _1, _2).track(tracker)); | |
80 | 40 } |
41 | |
42 | |
43 void WebServiceGetCommand::Execute() | |
44 { | |
45 Orthanc::HttpClient client(parameters_, uri_); | |
123
ed0003f6102c
dynamic loading of rt-struct renderers
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
113
diff
changeset
|
46 client.SetTimeout(60); |
80 | 47 client.SetMethod(Orthanc::HttpMethod_Get); |
48 success_ = client.Apply(answer_); | |
49 } | |
50 | |
51 | |
52 void WebServiceGetCommand::Commit() | |
53 { | |
54 if (success_) | |
55 { | |
246 | 56 SignalSuccess(uri_, answer_.c_str(), answer_.size(), payload_.release()); |
80 | 57 } |
58 else | |
59 { | |
247 | 60 SignalError(uri_, payload_.release()); |
80 | 61 } |
62 } | |
63 } |