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::OnNotificationSentToAllUsers.connect(bind(&ServiceDbObject::AddNotificationHistory, _1, _2, _3, _4, _5, _6));
|
||||||
|
|
||||||
Service::OnStateChange.connect(boost::bind(&ServiceDbObject::AddStateChangeHistory, _1, _2, _3));
|
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)
|
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);
|
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
|
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.
|
* A Service database object.
|
||||||
*
|
*
|
||||||
|
@ -61,8 +85,9 @@ private:
|
||||||
static void AddDowntimes(const Service::Ptr& service);
|
static void AddDowntimes(const Service::Ptr& service);
|
||||||
static void RemoveDowntimes(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 AddComment(const Service::Ptr& service, const Dictionary::Ptr& comment);
|
||||||
static void RemoveComment(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 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 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