1
0
mirror of https://github.com/fafhrd91/actix-web synced 2025-01-19 14:14:41 +01:00

51 lines
1.5 KiB
Rust
Raw Normal View History

#![allow(unused_variables)]
extern crate actix;
extern crate actix_web;
extern crate env_logger;
extern crate openssl;
use openssl::ssl::{SslMethod, SslAcceptor, SslFiletype};
2018-03-30 18:54:38 -07:00
use actix_web::{
http, middleware, server,
Application, HttpRequest, HttpResponse, Error};
2018-01-05 16:32:36 -08:00
2018-01-16 21:59:33 +03:00
/// simple handle
2018-03-30 18:54:38 -07:00
fn index(req: HttpRequest) -> Result<HttpResponse, Error> {
println!("{:?}", req);
2018-03-30 18:54:38 -07:00
Ok(HttpResponse::Ok()
2017-11-29 14:03:18 -08:00
.content_type("text/plain")
.body("Welcome!")?)
}
fn main() {
2017-11-04 09:07:44 -07:00
if ::std::env::var("RUST_LOG").is_err() {
::std::env::set_var("RUST_LOG", "actix_web=info");
2017-11-04 09:07:44 -07:00
}
2018-03-30 18:54:38 -07:00
env_logger::init();
let sys = actix::System::new("ws-example");
// load ssl keys
let mut builder = SslAcceptor::mozilla_intermediate(SslMethod::tls()).unwrap();
builder.set_private_key_file("key.pem", SslFiletype::PEM).unwrap();
builder.set_certificate_chain_file("cert.pem").unwrap();
2018-03-30 18:54:38 -07:00
let _ = server::new(
|| Application::new()
// enable logger
2017-12-26 19:59:41 -08:00
.middleware(middleware::Logger::default())
// register simple handler, handle all methods
2017-12-07 18:08:16 -08:00
.resource("/index.html", |r| r.f(index))
// with path parameters
2018-03-30 18:54:38 -07:00
.resource("/", |r| r.method(http::Method::GET).f(|req| {
HttpResponse::Found()
2017-11-29 14:03:18 -08:00
.header("LOCATION", "/index.html")
2018-03-30 18:54:38 -07:00
.finish()
})))
2017-12-18 13:06:41 -08:00
.bind("127.0.0.1:8443").unwrap()
.start_ssl(builder).unwrap();
2017-12-05 17:09:15 -08:00
println!("Started http server: 127.0.0.1:8443");
let _ = sys.run();
}