Implement class for service comments.

Refs #5039
This commit is contained in:
Gunnar Beutner 2013-11-09 21:19:52 +01:00
parent 17834e0a77
commit cb526ddccc
14 changed files with 208 additions and 123 deletions

View File

@ -831,7 +831,7 @@ void ClusterListener::EnableFlappingChangedHandler(const Service::Ptr& service,
AsyncRelayMessage(Endpoint::Ptr(), message, true); AsyncRelayMessage(Endpoint::Ptr(), message, true);
} }
void ClusterListener::CommentAddedHandler(const Service::Ptr& service, const Dictionary::Ptr& comment, const String& authority) void ClusterListener::CommentAddedHandler(const Service::Ptr& service, const Comment::Ptr& comment, const String& authority)
{ {
if (!authority.IsEmpty() && authority != GetIdentity()) if (!authority.IsEmpty() && authority != GetIdentity())
return; return;
@ -850,14 +850,14 @@ void ClusterListener::CommentAddedHandler(const Service::Ptr& service, const Dic
AsyncRelayMessage(Endpoint::Ptr(), message, true); AsyncRelayMessage(Endpoint::Ptr(), message, true);
} }
void ClusterListener::CommentRemovedHandler(const Service::Ptr& service, const Dictionary::Ptr& comment, const String& authority) void ClusterListener::CommentRemovedHandler(const Service::Ptr& service, const Comment::Ptr& comment, const String& authority)
{ {
if (!authority.IsEmpty() && authority != GetIdentity()) if (!authority.IsEmpty() && authority != GetIdentity())
return; return;
Dictionary::Ptr params = make_shared<Dictionary>(); Dictionary::Ptr params = make_shared<Dictionary>();
params->Set("service", service->GetName()); params->Set("service", service->GetName());
params->Set("id", comment->Get("id")); params->Set("id", comment->GetId());
Dictionary::Ptr message = make_shared<Dictionary>(); Dictionary::Ptr message = make_shared<Dictionary>();
message->Set("jsonrpc", "2.0"); message->Set("jsonrpc", "2.0");
@ -1206,11 +1206,10 @@ void ClusterListener::MessageHandler(const Endpoint::Ptr& sender, const Dictiona
return; return;
} }
Dictionary::Ptr comment = params->Get("comment"); Comment::Ptr comment = params->Get("comment");
long type = static_cast<long>(comment->Get("entry_type")); service->AddComment(comment->GetEntryType(), comment->GetAuthor(),
service->AddComment(static_cast<CommentType>(type), comment->Get("author"), comment->GetText(), comment->GetExpireTime(), comment->GetId(), sender->GetName());
comment->Get("text"), comment->Get("expire_time"), comment->Get("id"), sender->GetName());
AsyncRelayMessage(sender, message, true); AsyncRelayMessage(sender, message, true);
} else if (message->Get("method") == "cluster::RemoveComment") { } else if (message->Get("method") == "cluster::RemoveComment") {

View File

@ -92,8 +92,8 @@ private:
void EnablePassiveChecksChangedHandler(const Service::Ptr& service, bool enabled, const String& authority); void EnablePassiveChecksChangedHandler(const Service::Ptr& service, bool enabled, const String& authority);
void EnableNotificationsChangedHandler(const Service::Ptr& service, bool enabled, const String& authority); void EnableNotificationsChangedHandler(const Service::Ptr& service, bool enabled, const String& authority);
void EnableFlappingChangedHandler(const Service::Ptr& service, bool enabled, const String& authority); void EnableFlappingChangedHandler(const Service::Ptr& service, bool enabled, const String& authority);
void CommentAddedHandler(const Service::Ptr& service, const Dictionary::Ptr& comment, const String& authority); void CommentAddedHandler(const Service::Ptr& service, const Comment::Ptr& comment, const String& authority);
void CommentRemovedHandler(const Service::Ptr& service, const Dictionary::Ptr& comment, const String& authority); void CommentRemovedHandler(const Service::Ptr& service, const Comment::Ptr& comment, const String& authority);
void DowntimeAddedHandler(const Service::Ptr& service, const Dictionary::Ptr& downtime, const String& authority); void DowntimeAddedHandler(const Service::Ptr& service, const Dictionary::Ptr& downtime, const String& authority);
void DowntimeRemovedHandler(const Service::Ptr& service, const Dictionary::Ptr& downtime, const String& authority); void DowntimeRemovedHandler(const Service::Ptr& service, const Dictionary::Ptr& downtime, const String& authority);
void AcknowledgementSetHandler(const Service::Ptr& service, const String& author, const String& comment, AcknowledgementType type, double expiry, const String& authority); void AcknowledgementSetHandler(const Service::Ptr& service, const String& author, const String& comment, AcknowledgementType type, double expiry, const String& authority);

View File

@ -76,7 +76,7 @@ void StatusDataWriter::DumpComments(std::ostream& fp, const Service::Ptr& owner,
ObjectLock olock(comments); ObjectLock olock(comments);
String id; String id;
Dictionary::Ptr comment; Comment::Ptr comment;
BOOST_FOREACH(boost::tie(id, comment), comments) { BOOST_FOREACH(boost::tie(id, comment), comments) {
if (Service::IsCommentExpired(comment)) if (Service::IsCommentExpired(comment))
continue; continue;
@ -88,14 +88,14 @@ void StatusDataWriter::DumpComments(std::ostream& fp, const Service::Ptr& owner,
<< "\t" << "service_description=" << owner->GetShortName() << "\n"; << "\t" << "service_description=" << owner->GetShortName() << "\n";
fp << "\t" << "host_name=" << host->GetName() << "\n" fp << "\t" << "host_name=" << host->GetName() << "\n"
<< "\t" << "comment_id=" << static_cast<String>(comment->Get("legacy_id")) << "\n" << "\t" << "comment_id=" << comment->GetLegacyId() << "\n"
<< "\t" << "entry_time=" << static_cast<double>(comment->Get("entry_time")) << "\n" << "\t" << "entry_time=" << comment->GetEntryTime() << "\n"
<< "\t" << "entry_type=" << static_cast<long>(comment->Get("entry_type")) << "\n" << "\t" << "entry_type=" << comment->GetEntryType() << "\n"
<< "\t" << "persistent=" << 1 << "\n" << "\t" << "persistent=" << 1 << "\n"
<< "\t" << "author=" << static_cast<String>(comment->Get("author")) << "\n" << "\t" << "author=" << comment->GetAuthor() << "\n"
<< "\t" << "comment_data=" << static_cast<String>(comment->Get("text")) << "\n" << "\t" << "comment_data=" << comment->GetText() << "\n"
<< "\t" << "expires=" << (static_cast<double>(comment->Get("expire_time")) != 0 ? 1 : 0) << "\n" << "\t" << "expires=" << (comment->GetExpireTime() != 0 ? 1 : 0) << "\n"
<< "\t" << "expire_time=" << static_cast<double>(comment->Get("expire_time")) << "\n" << "\t" << "expire_time=" << comment->GetExpireTime() << "\n"
<< "\t" << "}" << "\n" << "\t" << "}" << "\n"
<< "\n"; << "\n";
} }

View File

@ -78,42 +78,42 @@ Object::Ptr CommentsTable::ServiceAccessor(const Value& row, const Column::Objec
Value CommentsTable::AuthorAccessor(const Value& row) Value CommentsTable::AuthorAccessor(const Value& row)
{ {
Dictionary::Ptr comment = Service::GetCommentByID(row); Comment::Ptr comment = Service::GetCommentByID(row);
if (!comment) if (!comment)
return Empty; return Empty;
return comment->Get("author"); return comment->GetAuthor();
} }
Value CommentsTable::CommentAccessor(const Value& row) Value CommentsTable::CommentAccessor(const Value& row)
{ {
Dictionary::Ptr comment = Service::GetCommentByID(row); Comment::Ptr comment = Service::GetCommentByID(row);
if (!comment) if (!comment)
return Empty; return Empty;
return comment->Get("text"); return comment->GetText();
} }
Value CommentsTable::IdAccessor(const Value& row) Value CommentsTable::IdAccessor(const Value& row)
{ {
Dictionary::Ptr comment = Service::GetCommentByID(row); Comment::Ptr comment = Service::GetCommentByID(row);
if (!comment) if (!comment)
return Empty; return Empty;
return comment->Get("legacy_id"); return comment->GetLegacyId();
} }
Value CommentsTable::EntryTimeAccessor(const Value& row) Value CommentsTable::EntryTimeAccessor(const Value& row)
{ {
Dictionary::Ptr comment = Service::GetCommentByID(row); Comment::Ptr comment = Service::GetCommentByID(row);
if (!comment) if (!comment)
return Empty; return Empty;
return static_cast<int>(comment->Get("entry_time")); return static_cast<int>(comment->GetEntryTime());
} }
Value CommentsTable::TypeAccessor(const Value& row) Value CommentsTable::TypeAccessor(const Value& row)
@ -138,30 +138,30 @@ Value CommentsTable::IsServiceAccessor(const Value& row)
Value CommentsTable::EntryTypeAccessor(const Value& row) Value CommentsTable::EntryTypeAccessor(const Value& row)
{ {
Dictionary::Ptr comment = Service::GetCommentByID(row); Comment::Ptr comment = Service::GetCommentByID(row);
if (!comment) if (!comment)
return Empty; return Empty;
return comment->Get("entry_type"); return comment->GetEntryType();
} }
Value CommentsTable::ExpiresAccessor(const Value& row) Value CommentsTable::ExpiresAccessor(const Value& row)
{ {
Dictionary::Ptr comment = Service::GetCommentByID(row); Comment::Ptr comment = Service::GetCommentByID(row);
if (!comment) if (!comment)
return Empty; return Empty;
return comment->Get("expires"); return comment->GetExpireTime() != 0;
} }
Value CommentsTable::ExpireTimeAccessor(const Value& row) Value CommentsTable::ExpireTimeAccessor(const Value& row)
{ {
Dictionary::Ptr comment = Service::GetCommentByID(row); Comment::Ptr comment = Service::GetCommentByID(row);
if (!comment) if (!comment)
return Empty; return Empty;
return static_cast<int>(comment->Get("expire_time")); return static_cast<int>(comment->GetExpireTime());
} }

View File

@ -1493,7 +1493,7 @@ Value HostsTable::CommentsAccessor(const Value& row)
ObjectLock olock(comments); ObjectLock olock(comments);
String id; String id;
Dictionary::Ptr comment; Comment::Ptr comment;
BOOST_FOREACH(boost::tie(id, comment), comments) { BOOST_FOREACH(boost::tie(id, comment), comments) {
if (!comment) if (!comment)
@ -1502,7 +1502,7 @@ Value HostsTable::CommentsAccessor(const Value& row)
if (Service::IsCommentExpired(comment)) if (Service::IsCommentExpired(comment))
continue; continue;
ids->Add(comment->Get("legacy_id")); ids->Add(comment->GetLegacyId());
} }
return ids; return ids;
@ -1528,7 +1528,7 @@ Value HostsTable::CommentsWithInfoAccessor(const Value& row)
ObjectLock olock(comments); ObjectLock olock(comments);
String id; String id;
Dictionary::Ptr comment; Comment::Ptr comment;
BOOST_FOREACH(boost::tie(id, comment), comments) { BOOST_FOREACH(boost::tie(id, comment), comments) {
if (!comment) if (!comment)
@ -1538,9 +1538,9 @@ Value HostsTable::CommentsWithInfoAccessor(const Value& row)
continue; continue;
Array::Ptr comment_info = make_shared<Array>(); Array::Ptr comment_info = make_shared<Array>();
comment_info->Add(comment->Get("legacy_id")); comment_info->Add(comment->GetLegacyId());
comment_info->Add(comment->Get("author")); comment_info->Add(comment->GetAuthor());
comment_info->Add(comment->Get("text")); comment_info->Add(comment->GetText());
ids->Add(comment_info); ids->Add(comment_info);
} }
@ -1567,7 +1567,7 @@ Value HostsTable::CommentsWithExtraInfoAccessor(const Value& row)
ObjectLock olock(comments); ObjectLock olock(comments);
String id; String id;
Dictionary::Ptr comment; Comment::Ptr comment;
BOOST_FOREACH(boost::tie(id, comment), comments) { BOOST_FOREACH(boost::tie(id, comment), comments) {
if (!comment) if (!comment)
@ -1577,11 +1577,11 @@ Value HostsTable::CommentsWithExtraInfoAccessor(const Value& row)
continue; continue;
Array::Ptr comment_info = make_shared<Array>(); Array::Ptr comment_info = make_shared<Array>();
comment_info->Add(comment->Get("legacy_id")); comment_info->Add(comment->GetLegacyId());
comment_info->Add(comment->Get("author")); comment_info->Add(comment->GetAuthor());
comment_info->Add(comment->Get("text")); comment_info->Add(comment->GetText());
comment_info->Add(comment->Get("entry_type")); comment_info->Add(comment->GetEntryType());
comment_info->Add(static_cast<int>(comment->Get("entry_time"))); comment_info->Add(static_cast<int>(comment->GetEntryTime()));
ids->Add(comment_info); ids->Add(comment_info);
} }

View File

@ -1106,7 +1106,7 @@ Value ServicesTable::CommentsAccessor(const Value& row)
ObjectLock olock(comments); ObjectLock olock(comments);
String id; String id;
Dictionary::Ptr comment; Comment::Ptr comment;
BOOST_FOREACH(boost::tie(id, comment), comments) { BOOST_FOREACH(boost::tie(id, comment), comments) {
if (!comment) if (!comment)
@ -1115,7 +1115,7 @@ Value ServicesTable::CommentsAccessor(const Value& row)
if (Service::IsCommentExpired(comment)) if (Service::IsCommentExpired(comment))
continue; continue;
ids->Add(comment->Get("legacy_id")); ids->Add(comment->GetLegacyId());
} }
return ids; return ids;
@ -1135,7 +1135,7 @@ Value ServicesTable::CommentsWithInfoAccessor(const Value& row)
ObjectLock olock(comments); ObjectLock olock(comments);
String id; String id;
Dictionary::Ptr comment; Comment::Ptr comment;
BOOST_FOREACH(boost::tie(id, comment), comments) { BOOST_FOREACH(boost::tie(id, comment), comments) {
if (!comment) if (!comment)
@ -1145,9 +1145,9 @@ Value ServicesTable::CommentsWithInfoAccessor(const Value& row)
continue; continue;
Array::Ptr comment_info = make_shared<Array>(); Array::Ptr comment_info = make_shared<Array>();
comment_info->Add(comment->Get("legacy_id")); comment_info->Add(comment->GetLegacyId());
comment_info->Add(comment->Get("author")); comment_info->Add(comment->GetAuthor());
comment_info->Add(comment->Get("text")); comment_info->Add(comment->GetText());
ids->Add(comment_info); ids->Add(comment_info);
} }
@ -1168,7 +1168,7 @@ Value ServicesTable::CommentsWithExtraInfoAccessor(const Value& row)
ObjectLock olock(comments); ObjectLock olock(comments);
String id; String id;
Dictionary::Ptr comment; Comment::Ptr comment;
BOOST_FOREACH(boost::tie(id, comment), comments) { BOOST_FOREACH(boost::tie(id, comment), comments) {
if (!comment) if (!comment)
@ -1178,11 +1178,11 @@ Value ServicesTable::CommentsWithExtraInfoAccessor(const Value& row)
continue; continue;
Array::Ptr comment_info = make_shared<Array>(); Array::Ptr comment_info = make_shared<Array>();
comment_info->Add(comment->Get("legacy_id")); comment_info->Add(comment->GetLegacyId());
comment_info->Add(comment->Get("author")); comment_info->Add(comment->GetAuthor());
comment_info->Add(comment->Get("text")); comment_info->Add(comment->GetText());
comment_info->Add(comment->Get("entry_type")); comment_info->Add(comment->GetEntryType());
comment_info->Add(static_cast<int>(comment->Get("entry_time"))); comment_info->Add(static_cast<int>(comment->GetEntryTime()));
ids->Add(comment_info); ids->Add(comment_info);
} }

View File

@ -371,23 +371,23 @@ void ServiceDbObject::AddComments(const Service::Ptr& service)
ObjectLock olock(comments); ObjectLock olock(comments);
String comment_id; String comment_id;
Dictionary::Ptr comment; Comment::Ptr comment;
BOOST_FOREACH(boost::tie(comment_id, comment), comments) { BOOST_FOREACH(boost::tie(comment_id, comment), comments) {
AddComment(service, comment); AddComment(service, comment);
} }
} }
void ServiceDbObject::AddComment(const Service::Ptr& service, const Dictionary::Ptr& comment) void ServiceDbObject::AddComment(const Service::Ptr& service, const Comment::Ptr& comment)
{ {
AddCommentInternal(service, comment, false); AddCommentInternal(service, comment, false);
} }
void ServiceDbObject::AddCommentHistory(const Service::Ptr& service, const Dictionary::Ptr& comment) void ServiceDbObject::AddCommentHistory(const Service::Ptr& service, const Comment::Ptr& comment)
{ {
AddCommentInternal(service, comment, true); AddCommentInternal(service, comment, true);
} }
void ServiceDbObject::AddCommentInternal(const Service::Ptr& service, const Dictionary::Ptr& comment, bool historical) void ServiceDbObject::AddCommentInternal(const Service::Ptr& service, const Comment::Ptr& comment, bool historical)
{ {
Host::Ptr host = service->GetHost(); Host::Ptr host = service->GetHost();
@ -399,48 +399,48 @@ void ServiceDbObject::AddCommentInternal(const Service::Ptr& service, const Dict
return; return;
} }
Log(LogDebug, "db_ido", "adding service comment (id = " + comment->Get("legacy_id") + ") for '" + service->GetName() + "'"); Log(LogDebug, "db_ido", "adding service comment (id = " + Convert::ToString(comment->GetLegacyId()) + ") for '" + service->GetName() + "'");
/* add the service comment */ /* add the service comment */
AddCommentByType(service, comment, historical); AddCommentByType(service, comment, historical);
/* add the hostcheck service comment to the host as well */ /* add the hostcheck service comment to the host as well */
if (host->GetCheckService() == service) { if (host->GetCheckService() == service) {
Log(LogDebug, "db_ido", "adding host comment (id = " + comment->Get("legacy_id") + ") for '" + host->GetName() + "'"); Log(LogDebug, "db_ido", "adding host comment (id = " + Convert::ToString(comment->GetLegacyId()) + ") for '" + host->GetName() + "'");
AddCommentByType(host, comment, historical); AddCommentByType(host, comment, historical);
} }
} }
void ServiceDbObject::AddCommentByType(const DynamicObject::Ptr& object, const Dictionary::Ptr& comment, bool historical) void ServiceDbObject::AddCommentByType(const DynamicObject::Ptr& object, const Comment::Ptr& comment, bool historical)
{ {
unsigned long entry_time = static_cast<long>(comment->Get("entry_time")); unsigned long entry_time = static_cast<long>(comment->GetEntryTime());
unsigned long entry_time_usec = (comment->Get("entry_time") - entry_time) * 1000 * 1000; unsigned long entry_time_usec = (comment->GetEntryTime() - entry_time) * 1000 * 1000;
Dictionary::Ptr fields1 = make_shared<Dictionary>(); Dictionary::Ptr fields1 = make_shared<Dictionary>();
fields1->Set("entry_time", DbValue::FromTimestamp(entry_time)); fields1->Set("entry_time", DbValue::FromTimestamp(entry_time));
fields1->Set("entry_time_usec", entry_time_usec); fields1->Set("entry_time_usec", entry_time_usec);
fields1->Set("entry_type", comment->Get("entry_type")); fields1->Set("entry_type", comment->GetEntryType());
fields1->Set("object_id", object); fields1->Set("object_id", object);
if (object->GetType() == DynamicType::GetByName("Host")) { if (object->GetType() == DynamicType::GetByName("Host")) {
fields1->Set("comment_type", 2); fields1->Set("comment_type", 2);
/* requires idoutils 1.10 schema fix */ /* requires idoutils 1.10 schema fix */
fields1->Set("internal_comment_id", comment->Get("legacy_id")); fields1->Set("internal_comment_id", comment->GetLegacyId());
} else if (object->GetType() == DynamicType::GetByName("Service")) { } else if (object->GetType() == DynamicType::GetByName("Service")) {
fields1->Set("comment_type", 1); fields1->Set("comment_type", 1);
fields1->Set("internal_comment_id", comment->Get("legacy_id")); fields1->Set("internal_comment_id", comment->GetLegacyId());
} else { } else {
Log(LogDebug, "db_ido", "unknown object type for adding comment."); Log(LogDebug, "db_ido", "unknown object type for adding comment.");
return; return;
} }
fields1->Set("comment_time", DbValue::FromTimestamp(entry_time)); /* same as entry_time */ fields1->Set("comment_time", DbValue::FromTimestamp(entry_time)); /* same as entry_time */
fields1->Set("author_name", comment->Get("author")); fields1->Set("author_name", comment->GetAuthor());
fields1->Set("comment_data", comment->Get("text")); fields1->Set("comment_data", comment->GetText());
fields1->Set("is_persistent", 1); fields1->Set("is_persistent", 1);
fields1->Set("comment_source", 1); /* external */ fields1->Set("comment_source", 1); /* external */
fields1->Set("expires", (comment->Get("expire_time") > 0) ? 1 : 0); fields1->Set("expires", (comment->GetExpireTime() > 0) ? 1 : 0);
fields1->Set("expiration_time", comment->Get("expire_time")); fields1->Set("expiration_time", comment->GetExpireTime());
fields1->Set("instance_id", 0); /* DbConnection class fills in real ID */ fields1->Set("instance_id", 0); /* DbConnection class fills in real ID */
DbQuery query1; DbQuery query1;
@ -479,7 +479,7 @@ void ServiceDbObject::RemoveComments(const Service::Ptr& service)
} }
} }
void ServiceDbObject::RemoveComment(const Service::Ptr& service, const Dictionary::Ptr& comment) void ServiceDbObject::RemoveComment(const Service::Ptr& service, const Comment::Ptr& comment)
{ {
Host::Ptr host = service->GetHost(); Host::Ptr host = service->GetHost();
@ -491,7 +491,7 @@ void ServiceDbObject::RemoveComment(const Service::Ptr& service, const Dictionar
return; return;
} }
Log(LogDebug, "db_ido", "removing service comment (id = " + comment->Get("legacy_id") + ") for '" + service->GetName() + "'"); Log(LogDebug, "db_ido", "removing service comment (id = " + Convert::ToString(comment->GetLegacyId()) + ") for '" + service->GetName() + "'");
/* Status */ /* Status */
DbQuery query1; DbQuery query1;
@ -500,7 +500,7 @@ void ServiceDbObject::RemoveComment(const Service::Ptr& service, const Dictionar
query1.Category = DbCatComment; query1.Category = DbCatComment;
query1.WhereCriteria = make_shared<Dictionary>(); query1.WhereCriteria = make_shared<Dictionary>();
query1.WhereCriteria->Set("object_id", service); query1.WhereCriteria->Set("object_id", service);
query1.WhereCriteria->Set("internal_comment_id", comment->Get("legacy_id")); query1.WhereCriteria->Set("internal_comment_id", comment->GetLegacyId());
OnQuery(query1); OnQuery(query1);
/* delete hostcheck service's host comments */ /* delete hostcheck service's host comments */
@ -510,7 +510,7 @@ void ServiceDbObject::RemoveComment(const Service::Ptr& service, const Dictionar
} }
/* History - update deletion time for service (and host in case) */ /* History - update deletion time for service (and host in case) */
unsigned long entry_time = static_cast<long>(comment->Get("entry_time")); unsigned long entry_time = static_cast<long>(comment->GetEntryTime());
double now = Utility::GetTime(); double now = Utility::GetTime();
Dictionary::Ptr time_bag = CompatUtility::ConvertTimestamp(now); Dictionary::Ptr time_bag = CompatUtility::ConvertTimestamp(now);
@ -526,7 +526,7 @@ void ServiceDbObject::RemoveComment(const Service::Ptr& service, const Dictionar
query2.Fields = fields2; query2.Fields = fields2;
query2.WhereCriteria = make_shared<Dictionary>(); query2.WhereCriteria = make_shared<Dictionary>();
query2.WhereCriteria->Set("internal_comment_id", comment->Get("legacy_id")); query2.WhereCriteria->Set("internal_comment_id", comment->GetLegacyId());
query2.WhereCriteria->Set("comment_time", DbValue::FromTimestamp(entry_time)); query2.WhereCriteria->Set("comment_time", DbValue::FromTimestamp(entry_time));
query2.WhereCriteria->Set("instance_id", 0); /* DbConnection class fills in real ID */ query2.WhereCriteria->Set("instance_id", 0); /* DbConnection class fills in real ID */

View File

@ -75,8 +75,8 @@ protected:
virtual void OnStatusUpdate(void); virtual void OnStatusUpdate(void);
private: private:
static void AddCommentInternal(const Service::Ptr& service, const Dictionary::Ptr& comment, bool historical); static void AddCommentInternal(const Service::Ptr& service, const Comment::Ptr& comment, bool historical);
static void AddCommentByType(const DynamicObject::Ptr& object, const Dictionary::Ptr& comment, bool historical); static void AddCommentByType(const DynamicObject::Ptr& object, const Comment::Ptr& comment, bool historical);
static void AddComments(const Service::Ptr& service); static void AddComments(const Service::Ptr& service);
static void RemoveComments(const Service::Ptr& service); static void RemoveComments(const Service::Ptr& service);
@ -88,16 +88,16 @@ private:
static void AddLogHistory(const Service::Ptr& service, String buffer, LogEntryType type); static void AddLogHistory(const Service::Ptr& service, String buffer, LogEntryType type);
/* Status */ /* Status */
static void AddComment(const Service::Ptr& service, const Dictionary::Ptr& comment); static void AddComment(const Service::Ptr& service, const Comment::Ptr& comment);
static void RemoveComment(const Service::Ptr& service, const Dictionary::Ptr& comment); static void RemoveComment(const Service::Ptr& service, const Comment::Ptr& comment);
static void AddDowntime(const Service::Ptr& service, const Dictionary::Ptr& downtime); static void AddDowntime(const Service::Ptr& service, const Dictionary::Ptr& downtime);
static void RemoveDowntime(const Service::Ptr& service, const Dictionary::Ptr& downtime); static void RemoveDowntime(const Service::Ptr& service, const Dictionary::Ptr& downtime);
static void TriggerDowntime(const Service::Ptr& service, const Dictionary::Ptr& downtime); static void TriggerDowntime(const Service::Ptr& service, const Dictionary::Ptr& downtime);
/* History */ /* History */
static void AddCommentHistory(const Service::Ptr& service, const Dictionary::Ptr& comment); static void AddCommentHistory(const Service::Ptr& service, const Comment::Ptr& comment);
static void AddDowntimeHistory(const Service::Ptr& service, const Dictionary::Ptr& downtime); static void AddDowntimeHistory(const Service::Ptr& service, const Dictionary::Ptr& downtime);
static void AddAcknowledgementHistory(const Service::Ptr& service, const String& author, const String& comment, AcknowledgementType type, double expiry); static void AddAcknowledgementHistory(const Service::Ptr& service, const String& author, const String& comment, AcknowledgementType type, double expiry);
static void AddContactNotificationHistory(const Service::Ptr& service, const User::Ptr& user); static void AddContactNotificationHistory(const Service::Ptr& service, const User::Ptr& user);
static void AddNotificationHistory(const Service::Ptr& service, const std::set<User::Ptr>& users, NotificationType type, const CheckResult::Ptr& cr, const String& author, const String& text); static void AddNotificationHistory(const Service::Ptr& service, const std::set<User::Ptr>& users, NotificationType type, const CheckResult::Ptr& cr, const String& author, const String& text);

View File

@ -18,6 +18,7 @@
mkclass_target(checkcommand.ti checkcommand.th) mkclass_target(checkcommand.ti checkcommand.th)
mkclass_target(checkresult.ti checkresult.th) mkclass_target(checkresult.ti checkresult.th)
mkclass_target(command.ti command.th) mkclass_target(command.ti command.th)
mkclass_target(comment.ti comment.th)
mkclass_target(domain.ti domain.th) mkclass_target(domain.ti domain.th)
mkclass_target(eventcommand.ti eventcommand.th) mkclass_target(eventcommand.ti eventcommand.th)
mkclass_target(hostgroup.ti hostgroup.th) mkclass_target(hostgroup.ti hostgroup.th)
@ -36,8 +37,8 @@ mkembedconfig_target(icinga-type.conf icinga-type.cpp)
add_library(icinga SHARED add_library(icinga SHARED
api.cpp api.h checkcommand.cpp checkcommand.th checkresult.cpp checkresult.th api.cpp api.h checkcommand.cpp checkcommand.th checkresult.cpp checkresult.th
cib.cpp command.cpp command.th compatutility.cpp domain.cpp domain.th cib.cpp command.cpp command.th comment.cpp comment.th compatutility.cpp
eventcommand.cpp eventcommand.th externalcommandprocessor.cpp host.cpp domain.cpp domain.th eventcommand.cpp eventcommand.th externalcommandprocessor.cpp host.cpp
host.th hostgroup.cpp hostgroup.th icingaapplication.cpp icingaapplication.th host.th hostgroup.cpp hostgroup.th icingaapplication.cpp icingaapplication.th
macroprocessor.cpp macroresolver.cpp notificationcommand.cpp notificationcommand.th macroprocessor.cpp macroresolver.cpp notificationcommand.cpp notificationcommand.th
notification.cpp notification.th perfdatavalue.cpp perfdatavalue.th notification.cpp notification.th perfdatavalue.cpp perfdatavalue.th

25
lib/icinga/comment.cpp Normal file
View File

@ -0,0 +1,25 @@
/******************************************************************************
* Icinga 2 *
* Copyright (C) 2012-2013 Icinga Development Team (http://www.icinga.org/) *
* *
* This program is free software; you can redistribute it and/or *
* modify it under the terms of the GNU General Public License *
* as published by the Free Software Foundation; either version 2 *
* of the License, or (at your option) any later version. *
* *
* This program is distributed in the hope that it will be useful, *
* but WITHOUT ANY WARRANTY; without even the implied warranty of *
* MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the *
* GNU General Public License for more details. *
* *
* You should have received a copy of the GNU General Public License *
* along with this program; if not, write to the Free Software Foundation *
* Inc., 51 Franklin St, Fifth Floor, Boston, MA 02110-1301, USA. *
******************************************************************************/
#include "icinga/comment.h"
#include "base/dynamictype.h"
using namespace icinga;
REGISTER_TYPE(Comment);

42
lib/icinga/comment.h Normal file
View File

@ -0,0 +1,42 @@
/******************************************************************************
* Icinga 2 *
* Copyright (C) 2012-2013 Icinga Development Team (http://www.icinga.org/) *
* *
* This program is free software; you can redistribute it and/or *
* modify it under the terms of the GNU General Public License *
* as published by the Free Software Foundation; either version 2 *
* of the License, or (at your option) any later version. *
* *
* This program is distributed in the hope that it will be useful, *
* but WITHOUT ANY WARRANTY; without even the implied warranty of *
* MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the *
* GNU General Public License for more details. *
* *
* You should have received a copy of the GNU General Public License *
* along with this program; if not, write to the Free Software Foundation *
* Inc., 51 Franklin St, Fifth Floor, Boston, MA 02110-1301, USA. *
******************************************************************************/
#ifndef COMMENT_H
#define COMMENT_H
#include "icinga/i2-icinga.h"
#include "icinga/comment.th"
namespace icinga
{
/**
* A service comment.
*
* @ingroup icinga
*/
class I2_ICINGA_API Comment : public ObjectImpl<Comment>
{
public:
DECLARE_PTR_TYPEDEFS(Comment);
};
}
#endif /* COMMENT_H */

30
lib/icinga/comment.ti Normal file
View File

@ -0,0 +1,30 @@
namespace icinga
{
code {{{
/**
* The type of a service comment.
*
* @ingroup icinga
*/
enum CommentType
{
CommentUser = 1,
CommentDowntime = 2,
CommentFlapping = 3,
CommentAcknowledgement = 4
};
}}}
class Comment
{
[state] String id;
[state] double entry_time;
[state, enum] CommentType entry_type;
[state] String author;
[state] String text;
[state] double expire_time;
[state] int legacy_id;
};
}

View File

@ -34,8 +34,8 @@ static std::map<int, String> l_LegacyCommentsCache;
static std::map<String, Service::WeakPtr> l_CommentsCache; static std::map<String, Service::WeakPtr> l_CommentsCache;
static Timer::Ptr l_CommentsExpireTimer; static Timer::Ptr l_CommentsExpireTimer;
boost::signals2::signal<void (const Service::Ptr&, const Dictionary::Ptr&, const String&)> Service::OnCommentAdded; boost::signals2::signal<void (const Service::Ptr&, const Comment::Ptr&, const String&)> Service::OnCommentAdded;
boost::signals2::signal<void (const Service::Ptr&, const Dictionary::Ptr&, const String&)> Service::OnCommentRemoved; boost::signals2::signal<void (const Service::Ptr&, const Comment::Ptr&, const String&)> Service::OnCommentRemoved;
int Service::GetNextCommentID(void) int Service::GetNextCommentID(void)
{ {
@ -54,13 +54,13 @@ String Service::AddComment(CommentType entryType, const String& author,
else else
uid = id; uid = id;
Dictionary::Ptr comment = make_shared<Dictionary>(); Comment::Ptr comment = make_shared<Comment>();
comment->Set("id", uid); comment->SetId(uid);;
comment->Set("entry_time", Utility::GetTime()); comment->SetEntryTime(Utility::GetTime());
comment->Set("entry_type", entryType); comment->SetEntryType(entryType);
comment->Set("author", author); comment->SetAuthor(author);
comment->Set("text", text); comment->SetText(text);
comment->Set("expire_time", expireTime); comment->SetExpireTime(expireTime);
int legacy_id; int legacy_id;
@ -69,7 +69,7 @@ String Service::AddComment(CommentType entryType, const String& author,
legacy_id = l_NextCommentID++; legacy_id = l_NextCommentID++;
} }
comment->Set("legacy_id", legacy_id); comment->SetLegacyId(legacy_id);
GetComments()->Set(uid, comment); GetComments()->Set(uid, comment);
@ -111,12 +111,12 @@ void Service::RemoveComment(const String& id, const String& authority)
ObjectLock olock(owner); ObjectLock olock(owner);
Dictionary::Ptr comment = comments->Get(id); Comment::Ptr comment = comments->Get(id);
if (!comment) if (!comment)
return; return;
int legacy_id = comment->Get("legacy_id"); int legacy_id = comment->GetLegacyId();
comments->Remove(id); comments->Remove(id);
@ -148,24 +148,24 @@ Service::Ptr Service::GetOwnerByCommentID(const String& id)
return l_CommentsCache[id].lock(); return l_CommentsCache[id].lock();
} }
Dictionary::Ptr Service::GetCommentByID(const String& id) Comment::Ptr Service::GetCommentByID(const String& id)
{ {
Service::Ptr owner = GetOwnerByCommentID(id); Service::Ptr owner = GetOwnerByCommentID(id);
if (!owner) if (!owner)
return Dictionary::Ptr(); return Comment::Ptr();
Dictionary::Ptr comments = owner->GetComments(); Dictionary::Ptr comments = owner->GetComments();
if (comments) if (comments)
return comments->Get(id); return comments->Get(id);
return Dictionary::Ptr(); return Comment::Ptr();
} }
bool Service::IsCommentExpired(const Dictionary::Ptr& comment) bool Service::IsCommentExpired(const Comment::Ptr& comment)
{ {
double expire_time = comment->Get("expire_time"); double expire_time = comment->GetExpireTime();
return (expire_time != 0 && expire_time < Utility::GetTime()); return (expire_time != 0 && expire_time < Utility::GetTime());
} }
@ -181,9 +181,9 @@ void Service::AddCommentsToCache(void)
boost::mutex::scoped_lock lock(l_CommentMutex); boost::mutex::scoped_lock lock(l_CommentMutex);
String id; String id;
Dictionary::Ptr comment; Comment::Ptr comment;
BOOST_FOREACH(boost::tie(id, comment), comments) { BOOST_FOREACH(boost::tie(id, comment), comments) {
int legacy_id = comment->Get("legacy_id"); int legacy_id = comment->GetLegacyId();
if (legacy_id >= l_NextCommentID) if (legacy_id >= l_NextCommentID)
l_NextCommentID = legacy_id + 1; l_NextCommentID = legacy_id + 1;
@ -203,9 +203,9 @@ void Service::RemoveCommentsByType(int type)
ObjectLock olock(comments); ObjectLock olock(comments);
String id; String id;
Dictionary::Ptr comment; Comment::Ptr comment;
BOOST_FOREACH(boost::tie(id, comment), comments) { BOOST_FOREACH(boost::tie(id, comment), comments) {
if (comment->Get("entry_type") == type) if (comment->GetEntryType() == type)
removedComments.push_back(id); removedComments.push_back(id);
} }
} }
@ -225,7 +225,7 @@ void Service::RemoveExpiredComments(void)
ObjectLock olock(comments); ObjectLock olock(comments);
String id; String id;
Dictionary::Ptr comment; Comment::Ptr comment;
BOOST_FOREACH(boost::tie(id, comment), comments) { BOOST_FOREACH(boost::tie(id, comment), comments) {
if (IsCommentExpired(comment)) if (IsCommentExpired(comment))
expiredComments.push_back(id); expiredComments.push_back(id);

View File

@ -26,6 +26,7 @@
#include "icinga/host.h" #include "icinga/host.h"
#include "icinga/timeperiod.h" #include "icinga/timeperiod.h"
#include "icinga/notification.h" #include "icinga/notification.h"
#include "icinga/comment.h"
#include "base/i2-base.h" #include "base/i2-base.h"
#include "base/array.h" #include "base/array.h"
#include <boost/signals2.hpp> #include <boost/signals2.hpp>
@ -34,19 +35,6 @@
namespace icinga namespace icinga
{ {
/**
* The type of a service comment.
*
* @ingroup icinga
*/
enum CommentType
{
CommentUser = 1,
CommentDowntime = 2,
CommentFlapping = 3,
CommentAcknowledgement = 4
};
/** /**
* The state of a service downtime. * The state of a service downtime.
* *
@ -201,8 +189,8 @@ public:
static boost::signals2::signal<void (const Service::Ptr&, NotificationType, const CheckResult::Ptr&, const String&, const String&)> OnNotificationsRequested; static boost::signals2::signal<void (const Service::Ptr&, NotificationType, const CheckResult::Ptr&, const String&, const String&)> OnNotificationsRequested;
static boost::signals2::signal<void (const Service::Ptr&, const User::Ptr&, const NotificationType&, const CheckResult::Ptr&, const String&, const String&, const String&)> OnNotificationSentToUser; static boost::signals2::signal<void (const Service::Ptr&, const User::Ptr&, const NotificationType&, const CheckResult::Ptr&, const String&, const String&, const String&)> OnNotificationSentToUser;
static boost::signals2::signal<void (const Service::Ptr&, const std::set<User::Ptr>&, const NotificationType&, const CheckResult::Ptr&, const String&, const String&)> OnNotificationSentToAllUsers; static boost::signals2::signal<void (const Service::Ptr&, const std::set<User::Ptr>&, const NotificationType&, const CheckResult::Ptr&, const String&, const String&)> OnNotificationSentToAllUsers;
static boost::signals2::signal<void (const Service::Ptr&, const Dictionary::Ptr&, const String&)> OnCommentAdded; static boost::signals2::signal<void (const Service::Ptr&, const Comment::Ptr&, const String&)> OnCommentAdded;
static boost::signals2::signal<void (const Service::Ptr&, const Dictionary::Ptr&, const String&)> OnCommentRemoved; static boost::signals2::signal<void (const Service::Ptr&, const Comment::Ptr&, const String&)> OnCommentRemoved;
static boost::signals2::signal<void (const Service::Ptr&, const Dictionary::Ptr&, const String&)> OnDowntimeAdded; static boost::signals2::signal<void (const Service::Ptr&, const Dictionary::Ptr&, const String&)> OnDowntimeAdded;
static boost::signals2::signal<void (const Service::Ptr&, const Dictionary::Ptr&, const String&)> OnDowntimeRemoved; static boost::signals2::signal<void (const Service::Ptr&, const Dictionary::Ptr&, const String&)> OnDowntimeRemoved;
static boost::signals2::signal<void (const Service::Ptr&, FlappingState)> OnFlappingChanged; static boost::signals2::signal<void (const Service::Ptr&, FlappingState)> OnFlappingChanged;
@ -253,9 +241,9 @@ public:
static String GetCommentIDFromLegacyID(int id); static String GetCommentIDFromLegacyID(int id);
static Service::Ptr GetOwnerByCommentID(const String& id); static Service::Ptr GetOwnerByCommentID(const String& id);
static Dictionary::Ptr GetCommentByID(const String& id); static Comment::Ptr GetCommentByID(const String& id);
static bool IsCommentExpired(const Dictionary::Ptr& comment); static bool IsCommentExpired(const Comment::Ptr& comment);
/* Notifications */ /* Notifications */
bool GetEnableNotifications(void) const; bool GetEnableNotifications(void) const;