Add a 'Make DKDM' dialogue box to simplify and (hopefully) clarify DKDM creation...
[dcpomatic.git] / src / lib / kdm_with_metadata.h
index ee84d9eb4842699d2dcc5085184ee6609713aa84..b6bec1c4c200693b5932619e9f0b7497ef9aa2c2 100644 (file)
@@ -33,16 +33,16 @@ class Cinema;
 class KDMWithMetadata
 {
 public:
-       KDMWithMetadata (dcp::NameFormat::Map const& name_values, boost::shared_ptr<Cinema> cinema)
+       KDMWithMetadata (dcp::NameFormat::Map const& name_values, void const* group, std::list<std::string> emails)
                : _name_values (name_values)
-               , _cinema (cinema)
+               , _group (group)
+               , _emails (emails)
        {}
 
        virtual ~KDMWithMetadata () {}
 
        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;
 
        dcp::NameFormat::Map const& name_values () const {
                return _name_values;
@@ -50,13 +50,18 @@ public:
 
        boost::optional<std::string> get (char k) const;
 
-       boost::shared_ptr<Cinema> cinema () const {
-               return _cinema;
+       void const* group () const {
+               return _group;
+       }
+
+       std::list<std::string> emails () const {
+               return _emails;
        }
 
 private:
        dcp::NameFormat::Map _name_values;
-       boost::shared_ptr<Cinema> _cinema;
+       void const* _group;
+       std::list<std::string> _emails;
 };
 
 
@@ -65,40 +70,48 @@ typedef boost::shared_ptr<KDMWithMetadata> KDMWithMetadataPtr;
 
 int write_files (
        std::list<KDMWithMetadataPtr> screen_kdms, boost::filesystem::path directory,
-       dcp::NameFormat name_format, dcp::NameFormat::Map name_values,
-       boost::function<bool (boost::filesystem::path)> confirm_overwrite
+       dcp::NameFormat name_format, boost::function<bool (boost::filesystem::path)> confirm_overwrite
        );
 
 
-class DCPKDMWithMetadata : public KDMWithMetadata
-{
-public:
-       DCPKDMWithMetadata (dcp::NameFormat::Map const& name_values, boost::shared_ptr<Cinema> cinema, dcp::EncryptedKDM k)
-               : KDMWithMetadata (name_values, cinema)
-               , kdm (k)
-       {}
+void make_zip_file (std::list<KDMWithMetadataPtr> 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<std::list<KDMWithMetadataPtr> > collect (std::list<KDMWithMetadataPtr> kdms);
 
-       std::string kdm_id () const {
-               return kdm.cpl_id ();
-       }
 
-       dcp::EncryptedKDM kdm;
-};
+int write_directories (
+               std::list<std::list<KDMWithMetadataPtr> > kdms,
+               boost::filesystem::path directory,
+               dcp::NameFormat container_name_format,
+               dcp::NameFormat filename_format,
+               boost::function<bool (boost::filesystem::path)> confirm_overwrite
+               );
 
-#ifdef DCPOMATIC_VARIANT_SWAROOP
-class ECinemaKDMWithMetadata : public KDMWithMetadata
+
+int write_zip_files (
+               std::list<std::list<KDMWithMetadataPtr> > kdms,
+               boost::filesystem::path directory,
+               dcp::NameFormat container_name_format,
+               dcp::NameFormat filename_format,
+               boost::function<bool (boost::filesystem::path)> confirm_overwrite
+               );
+
+
+void email (
+               std::list<std::list<KDMWithMetadataPtr> > kdms,
+               dcp::NameFormat container_name_format,
+               dcp::NameFormat filename_format,
+               std::string cpl_name
+               );
+
+
+template <class T>
+class SpecialKDMWithMetadata : public KDMWithMetadata
 {
 public:
-       ECinemaKDMWithMetadata (dcp::NameValues::Map const& name_values, boost::shared_ptr<Cinema> cinema, EncryptedECinemaKDM k)
-               : KDMWithMetadata (name_values, cinema)
+       SpecialKDMWithMetadata (dcp::NameFormat::Map const& name_values, void const* group, std::list<std::string> emails, T k)
+               : KDMWithMetadata (name_values, group, emails)
                , kdm (k)
        {}
 
@@ -110,12 +123,13 @@ public:
                return kdm.as_xml (out);
        }
 
-       std::string kdm_id () const {
-               return kdm.id ();
-       }
-
-       EncryptedECinemaKDM kdm;
+       T kdm;
 };
+
+typedef SpecialKDMWithMetadata<dcp::EncryptedKDM> DCPKDMWithMetadata;
+#ifdef DCPOMATIC_VARIANT_SWAROOP
+typedef SpecialKDMWithMetadata<EncryptedECinemaKDM> ECinemaKDMWithMetadata;
 #endif
 
 #endif
+