baa11c18b0
Allow for the MOBILIZON_CA_CERT_PATH to be used to provide your own root certificates. The CAStore and certify certificates stores should be always already be used as fallback instead of the system store. Closes #1355 Signed-off-by: Thomas Citharel <tcit@tcit.fr>
34 lines
803 B
Elixir
34 lines
803 B
Elixir
defmodule Mobilizon.Service.HTTP.WebfingerClient do
|
|
@moduledoc """
|
|
Tesla HTTP Basic Client
|
|
with JSON middleware
|
|
"""
|
|
|
|
use Tesla
|
|
alias Mobilizon.Config
|
|
import Mobilizon.Service.HTTP.Utils, only: [get_tls_config: 0]
|
|
|
|
@default_opts [
|
|
recv_timeout: 20_000
|
|
]
|
|
|
|
adapter(Tesla.Adapter.Hackney, Keyword.merge([ssl_options: get_tls_config()], @default_opts))
|
|
|
|
plug(Tesla.Middleware.FollowRedirects)
|
|
|
|
plug(Tesla.Middleware.Timeout, timeout: 10_000)
|
|
|
|
plug(Tesla.Middleware.Headers, [
|
|
{"User-Agent", Config.instance_user_agent()},
|
|
{"Accept", "application/json, application/activity+json, application/jrd+json"}
|
|
])
|
|
|
|
plug(Tesla.Middleware.JSON,
|
|
decode_content_types: [
|
|
"application/jrd+json",
|
|
"application/json",
|
|
"application/activity+json"
|
|
]
|
|
)
|
|
end
|