X-Git-Url: https://git.carlh.net/gitweb/?a=blobdiff_plain;f=src%2Flib%2Fkdm_with_metadata.h;h=df9f041251ec9d8075b338cd164ea0bc50949ece;hb=182b9d2e2feb6545592868606aaf0f0146095481;hp=ee84d9eb4842699d2dcc5085184ee6609713aa84;hpb=4e62980064496060af5a8c6ecab26ddf218aa63a;p=dcpomatic.git diff --git a/src/lib/kdm_with_metadata.h b/src/lib/kdm_with_metadata.h index ee84d9eb4..df9f04125 100644 --- a/src/lib/kdm_with_metadata.h +++ b/src/lib/kdm_with_metadata.h @@ -1,5 +1,5 @@ /* - Copyright (C) 2013-2019 Carl Hetherington + Copyright (C) 2013-2021 Carl Hetherington This file is part of DCP-o-matic. @@ -18,31 +18,35 @@ */ + #ifndef DCPOMATIC_KDM_WITH_METADATA_H #define DCPOMATIC_KDM_WITH_METADATA_H -#ifdef DCPOMATIC_VARIANT_SWAROOP -#include "encrypted_ecinema_kdm.h" -#endif + #include #include -#include + class Cinema; + class KDMWithMetadata { public: - KDMWithMetadata (dcp::NameFormat::Map const& name_values, boost::shared_ptr cinema) + KDMWithMetadata (dcp::NameFormat::Map const& name_values, void const* group, std::list emails, dcp::EncryptedKDM kdm) : _name_values (name_values) - , _cinema (cinema) + , _group (group) + , _emails (emails) + , _kdm (kdm) {} - virtual ~KDMWithMetadata () {} + std::string kdm_as_xml () const { + return _kdm.as_xml (); + } - virtual std::string kdm_as_xml () const = 0; - virtual void kdm_as_xml (boost::filesystem::path out) const = 0; - virtual std::string kdm_id () const = 0; + void kdm_as_xml (boost::filesystem::path out) const { + return _kdm.as_xml (out); + } dcp::NameFormat::Map const& name_values () const { return _name_values; @@ -50,72 +54,62 @@ public: boost::optional get (char k) const; - boost::shared_ptr cinema () const { - return _cinema; + void const* group () const { + return _group; + } + + std::list emails () const { + return _emails; } private: dcp::NameFormat::Map _name_values; - boost::shared_ptr _cinema; + void const* _group; + std::list _emails; + dcp::EncryptedKDM _kdm; }; -typedef boost::shared_ptr KDMWithMetadataPtr; +typedef std::shared_ptr KDMWithMetadataPtr; int write_files ( std::list screen_kdms, boost::filesystem::path directory, - dcp::NameFormat name_format, dcp::NameFormat::Map name_values, - boost::function confirm_overwrite + dcp::NameFormat name_format, std::function confirm_overwrite ); -class DCPKDMWithMetadata : public KDMWithMetadata -{ -public: - DCPKDMWithMetadata (dcp::NameFormat::Map const& name_values, boost::shared_ptr cinema, dcp::EncryptedKDM k) - : KDMWithMetadata (name_values, cinema) - , kdm (k) - {} +void make_zip_file (std::list kdms, boost::filesystem::path zip_file, dcp::NameFormat name_format); - std::string kdm_as_xml () const { - return kdm.as_xml (); - } - void kdm_as_xml (boost::filesystem::path out) const { - return kdm.as_xml (out); - } +std::list> collect (std::list kdms); - std::string kdm_id () const { - return kdm.cpl_id (); - } - dcp::EncryptedKDM kdm; -}; +int write_directories ( + std::list> kdms, + boost::filesystem::path directory, + dcp::NameFormat container_name_format, + dcp::NameFormat filename_format, + std::function confirm_overwrite + ); -#ifdef DCPOMATIC_VARIANT_SWAROOP -class ECinemaKDMWithMetadata : public KDMWithMetadata -{ -public: - ECinemaKDMWithMetadata (dcp::NameValues::Map const& name_values, boost::shared_ptr cinema, EncryptedECinemaKDM k) - : KDMWithMetadata (name_values, cinema) - , kdm (k) - {} - std::string kdm_as_xml () const { - return kdm.as_xml (); - } +int write_zip_files ( + std::list> kdms, + boost::filesystem::path directory, + dcp::NameFormat container_name_format, + dcp::NameFormat filename_format, + std::function confirm_overwrite + ); - void kdm_as_xml (boost::filesystem::path out) const { - return kdm.as_xml (out); - } - std::string kdm_id () const { - return kdm.id (); - } +void send_emails ( + std::list> kdms, + dcp::NameFormat container_name_format, + dcp::NameFormat filename_format, + std::string cpl_name, + std::vector extra_addresses + ); - EncryptedECinemaKDM kdm; -}; #endif -#endif