/* Copyright (C) 2012-2014 Carl Hetherington This program is free software; you can redistribute it and/or modify it under the terms of the GNU General Public License as published by the Free Software Foundation; either version 2 of the License, or (at your option) any later version. This program is distributed in the hope that it will be useful, but WITHOUT ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the GNU General Public License for more details. You should have received a copy of the GNU General Public License along with this program; if not, write to the Free Software Foundation, Inc., 675 Mass Ave, Cambridge, MA 02139, USA. */ #ifndef LIBDCP_MXF_H #define LIBDCP_MXF_H #include "asset.h" #include "key.h" #include "metadata.h" #include namespace ASDCP { class AESDecContext; class WriterInfo; } /* Undefine some stuff that the OS X 10.5 SDK defines */ #undef Key #undef set_key namespace dcp { class MXFMetadata; class PictureAssetWriter; /** @class MXF * @brief Parent for classes which represent MXF files. */ class MXF { public: MXF (); virtual ~MXF (); /** @return true if the data is encrypted */ bool encrypted () const { return static_cast(_key_id); } /** Set the ID of the key that is used for encryption/decryption. * @param i key ID. */ void set_key_id (std::string i) { _key_id = i; } /** @return the ID of the key used for encryption/decryption, if there is one */ boost::optional key_id () const { return _key_id; } void set_key (Key); /** @return encryption/decryption key, if one has been set */ boost::optional key () const { return _key; } /** Set the metadata that is written to the MXF file. * @param m Metadata. */ void set_metadata (MXFMetadata m) { _metadata = m; } /** @return metadata from the MXF file */ MXFMetadata metadata () const { return _metadata; } protected: template friend void start (PictureAssetWriter* writer, boost::shared_ptr

state, Standard standard, Q* mxf, uint8_t* data, int size); std::string read_writer_info (ASDCP::WriterInfo const &); /** Fill in a ADSCP::WriteInfo struct. * @param w struct to fill in. * @param standard INTEROP or SMPTE. */ void fill_writer_info (ASDCP::WriterInfo* w, std::string id, Standard standard) const; ASDCP::AESDecContext* _decryption_context; /** ID of the key used for encryption/decryption, if there is one */ boost::optional _key_id; /** Key used for encryption/decryption, if there is one */ boost::optional _key; MXFMetadata _metadata; }; } #endif