From 12b1a3f10ee0e14691e68784bfccc7359d44b0a4 Mon Sep 17 00:00:00 2001 From: Carl Hetherington Date: Fri, 21 Dec 2018 23:57:09 +0000 Subject: [PATCH] swaroop: check for KDMs when selecting playlist. --- src/tools/dcpomatic_player.cc | 57 ----------------------------- src/wx/swaroop_controls.cc | 67 +++++++++++++++++++++++++++++++++++ src/wx/swaroop_controls.h | 5 +++ 3 files changed, 72 insertions(+), 57 deletions(-) diff --git a/src/tools/dcpomatic_player.cc b/src/tools/dcpomatic_player.cc index 26110b373..b39e59d6b 100644 --- a/src/tools/dcpomatic_player.cc +++ b/src/tools/dcpomatic_player.cc @@ -389,49 +389,6 @@ public: } } -#ifdef DCPOMATIC_VARIANT_SWAROOP - optional get_kdm_from_url (shared_ptr dcp) - { - ScopedTemporary temp; - string url = Config::instance()->kdm_server_url(); - boost::algorithm::replace_all (url, "{CPL}", *dcp->cpl()); - optional kdm; - if (dcp->cpl() && !get_from_url(url, false, temp)) { - try { - kdm = dcp::EncryptedKDM (dcp::file_to_string(temp.file())); - if (kdm->cpl_id() != dcp->cpl()) { - kdm = boost::none; - } - } catch (std::exception& e) { - /* Hey well */ - } - } - return kdm; - } -#endif - - optional get_kdm_from_directory (shared_ptr dcp) - { - using namespace boost::filesystem; - optional kdm_dir = Config::instance()->player_kdm_directory(); - if (!kdm_dir) { - return optional(); - } - for (directory_iterator i = directory_iterator(*kdm_dir); i != directory_iterator(); ++i) { - try { - if (file_size(i->path()) < MAX_KDM_SIZE) { - dcp::EncryptedKDM kdm (dcp::file_to_string(i->path())); - if (kdm.cpl_id() == dcp->cpl()) { - return kdm; - } - } - } catch (std::exception& e) { - /* Hey well */ - } - } - return optional(); - } - void reset_film_weak (weak_ptr weak_film) { shared_ptr film = weak_film.lock (); @@ -464,20 +421,6 @@ public: BOOST_FOREACH (shared_ptr i, _film->content()) { shared_ptr dcp = dynamic_pointer_cast(i); - if (dcp && dcp->needs_kdm()) { - optional kdm; -#ifdef DCPOMATIC_VARIANT_SWAROOP - kdm = get_kdm_from_url (dcp); -#endif - if (!kdm) { - kdm = get_kdm_from_directory (dcp); - } - - if (kdm) { - dcp->add_kdm (*kdm); - dcp->examine (_film, shared_ptr()); - } - } BOOST_FOREACH (shared_ptr j, i->text) { j->set_use (true); diff --git a/src/wx/swaroop_controls.cc b/src/wx/swaroop_controls.cc index 870ac518b..7eed86743 100644 --- a/src/wx/swaroop_controls.cc +++ b/src/wx/swaroop_controls.cc @@ -27,6 +27,8 @@ #include "lib/player_video.h" #include "lib/dcp_content.h" #include "lib/cross.h" +#include "lib/scoped_temporary.h" +#include "lib/internet.h" #include #include #include @@ -317,6 +319,49 @@ SwaroopControls::update_playlist_directory () _selected_playlist = boost::none; } +optional +SwaroopControls::get_kdm_from_url (shared_ptr dcp) +{ + ScopedTemporary temp; + string url = Config::instance()->kdm_server_url(); + boost::algorithm::replace_all (url, "{CPL}", *dcp->cpl()); + optional kdm; + if (dcp->cpl() && !get_from_url(url, false, temp)) { + try { + kdm = dcp::EncryptedKDM (dcp::file_to_string(temp.file())); + if (kdm->cpl_id() != dcp->cpl()) { + kdm = boost::none; + } + } catch (std::exception& e) { + /* Hey well */ + } + } + return kdm; +} + +optional +SwaroopControls::get_kdm_from_directory (shared_ptr dcp) +{ + using namespace boost::filesystem; + optional kdm_dir = Config::instance()->player_kdm_directory(); + if (!kdm_dir) { + return optional(); + } + for (directory_iterator i = directory_iterator(*kdm_dir); i != directory_iterator(); ++i) { + try { + if (file_size(i->path()) < MAX_KDM_SIZE) { + dcp::EncryptedKDM kdm (dcp::file_to_string(i->path())); + if (kdm.cpl_id() == dcp->cpl()) { + return kdm; + } + } + } catch (std::exception& e) { + /* Hey well */ + } + } + return optional(); +} + void SwaroopControls::spl_selection_changed () { @@ -342,6 +387,28 @@ SwaroopControls::spl_selection_changed () wxProgressDialog dialog (_("DCP-o-matic"), "Loading playlist"); dialog.Pulse (); + BOOST_FOREACH (SPLEntry const & i, _playlists[selected].get()) { + shared_ptr dcp = dynamic_pointer_cast (i.content); + if (dcp && dcp->needs_kdm()) { + optional kdm; + kdm = get_kdm_from_url (dcp); + if (!kdm) { + kdm = get_kdm_from_directory (dcp); + } + if (kdm) { + dcp->add_kdm (*kdm); + dcp->examine (_film, shared_ptr()); + } + if (dcp->needs_kdm()) { + /* We didn't get a KDM for this */ + error_dialog (this, "This playlist cannot be loaded as a KDM is missing."); + _selected_playlist = boost::none; + _spl_view->SetItemState (selected, 0, wxLIST_STATE_SELECTED); + return; + } + } + } + _current_spl_view->DeleteAllItems (); int N = 0; diff --git a/src/wx/swaroop_controls.h b/src/wx/swaroop_controls.h index 077b16fbe..e2c4190b6 100644 --- a/src/wx/swaroop_controls.h +++ b/src/wx/swaroop_controls.h @@ -20,6 +20,8 @@ #include "controls.h" +class DCPContent; + class SwaroopControls : public Controls { public: @@ -56,6 +58,9 @@ private: bool can_do_previous (); bool can_do_next (); + boost::optional get_kdm_from_url (boost::shared_ptr dcp); + boost::optional get_kdm_from_directory (boost::shared_ptr dcp); + wxButton* _play_button; wxButton* _pause_button; wxButton* _stop_button; -- 2.30.2