Conflicts: - `Gemfile.lock`: Not a real conflict, upstream updated dependencies that were too close to glitch-soc-only ones in the file. - `app/controllers/oauth/authorized_applications_controller.rb`: Upstream changed the logic surrounding suspended accounts. Minor conflict due to glitch-soc's theming system. Ported upstream changes. - `app/controllers/settings/base_controller.rb`: Upstream refactored and changed the logic surrounding suspended accounts. Minor conflict due to glitch-soc's theming system. Ported upstream changes. - `app/controllers/settings/sessions_controller.rb`: Upstream refactored and changed the logic surrounding suspended accounts. Minor conflict due to glitch-soc's theming system. Ported upstream changes. - `app/models/user.rb`: Upstream refactored and changed the logic surrounding suspended accounts. Minor conflict due to glitch-soc not preventing moved accounts from logging in. Ported upstream changes while keeping the ability for moved accounts to log in. - `app/policies/status_policy.rb`: Upstream refactored and changed the logic surrounding suspended accounts. Minor conflict due to glitch-soc's local-only toots. Ported upstream changes. - `app/serializers/rest/account_serializer.rb`: Upstream refactored and changed the logic surrounding suspended accounts. Minor conflict due to glitch-soc's ability to hide followers count. Ported upstream changes. - `app/services/process_mentions_service.rb`: Upstream refactored and changed the logic surrounding suspended accounts. Minor conflict due to glitch-soc's local-only toots. Ported upstream changes. - `package.json`: Not a real conflict, upstream updated dependencies that were too close to glitch-soc-only ones in the file.
		
			
				
	
	
		
			104 lines
		
	
	
		
			2.3 KiB
		
	
	
	
		
			Ruby
		
	
	
	
	
	
			
		
		
	
	
			104 lines
		
	
	
		
			2.3 KiB
		
	
	
	
		
			Ruby
		
	
	
	
	
	
| # frozen_string_literal: true
 | |
| 
 | |
| class REST::AccountSerializer < ActiveModel::Serializer
 | |
|   include RoutingHelper
 | |
| 
 | |
|   attributes :id, :username, :acct, :display_name, :locked, :bot, :discoverable, :group, :created_at,
 | |
|              :note, :url, :avatar, :avatar_static, :header, :header_static,
 | |
|              :followers_count, :following_count, :statuses_count, :last_status_at
 | |
| 
 | |
|   has_one :moved_to_account, key: :moved, serializer: REST::AccountSerializer, if: :moved_and_not_nested?
 | |
| 
 | |
|   has_many :emojis, serializer: REST::CustomEmojiSerializer
 | |
| 
 | |
|   attribute :suspended, if: :suspended?
 | |
| 
 | |
|   class FieldSerializer < ActiveModel::Serializer
 | |
|     attributes :name, :value, :verified_at
 | |
| 
 | |
|     def value
 | |
|       Formatter.instance.format_field(object.account, object.value)
 | |
|     end
 | |
|   end
 | |
| 
 | |
|   has_many :fields
 | |
| 
 | |
|   def id
 | |
|     object.id.to_s
 | |
|   end
 | |
| 
 | |
|   def acct
 | |
|     object.pretty_acct
 | |
|   end
 | |
| 
 | |
|   def note
 | |
|     object.suspended? ? '' : Formatter.instance.simplified_format(object)
 | |
|   end
 | |
| 
 | |
|   def url
 | |
|     ActivityPub::TagManager.instance.url_for(object)
 | |
|   end
 | |
| 
 | |
|   def avatar
 | |
|     full_asset_url(object.suspended? ? object.avatar.default_url : object.avatar_original_url)
 | |
|   end
 | |
| 
 | |
|   def avatar_static
 | |
|     full_asset_url(object.suspended? ? object.avatar.default_url : object.avatar_static_url)
 | |
|   end
 | |
| 
 | |
|   def header
 | |
|     full_asset_url(object.suspended? ? object.header.default_url : object.header_original_url)
 | |
|   end
 | |
| 
 | |
|   def header_static
 | |
|     full_asset_url(object.suspended? ? object.header.default_url : object.header_static_url)
 | |
|   end
 | |
| 
 | |
|   def last_status_at
 | |
|     object.last_status_at&.to_date&.iso8601
 | |
|   end
 | |
| 
 | |
|   def followers_count
 | |
|     (Setting.hide_followers_count || object.user&.setting_hide_followers_count) ? -1 : object.followers_count
 | |
|   end
 | |
| 
 | |
|   def display_name
 | |
|     object.suspended? ? '' : object.display_name
 | |
|   end
 | |
| 
 | |
|   def locked
 | |
|     object.suspended? ? false : object.locked
 | |
|   end
 | |
| 
 | |
|   def bot
 | |
|     object.suspended? ? false : object.bot
 | |
|   end
 | |
| 
 | |
|   def discoverable
 | |
|     object.suspended? ? false : object.discoverable
 | |
|   end
 | |
| 
 | |
|   def moved_to_account
 | |
|     object.suspended? ? nil : object.moved_to_account
 | |
|   end
 | |
| 
 | |
|   def emojis
 | |
|     object.suspended? ? [] : object.emojis
 | |
|   end
 | |
| 
 | |
|   def fields
 | |
|     object.suspended? ? [] : object.fields
 | |
|   end
 | |
| 
 | |
|   def suspended
 | |
|     object.suspended?
 | |
|   end
 | |
| 
 | |
|   delegate :suspended?, to: :object
 | |
| 
 | |
|   def moved_and_not_nested?
 | |
|     object.moved? && object.moved_to_account.moved_to_account_id.nil?
 | |
|   end
 | |
| end
 |