mirror of https://github.com/Icinga/icinga2.git
parent
2d49e3f8e1
commit
1827e25d7a
|
@ -54,6 +54,12 @@ void ServiceDbObject::StaticInitialize(void)
|
|||
Service::OnNotificationSentToAllUsers.connect(bind(&ServiceDbObject::AddNotificationHistory, _1, _2, _3, _4, _5, _6));
|
||||
|
||||
Service::OnStateChange.connect(boost::bind(&ServiceDbObject::AddStateChangeHistory, _1, _2, _3));
|
||||
|
||||
Service::OnNewCheckResult.connect(bind(&ServiceDbObject::AddCheckResultLogHistory, _1, _2));
|
||||
Service::OnNotificationSentToUser.connect(bind(&ServiceDbObject::AddNotificationSentLogHistory, _1, _2, _3, _4, _5, _6));
|
||||
Service::OnFlappingChanged.connect(bind(&ServiceDbObject::AddFlappingLogHistory, _1, _2));
|
||||
Service::OnDowntimeTriggered.connect(boost::bind(&ServiceDbObject::AddTriggerDowntimeLogHistory, _1, _2));
|
||||
Service::OnDowntimeRemoved.connect(boost::bind(&ServiceDbObject::AddRemoveDowntimeLogHistory, _1, _2));
|
||||
}
|
||||
|
||||
ServiceDbObject::ServiceDbObject(const DbType::Ptr& type, const String& name1, const String& name2)
|
||||
|
@ -856,3 +862,322 @@ void ServiceDbObject::AddStateChangeHistory(const Service::Ptr& service, const D
|
|||
OnQuery(query1);
|
||||
}
|
||||
}
|
||||
|
||||
void ServiceDbObject::AddCheckResultLogHistory(const Service::Ptr& service, const Dictionary::Ptr &cr)
|
||||
{
|
||||
Host::Ptr host = service->GetHost();
|
||||
|
||||
if (!host)
|
||||
return;
|
||||
|
||||
Dictionary::Ptr vars_after = cr->Get("vars_after");
|
||||
|
||||
long state_after = vars_after->Get("state");
|
||||
long stateType_after = vars_after->Get("state_type");
|
||||
long attempt_after = vars_after->Get("attempt");
|
||||
bool reachable_after = vars_after->Get("reachable");
|
||||
bool host_reachable_after = vars_after->Get("host_reachable");
|
||||
|
||||
Dictionary::Ptr vars_before = cr->Get("vars_before");
|
||||
|
||||
if (vars_before) {
|
||||
long state_before = vars_before->Get("state");
|
||||
long stateType_before = vars_before->Get("state_type");
|
||||
long attempt_before = vars_before->Get("attempt");
|
||||
bool reachable_before = vars_before->Get("reachable");
|
||||
|
||||
if (state_before == state_after && stateType_before == stateType_after &&
|
||||
attempt_before == attempt_after && reachable_before == reachable_after)
|
||||
return; /* Nothing changed, ignore this checkresult. */
|
||||
}
|
||||
|
||||
LogEntryType type;
|
||||
switch (service->GetState()) {
|
||||
case StateOK:
|
||||
type = LogEntryTypeServiceOk;
|
||||
break;
|
||||
case StateUnknown:
|
||||
type = LogEntryTypeServiceUnknown;
|
||||
break;
|
||||
case StateWarning:
|
||||
type = LogEntryTypeServiceWarning;
|
||||
break;
|
||||
case StateCritical:
|
||||
type = LogEntryTypeServiceCritical;
|
||||
break;
|
||||
default:
|
||||
Log(LogCritical, "db_ido", "Unknown service state: " + Convert::ToString(state_after));
|
||||
return;
|
||||
}
|
||||
|
||||
String output;
|
||||
|
||||
if (cr) {
|
||||
Dictionary::Ptr output_bag = CompatUtility::GetCheckResultOutput(cr);
|
||||
output = output_bag->Get("output");
|
||||
}
|
||||
|
||||
std::ostringstream msgbuf;
|
||||
msgbuf << "SERVICE ALERT: "
|
||||
<< host->GetName() << ";"
|
||||
<< service->GetShortName() << ";"
|
||||
<< Service::StateToString(static_cast<ServiceState>(state_after)) << ";"
|
||||
<< Service::StateTypeToString(static_cast<StateType>(stateType_after)) << ";"
|
||||
<< attempt_after << ";"
|
||||
<< output << ""
|
||||
<< "";
|
||||
|
||||
AddLogHistory(service, msgbuf.str(), type);
|
||||
|
||||
if (service == host->GetCheckService()) {
|
||||
std::ostringstream msgbuf;
|
||||
msgbuf << "HOST ALERT: "
|
||||
<< host->GetName() << ";"
|
||||
<< Host::StateToString(Host::CalculateState(static_cast<ServiceState>(state_after), host_reachable_after)) << ";"
|
||||
<< Service::StateTypeToString(static_cast<StateType>(stateType_after)) << ";"
|
||||
<< attempt_after << ";"
|
||||
<< output << ""
|
||||
<< "";
|
||||
|
||||
switch (host->GetState()) {
|
||||
case HostUp:
|
||||
type = LogEntryTypeHostUp;
|
||||
break;
|
||||
case HostDown:
|
||||
type = LogEntryTypeHostDown;
|
||||
break;
|
||||
case HostUnreachable:
|
||||
type = LogEntryTypeHostUnreachable;
|
||||
break;
|
||||
default:
|
||||
Log(LogCritical, "db_ido", "Unknown host state: " + Convert::ToString(state_after));
|
||||
return;
|
||||
}
|
||||
|
||||
AddLogHistory(service, msgbuf.str(), type);
|
||||
}
|
||||
}
|
||||
|
||||
void ServiceDbObject::AddTriggerDowntimeLogHistory(const Service::Ptr& service, const Dictionary::Ptr& downtime)
|
||||
{
|
||||
Host::Ptr host = service->GetHost();
|
||||
|
||||
if (!host)
|
||||
return;
|
||||
|
||||
if (!downtime)
|
||||
return;
|
||||
|
||||
std::ostringstream msgbuf;
|
||||
msgbuf << "SERVICE DOWNTIME ALERT: "
|
||||
<< host->GetName() << ";"
|
||||
<< service->GetShortName() << ";"
|
||||
<< "STARTED" << "; "
|
||||
<< "Service has entered a period of scheduled downtime."
|
||||
<< "";
|
||||
|
||||
AddLogHistory(service, msgbuf.str(), LogEntryTypeInfoMessage);
|
||||
|
||||
if (service == host->GetCheckService()) {
|
||||
std::ostringstream msgbuf;
|
||||
msgbuf << "HOST DOWNTIME ALERT: "
|
||||
<< host->GetName() << ";"
|
||||
<< "STARTED" << "; "
|
||||
<< "Service has entered a period of scheduled downtime."
|
||||
<< "";
|
||||
|
||||
AddLogHistory(service, msgbuf.str(), LogEntryTypeInfoMessage);
|
||||
}
|
||||
}
|
||||
|
||||
void ServiceDbObject::AddRemoveDowntimeLogHistory(const Service::Ptr& service, const Dictionary::Ptr& downtime)
|
||||
{
|
||||
Host::Ptr host = service->GetHost();
|
||||
|
||||
if (!host)
|
||||
return;
|
||||
|
||||
if (!downtime)
|
||||
return;
|
||||
|
||||
String downtime_output;
|
||||
String downtime_state_str;
|
||||
|
||||
if (downtime->Get("was_cancelled") == true) {
|
||||
downtime_output = "Scheduled downtime for service has been cancelled.";
|
||||
downtime_state_str = "CANCELLED";
|
||||
} else {
|
||||
downtime_output = "Service has exited from a period of scheduled downtime.";
|
||||
downtime_state_str = "STOPPED";
|
||||
}
|
||||
|
||||
std::ostringstream msgbuf;
|
||||
msgbuf << "SERVICE DOWNTIME ALERT: "
|
||||
<< host->GetName() << ";"
|
||||
<< service->GetShortName() << ";"
|
||||
<< downtime_state_str << "; "
|
||||
<< downtime_output
|
||||
<< "";
|
||||
|
||||
AddLogHistory(service, msgbuf.str(), LogEntryTypeInfoMessage);
|
||||
|
||||
if (service == host->GetCheckService()) {
|
||||
std::ostringstream msgbuf;
|
||||
msgbuf << "HOST DOWNTIME ALERT: "
|
||||
<< host->GetName() << ";"
|
||||
<< downtime_state_str << "; "
|
||||
<< downtime_output
|
||||
<< "";
|
||||
|
||||
AddLogHistory(service, msgbuf.str(), LogEntryTypeInfoMessage);
|
||||
}
|
||||
}
|
||||
|
||||
void ServiceDbObject::AddNotificationSentLogHistory(const Service::Ptr& service, const User::Ptr& user,
|
||||
NotificationType const& notification_type, Dictionary::Ptr const& cr,
|
||||
const String& author, const String& comment_text)
|
||||
{
|
||||
Host::Ptr host = service->GetHost();
|
||||
|
||||
if (!host)
|
||||
return;
|
||||
|
||||
CheckCommand::Ptr commandObj = service->GetCheckCommand();
|
||||
|
||||
String check_command = "";
|
||||
if (commandObj)
|
||||
check_command = commandObj->GetName();
|
||||
|
||||
String notification_type_str = Notification::NotificationTypeToString(notification_type);
|
||||
|
||||
String author_comment = "";
|
||||
if (notification_type == NotificationCustom || notification_type == NotificationAcknowledgement) {
|
||||
author_comment = ";" + author + ";" + comment_text;
|
||||
}
|
||||
|
||||
if (!cr)
|
||||
return;
|
||||
|
||||
String output;
|
||||
|
||||
if (cr) {
|
||||
Dictionary::Ptr output_bag = CompatUtility::GetCheckResultOutput(cr);
|
||||
output = output_bag->Get("output");
|
||||
}
|
||||
|
||||
std::ostringstream msgbuf;
|
||||
msgbuf << "SERVICE NOTIFICATION: "
|
||||
<< user->GetName() << ";"
|
||||
<< host->GetName() << ";"
|
||||
<< service->GetShortName() << ";"
|
||||
<< notification_type_str << " "
|
||||
<< "(" << Service::StateToString(service->GetState()) << ");"
|
||||
<< check_command << ";"
|
||||
<< output << author_comment
|
||||
<< "";
|
||||
|
||||
AddLogHistory(service, msgbuf.str(), LogEntryTypeServiceNotification);
|
||||
|
||||
if (service == host->GetCheckService()) {
|
||||
std::ostringstream msgbuf;
|
||||
msgbuf << "HOST NOTIFICATION: "
|
||||
<< user->GetName() << ";"
|
||||
<< host->GetName() << ";"
|
||||
<< notification_type_str << " "
|
||||
<< "(" << Service::StateToString(service->GetState()) << ");"
|
||||
<< check_command << ";"
|
||||
<< output << author_comment
|
||||
<< "";
|
||||
|
||||
AddLogHistory(service, msgbuf.str(), LogEntryTypeHostNotification);
|
||||
}
|
||||
}
|
||||
|
||||
void ServiceDbObject::AddFlappingLogHistory(const Service::Ptr& service, FlappingState flapping_state)
|
||||
{
|
||||
Host::Ptr host = service->GetHost();
|
||||
|
||||
if (!host)
|
||||
return;
|
||||
|
||||
String flapping_state_str;
|
||||
String flapping_output;
|
||||
|
||||
switch (flapping_state) {
|
||||
case FlappingStarted:
|
||||
flapping_output = "Service appears to have started flapping (" + Convert::ToString(service->GetFlappingCurrent()) + "% change >= " + Convert::ToString(service->GetFlappingThreshold()) + "% threshold)";
|
||||
flapping_state_str = "STARTED";
|
||||
break;
|
||||
case FlappingStopped:
|
||||
flapping_output = "Service appears to have stopped flapping (" + Convert::ToString(service->GetFlappingCurrent()) + "% change < " + Convert::ToString(service->GetFlappingThreshold()) + "% threshold)";
|
||||
flapping_state_str = "STOPPED";
|
||||
break;
|
||||
case FlappingDisabled:
|
||||
flapping_output = "Flap detection has been disabled";
|
||||
flapping_state_str = "DISABLED";
|
||||
break;
|
||||
default:
|
||||
Log(LogCritical, "db_ido", "Unknown flapping state: " + Convert::ToString(flapping_state));
|
||||
return;
|
||||
}
|
||||
|
||||
std::ostringstream msgbuf;
|
||||
msgbuf << "SERVICE FLAPPING ALERT: "
|
||||
<< host->GetName() << ";"
|
||||
<< service->GetShortName() << ";"
|
||||
<< flapping_state_str << "; "
|
||||
<< flapping_output
|
||||
<< "";
|
||||
|
||||
AddLogHistory(service, msgbuf.str(), LogEntryTypeInfoMessage);
|
||||
|
||||
if (service == host->GetCheckService()) {
|
||||
std::ostringstream msgbuf;
|
||||
msgbuf << "HOST FLAPPING ALERT: "
|
||||
<< host->GetName() << ";"
|
||||
<< flapping_state_str << "; "
|
||||
<< flapping_output
|
||||
<< "";
|
||||
|
||||
AddLogHistory(service, msgbuf.str(), LogEntryTypeInfoMessage);
|
||||
}
|
||||
}
|
||||
|
||||
void ServiceDbObject::AddLogHistory(const Service::Ptr& service, String buffer, LogEntryType type)
|
||||
{
|
||||
Host::Ptr host = service->GetHost();
|
||||
|
||||
if (!host)
|
||||
return;
|
||||
|
||||
Log(LogDebug, "db_ido", "add log entry for '" + service->GetName() + "'");
|
||||
|
||||
double now = Utility::GetTime();
|
||||
unsigned long entry_time = static_cast<long>(now);
|
||||
unsigned long entry_time_usec = (now - entry_time) * 1000 * 1000;
|
||||
|
||||
DbQuery query1;
|
||||
query1.Table = "logentries";
|
||||
query1.Type = DbQueryInsert;
|
||||
|
||||
Dictionary::Ptr fields1 = boost::make_shared<Dictionary>();
|
||||
fields1->Set("logentry_time", DbValue::FromTimestamp(entry_time));
|
||||
fields1->Set("entry_time", DbValue::FromTimestamp(entry_time));
|
||||
fields1->Set("entry_time_usec", entry_time_usec);
|
||||
//fields1->Set("object_id", service); // not supported in 1.x see #4754
|
||||
fields1->Set("logentry_type", type);
|
||||
fields1->Set("logentry_data", buffer);
|
||||
|
||||
fields1->Set("instance_id", 0); /* DbConnection class fills in real ID */
|
||||
|
||||
query1.Fields = fields1;
|
||||
OnQuery(query1);
|
||||
|
||||
/*
|
||||
if (host->GetCheckService() == service) {
|
||||
//fields1->Set("object_id", host); // not supported in 1.x see #4754
|
||||
query1.Fields = fields1;
|
||||
OnQuery(query1);
|
||||
}
|
||||
*/
|
||||
}
|
||||
|
|
|
@ -27,6 +27,30 @@
|
|||
namespace icinga
|
||||
{
|
||||
|
||||
enum LogEntryType
|
||||
{
|
||||
LogEntryTypeRuntimeError = 1,
|
||||
LogEntryTypeRuntimeWarning = 2,
|
||||
LogEntryTypeVerificationError = 4,
|
||||
LogEntryTypeVerificationWarning = 8,
|
||||
LogEntryTypeConfigError = 16,
|
||||
LogEntryTypeConfigWarning = 32,
|
||||
LogEntryTypeProcessInfo = 64,
|
||||
LogEntryTypeEventHandler = 128,
|
||||
LogEntryTypeExternalCommand = 512,
|
||||
LogEntryTypeHostUp = 1024,
|
||||
LogEntryTypeHostDown = 2048,
|
||||
LogEntryTypeHostUnreachable = 4096,
|
||||
LogEntryTypeServiceOk = 8192,
|
||||
LogEntryTypeServiceUnknown = 16384,
|
||||
LogEntryTypeServiceWarning = 32768,
|
||||
LogEntryTypeServiceCritical = 65536,
|
||||
LogEntryTypePassiveCheck = 1231072,
|
||||
LogEntryTypeInfoMessage = 262144,
|
||||
LogEntryTypeHostNotification = 524288,
|
||||
LogEntryTypeServiceNotification = 1048576
|
||||
};
|
||||
|
||||
/**
|
||||
* A Service database object.
|
||||
*
|
||||
|
@ -61,8 +85,9 @@ private:
|
|||
static void AddDowntimes(const Service::Ptr& service);
|
||||
static void RemoveDowntimes(const Service::Ptr& service);
|
||||
|
||||
/* Status */
|
||||
static void AddLogHistory(const Service::Ptr& service, String buffer, LogEntryType type);
|
||||
|
||||
/* Status */
|
||||
static void AddComment(const Service::Ptr& service, const Dictionary::Ptr& comment);
|
||||
static void RemoveComment(const Service::Ptr& service, const Dictionary::Ptr& comment);
|
||||
|
||||
|
@ -77,6 +102,11 @@ private:
|
|||
static void AddNotificationHistory(const Service::Ptr& service, const std::set<User::Ptr>& users, NotificationType type, const Dictionary::Ptr& cr, const String& author, const String& text);
|
||||
static void AddStateChangeHistory(const Service::Ptr& service, const Dictionary::Ptr& cr, StateType type);
|
||||
|
||||
static void AddCheckResultLogHistory(const Service::Ptr& service, const Dictionary::Ptr &cr);
|
||||
static void AddTriggerDowntimeLogHistory(const Service::Ptr& service, const Dictionary::Ptr& downtime);
|
||||
static void AddRemoveDowntimeLogHistory(const Service::Ptr& service, const Dictionary::Ptr& downtime);
|
||||
static void AddNotificationSentLogHistory(const Service::Ptr& service, const User::Ptr& user, NotificationType const& notification_type, Dictionary::Ptr const& cr, const String& author, const String& comment_text);
|
||||
static void AddFlappingLogHistory(const Service::Ptr& service, FlappingState flapping_state);
|
||||
};
|
||||
|
||||
}
|
||||
|
|
Loading…
Reference in New Issue