Module: Mongoid::Validatable::ClassMethods

Defined in:
build/mongoid-7.4/lib/mongoid/validatable.rb

Instance Method Summary collapse

Instance Method Details

#validates_relation(association) ⇒ Object

Adds an associated validator for the association if the validate option was not provided or set to true.

Examples:

Set up validation.

Person.validates_relation(association)

Parameters:

  • association (Association)

    The association metadata.



120
121
122
123
124
# File 'build/mongoid-7.4/lib/mongoid/validatable.rb', line 120

def validates_relation(association)
  if association.validate?
    validates_associated(association.name)
  end
end

#validates_with(*args, &block) ⇒ Object

Note:

See ActiveModel::Validations::With for full options. This is overridden to add autosave functionality when presence validation is added.

Add validation with the supplied validators for the provided fields with options.

Examples:

Validate with a specific validator.

validates_with MyValidator, on: :create

Parameters:

  • args (Class<Array>, Hash)

    The validator classes and options.



137
138
139
140
141
142
143
144
145
146
147
# File 'build/mongoid-7.4/lib/mongoid/validatable.rb', line 137

def validates_with(*args, &block)
  if args.first == PresenceValidator
    args.last[:attributes].each do |name|
      association = relations[name.to_s]
      if association && association.autosave?
        Association::Referenced::AutoSave.define_autosave!(association)
      end
    end
  end
  super
end

#validating_with_query?true, false

Are we currently performing a validation that has a query?

Examples:

Are we validating with a query?

Model.validating_with_query?

Returns:

  • (true, false)

    If we are validating with a query.



155
156
157
# File 'build/mongoid-7.4/lib/mongoid/validatable.rb', line 155

def validating_with_query?
  Threaded.executing?("#{name}-validate-with-query")
end