1
0
mirror of https://github.com/mgerb/classic-wow-forums synced 2026-01-11 01:22:49 +00:00

thread update/insert changeset fixed - auth permissions done

This commit is contained in:
2018-01-03 23:04:29 -06:00
parent 11eaa3565b
commit 148bde8f99
9 changed files with 120 additions and 48 deletions

33
lib/myapp/auth/token.ex Normal file
View File

@@ -0,0 +1,33 @@
defmodule MyApp.Guardian.Auth.Token do
alias MyApp.Guardian
# ~1 year
defp tokenTTL(), do: {52, :weeks}
@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))
case Guardian.encode_and_sign(user, claims, ttl: tokenTTL()) 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