Ecosyste.ms: Awesome
An open API service indexing awesome lists of open source software.
https://github.com/photonquantum/actix-xml
XML extractor for actix-web
https://github.com/photonquantum/actix-xml
actix actor extractor parser parsing reader request rust xml
Last synced: 3 months ago
JSON representation
XML extractor for actix-web
- Host: GitHub
- URL: https://github.com/photonquantum/actix-xml
- Owner: PhotonQuantum
- License: mit
- Created: 2021-07-11T15:34:20.000Z (over 3 years ago)
- Default Branch: master
- Last Pushed: 2024-10-23T16:44:08.000Z (3 months ago)
- Last Synced: 2024-10-25T00:08:04.418Z (3 months ago)
- Topics: actix, actor, extractor, parser, parsing, reader, request, rust, xml
- Language: Rust
- Homepage:
- Size: 306 KB
- Stars: 1
- Watchers: 3
- Forks: 4
- Open Issues: 4
-
Metadata Files:
- Readme: README.md
- License: LICENSE
Awesome Lists containing this project
README
# actix-xml
[![crates.io](https://img.shields.io/crates/v/actix-xml?style=flat-square)](https://crates.io/crates/actix-xml)
[![Documentation](https://img.shields.io/docsrs/actix-xml?style=flat-square)](https://docs.rs/actix-xml)XML extractor for actix-web.
This crate provides struct `Xml` that can be used to extract typed information from request's body.
Under the hood, [quick-xml](https://github.com/tafia/quick-xml) is used to parse payloads.
## Example
```rust
use actix_web::{web, App};
use actix_xml::Xml;
use serde::Deserialize;#[derive(Deserialize)]
struct Info {
username: String,
}/// deserialize `Info` from request's body
async fn index(info: Xml) -> String {
format!("Welcome {}!", info.username)
}fn main() {
let app = App::new().service(
web::resource("/index.html").route(
web::post().to(index))
);
}
```## Features
- `encoding`: support non utf-8 payload
- `compress-brotli`(default): enable actix-web `compress-brotli` support
- `compress-gzip`(default): enable actix-web `compress-gzip` support
- `compress-zstd`(default): enable actix-web `compress-zstd` supportIf you've removed one of the `compress-*` feature flag for actix-web, make sure to remove it by
setting `default-features=false`, or it will be re-enabled for actix-web.## Version Support
- `0.1.x` - supports `actix-web 3.3.x`
- `0.2.0-beta.0` - supports `actix-web 4.0.0.beta.8`
- `0.2.0` - supports `actix-web 4.0.x`## License
MIT