Shadowrun: Awakened 29 September 2011 - Build 871
CookieJar.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 #ifndef CAT_COOKIE_JAR_HPP
00030 #define CAT_COOKIE_JAR_HPP
00031 
00032 #include <cat/crypt/rand/Fortuna.hpp>
00033 
00034 namespace cat {
00035 
00036 
00037 class CookieJar
00038 {
00039     static const int EXPIRE_TIME = 4000; // ms
00040     static const int BIN_COUNT = 16; // power of 2
00041     static const int BIN_TIME = EXPIRE_TIME / BIN_COUNT;
00042     static const int BIN_MASK = BIN_COUNT - 1;
00043 
00044     u32 key[16];
00045 
00046     u32 Salsa6(u32 *x);
00047 
00048     u32 Hash(u32 ip, u16 port, u32 epoch);
00049     u32 Hash(const void *address_info, int bytes, u32 epoch);
00050 
00051     u32 GetEpoch();
00052     u32 ReconstructEpoch(u32 cookie);
00053 
00054 public:
00055     // Initialize to a random 512-bit key on startup
00056     void Initialize(FortunaOutput *csprng);
00057 
00058     // Thread-safe and lock-free
00059     u32 Generate(u32 ip, u16 port);
00060     u32 Generate(const void *address_info, int bytes); // bytes <= 48
00061 
00062     // Thread-safe and lock-free
00063     bool Verify(u32 ip, u16 port, u32 cookie);
00064     bool Verify(const void *address_info, int bytes, u32 cookie); // bytes <= 48
00065 };
00066 
00067 
00068 } // namespace cat
00069 
00070 #endif // CAT_COOKIE_JAR_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