4aed977b153f54735b8ecb83e2577c733d53a6c4
[akkoma] / lib / pleroma / uploaders / swift / keystone.ex
1 defmodule Pleroma.Uploaders.Swift.Keystone do
2 use HTTPoison.Base
3
4 def process_url(url) do
5 Enum.join(
6 [Pleroma.Config.get!([Pleroma.Uploaders.Swift, :auth_url]), url],
7 "/"
8 )
9 end
10
11 def process_response_body(body) do
12 body
13 |> Poison.decode!()
14 end
15
16 def get_token() do
17 settings = Pleroma.Config.get(Pleroma.Uploaders.Swift)
18 username = Keyword.fetch!(settings, :username)
19 password = Keyword.fetch!(settings, :password)
20 tenant_id = Keyword.fetch!(settings, :tenant_id)
21
22 case post(
23 "/tokens",
24 make_auth_body(username, password, tenant_id),
25 ["Content-Type": "application/json"],
26 hackney: [:insecure]
27 ) do
28 {:ok, %Tesla.Env{status: 200, body: body}} ->
29 body["access"]["token"]["id"]
30
31 {:ok, %Tesla.Env{status: _}} ->
32 ""
33 end
34 end
35
36 def make_auth_body(username, password, tenant) do
37 Poison.encode!(%{
38 :auth => %{
39 :passwordCredentials => %{
40 :username => username,
41 :password => password
42 },
43 :tenantId => tenant
44 }
45 })
46 end
47 end