Store all RSS Article data in auto downloading job

This commit is contained in:
Vladimir Golovnev (Glassez) 2017-05-28 14:32:41 +03:00
parent 475348595c
commit 080dd79875
3 changed files with 48 additions and 42 deletions

View File

@ -36,47 +36,47 @@
#include "rss_feed.h" #include "rss_feed.h"
const QString Str_Id(QStringLiteral("id"));
const QString Str_Date(QStringLiteral("date"));
const QString Str_Title(QStringLiteral("title"));
const QString Str_Author(QStringLiteral("author"));
const QString Str_Description(QStringLiteral("description"));
const QString Str_TorrentURL(QStringLiteral("torrentURL"));
const QString Str_Link(QStringLiteral("link"));
const QString Str_IsRead(QStringLiteral("isRead"));
using namespace RSS; using namespace RSS;
const QString Article::KeyId(QStringLiteral("id"));
const QString Article::KeyDate(QStringLiteral("date"));
const QString Article::KeyTitle(QStringLiteral("title"));
const QString Article::KeyAuthor(QStringLiteral("author"));
const QString Article::KeyDescription(QStringLiteral("description"));
const QString Article::KeyTorrentURL(QStringLiteral("torrentURL"));
const QString Article::KeyLink(QStringLiteral("link"));
const QString Article::KeyIsRead(QStringLiteral("isRead"));
Article::Article(Feed *feed, const QVariantHash &varHash) Article::Article(Feed *feed, const QVariantHash &varHash)
: QObject(feed) : QObject(feed)
, m_feed(feed) , m_feed(feed)
, m_guid(varHash.value(Str_Id).toString()) , m_guid(varHash.value(KeyId).toString())
, m_date(varHash.value(Str_Date).toDateTime()) , m_date(varHash.value(KeyDate).toDateTime())
, m_title(varHash.value(Str_Title).toString()) , m_title(varHash.value(KeyTitle).toString())
, m_author(varHash.value(Str_Author).toString()) , m_author(varHash.value(KeyAuthor).toString())
, m_description(varHash.value(Str_Description).toString()) , m_description(varHash.value(KeyDescription).toString())
, m_torrentURL(varHash.value(Str_TorrentURL).toString()) , m_torrentURL(varHash.value(KeyTorrentURL).toString())
, m_link(varHash.value(Str_Link).toString()) , m_link(varHash.value(KeyLink).toString())
, m_isRead(varHash.value(Str_IsRead, false).toBool()) , m_isRead(varHash.value(KeyIsRead, false).toBool())
, m_data(varHash) , m_data(varHash)
{ {
// If item does not have a guid, fall back to some other identifier // If item does not have a guid, fall back to some other identifier
if (m_guid.isEmpty()) if (m_guid.isEmpty())
m_guid = varHash.value(Str_TorrentURL).toString(); m_guid = varHash.value(KeyTorrentURL).toString();
if (m_guid.isEmpty()) if (m_guid.isEmpty())
m_guid = varHash.value(Str_Title).toString(); m_guid = varHash.value(KeyTitle).toString();
if (m_guid.isEmpty()) if (m_guid.isEmpty())
throw std::runtime_error("Bad RSS Article data"); throw std::runtime_error("Bad RSS Article data");
m_data[Str_Id] = m_guid; m_data[KeyId] = m_guid;
} }
Article::Article(Feed *feed, const QJsonObject &jsonObj) Article::Article(Feed *feed, const QJsonObject &jsonObj)
: Article(feed, jsonObj.toVariantHash()) : Article(feed, jsonObj.toVariantHash())
{ {
// JSON object store DateTime as string so we need to convert it // JSON object store DateTime as string so we need to convert it
m_date = QDateTime::fromString(jsonObj.value(Str_Date).toString(), Qt::RFC2822Date); m_date = QDateTime::fromString(jsonObj.value(KeyDate).toString(), Qt::RFC2822Date);
m_data[Str_Date] = m_date; m_data[KeyDate] = m_date;
} }
QString Article::guid() const QString Article::guid() const
@ -128,7 +128,7 @@ void Article::markAsRead()
{ {
if (!m_isRead) { if (!m_isRead) {
m_isRead = true; m_isRead = true;
m_data[Str_IsRead] = m_isRead; m_data[KeyIsRead] = m_isRead;
emit read(this); emit read(this);
} }
} }
@ -137,7 +137,7 @@ QJsonObject Article::toJsonObject() const
{ {
auto jsonObj = QJsonObject::fromVariantHash(m_data); auto jsonObj = QJsonObject::fromVariantHash(m_data);
// JSON object doesn't support DateTime so we need to convert it // JSON object doesn't support DateTime so we need to convert it
jsonObj[Str_Date] = m_date.toString(Qt::RFC2822Date); jsonObj[KeyDate] = m_date.toString(Qt::RFC2822Date);
return jsonObj; return jsonObj;
} }

View File

