mirror of
https://github.com/mastodon/mastodon.git
synced 2025-01-25 16:05:34 +01:00
aae60a2366
Conflicts: - `app/controllers/concerns/sign_in_token_authentication_concern.rb`: Conflict due to glitch-soc's theming system. Ported upstream changes. - `app/controllers/concerns/two_factor_authentication_concern.rb`: Conflict due to glitch-soc's theming system. Ported upstream changes.
60 lines
1.3 KiB
Ruby
60 lines
1.3 KiB
Ruby
# frozen_string_literal: true
|
|
|
|
class RemoteInteractionController < ApplicationController
|
|
include Authorization
|
|
|
|
layout 'modal'
|
|
|
|
before_action :authenticate_user!, if: :whitelist_mode?
|
|
before_action :set_interaction_type
|
|
before_action :set_status
|
|
before_action :set_body_classes
|
|
before_action :set_pack
|
|
|
|
skip_before_action :require_functional!, unless: :whitelist_mode?
|
|
|
|
def new
|
|
@remote_follow = RemoteFollow.new(session_params)
|
|
end
|
|
|
|
def create
|
|
@remote_follow = RemoteFollow.new(resource_params)
|
|
|
|
if @remote_follow.valid?
|
|
session[:remote_follow] = @remote_follow.acct
|
|
redirect_to @remote_follow.interact_address_for(@status)
|
|
else
|
|
render :new
|
|
end
|
|
end
|
|
|
|
private
|
|
|
|
def resource_params
|
|
params.require(:remote_follow).permit(:acct)
|
|
end
|
|
|
|
def session_params
|
|
{ acct: session[:remote_follow] || current_account&.username }
|
|
end
|
|
|
|
def set_status
|
|
@status = Status.find(params[:id])
|
|
authorize @status, :show?
|
|
rescue Mastodon::NotPermittedError
|
|
not_found
|
|
end
|
|
|
|
def set_body_classes
|
|
@body_classes = 'modal-layout'
|
|
@hide_header = true
|
|
end
|
|
|
|
def set_pack
|
|
use_pack 'modal'
|
|
end
|
|
|
|
def set_interaction_type
|
|
@interaction_type = %w(reply reblog favourite).include?(params[:type]) ? params[:type] : 'reply'
|
|
end
|
|
end
|