digest: add rate limit for headline requests when catching up; control OOE responses with seq numbers

This commit is contained in:
Andrew Dolgov 2010-09-12 22:36:18 +04:00
parent eb4f33ec02
commit e4c530dcc3
2 changed files with 33 additions and 3 deletions

View File

@ -3,7 +3,9 @@ var last_feeds = [];
var _active_feed_id = false;
var _active_feed_offset = false;
var _update_timeout = false;
var _view_update_timeout = false;
var _feedlist_expanded = false;
var _update_seq = 1;
function article_appear(article_id) {
try {
@ -181,14 +183,23 @@ function remove_headline_entry(article_id) {
}
}
function view_update() {
try {
viewfeed(_active_feed_id, _active_feed_offset, false, true);
update();
} catch (e) {
exception_error("view_update", e);
}
}
function view(article_id, dismiss_only) {
try {
remove_headline_entry(article_id);
catchup_article(article_id,
function() {
viewfeed(_active_feed_id, _active_feed_offset, false, true);
update();
window.clearTimeout(_view_update_timeout);
_view_update_timeout = window.setTimeout("view_update()", 1000);
});
return dismiss_only != true;
@ -210,8 +221,11 @@ function viewfeed(feed_id, offset, replace, no_effects) {
if (replace == undefined) replace = (offset == 0);
_update_seq = _update_seq + 1;
var query = "backend.php?op=rpc&subop=digest-update&feed_id=" +
param_escape(feed_id) + "&offset=" + offset;
param_escape(feed_id) + "&offset=" + offset +
"&seq=" + _update_seq;
console.log(query);
@ -222,6 +236,7 @@ function viewfeed(feed_id, offset, replace, no_effects) {
if ($('H-LOADING-IMG')) Element.show("H-LOADING-IMG");
new Ajax.Request("backend.php", {
parameters: query,
onComplete: function(transport) {
@ -465,6 +480,18 @@ function parse_headlines(transport, replace, no_effects) {
try {
if (!transport.responseXML) return;
var seq = transport.responseXML.getElementsByTagName('seq')[0];
if (seq) {
seq = seq.firstChild.nodeValue;
if (seq != _update_seq) {
console.log("parse_headlines: wrong sequence received.");
return;
}
} else {
return;
}
var headlines = transport.responseXML.getElementsByTagName('headlines')[0];
var headlines_title = transport.responseXML.getElementsByTagName('headlines-title')[0];

View File

@ -1003,11 +1003,14 @@
if ($subop == "digest-update") {
$feed_id = db_escape_string($_REQUEST['feed_id']);
$offset = db_escape_string($_REQUEST['offset']);
$seq = db_escape_string($_REQUEST['seq']);
if (!$feed_id) $feed_id = -4;
if (!$offset) $offset = 0;
print "<rpc-reply>";
print "<seq>$seq</seq>";
$headlines = api_get_headlines($link, $feed_id, 10, $offset,
'', ($feed_id == -4), true, false, "unread", "updated DESC");