@ -50,6 +50,15 @@ namespace RSS
Article(Feed *feed, const QJsonObject &jsonObj); Article(Feed *feed, const QJsonObject &jsonObj);
public: public:
static const QString KeyId;
static const QString KeyDate;
static const QString KeyTitle;
static const QString KeyAuthor;
static const QString KeyDescription;
static const QString KeyTorrentURL;
static const QString KeyLink;
static const QString KeyIsRead;
Feed *feed() const; Feed *feed() const;
QString guid() const; QString guid() const;
QDateTime date() const; QDateTime date() const;

View File

@ -36,6 +36,7 @@
#include <QSaveFile> #include <QSaveFile>
#include <QThread> #include <QThread>
#include <QTimer> #include <QTimer>
#include <QVariant>
#include "../bittorrent/magneturi.h" #include "../bittorrent/magneturi.h"
#include "../bittorrent/session.h" #include "../bittorrent/session.h"
@ -54,10 +55,7 @@
struct ProcessingJob struct ProcessingJob
{ {
QString feedURL; QString feedURL;
QString articleGUID; QVariantHash articleData;
QString articleTitle;
QDateTime articleDate;
QString torrentURL;
}; };
const QString ConfFolderName(QStringLiteral("rss")); const QString ConfFolderName(QStringLiteral("rss"));
@ -191,8 +189,8 @@ void AutoDownloader::handleTorrentDownloadFinished(const QString &url)
auto job = m_waitingJobs.take(url); auto job = m_waitingJobs.take(url);
if (!job) return; if (!job) return;
if (auto feed = Session::instance()->feedByURL(job->feedURL)) if (Feed *feed = Session::instance()->feedByURL(job->feedURL))
if (auto article = feed->articleByGUID(job->articleGUID)) if (Article *article = feed->articleByGUID(job->articleData.value(Article::KeyId).toString()))
article->markAsRead(); article->markAsRead();
} }
@ -220,10 +218,7 @@ void AutoDownloader::addJobForArticle(Article *article)
QSharedPointer<ProcessingJob> job(new ProcessingJob); QSharedPointer<ProcessingJob> job(new ProcessingJob);
job->feedURL = article->feed()->url(); job->feedURL = article->feed()->url();
job->articleGUID = article->guid(); job->articleData = article->data();
job->articleTitle = article->title();
job->articleDate = article->date();
job->torrentURL = torrentURL;
m_processingQueue.append(job); m_processingQueue.append(job);
if (!m_processingTimer->isActive()) if (!m_processingTimer->isActive())
m_processingTimer->start(); m_processingTimer->start();
@ -234,17 +229,18 @@ void AutoDownloader::processJob(const QSharedPointer<ProcessingJob> &job)
for (AutoDownloadRule &rule: m_rules) { for (AutoDownloadRule &rule: m_rules) {
if (!rule.isEnabled()) continue; if (!rule.isEnabled()) continue;
if (!rule.feedURLs().contains(job->feedURL)) continue; if (!rule.feedURLs().contains(job->feedURL)) continue;
if (!rule.matches(job->articleTitle)) continue; if (!rule.matches(job->articleData.value(Article::KeyTitle).toString())) continue;
auto articleDate = job->articleData.value(Article::KeyDate).toDateTime();
// if rule is in ignoring state do nothing with matched torrent // if rule is in ignoring state do nothing with matched torrent
if (rule.ignoreDays() > 0) { if (rule.ignoreDays() > 0) {
if (rule.lastMatch().isValid()) { if (rule.lastMatch().isValid()) {
if (job->articleDate < rule.lastMatch().addDays(rule.ignoreDays())) if (articleDate < rule.lastMatch().addDays(rule.ignoreDays()))
return; return;
} }
} }
rule.setLastMatch(job->articleDate); rule.setLastMatch(articleDate);
m_dirty = true; m_dirty = true;
storeDeferred(); storeDeferred();
@ -252,18 +248,19 @@ void AutoDownloader::processJob(const QSharedPointer<ProcessingJob> &job)
params.savePath = rule.savePath(); params.savePath = rule.savePath();
params.category = rule.assignedCategory(); params.category = rule.assignedCategory();
params.addPaused = rule.addPaused(); params.addPaused = rule.addPaused();
BitTorrent::Session::instance()->addTorrent(job->torrentURL, params); auto torrentURL = job->articleData.value(Article::KeyTorrentURL).toString();
BitTorrent::Session::instance()->addTorrent(torrentURL, params);
if (BitTorrent::MagnetUri(job->torrentURL).isValid()) { if (BitTorrent::MagnetUri(torrentURL).isValid()) {
if (auto feed = Session::instance()->feedByURL(job->feedURL)) { if (Feed *feed = Session::instance()->feedByURL(job->feedURL)) {
if (auto article = feed->articleByGUID(job->articleGUID)) if (Article *article = feed->articleByGUID(job->articleData.value(Article::KeyId).toString()))
article->markAsRead(); article->markAsRead();
} }
} }
else { else {
// waiting for torrent file downloading // waiting for torrent file downloading
// normalize URL string via QUrl since DownloadManager do it // normalize URL string via QUrl since DownloadManager do it
m_waitingJobs.insert(QUrl(job->torrentURL).toString(), job); m_waitingJobs.insert(QUrl(torrentURL).toString(), job);
} }
return; return;