]> granicus.if.org Git - icinga2/commitdiff
Implement status updates for services.
authorGunnar Beutner <gunnar.beutner@netways.de>
Wed, 24 Jul 2013 08:55:04 +0000 (10:55 +0200)
committerGunnar Beutner <gunnar.beutner@netways.de>
Wed, 24 Jul 2013 08:55:04 +0000 (10:55 +0200)
components/ido_mysql/mysqldbconnection.cpp
components/ido_mysql/mysqldbconnection.h
lib/base/dynamicobject.cpp
lib/base/dynamicobject.h
lib/ido/dbobject.cpp
lib/ido/dbobject.h
lib/ido/servicedbobject.cpp
lib/ido/servicedbobject.h

index 2e79ec0c241bba4a68e446c2cd46f4700a60a586..bcf9f5b2cc32bc80b4b419f8b9e8f91cf017f8ff 100644 (file)
@@ -244,7 +244,11 @@ Dictionary::Ptr MysqlDbConnection::FetchRow(MYSQL_RES *result)
 void MysqlDbConnection::ActivateObject(const DbObject::Ptr& dbobj)
 {
        boost::mutex::scoped_lock lock(m_ConnectionMutex);
+       InternalActivateObject(dbobj);
+}
 
+void MysqlDbConnection::InternalActivateObject(const DbObject::Ptr& dbobj)
+{
        if (!m_Connected)
                return;
 
@@ -282,6 +286,7 @@ void MysqlDbConnection::DeactivateObject(const DbObject::Ptr& dbobj)
        SetReference(dbobj, DbReference());
 }
 
