$this->host = $host;
$host->add_hook($host::HOOK_FETCH_FEED, $this);
+ $host->add_hook($host::HOOK_SUBSCRIBE_FEED, $this);
$host->add_hook($host::HOOK_ARTICLE_FILTER, $this);
$host->add_hook($host::HOOK_PREFS_TAB, $this);
require_once __DIR__ . "/filter_base.php";
- $filters = glob(__DIR__ . "/filters/*.php");
+ $filters = array_merge(glob(__DIR__ . "/filters.local/*.php"), glob(__DIR__ . "/filters/*.php"));
+ $names = [];
foreach ($filters as $file) {
- require_once $file;
$filter_name = preg_replace("/\..*$/", "", basename($file));
- $filter = new $filter_name();
+ if (array_search($filter_name, $names) === FALSE) {
+ if (!class_exists($filter_name)) {
+ require_once $file;
+ }
+
+ array_push($names, $filter_name);
- if (is_subclass_of($filter, "Af_ComicFilter")) {
- array_push($this->filters, $filter);
+ $filter = new $filter_name();
+
+ if (is_subclass_of($filter, "Af_ComicFilter")) {
+ array_push($this->filters, $filter);
+ array_push($names, $filter_name);
+ }
}
}
-
}
function hook_prefs_tab($args) {
- if ($args != "prefPrefs") return;
+ if ($args != "prefFeeds") return;
print "<div dojoType=\"dijit.layout.AccordionPane\" title=\"".__('Feeds supported by af_comics')."\">";
}
print "</ul>";
- print "<p>".__('GoComics requires a specific URL to workaround their lack of feed support: <code>http://feeds.feedburner.com/uclick/<em>comic_name</em></code> (e.g. <code>http://www.gocomics.com/garfield</code> uses <code>http://feeds.feedburner.com/uclick/garfield</code>).')."</p>";
+ print "<p>".__("To subscribe to GoComics use the comic's regular web page as the feed URL (e.g. for the <em>Garfield</em> comic use <code>http://www.gocomics.com/garfield</code>).")."</p>";
+
+ print "<p>".__('Drop any updated filters into <code>filters.local</code> in plugin directory.')."</p>";
print "</div>";
}
if ($auth_login || $auth_pass)
return $feed_data;
- if (preg_match('#^https?://feeds.feedburner.com/uclick/([-a-z]+)#', $fetch_url, $comic)) {
- $site_url = 'http://www.gocomics.com/' . $comic[1];
+ if (preg_match('#^https?://(?:feeds\.feedburner\.com/uclick|www\.gocomics\.com)/([-a-z0-9]+)$#i', $fetch_url, $comic)) {
+ $site_url = 'https://www.gocomics.com/' . $comic[1];
$article_link = $site_url . date('/Y/m/d');
$node = $xpath->query('//picture[contains(@class, "item-comic-image")]/img')->item(0);
if ($node) {
+ $node->removeAttribute("width");
+ $node->removeAttribute("data-srcset");
+ $node->removeAttribute("srcset");
+
$tpl->setVariable('ARTICLE_ID', $article_link, true);
$tpl->setVariable('ARTICLE_LINK', $article_link, true);
$tpl->setVariable('ARTICLE_TITLE', date('l, F d, Y'), true);
$tpl->setVariable('ARTICLE_EXCERPT', '', true);
- $tpl->setVariable('ARTICLE_CONTENT', $doc->saveXML($node), true);
+ $tpl->setVariable('ARTICLE_CONTENT', $doc->saveHTML($node), true);
$tpl->setVariable('ARTICLE_AUTHOR', '', true);
$tpl->setVariable('ARTICLE_SOURCE_LINK', $site_url, true);
$tpl->setVariable('ARTICLE_SOURCE_TITLE', $feed_title, true);
$tpl->addBlock('entry');
+
}
}
}
return $feed_data;
}
+ function hook_subscribe_feed($contents, $url, $auth_login, $auth_pass) {
+ if ($auth_login || $auth_pass)
+ return $contents;
+
+ if (preg_match('#^https?://www\.gocomics\.com/([-a-z0-9]+)$#i', $url))
+ return '<?xml version="1.0" encoding="utf-8"?>'; // Get is_html() to return false.
+
+ return $contents;
+ }
+
function api_version() {
return 2;
}
-}
\ No newline at end of file
+}