#ifndef DCPOMATIC_KDM_WITH_METADATA_H
#define DCPOMATIC_KDM_WITH_METADATA_H
-#ifdef DCPOMATIC_VARIANT_SWAROOP
-#include "encrypted_ecinema_kdm.h"
-#endif
#include <dcp/encrypted_kdm.h>
#include <dcp/name_format.h>
-#include <boost/shared_ptr.hpp>
-namespace dcpomatic {
- class Screen;
-}
+class Cinema;
-/** Simple class to collect a screen and an encrypted KDM */
class KDMWithMetadata
{
public:
- KDMWithMetadata (boost::shared_ptr<dcpomatic::Screen> s)
- : screen (s)
+ KDMWithMetadata (dcp::NameFormat::Map const& name_values, void const* group, std::list<std::string> emails, dcp::EncryptedKDM kdm)
+ : _name_values (name_values)
+ , _group (group)
+ , _emails (emails)
+ , _kdm (kdm)
{}
- virtual ~KDMWithMetadata () {}
+ std::string kdm_as_xml () const {
+ return _kdm.as_xml ();
+ }
+
+ void kdm_as_xml (boost::filesystem::path out) const {
+ return _kdm.as_xml (out);
+ }
+
+ dcp::NameFormat::Map const& name_values () const {
+ return _name_values;
+ }
+
+ boost::optional<std::string> get (char k) const;
+
+ void const* group () const {
+ return _group;
+ }
- 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;
+ std::list<std::string> emails () const {
+ return _emails;
+ }
- boost::shared_ptr<dcpomatic::Screen> screen;
+private:
+ dcp::NameFormat::Map _name_values;
+ void const* _group;
+ std::list<std::string> _emails;
+ dcp::EncryptedKDM _kdm;
};
-typedef boost::shared_ptr<KDMWithMetadata> KDMWithMetadataPtr;
+typedef std::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 (boost::shared_ptr<dcpomatic::Screen> s, dcp::EncryptedKDM k)
- : KDMWithMetadata (s)
- , 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
-{
-public:
- ECinemaKDMWithMetadata (boost::shared_ptr<dcpomatic::Screen> s, EncryptedECinemaKDM k)
- : KDMWithMetadata (s)
- , kdm (k)
- {}
- std::string kdm_as_xml () const {
- return kdm.as_xml ();
- }
+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 kdm_as_xml (boost::filesystem::path out) const {
- return kdm.as_xml (out);
- }
- std::string kdm_id () const {
- return kdm.id ();
- }
+void email (
+ std::list<std::list<KDMWithMetadataPtr> > kdms,
+ dcp::NameFormat container_name_format,
+ dcp::NameFormat filename_format,
+ std::string cpl_name
+ );
- EncryptedECinemaKDM kdm;
-};
#endif
-#endif