Sha256: bd455c577af88efe4f9655f484b79f64c708ed37b1d8e6da97b983fa152c3ca2
Contents?: true
Size: 1.64 KB
Versions: 2
Compression:
Stored size: 1.64 KB
Contents
require 'rein/util' module Rein module Constraint # This module contains methods for defining length constraints. module Length OPERATORS = { greater_than: :>, greater_than_or_equal_to: :>=, equal_to: :"=", not_equal_to: :"!=", less_than: :<, less_than_or_equal_to: :<= }.freeze def add_length_constraint(*args) reversible do |dir| dir.up do _add_length_constraint(*args) end dir.down { _remove_length_constraint(*args) } end end def remove_length_constraint(*args) reversible do |dir| dir.up do _remove_length_constraint(*args) end dir.down { _add_length_constraint(*args) } end end private def _add_length_constraint(table, attribute, options = {}) name = Util.constraint_name(table, attribute, 'length', options) table = Util.wrap_identifier(table) attribute = Util.wrap_identifier(attribute) attribute_length = "length(#{attribute})" conditions = OPERATORS.slice(*options.keys).map { |key, operator| value = options[key] [attribute_length, operator, value].join(' ') }.join(' AND ') conditions = Util.conditions_with_if(conditions, options) execute("ALTER TABLE #{table} ADD CONSTRAINT #{name} CHECK (#{conditions})") end def _remove_length_constraint(table, attribute, options = {}) name = Util.constraint_name(table, attribute, 'length', options) table = Util.wrap_identifier(table) execute("ALTER TABLE #{table} DROP CONSTRAINT #{name}") end end end end
Version data entries
2 entries across 2 versions & 1 rubygems
Version | Path |
---|---|
rein-3.5.0 | lib/rein/constraint/length.rb |
rein-3.4.0 | lib/rein/constraint/length.rb |