# frozen_string_literal: true class REST::StatusSerializer < ActiveModel::Serializer attributes :id, :created_at, :in_reply_to_id, :in_reply_to_account_id, :sensitive, :spoiler_text, :visibility, :language, :uri, :url, :replies_count, :reblogs_count, :favourites_count, :emoji_reactions_count, :emoji_reactions, :status_reference_ids, :status_references_count, :status_referred_by_count attribute :favourited, if: :current_user? attribute :reblogged, if: :current_user? attribute :muted, if: :current_user? attribute :bookmarked, if: :current_user? attribute :emoji_reactioned, if: :current_user? attribute :pinned, if: :pinnable? attribute :circle_id, if: :limited_owned_parent_status? attribute :content, unless: :source_requested? attribute :text, if: :source_requested? attribute :nyaize_content, if: :joke_applied? attribute :quote_id, if: :quote? attribute :expires_at, if: :has_expires? attribute :expires_action, if: :has_expires? attribute :visibility_ex, if: :visibility_ex? belongs_to :reblog, serializer: REST::StatusSerializer belongs_to :application, if: :show_application? belongs_to :account, serializer: REST::AccountSerializer has_many :media_attachments, serializer: REST::MediaAttachmentSerializer has_many :ordered_mentions, key: :mentions has_many :tags has_many :emojis, serializer: REST::CustomEmojiSerializer has_one :preview_card, key: :card, serializer: REST::PreviewCardSerializer has_one :preloadable_poll, key: :poll, serializer: REST::PollSerializer def id object.id.to_s end def in_reply_to_id object.in_reply_to_id&.to_s end def in_reply_to_account_id object.in_reply_to_account_id&.to_s end def quote_id object.quote_id.to_s end def current_user? !current_user.nil? end def owned_status? current_user? && current_user.account_id == object.account_id end def show_application? object.account.user_shows_application? || owned_status? end def quote? object.quote? end def has_expires? object.expires? || object.expired? end def expires_at object&.status_expire&.expires_at || object.expired_at end def expires_action object&.status_expire&.action || 'mark' end def visibility_ex? object.limited_visibility? end def visibility # This visibility is masked behind "private" # to avoid API changes because there are no # UX differences if object.limited_visibility? 'private' else object.visibility end end def visibility_ex object.visibility end def sensitive if current_user? && current_user.account_id == object.account_id object.sensitive else object.account.sensitized? || object.sensitive end end def limited_owned_parent_status? object.limited_visibility? && owned_status? && (!object.reply? || object.thread&.conversation_id != object.conversation_id) end def circle_id Redis.current.get("statuses/#{object.id}/circle_id") end def uri ActivityPub::TagManager.instance.uri_for(object) end def content @content ||= Formatter.instance.format(object) end def nyaize_content @nyaize_content ||= Formatter.instance.format(object, nyaize: object.account.cat?) end def url ActivityPub::TagManager.instance.url_for(object) end def favourited if instance_options && instance_options[:relationships] instance_options[:relationships].favourites_map[object.id] || false else current_user.account.favourited?(object) end end def emoji_reactions object.grouped_emoji_reactions(current_user&.account) end def status_reference_ids object.references.map(&:id).map(&:to_s) end def reblogged if instance_options && instance_options[:relationships] instance_options[:relationships].reblogs_map[object.id] || false else current_user.account.reblogged?(object) end end def muted if instance_options && instance_options[:relationships] instance_options[:relationships].mutes_map[object.conversation_id] || false else current_user.account.muting_conversation?(object.conversation) end end def bookmarked if instance_options && instance_options[:relationships] instance_options[:relationships].bookmarks_map[object.id] || false else current_user.account.bookmarked?(object) end end def emoji_reactioned if instance_options && instance_options[:relationships] instance_options[:relationships].emoji_reactions_map[object.id] || false else current_user.account.emoji_reactioned?(object) end end def pinned if instance_options && instance_options[:relationships] instance_options[:relationships].pins_map[object.id] || false else current_user.account.pinned?(object) end end def pinnable? owned_status? && !object.reblog? && %w(public unlisted).include?(object.visibility) end def source_requested? instance_options[:source_requested] end def joke_applied? !source_requested? && object.account.cat? && nyaize_content != content end def ordered_mentions object.active_mentions.to_a.sort_by(&:id) end class ApplicationSerializer < ActiveModel::Serializer attributes :name, :website end class MentionSerializer < ActiveModel::Serializer attributes :id, :username, :url, :acct, :group def id object.account_id.to_s end def username object.account_username end def url ActivityPub::TagManager.instance.url_for(object.account) end def acct object.account.pretty_acct end def group object.account.group? end end class TagSerializer < ActiveModel::Serializer include RoutingHelper attributes :name, :url def url tag_url(object) end end end class REST::NestedQuoteSerializer < REST::StatusSerializer attribute :quote do nil end attribute :quote_muted, if: :current_user? def quote_muted if instance_options && instance_options[:account_relationships] instance_options[:account_relationships].muting[object.account_id] ? true : false || instance_options[:account_relationships].blocking[object.account_id] || instance_options[:account_relationships].blocked_by[object.account_id] || instance_options[:account_relationships].domain_blocking[object.account_id] || false else current_user.account.muting?(object.account) || object.account.blocking?(current_user.account) || current_user.account.blocking?(object.account) || current_user.account.domain_blocking?(object.account.domain) end end end class REST::StatusSerializer < ActiveModel::Serializer belongs_to :quote, serializer: REST::NestedQuoteSerializer end