a7aedebc31
Conflicts: - `Gemfile.lock`: Not a real conflict, upstream updated dependencies that were too close to glitch-soc-only ones in the file. - `app/controllers/oauth/authorized_applications_controller.rb`: Upstream changed the logic surrounding suspended accounts. Minor conflict due to glitch-soc's theming system. Ported upstream changes. - `app/controllers/settings/base_controller.rb`: Upstream refactored and changed the logic surrounding suspended accounts. Minor conflict due to glitch-soc's theming system. Ported upstream changes. - `app/controllers/settings/sessions_controller.rb`: Upstream refactored and changed the logic surrounding suspended accounts. Minor conflict due to glitch-soc's theming system. Ported upstream changes. - `app/models/user.rb`: Upstream refactored and changed the logic surrounding suspended accounts. Minor conflict due to glitch-soc not preventing moved accounts from logging in. Ported upstream changes while keeping the ability for moved accounts to log in. - `app/policies/status_policy.rb`: Upstream refactored and changed the logic surrounding suspended accounts. Minor conflict due to glitch-soc's local-only toots. Ported upstream changes. - `app/serializers/rest/account_serializer.rb`: Upstream refactored and changed the logic surrounding suspended accounts. Minor conflict due to glitch-soc's ability to hide followers count. Ported upstream changes. - `app/services/process_mentions_service.rb`: Upstream refactored and changed the logic surrounding suspended accounts. Minor conflict due to glitch-soc's local-only toots. Ported upstream changes. - `package.json`: Not a real conflict, upstream updated dependencies that were too close to glitch-soc-only ones in the file.
79 lines
1.9 KiB
Ruby
79 lines
1.9 KiB
Ruby
# frozen_string_literal: true
|
|
|
|
class Api::V1::MutesController < Api::BaseController
|
|
before_action -> { doorkeeper_authorize! :follow, :'read:mutes' }
|
|
before_action :require_user!
|
|
after_action :insert_pagination_headers
|
|
|
|
def index
|
|
@data = @accounts = load_accounts
|
|
render json: @accounts, each_serializer: REST::AccountSerializer
|
|
end
|
|
|
|
def details
|
|
@data = @mutes = load_mutes
|
|
render json: @mutes, each_serializer: REST::MuteSerializer
|
|
end
|
|
|
|
private
|
|
|
|
def load_accounts
|
|
paginated_mutes.map(&:target_account)
|
|
end
|
|
|
|
def load_mutes
|
|
paginated_mutes.includes(:account, :target_account).to_a
|
|
end
|
|
|
|
def paginated_mutes
|
|
@paginated_mutes ||= Mute.eager_load(:target_account)
|
|
.joins(:target_account)
|
|
.merge(Account.without_suspended)
|
|
.where(account: current_account)
|
|
.paginate_by_max_id(
|
|
limit_param(DEFAULT_ACCOUNTS_LIMIT),
|
|
params[:max_id],
|
|
params[:since_id]
|
|
)
|
|
end
|
|
|
|
def insert_pagination_headers
|
|
set_pagination_headers(next_path, prev_path)
|
|
end
|
|
|
|
def next_path
|
|
if records_continue?
|
|
url_for pagination_params(max_id: pagination_max_id)
|
|
end
|
|
end
|
|
|
|
def prev_path
|
|
unless @data.empty?
|
|
url_for pagination_params(since_id: pagination_since_id)
|
|
end
|
|
end
|
|
|
|
def pagination_max_id
|
|
if params[:action] == "details"
|
|
@mutes.last.id
|
|
else
|
|
paginated_mutes.last.id
|
|
end
|
|
end
|
|
|
|
def pagination_since_id
|
|
if params[:action] == "details"
|
|
@mutes.first.id
|
|
else
|
|
paginated_mutes.first.id
|
|
end
|
|
end
|
|
|
|
def records_continue?
|
|
@data.size == limit_param(DEFAULT_ACCOUNTS_LIMIT)
|
|
end
|
|
|
|
def pagination_params(core_params)
|
|
params.slice(:limit).permit(:limit).merge(core_params)
|
|
end
|
|
end
|