Merge pull request #950 from ThibG/glitch-soc/merge-upstream
Merge upstream changes
This commit is contained in:
		
						commit
						3cef04610c
					
				
							
								
								
									
										13
									
								
								Vagrantfile
									
									
									
									
										vendored
									
									
								
							
							
						
						
									
										13
									
								
								Vagrantfile
									
									
									
									
										vendored
									
									
								
							@ -44,7 +44,18 @@ sudo apt-get install \
 | 
				
			|||||||
 | 
					
 | 
				
			||||||
# Install rvm
 | 
					# Install rvm
 | 
				
			||||||
read RUBY_VERSION < .ruby-version
 | 
					read RUBY_VERSION < .ruby-version
 | 
				
			||||||
gpg --keyserver hkp://keys.gnupg.net --recv-keys 409B6B1796C275462A1703113804BB82D39DC0E3 7D2BAF1CF37B13E2069D6956105BD0E739499BDB
 | 
					
 | 
				
			||||||
 | 
					gpg_command="gpg --keyserver hkp://keys.gnupg.net --recv-keys 409B6B1796C275462A1703113804BB82D39DC0E3 7D2BAF1CF37B13E2069D6956105BD0E739499BDB"
 | 
				
			||||||
 | 
					$($gpg_command)
 | 
				
			||||||
 | 
					if [ $? -ne 0 ];then
 | 
				
			||||||
 | 
					  echo "GPG command failed, This prevented RVM from installing."
 | 
				
			||||||
 | 
					  echo "Retrying once..." && $($gpg_command)
 | 
				
			||||||
 | 
					  if [ $? -ne 0 ];then
 | 
				
			||||||
 | 
					    echo "GPG failed for the second time, please ensure network connectivity."
 | 
				
			||||||
 | 
					    echo "Exiting..." && exit 1
 | 
				
			||||||
 | 
					  fi
 | 
				
			||||||
 | 
					fi
 | 
				
			||||||
 | 
					
 | 
				
			||||||
curl -sSL https://raw.githubusercontent.com/rvm/rvm/stable/binscripts/rvm-installer | bash -s stable --ruby=$RUBY_VERSION
 | 
					curl -sSL https://raw.githubusercontent.com/rvm/rvm/stable/binscripts/rvm-installer | bash -s stable --ruby=$RUBY_VERSION
 | 
				
			||||||
source /home/vagrant/.rvm/scripts/rvm
 | 
					source /home/vagrant/.rvm/scripts/rvm
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
				
			|||||||
@ -41,6 +41,7 @@ class SuspendAccountService < BaseService
 | 
				
			|||||||
    @account = account
 | 
					    @account = account
 | 
				
			||||||
    @options = options
 | 
					    @options = options
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					    reject_follows!
 | 
				
			||||||
    purge_user!
 | 
					    purge_user!
 | 
				
			||||||
    purge_profile!
 | 
					    purge_profile!
 | 
				
			||||||
    purge_content!
 | 
					    purge_content!
 | 
				
			||||||
@ -48,6 +49,14 @@ class SuspendAccountService < BaseService
 | 
				
			|||||||
 | 
					
 | 
				
			||||||
  private
 | 
					  private
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					  def reject_follows!
 | 
				
			||||||
 | 
					    return if @account.local? || !@account.activitypub?
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					    ActivityPub::DeliveryWorker.push_bulk(Follow.where(account: @account)) do |follow|
 | 
				
			||||||
 | 
					      [build_reject_json(follow), follow.target_account_id, follow.account.inbox_url]
 | 
				
			||||||
 | 
					    end
 | 
				
			||||||
 | 
					  end
 | 
				
			||||||
 | 
					
 | 
				
			||||||
  def purge_user!
 | 
					  def purge_user!
 | 
				
			||||||
    return if !@account.local? || @account.user.nil?
 | 
					    return if !@account.local? || @account.user.nil?
 | 
				
			||||||
 | 
					
 | 
				
			||||||
@ -120,6 +129,14 @@ class SuspendAccountService < BaseService
 | 
				
			|||||||
    @delete_actor_json = Oj.dump(ActivityPub::LinkedDataSignature.new(payload).sign!(@account))
 | 
					    @delete_actor_json = Oj.dump(ActivityPub::LinkedDataSignature.new(payload).sign!(@account))
 | 
				
			||||||
  end
 | 
					  end
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					  def build_reject_json(follow)
 | 
				
			||||||
 | 
					    ActiveModelSerializers::SerializableResource.new(
 | 
				
			||||||
 | 
					      follow,
 | 
				
			||||||
 | 
					      serializer: ActivityPub::RejectFollowSerializer,
 | 
				
			||||||
 | 
					      adapter: ActivityPub::Adapter
 | 
				
			||||||
 | 
					    ).to_json
 | 
				
			||||||
 | 
					  end
 | 
				
			||||||
 | 
					
 | 
				
			||||||
  def delivery_inboxes
 | 
					  def delivery_inboxes
 | 
				
			||||||
    @delivery_inboxes ||= @account.followers.inboxes + Relay.enabled.pluck(:inbox_url)
 | 
					    @delivery_inboxes ||= @account.followers.inboxes + Relay.enabled.pluck(:inbox_url)
 | 
				
			||||||
  end
 | 
					  end
 | 
				
			||||||
 | 
				
			|||||||
