mirror of
https://github.com/Icinga/icinga2.git
synced 2025-07-23 21:55:03 +02:00
Cleaned up reconnection code.
This commit is contained in:
parent
c01477ff62
commit
3825e2902f
@ -8,8 +8,6 @@ TCPClient::TCPClient(TCPClientRole role)
|
|||||||
|
|
||||||
m_SendQueue = make_shared<FIFO>();
|
m_SendQueue = make_shared<FIFO>();
|
||||||
m_RecvQueue = make_shared<FIFO>();
|
m_RecvQueue = make_shared<FIFO>();
|
||||||
|
|
||||||
m_PeerPort = 0;
|
|
||||||
}
|
}
|
||||||
|
|
||||||
TCPClientRole TCPClient::GetRole(void) const
|
TCPClientRole TCPClient::GetRole(void) const
|
||||||
@ -52,8 +50,6 @@ void TCPClient::Connect(const string& hostname, unsigned short port)
|
|||||||
}
|
}
|
||||||
|
|
||||||
m_Role = RoleOutbound;
|
m_Role = RoleOutbound;
|
||||||
m_PeerHost = hostname;
|
|
||||||
m_PeerPort = port;
|
|
||||||
}
|
}
|
||||||
|
|
||||||
FIFO::Ptr TCPClient::GetSendQueue(void)
|
FIFO::Ptr TCPClient::GetSendQueue(void)
|
||||||
@ -66,17 +62,6 @@ FIFO::Ptr TCPClient::GetRecvQueue(void)
|
|||||||
return m_RecvQueue;
|
return m_RecvQueue;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|
||||||
string TCPClient::GetPeerHost(void)
|
|
||||||
{
|
|
||||||
return m_PeerHost;
|
|
||||||
}
|
|
||||||
|
|
||||||
int TCPClient::GetPeerPort(void)
|
|
||||||
{
|
|
||||||
return m_PeerPort;
|
|
||||||
}
|
|
||||||
|
|
||||||
int TCPClient::ReadableEventHandler(const EventArgs& ea)
|
int TCPClient::ReadableEventHandler(const EventArgs& ea)
|
||||||
{
|
{
|
||||||
int rc;
|
int rc;
|
||||||
|
@ -15,9 +15,6 @@ class I2_BASE_API TCPClient : public TCPSocket
|
|||||||
private:
|
private:
|
||||||
TCPClientRole m_Role;
|
TCPClientRole m_Role;
|
||||||
|
|
||||||
string m_PeerHost;
|
|
||||||
int m_PeerPort;
|
|
||||||
|
|
||||||
FIFO::Ptr m_SendQueue;
|
FIFO::Ptr m_SendQueue;
|
||||||
FIFO::Ptr m_RecvQueue;
|
FIFO::Ptr m_RecvQueue;
|
||||||
|
|
||||||
@ -39,9 +36,6 @@ public:
|
|||||||
FIFO::Ptr GetSendQueue(void);
|
FIFO::Ptr GetSendQueue(void);
|
||||||
FIFO::Ptr GetRecvQueue(void);
|
FIFO::Ptr GetRecvQueue(void);
|
||||||
|
|
||||||
string GetPeerHost(void);
|
|
||||||
int GetPeerPort(void);
|
|
||||||
|
|
||||||
virtual bool WantsToRead(void) const;
|
virtual bool WantsToRead(void) const;
|
||||||
virtual bool WantsToWrite(void) const;
|
virtual bool WantsToWrite(void) const;
|
||||||
|
|
||||||
|
@ -67,7 +67,7 @@ string TCPSocket::GetAddressFromSockaddr(sockaddr *address)
|
|||||||
else
|
else
|
||||||
IpAddress = &(((sockaddr_in6 *)address)->sin6_addr);
|
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();
|
return string();
|
||||||
#endif /* _WIN32 */
|
#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);
|
socklen_t len = sizeof(*address);
|
||||||
|
|
||||||
if (getsockname(GetFD(), (sockaddr *)address, &len) < 0)
|
if (getsockname(GetFD(), (sockaddr *)address, &len) < 0) {
|
||||||
HandleSocketError();
|
HandleSocketError();
|
||||||
|
|
||||||
|
return false;
|
||||||
|
}
|
||||||
|
|
||||||
|
return true;
|
||||||
}
|
}
|
||||||
|
|
||||||
void TCPSocket::GetPeerSockaddr(sockaddr_storage *address)
|
bool TCPSocket::GetPeerSockaddr(sockaddr_storage *address)
|
||||||
{
|
{
|
||||||
socklen_t len = sizeof(*address);
|
socklen_t len = sizeof(*address);
|
||||||
|
|
||||||
if (getpeername(GetFD(), (sockaddr *)address, &len) < 0)
|
if (getpeername(GetFD(), (sockaddr *)address, &len) < 0) {
|
||||||
HandleSocketError();
|
HandleSocketError();
|
||||||
|
|
||||||
|
return false;
|
||||||
|
}
|
||||||
|
|
||||||
|
return true;
|
||||||
}
|
}
|
||||||
|
|
||||||
string TCPSocket::GetClientAddress(void)
|
string TCPSocket::GetClientAddress(void)
|
||||||
{
|
{
|
||||||
sockaddr_storage sin;
|
sockaddr_storage sin;
|
||||||
|
|
||||||
GetClientSockaddr(&sin);
|
if (!GetClientSockaddr(&sin))
|
||||||
|
return "";
|
||||||
|
|
||||||
return GetAddressFromSockaddr((sockaddr *)&sin);
|
return GetAddressFromSockaddr((sockaddr *)&sin);
|
||||||
}
|
}
|
||||||
@ -116,7 +127,8 @@ string TCPSocket::GetPeerAddress(void)
|
|||||||
{
|
{
|
||||||
sockaddr_storage sin;
|
sockaddr_storage sin;
|
||||||
|
|
||||||
GetPeerSockaddr(&sin);
|
if (!GetPeerSockaddr(&sin))
|
||||||
|
return "";
|
||||||
|
|
||||||
return GetAddressFromSockaddr((sockaddr *)&sin);
|
return GetAddressFromSockaddr((sockaddr *)&sin);
|
||||||
}
|
}
|
||||||
|
@ -19,8 +19,8 @@ public:
|
|||||||
void Bind(unsigned short port);
|
void Bind(unsigned short port);
|
||||||
void Bind(const char *hostname, unsigned short port);
|
void Bind(const char *hostname, unsigned short port);
|
||||||
|
|
||||||
void GetClientSockaddr(sockaddr_storage *address);
|
bool GetClientSockaddr(sockaddr_storage *address);
|
||||||
void GetPeerSockaddr(sockaddr_storage *address);
|
bool GetPeerSockaddr(sockaddr_storage *address);
|
||||||
|
|
||||||
string GetClientAddress(void);
|
string GetClientAddress(void);
|
||||||
string GetPeerAddress(void);
|
string GetPeerAddress(void);
|
||||||
|
@ -9,7 +9,9 @@ EndpointManager::EndpointManager(shared_ptr<SSL_CTX> sslContext)
|
|||||||
|
|
||||||
void EndpointManager::AddListener(unsigned short port)
|
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<JsonRpcServer>(m_SSLContext);
|
JsonRpcServer::Ptr server = make_shared<JsonRpcServer>(m_SSLContext);
|
||||||
RegisterServer(server);
|
RegisterServer(server);
|
||||||
|
@ -59,6 +59,9 @@ bool JsonRpcEndpoint::IsAllowedMethodSource(string method) const
|
|||||||
|
|
||||||
void JsonRpcEndpoint::Connect(string host, unsigned short port, shared_ptr<SSL_CTX> sslContext)
|
void JsonRpcEndpoint::Connect(string host, unsigned short port, shared_ptr<SSL_CTX> sslContext)
|
||||||
{
|
{
|
||||||
|
m_PeerHostname = host;
|
||||||
|
m_PeerPort = port;
|
||||||
|
|
||||||
JsonRpcClient::Ptr client = make_shared<JsonRpcClient>(RoleOutbound, sslContext);
|
JsonRpcClient::Ptr client = make_shared<JsonRpcClient>(RoleOutbound, sslContext);
|
||||||
client->MakeSocket();
|
client->MakeSocket();
|
||||||
client->Connect(host, port);
|
client->Connect(host, port);
|
||||||
@ -140,7 +143,7 @@ int JsonRpcEndpoint::ClientClosedHandler(const EventArgs& ea)
|
|||||||
|
|
||||||
m_PendingCalls.clear();
|
m_PendingCalls.clear();
|
||||||
|
|
||||||
if (m_Client->GetPeerHost() != string()) {
|
if (m_PeerHostname != string()) {
|
||||||
Timer::Ptr timer = make_shared<Timer>();
|
Timer::Ptr timer = make_shared<Timer>();
|
||||||
timer->SetInterval(30);
|
timer->SetInterval(30);
|
||||||
timer->SetUserArgs(ea);
|
timer->SetUserArgs(ea);
|
||||||
@ -178,7 +181,7 @@ int JsonRpcEndpoint::ClientReconnectHandler(const TimerEventArgs& ea)
|
|||||||
JsonRpcClient::Ptr client = static_pointer_cast<JsonRpcClient>(ea.UserArgs.Source);
|
JsonRpcClient::Ptr client = static_pointer_cast<JsonRpcClient>(ea.UserArgs.Source);
|
||||||
Timer::Ptr timer = static_pointer_cast<Timer>(ea.Source);
|
Timer::Ptr timer = static_pointer_cast<Timer>(ea.Source);
|
||||||
|
|
||||||
GetEndpointManager()->AddConnection(client->GetPeerHost(), client->GetPeerPort());
|
GetEndpointManager()->AddConnection(m_PeerHostname, m_PeerPort);
|
||||||
|
|
||||||
timer->Stop();
|
timer->Stop();
|
||||||
m_ReconnectTimer.reset();
|
m_ReconnectTimer.reset();
|
||||||
|
@ -15,6 +15,9 @@ private:
|
|||||||
set<string> m_AllowedMethodSinkPrefixes;
|
set<string> m_AllowedMethodSinkPrefixes;
|
||||||
set<string> m_AllowedMethodSourcePrefixes;
|
set<string> m_AllowedMethodSourcePrefixes;
|
||||||
|
|
||||||
|
string m_PeerHostname;
|
||||||
|
unsigned short m_PeerPort;
|
||||||
|
|
||||||
bool IsConnected(void) const;
|
bool IsConnected(void) const;
|
||||||
|
|
||||||
int NewMessageHandler(const NewMessageEventArgs& nmea);
|
int NewMessageHandler(const NewMessageEventArgs& nmea);
|
||||||
|
Loading…
x
Reference in New Issue
Block a user