mirror of
https://github.com/kevin-DL/phoenix_api_template.git
synced 2026-01-12 02:55:13 +00:00
Update user
This commit is contained in:
@@ -1,6 +1,7 @@
|
||||
defmodule PhoenixApiTemplateWeb.UserController do
|
||||
use PhoenixApiTemplateWeb, :controller
|
||||
|
||||
alias PhoenixApiTemplateWeb.Auth.ErrorResponse
|
||||
alias PhoenixApiTemplateWeb.Auth.ErrorResponse.Unauthorized
|
||||
alias PhoenixApiTemplateWeb.Auth.Guardian
|
||||
alias PhoenixApiTemplate.Accounts
|
||||
@@ -8,8 +9,21 @@ defmodule PhoenixApiTemplateWeb.UserController do
|
||||
alias PhoenixApiTemplate.Profiles
|
||||
alias PhoenixApiTemplate.Profiles.Profile
|
||||
|
||||
plug :is_authorized_user when action in [:update, :delete]
|
||||
|
||||
action_fallback(PhoenixApiTemplateWeb.FallbackController)
|
||||
|
||||
defp is_authorized_user(conn, _options) do
|
||||
%{params: %{"id" => id}} = conn
|
||||
user = Accounts.get_user!(id)
|
||||
|
||||
if conn.assigns.user.id == user.id do
|
||||
conn
|
||||
else
|
||||
raise ErrorResponse.Forbidden
|
||||
end
|
||||
end
|
||||
|
||||
def index(conn, _params) do
|
||||
users = Accounts.list_users()
|
||||
render(conn, "index.json", users: users)
|
||||
|
||||
Reference in New Issue
Block a user