diff options
author | Kevin Decherf <kevin@kdecherf.com> | 2020-12-09 22:13:09 +0100 |
---|---|---|
committer | Benjamin Brahmer <info@b-brahmer.de> | 2020-12-15 20:02:21 +0100 |
commit | 42ea24f2f41ce04588aa929e5ffdaf1dbeb1a700 (patch) | |
tree | 657089d619d1ee76d8f86dbf8553f9ce86c6867d /lib/Db | |
parent | 1345cedd7e226c23a9fff6275a0fb71e444aa1b3 (diff) |
Remove LastModified-based cursor when updating feeds
We remove the call to readSince() as some feeds push new articles with
pubDate prior to the lastModified time stored for these feeds (e.g.
lemonde.fr). As we go through all items of a feed again and again, we
prevent the constant update of an item's lastModified timestamp by
keeping the previous one if its fingerprint does not change.
Fixes #921
Signed-off-by: Kevin Decherf <kevin@kdecherf.com>
Diffstat (limited to 'lib/Db')
-rw-r--r-- | lib/Db/NewsMapperV2.php | 4 |
1 files changed, 3 insertions, 1 deletions
diff --git a/lib/Db/NewsMapperV2.php b/lib/Db/NewsMapperV2.php index 708ef4f73..93500c7c9 100644 --- a/lib/Db/NewsMapperV2.php +++ b/lib/Db/NewsMapperV2.php @@ -58,7 +58,9 @@ abstract class NewsMapperV2 extends QBMapper public function update(Entity $entity): Entity { - $entity->setLastModified($this->time->getMicroTime()); + if ([] !== $entity->getUpdatedFields()) { + $entity->setLastModified($this->time->getMicroTime()); + } return parent::update($entity); } |