aboutsummaryrefslogtreecommitdiff
path: root/lib
diff options
context:
space:
mode:
authorkaniini <ariadne@dereferenced.org>2019-07-31 19:13:56 +0000
committerkaniini <ariadne@dereferenced.org>2019-07-31 19:13:56 +0000
commit6c06529cd4549fca3ba4b1de72838240463f8306 (patch)
treef7ba3b6370ab5a0c5abe121d860321857c32da9c /lib
parentb431b565f0d4eb944826c2a2745201d9bb62956e (diff)
parent813c686dd77e6d441c235b2f7a57ac7911e249af (diff)
downloadpleroma-6c06529cd4549fca3ba4b1de72838240463f8306.tar.gz
Merge branch 'fix/disallow-ostatus-follows-locked' into 'develop'
Disallow following locked accounts over OStatus See merge request pleroma/pleroma!1512
Diffstat (limited to 'lib')
-rw-r--r--lib/pleroma/web/ostatus/handlers/follow_handler.ex4
1 files changed, 4 insertions, 0 deletions
diff --git a/lib/pleroma/web/ostatus/handlers/follow_handler.ex b/lib/pleroma/web/ostatus/handlers/follow_handler.ex
index 03e4cbbb0..24513972e 100644
--- a/lib/pleroma/web/ostatus/handlers/follow_handler.ex
+++ b/lib/pleroma/web/ostatus/handlers/follow_handler.ex
@@ -14,9 +14,13 @@ defmodule Pleroma.Web.OStatus.FollowHandler do
followed_uri when not is_nil(followed_uri) <-
XML.string_from_xpath("/entry/activity:object/id", entry),
{:ok, followed} <- OStatus.find_or_make_user(followed_uri),
+ {:locked, false} <- {:locked, followed.info.locked},
{:ok, activity} <- ActivityPub.follow(actor, followed, id, false) do
User.follow(actor, followed)
{:ok, activity}
+ else
+ {:locked, true} ->
+ {:error, "It's not possible to follow locked accounts over OStatus"}
end
end
end