mirror of
https://github.com/kevin-DL/phoenix_api_template.git
synced 2026-01-13 11:25:28 +00:00
Create user
Create profile added some validation
This commit is contained in:
@@ -0,0 +1,24 @@
|
||||
defmodule PhoenixApiTemplateWeb.FallbackController do
|
||||
@moduledoc """
|
||||
Translates controller action results into valid `Plug.Conn` responses.
|
||||
|
||||
See `Phoenix.Controller.action_fallback/1` for more details.
|
||||
"""
|
||||
use PhoenixApiTemplateWeb, :controller
|
||||
|
||||
# This clause handles errors returned by Ecto's insert/update/delete.
|
||||
def call(conn, {:error, %Ecto.Changeset{} = changeset}) do
|
||||
conn
|
||||
|> put_status(:unprocessable_entity)
|
||||
|> put_view(PhoenixApiTemplateWeb.ChangesetView)
|
||||
|> render("error.json", changeset: changeset)
|
||||
end
|
||||
|
||||
# This clause is an example of how to handle resources that cannot be found.
|
||||
def call(conn, {:error, :not_found}) do
|
||||
conn
|
||||
|> put_status(:not_found)
|
||||
|> put_view(PhoenixApiTemplateWeb.ErrorView)
|
||||
|> render(:"404")
|
||||
end
|
||||
end
|
||||
@@ -0,0 +1,43 @@
|
||||
defmodule PhoenixApiTemplateWeb.ProfileController do
|
||||
use PhoenixApiTemplateWeb, :controller
|
||||
|
||||
alias PhoenixApiTemplate.Profiles
|
||||
alias PhoenixApiTemplate.Profiles.Profile
|
||||
|
||||
action_fallback PhoenixApiTemplateWeb.FallbackController
|
||||
|
||||
def index(conn, _params) do
|
||||
profiles = Profiles.list_profiles()
|
||||
render(conn, "index.json", profiles: profiles)
|
||||
end
|
||||
|
||||
def create(conn, %{"profile" => profile_params}) do
|
||||
with {:ok, %Profile{} = profile} <- Profiles.create_profile(profile_params) do
|
||||
conn
|
||||
|> put_status(:created)
|
||||
|> put_resp_header("location", Routes.profile_path(conn, :show, profile))
|
||||
|> render("show.json", profile: profile)
|
||||
end
|
||||
end
|
||||
|
||||
def show(conn, %{"id" => id}) do
|
||||
profile = Profiles.get_profile!(id)
|
||||
render(conn, "show.json", profile: profile)
|
||||
end
|
||||
|
||||
def update(conn, %{"id" => id, "profile" => profile_params}) do
|
||||
profile = Profiles.get_profile!(id)
|
||||
|
||||
with {:ok, %Profile{} = profile} <- Profiles.update_profile(profile, profile_params) do
|
||||
render(conn, "show.json", profile: profile)
|
||||
end
|
||||
end
|
||||
|
||||
def delete(conn, %{"id" => id}) do
|
||||
profile = Profiles.get_profile!(id)
|
||||
|
||||
with {:ok, %Profile{}} <- Profiles.delete_profile(profile) do
|
||||
send_resp(conn, :no_content, "")
|
||||
end
|
||||
end
|
||||
end
|
||||
42
lib/phoenix_api_template_web/controllers/user_controller.ex
Normal file
42
lib/phoenix_api_template_web/controllers/user_controller.ex
Normal file
@@ -0,0 +1,42 @@
|
||||
defmodule PhoenixApiTemplateWeb.UserController do
|
||||
use PhoenixApiTemplateWeb, :controller
|
||||
|
||||
alias PhoenixApiTemplate.Accounts
|
||||
alias PhoenixApiTemplate.Accounts.User
|
||||
|
||||
action_fallback(PhoenixApiTemplateWeb.FallbackController)
|
||||
|
||||
def index(conn, _params) do
|
||||
users = Accounts.list_users()
|
||||
render(conn, "index.json", users: users)
|
||||
end
|
||||
|
||||
def create(conn, %{"user" => user_params}) do
|
||||
with {:ok, %User{} = user} <- Accounts.create_user(user_params) do
|
||||
conn
|
||||
|> put_status(:created)
|
||||
|> render("show.json", user: user)
|
||||
end
|
||||
end
|
||||
|
||||
def show(conn, %{"id" => id}) do
|
||||
user = Accounts.get_user!(id)
|
||||
render(conn, "show.json", 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.json", 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
|
||||
end
|
||||
19
lib/phoenix_api_template_web/views/changeset_view.ex
Normal file
19
lib/phoenix_api_template_web/views/changeset_view.ex
Normal file
@@ -0,0 +1,19 @@
|
||||
defmodule PhoenixApiTemplateWeb.ChangesetView do
|
||||
use PhoenixApiTemplateWeb, :view
|
||||
|
||||
@doc """
|
||||
Traverses and translates changeset errors.
|
||||
|
||||
See `Ecto.Changeset.traverse_errors/2` and
|
||||
`PhoenixApiTemplateWeb.ErrorHelpers.translate_error/1` for more details.
|
||||
"""
|
||||
def translate_errors(changeset) do
|
||||
Ecto.Changeset.traverse_errors(changeset, &translate_error/1)
|
||||
end
|
||||
|
||||
def render("error.json", %{changeset: changeset}) do
|
||||
# When encoded, the changeset returns its errors
|
||||
# as a JSON object. So we just pass it forward.
|
||||
%{errors: translate_errors(changeset)}
|
||||
end
|
||||
end
|
||||
19
lib/phoenix_api_template_web/views/profile_view.ex
Normal file
19
lib/phoenix_api_template_web/views/profile_view.ex
Normal file
@@ -0,0 +1,19 @@
|
||||
defmodule PhoenixApiTemplateWeb.ProfileView do
|
||||
use PhoenixApiTemplateWeb, :view
|
||||
alias PhoenixApiTemplateWeb.ProfileView
|
||||
|
||||
def render("index.json", %{profiles: profiles}) do
|
||||
%{data: render_many(profiles, ProfileView, "profile.json")}
|
||||
end
|
||||
|
||||
def render("show.json", %{profile: profile}) do
|
||||
%{data: render_one(profile, ProfileView, "profile.json")}
|
||||
end
|
||||
|
||||
def render("profile.json", %{profile: profile}) do
|
||||
%{
|
||||
id: profile.id,
|
||||
display_name: profile.display_name
|
||||
}
|
||||
end
|
||||
end
|
||||
20
lib/phoenix_api_template_web/views/user_view.ex
Normal file
20
lib/phoenix_api_template_web/views/user_view.ex
Normal file
@@ -0,0 +1,20 @@
|
||||
defmodule PhoenixApiTemplateWeb.UserView do
|
||||
use PhoenixApiTemplateWeb, :view
|
||||
alias PhoenixApiTemplateWeb.UserView
|
||||
|
||||
def render("index.json", %{users: users}) do
|
||||
%{data: render_many(users, UserView, "user.json")}
|
||||
end
|
||||
|
||||
def render("show.json", %{user: user}) do
|
||||
%{data: render_one(user, UserView, "user.json")}
|
||||
end
|
||||
|
||||
def render("user.json", %{user: user}) do
|
||||
%{
|
||||
id: user.id,
|
||||
email: user.email,
|
||||
hashed_password: user.hashed_password
|
||||
}
|
||||
end
|
||||
end
|
||||
Reference in New Issue
Block a user