forked from mirrors/catstodon
Do not rely on activity arriving exactly once after delete arrived (#4754)
This commit is contained in:
parent
a75aa62f5b
commit
c2980d5b17
2 changed files with 7 additions and 14 deletions
|
@ -97,14 +97,7 @@ class ActivityPub::Activity
|
|||
end
|
||||
|
||||
def delete_arrived_first?(uri)
|
||||
key = "delete_upon_arrival:#{@account.id}:#{uri}"
|
||||
|
||||
if redis.exists(key)
|
||||
redis.del(key)
|
||||
true
|
||||
else
|
||||
false
|
||||
end
|
||||
redis.exists("delete_upon_arrival:#{@account.id}:#{uri}")
|
||||
end
|
||||
|
||||
def delete_later!(uri)
|
||||
|
|
|
@ -5,12 +5,12 @@ class ActivityPub::Activity::Delete < ActivityPub::Activity
|
|||
status = Status.find_by(uri: object_uri, account: @account)
|
||||
status ||= Status.find_by(uri: @object['_:atomUri'], account: @account) if @object.is_a?(Hash) && @object['_:atomUri'].present?
|
||||
|
||||
if status.nil?
|
||||
delete_later!(object_uri)
|
||||
else
|
||||
forward_for_reblogs(status)
|
||||
delete_now!(status)
|
||||
end
|
||||
delete_later!(object_uri)
|
||||
|
||||
return if status.nil?
|
||||
|
||||
forward_for_reblogs(status)
|
||||
delete_now!(status)
|
||||
end
|
||||
|
||||
private
|
||||
|
|
Loading…
Reference in a new issue