mirror of
https://framagit.org/tykayn/mastodon.git
synced 2023-08-25 08:33:12 +02:00
74c5b2bd08
Conflicts: - Gemfile - app/controllers/api/v1/search_controller.rb Conflict because we changed the number of default results to be configurable - app/lib/settings/scoped_settings.rb Addition of a new “noindex” site-wide setting, conflict due to our change of the two other site-wide settings (default flavour and skin instead of theme) - spec/controllers/application_controller_spec.rb Addition of a new “noindex” site-wide setting, conflict due to our change of the two other site-wide settings (default flavour and skin instead of theme)
33 lines
711 B
Ruby
33 lines
711 B
Ruby
# frozen_string_literal: true
|
|
|
|
class Api::V2::SearchController < Api::BaseController
|
|
include Authorization
|
|
|
|
RESULTS_LIMIT = (ENV['MAX_SEARCH_RESULTS'] || 20).to_i
|
|
|
|
before_action -> { doorkeeper_authorize! :read, :'read:search' }
|
|
before_action :require_user!
|
|
|
|
respond_to :json
|
|
|
|
def index
|
|
@search = Search.new(search_results)
|
|
render json: @search, serializer: REST::SearchSerializer
|
|
end
|
|
|
|
private
|
|
|
|
def search_results
|
|
SearchService.new.call(
|
|
params[:q],
|
|
current_account,
|
|
limit_param(RESULTS_LIMIT),
|
|
search_params.merge(resolve: truthy_param?(:resolve))
|
|
)
|
|
end
|
|
|
|
def search_params
|
|
params.permit(:type, :offset, :min_id, :max_id, :account_id)
|
|
end
|
|
end
|