check regular expression before adding/saving filter
This commit is contained in:
parent
a9d63d29a1
commit
f705f20656
4 changed files with 151 additions and 68 deletions
98
functions.js
98
functions.js
|
@ -577,55 +577,6 @@ function parse_counters(reply, scheduled_call) {
|
||||||
|
|
||||||
} */
|
} */
|
||||||
|
|
||||||
function handle_rpc_reply(transport, scheduled_call) {
|
|
||||||
try {
|
|
||||||
if (offline_mode) return false;
|
|
||||||
|
|
||||||
if (!transport.responseText && db) {
|
|
||||||
offlineConfirmModeChange();
|
|
||||||
return false;
|
|
||||||
}
|
|
||||||
|
|
||||||
if (transport.responseXML) {
|
|
||||||
|
|
||||||
if (!transport_error_check(transport)) return false;
|
|
||||||
|
|
||||||
var message = transport.responseXML.getElementsByTagName("message")[0];
|
|
||||||
|
|
||||||
if (message) {
|
|
||||||
message = message.firstChild.nodeValue;
|
|
||||||
|
|
||||||
if (message == "UPDATE_COUNTERS") {
|
|
||||||
setInitParam("last_article_id", -1);
|
|
||||||
_force_scheduled_update = true;
|
|
||||||
}
|
|
||||||
}
|
|
||||||
|
|
||||||
var counters = transport.responseXML.getElementsByTagName("counters")[0];
|
|
||||||
|
|
||||||
if (counters)
|
|
||||||
parse_counters(counters, scheduled_call);
|
|
||||||
|
|
||||||
var runtime_info = transport.responseXML.getElementsByTagName("runtime-info")[0];
|
|
||||||
|
|
||||||
if (runtime_info)
|
|
||||||
parse_runtime_info(runtime_info);
|
|
||||||
|
|
||||||
if (feedsSortByUnread())
|
|
||||||
resort_feedlist();
|
|
||||||
|
|
||||||
hideOrShowFeeds(getInitParam("hide_read_feeds") == 1);
|
|
||||||
|
|
||||||
} else {
|
|
||||||
notify_error("Error communicating with server.");
|
|
||||||
}
|
|
||||||
|
|
||||||
} catch (e) {
|
|
||||||
exception_error("handle_rpc_reply", e, transport);
|
|
||||||
}
|
|
||||||
|
|
||||||
return true;
|
|
||||||
}
|
|
||||||
|
|
||||||
function get_feed_unread(id) {
|
function get_feed_unread(id) {
|
||||||
try {
|
try {
|
||||||
|
@ -1290,20 +1241,45 @@ function createFilter() {
|
||||||
alert(__("Can't add filter: nothing to match on."));
|
alert(__("Can't add filter: nothing to match on."));
|
||||||
return false;
|
return false;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
var query = "?op=rpc&subop=verifyRegexp®_exp=" + param_escape(reg_exp);
|
||||||
|
|
||||||
|
notify_progress("Verifying regular expression...");
|
||||||
|
|
||||||
|
new Ajax.Request("backend.php", {
|
||||||
|
parameters: query,
|
||||||
|
onComplete: function(transport) {
|
||||||
|
handle_rpc_reply(transport);
|
||||||
|
|
||||||
|
var response = transport.responseXML;
|
||||||
|
|
||||||
|
if (response) {
|
||||||
|
var s = response.getElementsByTagName("status")[0].firstChild.nodeValue;
|
||||||
|
|
||||||
var query = Form.serialize("filter_add_form");
|
notify('');
|
||||||
|
|
||||||
// we can be called from some other tab in Prefs
|
if (s == "INVALID") {
|
||||||
if (typeof active_tab != 'undefined' && active_tab) {
|
alert("Match regular expression seems to be invalid.");
|
||||||
active_tab = "filterConfig";
|
return;
|
||||||
}
|
} else {
|
||||||
|
|
||||||
new Ajax.Request("backend.php?" + query, {
|
var query = Form.serialize("filter_add_form");
|
||||||
onComplete: function (transport) {
|
|
||||||
infobox_submit_callback2(transport);
|
// we can be called from some other tab in Prefs
|
||||||
|
if (typeof active_tab != 'undefined' && active_tab) {
|
||||||
|
active_tab = "filterConfig";
|
||||||
|
}
|
||||||
|
|
||||||
|
new Ajax.Request("backend.php?" + query, {
|
||||||
|
onComplete: function (transport) {
|
||||||
|
infobox_submit_callback2(transport);
|
||||||
|
} });
|
||||||
|
|
||||||
|
return true;
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
} });
|
} });
|
||||||
|
|
||||||
return true;
|
|
||||||
|
|
||||||
} catch (e) {
|
} catch (e) {
|
||||||
exception_error("createFilter", e);
|
exception_error("createFilter", e);
|
||||||
|
|
|
@ -1128,6 +1128,22 @@
|
||||||
return;
|
return;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
if ($subop == "verifyRegexp") {
|
||||||
|
$reg_exp = $_REQUEST["reg_exp"];
|
||||||
|
|
||||||
|
print "<rpc-reply><status>";
|
||||||
|
|
||||||
|
if (@preg_match("/$reg_exp/i", "TEST") === false) {
|
||||||
|
print "INVALID";
|
||||||
|
} else {
|
||||||
|
print "OK";
|
||||||
|
}
|
||||||
|
|
||||||
|
print "</status></rpc-reply>";
|
||||||
|
|
||||||
|
return;
|
||||||
|
}
|
||||||
|
|
||||||
print "<rpc-reply><error>Unknown method: $subop</error></rpc-reply>";
|
print "<rpc-reply><error>Unknown method: $subop</error></rpc-reply>";
|
||||||
}
|
}
|
||||||
?>
|
?>
|
||||||
|
|
55
prefs.js
55
prefs.js
|
@ -764,19 +764,44 @@ function userEditSave() {
|
||||||
|
|
||||||
|
|
||||||
function filterEditSave() {
|
function filterEditSave() {
|
||||||
|
|
||||||
try {
|
try {
|
||||||
|
var reg_exp = document.forms["filter_edit_form"].reg_exp.value;
|
||||||
|
|
||||||
notify_progress("Saving filter...");
|
var query = "?op=rpc&subop=verifyRegexp®_exp=" + param_escape(reg_exp);
|
||||||
|
|
||||||
var query = "?" + Form.serialize("filter_edit_form");
|
notify_progress("Verifying regular expression...");
|
||||||
|
|
||||||
closeInfoBox();
|
|
||||||
|
|
||||||
new Ajax.Request("backend.php", {
|
new Ajax.Request("backend.php", {
|
||||||
parameters: query,
|
parameters: query,
|
||||||
onComplete: function(transport) {
|
onComplete: function(transport) {
|
||||||
filterlist_callback2(transport);
|
handle_rpc_reply(transport);
|
||||||
|
|
||||||
|
var response = transport.responseXML;
|
||||||
|
|
||||||
|
if (response) {
|
||||||
|
var s = response.getElementsByTagName("status")[0].firstChild.nodeValue;
|
||||||
|
|
||||||
|
notify('');
|
||||||
|
|
||||||
|
if (s == "INVALID") {
|
||||||
|
alert("Match regular expression seems to be invalid.");
|
||||||
|
return;
|
||||||
|
} else {
|
||||||
|
|
||||||
|
var query = "?" + Form.serialize("filter_edit_form");
|
||||||
|
|
||||||
|
notify_progress("Saving filter...");
|
||||||
|
|
||||||
|
Form.disable("filter_edit_form");
|
||||||
|
|
||||||
|
new Ajax.Request("backend.php", {
|
||||||
|
parameters: query,
|
||||||
|
onComplete: function(transport) {
|
||||||
|
closeInfoBox();
|
||||||
|
filterlist_callback2(transport);
|
||||||
|
} });
|
||||||
|
}
|
||||||
|
}
|
||||||
} });
|
} });
|
||||||
|
|
||||||
} catch (e) {
|
} catch (e) {
|
||||||
|
@ -2099,4 +2124,20 @@ function clearFeedAccessKeys() {
|
||||||
return false;
|
return false;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
function handle_rpc_reply(transport, scheduled_call) {
|
||||||
|
try {
|
||||||
|
if (transport.responseXML) {
|
||||||
|
|
||||||
|
if (!transport_error_check(transport)) return false;
|
||||||
|
|
||||||
|
} else {
|
||||||
|
notify_error("Error communicating with server.");
|
||||||
|
}
|
||||||
|
|
||||||
|
} catch (e) {
|
||||||
|
exception_error("handle_rpc_reply", e, transport);
|
||||||
|
}
|
||||||
|
|
||||||
|
return true;
|
||||||
|
}
|
||||||
|
|
||||||
|
|
50
tt-rss.js
50
tt-rss.js
|
@ -1250,3 +1250,53 @@ function showFeedsWithErrors() {
|
||||||
displayDlg('feedUpdateErrors');
|
displayDlg('feedUpdateErrors');
|
||||||
}
|
}
|
||||||
|
|
||||||
|
function handle_rpc_reply(transport, scheduled_call) {
|
||||||
|
try {
|
||||||
|
if (offline_mode) return false;
|
||||||
|
|
||||||
|
if (!transport.responseText && db) {
|
||||||
|
offlineConfirmModeChange();
|
||||||
|
return false;
|
||||||
|
}
|
||||||
|
|
||||||
|
if (transport.responseXML) {
|
||||||
|
|
||||||
|
if (!transport_error_check(transport)) return false;
|
||||||
|
|
||||||
|
var message = transport.responseXML.getElementsByTagName("message")[0];
|
||||||
|
|
||||||
|
if (message) {
|
||||||
|
message = message.firstChild.nodeValue;
|
||||||
|
|
||||||
|
if (message == "UPDATE_COUNTERS") {
|
||||||
|
setInitParam("last_article_id", -1);
|
||||||
|
_force_scheduled_update = true;
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
var counters = transport.responseXML.getElementsByTagName("counters")[0];
|
||||||
|
|
||||||
|
if (counters)
|
||||||
|
parse_counters(counters, scheduled_call);
|
||||||
|
|
||||||
|
var runtime_info = transport.responseXML.getElementsByTagName("runtime-info")[0];
|
||||||
|
|
||||||
|
if (runtime_info)
|
||||||
|
parse_runtime_info(runtime_info);
|
||||||
|
|
||||||
|
if (feedsSortByUnread())
|
||||||
|
resort_feedlist();
|
||||||
|
|
||||||
|
hideOrShowFeeds(getInitParam("hide_read_feeds") == 1);
|
||||||
|
|
||||||
|
} else {
|
||||||
|
notify_error("Error communicating with server.");
|
||||||
|
}
|
||||||
|
|
||||||
|
} catch (e) {
|
||||||
|
exception_error("handle_rpc_reply", e, transport);
|
||||||
|
}
|
||||||
|
|
||||||
|
return true;
|
||||||
|
}
|
||||||
|
|
||||||
|
|
Loading…
Reference in a new issue