1
0
mirror of https://github.com/actix/examples synced 2025-02-03 01:49:05 +01:00

57 lines
1.4 KiB
Rust
Raw Normal View History

extern crate actix;
extern crate actix_web;
extern crate bytes;
extern crate futures;
#[macro_use]
extern crate failure;
extern crate env_logger;
extern crate prost;
#[macro_use]
extern crate prost_derive;
2018-05-20 21:03:29 -07:00
use actix_web::{
http, middleware, server, App, AsyncResponder, Error, HttpRequest, HttpResponse,
};
use futures::Future;
mod protobuf;
use protobuf::ProtoBufResponseBuilder;
#[derive(Clone, Debug, PartialEq, Message)]
pub struct MyObj {
2018-05-08 11:08:43 -07:00
#[prost(int32, tag = "1")]
pub number: i32,
2018-05-08 11:08:43 -07:00
#[prost(string, tag = "2")]
pub name: String,
}
/// This handler uses `ProtoBufMessage` for loading protobuf object.
2018-07-16 12:36:53 +06:00
fn index(req: &HttpRequest) -> Box<Future<Item = HttpResponse, Error = Error>> {
protobuf::ProtoBufMessage::new(req)
2019-03-09 18:03:09 -08:00
.from_err() // convert all errors into `Error`
.and_then(|val: MyObj| {
println!("model: {:?}", val);
2019-03-09 18:03:09 -08:00
Ok(HttpResponse::Ok().protobuf(val)?) // <- send response
})
.responder()
}
fn main() {
::std::env::set_var("RUST_LOG", "actix_web=info");
env_logger::init();
let sys = actix::System::new("protobuf-example");
server::new(|| {
App::new()
.middleware(middleware::Logger::default())
2018-05-08 11:08:43 -07:00
.resource("/", |r| r.method(http::Method::POST).f(index))
2019-03-09 18:03:09 -08:00
})
.bind("127.0.0.1:8080")
.unwrap()
.shutdown_timeout(1)
.start();
println!("Started http server: 127.0.0.1:8080");
let _ = sys.run();
}