|> json(nickname)
end
- def user_create(
- conn,
- %{user: %{"nickname" => nickname, "email" => email, "password" => password} = user}
- ) do
+ def user_create(conn, %{
+ user: %{"nickname" => nickname, "email" => email, "password" => password} = user
+ }) do
new_user = %User{
nickname: nickname,
name: user.name || nickname,
|> json(user.info)
end
+ def right_get(conn, %{"nickname" => nickname}) do
+ user = User.get_by_nickname(nickname)
+
+ conn
+ |> json(user.info)
+ end
+
def right_add(conn, _) do
conn
|> put_status(404)
|> json(%{error: "No such right"})
end
- def right_delete(conn, %{"right" => right, "nickname" => nickname})
+ def right_delete(
+ %{assigns: %{user: %User{:nickname => admin_nickname}}} = conn,
+ %{
+ "right" => right,
+ "nickname" => nickname
+ }
+ )
when right in ["moderator", "admin"] do
- user = User.get_by_nickname(nickname)
+ if admin_nickname == nickname do
+ conn
+ |> put_status(403)
+ |> json(%{error: "You can't revoke your own admin status."})
+ else
+ user = User.get_by_nickname(nickname)
- info =
- user.info
- |> Map.put("is_" <> right, false)
+ info =
+ user.info
+ |> Map.put("is_" <> right, false)
- 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)
- conn
- |> json(user.info)
+ conn
+ |> json(user.info)
+ end
end
def right_delete(conn, _) do
end
def relay_follow(conn, %{"relay_url" => target}) do
- :ok = Relay.follow(target)
+ status = Relay.follow(target)
- conn
- |> json(target)
+ if status == :ok do
+ conn
+ |> json(target)
+ else
+ conn
+ |> put_status(500)
+ |> json(target)
+ end
end
def relay_unfollow(conn, %{"relay_url" => target}) do
- :ok = Relay.unfollow(target)
+ status = Relay.unfollow(target)
- conn
- |> json(target)
+ if status == :ok do
+ conn
+ |> json(target)
+ else
+ conn
+ |> put_status(500)
+ |> json(target)
+ end
end
@shortdoc "Get a account registeration invite token (base64 string)"