X-Git-Url: https://git.mxchange.org/?a=blobdiff_plain;f=src%2FProtocol%2FFeed.php;h=203a2e83565d27396dcb4dc7486e17e8a5bab5a8;hb=9cbc4a7355027cf7b4e2d7439edcefe04e1c18c2;hp=2dafaaf6e71b0e01ac63b26b8b33d958df22c87c;hpb=34b80227e88f80bf22b2acbd09bd9cd7e78e086c;p=friendica.git
diff --git a/src/Protocol/Feed.php b/src/Protocol/Feed.php
index 2dafaaf6e7..203a2e8356 100644
--- a/src/Protocol/Feed.php
+++ b/src/Protocol/Feed.php
@@ -8,6 +8,8 @@ namespace Friendica\Protocol;
use Friendica\Database\DBM;
use Friendica\Core\System;
+use Friendica\Model\Item;
+use Friendica\Util\Network;
use dba;
use DOMDocument;
use DOMXPath;
@@ -65,7 +67,7 @@ class Feed {
$xpath->registerNamespace('media', "http://search.yahoo.com/mrss/");
$xpath->registerNamespace('poco', NAMESPACE_POCO);
- $author = array();
+ $author = [];
// Is it RDF?
if ($xpath->query('/rdf:RDF/rss:channel')->length > 0) {
@@ -185,7 +187,7 @@ class Feed {
$author["owner-avatar"] = $contact["thumb"];
}
- $header = array();
+ $header = [];
$header["uid"] = $importer["uid"];
$header["network"] = NETWORK_FEED;
$header["type"] = "remote";
@@ -198,19 +200,14 @@ class Feed {
$header["contact-id"] = $contact["id"];
- if (!strlen($contact["notify"])) {
- // one way feed - no remote comment ability
- $header["last-child"] = 0;
- }
-
if (!is_object($entries)) {
logger("There are no entries in this feed.", LOGGER_DEBUG);
return;
}
- $items = array();
+ $items = [];
- $entrylist = array();
+ $entrylist = [];
foreach ($entries AS $entry) {
$entrylist[] = $entry;
@@ -247,7 +244,7 @@ class Feed {
$orig_plink = $item["plink"];
- $item["plink"] = original_url($item["plink"]);
+ $item["plink"] = Network::finalUrl($item["plink"]);
$item["parent-uri"] = $item["uri"];
@@ -309,7 +306,7 @@ class Feed {
// Ausland
//
- $attachments = array();
+ $attachments = [];
$enclosures = $xpath->query("enclosure", $entry);
foreach ($enclosures AS $enclosure) {
@@ -331,7 +328,7 @@ class Feed {
$item["attach"] .= ',';
}
- $attachments[] = array("link" => $href, "type" => $type, "length" => $length);
+ $attachments[] = ["link" => $href, "type" => $type, "length" => $length];
$item["attach"] .= '[attach]href="'.$href.'" length="'.$length.'" type="'.$type.'"[/attach]';
}
@@ -362,7 +359,7 @@ class Feed {
// remove the content of the title if it is identically to the body
// This helps with auto generated titles e.g. from tumblr
- if (title_is_body($item["title"], $body)) {
+ if (self::titleIsBody($item["title"], $body)) {
$item["title"] = "";
}
$item["body"] = html2bbcode($body, $basepath);
@@ -417,8 +414,8 @@ class Feed {
}
$item["body"] .= "\n".$item['tag'];
}
-x // Add the link to the original feed entry if not present in feed
- if (!strstr($item["body"], $item['plink']) && ($item['plink'] != '')) {
+ // Add the link to the original feed entry if not present in feed
+ if (($item['plink'] != '') && !strstr($item["body"], $item['plink'])) {
$item["body"] .= "[hr][url]".$item['plink']."[/url]";
}
}
@@ -426,17 +423,17 @@ x // Add the link to the original feed entry if not present in feed
if (!$simulate) {
logger("Stored feed: ".print_r($item, true), LOGGER_DEBUG);
- $notify = item_is_remote_self($contact, $item);
+ $notify = Item::isRemoteSelf($contact, $item);
// Distributed items should have a well formatted URI.
// Additionally we have to avoid conflicts with identical URI between imported feeds and these items.
if ($notify) {
- $item['guid'] = uri_to_guid($orig_plink, $a->get_hostname());
+ $item['guid'] = Item::guidFromUri($orig_plink, $a->get_hostname());
unset($item['uri']);
unset($item['parent-uri']);
}
- $id = item_store($item, false, $notify);
+ $id = Item::insert($item, false, $notify);
logger("Feed for contact ".$contact["url"]." stored under id ".$id);
} else {
@@ -448,7 +445,33 @@ x // Add the link to the original feed entry if not present in feed
}
if ($simulate) {
- return array("header" => $author, "items" => $items);
+ return ["header" => $author, "items" => $items];
+ }
+ }
+
+ private static function titleIsBody($title, $body)
+ {
+ $title = strip_tags($title);
+ $title = trim($title);
+ $title = html_entity_decode($title, ENT_QUOTES, 'UTF-8');
+ $title = str_replace(["\n", "\r", "\t", " "], ["", "", "", ""], $title);
+
+ $body = strip_tags($body);
+ $body = trim($body);
+ $body = html_entity_decode($body, ENT_QUOTES, 'UTF-8');
+ $body = str_replace(["\n", "\r", "\t", " "], ["", "", "", ""], $body);
+
+ if (strlen($title) < strlen($body)) {
+ $body = substr($body, 0, strlen($title));
+ }
+
+ if (($title != $body) && (substr($title, -3) == "...")) {
+ $pos = strrpos($title, "...");
+ if ($pos > 0) {
+ $title = substr($title, 0, $pos);
+ $body = substr($body, 0, $pos);
+ }
}
+ return ($title == $body);
}
}