Skip to content
New issue

Have a question about this project? Sign up for a free GitHub account to open an issue and contact its maintainers and the community.

By clicking “Sign up for GitHub”, you agree to our terms of service and privacy statement. We’ll occasionally send you account related emails.

Already on GitHub? Sign in to your account

0.8.4 breaks with #[validate] attribute #109

Closed
luben opened this issue Sep 20, 2021 · 1 comment
Closed

0.8.4 breaks with #[validate] attribute #109

luben opened this issue Sep 20, 2021 · 1 comment

Comments

@luben
Copy link

luben commented Sep 20, 2021

Plain #[validate] is used to validate nested types (https://github.com/Keats/validator#nested). Schemars does not handle it and fails with

error: expected #[validate(...)]
   --> src/api/customer_model.rs:197:7
    |
197 |     #[validate]
    |       ^^^^^^^^
@GREsau GREsau closed this as completed in de7314f Sep 20, 2021
@GREsau
Copy link
Owner

GREsau commented Sep 20, 2021

Fixed in v0.8.5, thanks for the report!

sanlee42 added a commit to sanlee42/schemars that referenced this issue Jan 2, 2023
* Read #[validate(...)] attributes

* Handle required flattened Option fields

* Refactor out `add_schema_as_property`

* Process validation attributes in newtype structs

* Process validation attributes in tuple structs

* Refactor out "local_id" for type definitions

* Refactoring

* Support inline regex

* Allow setting validation attributes via #[schemars(...)]

* Add some doc comments

* Fix doc test

* Emit compilation errors for duplicate validation attributes

* Fix indexmap tests for rust 1.37

* upgrade diem dep (#1)

* Update changelog and docs

* Add newline to attributes docs

* v0.8.4

* Allow empty #[validate] attributes.

Fixes GREsau#109

* v0.8.5

* Use oneOf for enums when possible (GREsau#108)

* v0.8.6

* Correct latest changelog entry

* update diem dep

* Implement JsonSchema on EnumSet type

* update diem dep

* Upgrade move deps (#3)

* [deps] Upgrade move types dep.

* Update examples after 0a1200b

* Allow non-Serialize default values.

Default values that don't implement Serialize are now ignored, rather than causing a compile error.
This is done by simulating specialization using a technique copied from Rocket:
https://github.com/SergioBenitez/Rocket/blob/5ebefa97c992c37bdc476299304a339d429a43fc/core/lib/src/sentinel.rs#L391-L445

Fixes GREsau#115

* v0.8.7

* update diem deps

* Add example for optional dependency in readme

Based on https://github.com/GREsau/schemars/pull/118/files

* Add support for rust_decimal and bigdecimal (GREsau#101)

* Document new optional dependencies

* Internally tagged enums don't honor deny_unknown_fields as precisely as
they might.

flatten doesn't act quite as intended with regard to
additional_properties

* v0.8.8

* update diem deps to latest

* update diem deps

* Update dep

* update diem deps

* Update rust toolchain and dep

* update diem dep

* Update diem dep

* [crypto] Update dependency crypto to use starcoinorg/starcoin-crypto repo (#5)

* [crypto] Update dependency crypto to use starcoinorg/starcoin-crypto repo.

* [deps] Update move-core-types to starcoinorg/move

* Remove diem types

Co-authored-by: Graham Esau <[email protected]>
Co-authored-by: lerencao <[email protected]>
Co-authored-by: Graham Esau <[email protected]>
Co-authored-by: Adam Leventhal <[email protected]>
Co-authored-by: Matt Campbell <[email protected]>
Co-authored-by: jolestar <[email protected]>
Co-authored-by: timando <[email protected]>
Co-authored-by: Adam H. Leventhal <[email protected]>
Sign up for free to join this conversation on GitHub. Already have an account? Sign in to comment
Labels
None yet
Projects
None yet
Development

No branches or pull requests

2 participants