nsfw: support API clients
This commit is contained in:
parent
ffb93d72ac
commit
ac6a59914b
|
@ -787,7 +787,8 @@ class API extends Handler {
|
||||||
|
|
||||||
list ($flavor_image, $flavor_stream, $flavor_kind) = Article::_get_image($enclosures,
|
list ($flavor_image, $flavor_stream, $flavor_kind) = Article::_get_image($enclosures,
|
||||||
$line["content"], // unsanitized
|
$line["content"], // unsanitized
|
||||||
$line["site_url"]);
|
$line["site_url"],
|
||||||
|
$headline_row);
|
||||||
|
|
||||||
$headline_row["flavor_image"] = $flavor_image;
|
$headline_row["flavor_image"] = $flavor_image;
|
||||||
$headline_row["flavor_stream"] = $flavor_stream;
|
$headline_row["flavor_stream"] = $flavor_stream;
|
||||||
|
|
|
@ -543,7 +543,7 @@ class Article extends Handler_Protected {
|
||||||
return $rv;
|
return $rv;
|
||||||
}
|
}
|
||||||
|
|
||||||
static function _get_image($enclosures, $content, $site_url) {
|
static function _get_image(array $enclosures, string $content, string $site_url, array $headline) {
|
||||||
|
|
||||||
$article_image = "";
|
$article_image = "";
|
||||||
$article_stream = "";
|
$article_stream = "";
|
||||||
|
@ -553,7 +553,7 @@ class Article extends Handler_Protected {
|
||||||
function ($result) use (&$article_image, &$article_stream, &$content) {
|
function ($result) use (&$article_image, &$article_stream, &$content) {
|
||||||
list ($article_image, $article_stream, $content) = $result;
|
list ($article_image, $article_stream, $content) = $result;
|
||||||
},
|
},
|
||||||
$enclosures, $content, $site_url);
|
$enclosures, $content, $site_url, $headline);
|
||||||
|
|
||||||
if (!$article_image && !$article_stream) {
|
if (!$article_image && !$article_stream) {
|
||||||
$tmpdoc = new DOMDocument();
|
$tmpdoc = new DOMDocument();
|
||||||
|
|
|
@ -251,21 +251,6 @@ class Feeds extends Handler_Protected {
|
||||||
|
|
||||||
$this->_mark_timestamp(" sanitize");
|
$this->_mark_timestamp(" sanitize");
|
||||||
|
|
||||||
PluginHost::getInstance()->chain_hooks_callback(PluginHost::HOOK_RENDER_ARTICLE_CDM,
|
|
||||||
function ($result, $plugin) use (&$line) {
|
|
||||||
$line = $result;
|
|
||||||
$this->_mark_timestamp(" hook_render_cdm: " . get_class($plugin));
|
|
||||||
},
|
|
||||||
$line);
|
|
||||||
|
|
||||||
$this->_mark_timestamp(" hook_render_cdm");
|
|
||||||
|
|
||||||
$line['content'] = DiskCache::rewrite_urls($line['content']);
|
|
||||||
|
|
||||||
$this->_mark_timestamp(" disk_cache_rewrite");
|
|
||||||
|
|
||||||
$this->_mark_timestamp(" note");
|
|
||||||
|
|
||||||
if (!get_pref(Prefs::CDM_EXPANDED)) {
|
if (!get_pref(Prefs::CDM_EXPANDED)) {
|
||||||
$line["cdm_excerpt"] = "<span class='collapse'>
|
$line["cdm_excerpt"] = "<span class='collapse'>
|
||||||
<i class='material-icons' onclick='return Article.cdmUnsetActive(event)'
|
<i class='material-icons' onclick='return Article.cdmUnsetActive(event)'
|
||||||
|
@ -330,6 +315,20 @@ class Feeds extends Handler_Protected {
|
||||||
}
|
}
|
||||||
|
|
||||||
$this->_mark_timestamp(" color");
|
$this->_mark_timestamp(" color");
|
||||||
|
$this->_mark_timestamp(" pre-hook_render_cdm");
|
||||||
|
|
||||||
|
PluginHost::getInstance()->chain_hooks_callback(PluginHost::HOOK_RENDER_ARTICLE_CDM,
|
||||||
|
function ($result, $plugin) use (&$line) {
|
||||||
|
$line = $result;
|
||||||
|
$this->_mark_timestamp(" hook: " . get_class($plugin));
|
||||||
|
},
|
||||||
|
$line);
|
||||||
|
|
||||||
|
$this->_mark_timestamp(" hook_render_cdm");
|
||||||
|
|
||||||
|
$line['content'] = DiskCache::rewrite_urls($line['content']);
|
||||||
|
|
||||||
|
$this->_mark_timestamp(" disk_cache_rewrite");
|
||||||
|
|
||||||
/* we don't need those */
|
/* we don't need those */
|
||||||
|
|
||||||
|
|
|
@ -152,7 +152,7 @@ class Handler_Public extends Handler {
|
||||||
$tpl->setVariable('ARTICLE_ENCLOSURE_LENGTH', "", true);
|
$tpl->setVariable('ARTICLE_ENCLOSURE_LENGTH', "", true);
|
||||||
}
|
}
|
||||||
|
|
||||||
list ($og_image, $og_stream) = Article::_get_image($enclosures, $line['content'], $feed_site_url);
|
list ($og_image, $og_stream) = Article::_get_image($enclosures, $line['content'], $feed_site_url, $line);
|
||||||
|
|
||||||
$tpl->setVariable('ARTICLE_OG_IMAGE', $og_image, true);
|
$tpl->setVariable('ARTICLE_OG_IMAGE', $og_image, true);
|
||||||
|
|
||||||
|
|
|
@ -2,11 +2,17 @@
|
||||||
|
|
||||||
Plugins.NSFW = {
|
Plugins.NSFW = {
|
||||||
toggle: function(elem) {
|
toggle: function(elem) {
|
||||||
const content = elem.domNode.parentNode.querySelector(".nswf.content");
|
elem = elem.domNode || elem;
|
||||||
|
|
||||||
if (content) {
|
const content = elem.closest(".nsfw-wrapper").querySelector('.nsfw-content');
|
||||||
Element.toggle(content);
|
|
||||||
}
|
// we can't use .toggle() here because this script could be invoked by the api client
|
||||||
|
// so it's back to vanilla js
|
||||||
|
|
||||||
|
if (content.style.display == 'none')
|
||||||
|
content.style.display = '';
|
||||||
|
else
|
||||||
|
content.style.display = 'none';
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|
|
@ -12,9 +12,11 @@ class NSFW extends Plugin {
|
||||||
function init($host) {
|
function init($host) {
|
||||||
$this->host = $host;
|
$this->host = $host;
|
||||||
|
|
||||||
$host->add_hook($host::HOOK_RENDER_ARTICLE, $this);
|
$host->add_hook(PluginHost::HOOK_RENDER_ARTICLE, $this);
|
||||||
$host->add_hook($host::HOOK_RENDER_ARTICLE_CDM, $this);
|
$host->add_hook(PluginHost::HOOK_RENDER_ARTICLE_CDM, $this);
|
||||||
$host->add_hook($host::HOOK_PREFS_TAB, $this);
|
$host->add_hook(PluginHost::HOOK_RENDER_ARTICLE_API, $this);
|
||||||
|
$host->add_hook(PluginHost::HOOK_ARTICLE_IMAGE, $this);
|
||||||
|
$host->add_hook(PluginHost::HOOK_PREFS_TAB, $this);
|
||||||
|
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@ -22,22 +24,46 @@ class NSFW extends Plugin {
|
||||||
return file_get_contents(__DIR__ . "/init.js");
|
return file_get_contents(__DIR__ . "/init.js");
|
||||||
}
|
}
|
||||||
|
|
||||||
function hook_render_article($article) {
|
function hook_article_image($enclosures, $content, $site_url, $article) {
|
||||||
$tags = array_map("trim", explode(",", $this->host->get($this, "tags")));
|
$tags = explode(",", $this->host->get($this, "tags"));
|
||||||
$a_tags = array_map("trim", explode(",", $article["tag_cache"]));
|
$article_tags = $article["tags"];
|
||||||
|
|
||||||
if (count(array_intersect($tags, $a_tags)) > 0) {
|
if (count(array_intersect($tags, $article_tags)) > 0) {
|
||||||
$article["content"] = "<div class='nswf wrapper'>".
|
return [Config::get_self_url() . "/plugins/nsfw/nsfw.png", "", "nsfw", []];
|
||||||
|
} else {
|
||||||
|
return ["", "", $content];
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
private function rewrite_contents($article, bool $add_api_js = false) {
|
||||||
|
$tags = explode(",", $this->host->get($this, "tags"));
|
||||||
|
$article_tags = $article["tags"];
|
||||||
|
|
||||||
|
if (count(array_intersect($tags, $article_tags)) > 0) {
|
||||||
|
$article["content"] = "<div class='nsfw-wrapper'>".
|
||||||
\Controls\button_tag(__("Not work safe (click to toggle)"), '', ['onclick' => 'Plugins.NSFW.toggle(this)']).
|
\Controls\button_tag(__("Not work safe (click to toggle)"), '', ['onclick' => 'Plugins.NSFW.toggle(this)']).
|
||||||
"<div class='nswf content' style='display : none'>".$article["content"]."</div>
|
"<div class='nsfw-content' style='display : none'>".$article["content"]."</div>
|
||||||
</div>";
|
</div>";
|
||||||
|
|
||||||
|
if ($add_api_js) {
|
||||||
|
$article["content"] .= "<script type='text/javascript'>const Plugins = {}; " . $this->get_js() . "</script>";
|
||||||
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
return $article;
|
return $article;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
function hook_render_article_api($row) {
|
||||||
|
$article = isset($row['headline']) ? $row['headline'] : $row['article'];
|
||||||
|
return $this->rewrite_contents($article, true);
|
||||||
|
}
|
||||||
|
|
||||||
|
function hook_render_article($article) {
|
||||||
|
return $this->rewrite_contents($article);
|
||||||
|
}
|
||||||
|
|
||||||
function hook_render_article_cdm($article) {
|
function hook_render_article_cdm($article) {
|
||||||
return $this->hook_render_article($article);
|
return $this->rewrite_contents($article);
|
||||||
}
|
}
|
||||||
|
|
||||||
function hook_prefs_tab($args) {
|
function hook_prefs_tab($args) {
|
||||||
|
|
|
@ -142,7 +142,7 @@ class Share extends Plugin {
|
||||||
$line);
|
$line);
|
||||||
|
|
||||||
$enclosures = Article::_get_enclosures($line["id"]);
|
$enclosures = Article::_get_enclosures($line["id"]);
|
||||||
list ($og_image, $og_stream) = Article::_get_image($enclosures, $line['content'], $line["site_url"]);
|
list ($og_image, $og_stream) = Article::_get_image($enclosures, $line['content'], $line["site_url"], $line);
|
||||||
|
|
||||||
$content_decoded = html_entity_decode($line["title"], ENT_NOQUOTES | ENT_HTML401);
|
$content_decoded = html_entity_decode($line["title"], ENT_NOQUOTES | ENT_HTML401);
|
||||||
$parsed_updated = TimeHelper::make_local_datetime($line["updated"], true, $owner_uid, true);
|
$parsed_updated = TimeHelper::make_local_datetime($line["updated"], true, $owner_uid, true);
|
||||||
|
|
Loading…
Reference in New Issue