use Friendica\Content\Text\BBCode;
use Friendica\Content\Text\HTML;
use Friendica\Core\Config;
+use Friendica\Core\PConfig;
use Friendica\Core\Logger;
use Friendica\Core\Protocol;
use Friendica\Model\Contact;
continue;
}
+ if (PConfig::get($receiver, 'system', 'accept_only_sharer', false) && ($receiver != 0) && ($item['gravity'] == GRAVITY_PARENT)) {
+ $skip = !Contact::isSharingByURL($activity['author'], $receiver);
+
+ if ($skip && (($activity['type'] == 'as:Announce') || $isForum)) {
+ $skip = !Contact::isSharingByURL($activity['actor'], $receiver);
+ }
+
+ if ($skip) {
+ Logger::info('Skipping post', ['uid' => $receiver, 'url' => $item['uri']]);
+ continue;
+ }
+
+ Logger::info('Accepting post', ['uid' => $receiver, 'url' => $item['uri']]);
+ }
+
if ($activity['object_type'] == 'as:Event') {
self::createEvent($activity, $item);
}
* @param $child
* @throws \Friendica\Network\HTTPException\InternalServerErrorException
*/
- private static function fetchMissingActivity($url, $child)
+ public static function fetchMissingActivity($url, $child = [])
{
- if (Config::get('system', 'ostatus_full_threads')) {
- return;
+ if (!empty($child['receiver'])) {
+ $uid = ActivityPub\Receiver::getFirstUserFromReceivers($child['receiver']);
+ } else {
+ $uid = 0;
}
- $uid = ActivityPub\Receiver::getFirstUserFromReceivers($child['receiver']);
-
$object = ActivityPub::fetchContent($url, $uid);
if (empty($object)) {
Logger::log('Activity ' . $url . ' was not fetchable, aborting.');
return;
}
+ if (!empty($child['author'])) {
+ $actor = $child['author'];
+ } elseif (!empty($object['actor'])) {
+ $actor = $object['actor'];
+ } elseif (!empty($object['attributedTo'])) {
+ $actor = $object['attributedTo'];
+ } else {
+ // Shouldn't happen
+ $actor = '';
+ }
+
+ if (!empty($object['published'])) {
+ $published = $object['published'];
+ } elseif (!empty($child['published'])) {
+ $published = $child['published'];
+ } else {
+ $published = DateTimeFormat::utcNow();
+ }
+
$activity = [];
$activity['@context'] = $object['@context'];
unset($object['@context']);
$activity['id'] = $object['id'];
$activity['to'] = defaults($object, 'to', []);
$activity['cc'] = defaults($object, 'cc', []);
- $activity['actor'] = $child['author'];
+ $activity['actor'] = $actor;
$activity['object'] = $object;
- $activity['published'] = defaults($object, 'published', $child['published']);
+ $activity['published'] = $published;
$activity['type'] = 'Create';
$ldactivity = JsonLD::compact($activity);