forked from cybrespace/mastodon
		
	* Bump rubocop from 0.86.0 to 0.88.0 Bumps [rubocop](https://github.com/rubocop-hq/rubocop) from 0.86.0 to 0.88.0. - [Release notes](https://github.com/rubocop-hq/rubocop/releases) - [Changelog](https://github.com/rubocop-hq/rubocop/blob/master/CHANGELOG.md) - [Commits](https://github.com/rubocop-hq/rubocop/compare/v0.86.0...v0.88.0) Signed-off-by: dependabot[bot] <support@github.com> * Fix for latest RuboCop Co-authored-by: dependabot[bot] <49699333+dependabot[bot]@users.noreply.github.com> Co-authored-by: Yamagishi Kazutoshi <ykzts@desire.sh>
		
			
				
	
	
		
			37 lines
		
	
	
	
		
			1.1 KiB
		
	
	
	
		
			Ruby
		
	
	
	
	
	
			
		
		
	
	
			37 lines
		
	
	
	
		
			1.1 KiB
		
	
	
	
		
			Ruby
		
	
	
	
	
	
# frozen_string_literal: true
 | 
						|
 | 
						|
class UpdateAccountService < BaseService
 | 
						|
  def call(account, params, raise_error: false)
 | 
						|
    was_locked    = account.locked
 | 
						|
    update_method = raise_error ? :update! : :update
 | 
						|
 | 
						|
    account.send(update_method, params).tap do |ret|
 | 
						|
      next unless ret
 | 
						|
 | 
						|
      authorize_all_follow_requests(account) if was_locked && !account.locked
 | 
						|
      check_links(account)
 | 
						|
      process_hashtags(account)
 | 
						|
    end
 | 
						|
  rescue Mastodon::DimensionsValidationError, Mastodon::StreamValidationError => e
 | 
						|
    account.errors.add(:avatar, e.message)
 | 
						|
    false
 | 
						|
  end
 | 
						|
 | 
						|
  private
 | 
						|
 | 
						|
  def authorize_all_follow_requests(account)
 | 
						|
    follow_requests = FollowRequest.where(target_account: account)
 | 
						|
    follow_requests = follow_requests.preload(:account).select { |req| !req.account.silenced? }
 | 
						|
    AuthorizeFollowWorker.push_bulk(follow_requests) do |req|
 | 
						|
      [req.account_id, req.target_account_id]
 | 
						|
    end
 | 
						|
  end
 | 
						|
 | 
						|
  def check_links(account)
 | 
						|
    VerifyAccountLinksWorker.perform_async(account.id)
 | 
						|
  end
 | 
						|
 | 
						|
  def process_hashtags(account)
 | 
						|
    account.tags_as_strings = Extractor.extract_hashtags(account.note)
 | 
						|
  end
 | 
						|
end
 |