diff --git a/src/Content/Conversation.php b/src/Content/Conversation.php index 458a0a690..6e7820a6f 100644 --- a/src/Content/Conversation.php +++ b/src/Content/Conversation.php @@ -873,6 +873,9 @@ class Conversation case ItemModel::PR_BCC: $row['direction'] = ['direction' => 7, 'title' => $this->l10n->t('You had been addressed (%s).', 'bcc')]; break; + case ItemModel::PR_AUDIENCE: + $row['direction'] = ['direction' => 7, 'title' => $this->l10n->t('You had been addressed (%s).', 'audience')]; + break; case ItemModel::PR_FOLLOWER: $row['direction'] = ['direction' => 6, 'title' => $this->l10n->t('You are following %s.', $row['causer-name'] ?: $row['author-name'])]; break; diff --git a/src/Model/Item.php b/src/Model/Item.php index d7de9ca49..89446c492 100644 --- a/src/Model/Item.php +++ b/src/Model/Item.php @@ -79,6 +79,7 @@ class Item const PR_DISTRIBUTE = 79; const PR_PUSHED = 80; const PR_LOCAL = 81; + const PR_AUDIENCE = 82; // system.accept_only_sharer setting values const COMPLETION_NONE = 1; @@ -1624,7 +1625,7 @@ class Item if (($uid != 0) && (($item['gravity'] == self::GRAVITY_PARENT) || $is_reshare) && DI::pConfig()->get($uid, 'system', 'accept_only_sharer') == self::COMPLETION_NONE && - !in_array($item['post-reason'], [self::PR_FOLLOWER, self::PR_TAG, self::PR_TO, self::PR_CC, self::PR_ACTIVITY])) { + !in_array($item['post-reason'], [self::PR_FOLLOWER, self::PR_TAG, self::PR_TO, self::PR_CC, self::PR_ACTIVITY, self::PR_AUDIENCE])) { Logger::info('Contact is not a follower, thread will not be stored', ['author' => $item['author-link'], 'uid' => $uid, 'uri-id' => $uri_id, 'post-reason' => $item['post-reason']]); return 0; } diff --git a/src/Model/Tag.php b/src/Model/Tag.php index 0e891f9c6..215d81713 100644 --- a/src/Model/Tag.php +++ b/src/Model/Tag.php @@ -54,10 +54,12 @@ class Tag */ const EXCLUSIVE_MENTION = 9; - const TO = 10; - const CC = 11; - const BTO = 12; - const BCC = 13; + const TO = 10; + const CC = 11; + const BTO = 12; + const BCC = 13; + const AUDIENCE = 14; + const ATTRIBUTED = 15; const ACCOUNT = 1; const GENERAL_COLLECTION = 2; @@ -103,7 +105,7 @@ class Tag $cid = 0; $tagid = 0; - if (in_array($type, [self::MENTION, self::EXCLUSIVE_MENTION, self::IMPLICIT_MENTION, self::TO, self::CC, self::BTO, self::BCC])) { + if (in_array($type, [self::MENTION, self::EXCLUSIVE_MENTION, self::IMPLICIT_MENTION, self::TO, self::CC, self::BTO, self::BCC, self::AUDIENCE, self::ATTRIBUTED])) { if (empty($url)) { // No mention without a contact url return; @@ -130,7 +132,7 @@ class Tag } if (empty($cid)) { - if (!in_array($type, [self::TO, self::CC, self::BTO, self::BCC])) { + if (!in_array($type, [self::TO, self::CC, self::BTO, self::BCC, self::AUDIENCE, self::ATTRIBUTED])) { if (($type != self::HASHTAG) && !empty($url) && ($url != $name)) { $url = strtolower($url); } else { diff --git a/src/Module/PermissionTooltip.php b/src/Module/PermissionTooltip.php index ad5c11cc0..41cc8e0e9 100644 --- a/src/Module/PermissionTooltip.php +++ b/src/Module/PermissionTooltip.php @@ -190,7 +190,7 @@ class PermissionTooltip extends \Friendica\BaseModule } $receivers = []; - foreach (Tag::getByURIId($uriId, [Tag::TO, Tag::CC, Tag::BCC]) as $receiver) { + foreach (Tag::getByURIId($uriId, [Tag::TO, Tag::CC, Tag::BCC, Tag::AUDIENCE, Tag::ATTRIBUTED]) as $receiver) { // We only display BCC when it contains the current user if (($receiver['type'] == Tag::BCC) && ($receiver['url'] != $own_url)) { continue; @@ -236,7 +236,13 @@ class PermissionTooltip extends \Friendica\BaseModule case Tag::BCC: $output .= DI::l10n()->t('BCC: %s
', implode(', ', $receiver)); break; - } + case Tag::AUDIENCE: + $output .= DI::l10n()->t('Audience: %s
', implode(', ', $receiver)); + break; + case Tag::ATTRIBUTED: + $output .= DI::l10n()->t('Attributed To: %s
', implode(', ', $receiver)); + break; + } } return $output; diff --git a/src/Protocol/ActivityPub/ClientToServer.php b/src/Protocol/ActivityPub/ClientToServer.php index 48a5cfdec..fed0bc55b 100644 --- a/src/Protocol/ActivityPub/ClientToServer.php +++ b/src/Protocol/ActivityPub/ClientToServer.php @@ -208,7 +208,7 @@ class ClientToServer $targets = []; - foreach (['as:to', 'as:cc', 'as:bto', 'as:bcc'] as $element) { + foreach (['as:to', 'as:cc', 'as:bto', 'as:bcc', 'as:audience'] as $element) { switch ($element) { case 'as:to': $type = Receiver::TARGET_TO; @@ -222,7 +222,10 @@ class ClientToServer case 'as:bcc': $type = Receiver::TARGET_BCC; break; - } + case 'as:audience': + $type = Receiver::TARGET_AUDIENCE; + break; + } $receiver_list = JsonLD::fetchElementArray($object, $element, '@id'); if (empty($receiver_list)) { continue; diff --git a/src/Protocol/ActivityPub/Processor.php b/src/Protocol/ActivityPub/Processor.php index 86394bd91..b8d4005a6 100644 --- a/src/Protocol/ActivityPub/Processor.php +++ b/src/Protocol/ActivityPub/Processor.php @@ -1026,6 +1026,9 @@ class Processor case Receiver::TARGET_BCC: $item['post-reason'] = Item::PR_BCC; break; + case Receiver::TARGET_AUDIENCE: + $item['post-reason'] = Item::PR_AUDIENCE; + break; case Receiver::TARGET_FOLLOWER: $item['post-reason'] = Item::PR_FOLLOWER; break; @@ -1071,7 +1074,7 @@ class Processor continue; } - if (($receiver != 0) && ($item['gravity'] == Item::GRAVITY_PARENT) && !in_array($item['post-reason'], [Item::PR_FOLLOWER, Item::PR_TAG, item::PR_TO, Item::PR_CC])) { + if (($receiver != 0) && ($item['gravity'] == Item::GRAVITY_PARENT) && !in_array($item['post-reason'], [Item::PR_FOLLOWER, Item::PR_TAG, item::PR_TO, Item::PR_CC, Item::PR_AUDIENCE])) { if (!($item['isForum'] ?? false)) { if ($item['post-reason'] == Item::PR_BCC) { Logger::info('Top level post via BCC from a non sharer, ignoring', ['uid' => $receiver, 'contact' => $item['contact-id'], 'url' => $item['uri']]); @@ -1274,7 +1277,7 @@ class Processor public static function storeReceivers(int $uriid, array $receivers) { - foreach (['as:to' => Tag::TO, 'as:cc' => Tag::CC, 'as:bto' => Tag::BTO, 'as:bcc' => Tag::BCC] as $element => $type) { + foreach (['as:to' => Tag::TO, 'as:cc' => Tag::CC, 'as:bto' => Tag::BTO, 'as:bcc' => Tag::BCC, 'as:audience' => Tag::AUDIENCE, 'as:attributedTo' => Tag::ATTRIBUTED] as $element => $type) { if (!empty($receivers[$element])) { foreach ($receivers[$element] as $receiver) { if ($receiver == ActivityPub::PUBLIC_COLLECTION) { diff --git a/src/Protocol/ActivityPub/Receiver.php b/src/Protocol/ActivityPub/Receiver.php index 4bba5f5da..204e631c9 100644 --- a/src/Protocol/ActivityPub/Receiver.php +++ b/src/Protocol/ActivityPub/Receiver.php @@ -73,6 +73,7 @@ class Receiver const TARGET_FOLLOWER = 5; const TARGET_ANSWER = 6; const TARGET_GLOBAL = 7; + const TARGET_AUDIENCE = 8; const COMPLETION_NONE = 0; const COMPLETION_ANNOUNCE = 1; @@ -487,7 +488,7 @@ class Receiver $object_data['object_type'] = $object_type; } - foreach (['as:to', 'as:cc', 'as:bto', 'as:bcc'] as $element) { + foreach (['as:to', 'as:cc', 'as:bto', 'as:bcc', 'as:audience', 'as:attributedTo'] as $element) { if ((empty($object_data['receiver_urls'][$element]) || in_array($element, ['as:bto', 'as:bcc'])) && !empty($urls[$element])) { $object_data['receiver_urls'][$element] = array_unique(array_merge($object_data['receiver_urls'][$element] ?? [], $urls[$element])); } @@ -1032,7 +1033,7 @@ class Receiver { $urls = []; - foreach (['as:to', 'as:cc', 'as:bto', 'as:bcc'] as $element) { + foreach (['as:to', 'as:cc', 'as:bto', 'as:bcc', 'as:audience', 'as:attributedTo'] as $element) { $receiver_list = JsonLD::fetchElementArray($activity, $element, '@id'); if (empty($receiver_list)) { continue; @@ -1104,7 +1105,7 @@ class Receiver // We have to prevent false follower assumptions upon thread completions $follower_target = empty($activity['thread-completion']) ? self::TARGET_FOLLOWER : self::TARGET_UNKNOWN; - foreach (['as:to', 'as:cc', 'as:bto', 'as:bcc'] as $element) { + foreach (['as:to', 'as:cc', 'as:bto', 'as:bcc','as:audience'] as $element) { $receiver_list = JsonLD::fetchElementArray($activity, $element, '@id'); if (empty($receiver_list)) { continue; @@ -1165,7 +1166,10 @@ class Receiver case 'as:bcc': $type = self::TARGET_BCC; break; - } + case 'as:audience': + $type = self::TARGET_AUDIENCE; + break; + } $receivers[$contact['uid']] = ['uid' => $contact['uid'], 'type' => $type]; } diff --git a/view/lang/C/messages.po b/view/lang/C/messages.po index 7d21741b9..e01626656 100644 --- a/view/lang/C/messages.po +++ b/view/lang/C/messages.po @@ -8,7 +8,7 @@ msgid "" msgstr "" "Project-Id-Version: 2023.03-rc\n" "Report-Msgid-Bugs-To: \n" -"POT-Creation-Date: 2023-04-09 08:27-0400\n" +"POT-Creation-Date: 2023-04-14 17:15+0000\n" "PO-Revision-Date: YEAR-MO-DA HO:MI+ZONE\n" "Last-Translator: FULL NAME \n" "Language-Team: LANGUAGE \n" @@ -1388,81 +1388,82 @@ msgstr "" #: src/Content/Conversation.php:865 src/Content/Conversation.php:868 #: src/Content/Conversation.php:871 src/Content/Conversation.php:874 +#: src/Content/Conversation.php:877 #, php-format msgid "You had been addressed (%s)." msgstr "" -#: src/Content/Conversation.php:877 +#: src/Content/Conversation.php:880 #, php-format msgid "You are following %s." msgstr "" -#: src/Content/Conversation.php:880 +#: src/Content/Conversation.php:883 msgid "You subscribed to one or more tags in this post." msgstr "" -#: src/Content/Conversation.php:893 +#: src/Content/Conversation.php:896 #, php-format msgid "%s reshared this." msgstr "" -#: src/Content/Conversation.php:895 +#: src/Content/Conversation.php:898 msgid "Reshared" msgstr "" -#: src/Content/Conversation.php:895 -#, php-format -msgid "Reshared by %s <%s>" -msgstr "" - #: src/Content/Conversation.php:898 #, php-format -msgid "%s is participating in this thread." +msgid "Reshared by %s <%s>" msgstr "" #: src/Content/Conversation.php:901 -msgid "Stored for general reasons" +#, php-format +msgid "%s is participating in this thread." msgstr "" #: src/Content/Conversation.php:904 +msgid "Stored for general reasons" +msgstr "" + +#: src/Content/Conversation.php:907 msgid "Global post" msgstr "" -#: src/Content/Conversation.php:907 +#: src/Content/Conversation.php:910 msgid "Sent via an relay server" msgstr "" -#: src/Content/Conversation.php:907 +#: src/Content/Conversation.php:910 #, php-format msgid "Sent via the relay server %s <%s>" msgstr "" -#: src/Content/Conversation.php:910 +#: src/Content/Conversation.php:913 msgid "Fetched" msgstr "" -#: src/Content/Conversation.php:910 +#: src/Content/Conversation.php:913 #, php-format msgid "Fetched because of %s <%s>" msgstr "" -#: src/Content/Conversation.php:913 +#: src/Content/Conversation.php:916 msgid "Stored because of a child post to complete this thread." msgstr "" -#: src/Content/Conversation.php:916 +#: src/Content/Conversation.php:919 msgid "Local delivery" msgstr "" -#: src/Content/Conversation.php:919 +#: src/Content/Conversation.php:922 msgid "Stored because of your activity (like, comment, star, ...)" msgstr "" -#: src/Content/Conversation.php:922 +#: src/Content/Conversation.php:925 msgid "Distributed" msgstr "" -#: src/Content/Conversation.php:925 +#: src/Content/Conversation.php:928 msgid "Pushed to us" msgstr "" @@ -1596,7 +1597,7 @@ msgstr "" msgid "show more" msgstr "" -#: src/Content/Item.php:326 src/Model/Item.php:2913 +#: src/Content/Item.php:326 src/Model/Item.php:2922 msgid "event" msgstr "" @@ -1604,7 +1605,7 @@ msgstr "" msgid "status" msgstr "" -#: src/Content/Item.php:335 src/Model/Item.php:2915 +#: src/Content/Item.php:335 src/Model/Item.php:2924 #: src/Module/Post/Tag/Add.php:123 msgid "photo" msgstr "" @@ -2010,8 +2011,8 @@ msgid "" "%2$s %3$s" msgstr "" -#: src/Content/Text/BBCode.php:956 src/Model/Item.php:3598 -#: src/Model/Item.php:3604 src/Model/Item.php:3605 +#: src/Content/Text/BBCode.php:956 src/Model/Item.php:3607 +#: src/Model/Item.php:3613 src/Model/Item.php:3614 msgid "Link to source" msgstr "" @@ -3180,81 +3181,81 @@ msgstr "" msgid "Edit groups" msgstr "" -#: src/Model/Item.php:2014 +#: src/Model/Item.php:2023 #, php-format msgid "Detected languages in this post:\\n%s" msgstr "" -#: src/Model/Item.php:2917 +#: src/Model/Item.php:2926 msgid "activity" msgstr "" -#: src/Model/Item.php:2919 +#: src/Model/Item.php:2928 msgid "comment" msgstr "" -#: src/Model/Item.php:2922 src/Module/Post/Tag/Add.php:123 +#: src/Model/Item.php:2931 src/Module/Post/Tag/Add.php:123 msgid "post" msgstr "" -#: src/Model/Item.php:3084 +#: src/Model/Item.php:3093 #, php-format msgid "%s is blocked" msgstr "" -#: src/Model/Item.php:3086 +#: src/Model/Item.php:3095 #, php-format msgid "%s is ignored" msgstr "" -#: src/Model/Item.php:3088 +#: src/Model/Item.php:3097 #, php-format msgid "Content from %s is collapsed" msgstr "" -#: src/Model/Item.php:3092 +#: src/Model/Item.php:3101 #, php-format msgid "Content warning: %s" msgstr "" -#: src/Model/Item.php:3510 +#: src/Model/Item.php:3519 msgid "bytes" msgstr "" -#: src/Model/Item.php:3541 +#: src/Model/Item.php:3550 #, php-format msgid "%2$s (%3$d%%, %1$d vote)" msgid_plural "%2$s (%3$d%%, %1$d votes)" msgstr[0] "" msgstr[1] "" -#: src/Model/Item.php:3543 +#: src/Model/Item.php:3552 #, php-format msgid "%2$s (%1$d vote)" msgid_plural "%2$s (%1$d votes)" msgstr[0] "" msgstr[1] "" -#: src/Model/Item.php:3548 +#: src/Model/Item.php:3557 #, php-format msgid "%d voter. Poll end: %s" msgid_plural "%d voters. Poll end: %s" msgstr[0] "" msgstr[1] "" -#: src/Model/Item.php:3550 +#: src/Model/Item.php:3559 #, php-format msgid "%d voter." msgid_plural "%d voters." msgstr[0] "" msgstr[1] "" -#: src/Model/Item.php:3552 +#: src/Model/Item.php:3561 #, php-format msgid "Poll end: %s" msgstr "" -#: src/Model/Item.php:3586 src/Model/Item.php:3587 +#: src/Model/Item.php:3595 src/Model/Item.php:3596 msgid "View on separate page" msgstr "" @@ -8250,6 +8251,16 @@ msgstr "" msgid "BCC: %s
" msgstr "" +#: src/Module/PermissionTooltip.php:240 +#, php-format +msgid "Audience: %s
" +msgstr "" + +#: src/Module/PermissionTooltip.php:243 +#, php-format +msgid "Attributed To: %s
" +msgstr "" + #: src/Module/Photo.php:129 msgid "The Photo is not available." msgstr ""