+/* caller must hold m_ConnectionMutex */
 bool MysqlDbConnection::FieldToEscapedString(const String& key, const Value& value, Value *result)
 {
        if (key == "instance_id") {
@@ -300,7 +305,7 @@ bool MysqlDbConnection::FieldToEscapedString(const String& key, const Value& val
                DbReference dbrefcol = GetReference(dbobjcol);
 
                if (!dbrefcol.IsValid()) {
-                       ActivateObject(dbobjcol);
+                       InternalActivateObject(dbobjcol);
 
                        dbrefcol = GetReference(dbobjcol);
 
@@ -310,7 +315,7 @@ bool MysqlDbConnection::FieldToEscapedString(const String& key, const Value& val
 
                *result = static_cast<long>(dbrefcol);
        } else if (DbValue::IsTimestamp(value)) {
-               double ts = DbValue::ExtractValue(value);
+               long ts = DbValue::ExtractValue(value);
                std::ostringstream msgbuf;
                msgbuf << "FROM_UNIXTIME(" << ts << ")";
                *result = Value(msgbuf.str());
index 6384ffb48ffcf5c6ec7da452cbb9c60d38ea6470..62861558222bd212d0a764ab3acf7ae57a4cc5ac 100644 (file)
@@ -74,6 +74,7 @@ private:
        Dictionary::Ptr FetchRow(MYSQL_RES *result);
 
        bool FieldToEscapedString(const String& key, const Value& value, Value *result);
+       void InternalActivateObject(const DbObject::Ptr& dbobj);
 
        void TxTimerHandler(void);
        void ReconnectTimerHandler(void);
index 8bf1ef91c16090d248ee144feda90a22485d2cad..659e23acf0815b6d705c14ebb7c5503b4915cac9 100644 (file)
@@ -47,6 +47,7 @@ boost::signals2::signal<void (const DynamicObject::Ptr&)> DynamicObject::OnRegis
 boost::signals2::signal<void (const DynamicObject::Ptr&)> DynamicObject::OnUnregistered;
 boost::signals2::signal<void (double, const std::set<DynamicObject::WeakPtr>&)> DynamicObject::OnTransactionClosing;
 boost::signals2::signal<void (double, const DynamicObject::Ptr&)> DynamicObject::OnFlushObject;
+boost::signals2::signal<void (const DynamicObject::Ptr&, const std::set<String, string_iless>&)> DynamicObject::OnAttributesChanged;
 
 DynamicObject::DynamicObject(const Dictionary::Ptr& serializedObject)
        : m_ConfigTx(0), m_LocalTx(0), m_Registered(false)
@@ -627,6 +628,8 @@ void DynamicObject::NewTx(void)
                        attrs.swap(object->m_ModifiedAttributes);
                }
 
+               OnAttributesChanged(object, attrs);
+
                BOOST_FOREACH(const String& attr, attrs) {
                        object->OnAttributeChanged(attr);
                }
index 39e96e238cf88bf9fbffab9753c1fe8e69e20b64..ba6b419d4a86086b37b046f9593f56ed0801dd6f 100644 (file)
@@ -69,6 +69,7 @@ public:
        static boost::signals2::signal<void (const DynamicObject::Ptr&)> OnUnregistered;
        static boost::signals2::signal<void (double, const std::set<DynamicObject::WeakPtr>&)> OnTransactionClosing;
        static boost::signals2::signal<void (double, const DynamicObject::Ptr&)> OnFlushObject;
+       static boost::signals2::signal<void (const DynamicObject::Ptr&, const std::set<String, string_iless>&)> OnAttributesChanged;
 
        Value InvokeMethod(const String& method, const std::vector<Value>& arguments);
 
index 4d1e9920cfb054719b2ff6657d896fdd48bc0521..c19aad7b90369f6a613379e7e768168347f9dacd 100644 (file)
@@ -23,6 +23,7 @@
 #include "base/dynamictype.h"
 #include "base/objectlock.h"
 #include "base/utility.h"
+#include "base/logger_fwd.h"
 #include <boost/foreach.hpp>
 
 using namespace icinga;
@@ -32,15 +33,14 @@ boost::signals2::signal<void (const DbObject::Ptr&)> DbObject::OnUnregistered;
 boost::signals2::signal<void (const DbQuery&)> DbObject::OnQuery;
 
 DbObject::DbObject(const shared_ptr<DbType>& type, const String& name1, const String& name2)
-       : m_Name1(name1), m_Name2(name2), m_Type(type)
+       : m_Name1(name1), m_Name2(name2), m_Type(type), m_LastConfigUpdate(0), m_LastStatusUpdate(0)
 { }
 
 void DbObject::StaticInitialize(void)
 {
        DynamicObject::OnRegistered.connect(boost::bind(&DbObject::ObjectRegisteredHandler, _1));
        DynamicObject::OnUnregistered.connect(boost::bind(&DbObject::ObjectUnregisteredHandler, _1));
-//     DynamicObject::OnTransactionClosing.connect(boost::bind(&DbObject::TransactionClosingHandler, _1, _2));
-//     DynamicObject::OnFlushObject.connect(boost::bind(&DbObject::FlushObjectHandler, _1, _2));
+       DynamicObject::OnAttributesChanged.connect(boost::bind(&DbObject::AttributesChangedHandler, _1, _2));
 }
 
 void DbObject::SetObject(const DynamicObject::Ptr& object)
@@ -90,6 +90,8 @@ void DbObject::SendConfigUpdate(void)
        query2.Fields->Set("instance_id", 0); /* DbConnection class fills in real ID */
        query2.Fields->Set("config_type", 1);
        OnQuery(query2);
+
+       m_LastConfigUpdate = Utility::GetTime();
 }
 
 void DbObject::SendStatusUpdate(void)
@@ -114,6 +116,37 @@ void DbObject::SendStatusUpdate(void)
        query2.Fields->Set("instance_id", 0); /* DbConnection class fills in real ID */
        query2.Fields->Set("status_update_time", Utility::FormatDateTime("%Y-%m-%d %H:%M:%S", Utility::GetTime()));
        OnQuery(query2);
+
+       m_LastStatusUpdate = Utility::GetTime();
+}
+
+double DbObject::GetLastConfigUpdate(void) const
+{
+       return m_LastConfigUpdate;
+}
+
+double DbObject::GetLastStatusUpdate(void) const
+{
+       return m_LastStatusUpdate;
+}
+
+bool DbObject::IsConfigAttribute(const String& attribute) const
+{
+       DynamicObject::Ptr object = GetObject();
+       ObjectLock olock(object);
+       DynamicObject::AttributeConstIterator it;
+
+       it = object->GetAttributes().find(attribute);
+
+       if (it == object->GetAttributes().end())
+               return false;
+
+       return (it->second.GetType() == Attribute_Config);
+}
+
+bool DbObject::IsStatusAttribute(const String&) const
+{
+       return false;
 }
 
 DbObject::Ptr DbObject::GetOrCreateByObject(const DynamicObject::Ptr& object)
@@ -145,7 +178,7 @@ DbObject::Ptr DbObject::GetOrCreateByObject(const DynamicObject::Ptr& object)
                name1 = object->GetName();
        }
 
-       dbobj = dbtype->GetOrCreateObjectByName(object->GetName(), String());
+       dbobj = dbtype->GetOrCreateObjectByName(name1, name2);
 
        {
                ObjectLock olock(object);
@@ -185,24 +218,26 @@ void DbObject::ObjectUnregisteredHandler(const DynamicObject::Ptr& object)
        }
 }
 
