2022-10-13 15:42:37 +03:00
|
|
|
# frozen_string_literal: true
|
|
|
|
|
2023-11-10 14:46:00 +02:00
|
|
|
class Api::V1::Instances::DomainBlocksController < Api::V1::Instances::BaseController
|
2022-10-13 15:42:37 +03:00
|
|
|
before_action :require_enabled_api!
|
|
|
|
before_action :set_domain_blocks
|
|
|
|
|
2023-04-26 12:42:47 +03:00
|
|
|
vary_by '', if: -> { Setting.show_domain_blocks == 'all' }
|
2023-04-25 16:41:34 +03:00
|
|
|
|
2022-10-13 15:42:37 +03:00
|
|
|
def index
|
2023-04-26 12:42:47 +03:00
|
|
|
if Setting.show_domain_blocks == 'all'
|
|
|
|
cache_even_if_authenticated!
|
|
|
|
else
|
|
|
|
cache_if_unauthenticated!
|
|
|
|
end
|
|
|
|
|
2023-11-14 12:31:59 +02:00
|
|
|
render json: @domain_blocks, each_serializer: REST::DomainBlockSerializer, with_comment: show_rationale_in_response?
|
2022-10-13 15:42:37 +03:00
|
|
|
end
|
|
|
|
|
|
|
|
private
|
|
|
|
|
|
|
|
def require_enabled_api!
|
|
|
|
head 404 unless Setting.show_domain_blocks == 'all' || (Setting.show_domain_blocks == 'users' && user_signed_in?)
|
|
|
|
end
|
|
|
|
|
|
|
|
def set_domain_blocks
|
|
|
|
@domain_blocks = DomainBlock.with_user_facing_limitations.by_severity
|
|
|
|
end
|
2023-11-14 12:31:59 +02:00
|
|
|
|
|
|
|
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
|
2022-10-13 15:42:37 +03:00
|
|
|
end
|