Add configuration to disable private status federation over PuSH (#4582)
This commit is contained in:
		
							parent
							
								
									b01a19fe39
								
							
						
					
					
						commit
						cf615abbf9
					
				
					 4 changed files with 55 additions and 16 deletions
				
			
		| 
						 | 
				
			
			@ -39,7 +39,7 @@ class ProcessMentionsService < BaseService
 | 
			
		|||
 | 
			
		||||
    if mentioned_account.local?
 | 
			
		||||
      NotifyService.new.call(mentioned_account, mention)
 | 
			
		||||
    elsif mentioned_account.ostatus?
 | 
			
		||||
    elsif mentioned_account.ostatus? && (Rails.configuration.x.use_ostatus_privacy || !status.stream_entry.hidden?)
 | 
			
		||||
      NotificationWorker.perform_async(stream_entry_to_xml(status.stream_entry), status.account_id, mentioned_account.id)
 | 
			
		||||
    elsif mentioned_account.activitypub?
 | 
			
		||||
      ActivityPub::DeliveryWorker.perform_async(build_json(mention.status), mention.status.account_id, mentioned_account.inbox_url)
 | 
			
		||||
| 
						 | 
				
			
			
 | 
			
		|||
| 
						 | 
				
			
			@ -14,7 +14,7 @@ class Pubsubhubbub::DistributionWorker
 | 
			
		|||
    @subscriptions = active_subscriptions.to_a
 | 
			
		||||
 | 
			
		||||
    distribute_public!(stream_entries.reject(&:hidden?))
 | 
			
		||||
    distribute_hidden!(stream_entries.select(&:hidden?))
 | 
			
		||||
    distribute_hidden!(stream_entries.select(&:hidden?)) if Rails.configuration.x.use_ostatus_privacy
 | 
			
		||||
  end
 | 
			
		||||
 | 
			
		||||
  private
 | 
			
		||||
| 
						 | 
				
			
			
 | 
			
		|||
| 
						 | 
				
			
			@ -5,7 +5,7 @@ host     = ENV.fetch('LOCAL_DOMAIN') { "localhost:#{port}" }
 | 
			
		|||
web_host = ENV.fetch('WEB_DOMAIN') { host }
 | 
			
		||||
https    = ENV['LOCAL_HTTPS'] == 'true'
 | 
			
		||||
 | 
			
		||||
alternate_domains = ENV.fetch('ALTERNATE_DOMAINS') { "" }
 | 
			
		||||
alternate_domains = ENV.fetch('ALTERNATE_DOMAINS') { '' }
 | 
			
		||||
 | 
			
		||||
Rails.application.configure do
 | 
			
		||||
  config.x.local_domain = host
 | 
			
		||||
| 
						 | 
				
			
			@ -17,6 +17,7 @@ Rails.application.configure do
 | 
			
		|||
 | 
			
		||||
  config.action_mailer.default_url_options = { host: web_host, protocol: https ? 'https://' : 'http://', trailing_slash: false }
 | 
			
		||||
  config.x.streaming_api_base_url          = 'ws://localhost:4000'
 | 
			
		||||
  config.x.use_ostatus_privacy             = true
 | 
			
		||||
 | 
			
		||||
  if Rails.env.production?
 | 
			
		||||
    config.x.streaming_api_base_url = ENV.fetch('STREAMING_API_BASE_URL') { "ws#{https ? 's' : ''}://#{web_host}" }
 | 
			
		||||
| 
						 | 
				
			
			
 | 
			
		|||
| 
						 | 
				
			
			@ -22,24 +22,62 @@ describe Pubsubhubbub::DistributionWorker do
 | 
			
		|||
    end
 | 
			
		||||
  end
 | 
			
		||||
 | 
			
		||||
  describe 'with private status' do
 | 
			
		||||
    let(:status) { Fabricate(:status, account: alice, text: 'Hello', visibility: :private) }
 | 
			
		||||
  context 'when OStatus privacy is used' do
 | 
			
		||||
    around do |example|
 | 
			
		||||
      before_val = Rails.configuration.x.use_ostatus_privacy
 | 
			
		||||
      Rails.configuration.x.use_ostatus_privacy = true
 | 
			
		||||
      example.run
 | 
			
		||||
      Rails.configuration.x.use_ostatus_privacy = before_val
 | 
			
		||||
    end
 | 
			
		||||
 | 
			
		||||
    it 'delivers payload only to subscriptions with followers' do
 | 
			
		||||
      allow(Pubsubhubbub::DeliveryWorker).to receive(:push_bulk)
 | 
			
		||||
      subject.perform(status.stream_entry.id)
 | 
			
		||||
      expect(Pubsubhubbub::DeliveryWorker).to have_received(:push_bulk).with([subscription_with_follower])
 | 
			
		||||
      expect(Pubsubhubbub::DeliveryWorker).to_not have_received(:push_bulk).with([anonymous_subscription])
 | 
			
		||||
    describe 'with private status' do
 | 
			
		||||
      let(:status) { Fabricate(:status, account: alice, text: 'Hello', visibility: :private) }
 | 
			
		||||
 | 
			
		||||
      it 'delivers payload only to subscriptions with followers' do
 | 
			
		||||
        allow(Pubsubhubbub::DeliveryWorker).to receive(:push_bulk)
 | 
			
		||||
        subject.perform(status.stream_entry.id)
 | 
			
		||||
        expect(Pubsubhubbub::DeliveryWorker).to have_received(:push_bulk).with([subscription_with_follower])
 | 
			
		||||
        expect(Pubsubhubbub::DeliveryWorker).to_not have_received(:push_bulk).with([anonymous_subscription])
 | 
			
		||||
      end
 | 
			
		||||
    end
 | 
			
		||||
 | 
			
		||||
    describe 'with direct status' do
 | 
			
		||||
      let(:status) { Fabricate(:status, account: alice, text: 'Hello', visibility: :direct) }
 | 
			
		||||
 | 
			
		||||
      it 'does not deliver payload' do
 | 
			
		||||
        allow(Pubsubhubbub::DeliveryWorker).to receive(:push_bulk)
 | 
			
		||||
        subject.perform(status.stream_entry.id)
 | 
			
		||||
        expect(Pubsubhubbub::DeliveryWorker).to_not have_received(:push_bulk)
 | 
			
		||||
      end
 | 
			
		||||
    end
 | 
			
		||||
  end
 | 
			
		||||
 | 
			
		||||
  describe 'with direct status' do
 | 
			
		||||
    let(:status) { Fabricate(:status, account: alice, text: 'Hello', visibility: :direct) }
 | 
			
		||||
  context 'when OStatus privacy is not used' do
 | 
			
		||||
    around do |example|
 | 
			
		||||
      before_val = Rails.configuration.x.use_ostatus_privacy
 | 
			
		||||
      Rails.configuration.x.use_ostatus_privacy = false
 | 
			
		||||
      example.run
 | 
			
		||||
      Rails.configuration.x.use_ostatus_privacy = before_val
 | 
			
		||||
    end
 | 
			
		||||
 | 
			
		||||
    it 'does not deliver payload' do
 | 
			
		||||
      allow(Pubsubhubbub::DeliveryWorker).to receive(:push_bulk)
 | 
			
		||||
      subject.perform(status.stream_entry.id)
 | 
			
		||||
      expect(Pubsubhubbub::DeliveryWorker).to_not have_received(:push_bulk)
 | 
			
		||||
    describe 'with private status' do
 | 
			
		||||
      let(:status) { Fabricate(:status, account: alice, text: 'Hello', visibility: :private) }
 | 
			
		||||
 | 
			
		||||
      it 'does not deliver anything' do
 | 
			
		||||
        allow(Pubsubhubbub::DeliveryWorker).to receive(:push_bulk)
 | 
			
		||||
        subject.perform(status.stream_entry.id)
 | 
			
		||||
        expect(Pubsubhubbub::DeliveryWorker).to_not have_received(:push_bulk)
 | 
			
		||||
      end
 | 
			
		||||
    end
 | 
			
		||||
 | 
			
		||||
    describe 'with direct status' do
 | 
			
		||||
      let(:status) { Fabricate(:status, account: alice, text: 'Hello', visibility: :direct) }
 | 
			
		||||
 | 
			
		||||
      it 'does not deliver payload' do
 | 
			
		||||
        allow(Pubsubhubbub::DeliveryWorker).to receive(:push_bulk)
 | 
			
		||||
        subject.perform(status.stream_entry.id)
 | 
			
		||||
        expect(Pubsubhubbub::DeliveryWorker).to_not have_received(:push_bulk)
 | 
			
		||||
      end
 | 
			
		||||
    end
 | 
			
		||||
  end
 | 
			
		||||
end
 | 
			
		||||
| 
						 | 
				
			
			
 | 
			
		|||
		Reference in a new issue