]> git.mxchange.org Git - friendica.git/blobdiff - src/Content/Item.php
Merge pull request #13646 from annando/page-drop
[friendica.git] / src / Content / Item.php
index c25e5296f01e78504a0c5f4cfb28588b3fda3961..ab5ff1698f8db1f9d8bf8ae1dd406f14e93d902d 100644 (file)
@@ -34,19 +34,21 @@ use Friendica\Core\Protocol;
 use Friendica\Core\Session\Capability\IHandleUserSessions;
 use Friendica\Core\System;
 use Friendica\Database\DBA;
+use Friendica\DI;
 use Friendica\Model\Attach;
+use Friendica\Model\Circle;
 use Friendica\Model\Contact;
 use Friendica\Model\Conversation;
 use Friendica\Model\FileTag;
-use Friendica\Model\Circle;
 use Friendica\Model\Item as ItemModel;
 use Friendica\Model\Photo;
-use Friendica\Model\Tag;
 use Friendica\Model\Post;
+use Friendica\Model\Tag;
 use Friendica\Model\User;
 use Friendica\Network\HTTPException;
 use Friendica\Object\EMail\ItemCCEMail;
 use Friendica\Protocol\Activity;
+use Friendica\Protocol\ActivityPub;
 use Friendica\Util\ACLFormatter;
 use Friendica\Util\DateTimeFormat;
 use Friendica\Util\Emailer;
@@ -54,6 +56,7 @@ use Friendica\Util\ParseUrl;
 use Friendica\Util\Profiler;
 use Friendica\Util\Proxy;
 use Friendica\Util\XML;
