mirror of
https://github.com/monero-project/monero-gui.git
synced 2025-01-09 20:40:27 +00:00
Build
This commit is contained in:
parent
e29050f11a
commit
cdcdb79aa6
5 changed files with 170 additions and 18 deletions
10
external/CMakeLists.txt
vendored
10
external/CMakeLists.txt
vendored
|
@ -1,5 +1,3 @@
|
||||||
file(GLOB I2PD_SOURCES "i2pd/daemon/*.cpp" "i2pd/libi2pd/*.cpp" "i2pd/libi2pd_client/*.cpp" "i2pd/i18n/*.cpp")
|
|
||||||
|
|
||||||
add_library(quirc STATIC
|
add_library(quirc STATIC
|
||||||
quirc/lib/decode.c
|
quirc/lib/decode.c
|
||||||
quirc/lib/identify.c
|
quirc/lib/identify.c
|
||||||
|
@ -9,9 +7,5 @@ add_library(quirc STATIC
|
||||||
set_target_properties(quirc PROPERTIES POSITION_INDEPENDENT_CODE ON)
|
set_target_properties(quirc PROPERTIES POSITION_INDEPENDENT_CODE ON)
|
||||||
target_include_directories(quirc PUBLIC quirc/lib)
|
target_include_directories(quirc PUBLIC quirc/lib)
|
||||||
|
|
||||||
add_library(i2pd STATIC
|
option(WITH_BINARY "" OFF)
|
||||||
${I2PD_SOURCES}
|
add_subdirectory(i2pd/build)
|
||||||
)
|
|
||||||
set_target_properties(i2pd PROPERTIES POSITION_INDEPENDENT_CODE ON)
|
|
||||||
target_include_directories(i2pd PUBLIC i2pd/daemon i2pd/libi2pd i2pd/libi2pd_client i2pd/i18n)
|
|
||||||
target_compile_definitions(i2pd PUBLIC WIN32_LEAN_AND_MEAN)
|
|
||||||
|
|
|
@ -116,6 +116,7 @@ Rectangle {
|
||||||
|
|
||||||
function startI2PD()
|
function startI2PD()
|
||||||
{
|
{
|
||||||
|
/*
|
||||||
var noSync = false;
|
var noSync = false;
|
||||||
//these args will be deleted because DaemonManager::start will re-add them later.
|
//these args will be deleted because DaemonManager::start will re-add them later.
|
||||||
//removing '--tx-proxy=i2p,...' lets us blindly add '--tx-proxy i2p,...' later without risking duplication.
|
//removing '--tx-proxy=i2p,...' lets us blindly add '--tx-proxy i2p,...' later without risking duplication.
|
||||||
|
@ -147,8 +148,9 @@ Rectangle {
|
||||||
}
|
}
|
||||||
var success = daemonManager.start(allArgs.join(" "), persistentSettings.nettype, persistentSettings.blockchainDataDir, persistentSettings.bootstrapNodeAddress, noSync, persistentSettings.pruneBlockchain)
|
var success = daemonManager.start(allArgs.join(" "), persistentSettings.nettype, persistentSettings.blockchainDataDir, persistentSettings.bootstrapNodeAddress, noSync, persistentSettings.pruneBlockchain)
|
||||||
if (success) {
|
if (success) {
|
||||||
|
*/
|
||||||
i2pdManager.start();
|
i2pdManager.start();
|
||||||
}
|
//}
|
||||||
}
|
}
|
||||||
|
|
||||||
function stopI2PD()
|
function stopI2PD()
|
||||||
|
|
|
@ -1,5 +1,20 @@
|
||||||
add_library(i2p STATIC
|
add_library(i2p STATIC
|
||||||
I2PDManager.cpp
|
I2PDManager.cpp
|
||||||
)
|
)
|
||||||
find_package(ZLIB)
|
|
||||||
target_link_libraries(i2p PRIVATE i2pd ZLIB::ZLIB)
|
find_package(ZLIB REQUIRED)
|
||||||
|
|
||||||
|
target_include_directories(i2p
|
||||||
|
PRIVATE
|
||||||
|
"../../external/i2pd/libi2pd"
|
||||||
|
"../../external/i2pd/libi2pd_client"
|
||||||
|
"../../external/i2pd/i18n"
|
||||||
|
)
|
||||||
|
|
||||||
|
target_link_libraries(i2p
|
||||||
|
PRIVATE
|
||||||
|
libi2pdclient
|
||||||
|
libi2pd
|
||||||
|
libi2pdlang
|
||||||
|
ZLIB::ZLIB
|
||||||
|
)
|
||||||
|
|
|
@ -27,7 +27,23 @@
|
||||||
// THE USE OF THIS SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF SUCH DAMAGE.
|
// THE USE OF THIS SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF SUCH DAMAGE.
|
||||||
|
|
||||||
#include "I2PDManager.h"
|
#include "I2PDManager.h"
|
||||||
#include "../../external/i2pd/daemon/Daemon.h"
|
|
||||||
|
#include "../../external/i2pd/libi2pd/Config.h"
|
||||||
|
#include "../../external/i2pd/libi2pd/FS.h"
|
||||||
|
#include "../../external/i2pd/libi2pd/Base.h"
|
||||||
|
#include "../../external/i2pd/libi2pd/version.h"
|
||||||
|
#include "../../external/i2pd/libi2pd/Transports.h"
|
||||||
|
#include "../../external/i2pd/libi2pd/RouterInfo.h"
|
||||||
|
#include "../../external/i2pd/libi2pd/RouterContext.h"
|
||||||
|
#include "../../external/i2pd/libi2pd/Tunnel.h"
|
||||||
|
#include "../../external/i2pd/libi2pd/HTTP.h"
|
||||||
|
#include "../../external/i2pd/libi2pd/NetDb.hpp"
|
||||||
|
#include "../../external/i2pd/libi2pd/Garlic.h"
|
||||||
|
#include "../../external/i2pd/libi2pd/Streaming.h"
|
||||||
|
#include "../../external/i2pd/libi2pd/Destination.h"
|
||||||
|
#include "../../external/i2pd/libi2pd_client/ClientContext.h"
|
||||||
|
#include "../../external/i2pd/libi2pd/Crypto.h"
|
||||||
|
|
||||||
#include <vector>
|
#include <vector>
|
||||||
#include <QApplication>
|
#include <QApplication>
|
||||||
#include <QDir>
|
#include <QDir>
|
||||||
|
@ -53,7 +69,7 @@ I2PDManager::I2PDManager(QObject *parent)
|
||||||
|
|
||||||
std::string dataDir = "--datadir=" + m_i2pdDataDir.toStdString();
|
std::string dataDir = "--datadir=" + m_i2pdDataDir.toStdString();
|
||||||
std::vector<const char*> argv({"i2pd", dataDir.data()});
|
std::vector<const char*> argv({"i2pd", dataDir.data()});
|
||||||
Daemon.init(argv.size(), (char**) argv.data());
|
init(argv.size(), (char**) argv.data());
|
||||||
}
|
}
|
||||||
|
|
||||||
I2PDManager::~I2PDManager()
|
I2PDManager::~I2PDManager()
|
||||||
|
@ -61,22 +77,143 @@ I2PDManager::~I2PDManager()
|
||||||
|
|
||||||
}
|
}
|
||||||
|
|
||||||
|
void I2PDManager::init(int argc, char* argv[])
|
||||||
|
{
|
||||||
|
i2p::config::Init();
|
||||||
|
i2p::config::ParseCmdline(argc, argv);
|
||||||
|
|
||||||
|
std::string datadir;
|
||||||
|
i2p::config::GetOption("datadir", datadir);
|
||||||
|
i2p::fs::DetectDataDir(datadir, false);
|
||||||
|
i2p::fs::Init();
|
||||||
|
|
||||||
|
i2p::config::Finalize();
|
||||||
|
|
||||||
|
std::string certsdir; i2p::config::GetOption("certsdir", certsdir);
|
||||||
|
i2p::fs::SetCertsDir(certsdir);
|
||||||
|
certsdir = i2p::fs::GetCertsDir();
|
||||||
|
|
||||||
|
bool precomputation; i2p::config::GetOption("precomputation.elgamal", precomputation);
|
||||||
|
bool aesni; i2p::config::GetOption("cpuext.aesni", aesni);
|
||||||
|
bool avx; i2p::config::GetOption("cpuext.avx", avx);
|
||||||
|
bool forceCpuExt; i2p::config::GetOption("cpuext.force", forceCpuExt);
|
||||||
|
bool ssu; i2p::config::GetOption("ssu", ssu);
|
||||||
|
if (!ssu && i2p::config::IsDefault ("precomputation.elgamal"))
|
||||||
|
precomputation = false; // we don't elgamal table if no ssu, unless it's specified explicitly
|
||||||
|
i2p::crypto::InitCrypto(precomputation, aesni, avx, forceCpuExt);
|
||||||
|
|
||||||
|
i2p::transport::InitAddressFromIface(); // get address4/6 from interfaces
|
||||||
|
|
||||||
|
int netID; i2p::config::GetOption("netid", netID);
|
||||||
|
i2p::context.SetNetID(netID);
|
||||||
|
i2p::context.Init();
|
||||||
|
|
||||||
|
i2p::transport::InitTransports();
|
||||||
|
|
||||||
|
bool isFloodfill; i2p::config::GetOption("floodfill", isFloodfill);
|
||||||
|
if (isFloodfill)
|
||||||
|
{
|
||||||
|
i2p::context.SetFloodfill (true);
|
||||||
|
}
|
||||||
|
else
|
||||||
|
i2p::context.SetFloodfill (false);
|
||||||
|
|
||||||
|
bool transit; i2p::config::GetOption("notransit", transit);
|
||||||
|
i2p::context.SetAcceptsTunnels (!transit);
|
||||||
|
uint16_t transitTunnels; i2p::config::GetOption("limits.transittunnels", transitTunnels);
|
||||||
|
if (isFloodfill && i2p::config::IsDefault ("limits.transittunnels"))
|
||||||
|
transitTunnels *= 2; // double default number of transit tunnels for floodfill
|
||||||
|
i2p::tunnel::tunnels.SetMaxNumTransitTunnels (transitTunnels);
|
||||||
|
|
||||||
|
/* this section also honors 'floodfill' flag, if set above */
|
||||||
|
std::string bandwidth; i2p::config::GetOption("bandwidth", bandwidth);
|
||||||
|
if (bandwidth.length () > 0)
|
||||||
|
{
|
||||||
|
if (bandwidth[0] >= 'K' && bandwidth[0] <= 'X')
|
||||||
|
{
|
||||||
|
i2p::context.SetBandwidth (bandwidth[0]);
|
||||||
|
}
|
||||||
|
else
|
||||||
|
{
|
||||||
|
auto value = std::atoi(bandwidth.c_str());
|
||||||
|
if (value > 0)
|
||||||
|
{
|
||||||
|
i2p::context.SetBandwidth (value);
|
||||||
|
}
|
||||||
|
else
|
||||||
|
{
|
||||||
|
i2p::context.SetBandwidth (i2p::data::CAPS_FLAG_LOW_BANDWIDTH2);
|
||||||
|
}
|
||||||
|
}
|
||||||
|
}
|
||||||
|
else if (isFloodfill)
|
||||||
|
{
|
||||||
|
i2p::context.SetBandwidth (i2p::data::CAPS_FLAG_EXTRA_BANDWIDTH2);
|
||||||
|
}
|
||||||
|
else
|
||||||
|
{
|
||||||
|
i2p::context.SetBandwidth (i2p::data::CAPS_FLAG_LOW_BANDWIDTH2);
|
||||||
|
}
|
||||||
|
|
||||||
|
int shareRatio; i2p::config::GetOption("share", shareRatio);
|
||||||
|
i2p::context.SetShareRatio (shareRatio);
|
||||||
|
|
||||||
|
std::string family; i2p::config::GetOption("family", family);
|
||||||
|
i2p::context.SetFamily(family);
|
||||||
|
}
|
||||||
|
|
||||||
void I2PDManager::start()
|
void I2PDManager::start()
|
||||||
{
|
{
|
||||||
if (!isRunning()) {
|
if (!isRunning()) {
|
||||||
Daemon.start();
|
i2p::data::netdb.Start();
|
||||||
Daemon.running;
|
|
||||||
|
bool nettime; i2p::config::GetOption("nettime.enabled", nettime);
|
||||||
|
if (nettime)
|
||||||
|
{
|
||||||
|
m_NTPSync = std::unique_ptr<i2p::util::NTPTimeSync>(new i2p::util::NTPTimeSync);
|
||||||
|
m_NTPSync->Start();
|
||||||
|
}
|
||||||
|
|
||||||
|
bool ntcp2; i2p::config::GetOption("ntcp2.enabled", ntcp2);
|
||||||
|
bool ssu2; i2p::config::GetOption("ssu2.enabled", ssu2);
|
||||||
|
bool checkInReserved; i2p::config::GetOption("reservedrange", checkInReserved);
|
||||||
|
|
||||||
|
i2p::transport::transports.SetCheckReserved(checkInReserved);
|
||||||
|
i2p::transport::transports.Start(ntcp2, ssu2);
|
||||||
|
if (!(i2p::transport::transports.IsBoundSSU2() || i2p::transport::transports.IsBoundNTCP2()))
|
||||||
|
{
|
||||||
|
i2p::transport::transports.Stop();
|
||||||
|
i2p::data::netdb.Stop();
|
||||||
|
return;
|
||||||
|
}
|
||||||
|
|
||||||
|
i2p::tunnel::tunnels.Start();
|
||||||
|
i2p::context.Start();
|
||||||
|
i2p::client::context.Start();
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
void I2PDManager::stop()
|
void I2PDManager::stop()
|
||||||
{
|
{
|
||||||
if (isRunning()) {
|
if (isRunning()) {
|
||||||
Daemon.stop();
|
i2p::client::context.Stop();
|
||||||
|
i2p::context.Stop();
|
||||||
|
i2p::tunnel::tunnels.Stop();
|
||||||
|
|
||||||
|
if (m_NTPSync)
|
||||||
|
{
|
||||||
|
m_NTPSync->Stop ();
|
||||||
|
m_NTPSync = nullptr;
|
||||||
|
}
|
||||||
|
|
||||||
|
i2p::transport::transports.Stop();
|
||||||
|
i2p::data::netdb.Stop();
|
||||||
|
i2p::crypto::TerminateCrypto();
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
bool I2PDManager::isRunning() const
|
bool I2PDManager::isRunning() const
|
||||||
{
|
{
|
||||||
return Daemon.running;
|
//return m_isRunning;
|
||||||
|
return false;
|
||||||
}
|
}
|
||||||
|
|
|
@ -30,6 +30,7 @@
|
||||||
#define I2PDMANAGER_H
|
#define I2PDMANAGER_H
|
||||||
|
|
||||||
#include <QObject>
|
#include <QObject>
|
||||||
|
#include "../../external/i2pd/libi2pd/Timestamp.h"
|
||||||
|
|
||||||
class I2PDManager : public QObject
|
class I2PDManager : public QObject
|
||||||
{
|
{
|
||||||
|
@ -45,7 +46,10 @@ public:
|
||||||
Q_INVOKABLE bool isRunning() const;
|
Q_INVOKABLE bool isRunning() const;
|
||||||
|
|
||||||
private:
|
private:
|
||||||
|
void init(int argc, char* argv[]);
|
||||||
QString m_i2pdDataDir;
|
QString m_i2pdDataDir;
|
||||||
|
std::unique_ptr<i2p::util::NTPTimeSync> m_NTPSync;
|
||||||
|
bool m_isRunning;
|
||||||
};
|
};
|
||||||
|
|
||||||
#endif // I2PDMANAGER_H
|
#endif // I2PDMANAGER_H
|
||||||
|
|
Loading…
Reference in a new issue