//////////////////////////////////////////////////////////////////////////////// // This source file is part of the ZipArchive library source distribution and // is Copyrighted 2000 - 2011 by Artpol Software - Tadeusz Dracz // // 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. // // For the licensing details refer to the License.txt file. // // Web Site: http://www.artpol-software.com //////////////////////////////////////////////////////////////////////////////// /** * \file ZipCryptograph.h * Includes the CZipCryptograph class. * */ #if !defined(ZIPARCHIVE_ZIPCRYPTOGRAPH_DOT_H) #define ZIPARCHIVE_ZIPCRYPTOGRAPH_DOT_H #if _MSC_VER > 1000 #pragma once #pragma warning( push ) #pragma warning (disable : 4100) // unreferenced formal parameter #endif // _MSC_VER > 1000 #include "ZipAutoBuffer.h" #include "ZipStorage.h" class CZipFileHeader; /** The base class for cryptographs used in encryption and decryption of file data. \see 0610201627 */ class ZIP_API CZipCryptograph { public: /** The encryption method. \see 0610201627 */ enum EncryptionMethod { encStandard, ///< The traditional zip encryption. encWinZipAes128, ///< WinZip AES 128-bit encryption. encWinZipAes192, ///< WinZip AES 192-bit encryption. encWinZipAes256, ///< WinZip AES 256-bit encryption. encNone = 0xFF ///< Indicates no encryption. }; /** A factory method that creates an appropriate cryptograph for the given method. \param iEncryptionMethod The encryption method to create a cryptograph for. It can be one of the #EncryptionMethod values. \return The new cryptograph. The caller is responsible for destroying the object. If the method is not supported, creates CZipCrc32Cryptograph. */ static CZipCryptograph* CreateCryptograph(int iEncryptionMethod); /** Returns the value indicating whether the given method is one of the WinZip AES encryption methods. \param iEncryptionMethod The encryption method to test. It can be one of the #EncryptionMethod values. \return \c true, if the method is one the WinZip AES encryption methods; \c false otherwise. */ static bool IsWinZipAesEncryption(int iEncryptionMethod) { return iEncryptionMethod == encWinZipAes128 || iEncryptionMethod == encWinZipAes192 || iEncryptionMethod == encWinZipAes256; } /** Returns the total size of the extra data that is added to the compression stream during encryption with the given method. \param iEncryptionMethod The encryption method. It can be one of the #EncryptionMethod values. \return The total size of extra data for the given encryption method. */ static DWORD GetEncryptedInfoSize(int iEncryptionMethod); /** Returns the size of the extra data that is added before the compression stream during encryption with the given method. \param iEncryptionMethod The encryption method. It can be one of the #EncryptionMethod values. \return The size of extra data at the beginning of the compression stream for the given encryption method. */ static DWORD GetEncryptedInfoSizeBeforeData(int iEncryptionMethod); /** Returns the size of the extra data that is added after the compression stream during encryption with the given method. \param iEncryptionMethod The encryption method. It can be one of the #EncryptionMethod values. \return The size of extra data at the end of the compression stream for the given encryption method. */ static DWORD GetEncryptedInfoSizeAfterData(int iEncryptionMethod); /** Returns the value indicating whether the given encryption method is supported by the current compilation of the ZipArchive Library. \param iEncryptionMethod The encryption method to test. It can be one of the #EncryptionMethod values. \return \c true, if the method is supported; \c false otherwise. */ static bool IsEncryptionSupported(int iEncryptionMethod) { return iEncryptionMethod == encStandard; } /** The method called when an existing file is opened for extraction. \param password The supplied password with the CZipArchive::SetPassword method. \param currentFile The file being decoded and extracted. \param storage The current CZipStorage. \param ignoreCheck If \c true, skips control bytes verifications. \return \c true, if the password is initially considered correct; \c false otherwise. */ virtual bool InitDecode(CZipAutoBuffer& password, CZipFileHeader& currentFile, CZipStorage& storage, bool ignoreCheck) = 0; /** The method called when a new file is opened for compression. \param password The supplied password with the CZipArchive::SetPassword method. \param currentFile The file being compressed and encoded. \param storage The current CZipStorage. */ virtual void InitEncode(CZipAutoBuffer& password, CZipFileHeader& currentFile, CZipStorage& storage) = 0; /** Decodes the given data. \param pBuffer The buffer that holds the data to decode and that receives the results. \param uSize The size of \a pBuffer. */ virtual void Decode(char* pBuffer, DWORD uSize) = 0; /** Encodes the given data. \param pBuffer The buffer that holds the data to encode and that receives the results. \param uSize The size of \a pBuffer. */ virtual void Encode(char* pBuffer, DWORD uSize) = 0; /** The method called at the end of the decoding process. \param currentFile The file being decoded and extracted. \param storage The current CZipStorage. */ virtual void FinishDecode(CZipFileHeader& currentFile, CZipStorage& storage){}; /** The method called at the end of the decoding process. \param currentFile The file being compressed and encoded. \param storage The current CZipStorage. */ virtual void FinishEncode(CZipFileHeader& currentFile, CZipStorage& storage){}; /** Returns the value indicating whether the current compressor can handle the given encryption method. \param iEncryptionMethod The encryption method to test. It can be one of the #EncryptionMethod values. \return \c true, if the current compressor can handle the given encryption method; \c false otherwise. */ virtual bool CanHandle(int iEncryptionMethod) { return false; } virtual ~CZipCryptograph(){} }; #if _MSC_VER > 1000 #pragma warning( pop ) #endif // _MSC_VER > 1000 #endif