ido: Add host_parenthosts, use GetInsertID().

This commit is contained in:
Michael Friedrich 2013-08-02 15:20:28 +02:00
parent aa82ef7c06
commit 5977bdee2d
5 changed files with 74 additions and 9 deletions

View File

@ -291,35 +291,45 @@ bool MysqlDbConnection::FieldToEscapedString(const String& key, const Value& val
return true; return true;
} }
if (value.IsObjectType<DynamicObject>()) { Value rawvalue = DbValue::ExtractValue(value);
DbObject::Ptr dbobjcol = DbObject::GetOrCreateByObject(value);
if (rawvalue.IsObjectType<DynamicObject>()) {
DbObject::Ptr dbobjcol = DbObject::GetOrCreateByObject(rawvalue);
if (!dbobjcol) { if (!dbobjcol) {
*result = 0; *result = 0;
return true; return true;
} }
DbReference dbrefcol = GetObjectID(dbobjcol); DbReference dbrefcol;
if (!dbrefcol.IsValid()) { if (DbValue::IsObjectInsertID(value)) {
InternalActivateObject(dbobjcol); dbrefcol = GetInsertID(dbobjcol);
ASSERT(dbrefcol.IsValid());
} else {
dbrefcol = GetObjectID(dbobjcol); dbrefcol = GetObjectID(dbobjcol);
if (!dbrefcol.IsValid()) if (!dbrefcol.IsValid()) {
return false; InternalActivateObject(dbobjcol);
dbrefcol = GetObjectID(dbobjcol);
if (!dbrefcol.IsValid())
return false;
}
} }
*result = static_cast<long>(dbrefcol); *result = static_cast<long>(dbrefcol);
} else if (DbValue::IsTimestamp(value)) { } else if (DbValue::IsTimestamp(value)) {
long ts = DbValue::ExtractValue(value); long ts = rawvalue;
std::ostringstream msgbuf; std::ostringstream msgbuf;
msgbuf << "FROM_UNIXTIME(" << ts << ")"; msgbuf << "FROM_UNIXTIME(" << ts << ")";
*result = Value(msgbuf.str()); *result = Value(msgbuf.str());
} else if (DbValue::IsTimestampNow(value)) { } else if (DbValue::IsTimestampNow(value)) {
*result = "NOW()"; *result = "NOW()";
} else { } else {
*result = "'" + Escape(DbValue::ExtractValue(value)) + "'"; *result = "'" + Escape(rawvalue) + "'";
} }
return true; return true;

View File

@ -43,6 +43,11 @@ Value DbValue::FromValue(const Value& value)
return value; return value;
} }
Value DbValue::FromObjectInsertID(const Value& value)
{
return boost::make_shared<DbValue>(DbValueObjectInsertID, value);
}
bool DbValue::IsTimestamp(const Value& value) bool DbValue::IsTimestamp(const Value& value)
{ {
if (!value.IsObjectType<DbValue>()) if (!value.IsObjectType<DbValue>())
@ -61,6 +66,15 @@ bool DbValue::IsTimestampNow(const Value& value)
return dbv->GetType() == DbValueTimestampNow; return dbv->GetType() == DbValueTimestampNow;
} }
bool DbValue::IsObjectInsertID(const Value& value)
{
if (!value.IsObjectType<DbValue>())
return false;
DbValue::Ptr dbv = value;
return dbv->GetType() == DbValueObjectInsertID;
}
Value DbValue::ExtractValue(const Value& value) Value DbValue::ExtractValue(const Value& value)
{ {
if (!value.IsObjectType<DbValue>()) if (!value.IsObjectType<DbValue>())

View File

@ -31,6 +31,7 @@ enum DbValueType
{ {
DbValueTimestamp, DbValueTimestamp,
DbValueTimestampNow, DbValueTimestampNow,
DbValueObjectInsertID,
}; };
/** /**
@ -46,9 +47,11 @@ public:
static Value FromTimestamp(const Value& ts); static Value FromTimestamp(const Value& ts);
static Value FromTimestampNow(void); static Value FromTimestampNow(void);
static Value FromValue(const Value& value); static Value FromValue(const Value& value);
static Value FromObjectInsertID(const Value& value);
static bool IsTimestamp(const Value& value); static bool IsTimestamp(const Value& value);
static bool IsTimestampNow(const Value& value); static bool IsTimestampNow(const Value& value);
static bool IsObjectInsertID(const Value& value);
static Value ExtractValue(const Value& value); static Value ExtractValue(const Value& value);
DbValueType GetType(void) const; DbValueType GetType(void) const;

View File

@ -186,3 +186,37 @@ Dictionary::Ptr HostDbObject::GetStatusFields(void) const
return fields; return fields;
} }
void HostDbObject::OnConfigUpdate(void)
{
Host::Ptr host = static_pointer_cast<Host>(GetObject());
/* parents: host_id, parent_host_object_id */
/* delete possible definitions - TODO do that on startup */
DbQuery query1;
query1.Table = GetType()->GetTable() + "_parenthosts";
query1.Type = DbQueryDelete;
query1.WhereCriteria = boost::make_shared<Dictionary>();
query1.WhereCriteria->Set(GetType()->GetTable() + "_id", DbValue::FromObjectInsertID(GetObject()));
OnQuery(query1);
BOOST_FOREACH(const Host::Ptr& parent, host->GetParentHosts()) {
Log(LogDebug, "ido", "host parents: " + parent->GetName());
Dictionary::Ptr fields = boost::make_shared<Dictionary>();
fields->Set(GetType()->GetTable() + "_id", DbValue::FromObjectInsertID(GetObject()));
fields->Set("parent_host_object_id", parent);
fields->Set("instance_id", 0); /* DbConnection class fills in real ID */
DbQuery query2;
query2.Table = GetType()->GetTable() + "_parenthosts";
query2.Type = DbQueryInsert;
query2.Fields = fields;
OnQuery(query2);
}
}
void HostDbObject::OnStatusUpdate(void)
{
}

View File

@ -40,6 +40,10 @@ public:
virtual Dictionary::Ptr GetConfigFields(void) const; virtual Dictionary::Ptr GetConfigFields(void) const;
virtual Dictionary::Ptr GetStatusFields(void) const; virtual Dictionary::Ptr GetStatusFields(void) const;
private:
virtual void OnConfigUpdate(void);
virtual void OnStatusUpdate(void);
}; };
} }