diff options
| author | Carl Hetherington <cth@carlh.net> | 2020-05-05 00:56:54 +0200 |
|---|---|---|
| committer | Carl Hetherington <cth@carlh.net> | 2020-05-06 20:15:30 +0200 |
| commit | 8f8730cadb3dae36e8aa7b7c732a7c162eac0fb6 (patch) | |
| tree | e2e4a61b5aefc99be20f3f8209e9a59d8e1c3cba /src/lib/cinema_kdms.cc | |
| parent | 9262839360779de83b711f86151fcf56b86c3989 (diff) | |
Move some functions to kdm_with_metadata
Diffstat (limited to 'src/lib/cinema_kdms.cc')
| -rw-r--r-- | src/lib/cinema_kdms.cc | 245 |
1 files changed, 0 insertions, 245 deletions
diff --git a/src/lib/cinema_kdms.cc b/src/lib/cinema_kdms.cc deleted file mode 100644 index 94e83f807..000000000 --- a/src/lib/cinema_kdms.cc +++ /dev/null @@ -1,245 +0,0 @@ -/* - Copyright (C) 2013-2015 Carl Hetherington <cth@carlh.net> - - This file is part of DCP-o-matic. - - DCP-o-matic 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 2 of the License, or - (at your option) any later version. - - DCP-o-matic 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 DCP-o-matic. If not, see <http://www.gnu.org/licenses/>. - -*/ - -#include "exceptions.h" -#include "cinema_kdms.h" -#include "cinema.h" -#include "screen.h" -#include "config.h" -#include "util.h" -#include "emailer.h" -#include "compose.hpp" -#include "log.h" -#include "zipper.h" -#include "dcpomatic_log.h" -#include "kdm_with_metadata.h" -#include <boost/foreach.hpp> - -#include "i18n.h" - -using std::list; -using std::cout; -using std::string; -using std::runtime_error; -using boost::shared_ptr; -using boost::function; -using boost::optional; - -void -make_zip_file (list<KDMWithMetadataPtr> kdms, boost::filesystem::path zip_file, dcp::NameFormat name_format, dcp::NameFormat::Map name_values) -{ - Zipper zipper (zip_file); - - BOOST_FOREACH (KDMWithMetadataPtr i, kdms) { - name_values['i'] = i->kdm_id (); - string const name = careful_string_filter(name_format.get(name_values, ".xml")); - zipper.add (name, i->kdm_as_xml()); - } - - zipper.close (); -} - -/** Collect a list of KDMWithMetadatas into a list of list<KDMWithMetadata> so that each - * CinemaKDM contains the KDMs for its cinema. - */ -list<list<KDMWithMetadataPtr> > -collect (list<KDMWithMetadataPtr> screen_kdms) -{ - list<list<KDMWithMetadataPtr> > cinema_kdms; - - while (!screen_kdms.empty ()) { - - /* Get all the screens from a single cinema */ - - list<KDMWithMetadataPtr> ck; - - list<KDMWithMetadataPtr>::iterator i = screen_kdms.begin (); - ck.push_back (*i); - list<KDMWithMetadataPtr>::iterator j = i; - ++i; - screen_kdms.remove (*j); - - while (i != screen_kdms.end ()) { - if ((*i)->cinema() == ck.front()->cinema()) { - ck.push_back (*i); - list<KDMWithMetadataPtr>::iterator j = i; - ++i; - screen_kdms.remove (*j); - } else { - ++i; - } - } - - cinema_kdms.push_back (ck); - } - - return cinema_kdms; -} - -/** Write one directory per cinema into another directory */ -int -write_directories ( - list<list<KDMWithMetadataPtr> > cinema_kdms, - boost::filesystem::path directory, - dcp::NameFormat container_name_format, - dcp::NameFormat filename_format, - dcp::NameFormat::Map name_values, - function<bool (boost::filesystem::path)> confirm_overwrite - ) -{ - /* No specific screen */ - name_values['s'] = ""; - - int written = 0; - - BOOST_FOREACH (list<KDMWithMetadataPtr> const & i, cinema_kdms) { - boost::filesystem::path path = directory; - path /= container_name_format.get(name_values, ""); - if (!boost::filesystem::exists (path) || confirm_overwrite (path)) { - boost::filesystem::create_directories (path); - write_files (i, path, filename_format, name_values, confirm_overwrite); - } - written += i.size(); - } - - return written; -} - -/** Write one ZIP file per cinema into a directory */ -int -write_zip_files ( - list<list<KDMWithMetadataPtr> > cinema_kdms, - boost::filesystem::path directory, - dcp::NameFormat container_name_format, - dcp::NameFormat filename_format, - dcp::NameFormat::Map name_values, - function<bool (boost::filesystem::path)> confirm_overwrite - ) -{ - /* No specific screen */ - name_values['s'] = ""; - - int written = 0; - - BOOST_FOREACH (list<KDMWithMetadataPtr> const & i, cinema_kdms) { - boost::filesystem::path path = directory; - path /= container_name_format.get(name_values, ".zip"); - if (!boost::filesystem::exists (path) || confirm_overwrite (path)) { - if (boost::filesystem::exists (path)) { - /* Creating a new zip file over an existing one is an error */ - boost::filesystem::remove (path); - } - make_zip_file (i, path, filename_format, name_values); - written += i.size(); - } - } - - return written; -} - -/** Email one ZIP file per cinema to the cinema. - * @param cinema_kdms KDMS to email. - * @param container_name_format Format of folder / ZIP to use. - * @param filename_format Format of filenames to use. - * @param name_values Values to substitute into \p container_name_format and \p filename_format. - * @param cpl_name Name of the CPL that the KDMs are for. - */ -void -email ( - list<list<KDMWithMetadataPtr> > cinema_kdms, - dcp::NameFormat container_name_format, - dcp::NameFormat filename_format, - dcp::NameFormat::Map name_values, - string cpl_name - ) -{ - Config* config = Config::instance (); - - if (config->mail_server().empty()) { - throw NetworkError (_("No mail server configured in preferences")); - } - - /* No specific screen */ - name_values['s'] = ""; - - BOOST_FOREACH (list<KDMWithMetadataPtr> const & i, cinema_kdms) { - - if (i.front()->cinema()->emails.empty()) { - continue; - } - - boost::filesystem::path zip_file = boost::filesystem::temp_directory_path() / boost::filesystem::unique_path(); - boost::filesystem::create_directories (zip_file); - zip_file /= container_name_format.get(name_values, ".zip"); - make_zip_file (i, zip_file, filename_format, name_values); - - string subject = config->kdm_subject(); - boost::algorithm::replace_all (subject, "$CPL_NAME", cpl_name); - boost::algorithm::replace_all (subject, "$START_TIME", name_values['b']); - boost::algorithm::replace_all (subject, "$END_TIME", name_values['e']); - boost::algorithm::replace_all (subject, "$CINEMA_NAME", i.front()->cinema()->name); - - string body = config->kdm_email().c_str(); - boost::algorithm::replace_all (body, "$CPL_NAME", cpl_name); - boost::algorithm::replace_all (body, "$START_TIME", name_values['b']); - boost::algorithm::replace_all (body, "$END_TIME", name_values['e']); - boost::algorithm::replace_all (body, "$CINEMA_NAME", i.front()->cinema()->name); - - string screens; - BOOST_FOREACH (KDMWithMetadataPtr j, i) { - optional<string> screen_name = j->get('n'); - if (screen_name) { - screens += *screen_name + ", "; - } - } - boost::algorithm::replace_all (body, "$SCREENS", screens.substr (0, screens.length() - 2)); - - Emailer email (config->kdm_from(), i.front()->cinema()->emails, subject, body); - - BOOST_FOREACH (string i, config->kdm_cc()) { - email.add_cc (i); - } - if (!config->kdm_bcc().empty ()) { - email.add_bcc (config->kdm_bcc ()); - } - - email.add_attachment (zip_file, container_name_format.get(name_values, ".zip"), "application/zip"); - - Config* c = Config::instance (); - - try { - email.send (c->mail_server(), c->mail_port(), c->mail_protocol(), c->mail_user(), c->mail_password()); - } catch (...) { - boost::filesystem::remove (zip_file); - dcpomatic_log->log ("Email content follows", LogEntry::TYPE_DEBUG_EMAIL); - dcpomatic_log->log (email.email(), LogEntry::TYPE_DEBUG_EMAIL); - dcpomatic_log->log ("Email session follows", LogEntry::TYPE_DEBUG_EMAIL); - dcpomatic_log->log (email.notes(), LogEntry::TYPE_DEBUG_EMAIL); - throw; - } - - boost::filesystem::remove (zip_file); - - dcpomatic_log->log ("Email content follows", LogEntry::TYPE_DEBUG_EMAIL); - dcpomatic_log->log (email.email(), LogEntry::TYPE_DEBUG_EMAIL); - dcpomatic_log->log ("Email session follows", LogEntry::TYPE_DEBUG_EMAIL); - dcpomatic_log->log (email.notes(), LogEntry::TYPE_DEBUG_EMAIL); - } -} |
