mirror of
https://git.pleroma.social/pleroma/pleroma.git
synced 2024-12-23 08:36:29 +00:00
change new to gen in instance.ex . Refactor user.ex
This commit is contained in:
parent
03b2d1016d
commit
6396f1b58f
2 changed files with 44 additions and 58 deletions
|
@ -8,7 +8,7 @@ defmodule Mix.Tasks.Pleroma.Instance do
|
|||
|
||||
## Generate a new instance config.
|
||||
|
||||
mix pleroma.instance new [OPTION...]
|
||||
mix pleroma.instance gen [OPTION...]
|
||||
|
||||
If any options are left unspecified, you will be prompted interactively
|
||||
|
||||
|
@ -26,7 +26,7 @@ defmodule Mix.Tasks.Pleroma.Instance do
|
|||
- `--dbpass DBPASS` - the password to use for the database connection
|
||||
"""
|
||||
|
||||
def run(["new" | rest]) do
|
||||
def run(["gen" | rest]) do
|
||||
{options, [], []} =
|
||||
OptionParser.parse(
|
||||
rest,
|
||||
|
|
|
@ -197,6 +197,8 @@ defmodule Mix.Tasks.Pleroma.User do
|
|||
end
|
||||
|
||||
def run(["set", nickname | rest]) do
|
||||
Application.ensure_all_started(:pleroma)
|
||||
|
||||
{options, [], []} =
|
||||
OptionParser.parse(
|
||||
rest,
|
||||
|
@ -207,56 +209,58 @@ defmodule Mix.Tasks.Pleroma.User do
|
|||
]
|
||||
)
|
||||
|
||||
case Keyword.get(options, :moderator) do
|
||||
nil -> nil
|
||||
value -> set_moderator(nickname, value)
|
||||
end
|
||||
|
||||
case Keyword.get(options, :locked) do
|
||||
nil -> nil
|
||||
value -> set_locked(nickname, value)
|
||||
end
|
||||
|
||||
case Keyword.get(options, :admin) do
|
||||
nil -> nil
|
||||
value -> set_admin(nickname, value)
|
||||
end
|
||||
end
|
||||
|
||||
defp set_moderator(nickname, value) do
|
||||
Application.ensure_all_started(:pleroma)
|
||||
|
||||
with %User{local: true} = user <- User.get_by_nickname(nickname) do
|
||||
info =
|
||||
user.info
|
||||
|> Map.put("is_moderator", value)
|
||||
case Keyword.get(options, :moderator) do
|
||||
nil -> nil
|
||||
value -> set_moderator(user, value)
|
||||
end
|
||||
|
||||
cng = User.info_changeset(user, %{info: info})
|
||||
{:ok, user} = User.update_and_set_cache(cng)
|
||||
case Keyword.get(options, :locked) do
|
||||
nil -> nil
|
||||
value -> set_locked(user, value)
|
||||
end
|
||||
|
||||
Mix.shell().info("Moderator status of #{nickname}: #{user.info["is_moderator"]}")
|
||||
case Keyword.get(options, :admin) do
|
||||
nil -> nil
|
||||
value -> set_admin(user, value)
|
||||
end
|
||||
else
|
||||
_ ->
|
||||
Mix.shell().error("No local user #{nickname}")
|
||||
end
|
||||
end
|
||||
|
||||
defp set_admin(nickname, value) do
|
||||
Application.ensure_all_started(:pleroma)
|
||||
defp set_moderator(user, value) do
|
||||
info =
|
||||
user.info
|
||||
|> Map.put("is_moderator", value)
|
||||
|
||||
with %User{local: true} = user <- User.get_by_nickname(nickname) do
|
||||
info =
|
||||
user.info
|
||||
|> Map.put("is_admin", value)
|
||||
cng = User.info_changeset(user, %{info: info})
|
||||
{:ok, user} = User.update_and_set_cache(cng)
|
||||
|
||||
cng = User.info_changeset(user, %{info: info})
|
||||
{:ok, user} = User.update_and_set_cache(cng)
|
||||
Mix.shell().info("Moderator status of #{user.nickname}: #{user.info["is_moderator"]}")
|
||||
end
|
||||
|
||||
Mix.shell().info("Admin status of #{nickname}: #{user.info["is_admin"]}")
|
||||
else
|
||||
_ ->
|
||||
Mix.shell().error("No local user #{nickname}")
|
||||
end
|
||||
defp set_admin(user, value) do
|
||||
info =
|
||||
user.info
|
||||
|> Map.put("is_admin", value)
|
||||
|
||||
cng = User.info_changeset(user, %{info: info})
|
||||
{:ok, user} = User.update_and_set_cache(cng)
|
||||
|
||||
Mix.shell().info("Admin status of #{user.nickname}: #{user.info["is_admin"]}")
|
||||
end
|
||||
|
||||
defp set_locked(user, value) do
|
||||
info =
|
||||
user.info
|
||||
|> Map.put("locked", value)
|
||||
|
||||
cng = User.info_changeset(user, %{info: info})
|
||||
user = Repo.update!(cng)
|
||||
|
||||
IO.puts("Locked status of #{user.nickname}: #{user.info["locked"]}")
|
||||
end
|
||||
|
||||
def run(["invite"]) do
|
||||
|
@ -278,22 +282,4 @@ defmodule Mix.Tasks.Pleroma.User do
|
|||
Mix.shell().error("Could not create invite token.")
|
||||
end
|
||||
end
|
||||
|
||||
defp set_locked(nickname, value) do
|
||||
Mix.Ecto.ensure_started(Repo, [])
|
||||
|
||||
with %User{local: true} = user <- User.get_by_nickname(nickname) do
|
||||
info =
|
||||
user.info
|
||||
|> Map.put("locked", value)
|
||||
|
||||
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
|
||||
|
|
Loading…
Reference in a new issue