Skip to content
This repository has been archived by the owner on Mar 3, 2020. It is now read-only.

Commit

Permalink
Read status and headers from response after load
Browse files Browse the repository at this point in the history
  • Loading branch information
mhoran committed Oct 24, 2012
1 parent e531c1a commit e9a4b77
Show file tree
Hide file tree
Showing 6 changed files with 41 additions and 26 deletions.
3 changes: 2 additions & 1 deletion .gitignore
Expand Up @@ -16,4 +16,5 @@ src/webkit_server.exe
.DS_Store .DS_Store
tmp tmp
.rvmrc .rvmrc
src/debug src/debug
webkit_server.pro.user
7 changes: 6 additions & 1 deletion src/Headers.cpp
Expand Up @@ -6,6 +6,11 @@ Headers::Headers(WebPageManager *manager, QStringList &arguments, QObject *paren
} }


void Headers::start() { void Headers::start() {
emit finished(new Response(true, page()->pageHeaders())); QStringList headers;

foreach(QNetworkReply::RawHeaderPair header, page()->pageHeaders())
headers << header.first+": "+header.second;

emit finished(new Response(true, headers.join("\n")));
} }


24 changes: 19 additions & 5 deletions src/NetworkAccessManager.cpp
Expand Up @@ -3,9 +3,9 @@
#include <iostream> #include <iostream>
#include <fstream> #include <fstream>



NetworkAccessManager::NetworkAccessManager(QObject *parent):QNetworkAccessManager(parent) { NetworkAccessManager::NetworkAccessManager(QObject *parent):QNetworkAccessManager(parent) {
connect(this, SIGNAL(authenticationRequired(QNetworkReply*,QAuthenticator*)), SLOT(provideAuthentication(QNetworkReply*,QAuthenticator*))); connect(this, SIGNAL(authenticationRequired(QNetworkReply*,QAuthenticator*)), SLOT(provideAuthentication(QNetworkReply*,QAuthenticator*)));
connect(this, SIGNAL(finished(QNetworkReply *)), this, SLOT(finished(QNetworkReply *)));
} }


