|
|
|
|
|
|
|
|
MyRulebase.logThisInfo( // Log our success. |
|
|
MyRulebase.logThisInfo( // Log our success. |
|
|
snfReloadContext, snf_SUCCESS, "Success"); |
|
|
snfReloadContext, snf_SUCCESS, "Success"); |
|
|
} |
|
|
} |
|
|
catch(snf_RulebaseHandler::IgnoreListError) { // If we get an IgnoreListError - say so. |
|
|
|
|
|
|
|
|
catch(const snf_RulebaseHandler::IgnoreListError&) { // If we get an IgnoreListError - say so. |
|
|
MyRulebase.logThisError( |
|
|
MyRulebase.logThisError( |
|
|
snfReloadContext, snf_ERROR_RULE_FILE, "IgnoreListError"); |
|
|
snfReloadContext, snf_ERROR_RULE_FILE, "IgnoreListError"); |
|
|
} |
|
|
} |
|
|
catch(snf_RulebaseHandler::ConfigurationError) { // If we get a ConfigurationError - say so. |
|
|
|
|
|
|
|
|
catch(const snf_RulebaseHandler::ConfigurationError&) { // If we get a ConfigurationError - say so. |
|
|
MyRulebase.logThisError( |
|
|
MyRulebase.logThisError( |
|
|
snfReloadContext, snf_ERROR_RULE_FILE, "ConfigurationError"); |
|
|
snfReloadContext, snf_ERROR_RULE_FILE, "ConfigurationError"); |
|
|
} |
|
|
} |
|
|
catch(snf_RulebaseHandler::FileError x) { // If we get a FileError - say so. |
|
|
|
|
|
|
|
|
catch(const snf_RulebaseHandler::FileError&) { // If we get a FileError - say so. |
|
|
MyRulebase.logThisError( |
|
|
MyRulebase.logThisError( |
|
|
snfReloadContext, snf_ERROR_RULE_FILE, "FileError"); |
|
|
snfReloadContext, snf_ERROR_RULE_FILE, "FileError"); |
|
|
} |
|
|
} |
|
|
catch(snf_RulebaseHandler::AuthenticationError x) { // If we get a Auth Error - say so. |
|
|
|
|
|
|
|
|
catch(const snf_RulebaseHandler::AuthenticationError&) { // If we get a Auth Error - say so. |
|
|
MyRulebase.logThisError( |
|
|
MyRulebase.logThisError( |
|
|
snfReloadContext, snf_ERROR_RULE_AUTH, "AuthError"); |
|
|
snfReloadContext, snf_ERROR_RULE_AUTH, "AuthError"); |
|
|
} |
|
|
} |
|
|
catch(snf_RulebaseHandler::Busy x) { // If we get a Busy Exception - say so. |
|
|
|
|
|
|
|
|
catch(const snf_RulebaseHandler::Busy&) { // If we get a Busy Exception - say so. |
|
|
MyRulebase.logThisError( |
|
|
MyRulebase.logThisError( |
|
|
snfReloadContext, snf_ERROR_UNKNOWN, "BusyError"); |
|
|
snfReloadContext, snf_ERROR_UNKNOWN, "BusyError"); |
|
|
} |
|
|
} |
|
|
catch(snf_RulebaseHandler::Panic x) { // If we get a Panic - say so. |
|
|
|
|
|
|
|
|
catch(const snf_RulebaseHandler::Panic&) { // If we get a Panic - say so. |
|
|
MyRulebase.logThisError( |
|
|
MyRulebase.logThisError( |
|
|
snfReloadContext, snf_ERROR_UNKNOWN, "PanicError"); |
|
|
snfReloadContext, snf_ERROR_UNKNOWN, "PanicError"); |
|
|
} |
|
|
} |
|
|
|
|
|
|
|
|
|
|
|
|
|
|
// FileUTC(FileName) - utility function for tagging the active rulebase |
|
|
// FileUTC(FileName) - utility function for tagging the active rulebase |
|
|
|
|
|
|
|
|
|
|
|
RuntimeCheck GoodTimestampLength("SNFMulti.cpp:FileUTC snprintf(...) != CorrectTimestampLength"); |
|
|
|
|
|
|
|
|
string FileUTC(string FileName) { // Gets a files UTC. |
|
|
string FileUTC(string FileName) { // Gets a files UTC. |
|
|
struct stat FileNameStat; // First we need a stat buffer. |
|
|
struct stat FileNameStat; // First we need a stat buffer. |
|
|
string t; // We also need a Timestamp holder. |
|
|
string t; // We also need a Timestamp holder. |
|
|
if(0 != stat(FileName.c_str(), &FileNameStat)) { // If we can't get the stat we |
|
|
if(0 != stat(FileName.c_str(), &FileNameStat)) { // If we can't get the stat we |
|
|
t.append("000000000000"); return t; // will return 000000000000 to |
|
|
|
|
|
|
|
|
t.append("00000000000000"); return t; // will return all zeroz to |
|
|
} // make sure we should get the file. |
|
|
} // make sure we should get the file. |
|
|
struct tm FileNameTime; // Allocate a time structure. |
|
|
struct tm FileNameTime; // Allocate a time structure. |
|
|
FileNameTime = *(gmtime(&FileNameStat.st_mtime)); // Copy the file time to it as UTC. |
|
|
FileNameTime = *(gmtime(&FileNameStat.st_mtime)); // Copy the file time to it as UTC. |
|
|
|
|
|
|
|
|
char TimestampBfr[20]; // Timestamp buffer. |
|
|
|
|
|
|
|
|
const size_t TimestampBufferSize = 16; |
|
|
|
|
|
char TimestampBfr[TimestampBufferSize]; // Timestamp buffer. |
|
|
|
|
|
|
|
|
sprintf(TimestampBfr,"%04d%02d%02d%02d%02d%02d", // Format yyyymmddhhmmss |
|
|
|
|
|
|
|
|
size_t l = snprintf( // Format yyyymmddhhmmss |
|
|
|
|
|
TimestampBfr, TimestampBufferSize-1, |
|
|
|
|
|
"%04d%02d%02d%02d%02d%02d", |
|
|
FileNameTime.tm_year+1900, |
|
|
FileNameTime.tm_year+1900, |
|
|
FileNameTime.tm_mon+1, |
|
|
FileNameTime.tm_mon+1, |
|
|
FileNameTime.tm_mday, |
|
|
FileNameTime.tm_mday, |
|
|
|
|
|
|
|
|
FileNameTime.tm_sec |
|
|
FileNameTime.tm_sec |
|
|
); |
|
|
); |
|
|
|
|
|
|
|
|
|
|
|
const size_t CorrectTimestampLength = 4+2+2+2+2+2; |
|
|
|
|
|
GoodTimestampLength(l == CorrectTimestampLength); |
|
|
|
|
|
|
|
|
t.append(TimestampBfr); // Append the timestamp to t |
|
|
t.append(TimestampBfr); // Append the timestamp to t |
|
|
return t; // and return it to the caller. |
|
|
return t; // and return it to the caller. |
|
|
} |
|
|
} |
|
|
|
|
|
|
|
|
} |
|
|
} |
|
|
} // If nothing threw, we're golden! |
|
|
} // If nothing threw, we're golden! |
|
|
|
|
|
|
|
|
catch (TokenMatrix::BadFile) { // BadFile translates to FileError |
|
|
|
|
|
|
|
|
catch (const TokenMatrix::BadFile&) { // BadFile translates to FileError |
|
|
throw FileError("_snf_LoadNewRulebase() TokenMatrix::BadFile"); |
|
|
throw FileError("_snf_LoadNewRulebase() TokenMatrix::BadFile"); |
|
|
} |
|
|
} |
|
|
catch (TokenMatrix::BadMatrix) { // BadMatrix translates to AuthenticationError |
|
|
|
|
|
|
|
|
catch (const TokenMatrix::BadMatrix&) { // BadMatrix translates to AuthenticationError |
|
|
throw AuthenticationError("_snf_LoadNewRulebase() TokenMatrix::BadMatrix"); |
|
|
throw AuthenticationError("_snf_LoadNewRulebase() TokenMatrix::BadMatrix"); |
|
|
} |
|
|
} |
|
|
catch (TokenMatrix::BadAllocation) { // BadAllocation translates to AllocationError |
|
|
|
|
|
|
|
|
catch (const TokenMatrix::BadAllocation&) { // BadAllocation translates to AllocationError |
|
|
throw AllocationError("_snf_LoadNewRulebase() TokenMatrix::BadAllocation"); |
|
|
throw AllocationError("_snf_LoadNewRulebase() TokenMatrix::BadAllocation"); |
|
|
} |
|
|
} |
|
|
catch (TokenMatrix::OutOfRange) { // OutOfRange should never happen so PANIC! |
|
|
|
|
|
|
|
|
catch (const TokenMatrix::OutOfRange&) { // OutOfRange should never happen so PANIC! |
|
|
throw Panic("_snf_LoadNewRulebase() TokenMatrix::OutOfRange"); |
|
|
throw Panic("_snf_LoadNewRulebase() TokenMatrix::OutOfRange"); |
|
|
} |
|
|
} |
|
|
catch (exception e) { |
|
|
|
|
|
throw; |
|
|
|
|
|
} |
|
|
|
|
|
catch (...) { // Something unpredicted happens? PANIC! |
|
|
catch (...) { // Something unpredicted happens? PANIC! |
|
|
throw Panic("_snf_LoadNewRulebase() TokenMatrix.load() ???"); |
|
|
throw Panic("_snf_LoadNewRulebase() TokenMatrix.load() ???"); |
|
|
} |
|
|
} |
|
|
|
|
|
|
|
|
MyScanData.FilteredData.clear(); // Clear the FilteredData buffer. |
|
|
MyScanData.FilteredData.clear(); // Clear the FilteredData buffer. |
|
|
try { // Watch for exceptions and scan |
|
|
try { // Watch for exceptions and scan |
|
|
for(int a = 0; a < snf_ScanHorizon; a++) // the message through the filter |
|
|
for(int a = 0; a < snf_ScanHorizon; a++) // the message through the filter |
|
|
MyScanData.FilteredData.push_back(xb=IZ.GetByte()); // chain into the FilteredData buffer. |
|
|
|
|
|
|
|
|
MyScanData.FilteredData.push_back(xb=IZ.GetByte()); // chain into the FilteredData buffer. |
|
|
} // When we run out of data we will |
|
|
} // When we run out of data we will |
|
|
catch(FilterChain::Empty) {} // get the Empty exception and stop. |
|
|
|
|
|
|
|
|
catch(const FilterChain::Empty&) {} // get the Empty exception and stop. |
|
|
|
|
|
|
|
|
// Scan each byte in the file up to the horizon or the end of the message. |
|
|
// Scan each byte in the file up to the horizon or the end of the message. |
|
|
// If something goes wrong, an exception will be thrown. |
|
|
// If something goes wrong, an exception will be thrown. |
|
|
|
|
|
|
|
|
|
|
|
|
|
|
DebugInfo = "scanMessage() Scan Data Complete"; // If we panic, here we are. |
|
|
DebugInfo = "scanMessage() Scan Data Complete"; // If we panic, here we are. |
|
|
} |
|
|
} |
|
|
catch(EvaluationMatrix::BadAllocation) { // Check for bad allocation during scan. |
|
|
|
|
|
|
|
|
catch(const EvaluationMatrix::BadAllocation&) { // Check for bad allocation during scan. |
|
|
throw AllocationError("EvaluationMatrix::BadAllocation"); |
|
|
throw AllocationError("EvaluationMatrix::BadAllocation"); |
|
|
} |
|
|
} |
|
|
catch(EvaluationMatrix::MaxEvalsExceeded) { // Check for too many evaluators. |
|
|
|
|
|
|
|
|
catch(const EvaluationMatrix::MaxEvalsExceeded&) { // Check for too many evaluators. |
|
|
throw MaxEvals("EvaluationMatrix::MaxEvalsExceeded"); |
|
|
throw MaxEvals("EvaluationMatrix::MaxEvalsExceeded"); |
|
|
} |
|
|
} |
|
|
catch(EvaluationMatrix::OutOfRange) { // Check for out of range of (bad) matrix. |
|
|
|
|
|
|
|
|
catch(const EvaluationMatrix::OutOfRange&) { // Check for out of range of (bad) matrix. |
|
|
throw BadMatrix("EvaluationMatrix::OutOfRange"); |
|
|
throw BadMatrix("EvaluationMatrix::OutOfRange"); |
|
|
} |
|
|
} |
|
|
catch(exception& e) { // Some other known exception? |
|
|
|
|
|
throw; // rethrow. |
|
|
|
|
|
} |
|
|
|
|
|
catch(...){ // In order to prevent thread craziness |
|
|
catch(...){ // In order to prevent thread craziness |
|
|
throw Panic(DebugInfo); // throw a Panic. |
|
|
throw Panic(DebugInfo); // throw a Panic. |
|
|
} // The mutex will unlock in the outer try. |
|
|
} // The mutex will unlock in the outer try. |