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 = nil, **opts, &block) ⇒ 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])
32 33 34 |
# File 'lib/tram/policy.rb', line 32 def [](*args) new(*args) end |
.validate(name = nil, **opts, &block) ⇒ self
Registers a validator
22 23 24 25 |
# File 'lib/tram/policy.rb', line 22 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
66 67 68 |
# File 'lib/tram/policy.rb', line 66 def errors @errors ||= Errors.new(self) end |
#inspect ⇒ String
Human-readable representation of the policy
106 107 108 |
# File 'lib/tram/policy.rb', line 106 def inspect "#<#{self.class.name}[#{@__options__}]>" end |
#invalid?(&filter) ⇒ Boolean
Checks whether the policy is invalid
84 85 86 |
# File 'lib/tram/policy.rb', line 84 def invalid?(&filter) filter ? errors.any?(&filter) : errors.any? end |
#t(message, **options) ⇒ String
Translates a message in the scope of current policy
57 58 59 60 |
# File 'lib/tram/policy.rb', line 57 def t(, **) return .to_s unless .is_a? Symbol I18n.t , .merge(scope: @__scope__) end |
#valid?(&filter) ⇒ Boolean
Checks whether the policy is valid
75 76 77 |
# File 'lib/tram/policy.rb', line 75 def valid?(&filter) filter ? errors.reject(&filter).empty? : errors.empty? end |
#validate!(&filter) ⇒ nil
Raises exception if the policy is not valid
94 95 96 |
# File 'lib/tram/policy.rb', line 94 def validate!(&filter) raise ValidationError.new(self, filter) unless valid?(&filter) end |