2017-04-13 12:09:07 +01:00
|
|
|
# frozen_string_literal: true
|
|
|
|
|
|
|
|
module WellKnown
|
2023-04-19 15:07:29 +01:00
|
|
|
class WebfingerController < ActionController::Base # rubocop:disable Rails/ApplicationController
|
2017-06-02 21:21:36 +01:00
|
|
|
include RoutingHelper
|
|
|
|
|
2019-09-17 13:58:02 +01:00
|
|
|
before_action :set_account
|
|
|
|
before_action :check_account_suspension
|
2017-12-27 17:21:12 +00:00
|
|
|
|
2020-05-14 22:28:06 +01:00
|
|
|
rescue_from ActiveRecord::RecordNotFound, with: :not_found
|
|
|
|
rescue_from ActionController::ParameterMissing, WebfingerResource::InvalidRequest, with: :bad_request
|
2017-04-13 12:09:07 +01:00
|
|
|
|
2019-09-17 13:58:02 +01:00
|
|
|
def show
|
2019-07-08 11:03:45 +01:00
|
|
|
expires_in 3.days, public: true
|
2019-08-01 18:14:02 +01:00
|
|
|
render json: @account, serializer: WebfingerSerializer, content_type: 'application/jrd+json'
|
2017-04-13 12:09:07 +01:00
|
|
|
end
|
|
|
|
|
|
|
|
private
|
|
|
|
|
2019-09-17 13:58:02 +01:00
|
|
|
def set_account
|
2023-05-02 16:42:42 +01:00
|
|
|
username = username_from_resource
|
2023-07-27 15:11:17 +01:00
|
|
|
|
2023-05-02 16:42:42 +01:00
|
|
|
@account = begin
|
2024-01-04 14:14:46 +00:00
|
|
|
if username == Rails.configuration.x.local_domain || username == Rails.configuration.x.web_domain
|
2023-05-02 16:42:42 +01:00
|
|
|
Account.representative
|
|
|
|
else
|
|
|
|
Account.find_local!(username)
|
|
|
|
end
|
|
|
|
end
|
2019-09-17 13:58:02 +01:00
|
|
|
end
|
|
|
|
|
2017-04-13 12:09:07 +01:00
|
|
|
def username_from_resource
|
2019-07-08 11:03:45 +01:00
|
|
|
resource_user = resource_param
|
2017-05-22 14:40:04 +01:00
|
|
|
username, domain = resource_user.split('@')
|
2019-07-08 11:03:45 +01:00
|
|
|
resource_user = "#{username}@#{Rails.configuration.x.local_domain}" if Rails.configuration.x.alternate_domains.include?(domain)
|
2017-05-22 14:40:04 +01:00
|
|
|
|
|
|
|
WebfingerResource.new(resource_user).username
|
2017-04-13 12:09:07 +01:00
|
|
|
end
|
|
|
|
|
|
|
|
def resource_param
|
|
|
|
params.require(:resource)
|
|
|
|
end
|
2019-09-17 13:58:02 +01:00
|
|
|
|
|
|
|
def check_account_suspension
|
2023-11-30 15:43:26 +00:00
|
|
|
gone if @account.permanently_unavailable?
|
2023-04-19 15:07:29 +01:00
|
|
|
end
|
|
|
|
|
|
|
|
def gone
|
|
|
|
expires_in(3.minutes, public: true)
|
|
|
|
head 410
|
2019-09-17 13:58:02 +01:00
|
|
|
end
|
|
|
|
|
2020-05-14 22:28:06 +01:00
|
|
|
def bad_request
|
2021-07-03 20:13:47 +01:00
|
|
|
expires_in(3.minutes, public: true)
|
2020-05-14 22:28:06 +01:00
|
|
|
head 400
|
|
|
|
end
|
|
|
|
|
2019-09-17 13:58:02 +01:00
|
|
|
def not_found
|
2021-07-03 20:13:47 +01:00
|
|
|
expires_in(3.minutes, public: true)
|
2019-09-17 13:58:02 +01:00
|
|
|
head 404
|
|
|
|
end
|
2017-04-13 12:09:07 +01:00
|
|
|
end
|
|
|
|
end
|