Sha256: b345cd82a712f2b384c7466a9c147a384c861558b0599df92254870208c5fb1d
Contents?: true
Size: 1.63 KB
Versions: 1
Compression:
Stored size: 1.63 KB
Contents
# -*- encoding : utf-8 -*- class Hash def symbolize_keys! inject({}) do |options, (key, value)| options[(key.to_sym rescue key) || key] = value options end end def recursive_symbolize_keys! inject({}) do |options, (key, value)| options[(key.to_sym rescue key) || key] = value.is_a?( Hash ) ? value.recursive_symbolize_keys! : value options end end # Allows you to convert a hash to an array suitable for use in an ActiveRecord finder conditions clause # # @allowed_keys optional an array of param names to include - if given, any keys NOT in this array will be excluded # @column_aliases optional a hash of param name => column name mappings, for the case where the param name needs mapping to an alternative column name # e.g. # {:fish=>'trout', :cheese=>'gruyere', :rodent=>'vole'}.to_conditions( [:fish, :cheese], {:cheese=>:fromage}) # => ["(fish = ?) AND (fromage = ?)", 'trout', 'gruyere'] def to_conditions( allowed_keys, column_aliases={} ) conds = [ [] ] allowed_keys ||= keys allowed_keys.to_a.each do |k| this_key = ( keys.include?(k.to_sym) ? k.to_sym : (keys.include?(k.to_s) ? k.to_s : nil)) next unless this_key next if self[this_key].blank? conds[0] << "#{column_aliases[this_key.to_sym] ? column_aliases[this_key.to_sym] : this_key.to_s} = ?" conds << self[this_key] end conds[0] = conds[0].map{ |c| "(#{c})" }.join( " AND " ) conds end # # The way bindings work in ruby 1.9+ has changed so add this to work for both # 1.8 and 1.9 # def get_binding return binding end end
Version data entries
1 entries across 1 versions & 1 rubygems
Version | Path |
---|---|
itrigga-core_ext-1.0.0 | lib/itrigga/core_ext/hash.rb |