Merge branch 'security/activitypub-reject-bogus-ids' into 'develop'
[akkoma] / lib / mix / tasks / set_locked.ex
1 defmodule Mix.Tasks.SetLocked do
2 use Mix.Task
3 import Mix.Ecto
4 alias Pleroma.{Repo, User}
5
6 @shortdoc "Set locked status"
7 def run([nickname | rest]) do
8 ensure_started(Repo, [])
9
10 locked =
11 case rest do
12 [locked] -> locked == "true"
13 _ -> true
14 end
15
16 with %User{local: true} = user <- User.get_by_nickname(nickname) do
17 info =
18 user.info
19 |> Map.put("locked", !!locked)
20
21 cng = User.info_changeset(user, %{info: info})
22 user = Repo.update!(cng)
23
24 IO.puts("locked status of #{nickname}: #{user.info["locked"]}")
25 else
26 _ ->
27 IO.puts("No local user #{nickname}")
28 end
29 end
30 end