/* * Bittorrent Client using Qt4 and libtorrent. * Copyright (C) 2006 Ishan Arora and Christophe Dumez * * This program is free software; you can redistribute it and/or * modify it under the terms of the GNU General Public License * as published by the Free Software Foundation; either version 2 * of the License, or (at your option) any later version. * * This program is distributed in the hope that it will be useful, * but WITHOUT ANY WARRANTY; without even the implied warranty of * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the * GNU General Public License for more details. * * You should have received a copy of the GNU General Public License * along with this program; if not, write to the Free Software * Foundation, Inc., 51 Franklin Street, Fifth Floor, Boston, MA 02110-1301, USA. * * In addition, as a special exception, the copyright holders give permission to * link this program with the OpenSSL project's "OpenSSL" library (or with * modified versions of it that use the same license as the "OpenSSL" library), * and distribute the linked executables. You must obey the GNU General Public * License in all respects for all of the code used other than "OpenSSL". If you * modify file(s), you may extend this exception to your version of the file(s), * but you are not obligated to do so. If you do not wish to do so, delete this * exception statement from your version. * * Contact : chris@qbittorrent.org */ #include "httprequestparser.h" #include #include HttpRequestParser::HttpRequestParser() { headerDone = false; messageDone = false; error = false; } HttpRequestParser::~HttpRequestParser() { } bool HttpRequestParser::isParsable() const { return !error && headerDone && isValid() && (messageDone || !hasContentLength() || contentLength() == 0); } bool HttpRequestParser::isError() const { return error; } QString HttpRequestParser::url() const { return path; } QByteArray HttpRequestParser::message() const { if(isParsable()) return data; return QByteArray(); } QString HttpRequestParser::get(const QString key) const { return getMap[key]; } QString HttpRequestParser::post(const QString key) const { return postMap[key]; } QByteArray HttpRequestParser::torrent() const { return torrent_content; } void HttpRequestParser::write(QByteArray str) { while (!headerDone && str.size()>0) { int index = str.indexOf('\n') + 1; if(index == 0) { data += str; str.clear(); } else { data += str.left(index); str.remove(0, index); if(data.right(4) == "\r\n\r\n") { QHttpRequestHeader::operator=(QHttpRequestHeader(data)); headerDone = true; data.clear(); QUrl url = QUrl::fromEncoded(QHttpRequestHeader::path().toAscii()); path = url.path(); //() << path; QListIterator > i(url.queryItems()); while (i.hasNext()) { QPair pair = i.next(); getMap[pair.first] = pair.second; //qDebug() << pair.first << "=" << get(pair.first); } } } } if(!messageDone && str.size()>0) { if(hasContentLength()) { data += str; if(data.size() >= (int) contentLength()) { data.resize(contentLength()); messageDone = true; //parse POST data if(contentType() == "application/x-www-form-urlencoded") { QUrl url; url.setEncodedQuery(data); QListIterator > i(url.queryItems()); while (i.hasNext()) { QPair pair = i.next(); postMap[pair.first] = pair.second; //qDebug() << pair.first << "=" << post(pair.first); } } if(contentType() == "multipart/form-data") { //qDebug() << data.right(data.size()-data.indexOf("\r\n\r\n")-QByteArray("\r\n\r\n").size()); torrent_content = data.right(data.size()-data.indexOf("\r\n\r\n")-QByteArray("\r\n\r\n").size()); } } } else error = true; } }