Class: Grape::Validations::Base
- Inherits:
-
Object
- Object
- Grape::Validations::Base
- Defined in:
- lib/grape/validations/validators/base.rb
Direct Known Subclasses
AllowBlankValidator, AsValidator, CoerceValidator, DefaultValidator, ExceptValuesValidator, MultipleParamsBase, PresenceValidator, RegexpValidator, SameAsValidator, ValuesValidator
Instance Attribute Summary collapse
-
#attrs ⇒ Object
readonly
Returns the value of attribute attrs.
Class Method Summary collapse
Instance Method Summary collapse
- #fail_fast? ⇒ Boolean
-
#initialize(attrs, options, required, scope, opts = {}) ⇒ Base
constructor
Creates a new Validator from options specified by a
requires
oroptional
directive during parameter definition. - #message(default_key = nil) ⇒ Object
- #options_key?(key, options = nil) ⇒ Boolean
-
#validate(request) ⇒ void
Validates a given request.
-
#validate!(params) ⇒ void
Validates a given parameter hash.
Constructor Details
#initialize(attrs, options, required, scope, opts = {}) ⇒ Base
Creates a new Validator from options specified by a requires
or optional
directive during parameter definition.
16 17 18 19 20 21 22 23 |
# File 'lib/grape/validations/validators/base.rb', line 16 def initialize(attrs, , required, scope, opts = {}) @attrs = Array(attrs) @option = @required = required @scope = scope @fail_fast = opts[:fail_fast] || false @allow_blank = opts[:allow_blank] || false end |
Instance Attribute Details
#attrs ⇒ Object (readonly)
Returns the value of attribute attrs.
6 7 8 |
# File 'lib/grape/validations/validators/base.rb', line 6 def attrs @attrs end |
Class Method Details
.convert_to_short_name(klass) ⇒ Object
61 62 63 64 65 66 67 68 |
# File 'lib/grape/validations/validators/base.rb', line 61 def self.convert_to_short_name(klass) ret = klass.name.gsub(/::/, '/') ret.gsub!(/([A-Z]+)([A-Z][a-z])/, '\1_\2') ret.gsub!(/([a-z\d])([A-Z])/, '\1_\2') ret.tr!('-', '_') ret.downcase! File.basename(ret, '_validator') end |
.inherited(klass) ⇒ Object
70 71 72 73 |
# File 'lib/grape/validations/validators/base.rb', line 70 def self.inherited(klass) return unless klass.name.present? Validations.register_validator(convert_to_short_name(klass), klass) end |
Instance Method Details
#fail_fast? ⇒ Boolean
85 86 87 |
# File 'lib/grape/validations/validators/base.rb', line 85 def fail_fast? @fail_fast end |
#message(default_key = nil) ⇒ Object
75 76 77 78 |
# File 'lib/grape/validations/validators/base.rb', line 75 def (default_key = nil) = instance_variable_get(:@option) (:message) ? [:message] : default_key end |
#options_key?(key, options = nil) ⇒ Boolean
80 81 82 83 |
# File 'lib/grape/validations/validators/base.rb', line 80 def (key, = nil) = instance_variable_get(:@option) if .nil? .respond_to?(:key?) && .key?(key) && ![key].nil? end |
#validate(request) ⇒ void
Override #validate! unless you need to access the entire request.
This method returns an undefined value.
Validates a given request.
30 31 32 33 |
# File 'lib/grape/validations/validators/base.rb', line 30 def validate(request) return unless @scope.should_validate?(request.params) validate!(request.params) end |
#validate!(params) ⇒ void
Override #validate if you need to access the entire request.
This method returns an undefined value.
Validates a given parameter hash.
40 41 42 43 44 45 46 47 48 49 50 51 52 53 54 55 56 57 58 59 |
# File 'lib/grape/validations/validators/base.rb', line 40 def validate!(params) attributes = SingleAttributeIterator.new(self, @scope, params) # we collect errors inside array because # there may be more than one error per field array_errors = [] attributes.each do |val, attr_name, empty_val| next if !@scope.required? && empty_val next unless @scope.meets_dependency?(val, params) begin if @required || val.respond_to?(:key?) && val.key?(attr_name) validate_param!(attr_name, val) end rescue Grape::Exceptions::Validation => e array_errors << e end end raise Grape::Exceptions::ValidationArrayErrors, array_errors if array_errors.any? end |