diff options
author | squidboi <squidboi@waifu.club> | 2018-06-16 15:37:16 -0700 |
---|---|---|
committer | squidboi <squidboi@waifu.club> | 2018-06-16 15:37:16 -0700 |
commit | 2e294ee44a1baa7c0d3ac6b2905a70ed4e05cffb (patch) | |
tree | 740d660abc0ca455368144abc89c8a398e85caf0 /lib/mix/tasks/set_locked.ex | |
parent | 4f9ecfc77a54eef23741c89206b4cbce924f7d76 (diff) | |
parent | 1ea4a18ad859600841860cdd1a981da868aa18a0 (diff) | |
download | pleroma-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.ex | 30 |
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 |