mirror of
https://github.com/mgerb/classic-wow-forums
synced 2026-01-10 09:02:50 +00:00
authentication with persistence working
This commit is contained in:
@@ -1,16 +1,32 @@
|
||||
defmodule MyApp.BattleNet.User do
|
||||
defstruct id: nil, battletag: nil
|
||||
|
||||
@type battle_net_user :: %{"battle_net_id": integer, "battletag": String.t, "access_token": String.t}
|
||||
|
||||
def api_url, do: "https://us.api.battle.net"
|
||||
|
||||
def get_user(access_token) do
|
||||
case HTTPoison.get(resource_url("account/user", access_token)) do
|
||||
{:ok, %HTTPoison.Response{body: body}} -> {:ok, Poison.decode!(body, as: Battlenet.User)}
|
||||
{:error, err} -> {:error, err}
|
||||
# grab user information from battle net api - use token for auth
|
||||
@spec get_user(String.t | {atom, any}) :: {:ok, battle_net_user} | {:error, any}
|
||||
def get_user(access_token) when is_binary(access_token) do
|
||||
HTTPoison.get(resource_url("account/user", access_token))
|
||||
|> parse_user_response(access_token)
|
||||
end
|
||||
def get_user({:ok, access_token}), do: get_user(access_token)
|
||||
def get_user({:error, error}), do: {:error, error}
|
||||
|
||||
defp parse_user_response({:error, error}, _), do: {:error, error}
|
||||
defp parse_user_response({:ok, %HTTPoison.Response{body: body}}, access_token) do
|
||||
case Poison.decode(body) do
|
||||
{:ok, user} ->
|
||||
user = user
|
||||
|> Map.merge(%{"access_token" => access_token}) # add access token to return map
|
||||
|> Map.put("battle_net_id", Map.get(user, "id")) # change id key to battle_net_id
|
||||
|> Map.delete("id") # remove id key
|
||||
{:ok, user}
|
||||
{:error, error} -> {:error, error}
|
||||
end
|
||||
end
|
||||
|
||||
defp resource_url(path, access_token) do
|
||||
"#{api_url}/#{path}?access_token=#{access_token}"
|
||||
"#{api_url()}/#{path}?access_token=#{access_token}"
|
||||
end
|
||||
end
|
||||
|
||||
Reference in New Issue
Block a user