forked from cybrespace/mastodon
		
	Fix error when following locked accounts (#4896)
This commit is contained in:
		
							parent
							
								
									a6a206ef85
								
							
						
					
					
						commit
						0ef9d45d05
					
				
					 2 changed files with 37 additions and 21 deletions
				
			
		| 
						 | 
				
			
			@ -15,16 +15,9 @@ class Api::V1::AccountsController < Api::BaseController
 | 
			
		|||
  def follow
 | 
			
		||||
    FollowService.new.call(current_user.account, @account.acct)
 | 
			
		||||
 | 
			
		||||
    unless @account.locked?
 | 
			
		||||
      relationships = AccountRelationshipsPresenter.new(
 | 
			
		||||
        [@account.id],
 | 
			
		||||
        current_user.account_id,
 | 
			
		||||
        following_map: { @account.id => true },
 | 
			
		||||
        requested_map: { @account.id => false }
 | 
			
		||||
      )
 | 
			
		||||
    end
 | 
			
		||||
    options = @account.locked? ? {} : { following_map: { @account.id => true }, requested_map: { @account.id => false } }
 | 
			
		||||
 | 
			
		||||
    render json: @account, serializer: REST::RelationshipSerializer, relationships: relationships
 | 
			
		||||
    render json: @account, serializer: REST::RelationshipSerializer, relationships: relationships(options)
 | 
			
		||||
  end
 | 
			
		||||
 | 
			
		||||
  def block
 | 
			
		||||
| 
						 | 
				
			
			@ -58,7 +51,7 @@ class Api::V1::AccountsController < Api::BaseController
 | 
			
		|||
    @account = Account.find(params[:id])
 | 
			
		||||
  end
 | 
			
		||||
 | 
			
		||||
  def relationships
 | 
			
		||||
    AccountRelationshipsPresenter.new([@account.id], current_user.account_id)
 | 
			
		||||
  def relationships(options = {})
 | 
			
		||||
    AccountRelationshipsPresenter.new([@account.id], current_user.account_id, options)
 | 
			
		||||
  end
 | 
			
		||||
end
 | 
			
		||||
| 
						 | 
				
			
			
 | 
			
		|||
| 
						 | 
				
			
			@ -18,12 +18,15 @@ RSpec.describe Api::V1::AccountsController, type: :controller do
 | 
			
		|||
  end
 | 
			
		||||
 | 
			
		||||
  describe 'POST #follow' do
 | 
			
		||||
    let(:other_account) { Fabricate(:user, email: 'bob@example.com', account: Fabricate(:account, username: 'bob')).account }
 | 
			
		||||
    let(:other_account) { Fabricate(:user, email: 'bob@example.com', account: Fabricate(:account, username: 'bob', locked: locked)).account }
 | 
			
		||||
 | 
			
		||||
    before do
 | 
			
		||||
      post :follow, params: { id: other_account.id }
 | 
			
		||||
    end
 | 
			
		||||
 | 
			
		||||
    context 'with unlocked account' do
 | 
			
		||||
      let(:locked) { false }
 | 
			
		||||
 | 
			
		||||
      it 'returns http success' do
 | 
			
		||||
        expect(response).to have_http_status(:success)
 | 
			
		||||
      end
 | 
			
		||||
| 
						 | 
				
			
			@ -40,6 +43,26 @@ RSpec.describe Api::V1::AccountsController, type: :controller do
 | 
			
		|||
      end
 | 
			
		||||
    end
 | 
			
		||||
 | 
			
		||||
    context 'with locked account' do
 | 
			
		||||
      let(:locked) { true }
 | 
			
		||||
 | 
			
		||||
      it 'returns http success' do
 | 
			
		||||
        expect(response).to have_http_status(:success)
 | 
			
		||||
      end
 | 
			
		||||
 | 
			
		||||
      it 'returns JSON with following=false and requested=true' do
 | 
			
		||||
        json = body_as_json
 | 
			
		||||
 | 
			
		||||
        expect(json[:following]).to be false
 | 
			
		||||
        expect(json[:requested]).to be true
 | 
			
		||||
      end
 | 
			
		||||
 | 
			
		||||
      it 'creates a follow request relation between user and target user' do
 | 
			
		||||
        expect(user.account.requested?(other_account)).to be true
 | 
			
		||||
      end
 | 
			
		||||
    end
 | 
			
		||||
  end
 | 
			
		||||
 | 
			
		||||
  describe 'POST #unfollow' do
 | 
			
		||||
    let(:other_account) { Fabricate(:user, email: 'bob@example.com', account: Fabricate(:account, username: 'bob')).account }
 | 
			
		||||
 | 
			
		||||
| 
						 | 
				
			
			
 | 
			
		|||
		Loading…
	
	Add table
		
		Reference in a new issue