mirror of https://github.com/Icinga/icinga2.git
Bugfix: some legacy_id changes didn't cause the cache to get updated.
This commit is contained in:
parent
49cc9f5898
commit
7b03c77b66
|
@ -184,11 +184,6 @@ void CompatComponent::DumpComments(ofstream& fp, const DynamicObject::Ptr& owner
|
||||||
if (CommentProcessor::IsCommentExpired(comment))
|
if (CommentProcessor::IsCommentExpired(comment))
|
||||||
continue;
|
continue;
|
||||||
|
|
||||||
/* There's no way for us to dump comments that haven't been
|
|
||||||
* assigned a legacy ID yet. */
|
|
||||||
if (!comment->Contains("legacy_id"))
|
|
||||||
continue;
|
|
||||||
|
|
||||||
if (!service)
|
if (!service)
|
||||||
fp << "hostcomment {" << "\n";
|
fp << "hostcomment {" << "\n";
|
||||||
else
|
else
|
||||||
|
@ -234,11 +229,6 @@ void CompatComponent::DumpDowntimes(ofstream& fp, const DynamicObject::Ptr& owne
|
||||||
if (DowntimeProcessor::IsDowntimeExpired(downtime))
|
if (DowntimeProcessor::IsDowntimeExpired(downtime))
|
||||||
continue;
|
continue;
|
||||||
|
|
||||||
/* There's no way for us to dump downtimes that haven't been
|
|
||||||
* assigned a legacy ID yet. */
|
|
||||||
if (!downtime->Contains("legacy_id"))
|
|
||||||
continue;
|
|
||||||
|
|
||||||
if (!service)
|
if (!service)
|
||||||
fp << "hostdowntime {" << "\n";
|
fp << "hostdowntime {" << "\n";
|
||||||
else
|
else
|
||||||
|
|
|
@ -42,6 +42,7 @@ String CommentProcessor::AddComment(const DynamicObject::Ptr& owner,
|
||||||
comment->Set("author", author);
|
comment->Set("author", author);
|
||||||
comment->Set("text", text);
|
comment->Set("text", text);
|
||||||
comment->Set("expire_time", expireTime);
|
comment->Set("expire_time", expireTime);
|
||||||
|
comment->Set("legacy_id", m_NextCommentID++);
|
||||||
|
|
||||||
Dictionary::Ptr comments = owner->Get("comments");
|
Dictionary::Ptr comments = owner->Get("comments");
|
||||||
|
|
||||||
|
@ -133,15 +134,7 @@ void CommentProcessor::AddCommentsToCache(const DynamicObject::Ptr& owner)
|
||||||
String id;
|
String id;
|
||||||
Dictionary::Ptr comment;
|
Dictionary::Ptr comment;
|
||||||
BOOST_FOREACH(tie(id, comment), comments) {
|
BOOST_FOREACH(tie(id, comment), comments) {
|
||||||
int legacy_id;
|
int legacy_id = comment->Get("legacy_id");
|
||||||
|
|
||||||
if (!comment->Contains("legacy_id")) {
|
|
||||||
legacy_id = m_NextCommentID;
|
|
||||||
m_NextCommentID++;
|
|
||||||
comment->Set("legacy_id", legacy_id);
|
|
||||||
} else {
|
|
||||||
legacy_id = comment->Get("legacy_id");
|
|
||||||
}
|
|
||||||
|
|
||||||
if (legacy_id >= m_NextCommentID)
|
if (legacy_id >= m_NextCommentID)
|
||||||
m_NextCommentID = legacy_id + 1;
|
m_NextCommentID = legacy_id + 1;
|
||||||
|
@ -150,9 +143,9 @@ void CommentProcessor::AddCommentsToCache(const DynamicObject::Ptr& owner)
|
||||||
/* The legacy_id is already in use by another comment;
|
/* The legacy_id is already in use by another comment;
|
||||||
* this shouldn't usually happen - assign it a new ID */
|
* this shouldn't usually happen - assign it a new ID */
|
||||||
|
|
||||||
legacy_id = m_NextCommentID;
|
legacy_id = m_NextCommentID++;
|
||||||
m_NextCommentID++;
|
|
||||||
comment->Set("legacy_id", legacy_id);
|
comment->Set("legacy_id", legacy_id);
|
||||||
|
owner->Touch("comments");
|
||||||
}
|
}
|
||||||
|
|
||||||
m_LegacyCommentCache[legacy_id] = id;
|
m_LegacyCommentCache[legacy_id] = id;
|
||||||
|
|
|
@ -47,6 +47,7 @@ String DowntimeProcessor::AddDowntime(const DynamicObject::Ptr& owner,
|
||||||
downtime->Set("duration", duration);
|
downtime->Set("duration", duration);
|
||||||
downtime->Set("triggered_by", triggeredBy);
|
downtime->Set("triggered_by", triggeredBy);
|
||||||
downtime->Set("trigger_time", 0);
|
downtime->Set("trigger_time", 0);
|
||||||
|
downtime->Set("legacy_id", m_NextDowntimeID++);
|
||||||
|
|
||||||
Dictionary::Ptr downtimes = owner->Get("downtimes");
|
Dictionary::Ptr downtimes = owner->Get("downtimes");
|
||||||
|
|
||||||
|
@ -149,15 +150,7 @@ void DowntimeProcessor::AddDowntimesToCache(const DynamicObject::Ptr& owner)
|
||||||
BOOST_FOREACH(tie(id, downtime), downtimes) {
|
BOOST_FOREACH(tie(id, downtime), downtimes) {
|
||||||
double end_time = downtime->Get("end_time");
|
double end_time = downtime->Get("end_time");
|
||||||
|
|
||||||
int legacy_id;
|
int legacy_id = downtime->Get("legacy_id");
|
||||||
|
|
||||||
if (!downtime->Contains("legacy_id")) {
|
|
||||||
legacy_id = m_NextDowntimeID;
|
|
||||||
m_NextDowntimeID++;
|
|
||||||
downtime->Set("legacy_id", legacy_id);
|
|
||||||
} else {
|
|
||||||
legacy_id = downtime->Get("legacy_id");
|
|
||||||
}
|
|
||||||
|
|
||||||
if (legacy_id >= m_NextDowntimeID)
|
if (legacy_id >= m_NextDowntimeID)
|
||||||
m_NextDowntimeID = legacy_id + 1;
|
m_NextDowntimeID = legacy_id + 1;
|
||||||
|
@ -165,9 +158,9 @@ void DowntimeProcessor::AddDowntimesToCache(const DynamicObject::Ptr& owner)
|
||||||
if (m_LegacyDowntimeCache.find(legacy_id) != m_LegacyDowntimeCache.end()) {
|
if (m_LegacyDowntimeCache.find(legacy_id) != m_LegacyDowntimeCache.end()) {
|
||||||
/* The legacy_id is already in use by another downtime;
|
/* The legacy_id is already in use by another downtime;
|
||||||
* this shouldn't usually happen - assign it a new ID. */
|
* this shouldn't usually happen - assign it a new ID. */
|
||||||
legacy_id = m_NextDowntimeID;
|
legacy_id = m_NextDowntimeID++;
|
||||||
m_NextDowntimeID++;
|
|
||||||
downtime->Set("legacy_id", legacy_id);
|
downtime->Set("legacy_id", legacy_id);
|
||||||
|
owner->Touch("downtimes");
|
||||||
}
|
}
|
||||||
|
|
||||||
m_LegacyDowntimeCache[legacy_id] = id;
|
m_LegacyDowntimeCache[legacy_id] = id;
|
||||||
|
|
Loading…
Reference in New Issue