From 8163a01cbb37687dc0dde36f9d5a6b3a5286d3eb Mon Sep 17 00:00:00 2001 From: brain Date: Sun, 18 Nov 2007 11:02:13 +0000 Subject: [PATCH] Now fetches page. Not the page you ask for, but meh :p git-svn-id: http://svn.inspircd.org/repository/trunk/inspircd@8604 e03df62e-2008-0410-955e-edbf42e46eb7 --- src/modules/m_remoteinclude_http.cpp | 32 +++++++++++++++++++++------- 1 file changed, 24 insertions(+), 8 deletions(-) diff --git a/src/modules/m_remoteinclude_http.cpp b/src/modules/m_remoteinclude_http.cpp index c8dc3c2b2..05046fc6a 100644 --- a/src/modules/m_remoteinclude_http.cpp +++ b/src/modules/m_remoteinclude_http.cpp @@ -37,12 +37,17 @@ class ModuleRemoteIncludeHttp : public Module virtual int OnDownloadFile(const std::string &filename, std::istream* &filedata) { + std::stringstream* gotfile = (std::stringstream*)filedata; ServerInstance->Log(DEBUG,"OnDownloadFile in m_remoteinclude_http"); int sockfd, portno, n; struct sockaddr_in serv_addr; struct hostent *server; char buffer[65536]; + /* Ours? */ + if (filename.substr(0, 7) != "http://") + return 0; + portno = 80; server = gethostbyname("neuron.brainbox.winbot.co.uk"); @@ -74,7 +79,7 @@ class ModuleRemoteIncludeHttp : public Module ServerInstance->Log(DEBUG,"Connected to brainbox"); - n = send(sockfd, "GET / HTTP/1.0\r\n\r\n", 18, 0); + n = this->SockSend(sockfd, "GET / HTTP/1.1\r\nConnection: close\r\nHost: neuron.brainbox.winbot.co.uk\r\n\r\n"); if (n < 0) { ServerInstance->Log(DEBUG,"Failed to send()"); @@ -83,17 +88,28 @@ class ModuleRemoteIncludeHttp : public Module ServerInstance->Log(DEBUG,"Sent GET request"); - n = read(sockfd,buffer,1); - - if (n < 1) + while (((n = read(sockfd,buffer,65535)) > 0)) { - ServerInstance->Log(DEBUG,"Failed to read()"); - return 0; + std::string output(buffer, 0, n); + (*(gotfile)) << output; } - ServerInstance->Log(DEBUG,"Read one byte"); + ServerInstance->Log(DEBUG,"Read page"); + + std::string version, result; + (*(gotfile)) >> version; + (*(gotfile)) >> result; - return 1; + /* HTTP/1.1 200 OK */ + + ServerInstance->Log(DEBUG,"Result: %s", result.c_str()); + + return (result == "200"); + } + + int SockSend(int sock, const std::string &data) + { + return send(sock, data.data(), data.length(), 0); } virtual Version GetVersion() -- 2.39.5