Merge branch 'features/mastoapi-multi-hashtag' into 'develop'
[akkoma] / lib / pleroma / web / rich_media / parser.ex
index 3746feaf688b275b8a70cc5bb15ac91a40191b58..947dc0c3c2fef989d334f431cc4c9f29c2c9275a 100644 (file)
@@ -1,11 +1,23 @@
 defmodule Pleroma.Web.RichMedia.Parser do
-  @parsers [Pleroma.Web.RichMedia.Parsers.OGP]
+  @parsers [
+    Pleroma.Web.RichMedia.Parsers.OGP,
+    Pleroma.Web.RichMedia.Parsers.TwitterCard,
+    Pleroma.Web.RichMedia.Parsers.OEmbed
+  ]
+
+  def parse(nil), do: {:error, "No URL provided"}
 
   if Mix.env() == :test do
     def parse(url), do: parse_url(url)
   else
-    def parse(url),
-      do: {:commit, Cachex.fetch!(:rich_media_cache, url, fn _ -> parse_url(url) end)}
+    def parse(url) do
+      with {:ok, data} <- Cachex.fetch(:rich_media_cache, url, fn _ -> parse_url(url) end) do
+        data
+      else
+        _e ->
+          {:error, "Parsing error"}
+      end
+    end
   end
 
   defp parse_url(url) do