aboutsummaryrefslogtreecommitdiff
path: root/lib/mix/tasks/set_admin.ex
diff options
context:
space:
mode:
authorlambda <pleromagit@rogerbraun.net>2018-12-05 17:53:35 +0000
committerlambda <pleromagit@rogerbraun.net>2018-12-05 17:53:35 +0000
commit991b62cb4d3db851ac411240e2c8364b799a00d6 (patch)
tree70eb9ba5afa9faf24246b868d7fabbb2892c61c2 /lib/mix/tasks/set_admin.ex
parent22eff1791204864d0536e71c13649d0030c409a7 (diff)
parentc3519132dfdcd5f59c0ebe99fa8ab4b764ac4982 (diff)
downloadpleroma-991b62cb4d3db851ac411240e2c8364b799a00d6.tar.gz
Merge branch 'fix/mix-tasks-userinfo' into 'develop'
Update mix tasks that use User.info.info_changeset since it is deprecated See merge request pleroma/pleroma!503
Diffstat (limited to 'lib/mix/tasks/set_admin.ex')
-rw-r--r--lib/mix/tasks/set_admin.ex18
1 files changed, 10 insertions, 8 deletions
diff --git a/lib/mix/tasks/set_admin.ex b/lib/mix/tasks/set_admin.ex
index d5ccf261b..ac26516f1 100644
--- a/lib/mix/tasks/set_admin.ex
+++ b/lib/mix/tasks/set_admin.ex
@@ -1,5 +1,6 @@
defmodule Mix.Tasks.SetAdmin do
use Mix.Task
+ import Ecto.Changeset
alias Pleroma.User
@doc """
@@ -9,21 +10,22 @@ defmodule Mix.Tasks.SetAdmin do
def run([nickname | rest]) do
Application.ensure_all_started(:pleroma)
- status =
+ admin =
case rest do
- [status] -> status == "true"
+ [admin] -> admin == "true"
_ -> true
end
with %User{local: true} = user <- User.get_by_nickname(nickname) do
- info =
- user.info
- |> Map.put("is_admin", !!status)
+ info_cng = User.Info.admin_api_update(user.info, %{is_admin: !!admin})
- cng = User.info_changeset(user, %{info: info})
- {:ok, user} = User.update_and_set_cache(cng)
+ user_cng =
+ Ecto.Changeset.change(user)
+ |> put_embed(:info, info_cng)
- IO.puts("Admin status of #{nickname}: #{user.info["is_admin"]}")
+ {:ok, user} = User.update_and_set_cache(user_cng)
+
+ IO.puts("Admin status of #{nickname}: #{user.info.is_admin}")
else
_ ->
IO.puts("No local user #{nickname}")