aboutsummaryrefslogtreecommitdiff
diff options
context:
space:
mode:
authorkaniini <nenolod@gmail.com>2018-10-28 19:54:21 +0000
committerkaniini <nenolod@gmail.com>2018-10-28 19:54:21 +0000
commit658036881d132e22cb033dff1ac2bdbd74e802a1 (patch)
tree374c290d1a449068e954bd33cb53ffef34221504
parent39103a91be48abf0e9430c72c9799542ad7e4354 (diff)
parent69192f36ff617d237481c401850171bf79a2f547 (diff)
downloadpleroma-658036881d132e22cb033dff1ac2bdbd74e802a1.tar.gz
Merge branch 'feature/unsubscribe-user-task' into 'develop'
mix tasks: add new task to unsubscribe all users from, and then ban a remote user (e.g. followbots) See merge request pleroma/pleroma!399
-rw-r--r--lib/mix/tasks/unsubscribe_user.ex32
1 files changed, 32 insertions, 0 deletions
diff --git a/lib/mix/tasks/unsubscribe_user.ex b/lib/mix/tasks/unsubscribe_user.ex
new file mode 100644
index 000000000..bb72634b6
--- /dev/null
+++ b/lib/mix/tasks/unsubscribe_user.ex
@@ -0,0 +1,32 @@
+defmodule Mix.Tasks.UnsubscribeUser do
+ use Mix.Task
+ alias Pleroma.{User, Repo}
+ require Logger
+
+ @shortdoc "Unsubscribe all users from a target and then deactivate them"
+ def run([nickname]) do
+ Mix.Task.run("app.start")
+
+ with %User{} = user <- User.get_by_nickname(nickname) do
+ Logger.info("Deactivating #{user.nickname}")
+ User.deactivate(user)
+
+ {:ok, friends} = User.get_friends(user)
+
+ Enum.each(friends, fn friend ->
+ user = Repo.get(User, user.id)
+
+ Logger.info("Unsubscribing #{friend.nickname} from #{user.nickname}")
+ User.unfollow(user, friend)
+ end)
+
+ :timer.sleep(500)
+
+ user = Repo.get(User, user.id)
+
+ if length(user.following) == 0 do
+ Logger.info("Successfully unsubscribed all followers from #{user.nickname}")
+ end
+ end
+ end
+end