mirror of
https://github.com/PurpleI2P/i2pd
synced 2024-11-10 00:00:29 +03:00
* I2PControl.cpp : fix handling relative paths for cert/key
This commit is contained in:
parent
900fc1cb46
commit
3da6b3930b
@ -39,17 +39,23 @@ namespace client
|
|||||||
// certificate / keys
|
// certificate / keys
|
||||||
std::string i2pcp_crt; i2p::config::GetOption("i2pcontrol.cert", i2pcp_crt);
|
std::string i2pcp_crt; i2p::config::GetOption("i2pcontrol.cert", i2pcp_crt);
|
||||||
std::string i2pcp_key; i2p::config::GetOption("i2pcontrol.key", i2pcp_key);
|
std::string i2pcp_key; i2p::config::GetOption("i2pcontrol.key", i2pcp_key);
|
||||||
// TODO: properly handle absolute paths
|
|
||||||
auto path = GetPath ();
|
auto path = GetPath ();
|
||||||
if (!boost::filesystem::exists (path / i2pcp_crt) ||
|
// TODO: move this to i2p::fs::expand
|
||||||
!boost::filesystem::exists (path / i2pcp_key))
|
if (i2pcp_crt.at(0) != '/')
|
||||||
|
i2pcp_crt.insert(0, (path / "/").string());
|
||||||
|
if (i2pcp_key.at(0) != '/')
|
||||||
|
i2pcp_key.insert(0, (path / "/").string());
|
||||||
|
if (!boost::filesystem::exists (i2pcp_crt) ||
|
||||||
|
!boost::filesystem::exists (i2pcp_key))
|
||||||
{
|
{
|
||||||
LogPrint (eLogInfo, "I2PControl: creating new certificate for control connection");
|
LogPrint (eLogInfo, "I2PControl: creating new certificate for control connection");
|
||||||
CreateCertificate (i2pcp_crt.c_str(), i2pcp_key.c_str());
|
CreateCertificate (i2pcp_crt.c_str(), i2pcp_key.c_str());
|
||||||
|
} else {
|
||||||
|
LogPrint(eLogDebug, "I2PControl: using cert from ", i2pcp_crt);
|
||||||
}
|
}
|
||||||
m_SSLContext.set_options (boost::asio::ssl::context::default_workarounds | boost::asio::ssl::context::no_sslv2 | boost::asio::ssl::context::single_dh_use);
|
m_SSLContext.set_options (boost::asio::ssl::context::default_workarounds | boost::asio::ssl::context::no_sslv2 | boost::asio::ssl::context::single_dh_use);
|
||||||
m_SSLContext.use_certificate_file ((path / i2pcp_crt).string (), boost::asio::ssl::context::pem);
|
m_SSLContext.use_certificate_file (i2pcp_crt, boost::asio::ssl::context::pem);
|
||||||
m_SSLContext.use_private_key_file ((path / i2pcp_crt).string (), boost::asio::ssl::context::pem);
|
m_SSLContext.use_private_key_file (i2pcp_key, boost::asio::ssl::context::pem);
|
||||||
|
|
||||||
// handlers
|
// handlers
|
||||||
m_MethodHandlers["Authenticate"] = &I2PControlService::AuthenticateHandler;
|
m_MethodHandlers["Authenticate"] = &I2PControlService::AuthenticateHandler;
|
||||||
|
Loading…
Reference in New Issue
Block a user