aboutsummaryrefslogtreecommitdiff
diff options
context:
space:
mode:
authorWilliam Pitcock <nenolod@dereferenced.org>2019-02-05 20:50:57 +0000
committerWilliam Pitcock <nenolod@dereferenced.org>2019-02-05 20:50:57 +0000
commitd83dbd9070e8af0ec6c36c1bbd11c417510fa7e3 (patch)
tree60be0c9fbb73c98cd7697ea1c1c95f686ab4d3c1
parentd120aa63f0b2e688b292af5a9afe45ab45c8e10b (diff)
downloadpleroma-d83dbd9070e8af0ec6c36c1bbd11c417510fa7e3.tar.gz
rich media: parser: reject any data which cannot be explicitly encoded into JSON
-rw-r--r--lib/pleroma/web/rich_media/parser.ex18
1 files changed, 4 insertions, 14 deletions
diff --git a/lib/pleroma/web/rich_media/parser.ex b/lib/pleroma/web/rich_media/parser.ex
index 32dec9887..38f1cdeec 100644
--- a/lib/pleroma/web/rich_media/parser.ex
+++ b/lib/pleroma/web/rich_media/parser.ex
@@ -54,22 +54,12 @@ defmodule Pleroma.Web.RichMedia.Parser do
{:error, "Found metadata was invalid or incomplete: #{inspect(data)}"}
end
- defp string_is_valid_unicode(data) when is_binary(data) do
- data
- |> :unicode.characters_to_binary()
- |> clean_string()
- end
-
- defp string_is_valid_unicode(data), do: {:ok, data}
-
- defp clean_string({:error, _, _}), do: {:error, "Invalid data"}
- defp clean_string(data), do: {:ok, data}
-
defp clean_parsed_data(data) do
data
- |> Enum.reject(fn {_, val} ->
- case string_is_valid_unicode(val) do
- {:ok, _} -> false
+ |> Enum.reject(fn {key, val} ->
+ with {:ok, _} <- Jason.encode(%{key => val}) do
+ false
+ else
_ -> true
end
end)