소스 검색

Merge branch 'cycles-reverse-proxy' into 'develop'

Recompilation speedup: create Dynamic client for ReverseProxy

See merge request pleroma/pleroma!3440
cycles-validator
feld 3 년 전
부모
커밋
96e85ea687
3개의 변경된 파일30개의 추가작업 그리고 19개의 파일을 삭제
  1. +1
    -1
      lib/pleroma/reverse_proxy.ex
  2. +0
    -18
      lib/pleroma/reverse_proxy/client.ex
  3. +29
    -0
      lib/pleroma/reverse_proxy/client/wrapper.ex

+ 1
- 1
lib/pleroma/reverse_proxy.ex 파일 보기

@@ -411,7 +411,7 @@ defmodule Pleroma.ReverseProxy do
{:ok, :no_duration_limit, :no_duration_limit}
end

defp client, do: Pleroma.ReverseProxy.Client
defp client, do: Pleroma.ReverseProxy.Client.Wrapper

defp track_failed_url(url, error, opts) do
ttl =


+ 0
- 18
lib/pleroma/reverse_proxy/client.ex 파일 보기

@@ -17,22 +17,4 @@ defmodule Pleroma.ReverseProxy.Client do
@callback stream_body(map()) :: {:ok, binary(), map()} | :done | {:error, atom() | String.t()}

@callback close(reference() | pid() | map()) :: :ok

def request(method, url, headers, body \\ "", opts \\ []) do
client().request(method, url, headers, body, opts)
end

def stream_body(ref), do: client().stream_body(ref)

def close(ref), do: client().close(ref)

defp client do
:tesla
|> Application.get_env(:adapter)
|> client()
end

defp client(Tesla.Adapter.Hackney), do: Pleroma.ReverseProxy.Client.Hackney
defp client(Tesla.Adapter.Gun), do: Pleroma.ReverseProxy.Client.Tesla
defp client(_), do: Pleroma.Config.get!(Pleroma.ReverseProxy.Client)
end

+ 29
- 0
lib/pleroma/reverse_proxy/client/wrapper.ex 파일 보기

@@ -0,0 +1,29 @@
# Pleroma: A lightweight social networking server
# Copyright © 2017-2021 Pleroma Authors <https://pleroma.social/>
# SPDX-License-Identifier: AGPL-3.0-only

defmodule Pleroma.ReverseProxy.Client.Wrapper do
@moduledoc "Meta-client that calls the appropriate client from the config."
@behaviour Pleroma.ReverseProxy.Client

@impl true
def request(method, url, headers, body \\ "", opts \\ []) do
client().request(method, url, headers, body, opts)
end

@impl true
def stream_body(ref), do: client().stream_body(ref)

@impl true
def close(ref), do: client().close(ref)

defp client do
:tesla
|> Application.get_env(:adapter)
|> client()
end

defp client(Tesla.Adapter.Hackney), do: Pleroma.ReverseProxy.Client.Hackney
defp client(Tesla.Adapter.Gun), do: Pleroma.ReverseProxy.Client.Tesla
defp client(_), do: Pleroma.Config.get!(Pleroma.ReverseProxy.Client)
end

불러오는 중...
취소
저장