- # frozen_string_literal: true
-
- class Api::V1::FollowRequestsController < ApiController
- before_action -> { doorkeeper_authorize! :follow }
- before_action :require_user!
-
- def index
- results = FollowRequest.where(target_account: current_account).paginate_by_max_id(DEFAULT_ACCOUNTS_LIMIT, params[:max_id], params[:since_id])
- accounts = Account.where(id: results.map(&:account_id)).map { |a| [a.id, a] }.to_h
- @accounts = results.map { |f| accounts[f.account_id] }
-
- next_path = api_v1_follow_requests_url(pagination_params(max_id: results.last.id)) if results.size == DEFAULT_ACCOUNTS_LIMIT
- prev_path = api_v1_follow_requests_url(pagination_params(since_id: results.first.id)) unless results.empty?
-
- set_pagination_headers(next_path, prev_path)
- end
-
- def authorize
- AuthorizeFollowService.new.call(Account.find(params[:id]), current_account)
- render_empty
- end
-
- def reject
- RejectFollowService.new.call(Account.find(params[:id]), current_account)
- render_empty
- end
-
- private
-
- def pagination_params(core_params)
- params.permit(:limit).merge(core_params)
- end
- end
|