summaryrefslogtreecommitdiff
path: root/src/server
diff options
context:
space:
mode:
Diffstat (limited to 'src/server')
-rw-r--r--src/server/handler.rs14
-rw-r--r--src/server/mod.rs13
2 files changed, 21 insertions, 6 deletions
diff --git a/src/server/handler.rs b/src/server/handler.rs
index fb07a4d..ceb6551 100644
--- a/src/server/handler.rs
+++ b/src/server/handler.rs
@@ -1,7 +1,17 @@
-use url::Url;
use crate::server::response;
use crate::server::ServerConfig;
+use std::path::Path;
+use url::Url;
pub fn handle(config: &ServerConfig, url: Url) -> Option<response::Response> {
- Some(response::invalid_protocol())
+ if url.scheme() != "gemini" {
+ return Some(response::invalid_protocol());
+ }
+
+ let path = Path::new(url.path());
+ if !path.has_root() {
+ return Some(response::not_understood());
+ }
+
+ None
}
diff --git a/src/server/mod.rs b/src/server/mod.rs
index 5b7aedb..d7826f6 100644
--- a/src/server/mod.rs
+++ b/src/server/mod.rs
@@ -2,17 +2,19 @@ use crate::server::response::Response;
use openssl::ssl::{SslAcceptor, SslFiletype, SslMethod, SslStream};
use std::collections::HashMap;
use std::net::{SocketAddr, TcpListener, TcpStream};
+use std::path::{Path, PathBuf};
+use std::sync::Arc;
use std::thread;
use std::vec::Vec;
-use std::sync::Arc;
use url::Url;
-pub mod response;
pub mod handler;
+pub mod response;
#[derive(Clone)]
pub struct ServerConfig {
defaultHost: Url,
+ wwwRoot: PathBuf,
}
pub struct Server {
@@ -21,8 +23,11 @@ pub struct Server {
}
impl Server {
- pub fn new(host: &str) -> Server {
- let config = ServerConfig{defaultHost: Url::parse(host).unwrap()};
+ pub fn new(host: &str, wwwRoot: &Path) -> Server {
+ let config = ServerConfig {
+ defaultHost: Url::parse(host).unwrap(),
+ wwwRoot: PathBuf::from(wwwRoot),
+ };
Server {
acceptor: build_acceptor(),