mirror of
https://github.com/friendica/friendica
synced 2025-01-07 09:24:43 +00:00
Issue 14160: Don't add simple participants to "cc"
This commit is contained in:
parent
4b3498710f
commit
8ae1f0d0e9
1 changed files with 37 additions and 12 deletions
|
@ -513,10 +513,10 @@ class Transmitter
|
||||||
}
|
}
|
||||||
|
|
||||||
$permissions = [
|
$permissions = [
|
||||||
'to' => [$parent['author-link']],
|
'to' => [$parent['author-link']],
|
||||||
'cc' => [],
|
'cc' => [],
|
||||||
'bto' => [],
|
'bto' => [],
|
||||||
'bcc' => [],
|
'bcc' => [],
|
||||||
'audience' => [],
|
'audience' => [],
|
||||||
];
|
];
|
||||||
|
|
||||||
|
@ -653,7 +653,7 @@ class Transmitter
|
||||||
$networks = [Protocol::ACTIVITYPUB, Protocol::OSTATUS];
|
$networks = [Protocol::ACTIVITYPUB, Protocol::OSTATUS];
|
||||||
}
|
}
|
||||||
|
|
||||||
$data = ['to' => [], 'cc' => [], 'bcc' => [] , 'audience' => $audience];
|
$data = ['to' => [], 'cc' => [], 'bto' => [], 'bcc' => [], 'audience' => $audience];
|
||||||
|
|
||||||
if ($item['gravity'] == Item::GRAVITY_PARENT) {
|
if ($item['gravity'] == Item::GRAVITY_PARENT) {
|
||||||
$actor_profile = APContact::getByURL($item['owner-link']);
|
$actor_profile = APContact::getByURL($item['owner-link']);
|
||||||
|
@ -807,7 +807,7 @@ class Transmitter
|
||||||
if (($profile['type'] == 'Group') || ($parent['uri'] == $item['thr-parent'])) {
|
if (($profile['type'] == 'Group') || ($parent['uri'] == $item['thr-parent'])) {
|
||||||
$data['to'][] = $profile['url'];
|
$data['to'][] = $profile['url'];
|
||||||
} else {
|
} else {
|
||||||
$data['cc'][] = $profile['url'];
|
$data['bto'][] = $profile['url'];
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
@ -824,6 +824,7 @@ class Transmitter
|
||||||
|
|
||||||
$data['to'] = array_unique($data['to']);
|
$data['to'] = array_unique($data['to']);
|
||||||
$data['cc'] = array_unique($data['cc']);
|
$data['cc'] = array_unique($data['cc']);
|
||||||
|
$data['bto'] = array_unique($data['bto']);
|
||||||
$data['bcc'] = array_unique($data['bcc']);
|
$data['bcc'] = array_unique($data['bcc']);
|
||||||
$data['audience'] = array_unique($data['audience']);
|
$data['audience'] = array_unique($data['audience']);
|
||||||
|
|
||||||
|
@ -835,6 +836,10 @@ class Transmitter
|
||||||
unset($data['cc'][$key]);
|
unset($data['cc'][$key]);
|
||||||
}
|
}
|
||||||
|
|
||||||
|
if (($key = array_search($item['author-link'], $data['bto'])) !== false) {
|
||||||
|
unset($data['bto'][$key]);
|
||||||
|
}
|
||||||
|
|
||||||
if (($key = array_search($item['author-link'], $data['bcc'])) !== false) {
|
if (($key = array_search($item['author-link'], $data['bcc'])) !== false) {
|
||||||
unset($data['bcc'][$key]);
|
unset($data['bcc'][$key]);
|
||||||
}
|
}
|
||||||
|
@ -844,20 +849,35 @@ class Transmitter
|
||||||
unset($data['cc'][$key]);
|
unset($data['cc'][$key]);
|
||||||
}
|
}
|
||||||
|
|
||||||
|
if (($key = array_search($to, $data['bto'])) !== false) {
|
||||||
|
unset($data['bto'][$key]);
|
||||||
|
}
|
||||||
|
|
||||||
if (($key = array_search($to, $data['bcc'])) !== false) {
|
if (($key = array_search($to, $data['bcc'])) !== false) {
|
||||||
unset($data['bcc'][$key]);
|
unset($data['bcc'][$key]);
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
foreach ($data['cc'] as $cc) {
|
foreach ($data['cc'] as $cc) {
|
||||||
|
if (($key = array_search($cc, $data['bto'])) !== false) {
|
||||||
|
unset($data['bto'][$key]);
|
||||||
|
}
|
||||||
|
|
||||||
if (($key = array_search($cc, $data['bcc'])) !== false) {
|
if (($key = array_search($cc, $data['bcc'])) !== false) {
|
||||||
unset($data['bcc'][$key]);
|
unset($data['bcc'][$key]);
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
$receivers = ['to' => array_values($data['to']), 'cc' => array_values($data['cc']), 'bcc' => array_values($data['bcc']), 'audience' => array_values($data['audience'])];
|
foreach ($data['bcc'] as $cc) {
|
||||||
|
if (($key = array_search($cc, $data['bto'])) !== false) {
|
||||||
|
unset($data['bto'][$key]);
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
$receivers = ['to' => array_values($data['to']), 'cc' => array_values($data['cc']), 'bto' => array_values($data['bto']), 'bcc' => array_values($data['bcc']), 'audience' => array_values($data['audience'])];
|
||||||
|
|
||||||
if (!$blindcopy) {
|
if (!$blindcopy) {
|
||||||
|
unset($receivers['bto']);
|
||||||
unset($receivers['bcc']);
|
unset($receivers['bcc']);
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@ -883,7 +903,7 @@ class Transmitter
|
||||||
return;
|
return;
|
||||||
}
|
}
|
||||||
|
|
||||||
foreach (['to' => Tag::TO, 'cc' => Tag::CC, 'bcc' => Tag::BCC, 'audience' => Tag::AUDIENCE] as $element => $type) {
|
foreach (['to' => Tag::TO, 'cc' => Tag::CC, 'bto' => Tag::BTO, 'bcc' => Tag::BCC, 'audience' => Tag::AUDIENCE] as $element => $type) {
|
||||||
if (!empty($receivers[$element])) {
|
if (!empty($receivers[$element])) {
|
||||||
foreach ($receivers[$element] as $receiver) {
|
foreach ($receivers[$element] as $receiver) {
|
||||||
if ($receiver == ActivityPub::PUBLIC_COLLECTION) {
|
if ($receiver == ActivityPub::PUBLIC_COLLECTION) {
|
||||||
|
@ -906,13 +926,13 @@ class Transmitter
|
||||||
*/
|
*/
|
||||||
public static function getReceiversForUriId(int $uri_id, bool $blindcopy)
|
public static function getReceiversForUriId(int $uri_id, bool $blindcopy)
|
||||||
{
|
{
|
||||||
$tags = Tag::getByURIId($uri_id, [Tag::TO, Tag::CC, Tag::BCC, Tag::AUDIENCE]);
|
$tags = Tag::getByURIId($uri_id, [Tag::TO, Tag::CC, Tag::BTO, Tag::BCC, Tag::AUDIENCE]);
|
||||||
if (empty($tags)) {
|
if (empty($tags)) {
|
||||||
Logger::debug('No receivers found', ['uri-id' => $uri_id]);
|
Logger::debug('No receivers found', ['uri-id' => $uri_id]);
|
||||||
$post = Post::selectFirst(Item::DELIVER_FIELDLIST, ['uri-id' => $uri_id, 'origin' => true]);
|
$post = Post::selectFirst(Item::DELIVER_FIELDLIST, ['uri-id' => $uri_id, 'origin' => true]);
|
||||||
if (!empty($post)) {
|
if (!empty($post)) {
|
||||||
ActivityPub\Transmitter::storeReceiversForItem($post);
|
ActivityPub\Transmitter::storeReceiversForItem($post);
|
||||||
$tags = Tag::getByURIId($uri_id, [Tag::TO, Tag::CC, Tag::BCC, Tag::AUDIENCE]);
|
$tags = Tag::getByURIId($uri_id, [Tag::TO, Tag::CC, Tag::BTO, Tag::BCC, Tag::AUDIENCE]);
|
||||||
Logger::debug('Receivers are created', ['uri-id' => $uri_id, 'receivers' => count($tags)]);
|
Logger::debug('Receivers are created', ['uri-id' => $uri_id, 'receivers' => count($tags)]);
|
||||||
} else {
|
} else {
|
||||||
Logger::debug('Origin item not found', ['uri-id' => $uri_id]);
|
Logger::debug('Origin item not found', ['uri-id' => $uri_id]);
|
||||||
|
@ -922,6 +942,7 @@ class Transmitter
|
||||||
$receivers = [
|
$receivers = [
|
||||||
'to' => [],
|
'to' => [],
|
||||||
'cc' => [],
|
'cc' => [],
|
||||||
|
'bto' => [],
|
||||||
'bcc' => [],
|
'bcc' => [],
|
||||||
'audience' => [],
|
'audience' => [],
|
||||||
];
|
];
|
||||||
|
@ -934,6 +955,9 @@ class Transmitter
|
||||||
case Tag::CC:
|
case Tag::CC:
|
||||||
$receivers['cc'][] = $receiver['url'];
|
$receivers['cc'][] = $receiver['url'];
|
||||||
break;
|
break;
|
||||||
|
case Tag::BTO:
|
||||||
|
$receivers['bto'][] = $receiver['url'];
|
||||||
|
break;
|
||||||
case Tag::BCC:
|
case Tag::BCC:
|
||||||
$receivers['bcc'][] = $receiver['url'];
|
$receivers['bcc'][] = $receiver['url'];
|
||||||
break;
|
break;
|
||||||
|
@ -944,6 +968,7 @@ class Transmitter
|
||||||
}
|
}
|
||||||
|
|
||||||
if (!$blindcopy) {
|
if (!$blindcopy) {
|
||||||
|
unset($receivers['bto']);
|
||||||
unset($receivers['bcc']);
|
unset($receivers['bcc']);
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@ -1093,7 +1118,7 @@ class Transmitter
|
||||||
continue;
|
continue;
|
||||||
}
|
}
|
||||||
|
|
||||||
$blindcopy = in_array($element, ['bto', 'bcc']);
|
$blindcopy = in_array($element, ['bcc']);
|
||||||
|
|
||||||
foreach ($permissions[$element] as $receiver) {
|
foreach ($permissions[$element] as $receiver) {
|
||||||
if (empty($receiver) || Network::isUrlBlocked($receiver)) {
|
if (empty($receiver) || Network::isUrlBlocked($receiver)) {
|
||||||
|
|
Loading…
Reference in a new issue