summaryrefslogtreecommitdiff
path: root/src/lib/upload_job.cc
diff options
context:
space:
mode:
authorCarl Hetherington <cth@carlh.net>2015-07-17 15:37:23 +0100
committerCarl Hetherington <cth@carlh.net>2015-07-17 15:40:56 +0100
commit1d5462ef8d6a32b964f0335e3dd68aac31075d14 (patch)
tree69d94357bbfcc3b194152a6260d3cc450a47e8e9 /src/lib/upload_job.cc
parentb6abe4901c7115d37706f52febe0c7caa5d3c258 (diff)
Add FTP uploader using curl.
Diffstat (limited to 'src/lib/upload_job.cc')
-rw-r--r--src/lib/upload_job.cc24
1 files changed, 14 insertions, 10 deletions
diff --git a/src/lib/upload_job.cc b/src/lib/upload_job.cc
index 89ce5252d..44114b8a8 100644
--- a/src/lib/upload_job.cc
+++ b/src/lib/upload_job.cc
@@ -21,20 +21,14 @@
* @brief A job to copy DCPs to a server using libcurl.
*/
-#include <iostream>
-#include <sys/stat.h>
-#include <sys/types.h>
-#include <fcntl.h>
-#include <boost/filesystem.hpp>
-#include <libssh/libssh.h>
#include "compose.hpp"
#include "upload_job.h"
-#include "exceptions.h"
#include "config.h"
#include "log.h"
#include "film.h"
-#include "cross.h"
#include "scp_uploader.h"
+#include "curl_uploader.h"
+#include <iostream>
#include "i18n.h"
@@ -43,6 +37,7 @@
using std::string;
using std::min;
using boost::shared_ptr;
+using boost::scoped_ptr;
UploadJob::UploadJob (shared_ptr<const Film> film)
: Job (film)
@@ -68,8 +63,17 @@ UploadJob::run ()
{
LOG_GENERAL_NC (N_("Upload job starting"));
- SCPUploader uploader (bind (&UploadJob::set_status, this, _1), bind (&UploadJob::set_progress, this, _1, false));
- uploader.upload (_film->dir (_film->dcp_name ()));
+ scoped_ptr<Uploader> uploader;
+ switch (Config::instance()->tms_protocol ()) {
+ case PROTOCOL_SCP:
+ uploader.reset (new SCPUploader (bind (&UploadJob::set_status, this, _1), bind (&UploadJob::set_progress, this, _1, false)));
+ break;
+ case PROTOCOL_FTP:
+ uploader.reset (new CurlUploader (bind (&UploadJob::set_status, this, _1), bind (&UploadJob::set_progress, this, _1, false)));
+ break;
+ }
+
+ uploader->upload (_film->dir (_film->dcp_name ()));
set_progress (1);
set_status (N_(""));