Class: Tram::Policy
- Inherits:
-
Object
- Object
- Tram::Policy
- Extended by:
- Dry::Initializer
- Defined in:
- lib/tram/policy.rb,
lib/tram/policy/error.rb,
lib/tram/policy/errors.rb,
lib/tram/policy/generator.rb,
lib/tram/policy/inflector.rb,
lib/tram/policy/validator.rb,
lib/tram/policy/validation_error.rb
Overview
Base class for policy objects with composable validation errors
Defined Under Namespace
Modules: Inflector Classes: Error, Errors, Generator, ValidationError, Validator
Class Method Summary collapse
-
.[](*args) ⇒ Tram::Policy
Policy constructor/validator (alias for [.new]).
-
.validate(name, opts) ⇒ self
Registers a validator.
Instance Method Summary collapse
-
#errors ⇒ Tram::Policy::Errors
Collection of validation errors.
-
#inspect ⇒ String
Human-readable representation of the policy.
-
#invalid?(&filter) ⇒ Boolean
Checks whether the policy is invalid.
-
#t(message, options = {}) ⇒ String
Translates a message in the scope of current policy.
-
#valid?(&filter) ⇒ Boolean
Checks whether the policy is valid.
-
#validate!(&filter) ⇒ nil
Raises exception if the policy is not valid.
Class Method Details
.[](*args) ⇒ Tram::Policy
Policy constructor/validator (alias for [.new])
34 35 36 |
# File 'lib/tram/policy.rb', line 34 def [](*args) new(*args) end |
.validate(name, opts) ⇒ self
Registers a validator
24 25 26 27 |
# File 'lib/tram/policy.rb', line 24 def validate(name = nil, **opts, &block) local << Validator.new(scope, name, block, opts) self end |
Instance Method Details
#errors ⇒ Tram::Policy::Errors
Collection of validation errors
68 69 70 |
# File 'lib/tram/policy.rb', line 68 def errors @errors ||= Errors.new(self) end |
#inspect ⇒ String
Human-readable representation of the policy
108 109 110 |
# File 'lib/tram/policy.rb', line 108 def inspect "#<#{self.class.name}[#{@__options__}]>" end |
#invalid?(&filter) ⇒ Boolean
Checks whether the policy is invalid
86 87 88 |
# File 'lib/tram/policy.rb', line 86 def invalid?(&filter) filter ? errors.any?(&filter) : errors.any? end |
#t(message, options = {}) ⇒ String
Translates a message in the scope of current policy
59 60 61 62 |
# File 'lib/tram/policy.rb', line 59 def t(, = {}) return .to_s unless .is_a? Symbol I18n.t , .merge(scope: @__scope__) end |
#valid?(&filter) ⇒ Boolean
Checks whether the policy is valid
77 78 79 |
# File 'lib/tram/policy.rb', line 77 def valid?(&filter) filter ? errors.reject(&filter).empty? : errors.empty? end |
#validate!(&filter) ⇒ nil
Raises exception if the policy is not valid
96 97 98 |
# File 'lib/tram/policy.rb', line 96 def validate!(&filter) raise ValidationError.new(self, filter) unless valid?(&filter) end |