mirror of
https://github.com/mastodon/mastodon.git
synced 2024-11-14 10:54:27 +00:00
3ed94dcc1a
Fix #10736 - Change data export to be available for non-functional accounts - Change non-functional accounts to include redirecting accounts
83 lines
1.8 KiB
Ruby
83 lines
1.8 KiB
Ruby
# frozen_string_literal: true
|
|
|
|
class RemoteFollow
|
|
include ActiveModel::Validations
|
|
include RoutingHelper
|
|
|
|
attr_accessor :acct, :addressable_template
|
|
|
|
validates :acct, presence: true, domain: { acct: true }
|
|
|
|
def initialize(attrs = {})
|
|
@acct = normalize_acct(attrs[:acct])
|
|
end
|
|
|
|
def valid?
|
|
return false unless super
|
|
|
|
fetch_template!
|
|
|
|
errors.empty?
|
|
end
|
|
|
|
def subscribe_address_for(account)
|
|
addressable_template.expand(uri: ActivityPub::TagManager.instance.uri_for(account)).to_s
|
|
end
|
|
|
|
def interact_address_for(status)
|
|
addressable_template.expand(uri: ActivityPub::TagManager.instance.uri_for(status)).to_s
|
|
end
|
|
|
|
private
|
|
|
|
def normalize_acct(value)
|
|
return if value.blank?
|
|
|
|
username, domain = value.strip.gsub(/\A@/, '').split('@')
|
|
|
|
domain = begin
|
|
if TagManager.instance.local_domain?(domain)
|
|
nil
|
|
else
|
|
TagManager.instance.normalize_domain(domain)
|
|
end
|
|
end
|
|
|
|
[username, domain].compact.join('@')
|
|
rescue Addressable::URI::InvalidURIError
|
|
value
|
|
end
|
|
|
|
def fetch_template!
|
|
return missing_resource_error if acct.blank?
|
|
|
|
_, domain = acct.split('@')
|
|
|
|
if domain.nil?
|
|
@addressable_template = Addressable::Template.new("#{authorize_interaction_url}?uri={uri}")
|
|
elsif redirect_url_link.nil? || redirect_url_link.template.nil?
|
|
missing_resource_error
|
|
else
|
|
@addressable_template = Addressable::Template.new(redirect_uri_template)
|
|
end
|
|
end
|
|
|
|
def redirect_uri_template
|
|
redirect_url_link.template
|
|
end
|
|
|
|
def redirect_url_link
|
|
acct_resource&.link('http://ostatus.org/schema/1.0/subscribe')
|
|
end
|
|
|
|
def acct_resource
|
|
@acct_resource ||= Goldfinger.finger("acct:#{acct}")
|
|
rescue Goldfinger::Error, HTTP::ConnectionError
|
|
nil
|
|
end
|
|
|
|
def missing_resource_error
|
|
errors.add(:acct, I18n.t('remote_follow.missing_resource'))
|
|
end
|
|
end
|