2019-03-14 22:02:48 +03:00
|
|
|
# Pleroma: A lightweight social networking server
|
2021-01-13 07:49:20 +01:00
|
|
|
# Copyright © 2017-2021 Pleroma Authors <https://pleroma.social/>
|
2019-03-14 22:02:48 +03:00
|
|
|
# SPDX-License-Identifier: AGPL-3.0-only
|
|
|
|
|
2020-06-23 18:16:47 +03:00
|
|
|
defmodule Pleroma.Web.Plugs.UploadedMediaPlugTest do
|
2023-08-01 11:43:50 +01:00
|
|
|
use Pleroma.Web.ConnCase, async: false
|
2019-03-14 22:02:48 +03:00
|
|
|
alias Pleroma.Upload
|
|
|
|
|
2019-03-14 22:26:54 +03:00
|
|
|
defp upload_file(context) do
|
|
|
|
Pleroma.DataCase.ensure_local_uploader(context)
|
2019-03-14 22:02:48 +03:00
|
|
|
File.cp!("test/fixtures/image.jpg", "test/fixtures/image_tmp.jpg")
|
|
|
|
|
|
|
|
file = %Plug.Upload{
|
2020-10-13 10:37:24 -05:00
|
|
|
content_type: "image/jpeg",
|
2019-03-14 22:02:48 +03:00
|
|
|
path: Path.absname("test/fixtures/image_tmp.jpg"),
|
|
|
|
filename: "nice_tf.jpg"
|
|
|
|
}
|
|
|
|
|
|
|
|
{:ok, data} = Upload.store(file)
|
|
|
|
[%{"href" => attachment_url} | _] = data["url"]
|
|
|
|
[attachment_url: attachment_url]
|
|
|
|
end
|
|
|
|
|
2019-03-14 22:26:54 +03:00
|
|
|
setup_all :upload_file
|
|
|
|
|
2019-03-14 22:02:48 +03:00
|
|
|
test "does not send Content-Disposition header when name param is not set", %{
|
|
|
|
attachment_url: attachment_url
|
|
|
|
} do
|
|
|
|
conn = get(build_conn(), attachment_url)
|
|
|
|
refute Enum.any?(conn.resp_headers, &(elem(&1, 0) == "content-disposition"))
|
|
|
|
end
|
|
|
|
|
|
|
|
test "sends Content-Disposition header when name param is set", %{
|
|
|
|
attachment_url: attachment_url
|
|
|
|
} do
|
2023-04-18 00:07:39 +02:00
|
|
|
conn = get(build_conn(), attachment_url <> ~s[?name="cofe".gif])
|
2019-03-14 22:02:48 +03:00
|
|
|
|
|
|
|
assert Enum.any?(
|
|
|
|
conn.resp_headers,
|
2023-04-18 00:07:39 +02:00
|
|
|
&(&1 == {"content-disposition", ~s[inline; filename="\\"cofe\\".gif"]})
|
2019-03-14 22:02:48 +03:00
|
|
|
)
|
|
|
|
end
|
2022-11-10 11:54:12 +00:00
|
|
|
|
|
|
|
test "removes control characters from the Content-Disposition header", %{
|
|
|
|
attachment_url: attachment_url
|
|
|
|
} do
|
|
|
|
conn = get(build_conn(), attachment_url <> "?name=\"cofe\".gif\\r\\n")
|
|
|
|
|
|
|
|
assert Enum.any?(
|
|
|
|
conn.resp_headers,
|
2023-04-17 21:07:08 +02:00
|
|
|
&(&1 == {"content-disposition", ~s[inline; filename="\\"cofe\\".gif"]})
|
2022-11-10 11:54:12 +00:00
|
|
|
)
|
|
|
|
end
|
2019-03-14 22:02:48 +03:00
|
|
|
end
|