mirror of https://github.com/Icinga/icinga2.git
Check the certificate name when reconnecting to an instance
refs #10963
This commit is contained in:
parent
badeea7604
commit
b227dc77bf
|
@ -85,7 +85,7 @@ TlsStream::TlsStream(const Socket::Ptr& socket, const String& hostname, Connecti
|
|||
|
||||
TlsStream::~TlsStream(void)
|
||||
{
|
||||
Close();
|
||||
CloseInternal(true);
|
||||
}
|
||||
|
||||
int TlsStream::ValidateCertificate(int preverify_ok, X509_STORE_CTX *ctx)
|
||||
|
@ -321,10 +321,6 @@ void TlsStream::Shutdown(void)
|
|||
*/
|
||||
void TlsStream::Close(void)
|
||||
{
|
||||
<<<<<<< HEAD
|
||||
if (!m_Eof) {
|
||||
m_Eof = true;
|
||||
=======
|
||||
CloseInternal(false);
|
||||
}
|
||||
|
||||
|
@ -336,15 +332,13 @@ void TlsStream::CloseInternal(bool inDestructor)
|
|||
m_Eof = true;
|
||||
|
||||
if (!inDestructor)
|
||||
>>>>>>> 2dc385e... Fix memory/thread leak in the HttpServerConnection class
|
||||
SignalDataAvailable();
|
||||
|
||||
Stream::Close();
|
||||
|
||||
SocketEvents::Unregister();
|
||||
|
||||
boost::mutex::scoped_lock lock(m_Mutex);
|
||||
Stream::Close();
|
||||
|
||||
boost::mutex::scoped_lock lock(m_Mutex);
|
||||
|
||||
if (!m_SSL)
|
||||
return;
|
||||
|
|
|
@ -99,6 +99,8 @@ private:
|
|||
|
||||
static int ValidateCertificate(int preverify_ok, X509_STORE_CTX *ctx);
|
||||
static void NullCertificateDeleter(X509 *certificate);
|
||||
|
||||
void CloseInternal(bool inDestructor);
|
||||
};
|
||||
|
||||
}
|
||||
|
|
|
@ -321,6 +321,12 @@ void ApiListener::NewClientHandlerInternal(const Socket::Ptr& client, const Stri
|
|||
return;
|
||||
}
|
||||
|
||||
if (!hostname.IsEmpty() && identity != hostname) {
|
||||
Log(LogInformation, "ApiListener")
|
||||
<< "Unexpected certificate common name while connecting to endpoint '" << hostname << "': got '" << identity << "'";
|
||||
return;
|
||||
}
|
||||
|
||||
verify_ok = tlsStream->IsVerifyOK();
|
||||
|
||||
Log(LogInformation, "ApiListener")
|
||||
|
|
Loading…
Reference in New Issue