Class: StringSettingValidator
Instance Method Summary
collapse
#initialize_regex_opts, #regex_match?
Constructor Details
Returns a new instance of StringSettingValidator.
6
7
8
9
|
# File 'lib/validators/string_setting_validator.rb', line 6
def initialize(opts = {})
@opts = opts
initialize_regex_opts(opts)
end
|
Instance Method Details
#error_message ⇒ Object
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
|
# File 'lib/validators/string_setting_validator.rb', line 37
def error_message
if @regex_fail
I18n.t(@regex_error)
elsif @length_fail
if @opts[:min] && @opts[:max]
I18n.t("site_settings.errors.invalid_string_min_max", min: @opts[:min], max: @opts[:max])
elsif @opts[:min]
I18n.t("site_settings.errors.invalid_string_min", count: @opts[:min])
else
I18n.t("site_settings.errors.invalid_string_max", count: @opts[:max])
end
elsif @json_fail
I18n.t("site_settings.errors.invalid_json")
else
I18n.t("site_settings.errors.invalid_string")
end
end
|
#valid_json?(json) ⇒ Boolean
25
26
27
28
29
30
31
32
33
34
35
|
# File 'lib/validators/string_setting_validator.rb', line 25
def valid_json?(json)
begin
JSON.parse(json)
rescue JSON::ParserError => e
@json_fail = true
return false
end
true
end
|
#valid_value?(val) ⇒ Boolean
11
12
13
14
15
16
17
18
19
20
21
22
23
|
# File 'lib/validators/string_setting_validator.rb', line 11
def valid_value?(val)
return true if !val.present?
if (@opts[:min] && @opts[:min].to_i > (val.length)) ||
(@opts[:max] && @opts[:max].to_i < (val.length))
@length_fail = true
return false
end
return valid_json?(val) if (@opts[:json_schema])
regex_match?(val)
end
|