mirror of
https://github.com/kevin-DL/phoenix_api_template.git
synced 2026-01-12 02:55:13 +00:00
Installed guardian
create authentication/password verification method
This commit is contained in:
46
lib/phoenix_api_template_web/auth/guardian.ex
Normal file
46
lib/phoenix_api_template_web/auth/guardian.ex
Normal file
@@ -0,0 +1,46 @@
|
||||
defmodule PhoenixApiTemplateWeb.Auth.Guardian do
|
||||
use Guardian, otp_app: :phoenix_api_template
|
||||
alias PhoenixApiTemplate.Accounts
|
||||
|
||||
def subject_for_token(%{id: id}, _claims) do
|
||||
sub = to_string(id)
|
||||
{:ok, sub}
|
||||
end
|
||||
|
||||
def subject_for_token(_, _) do
|
||||
{:error, :no_id_provided}
|
||||
end
|
||||
|
||||
def resource_from_claims(%{"sub" => id}) do
|
||||
case Accounts.get_user!(id) do
|
||||
nil -> {:error, :not_found}
|
||||
resource -> {:ok, resource}
|
||||
end
|
||||
end
|
||||
|
||||
def resource_from_claims(_claims) do
|
||||
{:error, :no_id_provided}
|
||||
end
|
||||
|
||||
def authenticate(email, password) do
|
||||
case Accounts.get_user_by_email(email) do
|
||||
nil ->
|
||||
{:error, :unauthorized}
|
||||
|
||||
user ->
|
||||
case validate_password(password, user.hashed_password) do
|
||||
true -> create_token(user)
|
||||
false -> {:error, :unauthorized}
|
||||
end
|
||||
end
|
||||
end
|
||||
|
||||
defp validate_password(password, hashed_password) do
|
||||
Bcrypt.verify_pass(password, hashed_password)
|
||||
end
|
||||
|
||||
defp create_token(user) do
|
||||
{:ok, token, _claims} = encode_and_sign(user)
|
||||
{:ok, user, token}
|
||||
end
|
||||
end
|
||||
Reference in New Issue
Block a user