diff options
author | William Pitcock <nenolod@dereferenced.org> | 2019-02-05 20:50:57 +0000 |
---|---|---|
committer | William Pitcock <nenolod@dereferenced.org> | 2019-02-05 20:50:57 +0000 |
commit | d83dbd9070e8af0ec6c36c1bbd11c417510fa7e3 (patch) | |
tree | 60be0c9fbb73c98cd7697ea1c1c95f686ab4d3c1 | |
parent | d120aa63f0b2e688b292af5a9afe45ab45c8e10b (diff) | |
download | pleroma-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.ex | 18 |
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) |