forked from mirrors/catstodon
a4859446ab
* Add coverage for create with empty acct value * Add coverage for create with webfinger failure * Add coverage for create with webfinger providing bad values * Add coverage for create when webfinger is good * Add coverage for session[:remote_follow] having data * Simplify how remote follow pulls acct from session * Remote follow behaves more like model * Move the discovery portions of remote follow out of controller * Check for suspended accounts
37 lines
760 B
Ruby
37 lines
760 B
Ruby
# frozen_string_literal: true
|
|
|
|
class RemoteFollowController < ApplicationController
|
|
layout 'public'
|
|
|
|
before_action :set_account
|
|
before_action :gone, if: -> { @account.suspended? }
|
|
|
|
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_account
|
|
@account = Account.find_local!(params[:account_username])
|
|
end
|
|
end
|