X-Git-Url: https://git.mxchange.org/?a=blobdiff_plain;f=nsfw%2Fnsfw.php;h=6d8acbf034d7d440899cbf06609497ca0ccaade5;hb=c3e93f1ed9a487f823bcc75ddd43024334c25bfc;hp=0f94158bc83b19dd2d4b92623d808d9bf2be72fc;hpb=19b264a20cf384d9418061eb87b247090fb4d4a8;p=friendica-addons.git
diff --git a/nsfw/nsfw.php b/nsfw/nsfw.php
index 0f94158b..6d8acbf0 100755
--- a/nsfw/nsfw.php
+++ b/nsfw/nsfw.php
@@ -9,8 +9,10 @@
*
*/
+use Friendica\Core\PConfig;
+
function nsfw_install() {
- register_hook('prepare_body', 'addon/nsfw/nsfw.php', 'nsfw_prepare_body');
+ register_hook('prepare_body', 'addon/nsfw/nsfw.php', 'nsfw_prepare_body', 10);
register_hook('plugin_settings', 'addon/nsfw/nsfw.php', 'nsfw_addon_settings');
register_hook('plugin_settings_post', 'addon/nsfw/nsfw.php', 'nsfw_addon_settings_post');
@@ -24,6 +26,37 @@ function nsfw_uninstall() {
}
+// This function isn't perfect and isn't trying to preserve the html structure - it's just a
+// quick and dirty filter to pull out embedded photo blobs because 'nsfw' seems to come up
+// inside them quite often. We don't need anything fancy, just pull out the data blob so we can
+// check against the rest of the body.
+
+function nsfw_extract_photos($body) {
+
+ $new_body = '';
+
+ $img_start = strpos($body,'src="data:');
+ $img_end = (($img_start !== false) ? strpos(substr($body,$img_start),'>') : false);
+
+ $cnt = 0;
+
+ while($img_end !== false) {
+ $img_end += $img_start;
+ $new_body = $new_body . substr($body,0,$img_start);
+
+ $cnt ++;
+ $body = substr($body,0,$img_end);
+
+ $img_start = strpos($body,'src="data:');
+ $img_end = (($img_start !== false) ? strpos(substr($body,$img_start),'>') : false);
+
+ }
+
+ if(! $cnt)
+ return $body;
+
+ return $new_body;
+}
@@ -38,23 +71,29 @@ function nsfw_addon_settings(&$a,&$s) {
$a->page['htmlhead'] .= '' . "\r\n";
- $enable_checked = (intval(get_pconfig(local_user(),'nsfw','disable')) ? '' : ' checked="checked" ');
- $words = get_pconfig(local_user(),'nsfw','words');
+ $enable_checked = (intval(PConfig::get(local_user(),'nsfw','disable')) ? '' : ' checked="checked" ');
+ $words = PConfig::get(local_user(),'nsfw','words');
if(! $words)
$words = 'nsfw,';
- $s .= '
';
- $s .= '
' . t('Not Safe For Work (General Purpose Content Filter) settings') . '
';
+ $s .= '';
+ $s .= '
' . t('Not Safe For Work (General Purpose Content Filter)') . '
';
+ $s .= '';
+ $s .= '
';
+ $s .= '';
+ $s .= '
' . t('Not Safe For Work (General Purpose Content Filter)') . '
';
+ $s .= '';
+
$s .= '
';
$s .= '
' . t ('This plugin looks in posts for the words/text you specify below, and collapses any content containing those keywords so it is not displayed at inappropriate times, such as sexual innuendo that may be improper in a work setting. It is polite and recommended to tag any content containing nudity with #NSFW. This filter can also match any other word/text you specify, and can thereby be used as a general purpose content filter.') . '