Class: Blacklight::SearchBuilder
- Inherits:
-
Object
- Object
- Blacklight::SearchBuilder
- Defined in:
- lib/blacklight/search_builder.rb
Overview
Blacklight’s SearchBuilder converts blacklight request parameters into query parameters appropriate for search index. It does so by evaluating a chain of processing methods to populate a result hash (see #to_hash).
Direct Known Subclasses
Instance Attribute Summary collapse
-
#blacklight_params ⇒ Object
readonly
Returns the value of attribute blacklight_params.
-
#processor_chain ⇒ Object
readonly
Returns the value of attribute processor_chain.
-
#search_state ⇒ Object
readonly
Returns the value of attribute search_state.
Instance Method Summary collapse
-
#append(*addl_processor_chain) ⇒ Object
Append additional processor chain directives.
-
#except(*except_processor_chain) ⇒ Object
Converse to append, remove processor chain directives, returning a new builder that’s a copy of receiver with specified change.
- #facet(value = nil) ⇒ Object
-
#facet=(value) ⇒ Object
sets the facet that this query pertains to, for the purpose of facet pagination.
-
#initialize(*options) ⇒ SearchBuilder
constructor
A new instance of SearchBuilder.
-
#merge(extra_params, &block) ⇒ Object
Merge additional, repository-specific parameters.
- #page(value = nil) ⇒ Object
- #page=(value) ⇒ Object
-
#processed_parameters ⇒ Object
The CatalogController #index action uses this.
-
#reverse_merge(extra_params, &block) ⇒ Object
“Reverse merge” additional, repository-specific parameters.
- #rows(value = nil) ⇒ Object (also: #per)
- #rows=(value) ⇒ Object
-
#sort ⇒ String
Decode the user provided ‘sort’ parameter into a sort string that can be passed to the search.
- #start(value = nil) ⇒ Object (also: #padding)
- #start=(value) ⇒ Object
-
#to_hash ⇒ Blacklight::Solr::Response
(also: #query, #to_h)
a solr query method.
-
#where(conditions) ⇒ Object
Update the :q (query) parameter.
-
#with(blacklight_params_or_search_state = {}) ⇒ Object
Set the parameters to pass through the processor chain.
Constructor Details
#initialize(scope) ⇒ SearchBuilder #initialize(processor_chain, scope) ⇒ SearchBuilder
Returns a new instance of SearchBuilder.
19 20 21 22 23 24 25 26 27 28 29 30 31 32 33 34 35 36 |
# File 'lib/blacklight/search_builder.rb', line 19 def initialize(*) case .size when 1 @processor_chain = default_processor_chain.dup @scope = .first when 2 @processor_chain, @scope = else raise ArgumentError, "wrong number of arguments. (#{.size} for 1..2)" end @blacklight_params = {} search_state_class = @scope.try(:search_state_class) || Blacklight::SearchState @search_state = search_state_class.new(@blacklight_params, @scope&.blacklight_config, @scope) @additional_filters = {} @merged_params = {} @reverse_merged_params = {} end |
Instance Attribute Details
#blacklight_params ⇒ Object (readonly)
Returns the value of attribute blacklight_params.
12 13 14 |
# File 'lib/blacklight/search_builder.rb', line 12 def blacklight_params @blacklight_params end |
#processor_chain ⇒ Object (readonly)
Returns the value of attribute processor_chain.
12 13 14 |
# File 'lib/blacklight/search_builder.rb', line 12 def processor_chain @processor_chain end |
#search_state ⇒ Object (readonly)
Returns the value of attribute search_state.
12 13 14 |
# File 'lib/blacklight/search_builder.rb', line 12 def search_state @search_state end |
Instance Method Details
#append(*addl_processor_chain) ⇒ Object
Append additional processor chain directives
62 63 64 65 66 67 68 69 70 71 72 73 74 |
# File 'lib/blacklight/search_builder.rb', line 62 def append(*addl_processor_chain) params_will_change! builder = self.class.new(processor_chain + addl_processor_chain, scope) .with(search_state) .merge(@merged_params) .reverse_merge(@reverse_merged_params) builder.start = @start if @start builder.rows = @rows if @rows builder.page = @page if @page builder.facet = @facet if @facet builder end |
#except(*except_processor_chain) ⇒ Object
Converse to append, remove processor chain directives, returning a new builder that’s a copy of receiver with specified change.
Methods in argument that aren’t currently in processor chain are ignored as no-ops, rather than raising.
83 84 85 86 87 88 89 90 91 92 93 94 |
# File 'lib/blacklight/search_builder.rb', line 83 def except(*except_processor_chain) builder = self.class.new(processor_chain - except_processor_chain, scope) .with(search_state) .merge(@merged_params) .reverse_merge(@reverse_merged_params) builder.start = @start if @start builder.rows = @rows if @rows builder.page = @page if @page builder.facet = @facet if @facet builder end |
#facet(value = nil) ⇒ Object
219 220 221 222 223 224 225 |
# File 'lib/blacklight/search_builder.rb', line 219 def facet(value = nil) if value self.facet = value return self end @facet end |
#facet=(value) ⇒ Object
sets the facet that this query pertains to, for the purpose of facet pagination
213 214 215 216 |
# File 'lib/blacklight/search_builder.rb', line 213 def facet=(value) params_will_change! @facet = value end |
#merge(extra_params, &block) ⇒ Object
Merge additional, repository-specific parameters
98 99 100 101 102 103 104 |
# File 'lib/blacklight/search_builder.rb', line 98 def merge(extra_params, &block) if extra_params params_will_change! @merged_params.merge!(extra_params.to_hash, &block) end self end |
#page(value = nil) ⇒ Object
183 184 185 186 187 188 189 |
# File 'lib/blacklight/search_builder.rb', line 183 def page(value = nil) if value self.page = value return self end @page ||= search_state.page end |
#page=(value) ⇒ Object
176 177 178 179 180 |
# File 'lib/blacklight/search_builder.rb', line 176 def page=(value) params_will_change! @page = value.to_i @page = 1 if @page < 1 end |
#processed_parameters ⇒ Object
The CatalogController #index action uses this. Solr parameters can come from a number of places. From lowest precedence to highest:
1. General defaults in blacklight config (are trumped by)
2. defaults for the particular search field identified by params[:search_field] (are trumped by)
3. certain parameters directly on input HTTP query params
* not just any parameter is grabbed willy nilly, only certain ones are allowed by HTTP input)
* for legacy reasons, qt in http query does not over-ride qt in search field definition default.
4. extra parameters passed in as argument.
spellcheck.q will be supplied with the [:q] value unless specifically specified otherwise.
Incoming parameter :f is mapped to :fq solr parameter.
148 149 150 151 152 153 154 |
# File 'lib/blacklight/search_builder.rb', line 148 def processed_parameters request.tap do |request_parameters| processor_chain.each do |method_name| send(method_name, request_parameters) end end end |
#reverse_merge(extra_params, &block) ⇒ Object
“Reverse merge” additional, repository-specific parameters
108 109 110 111 112 113 114 |
# File 'lib/blacklight/search_builder.rb', line 108 def reverse_merge(extra_params, &block) if extra_params params_will_change! @reverse_merged_params.reverse_merge!(extra_params.to_hash, &block) end self end |
#rows(value = nil) ⇒ Object Also known as: per
197 198 199 200 201 202 203 204 205 206 207 208 |
# File 'lib/blacklight/search_builder.rb', line 197 def rows(value = nil) if value self.rows = value return self end @rows ||= begin # user-provided parameters should override any default row r = search_state.per_page # ensure we don't excede the max page size r.nil? ? nil : [r, blacklight_config.max_per_page].map(&:to_i).min end end |
#rows=(value) ⇒ Object
191 192 193 194 |
# File 'lib/blacklight/search_builder.rb', line 191 def rows=(value) params_will_change! @rows = [value, blacklight_config.max_per_page].map(&:to_i).min end |
#sort ⇒ String
Decode the user provided ‘sort’ parameter into a sort string that can be passed to the search. This sanitizes the input by ensuring only configured search values are passed through to the search.
231 232 233 |
# File 'lib/blacklight/search_builder.rb', line 231 def sort search_state.sort_field&.sort end |
#start(value = nil) ⇒ Object Also known as: padding
164 165 166 167 168 169 170 171 172 173 |
# File 'lib/blacklight/search_builder.rb', line 164 def start(value = nil) if value self.start = value return self end @start ||= (page - 1) * (rows || 10) val = @start || 0 val = 0 if @start < 0 val end |
#start=(value) ⇒ Object
158 159 160 161 |
# File 'lib/blacklight/search_builder.rb', line 158 def start=(value) params_will_change! @start = value.to_i end |
#to_hash ⇒ Blacklight::Solr::Response Also known as: query, to_h
a solr query method
120 121 122 123 124 125 126 127 |
# File 'lib/blacklight/search_builder.rb', line 120 def to_hash return @params unless params_need_update? @params = processed_parameters .reverse_merge(@reverse_merged_params) .merge(@merged_params) .tap { clear_changes } end |
#where(conditions) ⇒ Object
Update the :q (query) parameter
52 53 54 55 56 57 58 |
# File 'lib/blacklight/search_builder.rb', line 52 def where(conditions) params_will_change! @search_state = @search_state.reset(@search_state.params.merge(q: conditions)) @blacklight_params = @search_state.params @additional_filters = conditions self end |
#with(blacklight_params_or_search_state = {}) ⇒ Object
Set the parameters to pass through the processor chain
40 41 42 43 44 45 |
# File 'lib/blacklight/search_builder.rb', line 40 def with(blacklight_params_or_search_state = {}) params_will_change! @search_state = blacklight_params_or_search_state.is_a?(Blacklight::SearchState) ? blacklight_params_or_search_state : @search_state.reset(blacklight_params_or_search_state) @blacklight_params = @search_state.params.dup self end |