/*
- Copyright (C) 2018 Carl Hetherington <cth@carlh.net>
+ Copyright (C) 2018-2021 Carl Hetherington <cth@carlh.net>
This file is part of libdcp.
files in the program, then also delete it here.
*/
+
+/** @file src/pkl.cc
+ * @brief PKL class
+ */
+
+
#ifndef LIBDCP_PKL_H
#define LIBDCP_PKL_H
+
+#include "asset_list.h"
#include "object.h"
#include "types.h"
#include "util.h"
#include <libcxml/cxml.h>
#include <boost/filesystem.hpp>
+
namespace dcp {
-class PKL : public Object
+
+class PKL : public Object, public AssetList
{
public:
PKL (Standard standard, boost::optional<std::string> annotation_text, std::string issue_date, std::string issuer, std::string creator)
- : _standard (standard)
- , _annotation_text (annotation_text)
- , _issue_date (issue_date)
- , _issuer (issuer)
- , _creator (creator)
+ : AssetList(standard, annotation_text, issue_date, issuer, creator)
{}
explicit PKL (boost::filesystem::path file);
- Standard standard () const {
- return _standard;
- }
-
boost::optional<std::string> hash (std::string id) const;
boost::optional<std::string> type (std::string id) const;
- void add_asset (std::string id, boost::optional<std::string> annotation_text, std::string hash, int64_t size, std::string type);
- void write (boost::filesystem::path file, std::shared_ptr<const CertificateChain> signer) const;
+ void clear_assets();
+ void add_asset(std::string id, boost::optional<std::string> annotation_text, std::string hash, int64_t size, std::string type, std::string original_filename);
+ void write_xml (boost::filesystem::path file, std::shared_ptr<const CertificateChain> signer) const;
/** @return the most recent disk file used to read or write this PKL, if there is one */
boost::optional<boost::filesystem::path> file () const {
return _file;
}
-private:
-
class Asset : public Object
{
public:
Asset (cxml::ConstNodePtr node)
: Object (remove_urn_uuid(node->string_child("Id")))
- , annotation_text (node->optional_string_child("AnnotationText"))
- , hash (node->string_child("Hash"))
- , size (node->number_child<int64_t>("Size"))
- , type (node->string_child("Type"))
+ , _annotation_text (node->optional_string_child("AnnotationText"))
+ , _hash (node->string_child("Hash"))
+ , _size (node->number_child<int64_t>("Size"))
+ , _type (node->string_child("Type"))
+ , _original_filename(node->optional_string_child("OriginalFileName"))
{}
- Asset (std::string id_, boost::optional<std::string> annotation_text_, std::string hash_, int64_t size_, std::string type_)
- : Object (id_)
- , annotation_text (annotation_text_)
- , hash (hash_)
- , size (size_)
- , type (type_)
+ Asset(std::string id, boost::optional<std::string> annotation_text, std::string hash, int64_t size, std::string type, std::string original_filename)
+ : Object (id)
+ , _annotation_text (annotation_text)
+ , _hash (hash)
+ , _size (size)
+ , _type (type)
+ , _original_filename(original_filename)
{}
- boost::optional<std::string> annotation_text;
- std::string hash;
- int64_t size;
- std::string type;
+ boost::optional<std::string> annotation_text () const {
+ return _annotation_text;
+ }
+
+ std::string hash () const {
+ return _hash;
+ }
+
+ int64_t size () const {
+ return _size;
+ }
+
+ std::string type () const {
+ return _type;
+ }
+
+ boost::optional<std::string> original_filename() const {
+ return _original_filename;
+ }
+
+ private:
+ boost::optional<std::string> _annotation_text;
+ std::string _hash;
+ int64_t _size = 0;
+ std::string _type;
+ boost::optional<std::string> _original_filename;
};
- Standard _standard;
- boost::optional<std::string> _annotation_text;
- std::string _issue_date;
- std::string _issuer;
- std::string _creator;
- std::list<std::shared_ptr<Asset> > _asset_list;
+ std::vector<std::shared_ptr<Asset>> assets() const {
+ return _assets;
+ }
+
+private:
+ std::vector<std::shared_ptr<Asset>> _assets;
/** The most recent disk file used to read or write this PKL */
mutable boost::optional<boost::filesystem::path> _file;
};
+
}
+
#endif