def user_delete(conn, %{"nickname" => nickname}) do
user = User.get_by_nickname(nickname)
- if user[:local] == true do
+ if user.local == true do
User.delete(user)
else
User.delete(user)
|> json(nickname)
end
- def user_create(conn, %{
- user: %{"nickname" => nickname, "email" => email, "password" => password} = user
- }) do
- new_user = %User{
+ def user_create(
+ conn,
+ %{"nickname" => nickname, "email" => email, "password" => password}
+ ) do
+ new_user = %{
nickname: nickname,
- name: user.name || nickname,
+ name: nickname,
email: email,
password: password,
password_confirmation: password,
- bio: user.bio || "."
+ bio: "."
}
User.register_changeset(%User{}, new_user)
-
- Repo.insert!(new_user)
+ |> Repo.insert!()
conn
|> json(new_user.nickname)
user = User.get_by_nickname(nickname)
info =
- user.info
+ %{}
|> Map.put("is_" <> permission_group, true)
- cng = User.info_changeset(user, %{info: info})
+ info_cng = User.Info.admin_api_update(user.info, info)
+
+ cng =
+ Ecto.Changeset.change(user)
+ |> Ecto.Changeset.put_embed(:info, info_cng)
+
{:ok, user} = User.update_and_set_cache(cng)
conn
- |> json(user.info)
+ |> json(info)
end
def right_get(conn, %{"nickname" => nickname}) do
user = User.get_by_nickname(nickname)
conn
- |> json(user.info)
+ |> json(%{
+ is_moderator: user.info.is_moderator,
+ is_admin: user.info.is_admin
+ })
end
def right_add(conn, _) do
user = User.get_by_nickname(nickname)
info =
- user.info
+ %{}
|> Map.put("is_" <> permission_group, false)
- cng = User.info_changeset(user, %{info: info})
+ info_cng = User.Info.admin_api_update(user.info, info)
+
+ cng =
+ Ecto.Changeset.change(user)
+ |> Ecto.Changeset.put_embed(:info, info_cng)
+
{:ok, user} = User.update_and_set_cache(cng)
conn
- |> json(user.info)
+ |> json(info)
end
end
end
def relay_follow(conn, %{"relay_url" => target}) do
- status = Relay.follow(target)
+ {status, message} = Relay.follow(target)
if status == :ok do
conn
end
def relay_unfollow(conn, %{"relay_url" => target}) do
- status = Relay.unfollow(target)
+ {status, message} = Relay.unfollow(target)
if status == :ok do
conn