use std::env;
use std::process::exit;
use crate::squire::{constant, settings};
pub fn arguments(
metadata: &constant::MetaData
) -> settings::Config {
let args: Vec<String> = env::args().collect();
let mut version = false;
let mut bucket = String::new();
let mut website = String::new();
let mut region = String::new();
let mut filter = String::new();
let mut ignore = String::new();
let mut object = String::new();
let mut style = String::new();
let mut i = 1; while i < args.len() {
match args[i].as_str() {
"-h" | "--help" => {
let options: Vec<_> = [("--bucket | -b", "Bucket name for which listing has to be created"),
("--website | -w", "Website URL that has to be allowed through CORS configuration"),
("--region | -r", "Region name where the bucket is present"),
("--filter | -f", "S3 prefix to filter (eg: '[\"github/\"]')"),
("--ignore | -i", "Objects to be ignored (eg: '[\"github/.DS_Store\"]')"),
("--object | -o", "Object name to upload in s3 (eg: list.html)"),
("--style | -s", "Styling for the UI (eg: vanilla)"),
("--version | -v", "Get the package version.")].to_vec();
let longest_key = options.iter().map(|(k, _)| k.len()).max().unwrap_or(0);
let pretext = "\n* ";
let choices: String = options.iter().map(|(k, v)| {
format!("{}{} {}→ {}", pretext, k, "·".repeat(longest_key - k.len() + 8), v)
}).collect::<Vec<_>>().join("");
println!("Usage: {} [OPTIONS]\n\nlists3 takes the following arguments\n{}", args[0], choices);
exit(0)
}
"-V" | "-v" | "--version" => {
version = true;
}
"-b" | "--bucket" => {
i += 1; if i < args.len() {
bucket.clone_from(&args[i]);
} else {
eprintln!("--bucket requires a value.");
exit(1)
}
}
"-w" | "--website" => {
i += 1; if i < args.len() {
website.clone_from(&args[i]);
} else {
eprintln!("--bucket requires a value.");
exit(1)
}
}
"-r" | "--region" => {
i += 1; if i < args.len() {
region.clone_from(&args[i]);
} else {
eprintln!("--region requires a value.");
exit(1)
}
}
"-f" | "--filter" => {
i += 1; if i < args.len() {
filter.clone_from(&args[i]);
} else {
eprintln!("--filter requires a value.");
exit(1)
}
}
"-i" | "--ignore" => {
i += 1; if i < args.len() {
ignore.clone_from(&args[i]);
} else {
eprintln!("--ignore requires a value.");
exit(1)
}
}
"-o" | "--object" => {
i += 1; if i < args.len() {
object.clone_from(&args[i]);
} else {
eprintln!("--object requires a value.");
exit(1)
}
}
"-s" | "--style" => {
i += 1; if i < args.len() {
style.clone_from(&args[i]);
} else {
eprintln!("--style requires a value.");
exit(1)
}
}
_ => {
eprintln!("Unknown argument: {}", args[i]);
exit(1)
}
}
i += 1;
}
if version {
println!("{} {}", &metadata.pkg_name, &metadata.pkg_version);
exit(0)
}
if object.is_empty() {
object = "list".to_string()
}
if website.is_empty() {
website = format!("https://{}", bucket);
}
settings::parse_config(bucket, website, region, filter, ignore, object, style)
}