mirror of
https://github.com/PurpleI2P/i2pd.git
synced 2025-01-22 08:14:15 +00:00
* sane log messages: Reseed.cpp
This commit is contained in:
parent
6c0dfc4356
commit
7936f8730f
44
Reseed.cpp
44
Reseed.cpp
@ -54,7 +54,7 @@ namespace data
|
|||||||
int Reseeder::ReseedFromSU3 (const std::string& host, bool https)
|
int Reseeder::ReseedFromSU3 (const std::string& host, bool https)
|
||||||
{
|
{
|
||||||
std::string url = host + "i2pseeds.su3";
|
std::string url = host + "i2pseeds.su3";
|
||||||
LogPrint (eLogInfo, "Dowloading SU3 from ", host);
|
LogPrint (eLogInfo, "Reseed: Downloading SU3 from ", host);
|
||||||
std::string su3 = https ? HttpsRequest (url) : i2p::util::http::httpRequest (url);
|
std::string su3 = https ? HttpsRequest (url) : i2p::util::http::httpRequest (url);
|
||||||
if (su3.length () > 0)
|
if (su3.length () > 0)
|
||||||
{
|
{
|
||||||
@ -63,7 +63,7 @@ namespace data
|
|||||||
}
|
}
|
||||||
else
|
else
|
||||||
{
|
{
|
||||||
LogPrint (eLogWarning, "SU3 download failed");
|
LogPrint (eLogWarning, "Reseed: SU3 download failed");
|
||||||
return 0;
|
return 0;
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
@ -75,7 +75,7 @@ namespace data
|
|||||||
return ProcessSU3Stream (s);
|
return ProcessSU3Stream (s);
|
||||||
else
|
else
|
||||||
{
|
{
|
||||||
LogPrint (eLogError, "Can't open file ", filename);
|
LogPrint (eLogError, "Reseed: Can't open file ", filename);
|
||||||
return 0;
|
return 0;
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
@ -90,7 +90,7 @@ namespace data
|
|||||||
s.read (magicNumber, 7); // magic number and zero byte 6
|
s.read (magicNumber, 7); // magic number and zero byte 6
|
||||||
if (strcmp (magicNumber, SU3_MAGIC_NUMBER))
|
if (strcmp (magicNumber, SU3_MAGIC_NUMBER))
|
||||||
{
|
{
|
||||||
LogPrint (eLogError, "Unexpected SU3 magic number");
|
LogPrint (eLogError, "Reseed: Unexpected SU3 magic number");
|
||||||
return 0;
|
return 0;
|
||||||
}
|
}
|
||||||
s.seekg (1, std::ios::cur); // su3 file format version
|
s.seekg (1, std::ios::cur); // su3 file format version
|
||||||
@ -114,7 +114,7 @@ namespace data
|
|||||||
s.read ((char *)&fileType, 1); // file type
|
s.read ((char *)&fileType, 1); // file type
|
||||||
if (fileType != 0x00) // zip file
|
if (fileType != 0x00) // zip file
|
||||||
{
|
{
|
||||||
LogPrint (eLogError, "Can't handle file type ", (int)fileType);
|
LogPrint (eLogError, "Reseed: Can't handle file type ", (int)fileType);
|
||||||
return 0;
|
return 0;
|
||||||
}
|
}
|
||||||
s.seekg (1, std::ios::cur); // unused
|
s.seekg (1, std::ios::cur); // unused
|
||||||
@ -122,7 +122,7 @@ namespace data
|
|||||||
s.read ((char *)&contentType, 1); // content type
|
s.read ((char *)&contentType, 1); // content type
|
||||||
if (contentType != 0x03) // reseed data
|
if (contentType != 0x03) // reseed data
|
||||||
{
|
{
|
||||||
LogPrint (eLogError, "Unexpected content type ", (int)contentType);
|
LogPrint (eLogError, "Reseed: Unexpected content type ", (int)contentType);
|
||||||
return 0;
|
return 0;
|
||||||
}
|
}
|
||||||
s.seekg (12, std::ios::cur); // unused
|
s.seekg (12, std::ios::cur); // unused
|
||||||
@ -162,7 +162,7 @@ namespace data
|
|||||||
// digest is right aligned
|
// digest is right aligned
|
||||||
// we can't use RSA_verify due wrong padding in SU3
|
// we can't use RSA_verify due wrong padding in SU3
|
||||||
if (memcmp (enSigBuf + (signatureLength - 64), digest, 64))
|
if (memcmp (enSigBuf + (signatureLength - 64), digest, 64))
|
||||||
LogPrint (eLogWarning, "SU3 signature verification failed");
|
LogPrint (eLogWarning, "Reseed: SU3 signature verification failed");
|
||||||
delete[] enSigBuf;
|
delete[] enSigBuf;
|
||||||
BN_free (s); BN_free (n);
|
BN_free (s); BN_free (n);
|
||||||
BN_CTX_free (bnctx);
|
BN_CTX_free (bnctx);
|
||||||
@ -173,10 +173,10 @@ namespace data
|
|||||||
s.seekg (pos, std::ios::beg);
|
s.seekg (pos, std::ios::beg);
|
||||||
}
|
}
|
||||||
else
|
else
|
||||||
LogPrint (eLogWarning, "Signature type ", signatureType, " is not supported");
|
LogPrint (eLogWarning, "Reseed: Signature type ", signatureType, " is not supported");
|
||||||
}
|
}
|
||||||
else
|
else
|
||||||
LogPrint (eLogWarning, "Certificate for ", signerID, " not loaded");
|
LogPrint (eLogWarning, "Reseed: Certificate for ", signerID, " not loaded");
|
||||||
|
|
||||||
// handle content
|
// handle content
|
||||||
int numFiles = 0;
|
int numFiles = 0;
|
||||||
@ -220,7 +220,7 @@ namespace data
|
|||||||
size_t pos = s.tellg ();
|
size_t pos = s.tellg ();
|
||||||
if (!FindZipDataDescriptor (s))
|
if (!FindZipDataDescriptor (s))
|
||||||
{
|
{
|
||||||
LogPrint (eLogError, "SU3 archive data descriptor not found");
|
LogPrint (eLogError, "Reseed: SU3 archive data descriptor not found");
|
||||||
return numFiles;
|
return numFiles;
|
||||||
}
|
}
|
||||||
s.read ((char *)&crc_32, 4);
|
s.read ((char *)&crc_32, 4);
|
||||||
@ -234,10 +234,10 @@ namespace data
|
|||||||
s.seekg (pos, std::ios::beg); // back to compressed data
|
s.seekg (pos, std::ios::beg); // back to compressed data
|
||||||
}
|
}
|
||||||
|
|
||||||
LogPrint (eLogDebug, "Proccessing file ", localFileName, " ", compressedSize, " bytes");
|
LogPrint (eLogDebug, "Reseed: Proccessing file ", localFileName, " ", compressedSize, " bytes");
|
||||||
if (!compressedSize)
|
if (!compressedSize)
|
||||||
{
|
{
|
||||||
LogPrint (eLogWarning, "Unexpected size 0. Skipped");
|
LogPrint (eLogWarning, "Reseed: Unexpected size 0. Skipped");
|
||||||
continue;
|
continue;
|
||||||
}
|
}
|
||||||
|
|
||||||
@ -263,10 +263,10 @@ namespace data
|
|||||||
numFiles++;
|
numFiles++;
|
||||||
}
|
}
|
||||||
else
|
else
|
||||||
LogPrint (eLogError, "CRC32 verification failed");
|
LogPrint (eLogError, "Reseed: CRC32 verification failed");
|
||||||
}
|
}
|
||||||
else
|
else
|
||||||
LogPrint (eLogError, "decompression error ", err);
|
LogPrint (eLogError, "Reseed: SU3 decompression error ", err);
|
||||||
delete[] uncompressed;
|
delete[] uncompressed;
|
||||||
inflateEnd (&inflator);
|
inflateEnd (&inflator);
|
||||||
}
|
}
|
||||||
@ -282,7 +282,7 @@ namespace data
|
|||||||
else
|
else
|
||||||
{
|
{
|
||||||
if (signature != ZIP_CENTRAL_DIRECTORY_HEADER_SIGNATURE)
|
if (signature != ZIP_CENTRAL_DIRECTORY_HEADER_SIGNATURE)
|
||||||
LogPrint (eLogWarning, "Missing zip central directory header");
|
LogPrint (eLogWarning, "Reseed: Missing zip central directory header");
|
||||||
break; // no more files
|
break; // no more files
|
||||||
}
|
}
|
||||||
size_t end = s.tellg ();
|
size_t end = s.tellg ();
|
||||||
@ -335,7 +335,7 @@ namespace data
|
|||||||
SSL_free (ssl);
|
SSL_free (ssl);
|
||||||
}
|
}
|
||||||
else
|
else
|
||||||
LogPrint (eLogError, "Can't open certificate file ", filename);
|
LogPrint (eLogError, "Reseed: Can't open certificate file ", filename);
|
||||||
SSL_CTX_free (ctx);
|
SSL_CTX_free (ctx);
|
||||||
}
|
}
|
||||||
|
|
||||||
@ -345,7 +345,7 @@ namespace data
|
|||||||
|
|
||||||
if (!boost::filesystem::exists (reseedDir))
|
if (!boost::filesystem::exists (reseedDir))
|
||||||
{
|
{
|
||||||
LogPrint (eLogWarning, "Reseed certificates not loaded. ", reseedDir, " doesn't exist");
|
LogPrint (eLogWarning, "Reseed: certificates not loaded, ", reseedDir, " doesn't exist");
|
||||||
return;
|
return;
|
||||||
}
|
}
|
||||||
|
|
||||||
@ -359,7 +359,7 @@ namespace data
|
|||||||
numCertificates++;
|
numCertificates++;
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
LogPrint (eLogInfo, numCertificates, " certificates loaded");
|
LogPrint (eLogInfo, "Reseed: ", numCertificates, " certificates loaded");
|
||||||
}
|
}
|
||||||
|
|
||||||
std::string Reseeder::HttpsRequest (const std::string& address)
|
std::string Reseeder::HttpsRequest (const std::string& address)
|
||||||
@ -382,7 +382,7 @@ namespace data
|
|||||||
s.handshake (boost::asio::ssl::stream_base::client, ecode);
|
s.handshake (boost::asio::ssl::stream_base::client, ecode);
|
||||||
if (!ecode)
|
if (!ecode)
|
||||||
{
|
{
|
||||||
LogPrint (eLogInfo, "Connected to ", u.host_, ":", u.port_);
|
LogPrint (eLogInfo, "Reseed: Connected to ", u.host_, ":", u.port_);
|
||||||
// send request
|
// send request
|
||||||
std::stringstream ss;
|
std::stringstream ss;
|
||||||
ss << "GET " << u.path_ << " HTTP/1.1\r\nHost: " << u.host_
|
ss << "GET " << u.path_ << " HTTP/1.1\r\nHost: " << u.host_
|
||||||
@ -401,13 +401,13 @@ namespace data
|
|||||||
return i2p::util::http::GetHttpContent (rs);
|
return i2p::util::http::GetHttpContent (rs);
|
||||||
}
|
}
|
||||||
else
|
else
|
||||||
LogPrint (eLogError, "SSL handshake failed: ", ecode.message ());
|
LogPrint (eLogError, "Reseed: SSL handshake failed: ", ecode.message ());
|
||||||
}
|
}
|
||||||
else
|
else
|
||||||
LogPrint (eLogError, "Couldn't connect to ", u.host_, ": ", ecode.message ());
|
LogPrint (eLogError, "Reseed: Couldn't connect to ", u.host_, ": ", ecode.message ());
|
||||||
}
|
}
|
||||||
else
|
else
|
||||||
LogPrint (eLogError, "Couldn't resolve address ", u.host_, ": ", ecode.message ());
|
LogPrint (eLogError, "Reseed: Couldn't resolve address ", u.host_, ": ", ecode.message ());
|
||||||
return "";
|
return "";
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
Loading…
x
Reference in New Issue
Block a user