You are viewing a plain text version of this content. The canonical link for it is here.
Posted to commits@qpid.apache.org by mg...@apache.org on 2011/12/16 14:40:59 UTC

svn commit: r1215127 - in /qpid/trunk/qpid/cpp/src/qpid: broker/Connection.cpp broker/Connection.h broker/SaslAuthenticator.cpp cluster/Cluster.cpp cluster/Cluster.h cluster/Connection.cpp

Author: mgoulish
Date: Fri Dec 16 13:40:58 2011
New Revision: 1215127

URL: http://svn.apache.org/viewvc?rev=1215127&view=rev
Log:
QPID-3438
fix cluster causing cnx leak when bad credentials are given in login attempt.

Modified:
    qpid/trunk/qpid/cpp/src/qpid/broker/Connection.cpp
    qpid/trunk/qpid/cpp/src/qpid/broker/Connection.h
    qpid/trunk/qpid/cpp/src/qpid/broker/SaslAuthenticator.cpp
    qpid/trunk/qpid/cpp/src/qpid/cluster/Cluster.cpp
    qpid/trunk/qpid/cpp/src/qpid/cluster/Cluster.h
    qpid/trunk/qpid/cpp/src/qpid/cluster/Connection.cpp

Modified: qpid/trunk/qpid/cpp/src/qpid/broker/Connection.cpp
URL: http://svn.apache.org/viewvc/qpid/trunk/qpid/cpp/src/qpid/broker/Connection.cpp?rev=1215127&r1=1215126&r2=1215127&view=diff
==============================================================================
--- qpid/trunk/qpid/cpp/src/qpid/broker/Connection.cpp (original)
+++ qpid/trunk/qpid/cpp/src/qpid/broker/Connection.cpp Fri Dec 16 13:40:58 2011
@@ -100,7 +100,8 @@ Connection::Connection(ConnectionOutputH
     errorListener(0),
     objectId(objectId_),
     shadow(shadow_),
-    outboundTracker(*this)
+    outboundTracker(*this),
+    securityFailed(false)
 {
     outboundTracker.wrap(out);
     if (isLink)

Modified: qpid/trunk/qpid/cpp/src/qpid/broker/Connection.h
URL: http://svn.apache.org/viewvc/qpid/trunk/qpid/cpp/src/qpid/broker/Connection.h?rev=1215127&r1=1215126&r2=1215127&view=diff
==============================================================================
--- qpid/trunk/qpid/cpp/src/qpid/broker/Connection.h (original)
+++ qpid/trunk/qpid/cpp/src/qpid/broker/Connection.h Fri Dec 16 13:40:58 2011
@@ -205,9 +205,15 @@ class Connection : public sys::Connectio
     };
     OutboundFrameTracker outboundTracker;
 
-
     void sent(const framing::AMQFrame& f);
+
+    bool securityFailed;
+
   public:
+
+    bool securityFailure ( ) const { return securityFailed; }
+    void securityFailure ( bool failed ) { securityFailed = failed; }
+
     qmf::org::apache::qpid::broker::Connection* getMgmtObject() { return mgmtObject; }
 };
 

