Merge branch 'develop' into refactor/user-view
authorRoger Braun <roger@rogerbraun.net>
Tue, 20 Jun 2017 09:49:41 +0000 (11:49 +0200)
committerRoger Braun <roger@rogerbraun.net>
Tue, 20 Jun 2017 09:49:41 +0000 (11:49 +0200)
lib/pleroma/object.ex
lib/pleroma/web/twitter_api/twitter_api.ex

index 72991fa1f028a3610867edc5cd5f8eec6d79c54d..5b51d6be340170e649c55b7e8c8d06083c9464a2 100644 (file)
@@ -43,6 +43,6 @@ defmodule Pleroma.Object do
   end
 
   def context_mapping(context) do
-    %Object{data: %{"id" => context}}
+    Object.change(%Object{}, %{data: %{"id" => context}})
   end
 end
index e31a2cc7623b9ff2827fa6d220519fd2e291598c..b5b59eb4bea4415cf4797a2e66a4977875aa2b80 100644 (file)
@@ -282,10 +282,14 @@ defmodule Pleroma.Web.TwitterAPI.TwitterAPI do
   def context_to_conversation_id(context) do
     with %Object{id: id} <- Object.get_cached_by_ap_id(context) do
       id
-    else _e ->
-      changeset = Object.context_mapping(context)
-      {:ok, %{id: id}} = Repo.insert(changeset)
-      id
+      else _e ->
+        changeset = Object.context_mapping(context)
+        case Repo.insert(changeset) do
+          {:ok, %{id: id}} -> id
+          # This should be solved by an upsert, but it seems ecto
+          # has problems accessing the constraint inside the jsonb.
+          {:error, _} -> Object.get_cached_by_ap_id(context).id
+        end
     end
   end