Sha256: f5681b42b8580bc74e4524943b16fb6a7004b5940c700ae067d745421eb2ea94
Contents?: true
Size: 1.9 KB
Versions: 1
Compression:
Stored size: 1.9 KB
Contents
module RecordFilter module Restrictions class Base def initialize(column_name, value, options={}) @column_name, @value, @negated = column_name, value, !!options.delete(:negated) @value = @value.id if @value.kind_of?(ActiveRecord::Base) end def to_conditions @value.nil? ? [to_sql] : [to_sql, @value] end def to_sql @negated ? to_negative_sql : to_positive_sql end def to_negative_sql "!(#{to_positive_sql})" end def self.class_from_operator(operator) "RecordFilter::Restrictions::#{operator.to_s.camelize}".constantize end end class EqualTo < Base def to_positive_sql "#{@column_name} = ?" end def to_negative_sql "#{@column_name} != ?" end end class IsNull < Base def to_positive_sql "#{@column_name} IS NULL" end def to_negative_sql "#{@column_name} IS NOT NULL" end end class LessThan < Base def to_positive_sql "#{@column_name} < ?" end end class LessThanOrEqualTo < Base def to_positive_sql "#{@column_name} <= ?" end end class GreaterThan < Base def to_positive_sql "#{@column_name} > ?" end end class GreaterThanOrEqualTo < Base def to_positive_sql "#{@column_name} >= ?" end end class In < Base def to_positive_sql "#{@column_name} IN (?)" end def to_negative_sql "#{@column_name} NOT IN (?)" end end class Between < Base def to_conditions ["#{@column_name} #{'NOT ' if @negated}BETWEEN ? AND ?", @value.first, @value.last] end end class Like < Base def to_positive_sql "#{@column_name} LIKE ?" end def to_negative_sql "#{@column_name} NOT LIKE ?" end end end end
Version data entries
1 entries across 1 versions & 1 rubygems
Version | Path |
---|---|
aub-record_filter-0.1.4 | lib/record_filter/restrictions.rb |