diff options
Diffstat (limited to 'rust/src/bin')
-rw-r--r-- | rust/src/bin/fatcat-iron.rs | 69 | ||||
-rw-r--r-- | rust/src/bin/fatcat-tokio.rs | 67 |
2 files changed, 69 insertions, 67 deletions
diff --git a/rust/src/bin/fatcat-iron.rs b/rust/src/bin/fatcat-iron.rs new file mode 100644 index 00000000..8c87f55f --- /dev/null +++ b/rust/src/bin/fatcat-iron.rs @@ -0,0 +1,69 @@ +//! Main binary entry point for fatcat implementation. + +#![allow(missing_docs)] + +// Imports required by this file. +extern crate fatcat; +extern crate fatcat_api; +extern crate swagger; +extern crate iron; +//extern crate hyper_openssl; +extern crate clap; + +// Imports required by server library. +// extern crate fatcat; +// extern crate swagger; +extern crate futures; +extern crate chrono; +#[macro_use] +extern crate error_chain; + +//use hyper_openssl::OpensslServer; +//use hyper_openssl::openssl::x509::X509_FILETYPE_PEM; +//use hyper_openssl::openssl::ssl::{SslAcceptorBuilder, SslMethod}; +//use hyper_openssl::openssl::error::ErrorStack; +use clap::{App, Arg}; +use iron::{Iron, Chain}; +use swagger::auth::AllowAllMiddleware; + +/* +/// Builds an SSL implementation for Simple HTTPS from some hard-coded file names +fn ssl() -> Result<OpensslServer, ErrorStack> { + let mut ssl = SslAcceptorBuilder::mozilla_intermediate_raw(SslMethod::tls())?; + + // Server authentication + ssl.set_private_key_file("examples/server-key.pem", X509_FILETYPE_PEM)?; + ssl.set_certificate_chain_file("examples/server-chain.pem")?; + ssl.check_private_key()?; + + Ok(OpensslServer::from(ssl.build())) +} +*/ + +/// Create custom server, wire it to the autogenerated router, +/// and pass it to the web server. +fn main() { + let matches = App::new("server") + .arg(Arg::with_name("https") + .long("https") + .help("Whether to use HTTPS or not")) + .get_matches(); + + let server = fatcat::server().unwrap(); + let router = fatcat_api::router(server); + + let mut chain = Chain::new(router); + chain.link_before(fatcat_api::server::ExtractAuthData); + // add authentication middlewares into the chain here + // for the purpose of this example, pretend we have authenticated a user + chain.link_before(AllowAllMiddleware::new("cosmo")); + + if matches.is_present("https") { + unimplemented!() + // Using Simple HTTPS + //Iron::new(chain).https("localhost:8080", ssl().expect("Failed to load SSL keys")).expect("Failed to start HTTPS server"); + } else { + // Using HTTP + Iron::new(chain).http("localhost:8080").expect("Failed to start HTTP server"); + } +} diff --git a/rust/src/bin/fatcat-tokio.rs b/rust/src/bin/fatcat-tokio.rs deleted file mode 100644 index cc603908..00000000 --- a/rust/src/bin/fatcat-tokio.rs +++ /dev/null @@ -1,67 +0,0 @@ -//! Main binary entry point for fatcat implementation. - -#![allow(missing_docs)] - -// Imports required by this file. -extern crate fatcat; -extern crate fatcat_api; -extern crate hyper; -extern crate swagger; -//extern crate openssl; -//extern crate native_tls; -extern crate tokio_proto; -//extern crate tokio_tls; -extern crate clap; - -//use openssl::x509::X509_FILETYPE_PEM; -//use openssl::ssl::{SslAcceptorBuilder, SslMethod}; -//use openssl::error::ErrorStack; -use clap::{App, Arg}; -use hyper::server::Http; -use swagger::auth::AllowAllAuthenticator; -use tokio_proto::TcpServer; - -// Builds an SSL implementation for Simple HTTPS from some hard-coded file names -/* -fn ssl() -> Result<SslAcceptorBuilder, ErrorStack> { - let mut ssl = SslAcceptorBuilder::mozilla_intermediate_raw(SslMethod::tls())?; - - // Server authentication - ssl.set_private_key_file("examples/server-key.pem", X509_FILETYPE_PEM)?; - ssl.set_certificate_chain_file("examples/server-chain.pem")?; - ssl.check_private_key()?; - - Ok(ssl) -} -*/ - -/// Create custom server, wire it to the autogenerated router, -/// and pass it to the web server. -fn main() { - let matches = App::new("server") - .arg( - Arg::with_name("https") - .long("https") - .help("Whether to use HTTPS or not"), - ) - .get_matches(); - - let service_fn = fatcat_api::server::auth::NewService::new(AllowAllAuthenticator::new( - fatcat::NewService, - "cosmo", - )); - - let addr = "127.0.0.1:8080" - .parse() - .expect("Failed to parse bind address"); - if matches.is_present("https") { - unimplemented!() - //let ssl = ssl().expect("Failed to load SSL keys"); - //let builder: native_tls::TlsAcceptorBuilder = native_tls::backend::openssl::TlsAcceptorBuilderExt::from_openssl(ssl); - //let tls_acceptor = builder.build().expect("Failed to build TLS acceptor"); - //TcpServer::new(tokio_tls::proto::Server::new(Http::new(), tls_acceptor), addr).serve(service_fn); - } else { - // Using HTTP - TcpServer::new(Http::new(), addr).serve(service_fn); - } -} |