diff options
| author | Andrew Stitcher <astitcher@apache.org> | 2013-01-22 19:02:22 +0000 |
|---|---|---|
| committer | Andrew Stitcher <astitcher@apache.org> | 2013-01-22 19:02:22 +0000 |
| commit | 2cdc9df7213f1e19a032828e3574d5b87e7ac5f0 (patch) | |
| tree | fafcb45539003163ec5e455992df8e584ff26d83 /cpp | |
| parent | 0d54ccc0c7d3c3d2fa370e44ef69149f05514b9e (diff) | |
| download | qpid-python-2cdc9df7213f1e19a032828e3574d5b87e7ac5f0.tar.gz | |
NO-JIRA: Add abort() implementation for SSL client code - this make heartbeats
work for SSL client connections too.
git-svn-id: https://svn.apache.org/repos/asf/qpid/trunk/qpid@1437101 13f79535-47bb-0310-9956-ffa450edef68
Diffstat (limited to 'cpp')
| -rw-r--r-- | cpp/src/qpid/client/SslConnector.cpp | 22 |
1 files changed, 21 insertions, 1 deletions
diff --git a/cpp/src/qpid/client/SslConnector.cpp b/cpp/src/qpid/client/SslConnector.cpp index 3a146592e6..11707eb3f7 100644 --- a/cpp/src/qpid/client/SslConnector.cpp +++ b/cpp/src/qpid/client/SslConnector.cpp @@ -90,9 +90,11 @@ class SslConnector : public Connector void connect(const std::string& host, const std::string& port); void connected(const sys::Socket&); void connectFailed(const std::string& msg); + void close(); void send(framing::AMQFrame& frame); - void abort() {} // TODO: Need to fix for heartbeat timeouts to work + void abort(); + void connectAborted(); void setInputHandler(framing::InputHandler* handler); void setShutdownHandler(sys::ShutdownHandler* handler); @@ -224,6 +226,24 @@ void SslConnector::socketClosed(AsynchIO&, const Socket&) { shutdownHandler->shutdown(); } +void SslConnector::connectAborted() { + connector->stop(); + connectFailed("Connection timedout"); +} + +void SslConnector::abort() { + // Can't abort a closed connection + if (!closed) { + if (aio) { + // Established connection + aio->requestCallback(boost::bind(&SslConnector::eof, this, _1)); + } else if (connector) { + // We're still connecting + connector->requestCallback(boost::bind(&SslConnector::connectAborted, this)); + } + } +} + void SslConnector::setInputHandler(InputHandler* handler){ input = handler; } |
