Actix-web wrapper for garde, a Rust validation library.
toml
[dependencies]
garde = "0.14"
garde-actix-web = "0.1.0"
Simply use garde-actix-web
exposed types as a drop in for actix types.
Your types must implement Validate
from garde
. Validation happens during actix's FromRequest
invocation.
If payload is invalid, a 400 error is returned (404 for Path).
Custom error handling can be implemented with an extractor config (garde_actix_web::web::QueryConfig
in place of actix_web::web::QueryConfig
for example).
```rust use actixweb::HttpResponse; // instead of actixweb::web::Path use gardeactixweb::web::Path; use garde::Validate;
struct MyStruct<'a> { #[garde(ascii, length(min=3, max=25))] username: &'a str, }
fn test(id: Path
⚠️ When using garde
custom validation, the Context
type needs to implement Default
which is not required by garde
.
Context needs to be provided through actix's data
or app_data
, if not found default will be used instead.
| name | description | extra dependencies |
|------------|---------------------------------------------------------------|----------------------------------------------------------------------------------------------|
| serde_qs
| Enables the usage of garde
for serde_qs::actix::QsQuery<T>
| serde_qs
|
Garde-actix-web is provided by Netwo.
We use this crate for our internal needs and therefore are committed to its maintenance, however we cannot provide any additional guaranty. Use it at your own risks.
While we won't invest in any feature we don't need, we are open to accept any pull request you might propose.
We are a France based full-remote company operating in the telecom sector. If you are interested in learning more, feel free to visit our career page.