X-Git-Url: https://git.squeep.com/?a=blobdiff_plain;f=lib%2Fpleroma%2Fhttp%2Fconnection.ex;h=a1460d3038af6bae452259f50e2972e4925e51f4;hb=b001b8891a0ae9d8c7291f8148eb68a354cd319f;hp=5e8f2aabd1b3ed26b70ea548cae283da232962a3;hpb=114b95cee20c9bb4922627e5397a70d60e905fa6;p=akkoma diff --git a/lib/pleroma/http/connection.ex b/lib/pleroma/http/connection.ex index 5e8f2aabd..a1460d303 100644 --- a/lib/pleroma/http/connection.ex +++ b/lib/pleroma/http/connection.ex @@ -1,9 +1,18 @@ +# Pleroma: A lightweight social networking server +# Copyright © 2017-2019 Pleroma Authors +# SPDX-License-Identifier: AGPL-3.0-only + defmodule Pleroma.HTTP.Connection do @moduledoc """ Connection for http-requests. """ - @hackney_options [pool: :default] + @hackney_options [ + connect_timeout: 10_000, + recv_timeout: 20_000, + follow_redirect: true, + pool: :federation + ] @adapter Application.get_env(:tesla, :adapter) @doc """ @@ -20,8 +29,14 @@ defmodule Pleroma.HTTP.Connection do # fetch Hackney options # - defp hackney_options(opts \\ []) do + def hackney_options(opts) do options = Keyword.get(opts, :adapter, []) - @hackney_options ++ options + adapter_options = Pleroma.Config.get([:http, :adapter], []) + proxy_url = Pleroma.Config.get([:http, :proxy_url], nil) + + @hackney_options + |> Keyword.merge(adapter_options) + |> Keyword.merge(options) + |> Keyword.merge(proxy: proxy_url) end end