summaryrefslogtreecommitdiff
path: root/lib/pleroma/frontend.ex
diff options
context:
space:
mode:
authorlain <lain@soykaf.club>2025-03-01 17:47:12 +0000
committerlain <lain@soykaf.club>2025-03-01 17:47:12 +0000
commit16944eb9dae2b8c41793b5f015ee54818bd939f7 (patch)
tree81eb0ba210f674eb0f6f41cde9b692a27ea96ca0 /lib/pleroma/frontend.ex
parenta8e863e0d627b6ed9563d953ee2cc8c9f4c9ee7a (diff)
parentaf6d5470d29f294e9b356da36cccbcaf85379f78 (diff)
downloadpleroma-16944eb9dae2b8c41793b5f015ee54818bd939f7.tar.gz
pleroma-16944eb9dae2b8c41793b5f015ee54818bd939f7.zip
Merge branch 'stable' into 'develop'
2.9.0 mergeback See merge request pleroma/pleroma!4332
Diffstat (limited to 'lib/pleroma/frontend.ex')
-rw-r--r--lib/pleroma/frontend.ex22
1 files changed, 5 insertions, 17 deletions
diff --git a/lib/pleroma/frontend.ex b/lib/pleroma/frontend.ex
index a4f427ae5..fe7f525ea 100644
--- a/lib/pleroma/frontend.ex
+++ b/lib/pleroma/frontend.ex
@@ -65,24 +65,12 @@ defmodule Pleroma.Frontend do
end
def unzip(zip, dest) do
- with {:ok, unzipped} <- :zip.unzip(zip, [:memory]) do
- File.rm_rf!(dest)
- File.mkdir_p!(dest)
-
- Enum.each(unzipped, fn {filename, data} ->
- path = filename
-
- new_file_path = Path.join(dest, path)
-
- path
- |> Path.dirname()
- |> then(&Path.join(dest, &1))
- |> File.mkdir_p!()
+ File.rm_rf!(dest)
+ File.mkdir_p!(dest)
- if not File.dir?(new_file_path) do
- File.write!(new_file_path, data)
- end
- end)
+ case Pleroma.SafeZip.unzip_data(zip, dest) do
+ {:ok, _} -> :ok
+ error -> error
end
end