diff options
author | Kenneth Anthony Giusti <kgiusti@apache.org> | 2010-05-20 21:42:40 +0000 |
---|---|---|
committer | Kenneth Anthony Giusti <kgiusti@apache.org> | 2010-05-20 21:42:40 +0000 |
commit | f4325390e7653cb739a73a9029a9ca5a9976bb49 (patch) | |
tree | 3b8e5b72c28ac0804a08bc0377cb0770eecd1ab3 /cpp | |
parent | 2e056e55cf8c068d3b26a0dab83216d1d6438bb3 (diff) | |
download | qpid-python-f4325390e7653cb739a73a9029a9ca5a9976bb49.tar.gz |
QMF: provide event filter api for python console
git-svn-id: https://svn.apache.org/repos/asf/qpid/trunk/qpid@946801 13f79535-47bb-0310-9956-ffa450edef68
Diffstat (limited to 'cpp')
-rw-r--r-- | cpp/src/qpid/management/ManagementAgent.cpp | 46 | ||||
-rw-r--r-- | cpp/src/qpid/management/ManagementAgent.h | 2 |
2 files changed, 37 insertions, 11 deletions
diff --git a/cpp/src/qpid/management/ManagementAgent.cpp b/cpp/src/qpid/management/ManagementAgent.cpp index 39ac2d11af..7f2dd69b52 100644 --- a/cpp/src/qpid/management/ManagementAgent.cpp +++ b/cpp/src/qpid/management/ManagementAgent.cpp @@ -52,6 +52,25 @@ using namespace std; namespace _qmf = qmf::org::apache::qpid::broker; +namespace { + const string defaultVendorName("vendor"); + const string defaultProductName("product"); + + // Create a valid binding key substring by + // replacing all '.' chars with '_' + const string keyifyNameStr(const string& name) + { + string n2 = name; + + size_t pos = n2.find('.'); + while (pos != n2.npos) { + n2.replace(pos, 1, "_"); + pos = n2.find('.', pos); + } + return n2; + } +} + static Variant::Map mapEncodeSchemaId(const string& pname, const string& cname, @@ -81,6 +100,7 @@ ManagementAgent::ManagementAgent (const bool qmfV1, const bool qmfV2) : threadPoolSize(1), interval(10), broker(0), timer(0), startTime(sys::now()), suppressed(false), disallowAllV1Methods(false), + vendorNameKey(defaultVendorName), productNameKey(defaultProductName), qmf1Support(qmfV1), qmf2Support(qmfV2) { nextObjectId = 1; @@ -89,6 +109,8 @@ ManagementAgent::ManagementAgent (const bool qmfV1, const bool qmfV2) : nextRemoteBank = 10; nextRequestSequence = 1; clientWasAdded = false; + attrMap["_vendor"] = defaultVendorName; + attrMap["_product"] = defaultProductName; } ManagementAgent::~ManagementAgent () @@ -190,6 +212,9 @@ void ManagementAgent::setName(const string& vendor, const string& product, const name_address = vendor + ":" + product + ":" + inst; attrMap["_instance"] = inst; attrMap["_name"] = name_address; + + vendorNameKey = keyifyNameStr(vendor); + productNameKey = keyifyNameStr(product); } @@ -300,6 +325,10 @@ ObjectId ManagementAgent::addObject(ManagementObject* object, void ManagementAgent::raiseEvent(const ManagementEvent& event, severity_t severity) { + static const std::string severityStr[] = { + "emerg", "alert", "crit", "error", "warn", + "note", "info", "debug" + }; sys::Mutex::ScopedLock lock (userLock); uint8_t sev = (severity == SEV_DEFAULT) ? event.getSeverity() : (uint8_t) severity; @@ -344,7 +373,11 @@ void ManagementAgent::raiseEvent(const ManagementEvent& event, severity_t severi headers["qmf.agent"] = name_address; stringstream key; - key << "agent.ind.event." << sev << "." << name_address << "." << event.getEventName(); + key << "agent.ind.event." << vendorNameKey + << "." << productNameKey + << "." << severityStr[sev] + << "." << keyifyNameStr(event.getPackageName()) + << "." << keyifyNameStr(event.getEventName()); string content; MapCodec::encode(map_, content); @@ -720,16 +753,7 @@ void ManagementAgent::periodicProcessing (void) if (qmf2Support) { std::stringstream addr_key; - addr_key << "agent.ind.heartbeat"; - - // append .<vendor>.<product> to address key if present. - Variant::Map::const_iterator v; - if ((v = attrMap.find("_vendor")) != attrMap.end()){ - addr_key << "." << v->second.getString(); - if ((v = attrMap.find("_product")) != attrMap.end()) { - addr_key << "." << v->second.getString(); - } - } + addr_key << "agent.ind.heartbeat." << vendorNameKey << "." << productNameKey; Variant::Map map; Variant::Map headers; diff --git a/cpp/src/qpid/management/ManagementAgent.h b/cpp/src/qpid/management/ManagementAgent.h index a1c6f3ce24..d101ca198e 100644 --- a/cpp/src/qpid/management/ManagementAgent.h +++ b/cpp/src/qpid/management/ManagementAgent.h @@ -282,6 +282,8 @@ private: // Agent name and address qpid::types::Variant::Map attrMap; std::string name_address; + std::string vendorNameKey; // "." --> "_" + std::string productNameKey; // "." --> "_" // supported management protocol bool qmf1Support; |