Comments (9)
Hi, @solnic and @AMHOL
I would like to contribute into your project. I like the idea and see it like a clean and promising replacement for activemodel validations. I've already started playing around with this feature and made some progress there. Please let me know if you are interested in any help here.
from dry-validation.
@SunnyMagadan had a look at your branch and it all looks good to me, if you submit a pull request @solnic can take a look/merge it. Always good to see people taking an interest/helping out, thanks. 😄
from dry-validation.
🙇 Great! Keep doing.
from dry-validation.
@solnic I have one question regarding this feature. How do you plan to deal with optional
? Right now it uses Rule::Key
with Implication
under the hood https://github.com/dryrb/dry-validation/blob/master/lib/dry/validation/schema/definition.rb#L10. Also InputTypeCompiler
uses :key
for visit and
or
implication
https://github.com/dryrb/dry-validation/blob/master/lib/dry/validation/input_type_compiler.rb#L57. We need to distinguish optional key and optional attr somehow.
from dry-validation.
@SunnyMagadan there is no such thing as an optional attribute, an optional key means a hash may, or may not include a given key. When we talk about validating a model, it means it does have attribute readers for specified attributes. In this case, saying attr(:foo)
means a model must implement foo
reader. You can just skip this for attributes, since an attr reader will return nil
even when the ivar was never set, so one could easily write attr(:foo) { |foo| foo.none? | foo.int? }
etc.
from dry-validation.
BTW feel free to open a PR early, even when it's not finished. We can collaborate on changsets easily etc :)
from dry-validation.
True. It doesn't make sense to have optional attributes. Thank you. I'll open WIP PR soon. :)
Also, I've found that this feature requires changes in dry-data
, because current version of InputTypeCompiler
based on it and uses schema conversion into hash
type. I see that dry-data
supports struct, but it requires to define a separate class for this. This is not very efficient for cases when we need to define schema on the fly.
from dry-validation.
@SunnyMagadan let's focus on pure schema first w/o coercions. I need to think how to tackle this on the dry-data side. My initial thinking is that we don't want coercions on dry-validation side when you're validating an model, I would say the model should handle coercions instead.
from dry-validation.
This issue can be closed since corresponding PR was already merged.
from dry-validation.
Related Issues (20)
- Injecting dependencies using dry-auto_inject with reserved names
- `rule.each` produces error when input is `nil` HOT 2
- Building contract failed when or-ing types HOT 2
- Validation passes when array type is invalid HOT 1
- NoMethodError is raised when validating non-hash objects with a Dry::Validation::Contract that has config.validate_keys set to true HOT 4
- Dry::Validation::MissingMessageError after update dry stack HOT 2
- Weird issue since 1.10 dry-schema release HOT 3
- Validator didn't recognize nil string param value as empty, and didn't set default value HOT 6
- JSON schema contract failing to recognise valid input HOT 2
- Rule validation does not show in errors when the key validated is in an array of hashes HOT 1
- Mixing of `~>` and `<` in gemspec versioning HOT 1
- Documentation missmatch: `predicates_as_macros` is not available until v1.2
- `Dry::Validation::Result` lacks an `#output` method similar to `Dry::Schema::Result` HOT 4
- `Dry::Validation::Contract` behaves different when defined with a `params Dry::Schema::Params(parent: RawSchema)` vs. `params ParamsSchema` HOT 2
- errors(full: true), for nested input, could be better HOT 1
- False-positive when validating a nested datetime in an array of hashes HOT 2
- Consider release a new version with updated dependencies HOT 2
- Define contract with namespace but got TypeError when use errors(full: true)
- Wrong number of arguments HOT 3
- Getting proc instead of string message
Recommend Projects
-
React
A declarative, efficient, and flexible JavaScript library for building user interfaces.
-
Vue.js
🖖 Vue.js is a progressive, incrementally-adoptable JavaScript framework for building UI on the web.
-
Typescript
TypeScript is a superset of JavaScript that compiles to clean JavaScript output.
-
TensorFlow
An Open Source Machine Learning Framework for Everyone
-
Django
The Web framework for perfectionists with deadlines.
-
Laravel
A PHP framework for web artisans
-
D3
Bring data to life with SVG, Canvas and HTML. 📊📈🎉
-
Recommend Topics
-
javascript
JavaScript (JS) is a lightweight interpreted programming language with first-class functions.
-
web
Some thing interesting about web. New door for the world.
-
server
A server is a program made to process requests and deliver data to clients.
-
Machine learning
Machine learning is a way of modeling and interpreting data that allows a piece of software to respond intelligently.
-
Visualization
Some thing interesting about visualization, use data art
-
Game
Some thing interesting about game, make everyone happy.
Recommend Org
-
Facebook
We are working to build community through open source technology. NB: members must have two-factor auth.
-
Microsoft
Open source projects and samples from Microsoft.
-
Google
Google ❤️ Open Source for everyone.
-
Alibaba
Alibaba Open Source for everyone
-
D3
Data-Driven Documents codes.
-
Tencent
China tencent open source team.
from dry-validation.