You can not select more than 25 topics
Topics must start with a letter or number, can include dashes ('-') and can be up to 35 characters long.
68 lines
1.4 KiB
68 lines
1.4 KiB
# frozen_string_literal: true |
|
|
|
class AuthorizeInteractionsController < ApplicationController |
|
include Authorization |
|
|
|
layout 'modal' |
|
|
|
before_action :authenticate_user! |
|
before_action :set_body_classes |
|
before_action :set_resource |
|
|
|
def show |
|
if @resource.is_a?(Account) |
|
render :show |
|
elsif @resource.is_a?(Status) |
|
redirect_to web_url("@#{@resource.account.pretty_acct}/#{@resource.id}") |
|
else |
|
render :error |
|
end |
|
end |
|
|
|
def create |
|
if @resource.is_a?(Account) && FollowService.new.call(current_account, @resource, with_rate_limit: true) |
|
render :success |
|
else |
|
render :error |
|
end |
|
rescue ActiveRecord::RecordNotFound |
|
render :error |
|
end |
|
|
|
private |
|
|
|
def set_resource |
|
@resource = located_resource |
|
authorize(@resource, :show?) if @resource.is_a?(Status) |
|
rescue Mastodon::NotPermittedError |
|
not_found |
|
end |
|
|
|
def located_resource |
|
if uri_param_is_url? |
|
ResolveURLService.new.call(uri_param) |
|
else |
|
account_from_remote_follow |
|
end |
|
end |
|
|
|
def account_from_remote_follow |
|
ResolveAccountService.new.call(uri_param) |
|
end |
|
|
|
def uri_param_is_url? |
|
parsed_uri.path && %w(http https).include?(parsed_uri.scheme) |
|
end |
|
|
|
def parsed_uri |
|
Addressable::URI.parse(uri_param).normalize |
|
end |
|
|
|
def uri_param |
|
params[:uri] || params.fetch(:acct, '').gsub(/\Aacct:/, '') |
|
end |
|
|
|
def set_body_classes |
|
@body_classes = 'modal-layout' |
|
end |
|
end
|
|
|