Class: Devise::ParamFilter

Inherits:
Object
  • Object
show all
Defined in:
lib/devise/param_filter.rb

Instance Method Summary collapse

Constructor Details

#initialize(case_insensitive_keys, strip_whitespace_keys) ⇒ ParamFilter

Returns a new instance of ParamFilter.



3
4
5
6
# File 'lib/devise/param_filter.rb', line 3

def initialize(case_insensitive_keys, strip_whitespace_keys)
  @case_insensitive_keys = case_insensitive_keys || []
  @strip_whitespace_keys = strip_whitespace_keys || []
end

Instance Method Details

#filter(conditions) ⇒ Object



8
9
10
11
12
13
14
15
# File 'lib/devise/param_filter.rb', line 8

def filter(conditions)
  conditions = stringify_params(conditions.dup)

  conditions.merge!(filtered_hash_by_method_for_given_keys(conditions.dup, :downcase, @case_insensitive_keys))
  conditions.merge!(filtered_hash_by_method_for_given_keys(conditions.dup, :strip, @strip_whitespace_keys))

  conditions
end

#filtered_hash_by_method_for_given_keys(conditions, method, condition_keys) ⇒ Object



17
18
19
20
21
22
23
24
# File 'lib/devise/param_filter.rb', line 17

def filtered_hash_by_method_for_given_keys(conditions, method, condition_keys)
  condition_keys.each do |k|
    value = conditions[k]
    conditions[k] = value.send(method) if value.respond_to?(method)
  end

  conditions
end

#stringify_params(conditions) ⇒ Object

Force keys to be string to avoid injection on mongoid related database.



27
28
29
30
31
32
# File 'lib/devise/param_filter.rb', line 27

def stringify_params(conditions)
  return conditions unless conditions.is_a?(Hash)
  conditions.each do |k, v|
    conditions[k] = v.to_s if param_requires_string_conversion?(v)
  end
end