mirror of
https://git.bsd.gay/fef/nyastodon.git
synced 2025-01-01 12:33:41 +01:00
221580a3af
Conflicts: - `app/controllers/home_controller.rb`: Upstream made it so `/web` is available to non-logged-in users and `/` redirects to `/web` instead of `/about`. Kept our version since glitch-soc's WebUI doesn't have what's needed yet and I think /about is still a much better landing page anyway. - `app/models/form/admin_settings.rb`: Upstream added new settings, and glitch-soc had an extra setting. Not really a conflict. Added upstream's new settings. - `app/serializers/initial_state_serializer.rb`: Upstream added a new `server` initial state object. Not really a conflict. Merged upstream's changes. - `app/views/admin/settings/edit.html.haml`: Upstream added new settings. Not really a conflict. Merged upstream's changes. - `app/workers/scheduler/feed_cleanup_scheduler.rb`: Upstream refactored that part and removed the file. Ported our relevant changes into `app/lib/vacuum/feeds_vacuum.rb` - `config/settings.yml`: Upstream added new settings. Not a real conflict. Added upstream's new settings.
33 lines
852 B
Ruby
33 lines
852 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 -> { authorize_if_got_token! :read, :'read:search' }
|
|
|
|
def index
|
|
@search = Search.new(search_results)
|
|
render json: @search, serializer: REST::SearchSerializer
|
|
rescue Mastodon::SyntaxError
|
|
unprocessable_entity
|
|
rescue ActiveRecord::RecordNotFound
|
|
not_found
|
|
end
|
|
|
|
private
|
|
|
|
def search_results
|
|
SearchService.new.call(
|
|
params[:q],
|
|
current_account,
|
|
limit_param(RESULTS_LIMIT),
|
|
search_params.merge(resolve: user_signed_in? ? truthy_param?(:resolve) : false, exclude_unreviewed: truthy_param?(:exclude_unreviewed))
|
|
)
|
|
end
|
|
|
|
def search_params
|
|
params.permit(:type, :offset, :min_id, :max_id, :account_id)
|
|
end
|
|
end
|