X-Git-Url: https://git.carlh.net/gitweb/?a=blobdiff_plain;f=src%2Fdecrypted_kdm.h;h=16b0acbab0fc4280939239960b82f4d36d6cece0;hb=7d66bda50ade8ea618f331b885f1bfa4fa0a2af9;hp=c264bfbcf305aac9dd79482bc9ef009c1f5e6078;hpb=697a8c5a86b013ff4dd78b6c3b79b09522bd9e46;p=libdcp.git diff --git a/src/decrypted_kdm.h b/src/decrypted_kdm.h index c264bfbc..16b0acba 100644 --- a/src/decrypted_kdm.h +++ b/src/decrypted_kdm.h @@ -1,5 +1,5 @@ /* - Copyright (C) 2013-2017 Carl Hetherington + Copyright (C) 2013-2021 Carl Hetherington This file is part of libdcp. @@ -31,13 +31,16 @@ files in the program, then also delete it here. */ -#ifndef LIBDCP_DECRYPTED_KDM_H -#define LIBDCP_DECRYPTED_KDM_H /** @file src/decrypted_kdm.h - * @brief DecryptedKDM class. + * @brief DecryptedKDM class */ + +#ifndef LIBDCP_DECRYPTED_KDM_H +#define LIBDCP_DECRYPTED_KDM_H + + #include "key.h" #include "local_time.h" #include "decrypted_kdm_key.h" @@ -46,18 +49,22 @@ #include #include + class decrypted_kdm_test; + namespace dcp { + class DecryptedKDMKey; class EncryptedKDM; class CertificateChain; class CPL; -class ReelMXF; +class ReelEncryptableAsset; + /** @class DecryptedKDM - * @brief A decrypted KDM. + * @brief A decrypted KDM * * This is a KDM that has either been decrypted by a target private key, or one which * has been created (by some other means) ready for encryption later. @@ -92,7 +99,7 @@ public: */ DecryptedKDM ( std::string cpl_id, - std::map, Key> keys, + std::map, Key> keys, LocalTime not_valid_before, LocalTime not_valid_after, std::string annotation_text, @@ -109,7 +116,7 @@ public: * @param not_valid_after End time for the KDM. */ DecryptedKDM ( - boost::shared_ptr cpl, + std::shared_ptr cpl, Key key, LocalTime not_valid_before, LocalTime not_valid_after, @@ -121,25 +128,34 @@ public: /** Encrypt this KDM's keys and sign the whole KDM. * @param signer Chain to sign with. * @param recipient Certificate of the projector/server which should receive this KDM's keys. - * @param trusted_devices Extra trusted devices which should be written to the KDM (recipient will be written + * @param trusted_devices Thumbprints of extra trusted devices which should be written to the KDM (recipient will be written * as a trusted device automatically and does not need to be included in this list). * @param formulation Formulation to use for the encrypted KDM. + * @param disable_forensic_marking_picture true to disable forensic marking of picture. + * @param disable_forensic_marking_audio if not set, don't disable forensic marking of audio. If set to 0, + * disable all forensic marking; if set above 0, disable forensic marking above that channel. * @return Encrypted KDM. */ EncryptedKDM encrypt ( - boost::shared_ptr signer, + std::shared_ptr signer, Certificate recipient, - std::vector trusted_devices, + std::vector trusted_devices, Formulation formulation, - int disable_forensic_marking_picture, - int disable_forensic_marking_audio + bool disable_forensic_marking_picture, + boost::optional disable_forensic_marking_audio ) const; + /** @param type (MDIK, MDAK etc.) + * @param key_id Key ID + * @param key The actual symmetric key + * @param cpl_id ID of CPL that the key is for + */ void add_key (boost::optional type, std::string key_id, Key key, std::string cpl_id, Standard standard); + void add_key (DecryptedKDMKey key); /** @return This KDM's (decrypted) keys, which could be used to decrypt assets. */ - std::list keys () const { + std::vector keys () const { return _keys; } @@ -167,9 +183,11 @@ private: boost::optional _annotation_text; std::string _content_title_text; std::string _issue_date; - std::list _keys; + std::vector _keys; }; + } + #endif