![]() |
Shadowrun: Awakened 29 September 2011 - Build 871
|
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.