fix search, bnc#505240
[opensuse:software-o-o.git] / app / controllers / search_controller.rb
1 class SearchController < ApplicationController
2
3   def index
4     @exclude_debug = true
5     @exclude_filter = 'home:'
6     if params[:baseproject]
7       @baseproject = params[:baseproject]
8     end
9     if params[:q]
10       perform_search
11       set_default_message
12     end
13   end
14
15   def download
16     DownloadHistory.create :query => params[:query], :base => params[:base],
17       :file => params[:file]
18     redirect_to "http://download.opensuse.org/repositories/" + params[:file]
19   end
20
21   private
22
23   def perform_search
24     @query = params[:q]
25     @baseproject = params[:baseproject]
26     @current_page = params[:p].to_i
27     @current_page = 1 if @current_page == 0
28     @exclude_debug = params[:exclude_debug]
29     @exclude_filter = params[:exclude_filter]
30     @project = params[:project]
31
32     if @query.split(" ").select{|e| e.length < 2 }.size > 0
33       flash.now[:error] = _("Please use search strings of at least 2 characters") and return
34     end
35
36     base = @baseproject=="ALL" ? "" : @baseproject
37     begin
38       @result = Seeker.prepare_result(@query, base, @project, @exclude_filter, @exclude_debug)
39       if @current_page == 1 # ignore sub pages
40         SearchHistory.create :query => @query, :base => @baseproject, :patterns => @result.pattern_count,
41           :binaries => @result.binary_count, :count => @result.length
42       end
43     rescue => e
44       search_error, code, api_exception = ActiveXML::Transport.extract_error_message e
45       if code == "413"
46         logger.debug("Too many hits, trying exact match for: #{@query}")
47         @result = Seeker.prepare_result(CGI.escape("\"#{@query}\""), base, @project, @exclude_filter, @exclude_debug)
48         unless @result.blank?
49           @query = "\"#{@query}\""
50           flash.now[:note] = _("Switched to exact match due to too many hits on substring search.")
51         else
52           flash.now[:error] = _("Please be more precise in your search, search limit reached.")
53         end
54       else
55         logger.error _("Could not perform search: ") + search_error
56         flash.now[:error] = _("Could not perform search: ") + search_error
57       end
58       return
59     end
60
61     flash.now[:warn] = _("Please be more precise in your search, search limit reached.") if @result.binary_count >= 1000
62     return true
63   end
64
65
66   def set_default_message
67     if DEFAULT_SEARCHES[params[:q]]
68       flash.now[:note] = DEFAULT_SEARCHES[params[:q]]
69     end
70   end
71
72 end