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

server - set token expiration to the same as battlnet token expiration

This commit is contained in:
2018-01-28 13:13:01 -06:00
parent c526ccb61b
commit 8191603a2c
4 changed files with 16 additions and 20 deletions

View File

@@ -1,28 +1,26 @@
defmodule MyApp.BattleNet.User do
@type battle_net_user :: %{"battle_net_id": integer, "battletag": String.t, "access_token": String.t}
def api_url(region), do: "https://#{region}.api.battle.net"
def cache_key(user_id, region), do: "usr_char:#{user_id}:#{region}"
# grab user information from battle net api - use token for auth
@spec get_user(String.t | {atom, any}, String.t) :: {:ok, battle_net_user} | {:error, any}
def get_user(access_token, region) when is_binary(access_token) do
access_token
@spec get_user(%{"access_token": String.t, "expires_in": integer}, String.t) :: {:ok, map} | {:error, any}
def get_user(data, region) when is_map(data) do
data["access_token"]
|> resource_url("account/user", region)
|> HTTPoison.get
|> parse_user_response(access_token)
|> parse_user_response(data)
end
def get_user({:ok, access_token}, region), do: get_user(access_token, region)
def get_user({:ok, data}, region), do: get_user(data, region)
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
defp parse_user_response({:ok, %HTTPoison.Response{body: body}}, data) do
case Poison.decode(body) do
{:ok, user} ->
user = user
|> Map.merge(%{"access_token" => access_token}) # add access token to return map
|> Map.merge(data) # merge blizzard user api info
|> Map.put("battle_net_id", Map.get(user, "id")) # change id key to battle_net_id
|> Map.delete("id") # remove id key
{:ok, user}