All Downloads are FREE. Search and download functionalities are using the official Maven repository.

rust-server.example-server.mustache Maven / Gradle / Ivy

There is a newer version: 3.0.0-rc1
Show newest version
//! Main binary entry point for {{externCrateName}} implementation.

#![allow(missing_docs)]

// Imports required by this file.
// extern crate ;
extern crate {{externCrateName}};
extern crate swagger;
extern crate iron;
extern crate hyper_openssl;
extern crate clap;

// Imports required by server library.
// extern crate {{externCrateName}};
// 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;

mod server_lib;

/// Builds an SSL implementation for Simple HTTPS from some hard-coded file names
fn ssl() -> Result {
    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 = server_lib::server().unwrap();
    let router = {{externCrateName}}::router(server);

    let mut chain = Chain::new(router);
    chain.link_before({{externCrateName}}::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") {
        // Using Simple HTTPS
        Iron::new(chain).https("localhost:{{serverPort}}", ssl().expect("Failed to load SSL keys")).expect("Failed to start HTTPS server");
    } else {
        // Using HTTP
        Iron::new(chain).http("localhost:{{serverPort}}").expect("Failed to start HTTP server");
    }
}




© 2015 - 2025 Weber Informatics LLC | Privacy Policy