# frozen_string_literal: true module WellKnown class WebfingerController < ActionController::Base include RoutingHelper before_action :set_account before_action :check_account_suspension rescue_from ActiveRecord::RecordNotFound, with: :not_found rescue_from ActionController::ParameterMissing, WebfingerResource::InvalidRequest, with: :bad_request def show expires_in 3.days, public: true render json: @account, serializer: WebfingerSerializer, content_type: 'application/jrd+json' end private def set_account username = username_from_resource @account = begin if username == Rails.configuration.x.local_domain || username == Rails.configuration.x.web_domain Account.representative else Account.find_local!(username) end end end def username_from_resource resource_user = resource_param username, domain = resource_user.split('@') resource_user = "#{username}@#{Rails.configuration.x.local_domain}" if Rails.configuration.x.alternate_domains.include?(domain) WebfingerResource.new(resource_user).username end def resource_param params.require(:resource) end def check_account_suspension expires_in(3.minutes, public: true) && gone if @account.suspended_permanently? end def bad_request expires_in(3.minutes, public: true) head 400 end def not_found expires_in(3.minutes, public: true) head 404 end def gone head 410 end end end