diff options
| author | lain <lain@soykaf.club> | 2020-04-22 19:26:32 +0000 |
|---|---|---|
| committer | lain <lain@soykaf.club> | 2020-04-22 19:26:32 +0000 |
| commit | 850377a7b8d380088d8717d82b09a2976bbdd739 (patch) | |
| tree | 9c883b3b38f2692b376dfa55190570bce2b3bbb5 /lib | |
| parent | af27e4dffd0d7823f918f479d2a78f37077fa5a4 (diff) | |
| parent | 1bcbdc7a9f5df35f42d1ab331bc4b6785e180284 (diff) | |
| download | pleroma-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.ex | 13 |
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 |
