Merge pull request #2848 from Spudz76/dev-addClientReconnect

Add support for client.reconnect method
This commit is contained in:
xmrig 2021-12-30 20:44:22 +07:00 committed by GitHub
commit 7bde3ed5f7
No known key found for this signature in database
GPG key ID: 4AEE18F83AFDEB23
3 changed files with 40 additions and 1 deletions

View file

@ -23,6 +23,7 @@
#include <cstdio> #include <cstdio>
#include <cstring> #include <cstring>
#include <utility> #include <utility>
#include <sstream>
#ifdef XMRIG_FEATURE_TLS #ifdef XMRIG_FEATURE_TLS
@ -683,12 +684,48 @@ void xmrig::Client::parse(char *line, size_t len)
const auto &id = Json::getValue(doc, "id"); const auto &id = Json::getValue(doc, "id");
const auto &error = Json::getValue(doc, "error"); const auto &error = Json::getValue(doc, "error");
const char *method = Json::getString(doc, "method");
if (method && strcmp(method, "client.reconnect") == 0) {
const auto &params = Json::getValue(doc, "params");
if (!params.IsArray()) {
LOG_ERR("%s " RED("invalid client.reconnect notification: params is not an array"), tag());
return;
}
auto arr = params.GetArray();
if (arr.Empty()) {
LOG_ERR("%s " RED("invalid client.reconnect notification: params array is empty"), tag());
return;
}
if (arr.Size() != 2) {
LOG_ERR("%s " RED("invalid client.reconnect notification: params array has wrong size"), tag());
return;
}
if (!arr[0].IsString()) {
LOG_ERR("%s " RED("invalid client.reconnect notification: host is not a string"), tag());
return;
}
if (!arr[1].IsString()) {
LOG_ERR("%s " RED("invalid client.reconnect notification: port is not a string"), tag());
return;
}
std::stringstream s;
s << arr[0].GetString() << ":" << arr[1].GetString();
LOG_WARN("%s " YELLOW("client.reconnect to %s"), tag(), s.str().c_str());
setPoolUrl(s.str().c_str());
return reconnect();
}
if (id.IsInt64()) { if (id.IsInt64()) {
return parseResponse(id.GetInt64(), Json::getValue(doc, "result"), error); return parseResponse(id.GetInt64(), Json::getValue(doc, "result"), error);
} }
const char *method = Json::getString(doc, "method");
if (!method) { if (!method) {
return; return;
} }

View file

@ -84,6 +84,7 @@ protected:
inline const char *url() const { return m_pool.url(); } inline const char *url() const { return m_pool.url(); }
inline const String &rpcId() const { return m_rpcId; } inline const String &rpcId() const { return m_rpcId; }
inline void setRpcId(const char *id) { m_rpcId = id; } inline void setRpcId(const char *id) { m_rpcId = id; }
inline void setPoolUrl(const char *url) { m_pool.setUrl(url); }
virtual bool parseLogin(const rapidjson::Value &result, int *code); virtual bool parseLogin(const rapidjson::Value &result, int *code);
virtual void login(); virtual void login();

View file

@ -111,6 +111,7 @@ public:
inline int zmq_port() const { return m_zmqPort; } inline int zmq_port() const { return m_zmqPort; }
inline uint64_t pollInterval() const { return m_pollInterval; } inline uint64_t pollInterval() const { return m_pollInterval; }
inline void setAlgo(const Algorithm &algorithm) { m_algorithm = algorithm; } inline void setAlgo(const Algorithm &algorithm) { m_algorithm = algorithm; }
inline void setUrl(const char *url) { m_url = Url(url); }
inline void setPassword(const String &password) { m_password = password; } inline void setPassword(const String &password) { m_password = password; }
inline void setProxy(const ProxyUrl &proxy) { m_proxy = proxy; } inline void setProxy(const ProxyUrl &proxy) { m_proxy = proxy; }
inline void setRigId(const String &rigId) { m_rigId = rigId; } inline void setRigId(const String &rigId) { m_rigId = rigId; }