mirror of
https://github.com/mgerb/classic-wow-forums
synced 2026-01-09 00:42:47 +00:00
35 lines
1.2 KiB
Elixir
35 lines
1.2 KiB
Elixir
defmodule MyApp.Guardian.Auth.Token do
|
|
alias MyApp.Guardian
|
|
|
|
# one month in seconds
|
|
defp one_month(), do: 2592000
|
|
|
|
@spec add_token_and_map_claims(map | {atom, any}) :: {:ok, map} | {:error, String.t}
|
|
def add_token_and_map_claims(user) when is_map(user) do
|
|
|
|
claims = user
|
|
|> Map.take([:id, :battletag, :battle_net_id, :access_token]) # take values from user object to map to claims
|
|
|> Guardian.add_permissions(get_permissions(user))
|
|
|
|
# set token expiration to the same as the battlenet token
|
|
case Guardian.encode_and_sign(user, claims, ttl: {Map.get(user, :expires_in) || one_month(), :seconds}) do
|
|
{:ok, token, _claims} -> {:ok, Map.merge(user, %{token: token})}
|
|
{:error, error} -> {:error, error}
|
|
end
|
|
end
|
|
|
|
def add_token_and_map_claims({:ok, user}), do: add_token_and_map_claims(user)
|
|
def add_token_and_map_claims({:error, error}), do: {:error, error}
|
|
|
|
# return permissions base on field in database
|
|
defp get_permissions(user) do
|
|
case Map.get(user, :permissions) do
|
|
"user" -> %{user: [:read, :write]}
|
|
"mod" -> %{mod: [:read, :write]}
|
|
"admin" -> %{admin: [:read, :write]}
|
|
nil -> %{user: [:read, :write]}
|
|
end
|
|
end
|
|
|
|
end
|