Avoid duplicate config and status updates on startup

fixes #10765
This commit is contained in:
Michael Friedrich 2015-12-15 13:44:58 +01:00 committed by Gunnar Beutner
parent e1ac078d4b
commit 634b3d7bc4
3 changed files with 203 additions and 199 deletions

View File

@ -364,14 +364,14 @@ void DbConnection::UpdateObject(const ConfigObject::Ptr& object)
DbObject::Ptr dbobj = DbObject::GetOrCreateByObject(object);
if (dbobj) {
bool dbActive = GetObjectActive(dbobj);
bool active = object->IsActive();
if (active) {
if (active && !dbActive) {
ActivateObject(dbobj);
dbobj->SendConfigUpdate();
dbobj->SendStatusUpdate();
} else
} else if (!active && dbActive)
DeactivateObject(dbobj);
}
}

View File

@ -171,8 +171,6 @@ void IdoMysqlConnection::Reconnect(void)
SetShouldConnect(true);
std::vector<DbObject::Ptr> active_dbobjs;
bool reconnect = false;
if (GetConnected()) {
@ -351,6 +349,8 @@ void IdoMysqlConnection::Reconnect(void)
q1buf << "SELECT object_id, objecttype_id, name1, name2, is_active FROM " + GetTablePrefix() + "objects WHERE instance_id = " << static_cast<long>(m_InstanceID);
result = Query(q1buf.str());
std::vector<DbObject::Ptr> activeDbObjs;
while ((row = FetchRow(result))) {
DbType::Ptr dbtype = DbType::GetByID(row->Get("objecttype_id"));
@ -359,26 +359,29 @@ void IdoMysqlConnection::Reconnect(void)
DbObject::Ptr dbobj = dbtype->GetOrCreateObjectByName(row->Get("name1"), row->Get("name2"));
SetObjectID(dbobj, DbReference(row->Get("object_id")));
SetObjectActive(dbobj, row->Get("is_active"));
bool active = row->Get("is_active");
SetObjectActive(dbobj, active);
if (GetObjectActive(dbobj))
active_dbobjs.push_back(dbobj);
if (active)
activeDbObjs.push_back(dbobj);
}
Query("BEGIN");
UpdateAllObjects();
/* deactivate all deleted configuration objects */
BOOST_FOREACH(const DbObject::Ptr& dbobj, active_dbobjs) {
BOOST_FOREACH(const DbObject::Ptr& dbobj, activeDbObjs) {
if (dbobj->GetObject() == NULL) {
Log(LogNotice, "IdoMysqlConnection")
<< "Deactivate deleted object name1: '" << dbobj->GetName1()
<< "' name2: '" << dbobj->GetName2() + "'.";
DeactivateObject(dbobj);
} else {
dbobj->SendConfigUpdate();
dbobj->SendStatusUpdate();
}
}
UpdateAllObjects();
/* delete all customvariables without current session token */
ClearCustomVarTable("customvariables");
ClearCustomVarTable("customvariablestatus");

View File

@ -168,9 +168,6 @@ void IdoPgsqlConnection::Reconnect(void)
SetShouldConnect(true);
std::vector<DbObject::Ptr> active_dbobjs;
{
bool reconnect = false;
if (GetConnected()) {
@ -339,6 +336,8 @@ void IdoPgsqlConnection::Reconnect(void)
q1buf << "SELECT object_id, objecttype_id, name1, name2, is_active FROM " + GetTablePrefix() + "objects WHERE instance_id = " << static_cast<long>(m_InstanceID);
result = Query(q1buf.str());
std::vector<DbObject::Ptr> activeDbObjs;
int index = 0;
while ((row = FetchRow(result, index))) {
index++;
@ -350,27 +349,29 @@ void IdoPgsqlConnection::Reconnect(void)
DbObject::Ptr dbobj = dbtype->GetOrCreateObjectByName(row->Get("name1"), row->Get("name2"));
SetObjectID(dbobj, DbReference(row->Get("object_id")));
SetObjectActive(dbobj, row->Get("is_active"));
bool active = row->Get("is_active");
SetObjectActive(dbobj, active);
if (GetObjectActive(dbobj))
active_dbobjs.push_back(dbobj);
if (active)
activeDbObjs.push_back(dbobj);
}
Query("BEGIN");
}
UpdateAllObjects();
/* deactivate all deleted configuration objects */
BOOST_FOREACH(const DbObject::Ptr& dbobj, active_dbobjs) {
BOOST_FOREACH(const DbObject::Ptr& dbobj, activeDbObjs) {
if (dbobj->GetObject() == NULL) {
Log(LogNotice, "IdoPgsqlConnection")
<< "Deactivate deleted object name1: '" << dbobj->GetName1()
<< "' name2: '" << dbobj->GetName2() + "'.";
DeactivateObject(dbobj);
} else {
dbobj->SendConfigUpdate();
dbobj->SendStatusUpdate();
}
}
UpdateAllObjects();
/* delete all customvariables without current session token */
ClearCustomVarTable("customvariables");
ClearCustomVarTable("customvariablestatus");