63 lines
		
	
	
		
			1.5 KiB
		
	
	
	
		
			Ruby
		
	
	
	
	
	
			
		
		
	
	
			63 lines
		
	
	
		
			1.5 KiB
		
	
	
	
		
			Ruby
		
	
	
	
	
	
# frozen_string_literal: true
 | 
						|
 | 
						|
module WellKnown
 | 
						|
  class WebfingerController < ActionController::Base # rubocop:disable Rails/ApplicationController
 | 
						|
    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
 | 
						|
          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
 | 
						|
      gone if @account.suspended_permanently?
 | 
						|
    end
 | 
						|
 | 
						|
    def gone
 | 
						|
      expires_in(3.minutes, public: true)
 | 
						|
      head 410
 | 
						|
    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
 | 
						|
  end
 | 
						|
end
 |