//! An HTTP server demonstrating the probable direction of the library without actually being *in* //! the library. //! //! This demonstrates some handling of the RequestURI, which has several possibilities and for which //! the correct values depend on the method. #![crate_name = "request_uri"] extern crate time; extern crate http; use std::io::net::ip::{SocketAddr, Ipv4Addr}; use std::io::Writer; use http::server::{Config, Server, Request, ResponseWriter}; use http::server::request::RequestUri::{Star, AbsoluteUri, AbsolutePath, Authority}; use http::status::{BadRequest, MethodNotAllowed}; use http::method::{Get, Head, Post, Put, Delete, Trace, Options, Connect, Patch}; use http::headers::content_type::MediaType; #[deriving(Clone)] struct RequestUriServer; impl Server for RequestUriServer { fn get_config(&self) -> Config { Config { bind_address: SocketAddr { ip: Ipv4Addr(127, 0, 0, 1), port: 8001 } } } fn handle_request(&self, r: Request, w: &mut ResponseWriter) { w.headers.date = Some(time::now_utc()); w.headers.server = Some(String::from_str("Rust Thingummy/0.1-pre")); match (&r.method, &r.request_uri) { (&Connect, _) => { // "This specification reserves the method name CONNECT for use with a proxy that // can dynamically switch to being a tunnel (e.g. SSL tunneling Tunneling TCP based // protocols through Web proxy servers)." Thus, not applicable. w.status = MethodNotAllowed; return }, (_, &Authority(_)) => { // "The authority form is only used by the CONNECT method." Thus, not applicable. w.status = BadRequest; return }, (&Options, &Star) => { // Querying server capabilities. That's nice and simple. I can handle these methods: // (TODO: let user code override this, providing a default method.) w.headers.allow = Some(vec!(Get, Head, Post, Put, Delete, Trace, Options, Connect, Patch)); w.headers.content_length = Some(0); return; }, (&Options, &AbsoluteUri(_)) | (&Options, &AbsolutePath(_)) => { }, (_, &AbsoluteUri(_)) | (_, &AbsolutePath(_)) => { }, (_, &Star) => { }, } w.headers.content_type = Some(MediaType { type_: String::from_str("text"), subtype: String::from_str("html"), parameters: Vec::new() }); w.write(b"