25 lines
613 B
Elixir
25 lines
613 B
Elixir
defmodule Localiser.Web.Plugs.AuthRequired do
|
|
import Plug.Conn
|
|
|
|
alias Localiser.Web.Token
|
|
|
|
def init(opts), do: opts
|
|
|
|
def call(conn, _opts) do
|
|
with ["Bearer " <> token] <- get_req_header(conn, "authorization"),
|
|
{:ok, claims} <- Token.verify_token(token) do
|
|
assign(conn, :current_user, %{
|
|
user_id: claims["user_id"],
|
|
username: claims["username"],
|
|
is_admin: claims["is_admin"]
|
|
})
|
|
else
|
|
_ ->
|
|
conn
|
|
|> put_resp_content_type("application/json")
|
|
|> send_resp(401, ~s({"error":"unauthorised"}))
|
|
|> halt()
|
|
end
|
|
end
|
|
end
|