summaryrefslogtreecommitdiff
path: root/cpp/src
diff options
context:
space:
mode:
authorKenneth Anthony Giusti <kgiusti@apache.org>2010-05-20 21:42:40 +0000
committerKenneth Anthony Giusti <kgiusti@apache.org>2010-05-20 21:42:40 +0000
commitf4325390e7653cb739a73a9029a9ca5a9976bb49 (patch)
tree3b8e5b72c28ac0804a08bc0377cb0770eecd1ab3 /cpp/src
parent2e056e55cf8c068d3b26a0dab83216d1d6438bb3 (diff)
downloadqpid-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/src')
-rw-r--r--cpp/src/qpid/management/ManagementAgent.cpp46
-rw-r--r--cpp/src/qpid/management/ManagementAgent.h2
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;