# frozen_string_literal: true class Api::V1::Instances::DomainBlocksController < Api::V1::Instances::BaseController before_action :require_enabled_api! before_action :set_domain_blocks vary_by '', if: -> { Setting.show_domain_blocks == 'all' } def index if Setting.show_domain_blocks == 'all' cache_even_if_authenticated! else cache_if_unauthenticated! end render json: @domain_blocks, each_serializer: REST::DomainBlockSerializer, with_comment: show_rationale_in_response? end private def require_enabled_api! head 404 unless api_enabled? end def api_enabled? show_domain_blocks_for_all? || show_domain_blocks_to_user? end def show_domain_blocks_for_all? Setting.show_domain_blocks == 'all' end def show_domain_blocks_to_user? Setting.show_domain_blocks == 'users' && user_signed_in? end def set_domain_blocks @domain_blocks = DomainBlock.with_user_facing_limitations.by_severity end def show_rationale_in_response? always_show_rationale? || show_rationale_for_user? end def always_show_rationale? Setting.show_domain_blocks_rationale == 'all' end def show_rationale_for_user? Setting.show_domain_blocks_rationale == 'users' && user_signed_in? end end