|
|
|
|
|
|
|
|
#include "../CodeDweller/base64codec.hpp" |
|
|
#include "../CodeDweller/base64codec.hpp" |
|
|
// #include "tcp_watchdog.hpp" No longer using TCPWatchdog -- see below _M |
|
|
// #include "tcp_watchdog.hpp" No longer using TCPWatchdog -- see below _M |
|
|
|
|
|
|
|
|
using namespace std; |
|
|
|
|
|
|
|
|
namespace cd = codedweller; |
|
|
|
|
|
|
|
|
///// utilities //////////////////////////////////////////////////////////////// |
|
|
///// utilities //////////////////////////////////////////////////////////////// |
|
|
|
|
|
|
|
|
|
|
|
|
|
|
//-- <msg...> |
|
|
//-- <msg...> |
|
|
|
|
|
|
|
|
XML << "<msg size=\'" << ScanData.ScanSize << "'>" << endl; // Starting with the msg element. |
|
|
XML << "<msg size=\'" << ScanData.ScanSize << "'>" << endl; // Starting with the msg element. |
|
|
to_base64 EncodedMessageData( |
|
|
|
|
|
|
|
|
cd::to_base64 EncodedMessageData( |
|
|
reinterpret_cast<const char*>(MessageBuffer), MessageLength); // Encode the message to base64. |
|
|
reinterpret_cast<const char*>(MessageBuffer), MessageLength); // Encode the message to base64. |
|
|
|
|
|
|
|
|
const int SampleLineLength = 64; // 64 bytes per line is good. |
|
|
const int SampleLineLength = 64; // 64 bytes per line is good. |
|
|
|
|
|
|
|
|
|
|
|
|
|
|
CurrentThreadState(SYNC_Compute_Response); |
|
|
CurrentThreadState(SYNC_Compute_Response); |
|
|
|
|
|
|
|
|
from_base64 DecodedChallenge(Challenge.snf_sync_challenge_txt); // Decode the challenge. |
|
|
|
|
|
|
|
|
cd::from_base64 DecodedChallenge(Challenge.snf_sync_challenge_txt); // Decode the challenge. |
|
|
|
|
|
|
|
|
//--- Prepare the secret. |
|
|
//--- Prepare the secret. |
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
PadBuffer NewPad = OneTimePad(); // Grab a new Pad (default size). |
|
|
PadBuffer NewPad = OneTimePad(); // Grab a new Pad (default size). |
|
|
|
|
|
|
|
|
base64buffer ResponseBin; // With the key now established, |
|
|
|
|
|
|
|
|
cd::base64buffer ResponseBin; // With the key now established, |
|
|
for(unsigned int i = 0; i < NewPad.size(); i++) // encrypt the one time pad for |
|
|
for(unsigned int i = 0; i < NewPad.size(); i++) // encrypt the one time pad for |
|
|
ResponseBin.push_back( // transfer. |
|
|
ResponseBin.push_back( // transfer. |
|
|
ResponseGenerator.Encrypt(NewPad[i])); |
|
|
ResponseGenerator.Encrypt(NewPad[i])); |
|
|
|
|
|
|
|
|
|
|
|
|
|
|
//--- Encode our response as base64 and send it. |
|
|
//--- Encode our response as base64 and send it. |
|
|
|
|
|
|
|
|
to_base64 ResponseTxt(ResponseBin); // Encode the cyphertext as base64. |
|
|
|
|
|
|
|
|
cd::to_base64 ResponseTxt(ResponseBin); // Encode the cyphertext as base64. |
|
|
string ResponseTxtString; // Create a handy string and place |
|
|
string ResponseTxtString; // Create a handy string and place |
|
|
ResponseTxtString.assign(ResponseTxt.begin(), ResponseTxt.end()); // the base 64 text into it. |
|
|
ResponseTxtString.assign(ResponseTxt.begin(), ResponseTxt.end()); // the base 64 text into it. |
|
|
|
|
|
|