From 7b0df27591cf2b619d21fb44c5cf26ae9c52e065 Mon Sep 17 00:00:00 2001 From: Mikal Villa Date: Sun, 17 Aug 2014 13:20:57 +0200 Subject: [PATCH] Improving some html on the webconsole. I'm gonna need to import css files, or bundle them inside. And a html parser. --- HTTPServer.cpp | 172 +++++++++++++------------------------------------ version.h | 7 ++ 2 files changed, 51 insertions(+), 128 deletions(-) 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 "\"ICToopie" + +#define ICTOOPIE_64_FAVICON "" + + #endif