changeset 2605:1e11b0229e04 jobs

StorePeerOperation
author Sebastien Jodogne <s.jodogne@gmail.com>
date Fri, 18 May 2018 18:06:53 +0200
parents 76ef12fa136c
children f2b9d3256060
files CMakeLists.txt OrthancServer/ServerJobs/DeleteResourceOperation.cpp OrthancServer/ServerJobs/LuaJobManager.cpp OrthancServer/ServerJobs/LuaJobManager.h OrthancServer/ServerJobs/StorePeerOperation.cpp OrthancServer/ServerJobs/StorePeerOperation.h OrthancServer/ServerJobs/StoreScuOperation.cpp
diffstat 7 files changed, 155 insertions(+), 9 deletions(-) [+]
line wrap: on
line diff
--- a/CMakeLists.txt	Fri May 18 17:37:14 2018 +0200
+++ b/CMakeLists.txt	Fri May 18 18:06:53 2018 +0200
@@ -94,6 +94,7 @@
   OrthancServer/ServerJobs/DicomModalityStoreJob.cpp
   OrthancServer/ServerJobs/LuaJobManager.cpp
   OrthancServer/ServerJobs/OrthancPeerStoreJob.cpp
+  OrthancServer/ServerJobs/StorePeerOperation.cpp
   OrthancServer/ServerJobs/StoreScuOperation.cpp
   OrthancServer/ServerToolbox.cpp
   OrthancServer/SliceOrdering.cpp
--- a/OrthancServer/ServerJobs/DeleteResourceOperation.cpp	Fri May 18 17:37:14 2018 +0200
+++ b/OrthancServer/ServerJobs/DeleteResourceOperation.cpp	Fri May 18 18:06:53 2018 +0200
@@ -49,7 +49,7 @@
       case JobOperationValue::Type_DicomInstance:
       {
         const DicomInstanceOperationValue& instance = dynamic_cast<const DicomInstanceOperationValue&>(input);
-        LOG(INFO) << "Deleting instance: " << instance.GetId();
+        LOG(INFO) << "Lua: Deleting instance: " << instance.GetId();
 
         try
         {
@@ -58,7 +58,7 @@
         }
         catch (OrthancException& e)
         {
-          LOG(ERROR) << "Unable to delete instance " << instance.GetId() << ": " << e.What();
+          LOG(ERROR) << "Lua: Unable to delete instance " << instance.GetId() << ": " << e.What();
         }
 
         break;
--- a/OrthancServer/ServerJobs/LuaJobManager.cpp	Fri May 18 17:37:14 2018 +0200
+++ b/OrthancServer/ServerJobs/LuaJobManager.cpp	Fri May 18 18:06:53 2018 +0200
@@ -35,6 +35,7 @@
 #include "LuaJobManager.h"
 
 #include "DeleteResourceOperation.h"
+#include "StorePeerOperation.h"
 #include "StoreScuOperation.h"
 #include "../../Core/JobsEngine/Operations/LogJobOperation.h"
 
@@ -174,14 +175,20 @@
 
 
   size_t LuaJobManager::Lock::AddStoreScuOperation(const std::string& localAet,
-                                                   const RemoteModalityParameters& modality,
-                                                   IDicomConnectionManager& manager)
+                                                   const RemoteModalityParameters& modality)
   {
     assert(jobLock_.get() != NULL);
     return jobLock_->AddOperation(new StoreScuOperation(localAet, modality, that_.connectionManager_));    
   }
 
 
