diff options
| author | Carl Hetherington <cth@carlh.net> | 2014-06-13 16:11:51 +0100 |
|---|---|---|
| committer | Carl Hetherington <cth@carlh.net> | 2014-06-13 16:11:51 +0100 |
| commit | b7d81e736dc35325e98c558067c157b000b856c1 (patch) | |
| tree | cd8230bb2d671592e36e6dce6643cfe6c1e3231a /src | |
| parent | 7bca4c05ca38b218c252b0fe98a866806d9a2ded (diff) | |
Throw NotEncryptedError on trying to make a KDM for non-encrypted assets.
Diffstat (limited to 'src')
| -rw-r--r-- | src/decrypted_kdm.cc | 3 | ||||
| -rw-r--r-- | src/exceptions.cc | 12 | ||||
| -rw-r--r-- | src/exceptions.h | 104 |
3 files changed, 53 insertions, 66 deletions
diff --git a/src/decrypted_kdm.cc b/src/decrypted_kdm.cc index 7e9e146d..3d442ce7 100644 --- a/src/decrypted_kdm.cc +++ b/src/decrypted_kdm.cc @@ -202,6 +202,9 @@ DecryptedKDM::DecryptedKDM ( /* XXX: do non-MXF assets need keys? */ shared_ptr<const MXF> mxf = boost::dynamic_pointer_cast<const MXF> (*i); if (mxf) { + if (mxf->key_id().empty ()) { + throw NotEncryptedError (mxf->file().string ()); + } _keys.push_back (DecryptedKDMKey (mxf->key_type(), mxf->key_id(), mxf->key().get (), cpl->id ())); } } diff --git a/src/exceptions.cc b/src/exceptions.cc index 28846e16..b31974d4 100644 --- a/src/exceptions.cc +++ b/src/exceptions.cc @@ -28,7 +28,7 @@ using std::string; using namespace dcp; FileError::FileError (string message, boost::filesystem::path filename, int number) - : _message (String::compose ("%1 (%2) (error %3)", message, filename.string(), number)) + : StringError (String::compose ("%1 (%2) (error %3)", message, filename.string(), number)) , _filename (filename) , _number (number) { @@ -36,13 +36,13 @@ FileError::FileError (string message, boost::filesystem::path filename, int numb } UnresolvedRefError::UnresolvedRefError (string id) - : _message (String::compose ("Unresolved reference to asset id %1", id)) + : StringError (String::compose ("Unresolved reference to asset id %1", id)) { } TimeFormatError::TimeFormatError (string bad_time) - : _message (String::compose ("Bad time string %1", bad_time)) + : StringError (String::compose ("Bad time string %1", bad_time)) { } @@ -68,3 +68,9 @@ MissingAssetError::MissingAssetError (boost::filesystem::path path, AssetType ty _message = String::compose ("Missing asset %1%2", path.string(), type_name); } + +NotEncryptedError::NotEncryptedError (string const & what) + : StringError (String::compose ("%1 is not encrypted", what)) +{ + +} diff --git a/src/exceptions.h b/src/exceptions.h index 5d8000d7..be87c40b 100644 --- a/src/exceptions.h +++ b/src/exceptions.h @@ -29,20 +29,34 @@ namespace dcp { +class StringError : public std::exception +{ +public: + StringError () {} + StringError (std::string message) + : _message (message) + {} + + ~StringError () throw () {} + + /** @return error message */ + char const * what () const throw () { + return _message.c_str (); + } + +protected: + std::string _message; +}; + /** @class FileError * @brief An exception related to a file */ -class FileError : public std::exception +class FileError : public StringError { public: FileError (std::string message, boost::filesystem::path filename, int number); ~FileError () throw () {} - /** @return error message */ - char const * what () const throw () { - return _message.c_str (); - } - /** @return filename of file that was involved */ boost::filesystem::path filename () const { return _filename; @@ -54,8 +68,6 @@ public: } private: - /** message part */ - std::string _message; /** filename of file that was involved */ boost::filesystem::path _filename; int _number; @@ -75,41 +87,26 @@ public: /** @class MiscError * @brief A miscellaneous exception */ -class MiscError : public std::exception +class MiscError : public StringError { public: - MiscError (std::string message) : _message (message) {} - ~MiscError () throw () {} - - /** @return error message */ - char const * what () const throw () { - return _message.c_str (); - } - -private: - /** error message */ - std::string _message; + MiscError (std::string message) + : StringError (message) + {} }; /** @class DCPReadError * @brief A DCP read exception */ -class DCPReadError : public std::exception +class DCPReadError : public StringError { public: - DCPReadError (std::string message) : _message (message) {} - ~DCPReadError () throw () {} - - /** @return error message */ - char const * what () const throw () { - return _message.c_str (); - } + DCPReadError (std::string message) + : StringError (message) + {} protected: DCPReadError () {} - - /** error message */ - std::string _message; }; /** @class MissingAssetError @@ -136,58 +133,39 @@ private: /** @class XMLError * @brief An XML error */ -class XMLError : public std::exception +class XMLError : public StringError { public: - XMLError (std::string message) : _message (message) {} - ~XMLError () throw () {} - - /** @return error message */ - char const * what () const throw () { - return _message.c_str (); - } - -private: - /** error message */ - std::string _message; + XMLError (std::string message) + : StringError (message) + {} }; /** @class UnresolvedRefError * @brief An exception caused by a reference (by UUID) to something which is not known */ -class UnresolvedRefError : public std::exception +class UnresolvedRefError : public StringError { public: UnresolvedRefError (std::string id); - ~UnresolvedRefError () throw () {} - - /** @return error message */ - char const * what () const throw () { - return _message.c_str (); - } - -private: - std::string _message; }; /** @class TimeFormatError * @brief A an error with a string passed to LocalTime. */ -class TimeFormatError : public std::exception +class TimeFormatError : public StringError { public: TimeFormatError (std::string bad_time); - ~TimeFormatError () throw () {} - - /** @return error message */ - char const * what () const throw () { - return _message.c_str (); - } - -private: - std::string _message; }; +class NotEncryptedError : public StringError +{ +public: + NotEncryptedError (std::string const & asset_filename); + ~NotEncryptedError () throw () {} +}; + } #endif |
