diff options
author | Dmitriy Zaporozhets <dmitriy.zaporozhets@gmail.com> | 2014-01-09 14:37:12 +0400 |
---|---|---|
committer | Dmitriy Zaporozhets <dmitriy.zaporozhets@gmail.com> | 2014-01-09 14:37:12 +0400 |
commit | b49ebf5737ce95bcab792c18bddc1a4675f148ed (patch) | |
tree | aa54c0a7b8bee018761ec70d15df110655a0761c /app/contexts/search_context.rb | |
parent | 4791084d7c9356c16ead5bf3162fd132fa10c979 (diff) |
Use new context for search
Signed-off-by: Dmitriy Zaporozhets <dmitriy.zaporozhets@gmail.com>
Diffstat (limited to 'app/contexts/search_context.rb')
-rw-r--r-- | app/contexts/search_context.rb | 42 |
1 files changed, 0 insertions, 42 deletions
diff --git a/app/contexts/search_context.rb b/app/contexts/search_context.rb deleted file mode 100644 index 5985ab1fb0c..00000000000 --- a/app/contexts/search_context.rb +++ /dev/null @@ -1,42 +0,0 @@ -class SearchContext - attr_accessor :project_ids, :current_user, :params - - def initialize(project_ids, user, params) - @project_ids, @current_user, @params = project_ids, user, params.dup - end - - def execute - query = params[:search] - query = Shellwords.shellescape(query) if query.present? - - return result unless query.present? - visibility_levels = @current_user ? [ Gitlab::VisibilityLevel::INTERNAL, Gitlab::VisibilityLevel::PUBLIC ] : [ Gitlab::VisibilityLevel::PUBLIC ] - result[:projects] = Project.where("projects.id in (?) OR projects.visibility_level in (?)", project_ids, visibility_levels).search(query).limit(20) - - # Search inside single project - single_project_search(Project.where(id: project_ids), query) - result - end - - def single_project_search(projects, query) - project = projects.first if projects.length == 1 - - if params[:search_code].present? - result[:blobs] = project.repository.search_files(query, params[:repository_ref]) unless project.empty_repo? - else - result[:merge_requests] = MergeRequest.in_projects(project_ids).search(query).order('updated_at DESC').limit(20) - result[:issues] = Issue.where(project_id: project_ids).search(query).order('updated_at DESC').limit(20) - result[:wiki_pages] = [] - end - end - - def result - @result ||= { - projects: [], - merge_requests: [], - issues: [], - wiki_pages: [], - blobs: [] - } - end -end |