mirror of
https://git.bsd.gay/fef/nyastodon.git
synced 2025-01-10 21:06:58 +01:00
d392020da6
Conflicts: README.md app/controllers/statuses_controller.rb app/lib/feed_manager.rb config/navigation.rb spec/lib/feed_manager_spec.rb Conflicts were resolved by taking both versions for each change. This means the two filter systems (glitch-soc's keyword mutes and tootsuite's custom filters) are in place, which will be changed in a follow-up commit.
51 lines
976 B
Ruby
51 lines
976 B
Ruby
# frozen_string_literal: true
|
|
|
|
class RemoteFollowController < ApplicationController
|
|
layout 'modal'
|
|
|
|
before_action :set_account
|
|
before_action :set_pack
|
|
before_action :gone, if: :suspended_account?
|
|
before_action :set_body_classes
|
|
|
|
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.subscribe_address_for(@account)
|
|
else
|
|
render :new
|
|
end
|
|
end
|
|
|
|
private
|
|
|
|
def resource_params
|
|
params.require(:remote_follow).permit(:acct)
|
|
end
|
|
|
|
def session_params
|
|
{ acct: session[:remote_follow] }
|
|
end
|
|
|
|
def set_pack
|
|
use_pack 'modal'
|
|
end
|
|
|
|
def set_account
|
|
@account = Account.find_local!(params[:account_username])
|
|
end
|
|
|
|
def suspended_account?
|
|
@account.suspended?
|
|
end
|
|
|
|
def set_body_classes
|
|
@body_classes = 'modal-layout'
|
|
end
|
|
end
|