Fix (I think) AuthenticatedPublic signer.
[libdcp.git] / src / cpl.h
index 0abff749bdc0ef8966feb2136c7182460838e31c..95bcd03fb8d9ee217ee0b32f8da97806bf851b4f 100644 (file)
--- a/src/cpl.h
+++ b/src/cpl.h
 
 */
 
+#ifndef LIBDCP_CPL_H
+#define LIBDCP_CPL_H
+
 #include <list>
 #include <boost/shared_ptr.hpp>
 #include <boost/function.hpp>
+#include <boost/date_time/posix_time/posix_time.hpp>
+#include <boost/optional.hpp>
+#include <libxml++/libxml++.h>
 #include "types.h"
+#include "certificates.h"
 
 namespace libdcp {
 
-class AssetMap;
+namespace parse {
+       class AssetMap;
+       class AssetMapAsset;
+}
+       
 class Asset;
 class Reel;
 class XMLMetadata;
-
+class MXFMetadata;
+class Encryption;
+class KDM;
+       
 /** @brief A CPL within a DCP */
 class CPL
 {
 public:
        CPL (std::string directory, std::string name, ContentKind content_kind, int length, int frames_per_second);
-       CPL (std::string directory, std::string file, boost::shared_ptr<const AssetMap> asset_map, bool require_mxfs = true);
+       CPL (std::string directory, std::string file, std::list<PathAssetMap> asset_maps, bool require_mxfs = true);
 
-       void add_reel (boost::shared_ptr<const Reel> reel);
+       void add_reel (boost::shared_ptr<Reel> reel);
        
        /** @return the length in frames */
        int length () const {
@@ -50,7 +64,7 @@ public:
                return _content_kind;
        }
 
-       std::list<boost::shared_ptr<const Reel> > reels () const {
+       std::list<boost::shared_ptr<Reel> > reels () const {
                return _reels;
        }
 
@@ -67,14 +81,35 @@ public:
        }
 
        std::list<boost::shared_ptr<const Asset> > assets () const;
+
+       bool encrypted () const;
+
+       std::string id () const {
+               return _id;
+       }
        
        bool equals (CPL const & other, EqualityOptions options, boost::function<void (NoteType, std::string)> note) const;
        
-       void write_xml (XMLMetadata const &) const;
-       void write_to_assetmap (std::ostream& s) const;
-       void write_to_pkl (std::ostream& s) const;
+       void write_xml (bool, XMLMetadata const &, boost::shared_ptr<Encryption>) const;
+       void write_to_assetmap (xmlpp::Node *) const;
+       void write_to_pkl (xmlpp::Node *) const;
+
+       boost::shared_ptr<xmlpp::Document> make_kdm (
+               CertificateChain const &,
+               std::string const &,
+               boost::shared_ptr<const Certificate>,
+               boost::posix_time::ptime from,
+               boost::posix_time::ptime until,
+               bool,
+               MXFMetadata const &,
+               XMLMetadata const &
+               ) const;
+
+       void add_kdm (KDM const &);
        
 private:
+       std::pair<std::string, boost::shared_ptr<const parse::AssetMapAsset> > asset_from_id (std::list<PathAssetMap>, std::string id) const;
+       
        std::string _directory;
        /** the name of the DCP */
        std::string _name;
@@ -85,12 +120,14 @@ private:
        /** frames per second */
        int _fps;
        /** reels */
-       std::list<boost::shared_ptr<const Reel> > _reels;
+       std::list<boost::shared_ptr<Reel> > _reels;
 
        /** our UUID */
-       std::string _uuid;
+       std::string _id;
        /** a SHA1 digest of our XML */
        mutable std::string _digest;
 };
 
 }
+
+#endif