mirror of
https://code.mensbeam.com/MensBeam/Arsse.git
synced 2025-01-03 14:32:40 +00:00
Implement part of adaptive update interval; improves #51
Implements part of algorithm used when a feed has not been updated; this is much simpler than when a feed has been modified
This commit is contained in:
parent
f842439b01
commit
2e64e60f2e
2 changed files with 37 additions and 5 deletions
|
@ -517,10 +517,9 @@ class Database {
|
||||||
try {
|
try {
|
||||||
if(is_null($articleID)) {
|
if(is_null($articleID)) {
|
||||||
$articleID = $this->db->prepare(
|
$articleID = $this->db->prepare(
|
||||||
'INSERT INTO arsse_articles(feed,url,title,author,published,edited,guid,content,url_title_hash,url_content_hash,title_content_hash) values(?,?,?,?,?,?,?,?,?,?,?)',
|
'INSERT INTO arsse_articles(url,title,author,published,edited,guid,content,url_title_hash,url_content_hash,title_content_hash,feed) values(?,?,?,?,?,?,?,?,?,?,?)',
|
||||||
'int', 'str', 'str', 'str', 'datetime', 'datetime', 'str', 'str', 'str', 'str', 'str'
|
'str', 'str', 'str', 'datetime', 'datetime', 'str', 'str', 'str', 'str', 'str', 'int'
|
||||||
)->run(
|
)->run(
|
||||||
$feedID,
|
|
||||||
$article->url,
|
$article->url,
|
||||||
$article->title,
|
$article->title,
|
||||||
$article->author,
|
$article->author,
|
||||||
|
@ -530,7 +529,8 @@ class Database {
|
||||||
$article->content,
|
$article->content,
|
||||||
$article->urlTitleHash,
|
$article->urlTitleHash,
|
||||||
$article->urlContentHash,
|
$article->urlContentHash,
|
||||||
$article->titleContentHash
|
$article->titleContentHash,
|
||||||
|
$feedID
|
||||||
)->lastId();
|
)->lastId();
|
||||||
} else {
|
} else {
|
||||||
$this->db->prepare(
|
$this->db->prepare(
|
||||||
|
@ -553,7 +553,7 @@ class Database {
|
||||||
// If the article has categories add them into the categories database.
|
// If the article has categories add them into the categories database.
|
||||||
$this->db->prepare('DELETE FROM arsse_categories WHERE article is ?', 'int')->run($articleID);
|
$this->db->prepare('DELETE FROM arsse_categories WHERE article is ?', 'int')->run($articleID);
|
||||||
$this->categoriesAdd($articleID, $article);
|
$this->categoriesAdd($articleID, $article);
|
||||||
// increease the article edition ID
|
// add a new article edition ID
|
||||||
$this->db->prepare('INSERT INTO arse_editions(article) values(?)', 'int')->run($articleID);
|
$this->db->prepare('INSERT INTO arse_editions(article) values(?)', 'int')->run($articleID);
|
||||||
} catch(\Throwable $e) {
|
} catch(\Throwable $e) {
|
||||||
$this->db->rollback();
|
$this->db->rollback();
|
||||||
|
|
32
lib/Feed.php
32
lib/Feed.php
|
@ -12,6 +12,8 @@ class Feed {
|
||||||
public $parser;
|
public $parser;
|
||||||
public $reader;
|
public $reader;
|
||||||
public $resource;
|
public $resource;
|
||||||
|
public $modified = false;
|
||||||
|
public $lastModified = null;
|
||||||
public $newItems = [];
|
public $newItems = [];
|
||||||
public $changedItems = [];
|
public $changedItems = [];
|
||||||
|
|
||||||
|
@ -23,6 +25,11 @@ class Feed {
|
||||||
|
|
||||||
$this->reader = new Reader($config);
|
$this->reader = new Reader($config);
|
||||||
$this->resource = $this->reader->download($url, $lastModified, $etag, $username, $password);
|
$this->resource = $this->reader->download($url, $lastModified, $etag, $username, $password);
|
||||||
|
$lastMod = $this->resource->getLastModified();
|
||||||
|
if(strlen($lastMod)) {
|
||||||
|
$this->$lastModified = \DateTime::createFromFormat("!D, d M Y H:i:s e", $lastMod);
|
||||||
|
}
|
||||||
|
$this->modified = $this->resource->isModified();
|
||||||
} catch (PicoFeedException $e) {
|
} catch (PicoFeedException $e) {
|
||||||
throw new Feed\Exception($url, $e);
|
throw new Feed\Exception($url, $e);
|
||||||
}
|
}
|
||||||
|
@ -218,4 +225,29 @@ class Feed {
|
||||||
}
|
}
|
||||||
return true;
|
return true;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
public function nextFetch(): \DateTime {
|
||||||
|
if(!$this->modified) {
|
||||||
|
$now = time();
|
||||||
|
$diff = $now - $this->lastModified->getTimestamp();
|
||||||
|
if($diff < (30 * 60)) { // less than 30 minutes
|
||||||
|
$offset = "15 minutes";
|
||||||
|
} else if($diff < (60 * 60)) { // less than an hour
|
||||||
|
$offset = "30 minutes";
|
||||||
|
} else if($diff < (3 * 60 * 60)) { // less than three hours
|
||||||
|
$offset = "1 hour";
|
||||||
|
} else if($diff > (36 * 60 * 60)) { // more than 36 hours
|
||||||
|
$offset = "1 day";
|
||||||
|
} else {
|
||||||
|
$offset = "3 hours";
|
||||||
|
}
|
||||||
|
$t = new \DateTime();
|
||||||
|
$t->setTimestamp($now);
|
||||||
|
$t->modify("+".$offset);
|
||||||
|
return $t;
|
||||||
|
} else {
|
||||||
|
// FIXME: implement algorithm to use when a feed has been updated
|
||||||
|
return new \DateTime("now + 3 hours");
|
||||||
|
}
|
||||||
|
}
|
||||||
}
|
}
|
Loading…
Reference in a new issue