Welcome to mirror list, hosted at ThFree Co, Russian Federation.

gitlab.com/gitlab-org/gitlab-foss.git - Unnamed repository; edit this file 'description' to name the repository.
summaryrefslogtreecommitdiff
diff options
context:
space:
mode:
Diffstat (limited to 'lib/gitlab/config/entry/legacy_validation_helpers.rb')
-rw-r--r--lib/gitlab/config/entry/legacy_validation_helpers.rb34
1 files changed, 26 insertions, 8 deletions
diff --git a/lib/gitlab/config/entry/legacy_validation_helpers.rb b/lib/gitlab/config/entry/legacy_validation_helpers.rb
index 0a629075302..415f6f77214 100644
--- a/lib/gitlab/config/entry/legacy_validation_helpers.rb
+++ b/lib/gitlab/config/entry/legacy_validation_helpers.rb
@@ -6,17 +6,27 @@ module Gitlab
module LegacyValidationHelpers
private
- def validate_duration(value)
- value.is_a?(String) && ChronicDuration.parse(value)
+ def validate_duration(value, parser = nil)
+ return false unless value.is_a?(String)
+
+ if parser && parser.respond_to?(:validate_duration)
+ parser.validate_duration(value)
+ else
+ ChronicDuration.parse(value)
+ end
rescue ChronicDuration::DurationParseError
false
end
- def validate_duration_limit(value, limit)
+ def validate_duration_limit(value, limit, parser = nil)
return false unless value.is_a?(String)
- ChronicDuration.parse(value).second.from_now <
- ChronicDuration.parse(limit).second.from_now
+ if parser && parser.respond_to?(:validate_duration_limit)
+ parser.validate_duration_limit(value, limit)
+ else
+ ChronicDuration.parse(value).second.from_now <
+ ChronicDuration.parse(limit).second.from_now
+ end
rescue ChronicDuration::DurationParseError
false
end
@@ -30,10 +40,18 @@ module Gitlab
end
def validate_variables(variables)
+ variables.is_a?(Hash) && variables.flatten.all?(&method(:validate_alphanumeric))
+ end
+
+ def validate_array_value_variables(variables)
variables.is_a?(Hash) &&
- variables.flatten.all? do |value|
- validate_string(value) || validate_integer(value)
- end
+ variables.keys.all?(&method(:validate_alphanumeric)) &&
+ variables.values.all?(&:present?) &&
+ variables.values.flatten(1).all?(&method(:validate_alphanumeric))
+ end
+
+ def validate_alphanumeric(value)
+ validate_string(value) || validate_integer(value)
end
def validate_integer(value)