From ad00dc4f344ed441708c09a3d4dfa172c8aed3e7 Mon Sep 17 00:00:00 2001 From: Michael Date: Thu, 21 Mar 2024 07:40:46 +0000 Subject: [PATCH] Bluesky: Support Restrictions / Updated Friendica handle description --- bluesky/bluesky.php | 59 ++++++++++++++++++++++++++++++++++++++++++--- 1 file changed, 56 insertions(+), 3 deletions(-) diff --git a/bluesky/bluesky.php b/bluesky/bluesky.php index fe66d9a4..8644e4bd 100644 --- a/bluesky/bluesky.php +++ b/bluesky/bluesky.php @@ -323,7 +323,7 @@ function bluesky_addon_admin(string &$o) $o = Renderer::replaceMacros($t, [ '$submit' => DI::l10n()->t('Save Settings'), - '$friendica_handles' => ['friendica_handles', DI::l10n()->t('Allow your users to use your hostname for their Bluesky handles'), DI::config()->get('bluesky', 'friendica_handles'), DI::l10n()->t('Before enabling this option, you have to download and configure the bluesky-handles repository on your system. See https://git.friendi.ca/heluecht/bluesky-handles')], + '$friendica_handles' => ['friendica_handles', DI::l10n()->t('Allow your users to use your hostname for their Bluesky handles'), DI::config()->get('bluesky', 'friendica_handles'), DI::l10n()->t('Before enabling this option, you have to enable wildcard request in your webserver configuration. On Apache this is done by adding "ServerAlias *.%s" to your HTTP configuration. You don\'t need to change the HTTPS configuration.', DI::baseUrl()->getHost())], ]); } @@ -525,8 +525,8 @@ function bluesky_cron() // Refresh the token now, so that it doesn't need to be refreshed in parallel by the following workers bluesky_get_token($pconfig['uid']); - Worker::add(['priority' => Worker::PRIORITY_MEDIUM, 'force_priority' => true], 'addon/bluesky/bluesky_timeline.php', $pconfig['uid'], $last); Worker::add(['priority' => Worker::PRIORITY_MEDIUM, 'force_priority' => true], 'addon/bluesky/bluesky_notifications.php', $pconfig['uid'], $last); + Worker::add(['priority' => Worker::PRIORITY_MEDIUM, 'force_priority' => true], 'addon/bluesky/bluesky_timeline.php', $pconfig['uid'], $last); if (DI::pConfig()->get($pconfig['uid'], 'bluesky', 'import_feeds')) { $feeds = bluesky_get_feeds($pconfig['uid']); @@ -1176,6 +1176,8 @@ function bluesky_process_post(stdClass $post, int $uid, int $fetch_uid, int $pos $item = bluesky_add_media($post->embed, $item, $uid, $level, $last_poll); } + $item['restrictions'] = bluesky_get_restrictions_for_user($post, $item, $post_reason); + if (empty($item['post-reason'])) { $item['post-reason'] = $post_reason; } @@ -1183,7 +1185,15 @@ function bluesky_process_post(stdClass $post, int $uid, int $fetch_uid, int $pos if ($causer != 0) { $item['causer-id'] = $causer; } - +/* + if (($item['uid'] != 0) && !Post::exists(['uid' => 0, 'uri-id' => $item['uri-id']])) { + $shadow = $item; + $shadow['uid'] = 0; + $shadow['restrictions'] = bluesky_get_restrictions_for_user($post, 0); + unset($shadow['post-reason']); + $shadow['contact-id'] = Contact::getIdForURL($item['author-link']); + } +*/ Item::insert($item); return bluesky_fetch_uri_id($uri, $uid); } @@ -1223,6 +1233,49 @@ function bluesky_get_header(stdClass $post, string $uri, int $uid, int $fetch_ui return $item; } +function bluesky_get_restrictions_for_user(stdClass $post, array $item, int $post_reason): ?int +{ + if (!empty($post->viewer->replyDisabled)) { + return Item::CANT_REPLY; + } + + if(empty($post->threadgate)) { + return null; + } + + if (!isset($post->threadgate->record->allow)) { + return null; + } + + if ($item['uid'] == 0) { + return Item::CANT_REPLY; + } + + $restrict = true; + $type = '$type'; + foreach ($post->threadgate->record->allow as $allow) { + switch ($allow->$type) { + case 'app.bsky.feed.threadgate#followingRule': + // Only followers can reply. + if (Contact::isFollower($item['author-id'], $item['uid'])) { + $restrict = false; + } + break; + case 'app.bsky.feed.threadgate#mentionRule': + // Only mentioned accounts can reply. + if ($post_reason == Item::PR_TO) { + $restrict = false; + } + break; + case 'app.bsky.feed.threadgate#listRule'; + // Only accounts in the provided list can reply. We don't support this at the moment. + break; + } + } + + return $restrict ? Item::CANT_REPLY : null; +} + function bluesky_get_content(array $item, stdClass $record, string $uri, int $uid, int $fetch_uid, int $level, int $last_poll): array { if (empty($item)) {