summaryrefslogtreecommitdiff
path: root/lib/mix/tasks/set_locked.ex
diff options
context:
space:
mode:
authorsquidboi <squidboi@waifu.club>2018-06-16 15:37:16 -0700
committersquidboi <squidboi@waifu.club>2018-06-16 15:37:16 -0700
commit2e294ee44a1baa7c0d3ac6b2905a70ed4e05cffb (patch)
tree740d660abc0ca455368144abc89c8a398e85caf0 /lib/mix/tasks/set_locked.ex
parent4f9ecfc77a54eef23741c89206b4cbce924f7d76 (diff)
parent1ea4a18ad859600841860cdd1a981da868aa18a0 (diff)
downloadpleroma-2e294ee44a1baa7c0d3ac6b2905a70ed4e05cffb.tar.gz
pleroma-2e294ee44a1baa7c0d3ac6b2905a70ed4e05cffb.zip
Merge branch 'develop' into feature/configurable-blocks
Diffstat (limited to 'lib/mix/tasks/set_locked.ex')
-rw-r--r--lib/mix/tasks/set_locked.ex30
1 files changed, 30 insertions, 0 deletions
diff --git a/lib/mix/tasks/set_locked.ex b/lib/mix/tasks/set_locked.ex
new file mode 100644
index 000000000..2b3b18b09
--- /dev/null
+++ b/lib/mix/tasks/set_locked.ex
@@ -0,0 +1,30 @@
+defmodule Mix.Tasks.SetLocked do
+ use Mix.Task
+ import Mix.Ecto
+ alias Pleroma.{Repo, User}
+
+ @shortdoc "Set locked status"
+ def run([nickname | rest]) do
+ ensure_started(Repo, [])
+
+ locked =
+ case rest do
+ [locked] -> locked == "true"
+ _ -> true
+ end
+
+ with %User{local: true} = user <- User.get_by_nickname(nickname) do
+ info =
+ user.info
+ |> Map.put("locked", !!locked)
+
+ cng = User.info_changeset(user, %{info: info})
+ user = Repo.update!(cng)
+
+ IO.puts("locked status of #{nickname}: #{user.info["locked"]}")
+ else
+ _ ->
+ IO.puts("No local user #{nickname}")
+ end
+ end
+end