QNetworkReply* NetworkAccessManager::createRequest(QNetworkAccessManager::Operation operation, const QNetworkRequest &request, QIODevice * outgoingData = 0) { QNetworkReply* NetworkAccessManager::createRequest(QNetworkAccessManager::Operation operation, const QNetworkRequest &request, QIODevice * outgoingData = 0) {
Expand All @@ -22,15 +22,22 @@ QNetworkReply* NetworkAccessManager::createRequest(QNetworkAccessManager::Operat
QNetworkReply *reply = QNetworkAccessManager::createRequest(operation, new_request, outgoingData); QNetworkReply *reply = QNetworkAccessManager::createRequest(operation, new_request, outgoingData);
emit requestCreated(url, reply); emit requestCreated(url, reply);
return reply; return reply;
}; }

void NetworkAccessManager::finished(QNetworkReply *reply) {
NetworkResponse response;
response.statusCode = reply->attribute(QNetworkRequest::HttpStatusCodeAttribute).toInt();
response.headers = reply->rawHeaderPairs();
m_responses[reply->url()] = response;
}


void NetworkAccessManager::addHeader(QString key, QString value) { void NetworkAccessManager::addHeader(QString key, QString value) {
m_headers.insert(key, value); m_headers.insert(key, value);
}; }


void NetworkAccessManager::resetHeaders() { void NetworkAccessManager::resetHeaders() {
m_headers.clear(); m_headers.clear();
}; }


void NetworkAccessManager::setUserName(const QString &userName) { void NetworkAccessManager::setUserName(const QString &userName) {
m_userName = userName; m_userName = userName;
Expand All @@ -40,9 +47,16 @@ void NetworkAccessManager::setPassword(const QString &password) {
m_password = password; m_password = password;
} }



void NetworkAccessManager::provideAuthentication(QNetworkReply *reply, QAuthenticator *authenticator) { void NetworkAccessManager::provideAuthentication(QNetworkReply *reply, QAuthenticator *authenticator) {
Q_UNUSED(reply); Q_UNUSED(reply);
authenticator->setUser(m_userName); authenticator->setUser(m_userName);
authenticator->setPassword(m_password); authenticator->setPassword(m_password);
} }

int NetworkAccessManager::statusFor(QUrl url) {
return m_responses[url].statusCode;
}

const QList<QNetworkReply::RawHeaderPair> &NetworkAccessManager::headersFor(QUrl url) {
return m_responses[url].headers;
}
10 changes: 10 additions & 0 deletions src/NetworkAccessManager.h
Expand Up @@ -6,12 +6,20 @@ class NetworkAccessManager : public QNetworkAccessManager {


Q_OBJECT Q_OBJECT


struct NetworkResponse {
int statusCode;
QList<QNetworkReply::RawHeaderPair> headers;
NetworkResponse() : statusCode(0) { }
};

public: public:
NetworkAccessManager(QObject *parent = 0); NetworkAccessManager(QObject *parent = 0);
void addHeader(QString key, QString value); void addHeader(QString key, QString value);
void resetHeaders(); void resetHeaders();
void setUserName(const QString &userName); void setUserName(const QString &userName);
void setPassword(const QString &password); void setPassword(const QString &password);
int statusFor(QUrl url);
const QList<QNetworkReply::RawHeaderPair> &headersFor(QUrl url);


protected: protected:
QNetworkReply* createRequest(QNetworkAccessManager::Operation op, const QNetworkRequest &req, QIODevice * outgoingData); QNetworkReply* createRequest(QNetworkAccessManager::Operation op, const QNetworkRequest &req, QIODevice * outgoingData);
Expand All @@ -20,9 +28,11 @@ class NetworkAccessManager : public QNetworkAccessManager {


private: private:
QHash<QString, QString> m_headers; QHash<QString, QString> m_headers;
QHash<QUrl, NetworkResponse> m_responses;


private slots: private slots:
void provideAuthentication(QNetworkReply *reply, QAuthenticator *authenticator); void provideAuthentication(QNetworkReply *reply, QAuthenticator *authenticator);
void finished(QNetworkReply *);


signals: signals:
void requestCreated(QByteArray &url, QNetworkReply *reply); void requestCreated(QByteArray &url, QNetworkReply *reply);
Expand Down
19 changes: 3 additions & 16 deletions src/WebPage.cpp
Expand Up @@ -14,7 +14,6 @@ WebPage::WebPage(WebPageManager *manager, QObject *parent) : QWebPage(parent) {
m_failed = false; m_failed = false;
m_manager = manager; m_manager = manager;
m_uuid = QUuid::createUuid().toString(); m_uuid = QUuid::createUuid().toString();
m_lastStatus = 0;


setForwardUnsupportedContent(true); setForwardUnsupportedContent(true);
loadJavascript(); loadJavascript();
Expand Down Expand Up @@ -56,18 +55,6 @@ void WebPage::networkAccessManagerCreatedRequest(QByteArray &url, QNetworkReply
} }


void WebPage::networkAccessManagerFinishedReply(QNetworkReply *reply) { void WebPage::networkAccessManagerFinishedReply(QNetworkReply *reply) {
if (reply->url() == this->currentFrame()->requestedUrl()) {
QStringList headers;
m_lastStatus = reply->attribute(QNetworkRequest::HttpStatusCodeAttribute).toInt();
QList<QByteArray> list = reply->rawHeaderList();

int length = list.size();
for(int i = 0; i < length; i++) {
headers << list.at(i)+": "+reply->rawHeader(list.at(i));
}

m_pageHeaders = headers.join("\n");
}
emit replyFinished(reply); emit replyFinished(reply);
} }


Expand Down Expand Up @@ -265,11 +252,11 @@ void WebPage::setSkipImageLoading(bool skip) {
} }


int WebPage::getLastStatus() { int WebPage::getLastStatus() {
return m_lastStatus; return qobject_cast<NetworkAccessManager *>(networkAccessManager())->statusFor(currentFrame()->url());
} }


QString WebPage::pageHeaders() { const QList<QNetworkReply::RawHeaderPair> &WebPage::pageHeaders() {
return m_pageHeaders; return qobject_cast<NetworkAccessManager *>(networkAccessManager())->headersFor(currentFrame()->url());
} }


void WebPage::handleUnsupportedContent(QNetworkReply *reply) { void WebPage::handleUnsupportedContent(QNetworkReply *reply) {
Expand Down
4 changes: 1 addition & 3 deletions src/WebPage.h
Expand Up @@ -39,7 +39,7 @@ class WebPage : public QWebPage {
void loadStarted(); void loadStarted();
void loadFinished(bool); void loadFinished(bool);
bool isLoading() const; bool isLoading() const;
QString pageHeaders(); const QList<QNetworkReply::RawHeaderPair> &pageHeaders();
void frameCreated(QWebFrame *); void frameCreated(QWebFrame *);
void handleSslErrorsForReply(QNetworkReply *reply, const QList<QSslError> &); void handleSslErrorsForReply(QNetworkReply *reply, const QList<QSslError> &);
void handleUnsupportedContent(QNetworkReply *reply); void handleUnsupportedContent(QNetworkReply *reply);
Expand Down Expand Up @@ -67,8 +67,6 @@ class WebPage : public QWebPage {
QString getLastAttachedFileName(); QString getLastAttachedFileName();
void loadJavascript(); void loadJavascript();
void setUserStylesheet(); void setUserStylesheet();
int m_lastStatus;
QString m_pageHeaders;
bool m_confirm; bool m_confirm;
bool m_prompt; bool m_prompt;
QStringList m_consoleMessages; QStringList m_consoleMessages;
Expand Down

0 comments on commit e9a4b77

Please sign in to comment.