@ -1,7 +1,7 @@
 | 
				
			|||||||
- if @instance_presenter.open_registrations
 | 
					- if @instance_presenter.open_registrations
 | 
				
			||||||
  = render 'registration'
 | 
					  = render 'registration'
 | 
				
			||||||
- else
 | 
					- else
 | 
				
			||||||
  = link_to t('auth.register_elsewhere'), 'https://joinmastodon.org', class: 'button button-primary'
 | 
					  = link_to t('auth.register_elsewhere'), 'https://joinmastodon.org/#getting-started', class: 'button button-primary'
 | 
				
			||||||
 | 
					
 | 
				
			||||||
  .closed-registrations-message
 | 
					  .closed-registrations-message
 | 
				
			||||||
    - if @instance_presenter.closed_registrations_message.blank?
 | 
					    - if @instance_presenter.closed_registrations_message.blank?
 | 
				
			||||||
 | 
				
			|||||||
@ -11,6 +11,6 @@
 | 
				
			|||||||
        = link_to t('auth.login'), new_user_session_path, class: 'webapp-btn'
 | 
					        = link_to t('auth.login'), new_user_session_path, class: 'webapp-btn'
 | 
				
			||||||
    %li= link_to t('about.about_this'), about_more_path
 | 
					    %li= link_to t('about.about_this'), about_more_path
 | 
				
			||||||
    %li
 | 
					    %li
 | 
				
			||||||
      = link_to 'https://joinmastodon.org/' do
 | 
					      = link_to 'https://joinmastodon.org/#getting-started' do
 | 
				
			||||||
        = "#{t('about.other_instances')}"
 | 
					        = "#{t('about.other_instances')}"
 | 
				
			||||||
        %i.fa.fa-external-link{ style: 'padding-left: 5px;' }
 | 
					        %i.fa.fa-external-link{ style: 'padding-left: 5px;' }
 | 
				
			||||||
 | 
				
			|||||||
@ -1,7 +1,7 @@
 | 
				
			|||||||
require 'rails_helper'
 | 
					require 'rails_helper'
 | 
				
			||||||
 | 
					
 | 
				
			||||||
RSpec.describe SuspendAccountService, type: :service do
 | 
					RSpec.describe SuspendAccountService, type: :service do
 | 
				
			||||||
  describe '#call' do
 | 
					  describe '#call on local account' do
 | 
				
			||||||
    before do
 | 
					    before do
 | 
				
			||||||
      stub_request(:post, "https://alice.com/inbox").to_return(status: 201)
 | 
					      stub_request(:post, "https://alice.com/inbox").to_return(status: 201)
 | 
				
			||||||
      stub_request(:post, "https://bob.com/inbox").to_return(status: 201)
 | 
					      stub_request(:post, "https://bob.com/inbox").to_return(status: 201)
 | 
				
			||||||
@ -43,4 +43,46 @@ RSpec.describe SuspendAccountService, type: :service do
 | 
				
			|||||||
      expect(a_request(:post, "https://bob.com/inbox")).to have_been_made.once
 | 
					      expect(a_request(:post, "https://bob.com/inbox")).to have_been_made.once
 | 
				
			||||||
    end
 | 
					    end
 | 
				
			||||||
  end
 | 
					  end
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					  describe '#call on remote account' do
 | 
				
			||||||
 | 
					    before do
 | 
				
			||||||
 | 
					      stub_request(:post, "https://alice.com/inbox").to_return(status: 201)
 | 
				
			||||||
 | 
					      stub_request(:post, "https://bob.com/inbox").to_return(status: 201)
 | 
				
			||||||
 | 
					    end
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					    subject do
 | 
				
			||||||
 | 
					      -> { described_class.new.call(remote_bob) }
 | 
				
			||||||
 | 
					    end
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					    let!(:account) { Fabricate(:account) }
 | 
				
			||||||
 | 
					    let!(:remote_alice) { Fabricate(:account, inbox_url: 'https://alice.com/inbox', protocol: :activitypub) }
 | 
				
			||||||
 | 
					    let!(:remote_bob) { Fabricate(:account, inbox_url: 'https://bob.com/inbox', protocol: :activitypub) }
 | 
				
			||||||
 | 
					    let!(:status) { Fabricate(:status, account: remote_bob) }
 | 
				
			||||||
 | 
					    let!(:media_attachment) { Fabricate(:media_attachment, account: remote_bob) }
 | 
				
			||||||
 | 
					    let!(:notification) { Fabricate(:notification, account: remote_bob) }
 | 
				
			||||||
 | 
					    let!(:favourite) { Fabricate(:favourite, account: remote_bob) }
 | 
				
			||||||
 | 
					    let!(:active_relationship) { Fabricate(:follow, account: remote_bob, target_account: account) }
 | 
				
			||||||
 | 
					    let!(:passive_relationship) { Fabricate(:follow, target_account: remote_bob) }
 | 
				
			||||||
 | 
					    let!(:subscription) { Fabricate(:subscription, account: remote_bob) }
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					    it 'deletes associated records' do
 | 
				
			||||||
 | 
					      is_expected.to change {
 | 
				
			||||||
 | 
					        [
 | 
				
			||||||
 | 
					          remote_bob.statuses,
 | 
				
			||||||
 | 
					          remote_bob.media_attachments,
 | 
				
			||||||
 | 
					          remote_bob.stream_entries,
 | 
				
			||||||
 | 
					          remote_bob.notifications,
 | 
				
			||||||
 | 
					          remote_bob.favourites,
 | 
				
			||||||
 | 
					          remote_bob.active_relationships,
 | 
				
			||||||
 | 
					          remote_bob.passive_relationships,
 | 
				
			||||||
 | 
					          remote_bob.subscriptions
 | 
				
			||||||
 | 
					        ].map(&:count)
 | 
				
			||||||
 | 
					      }.from([1, 1, 1, 1, 1, 1, 1, 1]).to([0, 0, 0, 0, 0, 0, 0, 0])
 | 
				
			||||||
 | 
					    end
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					    it 'sends a reject follow to follwer inboxes' do
 | 
				
			||||||
 | 
					      subject.call
 | 
				
			||||||
 | 
					      expect(a_request(:post, remote_bob.inbox_url)).to have_been_made.once
 | 
				
			||||||
 | 
					    end
 | 
				
			||||||
 | 
					  end
 | 
				
			||||||
