forked from cybrespace/mastodon
		
	* Likely fix #2458, fix #2031 - handle out-of-order deletes for statuses If a delete arrives before the original status, cache that information for 6h, and if the original status arrives in that window, ignore it * Add test case
This commit is contained in:
		
							parent
							
								
									4fcc0d5ac9
								
							
						
					
					
						commit
						13c16b4e95
					
				
					 2 changed files with 60 additions and 1 deletions
				
			
		| 
						 | 
				
			
			@ -42,6 +42,11 @@ class ProcessFeedService < BaseService
 | 
			
		|||
    private
 | 
			
		||||
 | 
			
		||||
    def create_status
 | 
			
		||||
      if redis.exists("delete_upon_arrival:#{id}")
 | 
			
		||||
        Rails.logger.debug "Delete for status #{id} was queued, ignoring"
 | 
			
		||||
        return
 | 
			
		||||
      end
 | 
			
		||||
 | 
			
		||||
      Rails.logger.debug "Creating remote status #{id}"
 | 
			
		||||
      status, just_created = status_from_xml(@xml)
 | 
			
		||||
 | 
			
		||||
| 
						 | 
				
			
			@ -84,7 +89,13 @@ class ProcessFeedService < BaseService
 | 
			
		|||
    def delete_status
 | 
			
		||||
      Rails.logger.debug "Deleting remote status #{id}"
 | 
			
		||||
      status = Status.find_by(uri: id)
 | 
			
		||||
      RemoveStatusService.new.call(status) unless status.nil?
 | 
			
		||||
 | 
			
		||||
      if status.nil?
 | 
			
		||||
        redis.setex("delete_upon_arrival:#{id}", 6 * 3_600, id)
 | 
			
		||||
      else
 | 
			
		||||
        RemoveStatusService.new.call(status)
 | 
			
		||||
      end
 | 
			
		||||
 | 
			
		||||
      nil
 | 
			
		||||
    end
 | 
			
		||||
 | 
			
		||||
| 
						 | 
				
			
			@ -273,5 +284,9 @@ class ProcessFeedService < BaseService
 | 
			
		|||
    def account?(xml = @xml)
 | 
			
		||||
      !xml.at_xpath('./xmlns:author', xmlns: TagManager::XMLNS).nil?
 | 
			
		||||
    end
 | 
			
		||||
 | 
			
		||||
    def redis
 | 
			
		||||
      Redis.current
 | 
			
		||||
    end
 | 
			
		||||
  end
 | 
			
		||||
end
 | 
			
		||||
| 
						 | 
				
			
			
 | 
			
		|||
| 
						 | 
				
			
			@ -154,4 +154,48 @@ XML
 | 
			
		|||
    expect(created_statuses.first.reblog.account_id).to eq good_actor.id
 | 
			
		||||
    expect(created_statuses.first.reblog.text).to eq 'Overwatch rocks'
 | 
			
		||||
  end
 | 
			
		||||
 | 
			
		||||
  it 'ignores statuses with an out-of-order delete' do
 | 
			
		||||
    sender = Fabricate(:account, username: 'tracer', domain: 'overwatch.com')
 | 
			
		||||
 | 
			
		||||
    delete_body = <<XML
 | 
			
		||||
<?xml version="1.0"?>
 | 
			
		||||
<entry xmlns="http://www.w3.org/2005/Atom" xmlns:thr="http://purl.org/syndication/thread/1.0" xmlns:activity="http://activitystrea.ms/spec/1.0/" xmlns:poco="http://portablecontacts.net/spec/1.0" xmlns:media="http://purl.org/syndication/atommedia" xmlns:ostatus="http://ostatus.org/schema/1.0" xmlns:mastodon="http://mastodon.social/schema/1.0">
 | 
			
		||||
  <id>tag:overwatch.com,2017-04-27:objectId=4487555:objectType=Status</id>
 | 
			
		||||
  <published>2017-04-27T13:49:25Z</published>
 | 
			
		||||
  <updated>2017-04-27T13:49:25Z</updated>
 | 
			
		||||
  <activity:object-type>http://activitystrea.ms/schema/1.0/note</activity:object-type>
 | 
			
		||||
  <activity:verb>http://activitystrea.ms/schema/1.0/delete</activity:verb>
 | 
			
		||||
  <author>
 | 
			
		||||
    <id>https://overwatch.com/users/tracer</id>
 | 
			
		||||
    <activity:object-type>http://activitystrea.ms/schema/1.0/person</activity:object-type>
 | 
			
		||||
    <uri>https://overwatch.com/users/tracer</uri>
 | 
			
		||||
    <name>tracer</name>
 | 
			
		||||
  </author>
 | 
			
		||||
</entry>
 | 
			
		||||
XML
 | 
			
		||||
 | 
			
		||||
    status_body = <<XML
 | 
			
		||||
<?xml version="1.0"?>
 | 
			
		||||
<entry xmlns="http://www.w3.org/2005/Atom" xmlns:thr="http://purl.org/syndication/thread/1.0" xmlns:activity="http://activitystrea.ms/spec/1.0/" xmlns:poco="http://portablecontacts.net/spec/1.0" xmlns:media="http://purl.org/syndication/atommedia" xmlns:ostatus="http://ostatus.org/schema/1.0" xmlns:mastodon="http://mastodon.social/schema/1.0">
 | 
			
		||||
  <id>tag:overwatch.com,2017-04-27:objectId=4487555:objectType=Status</id>
 | 
			
		||||
  <published>2017-04-27T13:49:25Z</published>
 | 
			
		||||
  <updated>2017-04-27T13:49:25Z</updated>
 | 
			
		||||
  <activity:object-type>http://activitystrea.ms/schema/1.0/note</activity:object-type>
 | 
			
		||||
  <activity:verb>http://activitystrea.ms/schema/1.0/post</activity:verb>
 | 
			
		||||
  <author>
 | 
			
		||||
    <id>https://overwatch.com/users/tracer</id>
 | 
			
		||||
    <activity:object-type>http://activitystrea.ms/schema/1.0/person</activity:object-type>
 | 
			
		||||
    <uri>https://overwatch.com/users/tracer</uri>
 | 
			
		||||
    <name>tracer</name>
 | 
			
		||||
  </author>
 | 
			
		||||
  <content type="html">Overwatch rocks</content>
 | 
			
		||||
</entry>
 | 
			
		||||
XML
 | 
			
		||||
 | 
			
		||||
    subject.call(delete_body, sender)
 | 
			
		||||
    created_statuses = subject.call(status_body, sender)
 | 
			
		||||
 | 
			
		||||
    expect(created_statuses).to be_empty
 | 
			
		||||
  end
 | 
			
		||||
end
 | 
			
		||||
| 
						 | 
				
			
			
 | 
			
		|||
		Loading…
	
	Add table
		
		Reference in a new issue