return;
}
- self::storeConversation($object_data, $body);
+ // Only store content related stuff - and no announces, since they possibly overwrite the original content
+ if (in_array($object_data['object_type'], self::CONTENT_TYPES) && ($type != 'as:Announce')) {
+ self::storeConversation($object_data, $body);
+ }
// Internal flag for thread completion. See Processor.php
if (!empty($activity['thread-completion'])) {
$last_id = $item['id'];
}
+ $always_bcc = false;
+
+ // Check if we should always deliver our stuff via BCC
+ if (!empty($item['uid'])) {
+ $profile = Profile::getByUID($item['uid']);
+ if (!empty($profile)) {
+ $always_bcc = $profile['hide-friends'];
+ }
+ }
+
// Will be activated in a later step
// $networks = [Protocol::ACTIVITYPUB, Protocol::DFRN, Protocol::DIASPORA, Protocol::OSTATUS];
}
foreach ($receiver_list as $receiver) {
- $contact = DBA::selectFirst('contact', ['url'], ['id' => $receiver, 'network' => $networks]);
+ $contact = DBA::selectFirst('contact', ['url', 'hidden'], ['id' => $receiver, 'network' => $networks]);
if (DBA::isResult($contact) && !empty($profile = APContact::getByURL($contact['url'], false))) {
- // BCC is currently deactivated, due to Pleroma and Mastodon not reacting like expected
- // $data['bcc'][] = $profile['url'];
- $data['cc'][] = $profile['url'];
+ if ($contact['hidden'] || $always_bcc) {
+ $data['bcc'][] = $profile['url'];
+ } else {
+ $data['cc'][] = $profile['url'];
+ }
}
}
}