summaryrefslogtreecommitdiff
path: root/src/networkaccessmanager.cpp
diff options
context:
space:
mode:
authorAndrea Diamantini <adjam7@gmail.com>2009-09-26 00:45:34 +0200
committerAndrea Diamantini <adjam7@gmail.com>2009-09-26 00:45:34 +0200
commitc390fba4a976bd7998de681fed4c2aaeb29139d7 (patch)
tree4f266ca182eab53024574e9c36a61912e35a47bd /src/networkaccessmanager.cpp
parentFixing sessionmanager (at least I hope so): (diff)
downloadrekonq-c390fba4a976bd7998de681fed4c2aaeb29139d7.tar.xz
AccessManager fixes
- create request method - network disk cache
Diffstat (limited to 'src/networkaccessmanager.cpp')
-rw-r--r--src/networkaccessmanager.cpp49
1 files changed, 25 insertions, 24 deletions
diff --git a/src/networkaccessmanager.cpp b/src/networkaccessmanager.cpp
index 90d27cd0..c7f9790b 100644
--- a/src/networkaccessmanager.cpp
+++ b/src/networkaccessmanager.cpp
@@ -57,7 +57,6 @@
NetworkAccessManager::NetworkAccessManager(QObject *parent)
: AccessManager(parent)
- , m_diskCache(0)
{
connect(this, SIGNAL(authenticationRequired(QNetworkReply*, QAuthenticator*)),
SLOT(authenticationRequired(QNetworkReply*, QAuthenticator*)));
@@ -102,25 +101,14 @@ void NetworkAccessManager::loadSettings()
void NetworkAccessManager::resetDiskCache()
{
- if(!m_diskCache)
+ if(!cache())
{
- m_diskCache = new QNetworkDiskCache(this);
- QString location = KStandardDirs::locateLocal("cache", "", true);
-
- m_diskCache->setCacheDirectory(location);
- setCache(m_diskCache);
+ QNetworkDiskCache *diskCache = new QNetworkDiskCache(this);
+ setCache(diskCache);
}
else
{
- QString location = m_diskCache->cacheDirectory();
-
- QDir cacheDir(location + QString("/http") );
- QStringList fileList = cacheDir.entryList();
- Q_FOREACH(QString str, fileList)
- {
- QFile file(str);
- file.remove();
- }
+ cache()->clear();
}
}
@@ -203,26 +191,39 @@ void NetworkAccessManager::slotSSLErrors(QNetworkReply *reply, const QList<QSslE
#endif
-KIO::MetaData& NetworkAccessManager::metaData()
+KIO::MetaData& NetworkAccessManager::sessionMetaData()
{
- return m_metaData;
-};
+ return m_sessionMetaData;
+}
+
+
+KIO::MetaData& NetworkAccessManager::requestMetaData()
+{
+ return m_requestMetaData;
+}
QNetworkReply *NetworkAccessManager::createRequest(Operation op, const QNetworkRequest &req, QIODevice *outgoingData)
{
// TODO implement Ad-Block here (refuse connections..)
-
- QNetworkRequest request(req);
- KIO::MetaData metaData(m_metaData);
+ QNetworkRequest request(req);
+ KIO::MetaData metaData = m_sessionMetaData;
+ metaData += m_requestMetaData;
QVariant attr = req.attribute(QNetworkRequest::User);
if (attr.isValid() && attr.type() == QVariant::Map)
{
metaData += attr.toMap();
}
- request.setAttribute(QNetworkRequest::User, metaData.toVariant());
- return AccessManager::createRequest(op,request,outgoingData);
+ if (!metaData.isEmpty())
+ {
+ attr = metaData.toVariant();
+ request.setAttribute(QNetworkRequest::User, attr);
+ }
+
+ // Clear the per request meta data...
+ m_requestMetaData.clear();
+ return AccessManager::createRequest(op, request, outgoingData);
}