defmodule BeetRoundServerWeb.UserController do use BeetRoundServerWeb, :controller alias BeetRoundServer.Accounts alias BeetRoundServer.Accounts.User action_fallback BeetRoundServerWeb.FallbackController def index(conn, _params) do users = Accounts.list_users() render(conn, :index, users: users) end def create(conn, %{"user" => user_params}) do case Accounts.register_user(user_params) do {:ok, %User{} = user} -> send_created_response(conn, user) {:error, changeset} -> with %User{} = user <- Accounts.get_user_by_email(user_params["email"]) do send_already_reported_response(conn, user) else _ -> send_not_acceptable(conn, changeset) end _ -> conn |> put_status(:bad_request) |> put_resp_header("location", ~p"/api/users") |> render(:show, changeset: "Bad request") end end def show(conn, %{"id" => id}) do user = Accounts.get_user!(id) render(conn, :show, user: user) end # def update(conn, %{"id" => id, "user" => user_params}) do # user = Accounts.get_user!(id) # with {:ok, %User{} = user} <- Accounts.update_user(user, user_params) do # render(conn, :show, user: user) # end # end # def delete(conn, %{"id" => id}) do # user = Accounts.get_user!(id) # with {:ok, %User{}} <- Accounts.delete_user(user) do # send_resp(conn, :no_content, "") # end # end defp send_created_response(conn, %User{} = user) do conn |> put_status(:created) |> put_resp_header("location", ~p"/api/users/#{user}") |> render(:show, %{user: user}) end defp send_already_reported_response(conn, %User{} = user) do conn |> put_status(:already_reported) |> render(:show, %{user: user}) end defp send_not_acceptable(conn, changeset) do conn |> put_status(:not_acceptable) |> put_resp_header("location", ~p"/api/users") |> render(:show, changeset: changeset) end end