-//void DbObject::TransactionClosingHandler(double tx, const std::set<DynamicObject::WeakPtr>& modifiedObjects)
-//{
-//        BOOST_FOREACH(const DynamicObject::WeakPtr& wobject, modifiedObjects) {
-//                DynamicObject::Ptr object = wobject.lock();
-//
-//                if (!object)
-//                        continue;
-//
-//                FlushObjectHandler(tx, object);
-//        }
-//}
-//
-//void DbObject::FlushObjectHandler(double tx, const DynamicObject::Ptr& object)
-//{
-//     DbObject::Ptr dbobj = GetOrCreateByObject(object);
-//
-//     if (!dbobj)
-//             return;
-//
-//     dbobj->SendUpdate();
-//}
+void DbObject::AttributesChangedHandler(const DynamicObject::Ptr& object, const std::set<String, string_iless>& attributes)
+{
+       DbObject::Ptr dbobj = GetOrCreateByObject(object);
+
+       if (!dbobj)
+               return;
+
+       bool configUpdate = false, statusUpdate = false;
+
+       BOOST_FOREACH(const String& attribute, attributes) {
+               if (!configUpdate && dbobj->IsConfigAttribute(attribute))
+                       configUpdate = true;
+
+               if (!statusUpdate && dbobj->IsStatusAttribute(attribute))
+                       statusUpdate = true;
+       }
+
+       if (configUpdate)
+               dbobj->SendConfigUpdate();
+
+       if (statusUpdate)
+               dbobj->SendStatusUpdate();
+}
index c2a124622a98bea7e64fbad79b305cf46d5ec876..e1b351904a6fd1bcfdbe4d14e9e7eac724ab9671 100644 (file)
@@ -65,14 +65,22 @@ public:
        void SendConfigUpdate(void);
        void SendStatusUpdate(void);
 
+       double GetLastConfigUpdate(void) const;
+       double GetLastStatusUpdate(void) const;
+
 protected:
        DbObject(const boost::shared_ptr<DbType>& type, const String& name1, const String& name2);
 
+       virtual bool IsConfigAttribute(const String& attribute) const;
+       virtual bool IsStatusAttribute(const String& attribute) const;
+
 private:
        String m_Name1;
        String m_Name2;
        boost::shared_ptr<DbType> m_Type;
        DynamicObject::Ptr m_Object;
+       double m_LastConfigUpdate;
+       double m_LastStatusUpdate;
 
        friend boost::shared_ptr<DbObject> boost::make_shared<>(const icinga::String&, const icinga::String&);
 
@@ -80,6 +88,7 @@ private:
 
        static void ObjectRegisteredHandler(const DynamicObject::Ptr& object);
        static void ObjectUnregisteredHandler(const DynamicObject::Ptr& object);
+       static void AttributesChangedHandler(const DynamicObject::Ptr& object, const std::set<String, string_iless>& attributes);
        //static void TransactionClosingHandler(double tx, const std::set<DynamicObject::WeakPtr>& modifiedObjects);
        //static void FlushObjectHandler(double tx, const DynamicObject::Ptr& object);
 
index 7d61bd9a6731a2508a43ae56dd9f82962228bc58..576f27341becca68e2b77b28a65af6620b83835c 100644 (file)
@@ -145,4 +145,9 @@ Dictionary::Ptr ServiceDbObject::GetStatusFields(void) const
 
 
        return fields;
+}
+
+bool ServiceDbObject::IsStatusAttribute(const String& attribute) const
+{
+       return (attribute == "last_result");
 }
\ No newline at end of file
index d6b06088880ece8282f87942d5585210691a34ff..28a98b92aff34b294e8d429a9f74e52edf59de0e 100644 (file)
@@ -40,6 +40,8 @@ public:
 
        virtual Dictionary::Ptr GetConfigFields(void) const;
        virtual Dictionary::Ptr GetStatusFields(void) const;
+
+       virtual bool IsStatusAttribute(const String& attribute) const;
 };
 
 }