diff --git a/hello_server/404.html b/hello_server/404.html new file mode 100644 index 0000000..88d8e91 --- /dev/null +++ b/hello_server/404.html @@ -0,0 +1,11 @@ + + +
+ +Sorry, I don't know what you're asking for.
+ + diff --git a/hello_server/Cargo.toml b/hello_server/Cargo.toml new file mode 100644 index 0000000..d9fcb7f --- /dev/null +++ b/hello_server/Cargo.toml @@ -0,0 +1,9 @@ +[package] +name = "hello_server" +version = "0.1.0" +authors = ["Laurens MiersHi from Rust
+ + diff --git a/hello_server/src/bin/main.rs b/hello_server/src/bin/main.rs new file mode 100644 index 0000000..2dff088 --- /dev/null +++ b/hello_server/src/bin/main.rs @@ -0,0 +1,53 @@ +use std::fs; +use std::thread; +use std::time::Duration; + +use std::io::prelude::*; +use std::net::TcpListener; +use std::net::TcpStream; + +use hello_server::ThreadPool; + +fn main() { + let listener = TcpListener::bind("127.0.0.1:7878").unwrap(); + let pool = ThreadPool::new(4); + + for stream in listener.incoming() { + let stream = stream.unwrap(); + + pool.execute(|| { + handle_connection(stream); + }); + } + + println!("Shutting down."); +} + +fn handle_connection(mut stream: TcpStream) { + let mut buffer = [0; 1024]; + stream.read(&mut buffer).unwrap(); + + let get = b"GET / HTTP/1.1\r\n"; + let sleep = b"GET /sleep HTTP/1.1\r\n"; + + let (status_line, filename) = if buffer.starts_with(get) { + ("HTTP/1.1 200 OK", "hello.html") + } else if buffer.starts_with(sleep) { + thread::sleep(Duration::from_secs(5)); + ("HTTP/1.1 200 OK", "hello.html") + } else { + ("HTTP/1.1 404 NOT FOUND", "404.html") + }; + + let contents = fs::read_to_string(filename).unwrap(); + + let response = format!( + "{}\r\nContent-Length: {}\r\n\r\n{}", + status_line, + contents.len(), + contents + ); + + stream.write(response.as_bytes()).unwrap(); + stream.flush().unwrap(); +} diff --git a/hello_server/src/lib.rs b/hello_server/src/lib.rs new file mode 100644 index 0000000..706973c --- /dev/null +++ b/hello_server/src/lib.rs @@ -0,0 +1,101 @@ +use std::thread; +use std::sync::mpsc; +use std::sync::Arc; +use std::sync::Mutex; + +pub struct ThreadPool { + workers: Vec