diff --git a/HTTPServer.cpp b/HTTPServer.cpp
index b990614a..57afe6b4 100644
--- a/HTTPServer.cpp
+++ b/HTTPServer.cpp
@@ -8,106 +8,15 @@
#include "NetDb.h"
#include "HTTPServer.h"
+// For image and info
+#include "version.h"
+
namespace i2p
{
namespace util
{
- const std::string HTTPConnection::itoopieImage =
- "";
+ const std::string HTTPConnection::itoopieImage = ICTOOPIE_128;
namespace misc_strings
{
@@ -229,7 +138,13 @@ namespace util
void HTTPConnection::HandleRequest ()
{
std::stringstream s;
- s << "";
+ // Html5 head start
+ s << "\n"; // TODO: Add support for locale.
+ s << "
"; // TODO: Find something to parse html/template system. This is horrible.
+ s << "Purple I2Pd Webconsole";
+ // Head end
FillContent (s);
s << "";
SendReply (s.str ());
@@ -237,8 +152,9 @@ namespace util
void HTTPConnection::FillContent (std::stringstream& s)
{
- s << "Data path: " << i2p::util::filesystem::GetDataDir().string() << "
" << "
";
- s << "Our external address:" << "
";
+ s << "Welcome to the Webconsole!
";
+ s << "Data path: " << i2p::util::filesystem::GetDataDir().string() << "
" << "
";
+ s << "Our external address:" << "
";
for (auto& address : i2p::context.GetRouterInfo().GetAddresses())
{
switch (address.transportStyle)
@@ -252,13 +168,13 @@ namespace util
default:
s << "Unknown ";
}
- s << address.host.to_string() << ":" << address.port << "
";
+ s << address.host.to_string() << ":" << address.port << "
";
}
- s << "
Routers: " << i2p::data::netdb.GetNumRouters () << " ";
- s << "Floodfills: " << i2p::data::netdb.GetNumFloodfills () << " ";
- s << "LeaseSets: " << i2p::data::netdb.GetNumLeaseSets () << "
";
+ s << "
Routers: " << i2p::data::netdb.GetNumRouters () << " ";
+ s << "Floodfills: " << i2p::data::netdb.GetNumFloodfills () << " ";
+ s << "LeaseSets: " << i2p::data::netdb.GetNumLeaseSets () << "
";
- s << "Tunnels
";
+ s << "
Tunnels
";
for (auto it: i2p::tunnel::tunnels.GetOutboundTunnels ())
{
it->GetTunnelConfig ()->Print (s);
@@ -266,7 +182,7 @@ namespace util
s << " " << "Pool";
if (it->IsFailed ())
s << " " << "Failed";
- s << " " << (int)it->GetNumSentBytes () << "
";
+ s << " " << (int)it->GetNumSentBytes () << "
";
}
for (auto it: i2p::tunnel::tunnels.GetInboundTunnels ())
@@ -276,10 +192,10 @@ namespace util
s << " " << "Pool";
if (it.second->IsFailed ())
s << " " << "Failed";
- s << " " << (int)it.second->GetNumReceivedBytes () << "
";
+ s << " " << (int)it.second->GetNumReceivedBytes () << "
";
}
- s << "Transit tunnels
";
+ s << "
Transit tunnels
";
for (auto it: i2p::tunnel::tunnels.GetTransitTunnels ())
{
if (dynamic_cast(it.second))
@@ -288,11 +204,11 @@ namespace util
s << "-->" << it.second->GetTunnelID ();
else
s << "-->" << it.second->GetTunnelID () << "-->";
- s << " " << it.second->GetNumTransmittedBytes () << "
";
+ s << " " << it.second->GetNumTransmittedBytes () << "
";
}
- s << "Transports
";
- s << "NTCP
";
+ s << "
Transports
";
+ s << "NTCP
";
for (auto it: i2p::transports.GetNTCPSessions ())
{
// RouterInfo of incoming connection doesn't have address
@@ -304,13 +220,13 @@ namespace util
<< it.second->GetSocket ().remote_endpoint().address ().to_string ();
if (!outgoing) s << "-->";
s << " [" << it.second->GetNumSentBytes () << ":" << it.second->GetNumReceivedBytes () << "]";
- s << "
";
+ s << "
";
}
}
auto ssuServer = i2p::transports.GetSSUServer ();
if (ssuServer)
{
- s << "
SSU
";
+ s << "
SSU
";
for (auto it: ssuServer->GetSessions ())
{
// incoming connections don't have remote router
@@ -320,7 +236,7 @@ namespace util
s << endpoint.address ().to_string () << ":" << endpoint.port ();
if (!outgoing) s << "-->";
s << " [" << it.second->GetNumSentBytes () << ":" << it.second->GetNumReceivedBytes () << "]";
- s << "
";
+ s << "
";
}
}
s << "Flibusta
";
@@ -370,7 +286,7 @@ namespace util
EepAccept (destination);
}
else
- {
+ {
if (i2p::data::Base32ToByteStream(address.c_str(), address.length(), (uint8_t *)destination, 32) != 32)
{
LogPrint("Invalid Base32 address ", address);
@@ -378,7 +294,7 @@ namespace util
return;
}
fullAddress = address + ".b32.i2p";
- }
+ }
}
}
@@ -431,7 +347,7 @@ namespace util
{
if (ecode == boost::asio::error::timed_out)
SendReply ("" + itoopieImage + "
Not responding", 504);
- else
+ else
Terminate ();
}
}
@@ -509,21 +425,21 @@ namespace util
}
// eepSite. TODO: move away
-
+
void HTTPConnection::EepAccept (i2p::stream::StreamingDestination * destination)
{
if (destination)
destination->SetAcceptor (std::bind (&HTTPConnection::HandleEepAccept, this, std::placeholders::_1));
}
-
+
void HTTPConnection::HandleEepAccept (i2p::stream::Stream * stream)
{
if (stream)
- {
+ {
auto conn = new EepSiteDummyConnection (stream);
conn->AsyncStreamReceive ();
- }
- }
+ }
+ }
void EepSiteDummyConnection::AsyncStreamReceive ()
{
@@ -532,15 +448,15 @@ namespace util
boost::bind (&EepSiteDummyConnection::HandleStreamReceive, this,
boost::asio::placeholders::error, boost::asio::placeholders::bytes_transferred),
60); // 60 seconds timeout
- }
-
+ }
+
void EepSiteDummyConnection::HandleStreamReceive (const boost::system::error_code& ecode, std::size_t bytes_transferred)
{
if (ecode)
- {
+ {
LogPrint ("eepSite error: ", ecode.message ());
DeleteStream (m_Stream);
- }
+ }
else
{
std::string content ("");
@@ -548,13 +464,13 @@ namespace util
std::string response ("HTTP/1.0 200 OK\r\n");
response += "Content-Length: " + boost::lexical_cast(content.length()) + "\r\n";
response += "Content-Type: text/html\r\n\r\n";
- response += content;
+ response += content;
m_Stream->Send ((uint8_t *)response.c_str (), response.length (), 30);
m_Stream->Close ();
- }
+ }
delete this;
- }
-
+ }
+
}
}
diff --git a/version.h b/version.h
index 52316fd2..68797867 100644
--- a/version.h
+++ b/version.h
@@ -8,4 +8,11 @@
#define I2P_VERSION "0.9.11"
+/* TEMPORARY STORE FOR IMAGE CODES */
+
+#define ICTOOPIE_128 ""
+
+#define ICTOOPIE_64_FAVICON ""
+
+
#endif