Add API rebind polling

This commit is contained in:
Tony Butler 2021-12-22 05:17:08 -07:00
parent 02d45834e1
commit 548fbb9f71
4 changed files with 20 additions and 0 deletions

View file

@ -123,6 +123,20 @@ void xmrig::Api::stop()
}
void xmrig::Api::tick()
{
# ifdef XMRIG_FEATURE_HTTP
if (!m_base->config()->http().isEnabled() || m_httpd->isBound()) {
return;
}
if (++m_ticks % 10 == 0) {
m_ticks = 0;
m_httpd->start();
}
# endif
}
void xmrig::Api::onConfigChanged(Config *config, Config *previousConfig)
{
if (config->apiId() != previousConfig->apiId()) {

View file

@ -54,6 +54,7 @@ public:
void request(const HttpData &req);
void start();
void stop();
void tick();
protected:
void onConfigChanged(Config *config, Config *previousConfig) override;
@ -67,6 +68,7 @@ private:
char m_id[32]{};
String m_workerId;
const uint64_t m_timestamp;
uint8_t m_ticks;
Httpd *m_httpd = nullptr;
std::vector<IApiListener *> m_listeners;
};

View file

@ -48,6 +48,7 @@ public:
bool start();
void stop();
inline const bool isBound() const { return m_server != nullptr; }
protected:
void onConfigChanged(Config *config, Config *previousConfig) override;

View file

@ -308,6 +308,9 @@ void xmrig::Network::tick()
if (m_donate) {
m_donate->tick(now);
}
#ifdef XMRIG_FEATURE_API
m_controller->api()->tick();
#endif
}