Shadowrun: Awakened 29 September 2011 - Build 871
KeyAgreementResponder.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_KEY_AGREEMENT_RESPONDER_HPP
00030 #define CAT_KEY_AGREEMENT_RESPONDER_HPP
00031 
00032 #include <cat/crypt/tunnel/KeyAgreement.hpp>
00033 #include <cat/crypt/tunnel/AuthenticatedEncryption.hpp>
00034 #include <cat/threads/Atomic.hpp>
00035 
00036 #if defined(CAT_NO_ATOMIC_ADD) || defined(CAT_NO_ATOMIC_SET)
00037 # include <cat/threads/Mutex.hpp>
00038 # define CAT_NO_ATOMIC_RESPONDER
00039 #endif
00040 
00041 namespace cat {
00042 
00043 
00044 class KeyAgreementResponder : public KeyAgreementCommon
00045 {
00046     Leg *b; // Responder's private key (kept secret)
00047     Leg *B; // Responder's public key (pre-shared with initiator)
00048     Leg *B_neutral; // Endian-neutral B
00049     Leg *G_MultPrecomp; // 8-bit table for multiplication
00050     Leg *y[2]; // Responder's ephemeral private key (kept secret)
00051     Leg *Y_neutral[2]; // Responder's ephemeral public key (shared online with initiator)
00052 
00053 #if defined(CAT_NO_ATOMIC_RESPONDER)
00054     Mutex m_thread_id_mutex;
00055 #endif // CAT_NO_ATOMIC_RESPONDER
00056 
00057     volatile u32 ChallengeCount;
00058     volatile u32 ActiveY;
00059 
00060     void Rekey(BigTwistedEdwards *math, FortunaOutput *csprng);
00061     bool AllocateMemory();
00062     void FreeMemory();
00063 
00064 public:
00065     KeyAgreementResponder();
00066     ~KeyAgreementResponder();
00067 
00068     bool Initialize(BigTwistedEdwards *math, FortunaOutput *csprng,
00069                     const u8 *responder_public_key, int public_bytes,
00070                     const u8 *responder_private_key, int private_bytes);
00071 
00072 public:
00073     bool ProcessChallenge(BigTwistedEdwards *math, FortunaOutput *csprng,
00074                           const u8 *initiator_challenge, int challenge_bytes,
00075                           u8 *responder_answer, int answer_bytes, Skein *key_hash);
00076 
00077     inline bool KeyEncryption(Skein *key_hash, AuthenticatedEncryption *auth_enc, const char *key_name)
00078     {
00079         return auth_enc->SetKey(KeyBytes, key_hash, false, key_name);
00080     }
00081 
00082 public:
00083     bool Sign(BigTwistedEdwards *math, FortunaOutput *csprng,
00084               const u8 *message, int message_bytes,
00085               u8 *signature, int signature_bytes);
00086 };
00087 
00088 
00089 } // namespace cat
00090 
00091 #endif // CAT_KEY_AGREEMENT_RESPONDER_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