Browse Source

feat: replace --static option to --no-edit

pull/8/head
sigoden 3 years ago
parent
commit
06ce7b0175
  1. 4
      README.md
  2. 79
      src/args.rs
  3. 7
      src/main.rs

4
README.md

@ -43,9 +43,9 @@ duf
duf folder_name duf folder_name
``` ```
Only serve static files, disable upload and delete operations Only serve static files, disable editing operations such as update or delete
``` ```
duf --static duf --no-edit
``` ```
Finally, run this command to see a list of all available option Finally, run this command to see a list of all available option

79
src/args.rs

@ -10,47 +10,43 @@ use crate::BoxResult;
const ABOUT: &str = concat!("\n", crate_description!()); // Add extra newline. const ABOUT: &str = concat!("\n", crate_description!()); // Add extra newline.
fn app() -> clap::Command<'static> { fn app() -> clap::Command<'static> {
let arg_port = Arg::new("port")
.short('p')
.long("port")
.default_value("5000")
.help("Specify port to listen on")
.value_name("port");
let arg_address = Arg::new("address")
.short('b')
.long("bind")
.default_value("127.0.0.1")
.help("Specify bind address")
.value_name("address");
let arg_path = Arg::new("path")
.default_value(".")
.allow_invalid_utf8(true)
.help("Path to a directory for serving files");
let arg_static = Arg::new("static")
.long("static")
.help("Only serve static files, disable upload and delete operations");
let arg_auth = Arg::new("auth")
.short('a')
.long("auth")
.help("Authenticate with user and pass")
.value_name("user:pass");
let arg_no_log = Arg::new("no-log")
.long("--no-log")
.help("Don't log any request/response information.");
clap::command!() clap::command!()
.about(ABOUT) .about(ABOUT)
.arg(arg_address) .arg(
.arg(arg_port) Arg::new("address")
.arg(arg_path) .short('b')
.arg(arg_static) .long("bind")
.arg(arg_auth) .default_value("127.0.0.1")
.arg(arg_no_log) .help("Specify bind address")
.value_name("address"),
)
.arg(
Arg::new("port")
.short('p')
.long("port")
.default_value("5000")
.help("Specify port to listen on")
.value_name("port"),
)
.arg(
Arg::new("path")
.default_value(".")
.allow_invalid_utf8(true)
.help("Path to a directory for serving files"),
)
.arg(
Arg::new("no-edit")
.short('E')
.long("no-edit")
.help("Disable editing operations such as update or delete"),
)
.arg(
Arg::new("auth")
.short('a')
.long("auth")
.help("Authenticate with user and pass")
.value_name("user:pass"),
)
} }
pub fn matches() -> ArgMatches { pub fn matches() -> ArgMatches {
@ -64,7 +60,6 @@ pub struct Args {
pub path: PathBuf, pub path: PathBuf,
pub readonly: bool, pub readonly: bool,
pub auth: Option<String>, pub auth: Option<String>,
pub log: bool,
} }
impl Args { impl Args {
@ -77,9 +72,8 @@ impl Args {
let port = matches.value_of_t::<u16>("port")?; let port = matches.value_of_t::<u16>("port")?;
let path = matches.value_of_os("path").unwrap_or_default(); let path = matches.value_of_os("path").unwrap_or_default();
let path = Args::parse_path(path)?; let path = Args::parse_path(path)?;
let readonly = matches.is_present("static"); let readonly = matches.is_present("no-edit");
let auth = matches.value_of("auth").map(|v| v.to_owned()); let auth = matches.value_of("auth").map(|v| v.to_owned());
let log = !matches.is_present("no-log");
Ok(Args { Ok(Args {
address, address,
@ -87,7 +81,6 @@ impl Args {
path, path,
readonly, readonly,
auth, auth,
log,
}) })
} }

7
src/main.rs

@ -28,13 +28,8 @@ async fn run() -> BoxResult<()> {
if std::env::var("RUST_LOG").is_ok() { if std::env::var("RUST_LOG").is_ok() {
simple_logger::init()?; simple_logger::init()?;
} else { } else {
let level = if args.log {
LevelFilter::Info
} else {
LevelFilter::Error
};
simple_logger::SimpleLogger::default() simple_logger::SimpleLogger::default()
.with_level(level) .with_level(LevelFilter::Info)
.init()?; .init()?;
} }
serve(args).await serve(args).await

Loading…
Cancel
Save