From: Gunnar Beutner Date: Thu, 26 Apr 2012 19:33:23 +0000 (+0200) Subject: Cleaned up reconnection code. X-Git-Tag: v0.0.1~576 X-Git-Url: https://granicus.if.org/sourcecode?a=commitdiff_plain;h=3825e2902f96433adfcab1160992203fc9ab768c;p=icinga2 Cleaned up reconnection code. --- diff --git a/base/tcpclient.cpp b/base/tcpclient.cpp index 7b13db5ce..e609e5116 100644 --- a/base/tcpclient.cpp +++ b/base/tcpclient.cpp @@ -8,8 +8,6 @@ TCPClient::TCPClient(TCPClientRole role) m_SendQueue = make_shared(); m_RecvQueue = make_shared(); - - m_PeerPort = 0; } TCPClientRole TCPClient::GetRole(void) const @@ -52,8 +50,6 @@ void TCPClient::Connect(const string& hostname, unsigned short port) } m_Role = RoleOutbound; - m_PeerHost = hostname; - m_PeerPort = port; } FIFO::Ptr TCPClient::GetSendQueue(void) @@ -66,17 +62,6 @@ FIFO::Ptr TCPClient::GetRecvQueue(void) return m_RecvQueue; } - -string TCPClient::GetPeerHost(void) -{ - return m_PeerHost; -} - -int TCPClient::GetPeerPort(void) -{ - return m_PeerPort; -} - int TCPClient::ReadableEventHandler(const EventArgs& ea) { int rc; diff --git a/base/tcpclient.h b/base/tcpclient.h index 7395e5f3e..d2b383251 100644 --- a/base/tcpclient.h +++ b/base/tcpclient.h @@ -15,9 +15,6 @@ class I2_BASE_API TCPClient : public TCPSocket private: TCPClientRole m_Role; - string m_PeerHost; - int m_PeerPort; - FIFO::Ptr m_SendQueue; FIFO::Ptr m_RecvQueue; @@ -39,9 +36,6 @@ public: FIFO::Ptr GetSendQueue(void); FIFO::Ptr GetRecvQueue(void); - string GetPeerHost(void); - int GetPeerPort(void); - virtual bool WantsToRead(void) const; virtual bool WantsToWrite(void) const; diff --git a/base/tcpsocket.cpp b/base/tcpsocket.cpp index 9172106c6..82239ef58 100644 --- a/base/tcpsocket.cpp +++ b/base/tcpsocket.cpp @@ -67,7 +67,7 @@ string TCPSocket::GetAddressFromSockaddr(sockaddr *address) else IpAddress = &(((sockaddr_in6 *)address)->sin6_addr); - if (inet_ntop(address->sa_family, address, buffer, sizeof(buffer)) == NULL) + if (inet_ntop(address->sa_family, IpAddress, buffer, sizeof(buffer)) == NULL) return string(); #endif /* _WIN32 */ @@ -87,27 +87,38 @@ unsigned short TCPSocket::GetPortFromSockaddr(sockaddr *address) } } -void TCPSocket::GetClientSockaddr(sockaddr_storage *address) +bool TCPSocket::GetClientSockaddr(sockaddr_storage *address) { socklen_t len = sizeof(*address); - if (getsockname(GetFD(), (sockaddr *)address, &len) < 0) + if (getsockname(GetFD(), (sockaddr *)address, &len) < 0) { HandleSocketError(); + + return false; + } + + return true; } -void TCPSocket::GetPeerSockaddr(sockaddr_storage *address) +bool TCPSocket::GetPeerSockaddr(sockaddr_storage *address) { socklen_t len = sizeof(*address); - if (getpeername(GetFD(), (sockaddr *)address, &len) < 0) + if (getpeername(GetFD(), (sockaddr *)address, &len) < 0) { HandleSocketError(); + + return false; + } + + return true; } string TCPSocket::GetClientAddress(void) { sockaddr_storage sin; - GetClientSockaddr(&sin); + if (!GetClientSockaddr(&sin)) + return ""; return GetAddressFromSockaddr((sockaddr *)&sin); } @@ -116,7 +127,8 @@ string TCPSocket::GetPeerAddress(void) { sockaddr_storage sin; - GetPeerSockaddr(&sin); + if (!GetPeerSockaddr(&sin)) + return ""; return GetAddressFromSockaddr((sockaddr *)&sin); } diff --git a/base/tcpsocket.h b/base/tcpsocket.h index e661b2da6..2373d2e1f 100644 --- a/base/tcpsocket.h +++ b/base/tcpsocket.h @@ -19,8 +19,8 @@ public: void Bind(unsigned short port); void Bind(const char *hostname, unsigned short port); - void GetClientSockaddr(sockaddr_storage *address); - void GetPeerSockaddr(sockaddr_storage *address); + bool GetClientSockaddr(sockaddr_storage *address); + bool GetPeerSockaddr(sockaddr_storage *address); string GetClientAddress(void); string GetPeerAddress(void); diff --git a/icinga/endpointmanager.cpp b/icinga/endpointmanager.cpp index c6b028068..b9adab381 100644 --- a/icinga/endpointmanager.cpp +++ b/icinga/endpointmanager.cpp @@ -9,7 +9,9 @@ EndpointManager::EndpointManager(shared_ptr sslContext) void EndpointManager::AddListener(unsigned short port) { - Application::Log("Adding new listener: port " + port); + stringstream s; + s << "Adding new listener: port " << port; + Application::Log(s.str()); JsonRpcServer::Ptr server = make_shared(m_SSLContext); RegisterServer(server); diff --git a/icinga/jsonrpcendpoint.cpp b/icinga/jsonrpcendpoint.cpp index 2b3dacaea..2ec80924e 100644 --- a/icinga/jsonrpcendpoint.cpp +++ b/icinga/jsonrpcendpoint.cpp @@ -59,6 +59,9 @@ bool JsonRpcEndpoint::IsAllowedMethodSource(string method) const void JsonRpcEndpoint::Connect(string host, unsigned short port, shared_ptr sslContext) { + m_PeerHostname = host; + m_PeerPort = port; + JsonRpcClient::Ptr client = make_shared(RoleOutbound, sslContext); client->MakeSocket(); client->Connect(host, port); @@ -140,7 +143,7 @@ int JsonRpcEndpoint::ClientClosedHandler(const EventArgs& ea) m_PendingCalls.clear(); - if (m_Client->GetPeerHost() != string()) { + if (m_PeerHostname != string()) { Timer::Ptr timer = make_shared(); timer->SetInterval(30); timer->SetUserArgs(ea); @@ -178,7 +181,7 @@ int JsonRpcEndpoint::ClientReconnectHandler(const TimerEventArgs& ea) JsonRpcClient::Ptr client = static_pointer_cast(ea.UserArgs.Source); Timer::Ptr timer = static_pointer_cast(ea.Source); - GetEndpointManager()->AddConnection(client->GetPeerHost(), client->GetPeerPort()); + GetEndpointManager()->AddConnection(m_PeerHostname, m_PeerPort); timer->Stop(); m_ReconnectTimer.reset(); diff --git a/icinga/jsonrpcendpoint.h b/icinga/jsonrpcendpoint.h index 234ccfb0e..b2340386a 100644 --- a/icinga/jsonrpcendpoint.h +++ b/icinga/jsonrpcendpoint.h @@ -15,6 +15,9 @@ private: set m_AllowedMethodSinkPrefixes; set m_AllowedMethodSourcePrefixes; + string m_PeerHostname; + unsigned short m_PeerPort; + bool IsConnected(void) const; int NewMessageHandler(const NewMessageEventArgs& nmea);