From 548fbb9f711b2817ad2386f9c4b8020ba3a28ec5 Mon Sep 17 00:00:00 2001 From: Tony Butler Date: Wed, 22 Dec 2021 05:17:08 -0700 Subject: [PATCH] Add API rebind polling --- src/base/api/Api.cpp | 14 ++++++++++++++ src/base/api/Api.h | 2 ++ src/base/api/Httpd.h | 1 + src/net/Network.cpp | 3 +++ 4 files changed, 20 insertions(+) diff --git a/src/base/api/Api.cpp b/src/base/api/Api.cpp index 54666efda..a7246b9f2 100644 --- a/src/base/api/Api.cpp +++ b/src/base/api/Api.cpp @@ -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()) { diff --git a/src/base/api/Api.h b/src/base/api/Api.h index c56e29ee1..685b56ff0 100644 --- a/src/base/api/Api.h +++ b/src/base/api/Api.h @@ -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 m_listeners; }; diff --git a/src/base/api/Httpd.h b/src/base/api/Httpd.h index 188646f55..fe8cb9143 100644 --- a/src/base/api/Httpd.h +++ b/src/base/api/Httpd.h @@ -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; diff --git a/src/net/Network.cpp b/src/net/Network.cpp index a35662428..841dd3166 100644 --- a/src/net/Network.cpp +++ b/src/net/Network.cpp @@ -308,6 +308,9 @@ void xmrig::Network::tick() if (m_donate) { m_donate->tick(now); } +#ifdef XMRIG_FEATURE_API + m_controller->api()->tick(); +#endif }