Class: PDK::CLI::Util::OptionValidator
- Inherits:
-
Object
- Object
- PDK::CLI::Util::OptionValidator
- Defined in:
- lib/pdk/cli/util/option_validator.rb
Class Method Summary collapse
- .comma_separated_list?(list, _options = {}) ⇒ Boolean
- .enum(val, valid_entries, _options = {}) ⇒ Object
-
.valid_fact_name?(name) ⇒ Boolean
True if the fact name is valid.
-
.valid_module_name?(string) ⇒ Boolean
Validate the module name against the regular expression in the documentation: docs.puppet.com/puppet/4.10/modules_fundamentals.html#allowed-module-names.
-
.valid_namespace?(string) ⇒ Boolean
Validate a Puppet namespace against the regular expression in the documentation: docs.puppet.com/puppet/4.10/lang_reserved.html#classes-and-defined-resource-types.
-
.valid_param_name?(string) ⇒ Boolean
Validate that a class/defined type parameter matches the regular expression in the documentation: docs.puppet.com/puppet/4.10/lang_reserved.html#parameters The parameter should also not be a reserved word or overload a metaparameter.
Class Method Details
.comma_separated_list?(list, _options = {}) ⇒ Boolean
7 8 9 |
# File 'lib/pdk/cli/util/option_validator.rb', line 7 def self.comma_separated_list?(list, = {}) (list =~ %r{^[\w\-]+(?:,[\w\-]+)+$}) ? true : false end |
.enum(val, valid_entries, _options = {}) ⇒ Object
16 17 18 19 20 21 22 23 24 25 |
# File 'lib/pdk/cli/util/option_validator.rb', line 16 def self.enum(val, valid_entries, = {}) vals = val.is_a?(Array) ? val : [val] invalid_entries = vals.reject { |e| valid_entries.include?(e) } unless invalid_entries.empty? raise ArgumentError, _('Error: the following values are invalid: %{invalid_entries}') % { invalid_entries: invalid_entries } end val end |
.valid_fact_name?(name) ⇒ Boolean
Returns true if the fact name is valid.
12 13 14 |
# File 'lib/pdk/cli/util/option_validator.rb', line 12 def self.valid_fact_name?(name) name.length > 1 end |
.valid_module_name?(string) ⇒ Boolean
Validate the module name against the regular expression in the documentation: docs.puppet.com/puppet/4.10/modules_fundamentals.html#allowed-module-names
29 30 31 |
# File 'lib/pdk/cli/util/option_validator.rb', line 29 def self.valid_module_name?(string) !(string =~ %r{\A[a-z][a-z0-9_]*\Z}).nil? end |
.valid_namespace?(string) ⇒ Boolean
Validate a Puppet namespace against the regular expression in the documentation: docs.puppet.com/puppet/4.10/lang_reserved.html#classes-and-defined-resource-types
44 45 46 47 48 |
# File 'lib/pdk/cli/util/option_validator.rb', line 44 def self.valid_namespace?(string) return false if (string || '').split('::').last == 'init' !(string =~ %r{\A([a-z][a-z0-9_]*)(::[a-z][a-z0-9_]*)*\Z}).nil? end |
.valid_param_name?(string) ⇒ Boolean
Validate that a class/defined type parameter matches the regular expression in the documentation: docs.puppet.com/puppet/4.10/lang_reserved.html#parameters The parameter should also not be a reserved word or overload a metaparameter.
58 59 60 61 62 63 64 |
# File 'lib/pdk/cli/util/option_validator.rb', line 58 def self.valid_param_name?(string) reserved_words = %w[trusted facts server_facts title name].freeze = %w[alias audit before loglevel noop notify require schedule stage subscribe tag].freeze return false if reserved_words.include?(string) || .include?(string) !(string =~ %r{\A[a-z][a-zA-Z0-9_]*\Z}).nil? end |