mirror of
https://github.com/actix/actix-web.git
synced 2025-01-04 06:18:51 +00:00
handler info
This commit is contained in:
parent
186726fbad
commit
f0c346f18c
3 changed files with 105 additions and 6 deletions
|
@ -85,9 +85,11 @@ optional = true
|
||||||
env_logger = "0.4"
|
env_logger = "0.4"
|
||||||
reqwest = "0.8"
|
reqwest = "0.8"
|
||||||
skeptic = "0.13"
|
skeptic = "0.13"
|
||||||
|
serde_derive = "1.0"
|
||||||
|
|
||||||
[build-dependencies]
|
[build-dependencies]
|
||||||
skeptic = "0.13"
|
skeptic = "0.13"
|
||||||
|
serde_derive = "1.0"
|
||||||
version_check = "0.1"
|
version_check = "0.1"
|
||||||
|
|
||||||
[profile.release]
|
[profile.release]
|
||||||
|
|
|
@ -71,14 +71,18 @@ fn main() {
|
||||||
|
|
||||||
## [WIP] Handler
|
## [WIP] Handler
|
||||||
|
|
||||||
A request handler can have different forms.
|
A request handler can by any object that implements
|
||||||
|
[`Handler` trait](../actix_web/struct.HttpResponse.html#implementations).
|
||||||
|
|
||||||
* Simple function that accepts `HttpRequest` and returns `HttpResponse` or any
|
By default actix provdes several `Handler` implementations:
|
||||||
type that can be converted into `HttpResponse`.
|
|
||||||
* Function that that accepts `HttpRequest` and returns `Stream<Item=Frame, Error=Error>`.
|
|
||||||
* Http actor, i.e. actor that has `HttpContext<A>`as a context.
|
|
||||||
|
|
||||||
Actix provides response conversion for some standard types, like `&'static str`, `String`, etc.
|
* Simple function that accepts `HttpRequest` and returns any object that
|
||||||
|
can be converted to `HttpResponse`
|
||||||
|
* Function that accepts `HttpRequest` and returns `Result<Reply, Into<Error>>` object.
|
||||||
|
* Function that accepts `HttpRequest` and return actor that has `HttpContext<A>`as a context.
|
||||||
|
|
||||||
|
Actix provides response conversion into `HttpResponse` for some standard types,
|
||||||
|
like `&'static str`, `String`, etc.
|
||||||
For complete list of implementations check
|
For complete list of implementations check
|
||||||
[HttpResponse documentation](../actix_web/struct.HttpResponse.html#implementations).
|
[HttpResponse documentation](../actix_web/struct.HttpResponse.html#implementations).
|
||||||
|
|
||||||
|
@ -101,3 +105,77 @@ fn index(req: HttpRequest) -> Bytes {
|
||||||
Bytes::from_static("Hello world!")
|
Bytes::from_static("Hello world!")
|
||||||
}
|
}
|
||||||
```
|
```
|
||||||
|
|
||||||
|
```rust,ignore
|
||||||
|
fn index(req: HttpRequest) -> Box<Future<Item=HttpResponse, Error=Error>> {
|
||||||
|
...
|
||||||
|
}
|
||||||
|
```
|
||||||
|
|
||||||
|
### Custom conversion
|
||||||
|
|
||||||
|
Let's create response for custom type that serializes to `application/json` response:
|
||||||
|
|
||||||
|
```rust
|
||||||
|
extern crate actix;
|
||||||
|
extern crate actix_web;
|
||||||
|
extern crate serde;
|
||||||
|
extern crate serde_json;
|
||||||
|
#[macro_use] extern crate serde_derive;
|
||||||
|
use actix_web::*;
|
||||||
|
|
||||||
|
#[derive(Serialize)]
|
||||||
|
struct MyObj {
|
||||||
|
name: String,
|
||||||
|
}
|
||||||
|
|
||||||
|
/// we have to convert Error into HttpResponse as well, but with
|
||||||
|
/// specialization this could be handled genericly.
|
||||||
|
impl Into<HttpResponse> for MyObj {
|
||||||
|
fn into(self) -> HttpResponse {
|
||||||
|
let body = match serde_json::to_string(&self) {
|
||||||
|
Err(err) => return Error::from(err).into(),
|
||||||
|
Ok(body) => body,
|
||||||
|
};
|
||||||
|
|
||||||
|
// Create response and set content type
|
||||||
|
HttpResponse::Ok()
|
||||||
|
.content_type("application/json")
|
||||||
|
.body(body).unwrap()
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
fn main() {
|
||||||
|
let sys = actix::System::new("example");
|
||||||
|
|
||||||
|
HttpServer::new(
|
||||||
|
Application::default("/")
|
||||||
|
.resource("/", |r| r.handler(
|
||||||
|
Method::GET, |req| {Ok(MyObj{name: "user".to_owned()})})))
|
||||||
|
.serve::<_, ()>("127.0.0.1:8088").unwrap();
|
||||||
|
|
||||||
|
println!("Started http server: 127.0.0.1:8088");
|
||||||
|
actix::Arbiter::system().send(actix::msgs::SystemExit(0)); // <- remove this line, this code stops system during testing
|
||||||
|
|
||||||
|
let _ = sys.run();
|
||||||
|
}
|
||||||
|
```
|
||||||
|
|
||||||
|
If `specialization` is enabled, conversion could be simplier:
|
||||||
|
|
||||||
|
```rust,ignore
|
||||||
|
#[derive(Serialize)]
|
||||||
|
struct MyObj {
|
||||||
|
name: String,
|
||||||
|
}
|
||||||
|
|
||||||
|
impl Into<Result<HttpResponse>> for MyObj {
|
||||||
|
fn into(self) -> Result<HttpResponse> {
|
||||||
|
let body = serde_json::to_string(&self)?;
|
||||||
|
|
||||||
|
Ok(HttpResponse::Ok()
|
||||||
|
.content_type("application/json")
|
||||||
|
.body(body)?)
|
||||||
|
}
|
||||||
|
}
|
||||||
|
```
|
||||||
|
|
19
src/route.rs
19
src/route.rs
|
@ -67,6 +67,7 @@ impl Reply {
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
|
#[cfg(not(actix_nightly))]
|
||||||
impl<T: Into<HttpResponse>> From<T> for Reply
|
impl<T: Into<HttpResponse>> From<T> for Reply
|
||||||
{
|
{
|
||||||
fn from(item: T) -> Self {
|
fn from(item: T) -> Self {
|
||||||
|
@ -74,6 +75,24 @@ impl<T: Into<HttpResponse>> From<T> for Reply
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
|
#[cfg(actix_nightly)]
|
||||||
|
default impl<T: Into<HttpResponse>> From<T> for Reply
|
||||||
|
{
|
||||||
|
fn from(item: T) -> Self {
|
||||||
|
Reply(ReplyItem::Message(item.into()))
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
#[cfg(actix_nightly)]
|
||||||
|
default impl<T: Into<HttpResponse>, E: Into<Error>> From<StdResult<T, E>> for Reply {
|
||||||
|
fn from(res: StdResult<T, E>) -> Self {
|
||||||
|
match res {
|
||||||
|
Ok(val) => val.into().into(),
|
||||||
|
Err(err) => err.into().into(),
|
||||||
|
}
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
impl<E: Into<Error>> From<StdResult<Reply, E>> for Reply {
|
impl<E: Into<Error>> From<StdResult<Reply, E>> for Reply {
|
||||||
fn from(res: StdResult<Reply, E>) -> Self {
|
fn from(res: StdResult<Reply, E>) -> Self {
|
||||||
match res {
|
match res {
|
||||||
|
|
Loading…
Reference in a new issue