summaryrefslogtreecommitdiff
path: root/lib
diff options
context:
space:
mode:
authorlain <lain@soykaf.club>2020-04-22 19:26:32 +0000
committerlain <lain@soykaf.club>2020-04-22 19:26:32 +0000
commit850377a7b8d380088d8717d82b09a2976bbdd739 (patch)
tree9c883b3b38f2692b376dfa55190570bce2b3bbb5 /lib
parentaf27e4dffd0d7823f918f479d2a78f37077fa5a4 (diff)
parent1bcbdc7a9f5df35f42d1ab331bc4b6785e180284 (diff)
downloadpleroma-850377a7b8d380088d8717d82b09a2976bbdd739.tar.gz
pleroma-850377a7b8d380088d8717d82b09a2976bbdd739.zip
Merge branch 'bugfix/1629-fav-race-condition' into 'develop'
SideEffects: Run in transaction. Closes #1629 See merge request pleroma/pleroma!2417
Diffstat (limited to 'lib')
-rw-r--r--lib/pleroma/web/activity_pub/side_effects.ex13
1 files changed, 9 insertions, 4 deletions
diff --git a/lib/pleroma/web/activity_pub/side_effects.ex b/lib/pleroma/web/activity_pub/side_effects.ex
index 6a8f1af96..5981e7545 100644
--- a/lib/pleroma/web/activity_pub/side_effects.ex
+++ b/lib/pleroma/web/activity_pub/side_effects.ex
@@ -15,12 +15,17 @@ defmodule Pleroma.Web.ActivityPub.SideEffects do
# - Add like to object
# - Set up notification
def handle(%{data: %{"type" => "Like"}} = object, meta) do
- liked_object = Object.get_by_ap_id(object.data["object"])
- Utils.add_like_to_object(object, liked_object)
+ {:ok, result} =
+ Pleroma.Repo.transaction(fn ->
+ liked_object = Object.get_by_ap_id(object.data["object"])
+ Utils.add_like_to_object(object, liked_object)
- Notification.create_notifications(object)
+ Notification.create_notifications(object)
- {:ok, object, meta}
+ {:ok, object, meta}
+ end)
+
+ result
end
# Nothing to do