Shadowrun: Awakened 29 September 2011 - Build 871
HMAC_MD5.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 /*
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.

GNU Lesser General Public License 3 Sourceforge.net