697 lines
29 KiB
YAML
697 lines
29 KiB
YAML
---
|
|
- version: 1.10.0
|
|
summary: This release is mostly about upgrading to dry-core 1.0 and dry-configurable 1.0. One of the outcomes is dropping dependency on dry-container (because it was moved to dry-core). If you happen to use dry-container, please switch to `Dry::Core::Container`.
|
|
date: 2022-11-04
|
|
changed:
|
|
- 'Upgraded to the latest versions of dry-{core,configurable,logic,types} (@flash-gordon + @solnic)'
|
|
- version: 1.9.0
|
|
summary:
|
|
date: 2022-10-15
|
|
fixed:
|
|
- 'Duplicated keys mishandling in rule evaluation (issue #676 fixed via #711) (@mereghost)'
|
|
added:
|
|
changed:
|
|
- 'Use Zeitwerk for auto-loading (via #715) (@solnic)'
|
|
- version: 1.8.1
|
|
summary:
|
|
date: '2022-05-28'
|
|
fixed:
|
|
- 'Raise an InvalidKeyErrors on substring of valid keys (issue #705 fixed via #706)
|
|
(@MatElGran)'
|
|
- 'Using `rule(:arr).each { .. }` doesn''t crash when `:arr` turns out to be `nil`
|
|
(issue #708 fixed via #709) (@bautrey37)'
|
|
added:
|
|
changed:
|
|
- version: 1.8.0
|
|
summary:
|
|
date: '2022-02-17'
|
|
fixed:
|
|
added:
|
|
- 'New rule helper `base_rule_error?` which checks if there''s any base error set
|
|
(via #690) (@wuarmin)'
|
|
changed:
|
|
- Dependency on dry-schema was bumped to 1.9.1 (@solnic)
|
|
- version: 1.7.0
|
|
date: '2021-09-12'
|
|
changed:
|
|
- "[internal] Upgraded to new `setting` API provided in dry-configurable 0.13.0
|
|
(@timriley in #686 and 3f8f7d8)"
|
|
- Bumped dry-schema dependency to 1.8.0 (in part, to ensure dry-configurable 0.13.0
|
|
is available) (@timriley)
|
|
- version: 1.6.0
|
|
summary:
|
|
date: '2020-12-05'
|
|
fixed:
|
|
- 'Checking `key?` within a rule no longer crashes when value is `nil` or an empty
|
|
string (issue #670 fixed via #672) (@alexxty7)'
|
|
added:
|
|
- 'You can now pass a key name or path to `rule_error?` predicate (issue #658 closed
|
|
via #673) (@moofkit)'
|
|
- 'You can now pass initial context object to `Contract#call` (issue #674 via #675)
|
|
(@pyromaniac)'
|
|
changed:
|
|
- version: 1.5.6
|
|
date: '2020-09-04'
|
|
summary:
|
|
fixed:
|
|
- Dependency on dry-schema was bumped to >= 1.5.1. This time for real (@solnic)
|
|
- version: 1.5.5
|
|
date: '2020-09-03'
|
|
summary:
|
|
fixed:
|
|
- 'Dependency on dry-schema was bumped to >= 1.5.2 (see #666 for more info) (@artofhuman)'
|
|
added:
|
|
changed:
|
|
- version: 1.5.4
|
|
summary:
|
|
date: '2020-08-21'
|
|
fixed:
|
|
- 'Full messages work correctly with rule failures now (issue #661 fixed via #662)
|
|
(@stind)'
|
|
- 'Providing a custom message template for array errors works correctly (issue #663
|
|
fixed via #665) (@tadeusz-niemiec)'
|
|
added:
|
|
- 'You can now pass any key or a path to the rule''s `key?` helper (see #664 for
|
|
more info) (@alassek)'
|
|
changed:
|
|
- version: 1.5.3
|
|
summary:
|
|
date: '2020-07-27'
|
|
fixed:
|
|
- 'Using `.each(:foo)` works as expected when there are errors related to other
|
|
keys (issue #659 fixed via #660) (@solnic)'
|
|
added:
|
|
- 'You can now access current value''s index via `rule(:foo).each do |index:|` (issue
|
|
#606 done via #657) (@mrbongiolo)'
|
|
changed:
|
|
- "`Result#error?` is now a public API and it takes into consideration both schema
|
|
and rule errors (issue #655 fixed via #656) (@PragTob)"
|
|
- version: 1.5.2
|
|
summary:
|
|
date: '2020-07-14'
|
|
fixed:
|
|
- "`key?` predicate in rules no longer crashes when the rule path points to a non-existent
|
|
array value (issue #653 fixed via #654) (@solnic)"
|
|
- version: 1.5.1
|
|
date: '2020-06-18'
|
|
fixed:
|
|
- dry-monads no longer required for the `:hints` extension (@schokomarie)
|
|
- 'Using `full: true` option works as expected with custom rule messages (issue
|
|
#618 fixed via #651) (@sirfilip)'
|
|
- 'Using `locale: ...` option works as expected with hints (issue #589 fixed via
|
|
652) (@sirfilip)'
|
|
- version: 1.5.0
|
|
summary:
|
|
date: '2020-03-11'
|
|
fixed:
|
|
added:
|
|
- "`schema_error?` rule helper (@waiting-for-dev)"
|
|
- "`rule_error?` rule helper (@waiting-for-dev)"
|
|
changed:
|
|
- dry-schema dependency was bumped to `~> 1.5` (@solnic)
|
|
- "[internal] `KeyMap` patches have been removed since dry-schema now provides required
|
|
functionality (@solnic)"
|
|
- version: 1.4.2
|
|
date: '2020-01-18'
|
|
fixed:
|
|
- Macros using predicates that accept a range argument work as expected (no need
|
|
to wrap the argument in an array) (@waiting-for-dev)
|
|
- version: 1.4.1
|
|
date: '2020-01-08'
|
|
added:
|
|
- Pattern matching on result values (@flash-gordon)
|
|
fixed:
|
|
- 'List tokens are correctly interpolated as a comma separated list in rule messages
|
|
(see #611) (@waiting-for-dev)'
|
|
- Warnings about delegated keywords (@flash-gordon)
|
|
- version: 1.4.0
|
|
date: '2019-12-12'
|
|
added:
|
|
- Support for multi-schema inheritance (@ianwhite)
|
|
fixed:
|
|
- Keyword warnings reported by Ruby 2.7 (@flash-gordon)
|
|
- Fixed an issue where `MessageSet` would be marked as empty too early (@ianwhite)
|
|
- 'Messages are correctly generated when there are errors for both an array and
|
|
one or more of its elements (see #599) (@Bugagazavr)'
|
|
changed:
|
|
- A meaningful exception is raised when failure options are not valid (@MatElGran)
|
|
- "[internal] improved performance in `Contract.ensure_valid_keys` (@grzegorz-jakubiak)"
|
|
- "[internal] fixed keyword warnings on MRI 2.7.0 (@flash-gordon)"
|
|
- version: 1.3.1
|
|
date: '2019-08-16'
|
|
changed:
|
|
- You can now set an external schema without providing a block (@alassek)
|
|
- version: 1.3.0
|
|
date: '2019-08-14'
|
|
added:
|
|
- 'Support for setting an external schema (that can be extended too) (fixed #574)
|
|
(@solnic)'
|
|
fixed:
|
|
- 'Using a hash spec to define rule keys with more than one value is properly handled
|
|
by rule guard now (fixed #576) (@solnic)'
|
|
changed:
|
|
- "`values` within rules uses `Hash#fetch_values` internally now, which improves
|
|
performance (@esparta)"
|
|
- version: 1.2.1
|
|
date: '2019-07-16'
|
|
fixed:
|
|
- 'Defining an abstract contract class that has no schema no longer crashes (issue
|
|
#565) (@solnic)'
|
|
- 'Fixed an issue where `Rule#each` would crash when the value is not an array (issue
|
|
#567) (@solnic)'
|
|
- 'Fixed an issue where guarding a rule would crash when keys are missing in the
|
|
input (issue #569) (@solnic)'
|
|
- 'Added missing "pathname" require (issue #570) (@solnic)'
|
|
- version: 1.2.0
|
|
date: '2019-07-08'
|
|
added:
|
|
- New extension `:predicates_as_macros` (@waiting-for-dev)
|
|
fixed:
|
|
- 'Guarding rules for nested keys works correctly (issue #560) (@solnic)'
|
|
changed:
|
|
- "`dry-schema` dependency was bumped to `>= 1.3.1` (@solnic)"
|
|
- version: 1.1.1
|
|
date: '2019-06-24'
|
|
fixed:
|
|
- "`Rule#each` works with array values from nested hashes (@mustardnoise)"
|
|
- version: 1.1.0
|
|
date: '2019-06-14'
|
|
added:
|
|
- "`key?` method available within rules, that can be used to check if there's a
|
|
value under the rule's default key (refs #540) (@solnic)"
|
|
- "`value` supports hash-based path specifications now (refs #547) (@solnic)"
|
|
- "`value` can read multiple values when the key points to them, ie in case of `rule(geo:
|
|
[:lat, :lon])` it would return an array with `lat` and `lon` (@solnic)"
|
|
fixed:
|
|
- 'Passing multiple macro names to `validate` or `each` works correctly (fixed #538
|
|
#541) (@jandudulski)'
|
|
- version: 1.0.0
|
|
date: '2019-06-10'
|
|
summary: See [the list of all addressed issues](https://github.com/dry-rb/dry-validation/issues?utf8=✓&q=is%3Aissue+is%3Aclosed+closed%3A%3E%3D2019-01-01+)
|
|
as well as issues that were moved to dry-schema and [addressed there](https://github.com/dry-rb/dry-schema/issues?q=is%3Aissue+is%3Aclosed+dry-validation+milestone%3A1.0.0).
|
|
- version: 1.0.0
|
|
date: '2019-06-10'
|
|
added:
|
|
- Support for defining rules for each element of an array via `rule(:items).each
|
|
{ ... }` (solnic)
|
|
- 'Support for parameterized macros via `rule(:foo).validate(my_macro: :some_option)`
|
|
(solnic)'
|
|
- "`values#[]` is now compatible with path specs (symbol, array with keys or dot-notation)
|
|
(issue #528) (solnic)"
|
|
- "`value` shortcut for accessing the value found under the first key specified
|
|
by a rule. ie `rule(:foo) { value }` returns `values[:foo]` (solnic)"
|
|
fixed:
|
|
- Contract's `config.locale` option was replaced by `config.messages.default_locale`
|
|
to avoid conflicts with run-time `:locale` option and/or whatever is set via `I18n`
|
|
gem (solnic)
|
|
- Macros no longer mutate `Dry::Validation::Contract.macros` when using inheritance
|
|
(solnic)
|
|
- Missing dependency on `dry-container` was added (solnic)
|
|
changed:
|
|
- "`rule` will raise `InvalidKeysError` when specified keys are not defined by the
|
|
schema (solnic)"
|
|
- "`Contract.new` will raise `SchemaMissingError` when the class doesn't have schema
|
|
defined (solnic)"
|
|
- 'Contracts no longer support `:locale` option in the constructor. Use `Result#errors(locale:
|
|
:pl)` to change locale at run-time (solnic)'
|
|
- version: 1.0.0.rc3
|
|
date: '2019-05-06'
|
|
added:
|
|
- "[EXPERIMENTAL] `Validation.register_macro` for registering global macros (solnic)"
|
|
- "[EXPERIMENTAL] `Contract.register_macro` for registering macros available to
|
|
specific contract classes (solnic)"
|
|
- "`Dry::Validation.Contract` shortcut for quickly defining a contract and getting
|
|
its instance back (solnic)"
|
|
- New configuration option `config.locale` for setting the default locale (solnic)
|
|
fixed:
|
|
- "`config/errors.yml` are now bundled with the gem, **`rc2` was broken because
|
|
of this** (solnic)"
|
|
- version: 1.0.0.rc2
|
|
date: '2019-05-04'
|
|
summary: This was **yanked** on rubygems.org because the bundled gem was missing
|
|
`config` directory, thus it was not possible to require it. It was fixed in `rc3`.
|
|
added:
|
|
- "[EXPERIMENTAL] support for registering macros via `Dry::Validation::Macros.register(:your_macro,
|
|
&block)` (solnic)"
|
|
- "[EXPERIMENTAL] `:acceptance` as the first built-in macro (issue #157) (solnic)"
|
|
fixed:
|
|
- Passing invalid argument to `failure` will raise a meaningful error instead of
|
|
crashing (solnic)
|
|
changed:
|
|
- In rule validation blocks, `values` is now an instance of a hash-like `Dry::Validation::Values`
|
|
class, rather than `Dry::Schema::Result`. This gives more convenient access to
|
|
data within rules (solnic)
|
|
- Dependency on `dry-schema` was updated to `~> 1.0` (solnic)
|
|
- version: 1.0.0.rc1
|
|
date: '2019-04-26'
|
|
added:
|
|
- "`:hints` extension is back (solnic)"
|
|
- "`Result` objects have access to the context object which is shared between rules
|
|
(flash-gordon)"
|
|
fixed:
|
|
- Multiple hint messages no longer crash message set (flash-gordon)
|
|
- "`Contract#inspect` no longer crashes (solnic)"
|
|
changed:
|
|
- Dependency on `dry-schema` was bumped to `~> 0.6` - this pulls in `dry-types 1.0.0`
|
|
and `dry-logic 1.0.0` (solnic)
|
|
- Dependency on `dry-initializer` was bumped to `~> 3.0` (solnic)
|
|
- version: 1.0.0.beta2
|
|
date: '2019-04-04'
|
|
added:
|
|
- |-
|
|
Support for arbitrary meta-data in failures, ie:
|
|
|
|
```ruby
|
|
class NewUserContract < Dry::Validation::Contract
|
|
params do
|
|
required(:login).filled(:string)
|
|
end
|
|
|
|
rule(:login) do
|
|
key.failure(text: 'is taken', code: 123) unless db.unique?(values[:login])
|
|
end
|
|
end
|
|
```
|
|
|
|
Now your error hash will include `{ login: [{ text: 'is taken', code: 123 }] }` (solnic + flash-gordon)
|
|
changed:
|
|
- "[BREAKING] `Error` was renamed to `Message` as it is a more generic concept (solnic)"
|
|
- "[BREAKING] `ErrorSet` was renamed to `MessageSet` for consistency (solnic)"
|
|
- "[BREAKING] `:monads` extension wraps entire result objects in `Success` or `Failure`
|
|
(flash-gordon)"
|
|
- version: 1.0.0.beta1
|
|
date: '2019-03-26'
|
|
added:
|
|
- New API for setting failures `base.failure` for base errors and `key.failure`
|
|
for key errors (solnic)
|
|
- Support for `base` errors associated with a key even when child keys have errors
|
|
too (solnic)
|
|
- Support for `base` errors not associated with any key (solnic)
|
|
- Result objects use `ErrorSet` object now for managing messages (solnic)
|
|
- 'Nested keys are properly handled when generating messages hash (issue #489) (flash-gordon
|
|
+ solnic)'
|
|
- Result objects support `locale` and `full` options now (solnic)
|
|
- Ability to configure `top_namespace` for messages, which will be used for both
|
|
schema and rule localization (solnic)
|
|
- Rule blocks receive a context object that you can use to share data between rules
|
|
(solnic)
|
|
changed:
|
|
- "[BREAKING] `Result#errors` returns an instance of `ErrorSet` now, it's an enumerable,
|
|
coerible to a hash (solnic)"
|
|
- "[BREAKING] `failure` was removed in favor of `key.failure` or `key(:foo).failure`
|
|
(solnic)"
|
|
- "[BREAKING] `Result#to_hash` was removed (flash-gordon)"
|
|
- version: 1.0.0.alpha2
|
|
date: '2019-03-05'
|
|
summary: First round of bug fixes. Thanks for testing <3!
|
|
fixed:
|
|
- Errors with nested messages are correctly built (flash-gordon)
|
|
- Messages for nested keys are correctly resolved (solnic)
|
|
- A message for a nested key is resolved when it's defined under `errors.rule.%{key}`
|
|
too, but a message under nested key will override it (solnic)
|
|
changed:
|
|
- When a message template is not found a more meaningful error is raised that includes
|
|
both rule identifier and key path (solnic)
|
|
- version: 1.0.0.alpha1
|
|
date: '2019-03-04'
|
|
summary: Complete rewrite on top of `dry-schema`.
|
|
added:
|
|
- "[BREAKING] `Dry::Validation::Contract` as a replacement for validation schemas
|
|
(solnic)"
|
|
- "[BREAKING] New `rule` DSL with an improved API for setting error messages (solnic)"
|
|
- version: 0.13.0
|
|
date: '2019-01-29'
|
|
fixed:
|
|
- Warning about method redefined (amatsuda)
|
|
changed:
|
|
- "`dry-logic` was bumped to `~> 0.5` (solnic)"
|
|
- "`dry-types` was bumped to `~> 0.14` (solnic)"
|
|
- version: 0.12.3
|
|
date: '2019-01-29'
|
|
changed:
|
|
- "[internal] dry-logic was pinned to `~> 0.4.2` (flash-gordon)"
|
|
- version: 0.12.2
|
|
date: '2018-08-29'
|
|
fixed:
|
|
- Use correct key names for rule messages when using i18n (jozzi05)
|
|
- version: 0.12.1
|
|
date: '2018-07-06'
|
|
fixed:
|
|
- "[internal] fixed deprecation warnings (flash-gordon)"
|
|
- version: 0.12.0
|
|
date: '2018-05-31'
|
|
changed:
|
|
- Code updated to work with `dry-types` 0.13.1 and `dry-struct` 0.5.0, these are
|
|
now minimal supported versions (flash-gordon)
|
|
- "[BREAKING] `Form` was renamed to `Params` to be consistent with the latest changes
|
|
from `dry-types`. You can `require 'dry/validation/compat/form'` to use the previous
|
|
names but it will be removed in the next version (flash-gordon)"
|
|
- version: 0.11.1
|
|
date: '2017-09-15'
|
|
changed:
|
|
- "`Result#to_either` was renamed to `#to_monad`, the previous name is kept for
|
|
backward compatibility (flash-gordon)"
|
|
- "[internal] fix warnings from dry-types v0.12.0"
|
|
- version: 0.11.0
|
|
date: '2017-05-30'
|
|
changed:
|
|
- "[internal] input processor compilers have been updated to work with new dry-types'
|
|
AST (GustavoCaso)"
|
|
- version: 0.10.7
|
|
date: '2017-05-15'
|
|
fixed:
|
|
- "`validate` can now be defined multiple times for the same key (kimquy)"
|
|
- Re-using rules between schemas no longer mutates original rule set (pabloh)
|
|
- version: 0.10.6
|
|
date: '2017-04-26'
|
|
fixed:
|
|
- Fixes issue with wrong localized error messages when namespaced messages are used
|
|
(kbredemeier)
|
|
- version: 0.10.5
|
|
date: '2017-01-12'
|
|
fixed:
|
|
- Warnings under MRI 2.4.0 are gone (koic)
|
|
- version: 0.10.4
|
|
date: '2016-12-03'
|
|
fixed:
|
|
- Updated to dry-core >= 0.2.1 (ruby warnings are gone) (flash-gordon)
|
|
- "`format?` predicate is excluded from hints (solnic)"
|
|
changed:
|
|
- "`version` file is now required by default (georgemillo)"
|
|
- version: 0.10.3
|
|
date: '2016-09-27'
|
|
fixed:
|
|
- Custom predicates work correctly with `each` macro (solnic)
|
|
- version: 0.10.2
|
|
date: '2016-09-23'
|
|
fixed:
|
|
- Constrained types + hints work again (solnic)
|
|
- version: 0.10.1
|
|
date: '2016-09-22'
|
|
fixed:
|
|
- Remove obsolete require of `dry/struct` which is now an optional extension (flash-gordon)
|
|
- version: 0.10.0
|
|
date: '2016-09-21'
|
|
added:
|
|
- Support for `validate` DSL which accepts an arbitratry validation block that gets
|
|
executed in the context of a schema object and is treated as a custom predicate
|
|
(solnic)
|
|
- Support for `or` error messages ie "must be a string or must be an integer" (solnic)
|
|
- Support for retrieving error messages exclusively via `schema.(input).errors`
|
|
(solnic)
|
|
- Support for retrieving hint messages exclusively via `schema.(input).hints` (solnic)
|
|
- Support for opt-in extensions loaded via `Dry::Validation.load_extensions(:my_ext)`
|
|
(flash-gordon)
|
|
- Add `:monads` extension which transforms a result instance to `Either` monad,
|
|
`schema.(input).to_either` (flash-gordon)
|
|
- Add `dry-struct` integration via an extension activated by `Dry::Validation.load_extensions(:struct)`
|
|
(flash-gordon)
|
|
fixed:
|
|
- Input rules (defined via `input` macro) are now lazy-initialized which makes it
|
|
work with predicates defined on the schema object (solnic)
|
|
- Hints are properly generated based on argument type in cases like `size?`, where
|
|
the message should be different for strings (uses "length") or other types (uses
|
|
"size") (solnic)
|
|
- Defining nested keys without `schema` blocks results in `ArgumentError` (solnic)
|
|
changed:
|
|
- "[BREAKING] `when` macro no longer supports multiple disconnected rules in its
|
|
block, whatever the block returns will be used for the implication (solnic)"
|
|
- "[BREAKING] `rule(some_name: %i(some keys))` will _always_ use `:some_name` as
|
|
the key for failure messages (solnic)"
|
|
- version: 0.9.5
|
|
date: '2016-08-16'
|
|
fixed:
|
|
- 'Infering multiple predicates with options works as expected ie `value(:str?,
|
|
min_size?: 3, max_size?: 6)` (solnic)'
|
|
- Default `locale` configured in `I18n` is now respected by the messages compiler
|
|
(agustin + cavi21)
|
|
- version: 0.9.4
|
|
date: '2016-08-11'
|
|
fixed:
|
|
- Error messages for sibling deeply nested schemas are nested correctly (timriley)
|
|
- version: 0.9.3
|
|
date: '2016-07-22'
|
|
added:
|
|
- Support for range arg in error messages for `excluded_from?` and `included_in?`
|
|
(mrbongiolo)
|
|
- "`Result#message_set` returns raw message set object (solnic)"
|
|
fixed:
|
|
- Error messages for high-level rules in nested schemas are nested correctly (solnic)
|
|
- Dumping error messages works with high-level rules relying on the same value (solnic)
|
|
changed:
|
|
- "`#messages` is no longer memoized (solnic)"
|
|
- version: 0.9.2
|
|
date: '2016-07-13'
|
|
fixed:
|
|
- Constrained types now work with `each` macro (solnic)
|
|
- Array coercion without member type works now ie `required(:arr).maybe(:array?)`
|
|
(solnic)
|
|
- version: 0.9.1
|
|
date: '2016-07-11'
|
|
fixed:
|
|
- "`I18n` backend is no longer required and set by default (solnic)"
|
|
- version: 0.9.0
|
|
date: '2016-07-08'
|
|
added:
|
|
- Support for defining maybe-schemas via `maybe { schema { .. } }` (solnic)
|
|
- Support for interpolation of custom failure messages for custom rules (solnic)
|
|
- Support for defining a base schema **class** with config and rules (solnic)
|
|
- Support for more than 1 predicate in `input` macro (solnic)
|
|
- Class-level `define!` API for defining rules on a class (solnic)
|
|
- "`:i18n` messages support merging from other paths via `messages_file` setting
|
|
(solnic)"
|
|
- Support for message token transformations in custom predicates (fran-worley)
|
|
- "[EXPERIMENTAL] Ability to compose predicates that accept dynamic args provided
|
|
by the schema (solnic)"
|
|
fixed:
|
|
- Duped key names in nested schemas no longer result in invalid error messages structure
|
|
(solnic)
|
|
- Error message structure for deeply nested each/schema rules (solnic)
|
|
- Values from `option` are passed down to nested schemas when using `Schema#with`
|
|
(solnic)
|
|
- Hints now work with array elements too (solnic)
|
|
- Hints for elements are no longer provided for an array when the value is not an
|
|
array (solnic)
|
|
- "`input` macro no longer messes up error messages for nested structures (solnic)"
|
|
changed:
|
|
- Tokens for `size?` were renamed `left` => `size_left` and `right` => `size_right`
|
|
(fran-worley)
|
|
- version: 0.8.0
|
|
date: '2016-07-01'
|
|
added:
|
|
- Explicit interface for type specs used to set up coercions, ie `required(:age,
|
|
:int)` (solnic)
|
|
- 'Support new dry-logic predicates: `:excluded_from?`, `:excludes?`, `:included_in?`,
|
|
`:includes?`, `:not_eql?`, `:odd?`, `:even?` (jodosha, fran-worley)'
|
|
- Support for blocks in `value`, `filled` and `maybe` macros (solnic)
|
|
- Support for passing a schema to `value|filled|maybe` macros ie `maybe(SomeSchema)`
|
|
(solnic)
|
|
- Support for `each(SomeSchema)` (solnic)
|
|
- 'Support for `value|filled|maybe` macros + `each` inside a block ie: `maybe(:filled?)
|
|
{ each(:int?) }` (solnic)'
|
|
- Support for dedicated hint messages via `en.errors.#{predicate}.(hint|failure)`
|
|
look-up paths (solnic)
|
|
- Support for configuring custom DSL extensions via `dsl_extensions` setting on
|
|
Schema class (solnic)
|
|
- Support for preconfiguring a predicate for the input value ie `value :hash?` used
|
|
for prerequisite-checks (solnic)
|
|
- Infer coercion from constrained types (solnic)
|
|
- Add value macro (coop)
|
|
- 'Enable .schema to accept objects that respond to #schema (ttdonovan)'
|
|
- Support for schema predicates which don't need any arguments (fran-worley)
|
|
- Error and hint messages have access to all predicate arguments by default (fran-worley+solnic)
|
|
- Invalid predicate name in DSL will raise an error (solnic)
|
|
- Predicate with invalid arity in DSL will raise an error (solnic)
|
|
fixed:
|
|
- Support for jRuby 9.1.1.0 (flash-gordon)
|
|
- Fix bug when using predicates with options in each and when (fran-worley)
|
|
- Fix bug when validating custom types (coop)
|
|
- Fix depending on deeply nested values in high-lvl rules (solnic)
|
|
- Fix duplicated error message for lt? when hint was used (solnic)
|
|
- Fix hints for nested schemas (solnic)
|
|
- Fix an issue where rules with same names inside nested schemas have incorrect
|
|
hints (solnic)
|
|
- Fix a bug where hints were being generated 4 times (solnic)
|
|
- Fix duplicated error messages when message is different than a hint (solnic)
|
|
changed:
|
|
- Uses new `:weak` hash constructor from dry-types 0.8.0 which can partially coerce
|
|
invalid hash (solnic)
|
|
- "`key` has been deprecated in favor of `required` (coop)"
|
|
- "`required` has been deprecated in favor of `filled` (coop)"
|
|
- Now relies on dry-logic v0.3.0 and dry-types v0.8.0 (fran-worley)
|
|
- Tring to use illogical predicates with maybe and filled macros now raise InvalidSchemaError
|
|
(fran-worley)
|
|
- Enable coercion on form.true and form.false (fran-worley)
|
|
- Remove attr (will be extracted to a separate gem) (coop)
|
|
- Deprecate required in favour of filled (coop)
|
|
- Deprecate key in favor of required (coop)
|
|
- Remove nested key syntax (solnic)
|
|
- version: 0.7.4
|
|
date: '2016-04-06'
|
|
added:
|
|
- "`Schema.JSON` with json-specific coercions (coop)"
|
|
- Support for error messages for `odd? and`even?` predicates (fran-worley)
|
|
fixed:
|
|
- Depending on deeply nested values in high-level rules works now (solnic)
|
|
- version: 0.7.3
|
|
date: '2016-03-30'
|
|
added:
|
|
- Support for inferring rules from constrained type (coop + solnic)
|
|
- Support for inferring nested schemas from `Dry::Types::Struct` classes (coop)
|
|
- Support for `number?` predicate (solnic)
|
|
fixed:
|
|
- Creating a nested schema properly sets full path to nested data structure (solnic)
|
|
- Error message for `empty?` predicate is now correct (jodosha)
|
|
- version: 0.7.2
|
|
date: '2016-03-28'
|
|
added:
|
|
- Support for nested schemas inside high-level rules (solnic)
|
|
- "`Schema#to_proc` so that you can do `data.each(&schema)` (solnic)"
|
|
- version: 0.7.1
|
|
date: '2016-03-21'
|
|
added:
|
|
- You can use `schema` inside `each` macro (solnic)
|
|
fixed:
|
|
- "`confirmation` macro defines an optional key with maybe value with `_confirmation`
|
|
suffix (solnic)"
|
|
- "`each` macro works correctly when its inner rule specify just one key (solnic)"
|
|
- error messages for `each` rules where input is equal are now correctly generated
|
|
(solnic)
|
|
changed:
|
|
- Now depends on `dry-logic` >= `0.2.1` (solnic)
|
|
- version: 0.7.0
|
|
date: '2016-03-16'
|
|
added:
|
|
- |-
|
|
Support for macros:
|
|
- `required` - when value must be filled
|
|
- `maybe` - when value can be nil (or empty, in case of `Form`)
|
|
- `when` - for composing high-level rule based on predicates applied to a
|
|
validated value
|
|
- `confirmation` - for confirmation validation
|
|
- Support for `value(:foo).eql?(value(:bar))` syntax in high-level rules (solnic)
|
|
- New DSL for defining schema objects `Dry::Validation.Schema do .. end` (solnic)
|
|
- Ability to define a schema for an array via top-level `each` rule (solnic)
|
|
- Ability to define nested schemas via `key(:location).schema do .. end` (solnic)
|
|
- Ability to re-use schemas inside other schemas via `key(:location).schema(LocationSchema)`
|
|
(solnic)
|
|
- Ability to inherit rules from another schema via `Dry::Validation.Schema(Other)
|
|
do .. end` (solnic)
|
|
- Ability to inject arbitrary dependencies to schemas via `Schema.option` + `Schema#with`
|
|
(solnic)
|
|
- Ability to provide translations for rule names under `%{locale}.rules.%{name}`
|
|
pattern (solnic)
|
|
- Ability to configure input processor, either `:form` or `:sanitizer` (solnic)
|
|
- Ability to pass a constrained dry type when defining keys or attrs, ie `key(:age,
|
|
Types::Age)` (solnic)
|
|
- "`Result#messages` supports `:full` option to get messages with rule names, disabled
|
|
by default (solnic)"
|
|
- |-
|
|
`Validation::Result` responds to `#[]` and `#each` (delegating to its output)
|
|
and it's an enumerable (solnic)
|
|
fixed:
|
|
- Qualified rule names properly use last node by default for error messages (solnic)
|
|
- Validation hints only include relevant messages (solnic)
|
|
- "`:yaml` messages respect `:locale` option in `Result#messages` (solnic)"
|
|
changed:
|
|
- "`schema` was **removed** from the DSL, just use `key(:name).schema` instead (solnic)"
|
|
- "`confirmation` is now a macro that you can call on a key rule (solnic)"
|
|
- |-
|
|
rule names for nested structures are now fully qualified, which means you can
|
|
provide customized messages for them. ie `user: :email` (solnic)
|
|
- "`Schema::Result#params` was renamed to `#output` (solnic)"
|
|
- |-
|
|
`Schema::Result` is now `Validation::Result` and it no longer has success and
|
|
failure results, only error results are provided (solnic)
|
|
- version: 0.6.0
|
|
date: '2016-01-20'
|
|
added:
|
|
- Support for validating objects with attr readers via `attr` (SunnyMagadan)
|
|
- Support for `value` interface in the DSL for composing high-level rules based
|
|
on values (solnic)
|
|
- |-
|
|
Support for `rule(name: :something)` syntax for grouping high-level rules under
|
|
the same name (solnic)
|
|
- 'Support for `confirmation(:foo, some_predicate: some_argument)` shortcut syntax
|
|
(solnic)'
|
|
- Support for error messages for grouped rules (like `confirmation`) (solnic)
|
|
- Schemas support injecting rules from the outside (solnic)
|
|
- "## Changed"
|
|
- |-
|
|
`rule` uses objects that inherit from `BasicObject` to avoid conflicts with
|
|
predicate names and built-in `Object` methods (solnic)
|
|
- |-
|
|
In `Schema::Form` both `key` and `optional` will apply `filled?` predicate by
|
|
default when no block is passed (solnic)
|
|
- version: 0.5.0
|
|
date: '2016-01-11'
|
|
fixed:
|
|
- "`Schema::Form` uses safe `form.array` and `form.hash` types which fixes #42 (solnic)"
|
|
changed:
|
|
- Now depends on [dry-logic](https://github.com/dry-rb/dry-logic) for predicates
|
|
and rules (solnic)
|
|
- "`dry/validation/schema/form` is now required by default (solnic)"
|
|
- version: 0.4.1
|
|
date: '2015-12-27'
|
|
added:
|
|
- Support for `each` and type coercion inference in `Schema::Form` (solnic)
|
|
- version: 0.4.0
|
|
date: '2015-12-21'
|
|
added:
|
|
- Support for high-level rule composition via `rule` interface (solnic)
|
|
- Support for exclusive disjunction (aka xor/^ operator) (solnic)
|
|
- Support for nested schemas within a schema class (solnic)
|
|
- Support for negating rules via `rule(name).not` (solnic)
|
|
- Support for `validation hints` that are included in the error messages (solnic)
|
|
fixed:
|
|
- Error messages hash has now consistent structure `rule_name => [msgs_array, input_value]`
|
|
(solnic)
|
|
- version: 0.3.1
|
|
date: '2015-12-08'
|
|
added:
|
|
- Support for `Range` and `Array` as an argument in `size?` predicate (solnic)
|
|
fixed:
|
|
- Error compiler returns an empty hash rather than a nil when there are no errors
|
|
(solnic)
|
|
- version: 0.3.0
|
|
date: '2015-12-07'
|
|
added:
|
|
- I18n messages support (solnic)
|
|
- Ability to configure `messages` via `configure { config.messages = :i18n }` (solnic)
|
|
- "`rule` interface in DSL for defining rules that depend on other rules (solnic)"
|
|
- '`confirmation` interface as a shortcut for defining "confirmation of" rule (solnic)'
|
|
- Error messages can be now matched by input value type too (solnic)
|
|
fixed:
|
|
- "`optional` rule with coercions work correctly with `|` + multiple `&`s (solnic)"
|
|
- "`Schema#[]` checks registered predicates first before defaulting to its own predicates
|
|
(solnic)"
|
|
changed:
|
|
- "`Schema#messages(input)` => `Schema#call(input).messages` (solnic)"
|
|
- |-
|
|
`Schema#call` returns `Schema::Result` which has access to all rule results,
|
|
errors and messages
|
|
- "`Schema::Result#messages` returns a hash with rule names, messages and input
|
|
values (solnic)"
|
|
- version: 0.2.0
|
|
date: '2015-11-30'
|
|
added:
|
|
- "`Schema::Form` with a built-in coercer inferred from type-check predicates (solnic)"
|
|
- Ability to pass a block to predicate check in the DSL ie `value.hash? { ... }`
|
|
(solnic)
|
|
- Optional keys using `optional(:key_name) { ... }` interface in the DSL (solnic)
|
|
- |-
|
|
New predicates:
|
|
- `bool?`
|
|
- `date?`
|
|
- `date_time?`
|
|
- `time?`
|
|
- `float?`
|
|
- `decimal?`
|
|
- `hash?`
|
|
- `array?`
|
|
fixed:
|
|
- Added missing `and` / `or` interfaces to composite rules (solnic)
|
|
- version: 0.1.0
|
|
date: '2015-11-25'
|
|
summary: First public release
|