mirror of
https://github.com/xmrig/xmrig.git
synced 2025-01-10 21:04:37 +00:00
Implemented switch to donate pool.
This commit is contained in:
parent
c31ea00399
commit
1cf5ad5212
7 changed files with 80 additions and 14 deletions
|
@ -50,7 +50,7 @@ if ("${CMAKE_BUILD_TYPE}" STREQUAL "")
|
||||||
set(CMAKE_BUILD_TYPE Release)
|
set(CMAKE_BUILD_TYPE Release)
|
||||||
endif()
|
endif()
|
||||||
|
|
||||||
set(CMAKE_CXX_FLAGS "${CMAKE_CXX_FLAGS} -maes -Wall")
|
set(CMAKE_CXX_FLAGS "${CMAKE_CXX_FLAGS} -maes -Wall -fno-exceptions")
|
||||||
set(CMAKE_CXX_FLAGS_RELEASE "${CMAKE_CXX_FLAGS_RELEASE} -Ofast -funroll-loops -fvariable-expansion-in-unroller -ftree-loop-if-convert-stores -fmerge-all-constants -fbranch-target-load-optimize2")
|
set(CMAKE_CXX_FLAGS_RELEASE "${CMAKE_CXX_FLAGS_RELEASE} -Ofast -funroll-loops -fvariable-expansion-in-unroller -ftree-loop-if-convert-stores -fmerge-all-constants -fbranch-target-load-optimize2")
|
||||||
#set(CMAKE_C_FLAGS_RELEASE "${CMAKE_C_FLAGS_RELEASE} -gdwarf-2")
|
#set(CMAKE_C_FLAGS_RELEASE "${CMAKE_C_FLAGS_RELEASE} -gdwarf-2")
|
||||||
#set(CMAKE_C_FLAGS_RELEASE "${CMAKE_C_FLAGS_RELEASE} -fprofile-generate")
|
#set(CMAKE_C_FLAGS_RELEASE "${CMAKE_C_FLAGS_RELEASE} -fprofile-generate")
|
||||||
|
|
|
@ -57,6 +57,7 @@ public:
|
||||||
inline const char *user() const { return m_user; }
|
inline const char *user() const { return m_user; }
|
||||||
inline const Url *backupUrl() const { return m_backupUrl; }
|
inline const Url *backupUrl() const { return m_backupUrl; }
|
||||||
inline const Url *url() const { return m_url; }
|
inline const Url *url() const { return m_url; }
|
||||||
|
inline int donateLevel() const { return m_donateLevel; }
|
||||||
inline int retries() const { return m_retries; }
|
inline int retries() const { return m_retries; }
|
||||||
inline int retryPause() const { return m_retryPause; }
|
inline int retryPause() const { return m_retryPause; }
|
||||||
|
|
||||||
|
|
|
@ -129,12 +129,16 @@ void Client::send(char *data)
|
||||||
free(req);
|
free(req);
|
||||||
});
|
});
|
||||||
|
|
||||||
uv_timer_start(&m_responseTimer, [](uv_timer_t* handle) { getClient(handle->data)->close(); }, kResponseTimeout, 0);
|
uv_timer_start(&m_responseTimer, [](uv_timer_t *handle) { getClient(handle->data)->close(); }, kResponseTimeout, 0);
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|
||||||
void Client::setUrl(const Url *url)
|
void Client::setUrl(const Url *url)
|
||||||
{
|
{
|
||||||
|
if (!url || !url->isValid()) {
|
||||||
|
return;
|
||||||
|
}
|
||||||
|
|
||||||
free(m_host);
|
free(m_host);
|
||||||
m_host = strdup(url->host());
|
m_host = strdup(url->host());
|
||||||
m_port = url->port();
|
m_port = url->port();
|
||||||
|
|
|
@ -22,7 +22,6 @@
|
||||||
*/
|
*/
|
||||||
|
|
||||||
|
|
||||||
#include <uv.h>
|
|
||||||
#include <memory>
|
#include <memory>
|
||||||
|
|
||||||
|
|
||||||
|
@ -41,11 +40,12 @@ Network::Network(const Options *options) :
|
||||||
m_pools.reserve(2);
|
m_pools.reserve(2);
|
||||||
m_agent = userAgent();
|
m_agent = userAgent();
|
||||||
|
|
||||||
auto url = std::make_unique<Url>("donate.xmrig.com", 443);
|
addPool(std::make_unique<Url>().get());
|
||||||
|
|
||||||
addPool(url.get());
|
|
||||||
addPool(m_options->url());
|
addPool(m_options->url());
|
||||||
addPool(m_options->backupUrl());
|
addPool(m_options->backupUrl());
|
||||||
|
|
||||||
|
m_timer.data = this;
|
||||||
|
uv_timer_init(uv_default_loop(), &m_timer);
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|
||||||
|
@ -61,15 +61,22 @@ Network::~Network()
|
||||||
|
|
||||||
void Network::connect()
|
void Network::connect()
|
||||||
{
|
{
|
||||||
m_pools.at(1)->connect();
|
m_pools[1]->connect();
|
||||||
|
|
||||||
|
if (m_options->donateLevel()) {
|
||||||
|
uv_timer_start(&m_timer, Network::onTimer, (100 - m_options->donateLevel()) * 60 * 1000, 0);
|
||||||
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|
||||||
void Network::onClose(Client *client, int failures)
|
void Network::onClose(Client *client, int failures)
|
||||||
{
|
{
|
||||||
const int id = client->id();
|
const int id = client->id();
|
||||||
if (id == 0 && failures == -1) {
|
if (id == 0) {
|
||||||
m_donate = false;
|
if (failures == -1) {
|
||||||
|
stopDonate();
|
||||||
|
}
|
||||||
|
|
||||||
return;
|
return;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@ -78,7 +85,7 @@ void Network::onClose(Client *client, int failures)
|
||||||
}
|
}
|
||||||
|
|
||||||
if (id == 1 && m_pools.size() > 2 && failures == m_options->retries()) {
|
if (id == 1 && m_pools.size() > 2 && failures == m_options->retries()) {
|
||||||
m_pools.at(2)->connect();
|
m_pools[2]->connect();
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@ -99,12 +106,11 @@ void Network::onLoginSuccess(Client *client)
|
||||||
{
|
{
|
||||||
const int id = client->id();
|
const int id = client->id();
|
||||||
if (id == 0) {
|
if (id == 0) {
|
||||||
m_donate = true;
|
return startDonate();
|
||||||
return;
|
|
||||||
}
|
}
|
||||||
|
|
||||||
if (id == 2 && m_pool) { // primary pool is already active
|
if (id == 2 && m_pool) { // primary pool is already active
|
||||||
m_pools.at(2)->disconnect();
|
m_pools[2]->disconnect();
|
||||||
return;
|
return;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@ -112,7 +118,7 @@ void Network::onLoginSuccess(Client *client)
|
||||||
m_pool = id;
|
m_pool = id;
|
||||||
|
|
||||||
if (m_pool == 1 && m_pools.size() > 2) { // try disconnect from backup pool
|
if (m_pool == 1 && m_pools.size() > 2) { // try disconnect from backup pool
|
||||||
m_pools.at(2)->disconnect();
|
m_pools[2]->disconnect();
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@ -130,3 +136,44 @@ void Network::addPool(const Url *url)
|
||||||
|
|
||||||
m_pools.push_back(client);
|
m_pools.push_back(client);
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|
||||||
|
void Network::startDonate()
|
||||||
|
{
|
||||||
|
if (m_donate) {
|
||||||
|
return;
|
||||||
|
}
|
||||||
|
|
||||||
|
LOG_NOTICE("dev donate started");
|
||||||
|
|
||||||
|
m_donate = true;
|
||||||
|
}
|
||||||
|
|
||||||
|
|
||||||
|
void Network::stopDonate()
|
||||||
|
{
|
||||||
|
if (!m_donate) {
|
||||||
|
return;
|
||||||
|
}
|
||||||
|
|
||||||
|
LOG_NOTICE("dev donate finished");
|
||||||
|
|
||||||
|
m_donate = false;
|
||||||
|
}
|
||||||
|
|
||||||
|
|
||||||
|
void Network::onTimer(uv_timer_t *handle)
|
||||||
|
{
|
||||||
|
auto net = static_cast<Network*>(handle->data);
|
||||||
|
|
||||||
|
if (!net->m_donate) {
|
||||||
|
auto url = std::make_unique<Url>("donate.xmrig.com", 443);
|
||||||
|
net->m_pools[0]->connect(url.get());
|
||||||
|
|
||||||
|
uv_timer_start(&net->m_timer, Network::onTimer, net->m_options->donateLevel() * 60 * 1000, 0);
|
||||||
|
return;
|
||||||
|
}
|
||||||
|
|
||||||
|
net->m_pools[0]->disconnect();
|
||||||
|
uv_timer_start(&net->m_timer, Network::onTimer, (100 - net->m_options->donateLevel()) * 60 * 1000, 0);
|
||||||
|
}
|
||||||
|
|
|
@ -26,6 +26,7 @@
|
||||||
|
|
||||||
|
|
||||||
#include <vector>
|
#include <vector>
|
||||||
|
#include <uv.h>
|
||||||
|
|
||||||
|
|
||||||
#include "interfaces/IClientListener.h"
|
#include "interfaces/IClientListener.h"
|
||||||
|
@ -53,12 +54,17 @@ protected:
|
||||||
|
|
||||||
private:
|
private:
|
||||||
void addPool(const Url *url);
|
void addPool(const Url *url);
|
||||||
|
void startDonate();
|
||||||
|
void stopDonate();
|
||||||
|
|
||||||
|
static void onTimer(uv_timer_t *handle);
|
||||||
|
|
||||||
bool m_donate;
|
bool m_donate;
|
||||||
char *m_agent;
|
char *m_agent;
|
||||||
const Options *m_options;
|
const Options *m_options;
|
||||||
int m_pool;
|
int m_pool;
|
||||||
std::vector<Client*> m_pools;
|
std::vector<Client*> m_pools;
|
||||||
|
uv_timer_t m_timer;
|
||||||
};
|
};
|
||||||
|
|
||||||
|
|
||||||
|
|
|
@ -29,6 +29,13 @@
|
||||||
#include "net/Url.h"
|
#include "net/Url.h"
|
||||||
|
|
||||||
|
|
||||||
|
Url::Url() :
|
||||||
|
m_host(nullptr),
|
||||||
|
m_port(3333)
|
||||||
|
{
|
||||||
|
}
|
||||||
|
|
||||||
|
|
||||||
/**
|
/**
|
||||||
* @brief Parse url.
|
* @brief Parse url.
|
||||||
*
|
*
|
||||||
|
|
|
@ -31,6 +31,7 @@
|
||||||
class Url
|
class Url
|
||||||
{
|
{
|
||||||
public:
|
public:
|
||||||
|
Url();
|
||||||
Url(const char *url);
|
Url(const char *url);
|
||||||
Url(const char *host, uint16_t port);
|
Url(const char *host, uint16_t port);
|
||||||
~Url();
|
~Url();
|
||||||
|
|
Loading…
Reference in a new issue