mirror of
https://github.com/qbittorrent/qBittorrent.git
synced 2024-11-25 10:46:15 +03:00
RSS Feed was not displaying remote images in html description. Closes #1119
This commit is contained in:
parent
60bc22119d
commit
2c6df559e8
4 changed files with 138 additions and 3 deletions
92
src/rss/htmlbrowser.cpp
Normal file
92
src/rss/htmlbrowser.cpp
Normal file
|
@ -0,0 +1,92 @@
|
||||||
|
#include "htmlbrowser.h"
|
||||||
|
|
||||||
|
#include <QDebug>
|
||||||
|
#include <QNetworkRequest>
|
||||||
|
#include <QNetworkReply>
|
||||||
|
#include <QNetworkDiskCache>
|
||||||
|
#include <QStyle>
|
||||||
|
#include <QApplication>
|
||||||
|
#include <QDir>
|
||||||
|
#include <QDateTime>
|
||||||
|
#include <QScrollBar>
|
||||||
|
|
||||||
|
#include "fs_utils.h"
|
||||||
|
|
||||||
|
HtmlBrowser::HtmlBrowser(QWidget* parent)
|
||||||
|
: QTextBrowser(parent)
|
||||||
|
{
|
||||||
|
m_netManager = new QNetworkAccessManager(this);
|
||||||
|
m_diskCache = new QNetworkDiskCache(this);
|
||||||
|
m_diskCache->setCacheDirectory(QDir::cleanPath(fsutils::cacheLocation() + "/browser"));
|
||||||
|
m_diskCache->setMaximumCacheSize(50 * 1024 * 1024);
|
||||||
|
qDebug() << "HtmlBrowser cache path:" << m_diskCache->cacheDirectory() << " max size:" << m_diskCache->maximumCacheSize() / 1024 / 1024 << "MB";
|
||||||
|
m_netManager->setCache(m_diskCache);
|
||||||
|
|
||||||
|
connect(m_netManager, SIGNAL(finished(QNetworkReply *)), this, SLOT(resourceLoaded(QNetworkReply*)));
|
||||||
|
}
|
||||||
|
|
||||||
|
HtmlBrowser::~HtmlBrowser()
|
||||||
|
{
|
||||||
|
}
|
||||||
|
|
||||||
|
QVariant HtmlBrowser::loadResource(int type, const QUrl &name)
|
||||||
|
{
|
||||||
|
if(type == QTextDocument::ImageResource) {
|
||||||
|
QUrl url(name);
|
||||||
|
if(url.scheme().isEmpty())
|
||||||
|
url.setScheme("http");
|
||||||
|
|
||||||
|
QIODevice *dev = m_diskCache->data(url);
|
||||||
|
if(dev != 0) {
|
||||||
|
qDebug() << "HtmlBrowser::loadResource() cache " << url.toString();
|
||||||
|
QByteArray res = dev->readAll();
|
||||||
|
delete dev;
|
||||||
|
return res;
|
||||||
|
}
|
||||||
|
|
||||||
|
if(!m_activeRequests.contains(url)) {
|
||||||
|
m_activeRequests.insert(url, true);
|
||||||
|
qDebug() << "HtmlBrowser::loadResource() get " << url.toString();
|
||||||
|
QNetworkRequest req(url);
|
||||||
|
req.setAttribute(QNetworkRequest::CacheLoadControlAttribute, QNetworkRequest::PreferCache);
|
||||||
|
m_netManager->get(req);
|
||||||
|
}
|
||||||
|
|
||||||
|
return QVariant();
|
||||||
|
}
|
||||||
|
|
||||||
|
return QTextBrowser::loadResource(type, name);
|
||||||
|
}
|
||||||
|
|
||||||
|
void HtmlBrowser::resourceLoaded(QNetworkReply *reply)
|
||||||
|
{
|
||||||
|
m_activeRequests.remove(reply->request().url());
|
||||||
|
|
||||||
|
if(reply->error() == QNetworkReply::NoError && reply->size() > 0) {
|
||||||
|
qDebug() << "HtmlBrowser::resourceLoaded() save " << reply->request().url().toString();
|
||||||
|
} else {
|
||||||
|
// If resource failed to load, replace it with warning icon and store it in cache for 1 day.
|
||||||
|
// Otherwise HTMLBrowser will keep trying to download it every time article is displayed,
|
||||||
|
// since it's not possible to cache error responses.
|
||||||
|
QNetworkCacheMetaData metaData;
|
||||||
|
QNetworkCacheMetaData::AttributesMap atts;
|
||||||
|
metaData.setUrl(reply->request().url());
|
||||||
|
metaData.setSaveToDisk(true);
|
||||||
|
atts[QNetworkRequest::HttpStatusCodeAttribute] = 200;
|
||||||
|
atts[QNetworkRequest::HttpReasonPhraseAttribute] = "Ok";
|
||||||
|
metaData.setAttributes(atts);
|
||||||
|
metaData.setLastModified(QDateTime::currentDateTime());
|
||||||
|
metaData.setExpirationDate(QDateTime::currentDateTime().addDays(1));
|
||||||
|
QIODevice *dev = m_diskCache->prepare(metaData);
|
||||||
|
if(!dev)
|
||||||
|
return;
|
||||||
|
QApplication::style()->standardIcon(QStyle::SP_MessageBoxWarning).pixmap(32, 32).save(dev, "PNG");
|
||||||
|
m_diskCache->insert(dev);
|
||||||
|
}
|
||||||
|
// Refresh the document display and keep scrollbars where they are
|
||||||
|
int sx = horizontalScrollBar()->value();
|
||||||
|
int sy = verticalScrollBar()->value();
|
||||||
|
document()->setHtml(document()->toHtml());
|
||||||
|
horizontalScrollBar()->setValue(sx);
|
||||||
|
verticalScrollBar()->setValue(sy);
|
||||||
|
}
|
30
src/rss/htmlbrowser.h
Normal file
30
src/rss/htmlbrowser.h
Normal file
|
@ -0,0 +1,30 @@
|
||||||
|
#ifndef HTMLBROWSER_H
|
||||||
|
#define HTMLBROWSER_H
|
||||||
|
|
||||||
|
#include <QTextBrowser>
|
||||||
|
#include <QHash>
|
||||||
|
|
||||||
|
class QNetworkAccessManager;
|
||||||
|
class QNetworkDiskCache;
|
||||||
|
class QNetworkReply;
|
||||||
|
|
||||||
|
class HtmlBrowser : public QTextBrowser
|
||||||
|
{
|
||||||
|
Q_OBJECT
|
||||||
|
|
||||||
|
public:
|
||||||
|
explicit HtmlBrowser(QWidget* parent = 0);
|
||||||
|
~HtmlBrowser();
|
||||||
|
|
||||||
|
virtual QVariant loadResource(int type, const QUrl &name);
|
||||||
|
|
||||||
|
protected:
|
||||||
|
QNetworkAccessManager *m_netManager;
|
||||||
|
QNetworkDiskCache *m_diskCache;
|
||||||
|
QHash<QUrl, bool> m_activeRequests;
|
||||||
|
|
||||||
|
protected slots:
|
||||||
|
void resourceLoaded(QNetworkReply *reply);
|
||||||
|
};
|
||||||
|
|
||||||
|
#endif // HTMLBROWSER_H
|
|
@ -12,7 +12,8 @@ HEADERS += $$PWD/rss_imp.h \
|
||||||
$$PWD/rssdownloadrule.h \
|
$$PWD/rssdownloadrule.h \
|
||||||
$$PWD/rssdownloadrulelist.h \
|
$$PWD/rssdownloadrulelist.h \
|
||||||
$$PWD/cookiesdlg.h \
|
$$PWD/cookiesdlg.h \
|
||||||
$$PWD/rssparser.h
|
$$PWD/rssparser.h \
|
||||||
|
$$PWD/htmlbrowser.h
|
||||||
|
|
||||||
SOURCES += $$PWD/rss_imp.cpp \
|
SOURCES += $$PWD/rss_imp.cpp \
|
||||||
$$PWD/rsssettingsdlg.cpp \
|
$$PWD/rsssettingsdlg.cpp \
|
||||||
|
@ -26,7 +27,8 @@ SOURCES += $$PWD/rss_imp.cpp \
|
||||||
$$PWD/rssdownloadrulelist.cpp \
|
$$PWD/rssdownloadrulelist.cpp \
|
||||||
$$PWD/cookiesdlg.cpp \
|
$$PWD/cookiesdlg.cpp \
|
||||||
$$PWD/rssfile.cpp \
|
$$PWD/rssfile.cpp \
|
||||||
$$PWD/rssparser.cpp
|
$$PWD/rssparser.cpp \
|
||||||
|
$$PWD/htmlbrowser.cpp
|
||||||
|
|
||||||
FORMS += $$PWD/rss.ui \
|
FORMS += $$PWD/rss.ui \
|
||||||
$$PWD/rsssettingsdlg.ui \
|
$$PWD/rsssettingsdlg.ui \
|
||||||
|
|
|
@ -145,7 +145,11 @@ p, li { white-space: pre-wrap; }
|
||||||
<enum>QAbstractItemView::SelectItems</enum>
|
<enum>QAbstractItemView::SelectItems</enum>
|
||||||
</property>
|
</property>
|
||||||
</widget>
|
</widget>
|
||||||
<widget class="QTextBrowser" name="textBrowser"/>
|
<widget class="HtmlBrowser" name="textBrowser">
|
||||||
|
<property name="openExternalLinks">
|
||||||
|
<bool>true</bool>
|
||||||
|
</property>
|
||||||
|
</widget>
|
||||||
</widget>
|
</widget>
|
||||||
</item>
|
</item>
|
||||||
</layout>
|
</layout>
|
||||||
|
@ -224,6 +228,13 @@ p, li { white-space: pre-wrap; }
|
||||||
</property>
|
</property>
|
||||||
</action>
|
</action>
|
||||||
</widget>
|
</widget>
|
||||||
|
<customwidgets>
|
||||||
|
<customwidget>
|
||||||
|
<class>HtmlBrowser</class>
|
||||||
|
<extends>QTextBrowser</extends>
|
||||||
|
<header>htmlbrowser.h</header>
|
||||||
|
</customwidget>
|
||||||
|
</customwidgets>
|
||||||
<resources/>
|
<resources/>
|
||||||
<connections/>
|
<connections/>
|
||||||
</ui>
|
</ui>
|
||||||
|
|
Loading…
Reference in a new issue