X-Git-Url: https://git.carlh.net/gitweb/?a=blobdiff_plain;f=src%2Flib%2Fscreen.h;h=96b0ce76416c1ab878a8f9c0a5238ba47aa0c1a2;hb=7132012dde96d6e9aa36d2beaade1a0036ae3d9f;hp=40990b684e04a4f6eac4e86c717e749032977e4d;hpb=9d049dc062df1c134105ec6a042aa9f56ae9c067;p=dcpomatic.git diff --git a/src/lib/screen.h b/src/lib/screen.h index 40990b684..96b0ce764 100644 --- a/src/lib/screen.h +++ b/src/lib/screen.h @@ -21,30 +21,16 @@ #ifndef DCPOMATIC_SCREEN_H #define DCPOMATIC_SCREEN_H +#include "kdm_with_metadata.h" +#include "kdm_recipient.h" +#include "trusted_device.h" #include #include #include #include class Cinema; - -class TrustedDevice -{ -public: - explicit TrustedDevice (std::string); - explicit TrustedDevice (dcp::Certificate); - - boost::optional certificate () const { - return _certificate; - } - - std::string thumbprint () const; - std::string as_string () const; - -private: - boost::optional _certificate; - boost::optional _thumbprint; -}; +class Film; namespace dcpomatic { @@ -55,14 +41,12 @@ namespace dcpomatic { * `recipient' (i.e. the mediablock) and the certificates/thumbprints * of any trusted devices. */ -class Screen +class Screen : public KDMRecipient { public: - Screen (std::string const & na, std::string const & no, boost::optional rec, std::vector td) - : name (na) - , notes (no) - , recipient (rec) - , trusted_devices (td) + Screen (std::string const & name_, std::string const & notes_, boost::optional recipient_, std::vector trusted_devices_) + : KDMRecipient (name_, notes_, recipient_) + , trusted_devices (trusted_devices_) {} explicit Screen (cxml::ConstNodePtr); @@ -70,13 +54,23 @@ public: void as_xml (xmlpp::Element *) const; std::vector trusted_device_thumbprints () const; - boost::shared_ptr cinema; - std::string name; - std::string notes; - boost::optional recipient; + std::shared_ptr cinema; std::vector trusted_devices; }; } +KDMWithMetadataPtr +kdm_for_screen ( + std::shared_ptr film, + boost::filesystem::path cpl, + std::shared_ptr screen, + boost::posix_time::ptime valid_from, + boost::posix_time::ptime valid_to, + dcp::Formulation formulation, + bool disable_forensic_marking_picture, + boost::optional disable_forensic_marking_audio + ); + + #endif