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)}".first(32) end
def assert_valid_options(options)
def assert_valid_options(options) unless options[:against] || options[:associated_against] || using_tsvector_column?(options[:using]) raise( ArgumentError, "the search scope #{@name} must have :against, :associated_against, or :tsvector_column in its options" ) end options.assert_valid_keys(VALID_KEYS) VALID_VALUES.each do |key, values_for_key| Array(options[key]).each do |value| raise ArgumentError, ":#{key} cannot accept #{value}" unless values_for_key.include?(value) 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 feature_options
def feature_options @feature_options ||= {}.tap do |hash| features.map do |feature_name, feature_options| hash[feature_name] = feature_options end end 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 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
def using_tsvector_column?(options)
def using_tsvector_column?(options) return unless options.is_a?(Hash) options.dig(:dmetaphone, :tsvector_column).present? || options.dig(:tsearch, :tsvector_column).present? end