class PgSearch::Configuration
def alias(*strings)
def alias(*strings) name = Array(strings).compact.join("_") # By default, PostgreSQL limits names to 32 characters, so we hash and limit to 32 characters. "pg_search_#{Digest::SHA2.hexdigest(name)}"[0,32] end
def assert_valid_options(options)
def assert_valid_options(options) unless options[:against] || options[:associated_against] raise ArgumentError, "the search scope #{@name} must have :against#{" or :associated_against" if defined?(ActiveRecord::Relation)} in its options" end if options[:associated_against] && !defined?(ActiveRecord::Relation) raise ArgumentError, ":associated_against requires Active Record 3 or later" end options.assert_valid_keys(VALID_KEYS) VALID_VALUES.each do |key, values_for_key| Array(options[key]).each do |value| unless values_for_key.include?(value) raise ArgumentError, ":#{key} cannot accept #{value}" end end end end
def associated_columns
def associated_columns associations.map(&:columns).flatten end
def associations
def associations return [] unless options[:associated_against] options[:associated_against].map do |association, column_names| Association.new(model, association, column_names) end.flatten end
def columns
def columns regular_columns + associated_columns end
def default_options
def default_options {:using => :tsearch} end
def features
def features Array(options[:using]) end
def ignore
def ignore Array(options[:ignoring]) end
def initialize(options, model)
def initialize(options, model) @options = default_options.merge(options) @model = model assert_valid_options(@options) end
def order_within_rank
def order_within_rank options[:order_within_rank] end
def postgresql_version
def postgresql_version model.connection.send(:postgresql_version) end
def query
def query options[:query].to_s end
def ranking_sql
def ranking_sql options[:ranked_by] end
def regular_columns
def regular_columns return [] unless options[:against] Array(options[:against]).map do |column_name, weight| Column.new(column_name, weight, model) end end