1 2 3 4 5 6 7 8 9 10 11 12 13 14 15 16 17 18 19 20 21 22 23 24 25 26 27 28 29 30 31 32 33 34 35 36 37 38 39 40 41 42 43 44 45 46 47 48 49 50 51 52 53 54 55 56 57 58 59 60 61 62 63 64 65 66 67 68 69 70 71 72 73 74 75 76 77 78 79 80 81 82 83 84 85 86 87 88 89 90 91 92 93 94 95 96 97 98 99 100 101 102
#![crate_name = "hyper_staticfile"] #![deny(missing_docs)] #![deny(warnings)] //! Static file-serving for [Hyper 0.12](https://github.com/hyperium/hyper). //! //! This library exports a high-level interface `Static` for simple file-serving, and lower-level //! interfaces for more control over responses. //! //! ## Basic usage //! //! The `Static` type is essentially a struct containing some settings, and a `serve` method to //! handle the request. It follows the builder pattern, and also implements the `hyper::Service` //! trait. It can be used as: //! //! ```rust //! extern crate http; //! extern crate hyper_staticfile; //! //! // Instance of `Static`. Can be reused for multiple requests. //! let static_ = hyper_staticfile::Static::new("my/doc/root/"); //! //! // A dummy request, but normally obtained from Hyper. //! let request = http::Request::get("/foo/bar.txt") //! .body(()) //! .unwrap(); //! //! // Serve the request. Returns a `StaticFuture` for a response. //! let response_future = static_.serve(request); //! ``` //! //! Typically, you'd store the `Static` instance somewhere, such as in your own `hyper::Service` //! implementation. //! //! ## Advanced usage //! //! The `Static` type is a simple wrapper for `resolve` and `ResponseBuilder`. You can achieve the //! same by doing something similar to the following: //! //! ```rust //! extern crate futures; //! extern crate http; //! extern crate hyper_staticfile; //! //! use futures::future::Future; //! use std::path::Path; //! //! // Document root path. //! let root = Path::new("my/doc/root/"); //! //! // A dummy request, but normally obtained from Hyper. //! let request = http::Request::get("/foo/bar.txt") //! .body(()) //! .unwrap(); //! //! // First, resolve the request. Returns a `ResolveFuture` for a `ResolveResult`. //! let resolve_future = hyper_staticfile::resolve(&root, &request); //! //! // Then, build a response based on the result. //! // The `ResponseBuilder` is typically a short-lived, per-request instance. //! let response_future = resolve_future.map(move |result| { //! hyper_staticfile::ResponseBuilder::new() //! .build(&request, result) //! .unwrap() //! }); //! ``` //! //! The `resolve` function tries to find the file in the root, and returns a `ResolveFuture` for //! the `ResolveResult` enum, which determines what kind of response should be sent. The //! `ResponseBuilder` is then used to create a default response. It holds some settings, and can be //! constructed using the builder pattern. //! //! It's useful to sit between these two steps to implement custom 404 pages, for example. Your //! custom logic can override specific cases of `ResolveResult`, and fall back to the default //! behavior using `ResponseBuilder` if necessary. //! //! The `ResponseBuilder` in turn uses `FileResponseBuilder` to serve files that are found. The //! `FileResponseBuilder` can also be used directly if you have an existing open `tokio::fs::File` //! and want to serve it. It takes care of basic headers, 'not modified' responses, and streaming //! the file in the body. //! //! Finally, there's `FileChunkStream`, which is used by `FileResponseBuilder` to stream the file. //! This is a struct wrapping a `tokio::fs::File` and implementing a `futures::Stream` that //! produces `hyper::Chunk`s. It can be used for streaming a file in custom response. extern crate chrono; #[macro_use] extern crate futures; extern crate http; extern crate hyper; extern crate tokio; extern crate url; mod resolve; mod response_builder; mod service; mod util; pub use resolve::*; pub use response_builder::*; pub use service::*; pub use util::{FileChunkStream, FileResponseBuilder};