Merge branch 'HTTPRebindSegFault' of https://github.com/Daviey/xmrig into Daviey-HTTPRebindSegFault

This commit is contained in:
XMRig 2024-02-12 14:50:48 +07:00
commit 2c9c40d623
No known key found for this signature in database
GPG key ID: 446A53638BE94409

View file

@ -39,6 +39,7 @@
#include <thread> #include <thread>
#include <iostream>
namespace xmrig { namespace xmrig {
@ -80,7 +81,8 @@ static rapidjson::Value getResources(rapidjson::Document &doc)
xmrig::Api::Api(Base *base) : xmrig::Api::Api(Base *base) :
m_base(base), m_base(base),
m_timestamp(Chrono::currentMSecsSinceEpoch()) m_timestamp(Chrono::currentMSecsSinceEpoch()),
m_httpd(nullptr)
{ {
base->addListener(this); base->addListener(this);
@ -91,7 +93,11 @@ xmrig::Api::Api(Base *base) :
xmrig::Api::~Api() xmrig::Api::~Api()
{ {
# ifdef XMRIG_FEATURE_HTTP # ifdef XMRIG_FEATURE_HTTP
if (m_httpd) {
m_httpd->stop();
delete m_httpd; delete m_httpd;
m_httpd = nullptr; // Ensure the pointer is set to nullptr after deletion
}
# endif # endif
} }
@ -109,8 +115,14 @@ void xmrig::Api::start()
genWorkerId(m_base->config()->apiWorkerId()); genWorkerId(m_base->config()->apiWorkerId());
# ifdef XMRIG_FEATURE_HTTP # ifdef XMRIG_FEATURE_HTTP
if (!m_httpd) {
m_httpd = new Httpd(m_base); m_httpd = new Httpd(m_base);
m_httpd->start(); if (!m_httpd->start()) {
std::cerr << "HTTP server failed to start." << std::endl;
delete m_httpd; // Properly handle failure to start
m_httpd = nullptr;
}
}
# endif # endif
} }
@ -118,7 +130,9 @@ void xmrig::Api::start()
void xmrig::Api::stop() void xmrig::Api::stop()
{ {
# ifdef XMRIG_FEATURE_HTTP # ifdef XMRIG_FEATURE_HTTP
if (m_httpd) {
m_httpd->stop(); m_httpd->stop();
}
# endif # endif
} }
@ -126,14 +140,16 @@ void xmrig::Api::stop()
void xmrig::Api::tick() void xmrig::Api::tick()
{ {
# ifdef XMRIG_FEATURE_HTTP # ifdef XMRIG_FEATURE_HTTP
if (m_httpd->isBound() || !m_base->config()->http().isEnabled()) { if (!m_httpd || !m_base->config()->http().isEnabled() || m_httpd->isBound()) {
return; return;
} }
if (++m_ticks % 10 == 0) { if (++m_ticks % 10 == 0) {
m_ticks = 0; m_ticks = 0;
if (m_httpd) {
m_httpd->start(); m_httpd->start();
} }
}
# endif # endif
} }