Automatically block outgoing notifications from silenced accounts to users
who don't follow them
This commit is contained in:
		@@ -85,6 +85,7 @@ class FeedManager
 | 
				
			|||||||
    should_filter   = receiver.id == status.account_id                                      # Filter if I'm mentioning myself
 | 
					    should_filter   = receiver.id == status.account_id                                      # Filter if I'm mentioning myself
 | 
				
			||||||
    should_filter ||= receiver.blocking?(status.account)                                    # or it's from someone I blocked
 | 
					    should_filter ||= receiver.blocking?(status.account)                                    # or it's from someone I blocked
 | 
				
			||||||
    should_filter ||= receiver.blocking?(status.mentions.includes(:account).map(&:account)) # or if it mentions someone I blocked
 | 
					    should_filter ||= receiver.blocking?(status.mentions.includes(:account).map(&:account)) # or if it mentions someone I blocked
 | 
				
			||||||
 | 
					    should_filter ||= (status.account.silenced? && !receiver.following?(status.account))    # of if the account is silenced and I'm not following them
 | 
				
			||||||
 | 
					
 | 
				
			||||||
    if status.reply? && !status.thread.account.nil?                                         # or it's a reply
 | 
					    if status.reply? && !status.thread.account.nil?                                         # or it's a reply
 | 
				
			||||||
      should_filter ||= receiver.blocking?(status.thread.account)                           # to a user I blocked
 | 
					      should_filter ||= receiver.blocking?(status.thread.account)                           # to a user I blocked
 | 
				
			||||||
 
 | 
				
			|||||||
@@ -36,6 +36,7 @@ class NotifyService < BaseService
 | 
				
			|||||||
    blocked   = false
 | 
					    blocked   = false
 | 
				
			||||||
    blocked ||= @recipient.id == @notification.from_account.id
 | 
					    blocked ||= @recipient.id == @notification.from_account.id
 | 
				
			||||||
    blocked ||= @recipient.blocking?(@notification.from_account)
 | 
					    blocked ||= @recipient.blocking?(@notification.from_account)
 | 
				
			||||||
 | 
					    blocked ||= (@notification.from_account.silenced? && !@recipient.following?(@notification.from_account))
 | 
				
			||||||
    blocked ||= (@recipient.user.settings(:interactions).must_be_follower  && !@notification.from_account.following?(@recipient))
 | 
					    blocked ||= (@recipient.user.settings(:interactions).must_be_follower  && !@notification.from_account.following?(@recipient))
 | 
				
			||||||
    blocked ||= (@recipient.user.settings(:interactions).must_be_following && !@recipient.following?(@notification.from_account))
 | 
					    blocked ||= (@recipient.user.settings(:interactions).must_be_following && !@recipient.following?(@notification.from_account))
 | 
				
			||||||
    blocked ||= send("blocked_#{@notification.type}?")
 | 
					    blocked ||= send("blocked_#{@notification.type}?")
 | 
				
			||||||
 
 | 
				
			|||||||
		Reference in New Issue
	
	Block a user