end
 | 
					end
 | 
				
			||||||
 | 
				
			|||||||
@ -24,7 +24,7 @@ const dbUrlToConfig = (dbUrl) => {
 | 
				
			|||||||
    return {};
 | 
					    return {};
 | 
				
			||||||
  }
 | 
					  }
 | 
				
			||||||
 | 
					
 | 
				
			||||||
  const params = url.parse(dbUrl);
 | 
					  const params = url.parse(dbUrl, true);
 | 
				
			||||||
  const config = {};
 | 
					  const config = {};
 | 
				
			||||||
 | 
					
 | 
				
			||||||
  if (params.auth) {
 | 
					  if (params.auth) {
 | 
				
			||||||
@ -45,8 +45,8 @@ const dbUrlToConfig = (dbUrl) => {
 | 
				
			|||||||
 | 
					
 | 
				
			||||||
  const ssl = params.query && params.query.ssl;
 | 
					  const ssl = params.query && params.query.ssl;
 | 
				
			||||||
 | 
					
 | 
				
			||||||
  if (ssl) {
 | 
					  if (ssl && ssl === 'true' || ssl === '1') {
 | 
				
			||||||
    config.ssl = ssl === 'true' || ssl === '1';
 | 
					    config.ssl = true;
 | 
				
			||||||
  }
 | 
					  }
 | 
				
			||||||
 | 
					
 | 
				
			||||||
  return config;
 | 
					  return config;
 | 
				
			||||||
@ -89,9 +89,7 @@ const startWorker = (workerId) => {
 | 
				
			|||||||
      host:     process.env.DB_HOST || pg.defaults.host,
 | 
					      host:     process.env.DB_HOST || pg.defaults.host,
 | 
				
			||||||
      port:     process.env.DB_PORT || pg.defaults.port,
 | 
					      port:     process.env.DB_PORT || pg.defaults.port,
 | 
				
			||||||
      max:      10,
 | 
					      max:      10,
 | 
				
			||||||
      ssl: {
 | 
					      ssl:      !!process.env.DB_SSLMODE && process.env.DB_SSLMODE !== 'disable' ? true : undefined,
 | 
				
			||||||
        sslmode: process.env.DB_SSLMODE || 'prefer',
 | 
					 | 
				
			||||||
      },
 | 
					 | 
				
			||||||
    },
 | 
					    },
 | 
				
			||||||
 | 
					
 | 
				
			||||||
    production: {
 | 
					    production: {
 | 
				
			||||||
@ -101,9 +99,7 @@ const startWorker = (workerId) => {
 | 
				
			|||||||
      host:     process.env.DB_HOST || 'localhost',
 | 
					      host:     process.env.DB_HOST || 'localhost',
 | 
				
			||||||
      port:     process.env.DB_PORT || 5432,
 | 
					      port:     process.env.DB_PORT || 5432,
 | 
				
			||||||
      max:      10,
 | 
					      max:      10,
 | 
				
			||||||
      ssl: {
 | 
					      ssl:      !!process.env.DB_SSLMODE && process.env.DB_SSLMODE !== 'disable' ? true : undefined,
 | 
				
			||||||
        sslmode: process.env.DB_SSLMODE || 'prefer',
 | 
					 | 
				
			||||||
      },
 | 
					 | 
				
			||||||
    },
 | 
					    },
 | 
				
			||||||
  };
 | 
					  };
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
				
			|||||||
		Loading…
	
	
			
			x
			
			
		
	
		Reference in New Issue
	
	Block a user