Conflicts:
- `.github/dependabot.yml`:
  Updated upstream, we deleted it to not be flooded by Depandabot.
  Kept deleted.
- `Gemfile.lock`:
  Puma updated on both sides, went for the most recent version.
- `app/controllers/api/v1/mutes_controller.rb`:
  Upstream updated the serializer to support timed mutes, while
  glitch-soc added a custom API ages ago to get information that
  is already available elsewhere.
  Dropped the glitch-soc-specific API, went with upstream changes.
- `app/javascript/core/admin.js`:
  Conflict due to changing how assets are loaded. Went with upstream.
- `app/javascript/packs/public.js`:
  Conflict due to changing how assets are loaded. Went with upstream.
- `app/models/mute.rb`:
  🤷
- `app/models/user.rb`:
  New user setting added upstream while we have glitch-soc-specific
  user settings. Added upstream's user setting.
- `config/settings.yml`:
  Upstream added a new user setting close to a user setting we had
  changed the defaults for. Added the new upstream setting.
- `package.json`:
  Upstream dependency updated “too close” to a glitch-soc-specific
  dependency. No real conflict. Updated the dependency.
		
	
			
		
			
				
	
	
		
			102 lines
		
	
	
		
			4.0 KiB
		
	
	
	
		
			Ruby
		
	
	
	
	
	
			
		
		
	
	
			102 lines
		
	
	
		
			4.0 KiB
		
	
	
	
		
			Ruby
		
	
	
	
	
	
| # frozen_string_literal: true
 | |
| 
 | |
| class InitialStateSerializer < ActiveModel::Serializer
 | |
|   attributes :meta, :compose, :accounts,
 | |
|              :media_attachments, :settings,
 | |
|              :max_toot_chars, :poll_limits
 | |
| 
 | |
|   has_one :push_subscription, serializer: REST::WebPushSubscriptionSerializer
 | |
| 
 | |
|   def max_toot_chars
 | |
|     StatusLengthValidator::MAX_CHARS
 | |
|   end
 | |
| 
 | |
|   def poll_limits
 | |
|     {
 | |
|       max_options: PollValidator::MAX_OPTIONS,
 | |
|       max_option_chars: PollValidator::MAX_OPTION_CHARS,
 | |
|       min_expiration: PollValidator::MIN_EXPIRATION,
 | |
|       max_expiration: PollValidator::MAX_EXPIRATION,
 | |
|     }
 | |
|   end
 | |
| 
 | |
|   def meta
 | |
|     store = {
 | |
|       streaming_api_base_url: Rails.configuration.x.streaming_api_base_url,
 | |
|       access_token: object.token,
 | |
|       locale: I18n.locale,
 | |
|       domain: Rails.configuration.x.local_domain,
 | |
|       title: instance_presenter.site_title,
 | |
|       admin: object.admin&.id&.to_s,
 | |
|       search_enabled: Chewy.enabled?,
 | |
|       repository: Mastodon::Version.repository,
 | |
|       source_url: Mastodon::Version.source_url,
 | |
|       version: Mastodon::Version.to_s,
 | |
|       invites_enabled: Setting.min_invite_role == 'user',
 | |
|       mascot: instance_presenter.mascot&.file&.url,
 | |
|       profile_directory: Setting.profile_directory,
 | |
|       trends: Setting.trends,
 | |
|     }
 | |
| 
 | |
|     if object.current_account
 | |
|       store[:me]                = object.current_account.id.to_s
 | |
|       store[:unfollow_modal]    = object.current_account.user.setting_unfollow_modal
 | |
|       store[:boost_modal]       = object.current_account.user.setting_boost_modal
 | |
|       store[:favourite_modal]   = object.current_account.user.setting_favourite_modal
 | |
|       store[:delete_modal]      = object.current_account.user.setting_delete_modal
 | |
|       store[:auto_play_gif]     = object.current_account.user.setting_auto_play_gif
 | |
|       store[:display_media]     = object.current_account.user.setting_display_media
 | |
|       store[:expand_spoilers]   = object.current_account.user.setting_expand_spoilers
 | |
|       store[:reduce_motion]     = object.current_account.user.setting_reduce_motion
 | |
|       store[:disable_swiping]   = object.current_account.user.setting_disable_swiping
 | |
|       store[:advanced_layout]   = object.current_account.user.setting_advanced_layout
 | |
|       store[:use_blurhash]      = object.current_account.user.setting_use_blurhash
 | |
|       store[:use_pending_items] = object.current_account.user.setting_use_pending_items
 | |
|       store[:is_staff]          = object.current_account.user.staff?
 | |
|       store[:trends]            = Setting.trends && object.current_account.user.setting_trends
 | |
|       store[:default_content_type] = object.current_account.user.setting_default_content_type
 | |
|       store[:system_emoji_font] = object.current_account.user.setting_system_emoji_font
 | |
|       store[:crop_images]       = object.current_account.user.setting_crop_images
 | |
|     else
 | |
|       store[:auto_play_gif] = Setting.auto_play_gif
 | |
|       store[:display_media] = Setting.display_media
 | |
|       store[:reduce_motion] = Setting.reduce_motion
 | |
|       store[:use_blurhash]  = Setting.use_blurhash
 | |
|       store[:crop_images]   = Setting.crop_images
 | |
|     end
 | |
| 
 | |
|     store
 | |
|   end
 | |
| 
 | |
|   def compose
 | |
|     store = {}
 | |
| 
 | |
|     if object.current_account
 | |
|       store[:me]                = object.current_account.id.to_s
 | |
|       store[:default_privacy]   = object.visibility || object.current_account.user.setting_default_privacy
 | |
|       store[:default_sensitive] = object.current_account.user.setting_default_sensitive
 | |
|     end
 | |
| 
 | |
|     store[:text] = object.text if object.text
 | |
| 
 | |
|     store
 | |
|   end
 | |
| 
 | |
|   def accounts
 | |
|     store = {}
 | |
|     store[object.current_account.id.to_s] = ActiveModelSerializers::SerializableResource.new(object.current_account, serializer: REST::AccountSerializer) if object.current_account
 | |
|     store[object.admin.id.to_s]           = ActiveModelSerializers::SerializableResource.new(object.admin, serializer: REST::AccountSerializer) if object.admin
 | |
|     store
 | |
|   end
 | |
| 
 | |
|   def media_attachments
 | |
|     { accept_content_types: MediaAttachment.supported_file_extensions + MediaAttachment.supported_mime_types }
 | |
|   end
 | |
| 
 | |
|   private
 | |
| 
 | |
|   def instance_presenter
 | |
|     @instance_presenter ||= InstancePresenter.new
 | |
|   end
 | |
| end
 |