Modified: qpid/trunk/qpid/cpp/src/qpid/broker/SaslAuthenticator.cpp
URL: http://svn.apache.org/viewvc/qpid/trunk/qpid/cpp/src/qpid/broker/SaslAuthenticator.cpp?rev=1215127&r1=1215126&r2=1215127&view=diff
==============================================================================
--- qpid/trunk/qpid/cpp/src/qpid/broker/SaslAuthenticator.cpp (original)
+++ qpid/trunk/qpid/cpp/src/qpid/broker/SaslAuthenticator.cpp Fri Dec 16 13:40:58 2011
@@ -450,6 +450,7 @@ void CyrusAuthenticator::processAuthenti
 
         client.secure(challenge_str);
     } else {
+        connection.securityFailure ( true );
         std::string uid;
         //save error detail before trying to retrieve username as error in doing so will overwrite it
         std::string errordetail = sasl_errdetail(sasl_conn);

Modified: qpid/trunk/qpid/cpp/src/qpid/cluster/Cluster.cpp
URL: http://svn.apache.org/viewvc/qpid/trunk/qpid/cpp/src/qpid/cluster/Cluster.cpp?rev=1215127&r1=1215126&r2=1215127&view=diff
==============================================================================
--- qpid/trunk/qpid/cpp/src/qpid/cluster/Cluster.cpp (original)
+++ qpid/trunk/qpid/cpp/src/qpid/cluster/Cluster.cpp Fri Dec 16 13:40:58 2011
@@ -383,12 +383,21 @@ void Cluster::erase(const ConnectionId& 
     erase(id,l);
 }
 
+void Cluster::eraseLocal(const ConnectionId& id) {
+    Lock l(lock);
+    eraseLocal(id,l);
+}
+
 // Called by Connection::deliverClose() in deliverFrameQueue thread.
 void Cluster::erase(const ConnectionId& id, Lock&) {
     connections.erase(id);
     decoder.erase(id);
 }
 
+void Cluster::eraseLocal(const ConnectionId& id, Lock&) {
+    localConnections.getErase(id);
+}
+
 std::vector<string> Cluster::getIds() const {
     Lock l(lock);
     return getIds(l);

Modified: qpid/trunk/qpid/cpp/src/qpid/cluster/Cluster.h
URL: http://svn.apache.org/viewvc/qpid/trunk/qpid/cpp/src/qpid/cluster/Cluster.h?rev=1215127&r1=1215126&r2=1215127&view=diff
==============================================================================
--- qpid/trunk/qpid/cpp/src/qpid/cluster/Cluster.h (original)
+++ qpid/trunk/qpid/cpp/src/qpid/cluster/Cluster.h Fri Dec 16 13:40:58 2011
@@ -101,6 +101,7 @@ class Cluster : private Cpg::Handler, pu
     void addLocalConnection(const ConnectionPtr&);
     void addShadowConnection(const ConnectionPtr&);
     void erase(const ConnectionId&);
+    void eraseLocal(const ConnectionId&);
 
     // URLs of current cluster members.
     std::vector<std::string> getIds() const;
@@ -212,6 +213,7 @@ class Cluster : private Cpg::Handler, pu
     void memberUpdate(Lock&);
     void setClusterId(const framing::Uuid&, Lock&);
     void erase(const ConnectionId&, Lock&);
+    void eraseLocal(const ConnectionId&, Lock&);
     void requestUpdate(Lock& );
     void initMapCompleted(Lock&);
     void becomeElder(Lock&);

Modified: qpid/trunk/qpid/cpp/src/qpid/cluster/Connection.cpp
URL: http://svn.apache.org/viewvc/qpid/trunk/qpid/cpp/src/qpid/cluster/Connection.cpp?rev=1215127&r1=1215126&r2=1215127&view=diff
==============================================================================
--- qpid/trunk/qpid/cpp/src/qpid/cluster/Connection.cpp (original)
+++ qpid/trunk/qpid/cpp/src/qpid/cluster/Connection.cpp Fri Dec 16 13:40:58 2011
@@ -738,8 +738,13 @@ void Connection::sessionError(uint16_t ,
 
 void Connection::connectionError(const std::string& msg) {
     // Ignore errors before isOpen(), we're not multicasting yet.
-    if (connection->isOpen())
+    if (connection->isOpen()) {
         cluster.flagError(*this, ERROR_TYPE_CONNECTION, msg);
+    }
+    else
+    if ( connection->securityFailure() ) {
+      cluster.eraseLocal(self);
+    }
 }
 
 void Connection::addQueueListener(const std::string& q, uint32_t listener) {



---------------------------------------------------------------------
Apache Qpid - AMQP Messaging Implementation
Project:      http://qpid.apache.org
Use/Interact: mailto:commits-subscribe@qpid.apache.org