/* XMRig * Copyright (c) 2018-2021 SChernykh * Copyright (c) 2016-2021 XMRig , * * This program is free software: you can redistribute it and/or modify * it under the terms of the GNU General Public License as published by * the Free Software Foundation, either version 3 of the License, or * (at your option) any later version. * * This program is distributed in the hope that it will be useful, * but WITHOUT ANY WARRANTY; without even the implied warranty of * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the * GNU General Public License for more details. * * You should have received a copy of the GNU General Public License * along with this program. If not, see . */ #ifndef XMRIG_POOLS_H #define XMRIG_POOLS_H #include #include "base/net/stratum/Pool.h" namespace xmrig { class IJsonReader; class IStrategy; class IStrategyListener; class Pools { public: static const char *kDonateLevel; static const char *kDonateOverProxy; static const char *kPools; static const char *kRetries; static const char *kRetryPause; enum ProxyDonate { PROXY_DONATE_NONE, PROXY_DONATE_AUTO, PROXY_DONATE_ALWAYS }; Pools(); # ifdef XMRIG_FEATURE_BENCHMARK inline bool isBenchmark() const { return !!m_benchmark; } # else inline constexpr static bool isBenchmark() { return false; } # endif inline const std::vector &data() const { return m_data; } inline int retries() const { return m_retries; } inline int retryPause() const { return m_retryPause; } inline ProxyDonate proxyDonate() const { return m_proxyDonate; } inline bool operator!=(const Pools &other) const { return !isEqual(other); } inline bool operator==(const Pools &other) const { return isEqual(other); } bool isEqual(const Pools &other) const; int donateLevel() const; IStrategy *createStrategy(IStrategyListener *listener) const; rapidjson::Value toJSON(rapidjson::Document &doc) const; size_t active() const; uint32_t benchSize() const; void load(const IJsonReader &reader); void print() const; void toJSON(rapidjson::Value &out, rapidjson::Document &doc) const; private: void setDonateLevel(int level); void setProxyDonate(int value); void setRetries(int retries); void setRetryPause(int retryPause); int m_donateLevel; int m_retries = 5; int m_retryPause = 5; ProxyDonate m_proxyDonate = PROXY_DONATE_AUTO; std::vector m_data; # ifdef XMRIG_FEATURE_BENCHMARK std::shared_ptr m_benchmark; # endif }; } /* namespace xmrig */ #endif /* XMRIG_POOLS_H */