1 2 3 4 5 6 7 8 9 10 11 12 13 14 15 16 17 18 19 20 21 22 23 24 25 26 27 28 29 30 31 32 33 34 35 36 37 38 39 40 41 42 43 44 45 46
defmodule ExOvh.Hubic.HubicApi.Request do
@moduledoc :false
alias ExOvh.Hubic.HubicApi.Auth
alias ExOvh.Hubic.HubicApi.Cache, as: TokenCache
@spec request(client :: atom, query :: ExOvh.Client.raw_query_t, retries :: integer)
:: {:ok, ExOvh.Client.response_t} | {:error, ExOvh.Client.response_t}
def request(client, {method, uri, params} = query, retries \\ 0) do
{method, uri, options} = Auth.prepare_request(client, query)
LoggingUtils.log_return({method, uri, options}, :debug)
resp = HTTPotion.request(method, uri, options)
|> LoggingUtils.log_return(:debug)
if resp.status_code >= 100 and resp.status_code < 300 do
try do
{:ok, %{
body: resp.body |> Poison.decode!(),
headers: resp.headers,
status_code: resp.status_code
}
}
rescue
_ ->
{:ok, %{
body: resp.body,
headers: resp.headers,
status_code: resp.status_code
}
}
end
else
if Map.has_key?(resp.body, "error") do
if resp.body["error"] === "invalid_token" do
GenServer.call(TokenCache, :stop) # Restart the gen_server to recuperate state
unless retries >= 1, do: request(query, 1) # Try request one more time
else
{:error, resp}
end
else
{:error, resp}
end
end
end
end