summaryrefslogtreecommitdiff
path: root/src/main.rs
diff options
context:
space:
mode:
authorJan Wolff <janw@mailbox.org>2020-05-17 12:54:10 +0200
committerJan Wolff <janw@mailbox.org>2020-05-17 12:54:10 +0200
commit872197c55805161e1ed6bbbd13b169b3bc809fd5 (patch)
tree600914246f6de5e7ae2cee82f0009aec3b2c77ac /src/main.rs
parent4a9c6c11acf4128b2c5158307088b0cbc377c3e5 (diff)
mime type handling and setuid/setgid support
Diffstat (limited to 'src/main.rs')
-rw-r--r--src/main.rs17
1 files changed, 16 insertions, 1 deletions
diff --git a/src/main.rs b/src/main.rs
index a381e28..aa572bb 100644
--- a/src/main.rs
+++ b/src/main.rs
@@ -1,4 +1,5 @@
mod server;
+mod mime;
use std::env;
fn help() {
@@ -12,12 +13,16 @@ fn help() {
println!(" -l, --listen\t\tadd a listening address (you can define multiple)");
println!(" -d, --default-host\tdefault hostname to listen for");
println!(" -g, --gem-root\tpath to the gemini root, aka the folder to serve files from");
+ println!(" --user\tuser to drop to after opening TLS socket");
+ println!(" --group\tgroup to drop to after opening TLS socket");
}
fn parse_args() -> Option<server::ServerConfig> {
let mut has_addr = false;
let mut has_host = false;
let mut has_root = false;
+ let mut has_user = false;
+ let mut has_group = false;
let mut config = server::ServerConfig::new();
let mut args = env::args();
@@ -42,12 +47,22 @@ fn parse_args() -> Option<server::ServerConfig> {
config.set_gem_root(gem_root);
has_root = true;
}
+ if arg == "--user" {
+ let user = args.next().unwrap();
+ config.set_user(user);
+ has_user = true;
+ }
+ if arg == "--group" {
+ let group = args.next().unwrap();
+ config.set_group(group);
+ has_group = true;
+ }
}
None => break,
}
}
- if !has_addr || !has_host || !has_root {
+ if !has_addr || !has_host || !has_root || !has_user || !has_group {
return None;
}