#include using std::string; #include "zeek-config.h" #include "RuleAction.h" #include "RuleMatcher.h" #include "Conn.h" #include "Event.h" #include "NetVar.h" #include "analyzer/protocol/pia/PIA.h" #include "analyzer/Manager.h" void RuleActionEvent::DoAction(const Rule* parent, RuleEndpointState* state, const u_char* data, int len) { if ( signature_match ) { mgr.QueueEventFast(signature_match, { rule_matcher->BuildRuleStateValue(parent, state), new StringVal(msg), data ? new StringVal(len, (const char*)data) : val_mgr->GetEmptyString(), }); } } void RuleActionEvent::PrintDebug() { fprintf(stderr, " RuleActionEvent: |%s|\n", msg); } void RuleActionMIME::PrintDebug() { fprintf(stderr, " RuleActionMIME: |%s|\n", mime); } RuleActionAnalyzer::RuleActionAnalyzer(const char* arg_analyzer) { string str(arg_analyzer); string::size_type pos = str.find(':'); string arg = str.substr(0, pos); analyzer = analyzer_mgr->GetComponentTag(arg.c_str()); if ( ! analyzer ) reporter->Warning("unknown analyzer '%s' specified in rule", arg.c_str()); if ( pos != string::npos ) { arg = str.substr(pos + 1); child_analyzer = analyzer_mgr->GetComponentTag(arg.c_str()); if ( ! child_analyzer ) reporter->Warning("unknown analyzer '%s' specified in rule", arg.c_str()); } else child_analyzer = analyzer::Tag(); } void RuleActionAnalyzer::PrintDebug() { if ( ! child_analyzer ) fprintf(stderr, "|%s|\n", analyzer_mgr->GetComponentName(analyzer).c_str()); else fprintf(stderr, "|%s:%s|\n", analyzer_mgr->GetComponentName(analyzer).c_str(), analyzer_mgr->GetComponentName(child_analyzer).c_str()); } void RuleActionEnable::DoAction(const Rule* parent, RuleEndpointState* state, const u_char* data, int len) { if ( ! ChildAnalyzer() ) { if ( ! analyzer_mgr->IsEnabled(Analyzer()) ) return; if ( state->PIA() ) state->PIA()->ActivateAnalyzer(Analyzer(), parent); } else { if ( ! analyzer_mgr->IsEnabled(ChildAnalyzer()) ) return; // This is ugly and works only if there exists only one // analyzer of each type. state->PIA()->AsAnalyzer()->Conn()->FindAnalyzer(Analyzer()) ->AddChildAnalyzer(ChildAnalyzer()); } } void RuleActionEnable::PrintDebug() { fprintf(stderr, " RuleActionEnable: "); RuleActionAnalyzer::PrintDebug(); } void RuleActionDisable::DoAction(const Rule* parent, RuleEndpointState* state, const u_char* data, int len) { if ( ! ChildAnalyzer() ) { if ( state->PIA() ) state->PIA()->DeactivateAnalyzer(Analyzer()); } else state->GetAnalyzer()->AddChildAnalyzer( state->GetAnalyzer()->FindChild(ChildAnalyzer())); } void RuleActionDisable::PrintDebug() { fprintf(stderr, " RuleActionDisable: "); RuleActionAnalyzer::PrintDebug(); }