diff --git a/xplat/Sonar/SonarWebSocketImpl.cpp b/xplat/Sonar/SonarWebSocketImpl.cpp index b10de40a3e7..021d85744fd 100644 --- a/xplat/Sonar/SonarWebSocketImpl.cpp +++ b/xplat/Sonar/SonarWebSocketImpl.cpp @@ -33,6 +33,8 @@ #define SONAR_CA_FILE_NAME "sonarCA.crt" #define CLIENT_CERT_FILE_NAME "device.crt" #define PRIVATE_KEY_FILE "privateKey.pem" +#define WRONG_THREAD_EXIT_MSG \ + "ERROR: Aborting sonar initialization because it's not running in the sonar thread." static constexpr int reconnectIntervalSeconds = 2; static constexpr int connectionKeepaliveSeconds = 10; @@ -104,6 +106,10 @@ void SonarWebSocketImpl::start() { } void SonarWebSocketImpl::startSync() { + if (!isRunningInOwnThread()) { + SONAR_LOG(WRONG_THREAD_EXIT_MSG); + return; + } if (isOpen()) { SONAR_LOG("Already connected"); return; @@ -289,6 +295,10 @@ bool SonarWebSocketImpl::ensureSonarDirExists() { } } +bool SonarWebSocketImpl::isRunningInOwnThread() { + return sonarEventBase_->isInEventBaseThread(); +} + bool fileExists(std::string fileName) { struct stat buffer; return stat(fileName.c_str(), &buffer) == 0; diff --git a/xplat/Sonar/SonarWebSocketImpl.h b/xplat/Sonar/SonarWebSocketImpl.h index 7d91fcd18db..ca1e3710a02 100644 --- a/xplat/Sonar/SonarWebSocketImpl.h +++ b/xplat/Sonar/SonarWebSocketImpl.h @@ -62,6 +62,7 @@ class SonarWebSocketImpl : public SonarWebSocket { bool isCertificateExchangeNeeded(); void requestSignedCertFromSonar(); bool ensureSonarDirExists(); + bool isRunningInOwnThread(); }; } // namespace sonar