2018-12-05 23:21:45 +05:30
|
|
|
# frozen_string_literal: true
|
|
|
|
|
2017-08-17 22:00:37 +05:30
|
|
|
module API
|
|
|
|
module Helpers
|
|
|
|
module CustomValidators
|
|
|
|
class Absence < Grape::Validations::Base
|
|
|
|
def validate_param!(attr_name, params)
|
|
|
|
return if params.respond_to?(:key?) && !params.key?(attr_name)
|
2018-03-17 18:26:18 +05:30
|
|
|
|
2017-08-17 22:00:37 +05:30
|
|
|
raise Grape::Exceptions::Validation, params: [@scope.full_name(attr_name)], message: message(:absence)
|
|
|
|
end
|
|
|
|
end
|
2018-12-13 13:39:08 +05:30
|
|
|
|
|
|
|
class IntegerNoneAny < Grape::Validations::Base
|
|
|
|
def validate_param!(attr_name, params)
|
|
|
|
value = params[attr_name]
|
|
|
|
|
|
|
|
return if value.is_a?(Integer) ||
|
|
|
|
[IssuableFinder::FILTER_NONE, IssuableFinder::FILTER_ANY].include?(value.to_s.downcase)
|
|
|
|
|
|
|
|
raise Grape::Exceptions::Validation, params: [@scope.full_name(attr_name)],
|
|
|
|
message: "should be an integer, 'None' or 'Any'"
|
|
|
|
end
|
|
|
|
end
|
2019-05-18 00:54:41 +05:30
|
|
|
|
|
|
|
class ArrayNoneAny < Grape::Validations::Base
|
|
|
|
def validate_param!(attr_name, params)
|
|
|
|
value = params[attr_name]
|
|
|
|
|
|
|
|
return if value.is_a?(Array) ||
|
|
|
|
[IssuableFinder::FILTER_NONE, IssuableFinder::FILTER_ANY].include?(value.to_s.downcase)
|
|
|
|
|
|
|
|
raise Grape::Exceptions::Validation, params: [@scope.full_name(attr_name)],
|
|
|
|
message: "should be an array, 'None' or 'Any'"
|
|
|
|
end
|
|
|
|
end
|
2017-08-17 22:00:37 +05:30
|
|
|
end
|
|
|
|
end
|
|
|
|
end
|
|
|
|
|
|
|
|
Grape::Validations.register_validator(:absence, ::API::Helpers::CustomValidators::Absence)
|
2018-12-13 13:39:08 +05:30
|
|
|
Grape::Validations.register_validator(:integer_none_any, ::API::Helpers::CustomValidators::IntegerNoneAny)
|
2019-05-18 00:54:41 +05:30
|
|
|
Grape::Validations.register_validator(:array_none_any, ::API::Helpers::CustomValidators::ArrayNoneAny)
|