include some default search result texts for popular failing searches, such as nvidia...
[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         @result = Seeker.prepare_result(@query, base, @project, @exclude_filter, @exclude_debug)
47         unless @result.blank?
48           flash.now[:note] = _("Switched to exact match due to too many hits on substring search.")
49         else
50           flash.now[:error] = _("Please be more precise in your search, search limit reached.")
51         end
52       else
53         logger.error _("Could not perform search: ") + search_error
54         flash.now[:error] = _("Could not perform search: ") + search_error
55       end
56       return
57     end
58
59     flash.now[:warn] = _("Please be more precise in your search, search limit reached.") if @result.binary_count >= 1000
60     return true
61   end
62
63
64   def set_default_message
65     if DEFAULT_SEARCHES[params[:q]]
66       flash.now[:note] = DEFAULT_SEARCHES[params[:q]]
67     end
68   end
69
70 end