agate

Simple gemini server for static files
git clone https://github.com/mbrubeck/agate.git
Log | Files | Refs | README

commit c12b2ab6567f92cd3e29d0a11fddbc68ee0d1a25
parent 29fddfe41ec2f10506b690a7778fdaf7f4acd5af
Author: Matt Brubeck <mbrubeck@limpet.net>
Date:   Sun, 28 Jun 2020 14:44:53 -0700

Factor out response code

Diffstat:
Msrc/main.rs | 23++++++++++++-----------
1 file changed, 12 insertions(+), 11 deletions(-)

diff --git a/src/main.rs b/src/main.rs @@ -54,12 +54,12 @@ async fn handle_request(stream: TcpStream) -> Result { Ok(url) => { eprintln!("Got request for {:?}", url); if let Err(e) = send_response(&url, &mut stream).await { - stream.write_all(b"51 Not found, sorry.\r\n").await?; + respond(&mut stream, "51", &["Not found, sorry."]).await?; return Err(e) } } Err(e) => { - stream.write_all(b"59 Invalid request.\r\n").await?; + respond(&mut stream, "59", &["Invalid request."]).await?; return Err(e) } } @@ -125,7 +125,8 @@ async fn send_response<W: Write + Unpin>(url: &Url, mut stream: W) -> Result { if url.as_str().ends_with('/') { path.push("index.gmi"); } else { - return redirect_slash(url, stream).await; + // Send a redirect when the URL for a directory has no trailing slash. + return respond(&mut stream, "31", &[url.as_str(), "/"]).await; } } @@ -136,9 +137,7 @@ async fn send_response<W: Write + Unpin>(url: &Url, mut stream: W) -> Result { stream.write_all(b"20 text/gemini\r\n").await?; } else { let mime = tree_magic_mini::from_filepath(&path).ok_or("Can't read file")?; - stream.write_all(b"20 ").await?; - stream.write_all(mime.as_bytes()).await?; - stream.write_all(b"\r\n").await?; + respond(&mut stream, "20", &[mime]).await?; } // Send body. @@ -146,10 +145,12 @@ async fn send_response<W: Write + Unpin>(url: &Url, mut stream: W) -> Result { Ok(()) } -/// Send a redirect when the URL for a directory is missing a trailing slash. -async fn redirect_slash<W: Write + Unpin>(url: &Url, mut stream: W) -> Result { - stream.write_all(b"31 ").await?; - stream.write_all(url.as_str().as_bytes()).await?; - stream.write_all(b"/\r\n").await?; +async fn respond<W: Write + Unpin>(mut stream: W, status: &str, meta: &[&str]) -> Result { + stream.write_all(status.as_bytes()).await?; + stream.write_all(b" ").await?; + for m in meta { + stream.write_all(m.as_bytes()).await?; + } + stream.write_all(b"\r\n").await?; Ok(()) }