+  size_t LuaJobManager::Lock::AddStorePeerOperation(const WebServiceParameters& peer)
+  {
+    assert(jobLock_.get() != NULL);
+    return jobLock_->AddOperation(new StorePeerOperation(peer));    
+  }
+
+
   void LuaJobManager::Lock::AddNullInput(size_t operation)
   {
     assert(jobLock_.get() != NULL);
--- a/OrthancServer/ServerJobs/LuaJobManager.h	Fri May 18 17:37:14 2018 +0200
+++ b/OrthancServer/ServerJobs/LuaJobManager.h	Fri May 18 18:06:53 2018 +0200
@@ -89,8 +89,9 @@
       size_t AddDeleteResourceOperation(ServerContext& context);
 
       size_t AddStoreScuOperation(const std::string& localAet,
-                                  const RemoteModalityParameters& modality,
-                                  IDicomConnectionManager& manager);
+                                  const RemoteModalityParameters& modality);
+
+      size_t AddStorePeerOperation(const WebServiceParameters& peer);
 
       void AddNullInput(size_t operation); 
 
--- /dev/null	Thu Jan 01 00:00:00 1970 +0000
+++ b/OrthancServer/ServerJobs/StorePeerOperation.cpp	Fri May 18 18:06:53 2018 +0200
@@ -0,0 +1,81 @@
+/**
+ * Orthanc - A Lightweight, RESTful DICOM Store
+ * Copyright (C) 2012-2016 Sebastien Jodogne, Medical Physics
+ * Department, University Hospital of Liege, Belgium
+ * Copyright (C) 2017-2018 Osimis S.A., Belgium
+ *
+ * This program is free software: you can redistribute it and/or
+ * modify it under the terms of the GNU General Public License as
+ * published by the Free Software Foundation, either version 3 of the
+ * License, or (at your option) any later version.
+ *
+ * In addition, as a special exception, the copyright holders of this
+ * program give permission to link the code of its release with the
+ * OpenSSL project's "OpenSSL" library (or with modified versions of it
+ * that use the same license as the "OpenSSL" library), and distribute
+ * the linked executables. You must obey the GNU General Public License
+ * in all respects for all of the code used other than "OpenSSL". If you
+ * modify file(s) with this exception, you may extend this exception to
+ * your version of the file(s), but you are not obligated to do so. If
+ * you do not wish to do so, delete this exception statement from your
+ * version. If you delete this exception statement from all source files
+ * in the program, then also delete it here.
+ * 
+ * This program is distributed in the hope that it will be useful, but
+ * WITHOUT ANY WARRANTY; without even the implied warranty of
+ * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the GNU
+ * General Public License for more details.
+ *
+ * You should have received a copy of the GNU General Public License
+ * along with this program. If not, see <http://www.gnu.org/licenses/>.
+ **/
+
+
+#include "../PrecompiledHeadersServer.h"
+#include "StorePeerOperation.h"
+
+#include "DicomInstanceOperationValue.h"
+
+#include "../../Core/Logging.h"
+#include "../../Core/OrthancException.h"
+#include "../../Core/HttpClient.h"
+
+namespace Orthanc
+{
+  void StorePeerOperation::Apply(JobOperationValues& outputs,
+                                const JobOperationValue& input)
+  {
+    // Configure the HTTP client
+    HttpClient client(peer_, "instances");
+    client.SetMethod(HttpMethod_Post);
+
+    if (input.GetType() != JobOperationValue::Type_DicomInstance)
+    {
+      throw OrthancException(ErrorCode_BadParameterType);
+    }
+
+    const DicomInstanceOperationValue& instance = dynamic_cast<const DicomInstanceOperationValue&>(input);
+
+    LOG(INFO) << "Lua: Sending instance " << instance.GetId() << " to Orthanc peer \"" 
+              << peer_.GetUrl() << "\"";
+
+    try
+    {
+      instance.ReadContent(client.GetBody());
+
+      std::string answer;
+      if (!client.Apply(answer))
+      {
+        LOG(ERROR) << "Lua: Unable to send instance " << instance.GetId() << " to Orthanc peer \"" 
+                   << peer_.GetUrl();
+      }
+
+      outputs.Append(instance.Clone());
+    }
+    catch (OrthancException& e)
+    {
+      LOG(ERROR) << "Lua: Unable to send instance " << instance.GetId() << " to Orthanc peer \"" 
+                 << peer_.GetUrl() << "\": " << e.What();
+    }
+  }
+}
--- /dev/null	Thu Jan 01 00:00:00 1970 +0000
+++ b/OrthancServer/ServerJobs/StorePeerOperation.h	Fri May 18 18:06:53 2018 +0200
@@ -0,0 +1,56 @@
+/**
+ * Orthanc - A Lightweight, RESTful DICOM Store
+ * Copyright (C) 2012-2016 Sebastien Jodogne, Medical Physics
+ * Department, University Hospital of Liege, Belgium
+ * Copyright (C) 2017-2018 Osimis S.A., Belgium
+ *
+ * This program is free software: you can redistribute it and/or
+ * modify it under the terms of the GNU General Public License as
+ * published by the Free Software Foundation, either version 3 of the
+ * License, or (at your option) any later version.
+ *
+ * In addition, as a special exception, the copyright holders of this
+ * program give permission to link the code of its release with the
+ * OpenSSL project's "OpenSSL" library (or with modified versions of it
+ * that use the same license as the "OpenSSL" library), and distribute
+ * the linked executables. You must obey the GNU General Public License
+ * in all respects for all of the code used other than "OpenSSL". If you
+ * modify file(s) with this exception, you may extend this exception to
+ * your version of the file(s), but you are not obligated to do so. If
+ * you do not wish to do so, delete this exception statement from your
+ * version. If you delete this exception statement from all source files
+ * in the program, then also delete it here.
+ * 
+ * This program is distributed in the hope that it will be useful, but
+ * WITHOUT ANY WARRANTY; without even the implied warranty of
+ * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the GNU
+ * General Public License for more details.
+ *
+ * You should have received a copy of the GNU General Public License
+ * along with this program. If not, see <http://www.gnu.org/licenses/>.
+ **/
+
+
+#pragma once
+
+#include "../../Core/JobsEngine/Operations/IJobOperation.h"
+#include "../../Core/WebServiceParameters.h"
+
+namespace Orthanc
+{
+  class StorePeerOperation : public IJobOperation
+  {
+  private:
+    WebServiceParameters peer_;
+
+  public:
+    StorePeerOperation(const WebServiceParameters& peer) :
+    peer_(peer)
+    {
+    }
+
+    virtual void Apply(JobOperationValues& outputs,
+                       const JobOperationValue& input);
+  };
+}
+
--- a/OrthancServer/ServerJobs/StoreScuOperation.cpp	Fri May 18 17:37:14 2018 +0200
+++ b/OrthancServer/ServerJobs/StoreScuOperation.cpp	Fri May 18 18:06:53 2018 +0200
@@ -49,7 +49,7 @@
 
     if (resource.get() == NULL)
     {
-      LOG(ERROR) << "Cannot connect to modality: " << modality_.GetApplicationEntityTitle();
+      LOG(ERROR) << "Lua: Cannot connect to modality: " << modality_.GetApplicationEntityTitle();
       return;
     }
 
@@ -60,7 +60,7 @@
 
     const DicomInstanceOperationValue& instance = dynamic_cast<const DicomInstanceOperationValue&>(input);
 
-    LOG(INFO) << "Sending instance " << instance.GetId() << " to modality \"" 
+    LOG(INFO) << "Lua: Sending instance " << instance.GetId() << " to modality \"" 
               << modality_.GetApplicationEntityTitle() << "\"";
 
     try
@@ -72,7 +72,7 @@
     }
     catch (OrthancException& e)
     {
-      LOG(ERROR) << "Unable to send instance " << instance.GetId() << " to modality \"" 
+      LOG(ERROR) << "Lua: Unable to send instance " << instance.GetId() << " to modality \"" 
                  << modality_.GetApplicationEntityTitle() << "\": " << e.What();
     }
   }