Class: Chef::Search::Query
Instance Attribute Summary collapse
-
#rest ⇒ Object
Returns the value of attribute rest.
Instance Method Summary collapse
-
#initialize(url = nil) ⇒ Query
constructor
A new instance of Query.
- #list_indexes ⇒ Object
-
#search(type, query = "*:*", sort = nil, start = 0, rows = 20, &block) ⇒ Object
Search Solr for objects of a given type, for a given query.
Constructor Details
Instance Attribute Details
#rest ⇒ Object
Returns the value of attribute rest.
30 31 32 |
# File 'lib/chef/search/query.rb', line 30 def rest @rest end |
Instance Method Details
#list_indexes ⇒ Object
57 58 59 |
# File 'lib/chef/search/query.rb', line 57 def list_indexes response = @rest.get_rest("search") end |
#search(type, query = "*:*", sort = nil, start = 0, rows = 20, &block) ⇒ Object
Search Solr for objects of a given type, for a given query. If you give it a block, it will handle the paging for you dynamically.
39 40 41 42 43 44 45 46 47 48 49 50 51 52 53 54 55 |
# File 'lib/chef/search/query.rb', line 39 def search(type, query="*:*", sort=nil, start=0, rows=20, &block) unless type.kind_of?(String) || type.kind_of?(Symbol) raise ArgumentError, "Type must be a string or a symbol!" end response = @rest.get_rest("search/#{type}?q=#{escape(query)}&sort=#{escape(sort)}&start=#{escape(start)}&rows=#{escape(rows)}") if block response["rows"].each { |o| block.call(o) unless o.nil?} unless (response["start"] + response["rows"].length) >= response["total"] nstart = response["start"] + rows search(type, query, sort, nstart, rows, &block) end true else [ response["rows"], response["start"], response["total"] ] end end |