+use GuzzleHttp\Psr7\Uri;
 
 /**
  * A content helper class for displaying items
@@ -295,7 +298,7 @@ class Item
 
                        if ($this->activity->match($item['verb'], Activity::TAG)) {
                                $fields = [
-                                       'author-id', 'author-link', 'author-name', 'author-network',
+                                       'author-id', 'author-link', 'author-name', 'author-network', 'author-link', 'author-alias',
                                        'verb', 'object-type', 'resource-id', 'body', 'plink'
                                ];
                                $obj = Post::selectFirst($fields, ['uri' => $item['parent-uri']]);
@@ -367,7 +370,7 @@ class Item
        {
                $this->profiler->startRecording('rendering');
                $sub_link = $contact_url = $pm_url = $status_link = '';
-               $photos_link = $posts_link = $block_link = $ignore_link = '';
+               $photos_link = $posts_link = $block_link = $ignore_link = $collapse_link = $ignoreserver_link = '';
 
                if ($this->userSession->getLocalUserId() && $this->userSession->getLocalUserId() == $item['uid'] && $item['gravity'] == ItemModel::GRAVITY_PARENT && !$item['self'] && !$item['mention']) {
                        $sub_link = 'javascript:doFollowThread(' . $item['id'] . '); return false;';
@@ -407,6 +410,11 @@ class Item
                        $collapse_link = $item['self'] ? '' : $contact_url . '/collapse?t=' . $formSecurityToken;
                }
 
+               $authorBaseUri = new Uri($item['author-baseurl'] ?? '');
+               if (!empty($item['author-gsid']) && $authorBaseUri->getHost() && !DI::baseUrl()->isLocalUrl($authorBaseUri)) {
+                       $ignoreserver_link = 'settings/server/' . $item['author-gsid'] . '/ignore';
+               }
+
                if ($cid && !$item['self']) {
                        $contact_url = 'contact/' . $cid;
                        $posts_link  = $contact_url . '/posts';
@@ -427,7 +435,8 @@ class Item
                                $this->l10n->t('Send PM') => $pm_url,
                                $this->l10n->t('Block') => $block_link,
                                $this->l10n->t('Ignore') => $ignore_link,
-                               $this->l10n->t('Collapse') => $collapse_link
+                               $this->l10n->t('Collapse') => $collapse_link,
+                               $this->l10n->t("Ignore %s server", $authorBaseUri->getHost()) => $ignoreserver_link,
                        ];
 
                        if (!empty($item['language'])) {
@@ -627,10 +636,10 @@ class Item
        public function addSharedPost(array $item, string $body = ''): string
        {
                if (empty($body)) {
-                       $body = $item['body'];
+                       $body = $item['body'] ?? '';
                }
 
-               if (empty($item['quote-uri-id'])) {
+               if (empty($item['quote-uri-id']) || ($item['quote-uri-id'] == $item['uri-id'])) {
                        return $body;
                }
 
@@ -721,7 +730,7 @@ class Item
         */
        public function getSharedPost(array $item, array $fields = []): array
        {
-               if (!empty($item['quote-uri-id'])) {
+               if (!empty($item['quote-uri-id']) && ($item['quote-uri-id'] != $item['uri-id'])) {
                        $shared = Post::selectFirst($fields, ['uri-id' => $item['quote-uri-id'], 'uid' => [0, $item['uid'] ?? 0]]);
                        if (is_array($shared)) {
                                return [
@@ -762,7 +771,7 @@ class Item
                        return $attributes;
                }
 
-               if (!empty($item['quote-uri-id'])) {
+               if (!empty($item['quote-uri-id']) && ($item['quote-uri-id'] != $item['uri-id'])) {
                        $shared = Post::selectFirst(['author-name', 'author-link', 'author-avatar', 'plink', 'created', 'guid', 'uri', 'body'], ['uri-id' => $item['quote-uri-id']]);
                        if (!empty($shared)) {
                                return [
@@ -983,12 +992,14 @@ class Item
                        $post['deny_gid']  = $owner['deny_gid'];
                }
 
-               if ($post['allow_gid'] || $post['allow_cid'] || $post['deny_gid'] || $post['deny_cid']) {
-                       $post['private'] = ItemModel::PRIVATE;
-               } elseif ($this->pConfig->get($post['uid'], 'system', 'unlisted')) {
-                       $post['private'] = ItemModel::UNLISTED;
-               } else {
-                       $post['private'] = ItemModel::PUBLIC;
+               if (!isset($post['private'])) {
+                       if ($post['allow_gid'] || $post['allow_cid'] || $post['deny_gid'] || $post['deny_cid']) {
+                               $post['private'] = ItemModel::PRIVATE;
+                       } elseif ($this->pConfig->get($post['uid'], 'system', 'unlisted')) {
+                               $post['private'] = ItemModel::UNLISTED;
+                       } else {
+                               $post['private'] = ItemModel::PUBLIC;
+                       }
                }
 
                if (empty($post['contact-id'])) {
@@ -1058,4 +1069,25 @@ class Item
                        ));
                }
        }
+
+       public function copyPermissions(int $fromUriId, int $toUriId)
+       {
+               $from        = Post::selectFirstPost(['author-id'], ['uri-id' => $fromUriId]);
+               $from_author = DBA::selectFirst('account-view', ['ap-followers'], ['id' => $from['author-id']]);
+               $to          = Post::selectFirstPost(['author-id'], ['uri-id' => $toUriId]);
+               $to_author   = DBA::selectFirst('account-view', ['ap-followers'], ['id' => $to['author-id']]);
+
+               $existing = array_column(Tag::getByURIId($toUriId, [Tag::TO, Tag::CC, Tag::BCC]), 'url');
+
+               foreach (Tag::getByURIId($fromUriId, [Tag::TO, Tag::CC, Tag::BCC]) as $receiver) {
+                       if ($receiver['url'] == $from_author['ap-followers']) {
+                               $receiver['url']  = $to_author['ap-followers'];
+                               $receiver['name'] = trim(parse_url($receiver['url'], PHP_URL_PATH), '/');
+                       }
+                       if (in_array($receiver['url'], $existing)) {
+                               continue;
+                       }
+                       Tag::store($toUriId, $receiver['type'], $receiver['name'], $receiver['url']);
+               }
+       }
 }