mirror of
https://github.com/d47081/qBittorrent.git
synced 2025-01-11 15:27:54 +00:00
Merge pull request #802 from Gelmir/rss_match_time_limit
Add setting to ignore RSS rule matches for X days
This commit is contained in:
commit
b9ce4d48a0
@ -255,6 +255,14 @@ void AutomatedRssDownloader::updateRuleDefinitionBox()
|
|||||||
} else {
|
} else {
|
||||||
ui->comboLabel->setCurrentIndex(ui->comboLabel->findText(rule->label()));
|
ui->comboLabel->setCurrentIndex(ui->comboLabel->findText(rule->label()));
|
||||||
}
|
}
|
||||||
|
ui->spinIgnorePeriod->setValue(rule->ignoreDays());
|
||||||
|
QDateTime dateTime = rule->lastMatch();
|
||||||
|
QString lMatch = tr("Last match: ");
|
||||||
|
if (dateTime.isValid())
|
||||||
|
lMatch += QString::number(dateTime.daysTo(QDateTime::currentDateTime())) + tr(" days ago.");
|
||||||
|
else
|
||||||
|
lMatch += tr("Unknown");
|
||||||
|
ui->lblLastMatch->setText(lMatch);
|
||||||
updateMustLineValidity();
|
updateMustLineValidity();
|
||||||
updateMustNotLineValidity();
|
updateMustNotLineValidity();
|
||||||
} else {
|
} else {
|
||||||
@ -281,6 +289,7 @@ void AutomatedRssDownloader::clearRuleDefinitionBox()
|
|||||||
ui->lineSavePath->clear();
|
ui->lineSavePath->clear();
|
||||||
ui->comboLabel->clearEditText();
|
ui->comboLabel->clearEditText();
|
||||||
ui->checkRegex->setChecked(false);
|
ui->checkRegex->setChecked(false);
|
||||||
|
ui->spinIgnorePeriod->setValue(0);
|
||||||
updateFieldsToolTips(ui->checkRegex->isChecked());
|
updateFieldsToolTips(ui->checkRegex->isChecked());
|
||||||
updateMustLineValidity();
|
updateMustLineValidity();
|
||||||
updateMustNotLineValidity();
|
updateMustNotLineValidity();
|
||||||
@ -333,6 +342,7 @@ void AutomatedRssDownloader::saveEditedRule()
|
|||||||
// Save new label
|
// Save new label
|
||||||
if (!rule->label().isEmpty())
|
if (!rule->label().isEmpty())
|
||||||
Preferences::instance()->addTorrentLabel(rule->label());
|
Preferences::instance()->addTorrentLabel(rule->label());
|
||||||
|
rule->setIgnoreDays(ui->spinIgnorePeriod->value());
|
||||||
//rule->setRssFeeds(getSelectedFeeds());
|
//rule->setRssFeeds(getSelectedFeeds());
|
||||||
// Save it
|
// Save it
|
||||||
m_editableRuleList->saveRule(rule);
|
m_editableRuleList->saveRule(rule);
|
||||||
|
@ -330,6 +330,70 @@
|
|||||||
</item>
|
</item>
|
||||||
</layout>
|
</layout>
|
||||||
</item>
|
</item>
|
||||||
|
<item>
|
||||||
|
<layout class="QHBoxLayout" name="horizontalLayout_6">
|
||||||
|
<item>
|
||||||
|
<widget class="QLabel" name="lblIgnoreDays">
|
||||||
|
<property name="text">
|
||||||
|
<string comment="... X days">Ignore subsequent matches for (0 to disable)</string>
|
||||||
|
</property>
|
||||||
|
</widget>
|
||||||
|
</item>
|
||||||
|
<item>
|
||||||
|
<spacer name="horizontalSpacer_4">
|
||||||
|
<property name="orientation">
|
||||||
|
<enum>Qt::Horizontal</enum>
|
||||||
|
</property>
|
||||||
|
<property name="sizeHint" stdset="0">
|
||||||
|
<size>
|
||||||
|
<width>40</width>
|
||||||
|
<height>20</height>
|
||||||
|
</size>
|
||||||
|
</property>
|
||||||
|
</spacer>
|
||||||
|
</item>
|
||||||
|
<item>
|
||||||
|
<widget class="QSpinBox" name="spinIgnorePeriod">
|
||||||
|
<property name="enabled">
|
||||||
|
<bool>true</bool>
|
||||||
|
</property>
|
||||||
|
<property name="suffix">
|
||||||
|
<string> days</string>
|
||||||
|
</property>
|
||||||
|
<property name="maximum">
|
||||||
|
<number>360</number>
|
||||||
|
</property>
|
||||||
|
</widget>
|
||||||
|
</item>
|
||||||
|
</layout>
|
||||||
|
</item>
|
||||||
|
<item>
|
||||||
|
<layout class="QHBoxLayout" name="horizontalLayout_7">
|
||||||
|
<item>
|
||||||
|
<spacer name="horizontalSpacer_5">
|
||||||
|
<property name="orientation">
|
||||||
|
<enum>Qt::Horizontal</enum>
|
||||||
|
</property>
|
||||||
|
<property name="sizeHint" stdset="0">
|
||||||
|
<size>
|
||||||
|
<width>40</width>
|
||||||
|
<height>20</height>
|
||||||
|
</size>
|
||||||
|
</property>
|
||||||
|
</spacer>
|
||||||
|
</item>
|
||||||
|
<item>
|
||||||
|
<widget class="QLabel" name="lblLastMatch">
|
||||||
|
<property name="enabled">
|
||||||
|
<bool>true</bool>
|
||||||
|
</property>
|
||||||
|
<property name="text">
|
||||||
|
<string notr="true"/>
|
||||||
|
</property>
|
||||||
|
</widget>
|
||||||
|
</item>
|
||||||
|
</layout>
|
||||||
|
</item>
|
||||||
</layout>
|
</layout>
|
||||||
</widget>
|
</widget>
|
||||||
</item>
|
</item>
|
||||||
|
@ -109,6 +109,7 @@ void RssArticle::markAsRead() {
|
|||||||
m_read = true;
|
m_read = true;
|
||||||
m_parent->decrementUnreadCount();
|
m_parent->decrementUnreadCount();
|
||||||
m_parent->markAsDirty();
|
m_parent->markAsDirty();
|
||||||
|
emit articleWasRead();
|
||||||
}
|
}
|
||||||
|
|
||||||
const QString& RssArticle::guid() const
|
const QString& RssArticle::guid() const
|
||||||
@ -122,8 +123,6 @@ const QString& RssArticle::title() const
|
|||||||
}
|
}
|
||||||
|
|
||||||
void RssArticle::handleTorrentDownloadSuccess(const QString &url) {
|
void RssArticle::handleTorrentDownloadSuccess(const QString &url) {
|
||||||
if (url == m_torrentUrl || url == m_link) {
|
if (url == m_torrentUrl || url == m_link)
|
||||||
markAsRead();
|
markAsRead();
|
||||||
emit articleWasRead();
|
|
||||||
}
|
|
||||||
}
|
}
|
||||||
|
@ -148,6 +148,8 @@ RssDownloadRulePtr RssDownloadRule::fromVariantHash(const QVariantHash &rule_has
|
|||||||
rule->setEnabled(rule_hash.value("enabled", false).toBool());
|
rule->setEnabled(rule_hash.value("enabled", false).toBool());
|
||||||
rule->setSavePath(rule_hash.value("save_path").toString());
|
rule->setSavePath(rule_hash.value("save_path").toString());
|
||||||
rule->setLabel(rule_hash.value("label_assigned").toString());
|
rule->setLabel(rule_hash.value("label_assigned").toString());
|
||||||
|
rule->setLastMatch(rule_hash.value("last_match").toDateTime());
|
||||||
|
rule->setIgnoreDays(rule_hash.value("ignore_days").toInt());
|
||||||
return rule;
|
return rule;
|
||||||
}
|
}
|
||||||
|
|
||||||
@ -163,6 +165,8 @@ QVariantHash RssDownloadRule::toVariantHash() const
|
|||||||
hash["label_assigned"] = m_label;
|
hash["label_assigned"] = m_label;
|
||||||
hash["use_regex"] = m_useRegex;
|
hash["use_regex"] = m_useRegex;
|
||||||
hash["episode_filter"] = m_episodeFilter;
|
hash["episode_filter"] = m_episodeFilter;
|
||||||
|
hash["last_match"] = m_lastMatch;
|
||||||
|
hash["ignore_days"] = m_ignoreDays;
|
||||||
return hash;
|
return hash;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@ -34,6 +34,7 @@
|
|||||||
#include <QStringList>
|
#include <QStringList>
|
||||||
#include <QVariantHash>
|
#include <QVariantHash>
|
||||||
#include <QSharedPointer>
|
#include <QSharedPointer>
|
||||||
|
#include <QDateTime>
|
||||||
|
|
||||||
class RssFeed;
|
class RssFeed;
|
||||||
typedef QSharedPointer<RssFeed> RssFeedPtr;
|
typedef QSharedPointer<RssFeed> RssFeedPtr;
|
||||||
@ -61,6 +62,10 @@ public:
|
|||||||
inline void setLabel(const QString &_label) { m_label = _label; }
|
inline void setLabel(const QString &_label) { m_label = _label; }
|
||||||
inline bool isEnabled() const { return m_enabled; }
|
inline bool isEnabled() const { return m_enabled; }
|
||||||
inline void setEnabled(bool enable) { m_enabled = enable; }
|
inline void setEnabled(bool enable) { m_enabled = enable; }
|
||||||
|
inline void setLastMatch(const QDateTime& d) { m_lastMatch = d; }
|
||||||
|
inline QDateTime lastMatch() const { return m_lastMatch; }
|
||||||
|
inline void setIgnoreDays(int d) { m_ignoreDays = d; }
|
||||||
|
inline int ignoreDays() const { return m_ignoreDays; }
|
||||||
inline QString mustContain() const { return m_mustContain.join(" "); }
|
inline QString mustContain() const { return m_mustContain.join(" "); }
|
||||||
inline QString mustNotContain() const { return m_mustNotContain.join("|"); }
|
inline QString mustNotContain() const { return m_mustNotContain.join("|"); }
|
||||||
inline bool useRegex() const { return m_useRegex; }
|
inline bool useRegex() const { return m_useRegex; }
|
||||||
@ -81,6 +86,8 @@ private:
|
|||||||
bool m_enabled;
|
bool m_enabled;
|
||||||
QStringList m_rssFeeds;
|
QStringList m_rssFeeds;
|
||||||
bool m_useRegex;
|
bool m_useRegex;
|
||||||
|
QDateTime m_lastMatch;
|
||||||
|
int m_ignoreDays;
|
||||||
};
|
};
|
||||||
|
|
||||||
#endif // RSSDOWNLOADRULE_H
|
#endif // RSSDOWNLOADRULE_H
|
||||||
|
@ -353,6 +353,18 @@ void RssFeed::downloadArticleTorrentIfMatching(RssDownloadRuleList* rules, const
|
|||||||
if (!matching_rule)
|
if (!matching_rule)
|
||||||
return;
|
return;
|
||||||
|
|
||||||
|
if (matching_rule->ignoreDays() > 0) {
|
||||||
|
QDateTime lastMatch = matching_rule->lastMatch();
|
||||||
|
if (lastMatch.isValid()) {
|
||||||
|
if (QDateTime::currentDateTime() < lastMatch.addDays(matching_rule->ignoreDays())) {
|
||||||
|
connect(article.data(), SIGNAL(articleWasRead()), SLOT(handleArticleStateChanged()), Qt::UniqueConnection);
|
||||||
|
article->markAsRead();
|
||||||
|
return;
|
||||||
|
}
|
||||||
|
}
|
||||||
|
}
|
||||||
|
matching_rule->setLastMatch(QDateTime::currentDateTime());
|
||||||
|
rules->saveRulesToStorage();
|
||||||
// Download the torrent
|
// Download the torrent
|
||||||
const QString& torrent_url = article->torrentUrl();
|
const QString& torrent_url = article->torrentUrl();
|
||||||
QBtSession::instance()->addConsoleMessage(tr("Automatically downloading %1 torrent from %2 RSS feed...").arg(article->title()).arg(displayName()));
|
QBtSession::instance()->addConsoleMessage(tr("Automatically downloading %1 torrent from %2 RSS feed...").arg(article->title()).arg(displayName()));
|
||||||
|
Loading…
Reference in New Issue
Block a user