diff options
| author | Philip Wittamore <philip@wittamore.com> | 2025-12-21 12:05:53 +0100 |
|---|---|---|
| committer | Philip Wittamore <philip@wittamore.com> | 2025-12-21 12:05:53 +0100 |
| commit | 2444adfe7afba6bed2608bfcd6cccc79eccf39f3 (patch) | |
| tree | 88a6ca97f124ec5a412172922a99a2a10d03ac09 /getfeeds.php | |
| parent | 5637b6bc9e9ca99779fd6483318f33a6fe38152d (diff) | |
| download | scripts-2444adfe7afba6bed2608bfcd6cccc79eccf39f3.tar.gz scripts-2444adfe7afba6bed2608bfcd6cccc79eccf39f3.tar.bz2 scripts-2444adfe7afba6bed2608bfcd6cccc79eccf39f3.zip | |
Diffstat (limited to 'getfeeds.php')
| -rwxr-xr-x[-rw-r--r--] | getfeeds.php | 36 |
1 files changed, 26 insertions, 10 deletions
diff --git a/getfeeds.php b/getfeeds.php index ca52b9b..a632c5f 100644..100755 --- a/getfeeds.php +++ b/getfeeds.php @@ -20,11 +20,16 @@ if (file_exists("$root/$hs")) { copy("$root/$hs", "$root/gophermap"); $dt = new DateTime("now", new DateTimeZone('Europe/Paris')); file_put_contents("$root/gophermap", "last update: ".$dt->format('Y-m-d H:i:s')."\n\n", FILE_APPEND); +}else{ + echo "$root/$hs not found, aborting"; + exit; } // iterate through feed directories +// each directory contains the feed url and title +// and receives the constructed gophermap foreach ($dir as $subdir) { - # get feed settings from directory + # if config files missing go to next directory if (!file_exists("$subdir/$fs")) continue; if (!file_exists("$subdir/$ts")) continue; @@ -43,6 +48,7 @@ foreach ($dir as $subdir) { // simplepie can't recuperate a gopher url // so we use curl in this case $gopher = 0; + $rssstring = ""; if (str_starts_with($feedurl, "gopher")) { exec("curl $feedurl", $rssdata, $retval); if (!empty($rssdata)) { @@ -64,18 +70,20 @@ foreach ($dir as $subdir) { // extract each feed item $x=0; + $youtube=false; foreach ($feed->get_items(0, 30) as $item) { $itemlink = $item->get_permalink(); $itemtitle = $item->get_title(); $itemdate = $item->get_date("Y-m-d"); - if (empty($itemtitle)) $itemtitle="No itemtitle found"; + if (empty($itemtitle)) $itemtitle="No item title found"; // build item link if ($gopher==1) { $host = parse_url($itemlink, PHP_URL_HOST); $port = parse_url($itemlink, PHP_URL_PORT); + if ((int)$port < 70) $port="70"; $path = parse_url($itemlink, PHP_URL_PATH); if (pathinfo($path, PATHINFO_EXTENSION)) { $itemlist .= "0".$itemdate." ".$itemtitle."\t".substr($path,2)."\t".$host."\t".$port."\n"; @@ -83,23 +91,28 @@ foreach ($dir as $subdir) { $itemlist .= "1".$itemdate." ".$itemtitle."\t".substr($path,2)."\t".$host."\t".$port."\n"; } }else{ + // + if (str_contains($itemlink,"youtu")) { // convert rss youtube url to youtu.be url - $itemlink = str_replace("www.youtube.com/watch?v=", "youtu.be/", $itemlink); - $itemlist .= "h".$itemdate." ".$itemtitle."\tURL:".$itemlink."\n"; + $youtube=true; + $itemlink = str_replace("www.youtube.com/watch?v=", "youtu.be/", $itemlink); + } + $itemlist .= "U".$itemdate." ".$itemtitle."\tURL:".$itemlink."\n"; } $x++; } // build list of feed items if ($x==0) { - $itemlist .= "! Error - No items found\n\n"; - $itemlist .= "DEBUG\n"; - $itemlist .= "curl $feedurl\n"; - $itemlist .= "result:\n"; - $itemlist .= $rssstring; - $itemlist .= "\nEOF\n"; + // gopher error tag + if ( str_starts_with($rssstring,"3")) { + $itemlist .= "$rssstring\t/errors.txt\tspike.nagatha.fr\t70\n"; + }else{ + $itemlist .= $rssstring; + } } file_put_contents("$subdir/gophermap", $itemlist); + file_put_contents("$subdir/gophermap", str_repeat("\n ", 30), FILE_APPEND); // build list of feeds $feedname = "1".$feeditemtitle."\t".basename($subdir)."\n"; @@ -112,6 +125,9 @@ foreach ($dir as $subdir) { unset($itemlist); } +// add empty lines to gophermap +file_put_contents("$root/gophermap", str_repeat("\n ", 30), FILE_APPEND); + ?> |
