summaryrefslogtreecommitdiff
path: root/modules/import.module
diff options
context:
space:
mode:
authorDries Buytaert <dries@buytaert.net>2001-06-09 11:05:13 +0000
committerDries Buytaert <dries@buytaert.net>2001-06-09 11:05:13 +0000
commit2c0866eca6749bdab08387ed93cc37d75d53ccc4 (patch)
tree674d443e68266b3c3f92954e878be70af93b54e4 /modules/import.module
parenta722a1fed777f65f834418546927658c4dbdb3fa (diff)
downloadbrdo-2c0866eca6749bdab08387ed93cc37d75d53ccc4.tar.gz
brdo-2c0866eca6749bdab08387ed93cc37d75d53ccc4.tar.bz2
- Added a 'remove items' feature to reset a feed.
- Slightly improved the parsing algorithm; in some cases, were tags have attributes, things went wrong. We ignore attributes for now as we don't do anything with those. Example: <item rdf:about="http://foo.com"></item> ^^^^^^^^^^^^^^^^^^^^^^^^^
Diffstat (limited to 'modules/import.module')
-rw-r--r--modules/import.module23
1 files changed, 18 insertions, 5 deletions
diff --git a/modules/import.module b/modules/import.module
index 355b77691..8545ad000 100644
--- a/modules/import.module
+++ b/modules/import.module
@@ -52,6 +52,11 @@ function import_block() {
return $blocks;
}
+function import_remove($feed) {
+ db_query("DELETE FROM item WHERE fid = '$feed[fid]'");
+ return "feed '$feed[title]' reset.";
+}
+
function import_update($feed) {
// open socket:
@@ -65,11 +70,13 @@ function import_update($feed) {
if (strstr($data, "200 OK")) {
- eregi("<item(.*)</item>", $data, $data);
+ eregi("<item([^s].*)</item>", $data, $data);
+
+ // print "<PRE>". htmlentities($data[0]) ."</PRE>";
foreach (explode("</item>", $data[0]) as $item) {
- $l = eregi("<link>(.*)</link>", $item, $link);
$t = eregi("<title>(.*)</title>", $item, $title);
+ $l = eregi("<link>(.*)</link>", $item, $link);
$a = eregi("<author>(.*)</author>", $item, $author);
$d = eregi("<description>(.*)</description>", $item, $description);
@@ -84,6 +91,8 @@ function import_update($feed) {
watchdog("error", "failed to syndicate from '$feed[title]'");
}
}
+
+ return "feed '$feed[title]' updated.";
}
function import_save_item($edit) {
@@ -185,9 +194,9 @@ function import_view_feed() {
$output .= "<H3>Feed overview</H3>";
$output .= "<TABLE BORDER=\"1\" CELLSPADDING=\"2\" CELLSPACING=\"2\">\n";
- $output .= " <TR><TH>title</TH><TH>attributes</TH><TH>items</TH><TH>last update</TH><TH>next update</TH><TH COLSPAN=\"2\">operations</TH></TR>\n";
+ $output .= " <TR><TH>title</TH><TH>attributes</TH><TH>items</TH><TH>last update</TH><TH>next update</TH><TH COLSPAN=\"3\">operations</TH></TR>\n";
while ($feed = db_fetch_object($result)) {
- $output .= " <TR><TD>". check_output($feed->title) ."</TD><TD>". check_output($feed->attribute) ."</TD><TD>". format_plural($feed->items, "item", "items") ."</TD><TD>". ($feed->timestamp ? format_interval(time() - $feed->timestamp) ." ago" : "never") ."</TD><TD>". ($feed->timestamp ? format_interval($feed->timestamp + $feed->refresh - time()) ." left" : "never") ."</TD><TD><A HREF=\"admin.php?mod=import&type=feed&op=edit&id=$feed->fid\">edit feed</A></TD><TD><A HREF=\"admin.php?mod=import&type=feed&op=update&id=$feed->fid\">update items</A></TD></TR>\n";
+ $output .= " <TR><TD>". check_output($feed->title) ."</TD><TD>". check_output($feed->attribute) ."</TD><TD>". format_plural($feed->items, "item", "items") ."</TD><TD>". ($feed->timestamp ? format_interval(time() - $feed->timestamp) ." ago" : "never") ."</TD><TD>". ($feed->timestamp ? format_interval($feed->timestamp + $feed->refresh - time()) ." left" : "never") ."</TD><TD><A HREF=\"admin.php?mod=import&type=feed&op=edit&id=$feed->fid\">edit feed</A></TD><TD><A HREF=\"admin.php?mod=import&type=feed&op=remove&id=$feed->fid\">remove items</A></TD><TD><A HREF=\"admin.php?mod=import&type=feed&op=update&id=$feed->fid\">update items</A></TD></TR>\n";
}
$output .= "</TABLE>\n";
@@ -243,8 +252,12 @@ function import_admin() {
else
print import_form_feed(import_get_feed($id));
break;
+ case "remove":
+ print status(import_remove(import_get_feed($id)));
+ print import_view_feed();
+ break;
case "update":
- print import_update(import_get_feed($id));
+ print status(import_update(import_get_feed($id)));
print import_view_feed();
break;
case "Save attributes":