# EzHttp Easy http server for small sites This library is under developement, so if you found any bugs, please write them to [Issues](https://github.com/MeexReay/ezhttp/issues) ## Setup ```toml ezhttp = "0.1.6" # stable ezhttp = { git = "https://github.com/MeexReay/ezhttp" } # unstable ``` Features: - http_rrs (adds handler_http_rrs) ## Examples Hello world example: ```rust use ezhttp::{Headers, HttpRequest, HttpResponse, HttpServer, HttpServerStarter}; use std::time::Duration; struct EzSite { index_page: String, } impl EzSite { fn new(index_page: &str) -> Self { EzSite { index_page: index_page.to_string(), } } } impl HttpServer for EzSite { async fn on_request(&mut self, req: &HttpRequest) -> Option { println!("{} > {} {}", req.addr, req.method, req.page); if req.page == "/" { Some(HttpResponse::from_string( Headers::from(vec![("Content-Type", "text/html")]), // response headers "200 OK", // response status code self.index_page.clone(), // response body )) } else { None // close connection } } async fn on_start(&mut self, host: &str) { println!("Http server started on {}", host); } async fn on_close(&mut self) { println!("Http server closed"); } } #[tokio::main] async fn main() { let site = EzSite::new("Hello World!"); let host = "localhost:8080"; HttpServerStarter::new(site, host) .timeout(Some(Duration::from_secs(5))) // read & write timeout .threads(5) // threadpool size .start_forever() .await .expect("http server error"); // ezhttp::start_server(site, host); } ``` [More examples](https://github.com/MeexReay/ezhttp/blob/main/examples) ### Contributing If you would like to contribute to the project, feel free to fork the repository and submit a pull request. ### License This project is licensed under the WTFPL License