From 3a6199fb2348f9bdef8ab155fdd158a3e8cbfeec Mon Sep 17 00:00:00 2001 From: brain Date: Sun, 24 Feb 2008 15:57:21 +0000 Subject: This craq can go byebye git-svn-id: http://svn.inspircd.org/repository/trunk/inspircd@9020 e03df62e-2008-0410-955e-edbf42e46eb7 --- src/modules/m_remoteinclude_http.cpp | 127 ----------------------------------- 1 file changed, 127 deletions(-) delete mode 100644 src/modules/m_remoteinclude_http.cpp (limited to 'src') diff --git a/src/modules/m_remoteinclude_http.cpp b/src/modules/m_remoteinclude_http.cpp deleted file mode 100644 index a0dc6cb0e..000000000 --- a/src/modules/m_remoteinclude_http.cpp +++ /dev/null @@ -1,127 +0,0 @@ -/* +------------------------------------+ - * | Inspire Internet Relay Chat Daemon | - * +------------------------------------+ - * - * InspIRCd: (C) 2002-2008 InspIRCd Development Team - * See: http://www.inspircd.org/wiki/index.php/Credits - * - * This program is free but copyrighted software; see - * the file COPYING for details. - * - * --------------------------------------------------- - */ - -#include "inspircd.h" - -/* $ModDesc: Remote includes HTTP scheme */ - -using irc::sockets::OpenTCPSocket; - -class ModuleRemoteIncludeHttp : public Module -{ - public: - - ModuleRemoteIncludeHttp(InspIRCd* Me) - : Module(Me) - { - // The constructor just makes a copy of the server class - - - Implementation eventlist[] = { I_OnDownloadFile }; - ServerInstance->Modules->Attach(eventlist, this, 1); - } - - virtual ~ModuleRemoteIncludeHttp() - { - } - - virtual int OnDownloadFile(const std::string &filename, std::istream* &filedata) - { -#ifdef WIN32 - return 0; -#else - std::stringstream* gotfile = (std::stringstream*)filedata; - ServerInstance->Logs->Log("m_remoteinclude_http",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"); - - sockfd = socket(AF_INET, SOCK_STREAM, 0); - if (sockfd < 0) - { - ServerInstance->Logs->Log("m_remoteinclude_http",DEBUG,"Failed to socket()"); - return 0; - } - - if (server == NULL) - { - ServerInstance->Logs->Log("m_remoteinclude_http",DEBUG,"No such host"); - return 0; - } - - memset(&serv_addr, sizeof(serv_addr), 0); - - serv_addr.sin_family = AF_INET; - - memcpy(&serv_addr.sin_addr.s_addr, server->h_addr, server->h_length); - serv_addr.sin_port = htons(portno); - - if (connect(sockfd, (const sockaddr*)&serv_addr, sizeof(serv_addr)) < 0) - { - ServerInstance->Logs->Log("m_remoteinclude_http",DEBUG,"Failed to connect()"); - return 0; - } - - ServerInstance->Logs->Log("m_remoteinclude_http",DEBUG,"Connected to brainbox"); - - 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->Logs->Log("m_remoteinclude_http",DEBUG,"Failed to send()"); - return 0; - } - - ServerInstance->Logs->Log("m_remoteinclude_http",DEBUG,"Sent GET request"); - - while (((n = read(sockfd,buffer,65535)) > 0)) - { - std::string output(buffer, 0, n); - (*(gotfile)) << output; - } - - ServerInstance->Logs->Log("m_remoteinclude_http",DEBUG,"Read page"); - - std::string version, result; - (*(gotfile)) >> version; - (*(gotfile)) >> result; - - /* HTTP/1.1 200 OK */ - - ServerInstance->Logs->Log("m_remoteinclude_http",DEBUG,"Result: %s", result.c_str()); - - return (result == "200"); -#endif - } - - int SockSend(int sock, const std::string &data) - { - return send(sock, data.data(), data.length(), 0); - } - - virtual Version GetVersion() - { - return Version(1,1,0,1,VF_VENDOR,API_VERSION); - } -}; - - -MODULE_INIT(ModuleRemoteIncludeHttp) - -- cgit v1.2.3