![]() |
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 /* 00030 HMAC-MD5 is still secure despite the ease of producing collisions in MD5. 00031 See Mihir Bellare paper "New Proofs for NMAC and HMAC: Security without Collision-Resistance" (June 2006) 00032 00033 Using HMAC construction: 00034 HMAC(x) = h(k || p1 || h(k || p2 || x)) 00035 h() = MD5 hash 00036 p1,p2 = distinct padding to bring k up to the block size 00037 p1 = 0x36 repeated, p2 = 0x5c repeated 00038 00039 Diverges from usual implementation by using little-endian rather than big-endian input 00040 */ 00041 00042 #ifndef HMAC_MD5_HPP 00043 #define HMAC_MD5_HPP 00044 00045 #include <cat/crypt/hash/ICryptHash.hpp> 00046 00047 namespace cat { 00048 00049 00050 class HMAC_MD5 : public ICryptHash 00051 { 00052 protected: 00053 static const int DIGEST_BYTES = 16; 00054 static const int WORK_BYTES = 64; // bytes in one block 00055 static const int WORK_WORDS = WORK_BYTES / sizeof(u32); 00056 00057 u32 CachedInitialState[4]; // Cached state for H(K||inner padding) 00058 u32 CachedFinalState[4]; // Cached state for H(K||outer padding) 00059 00060 u64 byte_counter; 00061 u32 State[4]; 00062 u8 Work[WORK_BYTES]; 00063 int used_bytes; 00064 00065 void HashComputation(const void *message, int blocks, u32 *NextState); 00066 00067 // Unsupported modes 00068 bool BeginKey(int /*bits*/) { return false; } 00069 bool BeginKDF() { return false; } 00070 bool BeginPRNG() { return false; } 00071 00072 public: 00073 ~HMAC_MD5(); 00074 bool SetKey(ICryptHash *parent); 00075 void RekeyFromMD5(HMAC_MD5 *parent); 00076 bool BeginMAC(); 00077 void Crunch(const void *message, int bytes); 00078 void End(); 00079 00080 // TODO: Strengthening is not supported right now 00081 void Generate(void *out, int bytes, int strengthening_rounds = 0); 00082 }; 00083 00084 00085 } // namespace cat 00086 00087 #endif // HMAC_MD5_HPP
Copyright © 2007-2010 by The Shadowrun: Awakened Team. This work is licensed under the GNU Lesser General Public License 3.