/* clear config tables for the initial config dump */
ClearConfigTables();
- Query("UPDATE " + GetTablePrefix() + "objects SET is_active = 0");
-
std::ostringstream q1buf;
- q1buf << "SELECT object_id, objecttype_id, name1, name2 FROM " + GetTablePrefix() + "objects WHERE instance_id = " << static_cast<long>(m_InstanceID);
+ q1buf << "SELECT object_id, objecttype_id, name1, name2, is_active FROM " + GetTablePrefix() + "objects WHERE instance_id = " << static_cast<long>(m_InstanceID);
rows = Query(q1buf.str());
ObjectLock olock(rows);
DbObject::Ptr dbobj = dbtype->GetOrCreateObjectByName(row->Get("name1"), row->Get("name2"));
SetObjectID(dbobj, DbReference(row->Get("object_id")));
+ SetObjectActive(dbobj, row->Get("is_active"));
}
Query("BEGIN");
ClearConfigTable("contactgroup_members");
ClearConfigTable("contactgroups");
ClearConfigTable("contacts");
+ ClearConfigTable("contactstatus");
ClearConfigTable("customvariables");
+ ClearConfigTable("customvariablestatus");
ClearConfigTable("host_contactgroups");
ClearConfigTable("host_contacts");
ClearConfigTable("host_parenthosts");
ClearConfigTable("hostgroup_members");
ClearConfigTable("hostgroups");
ClearConfigTable("hosts");
+ ClearConfigTable("hoststatus");
+ ClearConfigTable("programstatus");
ClearConfigTable("scheduleddowntime");
ClearConfigTable("service_contactgroups");
ClearConfigTable("service_contacts");
ClearConfigTable("servicegroup_members");
ClearConfigTable("servicegroups");
ClearConfigTable("services");
+ ClearConfigTable("servicestatus");
ClearConfigTable("timeperiod_timeranges");
ClearConfigTable("timeperiods");
}
Dictionary::Ptr dict = make_shared<Dictionary>();
mysql_field_seek(result, 0);
- for (field = mysql_fetch_field(result), i = 0; field; field = mysql_fetch_field(result), i++) {
- Value value;
-
- if (field)
- value = String(row[i], row[i] + lengths[i]);
-
- dict->Set(field->name, value);
- }
+ for (field = mysql_fetch_field(result), i = 0; field; field = mysql_fetch_field(result), i++)
+ dict->Set(field->name, String(row[i], row[i] + lengths[i]));
return dict;
}
if (hasid)
type = DbQueryUpdate;
- else {
- if (query.WhereCriteria)
- Query("DELETE FROM " + GetTablePrefix() + query.Table + where.str());
-
+ else
type = DbQueryInsert;
- }
} else
type = query.Type;
/* clear config tables for the initial config dump */
ClearConfigTables();
- Query("UPDATE " + GetTablePrefix() + "objects SET is_active = 0");
-
std::ostringstream q1buf;
- q1buf << "SELECT object_id, objecttype_id, name1, name2 FROM " + GetTablePrefix() + "objects WHERE instance_id = " << static_cast<long>(m_InstanceID);
+ q1buf << "SELECT object_id, objecttype_id, name1, name2, is_active FROM " + GetTablePrefix() + "objects WHERE instance_id = " << static_cast<long>(m_InstanceID);
rows = Query(q1buf.str());
ObjectLock olock(rows);
DbObject::Ptr dbobj = dbtype->GetOrCreateObjectByName(row->Get("name1"), row->Get("name2"));
SetObjectID(dbobj, DbReference(row->Get("object_id")));
+ SetObjectActive(dbobj, row->Get("is_active"));
}
Query("BEGIN");
ClearConfigTable("contactgroup_members");
ClearConfigTable("contactgroups");
ClearConfigTable("contacts");
+ ClearConfigTable("contactstatus");
ClearConfigTable("customvariables");
+ ClearConfigTable("customvariablestatus");
ClearConfigTable("host_contactgroups");
ClearConfigTable("host_contacts");
ClearConfigTable("host_parenthosts");
ClearConfigTable("hostgroup_members");
ClearConfigTable("hostgroups");
ClearConfigTable("hosts");
+ ClearConfigTable("hoststatus");
+ ClearConfigTable("programstatus");
ClearConfigTable("scheduleddowntime");
ClearConfigTable("service_contactgroups");
ClearConfigTable("service_contacts");
ClearConfigTable("servicegroup_members");
ClearConfigTable("servicegroups");
ClearConfigTable("services");
+ ClearConfigTable("servicestatus");
ClearConfigTable("timeperiod_timeranges");
ClearConfigTable("timeperiods");
}
if (hasid)
type = DbQueryUpdate;
- else {
- if (query.WhereCriteria)
- Query("DELETE FROM " + GetTablePrefix() + query.Table + where.str());
-
+ else
type = DbQueryInsert;
- }
} else
type = query.Type;
return it->second;
}
+void DbConnection::SetObjectActive(const DbObject::Ptr& dbobj, bool active)
+{
+ if (active)
+ m_ActiveObjects.insert(dbobj);
+ else
+ m_ActiveObjects.erase(dbobj);
+}
+
+bool DbConnection::GetObjectActive(const DbObject::Ptr& dbobj) const
+{
+ return (m_ActiveObjects.find(dbobj) != m_ActiveObjects.end());
+}
+
void DbConnection::ClearIDCache(void)
{
m_ObjectIDs.clear();
m_InsertIDs.clear();
+ m_ActiveObjects.clear();
}
void DbConnection::SetConfigUpdate(const DbObject::Ptr& dbobj, bool hasupdate)
DbObject::Ptr dbobj = DbObject::GetOrCreateByObject(object);
if (dbobj) {
- ActivateObject(dbobj);
+ if (!GetObjectActive(dbobj))
+ ActivateObject(dbobj);
+
dbobj->SendConfigUpdate();
dbobj->SendStatusUpdate();
}
void SetInsertID(const DbObject::Ptr& dbobj, const DbReference& dbref);
DbReference GetInsertID(const DbObject::Ptr& dbobj) const;
+ void SetObjectActive(const DbObject::Ptr& dbobj, bool active);
+ bool GetObjectActive(const DbObject::Ptr& dbobj) const;
+
void ClearIDCache(void);
void SetConfigUpdate(const DbObject::Ptr& dbobj, bool hasupdate);
private:
std::map<DbObject::Ptr, DbReference> m_ObjectIDs;
std::map<DbObject::Ptr, DbReference> m_InsertIDs;
+ std::set<DbObject::Ptr> m_ActiveObjects;
std::set<DbObject::Ptr> m_ConfigUpdates;
std::set<DbObject::Ptr> m_StatusUpdates;
Timer::Ptr m_CleanUpTimer;
Host::Ptr host = static_pointer_cast<Host>(GetObject());
/* parents, host dependencies */
- DbQuery query_del1;
- query_del1.Table = GetType()->GetTable() + "_parenthosts";
- query_del1.Type = DbQueryDelete;
- query_del1.Category = DbCatConfig;
- query_del1.WhereCriteria = make_shared<Dictionary>();
- query_del1.WhereCriteria->Set(GetType()->GetTable() + "_id", DbValue::FromObjectInsertID(GetObject()));
- OnQuery(query_del1);
-
- DbQuery query_del2;
- query_del2.Table = GetType()->GetTable() + "dependencies";
- query_del2.Type = DbQueryDelete;
- query_del2.Category = DbCatConfig;
- query_del2.WhereCriteria = make_shared<Dictionary>();
- query_del2.WhereCriteria->Set("dependent_host_object_id", host);
- OnQuery(query_del2);
-
BOOST_FOREACH(const Host::Ptr& parent, host->GetParentHosts()) {
Log(LogDebug, "db_ido", "host parents: " + parent->GetName());
/* custom variables */
Log(LogDebug, "ido", "host customvars for '" + host->GetName() + "'");
- DbQuery query_del3;
- query_del3.Table = "customvariables";
- query_del3.Type = DbQueryDelete;
- query_del3.Category = DbCatConfig;
- query_del3.WhereCriteria = make_shared<Dictionary>();
- query_del3.WhereCriteria->Set("object_id", host);
- OnQuery(query_del3);
-
Dictionary::Ptr customvars;
{
ObjectLock olock(host);