logo

pleroma

My custom branche(s) on git.pleroma.social/pleroma/pleroma
commit: 0d2c13a119302d0d217a7cb61c28a01c620b1b61
parent: b3c80b840445e4041042e140e3e2f58faa32f4f9
Author: lain <lain@soykaf.club>
Date:   Mon,  9 Dec 2019 15:10:05 +0000

Merge branch 'fix/otp-parsers' into 'develop'

OTP: Fix runtime upload limit config being ignored

Closes #1109

See merge request pleroma/pleroma!2045

Diffstat:

Alib/pleroma/plugs/parsers_plug.ex21+++++++++++++++++++++
Mlib/pleroma/web/endpoint.ex9+--------
2 files changed, 22 insertions(+), 8 deletions(-)

diff --git a/lib/pleroma/plugs/parsers_plug.ex b/lib/pleroma/plugs/parsers_plug.ex @@ -0,0 +1,21 @@ +# Pleroma: A lightweight social networking server +# Copyright © 2017-2019 Pleroma Authors <https://pleroma.social/> +# SPDX-License-Identifier: AGPL-3.0-only + +defmodule Pleroma.Plugs.Parsers do + @moduledoc "Initializes Plug.Parsers with upload limit set at boot time" + + @behaviour Plug + + def init(_opts) do + Plug.Parsers.init( + parsers: [:urlencoded, :multipart, :json], + pass: ["*/*"], + json_decoder: Jason, + length: Pleroma.Config.get([:instance, :upload_limit]), + body_reader: {Pleroma.Web.Plugs.DigestPlug, :read_body, []} + ) + end + + defdelegate call(conn, opts), to: Plug.Parsers +end diff --git a/lib/pleroma/web/endpoint.ex b/lib/pleroma/web/endpoint.ex @@ -61,14 +61,7 @@ defmodule Pleroma.Web.Endpoint do plug(Plug.RequestId) plug(Plug.Logger) - plug( - Plug.Parsers, - parsers: [:urlencoded, :multipart, :json], - pass: ["*/*"], - json_decoder: Jason, - length: Pleroma.Config.get([:instance, :upload_limit]), - body_reader: {Pleroma.Web.Plugs.DigestPlug, :read_body, []} - ) + plug(Pleroma.Plugs.Parsers) plug(Plug.MethodOverride) plug(Plug.Head)