aboutsummaryrefslogtreecommitdiff
path: root/lib
diff options
context:
space:
mode:
authorlambda <pleromagit@rogerbraun.net>2018-12-14 08:26:08 +0000
committerlambda <pleromagit@rogerbraun.net>2018-12-14 08:26:08 +0000
commit262cc6d44b2e77807373cfaff730c938112c5891 (patch)
tree1743aecf9800572403ddb4a9895f15d604a6a7e3 /lib
parent82dbd2d64fcd95361e5ebe510c8f5ed46bcaad1e (diff)
parent1ca080c8628d261cdb95145331aa36e631e90a3f (diff)
downloadpleroma-262cc6d44b2e77807373cfaff730c938112c5891.tar.gz
Merge branch 'fix/double-rt-or-fav' into 'develop'
Prevent accidental double RTs or favorites See merge request pleroma/pleroma!542
Diffstat (limited to 'lib')
-rw-r--r--lib/pleroma/web/common_api/common_api.ex7
1 files changed, 5 insertions, 2 deletions
diff --git a/lib/pleroma/web/common_api/common_api.ex b/lib/pleroma/web/common_api/common_api.ex
index e3385310f..f01d36370 100644
--- a/lib/pleroma/web/common_api/common_api.ex
+++ b/lib/pleroma/web/common_api/common_api.ex
@@ -1,6 +1,7 @@
defmodule Pleroma.Web.CommonAPI do
alias Pleroma.{User, Repo, Activity, Object}
alias Pleroma.Web.ActivityPub.ActivityPub
+ alias Pleroma.Web.ActivityPub.Utils
alias Pleroma.Formatter
import Pleroma.Web.CommonAPI.Utils
@@ -16,7 +17,8 @@ defmodule Pleroma.Web.CommonAPI do
def repeat(id_or_ap_id, user) do
with %Activity{} = activity <- get_by_id_or_ap_id(id_or_ap_id),
- object <- Object.normalize(activity.data["object"]["id"]) do
+ object <- Object.normalize(activity.data["object"]["id"]),
+ nil <- Utils.get_existing_announce(user.ap_id, object) do
ActivityPub.announce(user, object)
else
_ ->
@@ -36,7 +38,8 @@ defmodule Pleroma.Web.CommonAPI do
def favorite(id_or_ap_id, user) do
with %Activity{} = activity <- get_by_id_or_ap_id(id_or_ap_id),
- object <- Object.normalize(activity.data["object"]["id"]) do
+ object <- Object.normalize(activity.data["object"]["id"]),
+ nil <- Utils.get_existing_like(user.ap_id, object) do
ActivityPub.like(user, object)
else
_ ->