debian-mirror-gitlab/lib/gitlab/search_results.rb

94 lines
2.2 KiB
Ruby
Raw Normal View History

2015-04-26 12:48:37 +05:30
module Gitlab
class SearchResults
attr_reader :query
# Limit search results by passed project ids
# It allows us to search only for projects user has access to
attr_reader :limit_project_ids
def initialize(limit_project_ids, query)
@limit_project_ids = limit_project_ids || Project.all
@query = Shellwords.shellescape(query) if query.present?
end
def objects(scope, page = nil)
case scope
when 'projects'
projects.page(page).per(per_page)
when 'issues'
issues.page(page).per(per_page)
when 'merge_requests'
merge_requests.page(page).per(per_page)
2015-09-25 12:07:36 +05:30
when 'milestones'
milestones.page(page).per(per_page)
2015-04-26 12:48:37 +05:30
else
Kaminari.paginate_array([]).page(page).per(per_page)
end
end
def total_count
2015-09-25 12:07:36 +05:30
@total_count ||= projects_count + issues_count + merge_requests_count + milestones_count
2015-04-26 12:48:37 +05:30
end
def projects_count
@projects_count ||= projects.count
end
def issues_count
@issues_count ||= issues.count
end
def merge_requests_count
@merge_requests_count ||= merge_requests.count
end
2015-09-25 12:07:36 +05:30
def milestones_count
@milestones_count ||= milestones.count
end
2015-04-26 12:48:37 +05:30
def empty?
total_count.zero?
end
private
def projects
Project.where(id: limit_project_ids).search(query)
end
def issues
2015-09-11 14:41:01 +05:30
issues = Issue.where(project_id: limit_project_ids)
if query =~ /#(\d+)\z/
issues = issues.where(iid: $1)
else
issues = issues.full_search(query)
end
issues.order('updated_at DESC')
2015-04-26 12:48:37 +05:30
end
2015-09-25 12:07:36 +05:30
def milestones
milestones = Milestone.where(project_id: limit_project_ids)
milestones = milestones.search(query)
milestones.order('updated_at DESC')
end
2015-04-26 12:48:37 +05:30
def merge_requests
2015-09-11 14:41:01 +05:30
merge_requests = MergeRequest.in_projects(limit_project_ids)
if query =~ /[#!](\d+)\z/
merge_requests = merge_requests.where(iid: $1)
else
merge_requests = merge_requests.full_search(query)
end
merge_requests.order('updated_at DESC')
2015-04-26 12:48:37 +05:30
end
def default_scope
'projects'
end
def per_page
20
end
end
end