Class: DataMapper::Validate::GenericValidator

Inherits:
Object
  • Object
show all
Defined in:
lib/dm-validations/generic_validator.rb

Overview

All validators extend this base class. Validators must:

  • Implement the initialize method to capture its parameters, also calling super to have this parent class capture the optional, general :if and :unless parameters.

  • Implement the call method, returning true or false. The call method provides the validation logic.

Author:

  • Guy van den Berg

Since:

  • 0.9

Instance Attribute Summary collapse

Instance Method Summary collapse

Constructor Details

#initialize(field, opts = {}) ⇒ GenericValidator

Construct a validator. Capture the :if and :unless clauses when present.

All additional key/value pairs are passed through to the validator that is sub-classing this GenericValidator

Parameters:

  • field (String, Symbol)

    The property specified for validation

  • :if<Symbol, (Hash)

    a customizable set of options

  • :unless<Symbol, (Hash)

    a customizable set of options

Since:

  • 0.9



30
31
32
33
# File 'lib/dm-validations/generic_validator.rb', line 30

def initialize(field, opts = {})
  @if_clause = opts.has_key?(:if) ? opts[:if] : nil
  @unless_clause = opts.has_key?(:unless) ? opts[:unless] : nil
end

Instance Attribute Details

#if_clauseObject

Since:

  • 0.9



16
17
18
# File 'lib/dm-validations/generic_validator.rb', line 16

def if_clause
  @if_clause
end

#unless_clauseObject

Since:

  • 0.9



17
18
19
# File 'lib/dm-validations/generic_validator.rb', line 17

def unless_clause
  @unless_clause
end

Instance Method Details

#==(other) ⇒ Object

Since:

  • 0.9



89
90
91
92
93
94
95
96
# File 'lib/dm-validations/generic_validator.rb', line 89

def ==(other)
  self.class == other.class &&
  self.field_name == other.field_name &&
  self.class == other.class &&
  self.if_clause == other.if_clause &&
  self.unless_clause == other.unless_clause &&
  self.instance_variable_get(:@options) == other.instance_variable_get(:@options)
end

#add_error(target, message, field_name = :general) ⇒ Object

Add an error message to a target resource. If the error corresponds to a specific field of the resource, add it to that field, otherwise add it as a :general message.

TODO - should the field_name for a general message be :default???

Parameters:

  • target (Object)

    the resource that has the error

  • message (String)

    the message to add

  • field_name (Symbol) (defaults to: :general)

    the name of the field that caused the error

Since:

  • 0.9



45
46
47
# File 'lib/dm-validations/generic_validator.rb', line 45

def add_error(target, message, field_name = :general)
  target.errors.add(field_name,message)
end

#call(target) ⇒ Boolean

Call the validator. “call” is used so the operation is BoundMethod and Block compatible. This must be implemented in all concrete classes.

Parameters:

  • target (Object)

    the resource that the validator must be called against

Returns:

  • (Boolean)

    true if valid, otherwise false

Since:

  • 0.9



55
56
57
# File 'lib/dm-validations/generic_validator.rb', line 55

def call(target)
  raise "DataMapper::Validate::GenericValidator::call must be overriden in #{self.class.to_s}"
end

#execute?(target) ⇒ Boolean

Determines if this validator should be run against the target by evaluating the :if and :unless clauses optionally passed while specifying any validator.

Parameters:

  • target (Object)

    the resource that we check against

Returns:

  • (Boolean)

    true if should be run, otherwise false

Since:

  • 0.9



69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
# File 'lib/dm-validations/generic_validator.rb', line 69

def execute?(target)
  if unless_clause = self.unless_clause
    if unless_clause.is_a?(Symbol)
      return false if target.send(unless_clause)
    elsif unless_clause.respond_to?(:call)
      return false if unless_clause.call(target)
    end
  end

  if if_clause = self.if_clause
    if if_clause.is_a?(Symbol)
      return target.send(if_clause)
    elsif if_clause.respond_to?(:call)
      return if_clause.call(target)
    end
  end

  true
end

#field_nameObject

Since:

  • 0.9



59
60
61
# File 'lib/dm-validations/generic_validator.rb', line 59

def field_name
  @field_name
end