Shadowrun: Awakened 29 September 2011 - Build 871
ICryptHash.hpp
Go to the documentation of this file.
00001 /*
00002     Copyright (c) 2009-2010 Christopher A. Taylor.  All rights reserved.
00003 
00004     Redistribution and use in source and binary forms, with or without
00005     modification, are permitted provided that the following conditions are met:
00006 
00007     * Redistributions of source code must retain the above copyright notice,
00008       this list of conditions and the following disclaimer.
00009     * Redistributions in binary form must reproduce the above copyright notice,
00010       this list of conditions and the following disclaimer in the documentation
00011       and/or other materials provided with the distribution.
00012     * Neither the name of LibCat nor the names of its contributors may be used
00013       to endorse or promote products derived from this software without
00014       specific prior written permission.
00015 
00016     THIS SOFTWARE IS PROVIDED BY THE COPYRIGHT HOLDERS AND CONTRIBUTORS "AS IS"
00017     AND ANY EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT LIMITED TO, THE
00018     IMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS FOR A PARTICULAR PURPOSE
00019     ARE DISCLAIMED.  IN NO EVENT SHALL THE COPYRIGHT HOLDER OR CONTRIBUTORS BE
00020     LIABLE FOR ANY DIRECT, INDIRECT, INCIDENTAL, SPECIAL, EXEMPLARY, OR
00021     CONSEQUENTIAL DAMAGES (INCLUDING, BUT NOT LIMITED TO, PROCUREMENT OF
00022     SUBSTITUTE GOODS OR SERVICES; LOSS OF USE, DATA, OR PROFITS; OR BUSINESS
00023     INTERRUPTION) HOWEVER CAUSED AND ON ANY THEORY OF LIABILITY, WHETHER IN
00024     CONTRACT, STRICT LIABILITY, OR TORT (INCLUDING NEGLIGENCE OR OTHERWISE)
00025     ARISING IN ANY WAY OUT OF THE USE OF THIS SOFTWARE, EVEN IF ADVISED OF THE
00026     POSSIBILITY OF SUCH DAMAGE.
00027 */
00028 
00029 // 06/15/09 began
00030 
00031 #ifndef CAT_I_CRYPT_HASH_HPP
00032 #define CAT_I_CRYPT_HASH_HPP
00033 
00034 #include <cat/Platform.hpp>
00035 #include <cstring>
00036 
00037 namespace cat {
00038 
00039 
00040 // Cryptographic hash functions of any size will derive from ICryptoHash and implement its public methods
00041 class ICryptHash
00042 {
00043 protected:
00044     int digest_bytes;
00045 
00046 public:
00047     virtual ~ICryptHash() {}
00048 
00049     // Returns the number of bytes in a message digest produced by this hash
00050     CAT_INLINE int GetDigestByteCount() { return digest_bytes; }
00051 
00052     CAT_INLINE void CrunchString(const char *s) { Crunch(s, (int)std::strlen(s) + 1); }
00053 
00054 public:
00055     // Begin a new key
00056     virtual bool BeginKey(int bits) = 0;
00057 
00058     // Start from an existing key
00059     virtual bool SetKey(ICryptHash *parent) = 0;
00060 
00061     // Begin hash function in MAC, KDF, or PRNG mode
00062     virtual bool BeginMAC() = 0;
00063     virtual bool BeginKDF() = 0;
00064     virtual bool BeginPRNG() = 0;
00065 
00066     // Crunch some message bytes
00067     virtual void Crunch(const void *message, int bytes) = 0;
00068 
00069     // Finalize the hash and prepare to generate output
00070     virtual void End() = 0;
00071 
00072     // Extended hash output mode
00073     virtual void Generate(void *out, int bytes, int strengthening_rounds = 0) = 0;
00074 };
00075 
00076 
00077 } // namespace cat
00078 
00079 #endif // CAT_I_CRYPT_HASH_HPP

Copyright © 2007-2010 by The Shadowrun: Awakened Team. This work is licensed under the GNU Lesser General Public License 3.

GNU Lesser General Public License 3 Sourceforge.net